15f2c45f1SShri Abhyankar #define PETSCDM_DLL 2af0996ceSBarry Smith #include <petsc/private/dmnetworkimpl.h> /*I "petscdmnetwork.h" I*/ 35f2c45f1SShri Abhyankar #include <petscdmda.h> 495af8c53SHong Zhang #include <petsc/private/vecimpl.h> 55f2c45f1SShri Abhyankar 64416b707SBarry Smith PetscErrorCode DMSetFromOptions_Network(PetscOptionItems *PetscOptionsObject,DM dm) 75f2c45f1SShri Abhyankar { 85f2c45f1SShri Abhyankar PetscErrorCode ierr; 95f2c45f1SShri Abhyankar 105f2c45f1SShri Abhyankar PetscFunctionBegin; 115f2c45f1SShri Abhyankar PetscValidHeaderSpecific(dm, DM_CLASSID, 1); 121a1499c8SBarry Smith ierr = PetscOptionsHead(PetscOptionsObject,"DMNetwork Options");CHKERRQ(ierr); 135f2c45f1SShri Abhyankar ierr = PetscOptionsTail();CHKERRQ(ierr); 145f2c45f1SShri Abhyankar PetscFunctionReturn(0); 155f2c45f1SShri Abhyankar } 165f2c45f1SShri Abhyankar 175f2c45f1SShri Abhyankar /* External function declarations here */ 185f2c45f1SShri Abhyankar extern PetscErrorCode DMCreateMatrix_Network(DM, Mat*); 195f2c45f1SShri Abhyankar extern PetscErrorCode DMDestroy_Network(DM); 205f2c45f1SShri Abhyankar extern PetscErrorCode DMView_Network(DM, PetscViewer); 215f2c45f1SShri Abhyankar extern PetscErrorCode DMGlobalToLocalBegin_Network(DM, Vec, InsertMode, Vec); 225f2c45f1SShri Abhyankar extern PetscErrorCode DMGlobalToLocalEnd_Network(DM, Vec, InsertMode, Vec); 235f2c45f1SShri Abhyankar extern PetscErrorCode DMLocalToGlobalBegin_Network(DM, Vec, InsertMode, Vec); 245f2c45f1SShri Abhyankar extern PetscErrorCode DMLocalToGlobalEnd_Network(DM, Vec, InsertMode, Vec); 255f2c45f1SShri Abhyankar extern PetscErrorCode DMSetUp_Network(DM); 268415c774SShri Abhyankar extern PetscErrorCode DMClone_Network(DM, DM*); 275f2c45f1SShri Abhyankar 28a81b7fe4SHong Zhang static PetscErrorCode VecArrayPrint_private(PetscViewer viewer,PetscInt n,const PetscScalar *xv) 29a81b7fe4SHong Zhang { 30a81b7fe4SHong Zhang PetscErrorCode ierr; 31a81b7fe4SHong Zhang PetscInt i; 32a81b7fe4SHong Zhang 33a81b7fe4SHong Zhang PetscFunctionBegin; 34a81b7fe4SHong Zhang for (i=0; i<n; i++) { 35a81b7fe4SHong Zhang #if defined(PETSC_USE_COMPLEX) 36a81b7fe4SHong Zhang if (PetscImaginaryPart(xv[i]) > 0.0) { 37a81b7fe4SHong Zhang ierr = PetscViewerASCIIPrintf(viewer," %g + %g i\n",(double)PetscRealPart(xv[i]),(double)PetscImaginaryPart(xv[i]));CHKERRQ(ierr); 38a81b7fe4SHong Zhang } else if (PetscImaginaryPart(xv[i]) < 0.0) { 39a81b7fe4SHong Zhang ierr = PetscViewerASCIIPrintf(viewer," %g - %g i\n",(double)PetscRealPart(xv[i]),-(double)PetscImaginaryPart(xv[i]));CHKERRQ(ierr); 40a81b7fe4SHong Zhang } else { 41a81b7fe4SHong Zhang ierr = PetscViewerASCIIPrintf(viewer," %g\n",(double)PetscRealPart(xv[i]));CHKERRQ(ierr); 42a81b7fe4SHong Zhang } 43a81b7fe4SHong Zhang #else 44a81b7fe4SHong Zhang ierr = PetscViewerASCIIPrintf(viewer," %g\n",(double)xv[i]);CHKERRQ(ierr); 45a81b7fe4SHong Zhang #endif 46a81b7fe4SHong Zhang } 47a81b7fe4SHong Zhang PetscFunctionReturn(0); 48a81b7fe4SHong Zhang } 49a81b7fe4SHong Zhang 504dc485aaSHong Zhang static PetscErrorCode VecView_Network_Seq(DM networkdm,Vec X,PetscViewer viewer) 514dc485aaSHong Zhang { 524dc485aaSHong Zhang PetscErrorCode ierr; 537b6afd5bSHong Zhang PetscInt e,v,Start,End,offset,nvar,id; 544dc485aaSHong Zhang const PetscScalar *xv; 554dc485aaSHong Zhang 564dc485aaSHong Zhang PetscFunctionBegin; 574dc485aaSHong Zhang ierr = VecGetArrayRead(X,&xv);CHKERRQ(ierr); 584dc485aaSHong Zhang 594dc485aaSHong Zhang /* iterate over edges */ 604dc485aaSHong Zhang ierr = DMNetworkGetEdgeRange(networkdm,&Start,&End);CHKERRQ(ierr); 614dc485aaSHong Zhang for (e=Start; e<End; e++) { 624dc485aaSHong Zhang ierr = DMNetworkGetNumVariables(networkdm,e,&nvar);CHKERRQ(ierr); 634dc485aaSHong Zhang if (!nvar) continue; 64a81b7fe4SHong Zhang 657b6afd5bSHong Zhang ierr = DMNetworkGetVariableOffset(networkdm,e,&offset);CHKERRQ(ierr); 66e85e6aecSHong Zhang ierr = DMNetworkGetGlobalEdgeIndex(networkdm,e,&id);CHKERRQ(ierr); 677b6afd5bSHong Zhang 687b6afd5bSHong Zhang ierr = PetscViewerASCIIPrintf(viewer," Edge %D:\n",id);CHKERRQ(ierr); 69a81b7fe4SHong Zhang ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr); 704dc485aaSHong Zhang } 714dc485aaSHong Zhang 724dc485aaSHong Zhang /* iterate over vertices */ 734dc485aaSHong Zhang ierr = DMNetworkGetVertexRange(networkdm,&Start,&End);CHKERRQ(ierr); 744dc485aaSHong Zhang for (v=Start; v<End; v++) { 754dc485aaSHong Zhang ierr = DMNetworkGetNumVariables(networkdm,v,&nvar);CHKERRQ(ierr); 764dc485aaSHong Zhang if (!nvar) continue; 77a81b7fe4SHong Zhang 787b6afd5bSHong Zhang ierr = DMNetworkGetVariableOffset(networkdm,v,&offset);CHKERRQ(ierr); 79e85e6aecSHong Zhang ierr = DMNetworkGetGlobalVertexIndex(networkdm,v,&id);CHKERRQ(ierr); 8062aa33baSHong Zhang 817b6afd5bSHong Zhang ierr = PetscViewerASCIIPrintf(viewer," Vertex %D:\n",id);CHKERRQ(ierr); 82a81b7fe4SHong Zhang ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr); 834dc485aaSHong Zhang } 844dc485aaSHong Zhang ierr = PetscViewerFlush(viewer);CHKERRQ(ierr); 854dc485aaSHong Zhang ierr = VecRestoreArrayRead(X,&xv);CHKERRQ(ierr); 864dc485aaSHong Zhang PetscFunctionReturn(0); 874dc485aaSHong Zhang } 884dc485aaSHong Zhang 894062a5e5SHong Zhang static PetscErrorCode VecView_Network_MPI(DM networkdm,Vec X,PetscViewer viewer) 904062a5e5SHong Zhang { 914062a5e5SHong Zhang PetscErrorCode ierr; 92e8c2e809SHong Zhang PetscInt i,e,v,eStart,eEnd,vStart,vEnd,offset,nvar,len_loc,len,k; 934062a5e5SHong Zhang const PetscScalar *xv; 944062a5e5SHong Zhang MPI_Comm comm; 954062a5e5SHong Zhang PetscMPIInt size,rank,tag = ((PetscObject)viewer)->tag; 964062a5e5SHong Zhang Vec localX; 974062a5e5SHong Zhang PetscBool ghostvtex; 984062a5e5SHong Zhang PetscScalar *values; 997b6afd5bSHong Zhang PetscInt j,ne,nv,id; 1004062a5e5SHong Zhang MPI_Status status; 1014062a5e5SHong Zhang 1024062a5e5SHong Zhang PetscFunctionBegin; 1034062a5e5SHong Zhang ierr = PetscObjectGetComm((PetscObject)networkdm,&comm);CHKERRQ(ierr); 1044062a5e5SHong Zhang ierr = MPI_Comm_size(comm,&size);CHKERRQ(ierr); 1054062a5e5SHong Zhang ierr = MPI_Comm_rank(comm,&rank);CHKERRQ(ierr); 1064062a5e5SHong Zhang 1074062a5e5SHong Zhang ierr = DMGetLocalVector(networkdm,&localX);CHKERRQ(ierr); 1084062a5e5SHong Zhang ierr = DMGlobalToLocalBegin(networkdm,X,INSERT_VALUES,localX);CHKERRQ(ierr); 1094062a5e5SHong Zhang ierr = DMGlobalToLocalEnd(networkdm,X,INSERT_VALUES,localX);CHKERRQ(ierr); 1104062a5e5SHong Zhang ierr = VecGetArrayRead(localX,&xv);CHKERRQ(ierr); 1114062a5e5SHong Zhang 1124062a5e5SHong Zhang ierr = VecGetLocalSize(localX,&len_loc);CHKERRQ(ierr); 1134062a5e5SHong Zhang 114e8c2e809SHong Zhang ierr = DMNetworkGetEdgeRange(networkdm,&eStart,&eEnd);CHKERRQ(ierr); 1154062a5e5SHong Zhang ierr = DMNetworkGetVertexRange(networkdm,&vStart,&vEnd);CHKERRQ(ierr); 116e8c2e809SHong Zhang len_loc += 2*(1 + eEnd-eStart + vEnd-vStart); 1174062a5e5SHong Zhang 118e85e6aecSHong Zhang /* values = [nedges, nvertices; id, nvar, xedge; ...; id, nvars, xvertex;...], to be sent to proc[0] */ 1194062a5e5SHong Zhang ierr = MPI_Allreduce(&len_loc,&len,1,MPIU_INT,MPI_MAX,comm);CHKERRQ(ierr); 1204062a5e5SHong Zhang ierr = PetscCalloc1(len,&values);CHKERRQ(ierr); 1214062a5e5SHong Zhang 1224062a5e5SHong Zhang if (!rank) { 1234062a5e5SHong Zhang ierr = PetscViewerASCIIPrintf(viewer,"Process [%d]\n",rank);CHKERRQ(ierr); 1244062a5e5SHong Zhang } 1254062a5e5SHong Zhang 1264062a5e5SHong Zhang /* iterate over edges */ 1274062a5e5SHong Zhang k = 2; 128e8c2e809SHong Zhang for (e=eStart; e<eEnd; e++) { 1294062a5e5SHong Zhang ierr = DMNetworkGetNumVariables(networkdm,e,&nvar);CHKERRQ(ierr); 1304062a5e5SHong Zhang if (!nvar) continue; 1314062a5e5SHong Zhang 1327b6afd5bSHong Zhang ierr = DMNetworkGetVariableOffset(networkdm,e,&offset);CHKERRQ(ierr); 133e85e6aecSHong Zhang ierr = DMNetworkGetGlobalEdgeIndex(networkdm,e,&id);CHKERRQ(ierr); 13462aa33baSHong Zhang 1354062a5e5SHong Zhang if (!rank) { /* print its own entries */ 1367b6afd5bSHong Zhang ierr = PetscViewerASCIIPrintf(viewer," Edge %D:\n",id);CHKERRQ(ierr); 137a81b7fe4SHong Zhang ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr); 138a81b7fe4SHong Zhang } else { 1397b6afd5bSHong Zhang values[0] += 1; /* number of edges */ 1407b6afd5bSHong Zhang values[k++] = id; 1417b6afd5bSHong Zhang values[k++] = nvar; 1427b6afd5bSHong Zhang for (i=offset; i< offset+nvar; i++) values[k++] = xv[i]; 1434062a5e5SHong Zhang } 1444062a5e5SHong Zhang } 1454062a5e5SHong Zhang 1464062a5e5SHong Zhang /* iterate over vertices */ 1474062a5e5SHong Zhang for (v=vStart; v<vEnd; v++) { 1484062a5e5SHong Zhang ierr = DMNetworkIsGhostVertex(networkdm,v,&ghostvtex);CHKERRQ(ierr); 1494062a5e5SHong Zhang if (ghostvtex) continue; 1504062a5e5SHong Zhang ierr = DMNetworkGetNumVariables(networkdm,v,&nvar);CHKERRQ(ierr); 1514062a5e5SHong Zhang if (!nvar) continue; 1524062a5e5SHong Zhang 1537b6afd5bSHong Zhang ierr = DMNetworkGetVariableOffset(networkdm,v,&offset);CHKERRQ(ierr); 154e85e6aecSHong Zhang ierr = DMNetworkGetGlobalVertexIndex(networkdm,v,&id);CHKERRQ(ierr); 1554062a5e5SHong Zhang 1564062a5e5SHong Zhang if (!rank) { 1577b6afd5bSHong Zhang ierr = PetscViewerASCIIPrintf(viewer," Vertex %D:\n",id);CHKERRQ(ierr); 158a81b7fe4SHong Zhang ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr); 1594062a5e5SHong Zhang } else { 1607b6afd5bSHong Zhang values[1] += 1; /* number of vertices */ 1617b6afd5bSHong Zhang values[k++] = id; 1627b6afd5bSHong Zhang values[k++] = nvar; 1637b6afd5bSHong Zhang for (i=offset; i< offset+nvar; i++) values[k++] = xv[i]; 1644062a5e5SHong Zhang } 1654062a5e5SHong Zhang } 1664062a5e5SHong Zhang 1674062a5e5SHong Zhang if (!rank) { 1684062a5e5SHong Zhang /* proc[0] receives and prints messages */ 1694062a5e5SHong Zhang for (j=1; j<size; j++) { 1704062a5e5SHong Zhang ierr = PetscViewerASCIIPrintf(viewer,"Process [%d]\n",j);CHKERRQ(ierr); 1714062a5e5SHong Zhang 1724062a5e5SHong Zhang ierr = MPI_Recv(values,(PetscMPIInt)len,MPIU_SCALAR,j,tag,comm,&status);CHKERRQ(ierr); 1734062a5e5SHong Zhang 174dde233f4SSatish Balay ne = (PetscInt)PetscAbsScalar(values[0]); 175dde233f4SSatish Balay nv = (PetscInt)PetscAbsScalar(values[1]); 1764062a5e5SHong Zhang 1774062a5e5SHong Zhang /* print received edges */ 1784062a5e5SHong Zhang k = 2; 1794062a5e5SHong Zhang for (i=0; i<ne; i++) { 180dde233f4SSatish Balay id = (PetscInt)PetscAbsScalar(values[k++]); 181dde233f4SSatish Balay nvar = (PetscInt)PetscAbsScalar(values[k++]); 1827b6afd5bSHong Zhang ierr = PetscViewerASCIIPrintf(viewer," Edge %D:\n",id);CHKERRQ(ierr); 183a81b7fe4SHong Zhang ierr = VecArrayPrint_private(viewer,nvar,values+k);CHKERRQ(ierr); 184a81b7fe4SHong Zhang k += nvar; 1854062a5e5SHong Zhang } 1864062a5e5SHong Zhang 1874062a5e5SHong Zhang /* print received vertices */ 1884062a5e5SHong Zhang for (i=0; i<nv; i++) { 189dde233f4SSatish Balay id = (PetscInt)PetscAbsScalar(values[k++]); 190dde233f4SSatish Balay nvar = (PetscInt)PetscAbsScalar(values[k++]); 1917b6afd5bSHong Zhang ierr = PetscViewerASCIIPrintf(viewer," Vertex %D:\n",id);CHKERRQ(ierr); 192a81b7fe4SHong Zhang ierr = VecArrayPrint_private(viewer,nvar,values+k);CHKERRQ(ierr); 193a81b7fe4SHong Zhang k += nvar; 1944062a5e5SHong Zhang } 1954062a5e5SHong Zhang } 1964062a5e5SHong Zhang } else { 1974062a5e5SHong Zhang /* sends values to proc[0] */ 1984062a5e5SHong Zhang ierr = MPI_Send((void*)values,k,MPIU_SCALAR,0,tag,comm);CHKERRQ(ierr); 1994062a5e5SHong Zhang } 2004062a5e5SHong Zhang 2014062a5e5SHong Zhang ierr = PetscFree(values);CHKERRQ(ierr); 2024062a5e5SHong Zhang ierr = VecRestoreArrayRead(localX,&xv);CHKERRQ(ierr); 2034062a5e5SHong Zhang ierr = DMRestoreLocalVector(networkdm,&localX);CHKERRQ(ierr); 2044062a5e5SHong Zhang PetscFunctionReturn(0); 2054062a5e5SHong Zhang } 2064062a5e5SHong Zhang 20795af8c53SHong Zhang PETSC_EXTERN PetscErrorCode VecView_MPI(Vec,PetscViewer); 208a6c4b7b7SHong Zhang 2094dc485aaSHong Zhang PetscErrorCode VecView_Network(Vec v,PetscViewer viewer) 2104dc485aaSHong Zhang { 2114dc485aaSHong Zhang DM dm; 2124dc485aaSHong Zhang PetscErrorCode ierr; 2134dc485aaSHong Zhang PetscBool isseq; 214a6c4b7b7SHong Zhang PetscBool iascii; 2154dc485aaSHong Zhang 2164dc485aaSHong Zhang PetscFunctionBegin; 2174dc485aaSHong Zhang ierr = VecGetDM(v,&dm);CHKERRQ(ierr); 2184dc485aaSHong Zhang if (!dm) SETERRQ(PetscObjectComm((PetscObject)v),PETSC_ERR_ARG_WRONG,"Vector not generated from a DM"); 219a6c4b7b7SHong Zhang ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&iascii);CHKERRQ(ierr); 2204dc485aaSHong Zhang ierr = PetscObjectTypeCompare((PetscObject)v,VECSEQ,&isseq);CHKERRQ(ierr); 221a6c4b7b7SHong Zhang 222a6c4b7b7SHong Zhang /* Use VecView_Network if the viewer is ASCII; use VecView_Seq/MPI for other viewer formats */ 223a6c4b7b7SHong Zhang if (iascii) { 2244dc485aaSHong Zhang if (isseq) { 2254dc485aaSHong Zhang ierr = VecView_Network_Seq(dm,v,viewer);CHKERRQ(ierr); 2264dc485aaSHong Zhang } else { 2274062a5e5SHong Zhang ierr = VecView_Network_MPI(dm,v,viewer);CHKERRQ(ierr); 2284dc485aaSHong Zhang } 229a6c4b7b7SHong Zhang } else { 230a6c4b7b7SHong Zhang if (isseq) { 231a6c4b7b7SHong Zhang ierr = VecView_Seq(v,viewer);CHKERRQ(ierr); 232a6c4b7b7SHong Zhang } else { 233a6c4b7b7SHong Zhang ierr = VecView_MPI(v,viewer);CHKERRQ(ierr); 234a6c4b7b7SHong Zhang } 235a6c4b7b7SHong Zhang } 2364dc485aaSHong Zhang PetscFunctionReturn(0); 2374dc485aaSHong Zhang } 2385f2c45f1SShri Abhyankar 2395f2c45f1SShri Abhyankar static PetscErrorCode DMCreateGlobalVector_Network(DM dm,Vec *vec) 2405f2c45f1SShri Abhyankar { 2415f2c45f1SShri Abhyankar PetscErrorCode ierr; 2425f2c45f1SShri Abhyankar DM_Network *network = (DM_Network*) dm->data; 2435f2c45f1SShri Abhyankar 2445f2c45f1SShri Abhyankar PetscFunctionBegin; 2455f2c45f1SShri Abhyankar ierr = DMCreateGlobalVector(network->plex,vec);CHKERRQ(ierr); 2464dc485aaSHong Zhang ierr = VecSetOperation(*vec, VECOP_VIEW, (void (*)(void)) VecView_Network);CHKERRQ(ierr); 2475f2c45f1SShri Abhyankar ierr = VecSetDM(*vec,dm);CHKERRQ(ierr); 2485f2c45f1SShri Abhyankar PetscFunctionReturn(0); 2495f2c45f1SShri Abhyankar } 2505f2c45f1SShri Abhyankar 2515f2c45f1SShri Abhyankar static PetscErrorCode DMCreateLocalVector_Network(DM dm,Vec *vec) 2525f2c45f1SShri Abhyankar { 2535f2c45f1SShri Abhyankar PetscErrorCode ierr; 2545f2c45f1SShri Abhyankar DM_Network *network = (DM_Network*) dm->data; 2555f2c45f1SShri Abhyankar 2565f2c45f1SShri Abhyankar PetscFunctionBegin; 2575f2c45f1SShri Abhyankar ierr = DMCreateLocalVector(network->plex,vec);CHKERRQ(ierr); 2585f2c45f1SShri Abhyankar ierr = VecSetDM(*vec,dm);CHKERRQ(ierr); 2595f2c45f1SShri Abhyankar PetscFunctionReturn(0); 2605f2c45f1SShri Abhyankar } 2615f2c45f1SShri Abhyankar 2625f2c45f1SShri Abhyankar PetscErrorCode DMInitialize_Network(DM dm) 2635f2c45f1SShri Abhyankar { 2645f2c45f1SShri Abhyankar 2655f2c45f1SShri Abhyankar PetscFunctionBegin; 2665f2c45f1SShri Abhyankar 2675f2c45f1SShri Abhyankar dm->ops->view = NULL; 2685f2c45f1SShri Abhyankar dm->ops->setfromoptions = DMSetFromOptions_Network; 2698415c774SShri Abhyankar dm->ops->clone = DMClone_Network; 2705f2c45f1SShri Abhyankar dm->ops->setup = DMSetUp_Network; 2715f2c45f1SShri Abhyankar dm->ops->createglobalvector = DMCreateGlobalVector_Network; 2725f2c45f1SShri Abhyankar dm->ops->createlocalvector = DMCreateLocalVector_Network; 2735f2c45f1SShri Abhyankar dm->ops->getlocaltoglobalmapping = NULL; 2745f2c45f1SShri Abhyankar dm->ops->createfieldis = NULL; 2755f2c45f1SShri Abhyankar dm->ops->createcoordinatedm = NULL; 2765f2c45f1SShri Abhyankar dm->ops->getcoloring = 0; 2775f2c45f1SShri Abhyankar dm->ops->creatematrix = DMCreateMatrix_Network; 2785f2c45f1SShri Abhyankar dm->ops->createinterpolation = 0; 2795f2c45f1SShri Abhyankar dm->ops->getaggregates = 0; 2805f2c45f1SShri Abhyankar dm->ops->getinjection = 0; 2815f2c45f1SShri Abhyankar dm->ops->refine = 0; 2825f2c45f1SShri Abhyankar dm->ops->coarsen = 0; 2835f2c45f1SShri Abhyankar dm->ops->refinehierarchy = 0; 2845f2c45f1SShri Abhyankar dm->ops->coarsenhierarchy = 0; 2855f2c45f1SShri Abhyankar dm->ops->globaltolocalbegin = DMGlobalToLocalBegin_Network; 2865f2c45f1SShri Abhyankar dm->ops->globaltolocalend = DMGlobalToLocalEnd_Network; 2875f2c45f1SShri Abhyankar dm->ops->localtoglobalbegin = DMLocalToGlobalBegin_Network; 2885f2c45f1SShri Abhyankar dm->ops->localtoglobalend = DMLocalToGlobalEnd_Network; 2895f2c45f1SShri Abhyankar dm->ops->destroy = DMDestroy_Network; 2905f2c45f1SShri Abhyankar dm->ops->createsubdm = NULL; 2915f2c45f1SShri Abhyankar dm->ops->locatepoints = NULL; 2925f2c45f1SShri Abhyankar PetscFunctionReturn(0); 2935f2c45f1SShri Abhyankar } 2945f2c45f1SShri Abhyankar 2958415c774SShri Abhyankar PetscErrorCode DMClone_Network(DM dm, DM *newdm) 2968415c774SShri Abhyankar { 2978415c774SShri Abhyankar DM_Network *network = (DM_Network *) dm->data; 2988415c774SShri Abhyankar PetscErrorCode ierr; 2998415c774SShri Abhyankar 3008415c774SShri Abhyankar PetscFunctionBegin; 3018415c774SShri Abhyankar network->refct++; 3028415c774SShri Abhyankar (*newdm)->data = network; 3038415c774SShri Abhyankar ierr = PetscObjectChangeTypeName((PetscObject) *newdm, DMNETWORK);CHKERRQ(ierr); 3048415c774SShri Abhyankar ierr = DMInitialize_Network(*newdm);CHKERRQ(ierr); 3058415c774SShri Abhyankar PetscFunctionReturn(0); 3068415c774SShri Abhyankar } 3078415c774SShri Abhyankar 3085f2c45f1SShri Abhyankar /*MC 3095f2c45f1SShri Abhyankar DMNETWORK = "network" - A DM object that encapsulates an unstructured network. The implementation is based on the DM object 3105f2c45f1SShri Abhyankar DMPlex that manages unstructured grids. Distributed networks use a non-overlapping partitioning of 3115f2c45f1SShri Abhyankar the edges. In the local representation, Vecs contain all unknowns in the interior and shared boundary. 3125f2c45f1SShri Abhyankar This is specified by a PetscSection object. Ownership in the global representation is determined by 3135f2c45f1SShri Abhyankar ownership of the underlying DMPlex points. This is specified by another PetscSection object. 3145f2c45f1SShri Abhyankar 3155f2c45f1SShri Abhyankar Level: intermediate 3165f2c45f1SShri Abhyankar 3175f2c45f1SShri Abhyankar .seealso: DMType, DMNetworkCreate(), DMCreate(), DMSetType() 3185f2c45f1SShri Abhyankar M*/ 3195f2c45f1SShri Abhyankar 3205f2c45f1SShri Abhyankar PETSC_EXTERN PetscErrorCode DMCreate_Network(DM dm) 3215f2c45f1SShri Abhyankar { 3225f2c45f1SShri Abhyankar DM_Network *network; 3235f2c45f1SShri Abhyankar PetscErrorCode ierr; 3245f2c45f1SShri Abhyankar 3255f2c45f1SShri Abhyankar PetscFunctionBegin; 3265f2c45f1SShri Abhyankar PetscValidHeaderSpecific(dm, DM_CLASSID, 1); 3275f2c45f1SShri Abhyankar ierr = PetscNewLog(dm,&network);CHKERRQ(ierr); 3285f2c45f1SShri Abhyankar dm->data = network; 3295f2c45f1SShri Abhyankar 3305f2c45f1SShri Abhyankar network->refct = 1; 331*e2aaf10cSShri Abhyankar network->NVertices = 0; 332*e2aaf10cSShri Abhyankar network->NEdges = 0; 333*e2aaf10cSShri Abhyankar network->nVertices = 0; 334*e2aaf10cSShri Abhyankar network->nEdges = 0; 335*e2aaf10cSShri Abhyankar network->nsubnet = 0; 3365f2c45f1SShri Abhyankar 33713c2a604SAdrian Maldonado 3385f2c45f1SShri Abhyankar ierr = DMInitialize_Network(dm);CHKERRQ(ierr); 3395f2c45f1SShri Abhyankar PetscFunctionReturn(0); 3405f2c45f1SShri Abhyankar } 3415f2c45f1SShri Abhyankar 3425f2c45f1SShri Abhyankar /*@ 3435f2c45f1SShri Abhyankar DMNetworkCreate - Creates a DMNetwork object, which encapsulates an unstructured network. 3445f2c45f1SShri Abhyankar 3455f2c45f1SShri Abhyankar Collective on MPI_Comm 3465f2c45f1SShri Abhyankar 3475f2c45f1SShri Abhyankar Input Parameter: 3485f2c45f1SShri Abhyankar . comm - The communicator for the DMNetwork object 3495f2c45f1SShri Abhyankar 3505f2c45f1SShri Abhyankar Output Parameter: 3515f2c45f1SShri Abhyankar . network - The DMNetwork object 3525f2c45f1SShri Abhyankar 3535f2c45f1SShri Abhyankar Level: beginner 3545f2c45f1SShri Abhyankar 3555f2c45f1SShri Abhyankar .keywords: DMNetwork, create 3565f2c45f1SShri Abhyankar @*/ 3575f2c45f1SShri Abhyankar PetscErrorCode DMNetworkCreate(MPI_Comm comm, DM *network) 3585f2c45f1SShri Abhyankar { 3595f2c45f1SShri Abhyankar PetscErrorCode ierr; 3605f2c45f1SShri Abhyankar 3615f2c45f1SShri Abhyankar PetscFunctionBegin; 3625f2c45f1SShri Abhyankar PetscValidPointer(network,2); 3635f2c45f1SShri Abhyankar ierr = DMCreate(comm, network);CHKERRQ(ierr); 3645f2c45f1SShri Abhyankar ierr = DMSetType(*network, DMNETWORK);CHKERRQ(ierr); 3655f2c45f1SShri Abhyankar PetscFunctionReturn(0); 3665f2c45f1SShri Abhyankar } 367