xref: /petsc/src/dm/impls/network/networkcreate.c (revision 5c6496ba940341816c82c3b7fcda2e06e7ddfa20)
15f2c45f1SShri Abhyankar #define PETSCDM_DLL
2af0996ceSBarry Smith #include <petsc/private/dmnetworkimpl.h>    /*I   "petscdmnetwork.h"   I*/
395af8c53SHong Zhang #include <petsc/private/vecimpl.h>
45f2c45f1SShri Abhyankar 
54416b707SBarry Smith PetscErrorCode  DMSetFromOptions_Network(PetscOptionItems *PetscOptionsObject,DM dm)
65f2c45f1SShri Abhyankar {
75f2c45f1SShri Abhyankar   PetscErrorCode ierr;
85f2c45f1SShri Abhyankar 
95f2c45f1SShri Abhyankar   PetscFunctionBegin;
10064a246eSJacob Faibussowitsch   PetscValidHeaderSpecific(dm, DM_CLASSID, 2);
111a1499c8SBarry Smith   ierr = PetscOptionsHead(PetscOptionsObject,"DMNetwork Options");CHKERRQ(ierr);
125f2c45f1SShri Abhyankar   ierr = PetscOptionsTail();CHKERRQ(ierr);
135f2c45f1SShri Abhyankar   PetscFunctionReturn(0);
145f2c45f1SShri Abhyankar }
155f2c45f1SShri Abhyankar 
165f2c45f1SShri Abhyankar /* External function declarations here */
175f2c45f1SShri Abhyankar extern PetscErrorCode DMCreateMatrix_Network(DM, Mat*);
185f2c45f1SShri Abhyankar extern PetscErrorCode DMDestroy_Network(DM);
195f2c45f1SShri Abhyankar extern PetscErrorCode DMView_Network(DM, PetscViewer);
205f2c45f1SShri Abhyankar extern PetscErrorCode DMGlobalToLocalBegin_Network(DM, Vec, InsertMode, Vec);
215f2c45f1SShri Abhyankar extern PetscErrorCode DMGlobalToLocalEnd_Network(DM, Vec, InsertMode, Vec);
225f2c45f1SShri Abhyankar extern PetscErrorCode DMLocalToGlobalBegin_Network(DM, Vec, InsertMode, Vec);
235f2c45f1SShri Abhyankar extern PetscErrorCode DMLocalToGlobalEnd_Network(DM, Vec, InsertMode, Vec);
245f2c45f1SShri Abhyankar extern PetscErrorCode DMSetUp_Network(DM);
258415c774SShri Abhyankar extern PetscErrorCode DMClone_Network(DM, DM*);
265f2c45f1SShri Abhyankar 
27a81b7fe4SHong Zhang static PetscErrorCode VecArrayPrint_private(PetscViewer viewer,PetscInt n,const PetscScalar *xv)
28a81b7fe4SHong Zhang {
29a81b7fe4SHong Zhang   PetscErrorCode ierr;
30a81b7fe4SHong Zhang   PetscInt       i;
31a81b7fe4SHong Zhang 
32a81b7fe4SHong Zhang   PetscFunctionBegin;
33a81b7fe4SHong Zhang   for (i=0; i<n; i++) {
34a81b7fe4SHong Zhang #if defined(PETSC_USE_COMPLEX)
35a81b7fe4SHong Zhang     if (PetscImaginaryPart(xv[i]) > 0.0) {
36a81b7fe4SHong Zhang       ierr = PetscViewerASCIIPrintf(viewer,"    %g + %g i\n",(double)PetscRealPart(xv[i]),(double)PetscImaginaryPart(xv[i]));CHKERRQ(ierr);
37a81b7fe4SHong Zhang     } else if (PetscImaginaryPart(xv[i]) < 0.0) {
38a81b7fe4SHong Zhang       ierr = PetscViewerASCIIPrintf(viewer,"    %g - %g i\n",(double)PetscRealPart(xv[i]),-(double)PetscImaginaryPart(xv[i]));CHKERRQ(ierr);
39a81b7fe4SHong Zhang     } else {
40a81b7fe4SHong Zhang       ierr = PetscViewerASCIIPrintf(viewer,"    %g\n",(double)PetscRealPart(xv[i]));CHKERRQ(ierr);
41a81b7fe4SHong Zhang     }
42a81b7fe4SHong Zhang #else
43a81b7fe4SHong Zhang     ierr = PetscViewerASCIIPrintf(viewer,"    %g\n",(double)xv[i]);CHKERRQ(ierr);
44a81b7fe4SHong Zhang #endif
45a81b7fe4SHong Zhang   }
46a81b7fe4SHong Zhang   PetscFunctionReturn(0);
47a81b7fe4SHong Zhang }
48a81b7fe4SHong Zhang 
494dc485aaSHong Zhang static PetscErrorCode VecView_Network_Seq(DM networkdm,Vec X,PetscViewer viewer)
504dc485aaSHong Zhang {
514dc485aaSHong Zhang   PetscErrorCode    ierr;
527b6afd5bSHong Zhang   PetscInt          e,v,Start,End,offset,nvar,id;
534dc485aaSHong Zhang   const PetscScalar *xv;
544dc485aaSHong Zhang 
554dc485aaSHong Zhang   PetscFunctionBegin;
564dc485aaSHong Zhang   ierr = VecGetArrayRead(X,&xv);CHKERRQ(ierr);
574dc485aaSHong Zhang 
584dc485aaSHong Zhang   /* iterate over edges */
594dc485aaSHong Zhang   ierr = DMNetworkGetEdgeRange(networkdm,&Start,&End);CHKERRQ(ierr);
604dc485aaSHong Zhang   for (e=Start; e<End; e++) {
612bf73ac6SHong Zhang     ierr = DMNetworkGetComponent(networkdm,e,ALL_COMPONENTS,NULL,NULL,&nvar);CHKERRQ(ierr);
624dc485aaSHong Zhang     if (!nvar) continue;
63a81b7fe4SHong Zhang 
642bf73ac6SHong Zhang     ierr = DMNetworkGetLocalVecOffset(networkdm,e,ALL_COMPONENTS,&offset);CHKERRQ(ierr);
65e85e6aecSHong Zhang     ierr = DMNetworkGetGlobalEdgeIndex(networkdm,e,&id);CHKERRQ(ierr);
667b6afd5bSHong Zhang 
67*5c6496baSHong Zhang     ierr = PetscViewerASCIIPrintf(viewer,"  Edge %" PetscInt_FMT ":\n",id);CHKERRQ(ierr);
68a81b7fe4SHong Zhang     ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr);
694dc485aaSHong Zhang   }
704dc485aaSHong Zhang 
714dc485aaSHong Zhang   /* iterate over vertices */
724dc485aaSHong Zhang   ierr = DMNetworkGetVertexRange(networkdm,&Start,&End);CHKERRQ(ierr);
734dc485aaSHong Zhang   for (v=Start; v<End; v++) {
742bf73ac6SHong Zhang     ierr = DMNetworkGetComponent(networkdm,v,ALL_COMPONENTS,NULL,NULL,&nvar);CHKERRQ(ierr);
754dc485aaSHong Zhang     if (!nvar) continue;
76a81b7fe4SHong Zhang 
772bf73ac6SHong Zhang     ierr = DMNetworkGetLocalVecOffset(networkdm,v,ALL_COMPONENTS,&offset);CHKERRQ(ierr);
78e85e6aecSHong Zhang     ierr = DMNetworkGetGlobalVertexIndex(networkdm,v,&id);CHKERRQ(ierr);
7962aa33baSHong Zhang 
80*5c6496baSHong Zhang     ierr = PetscViewerASCIIPrintf(viewer,"  Vertex %" PetscInt_FMT ":\n",id);CHKERRQ(ierr);
81a81b7fe4SHong Zhang     ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr);
824dc485aaSHong Zhang   }
834dc485aaSHong Zhang   ierr = PetscViewerFlush(viewer);CHKERRQ(ierr);
844dc485aaSHong Zhang   ierr = VecRestoreArrayRead(X,&xv);CHKERRQ(ierr);
854dc485aaSHong Zhang   PetscFunctionReturn(0);
864dc485aaSHong Zhang }
874dc485aaSHong Zhang 
884062a5e5SHong Zhang static PetscErrorCode VecView_Network_MPI(DM networkdm,Vec X,PetscViewer viewer)
894062a5e5SHong Zhang {
904062a5e5SHong Zhang   PetscErrorCode    ierr;
91e8c2e809SHong Zhang   PetscInt          i,e,v,eStart,eEnd,vStart,vEnd,offset,nvar,len_loc,len,k;
924062a5e5SHong Zhang   const PetscScalar *xv;
934062a5e5SHong Zhang   MPI_Comm          comm;
944062a5e5SHong Zhang   PetscMPIInt       size,rank,tag = ((PetscObject)viewer)->tag;
954062a5e5SHong Zhang   Vec               localX;
964062a5e5SHong Zhang   PetscBool         ghostvtex;
974062a5e5SHong Zhang   PetscScalar       *values;
987b6afd5bSHong Zhang   PetscInt          j,ne,nv,id;
994062a5e5SHong Zhang   MPI_Status        status;
1004062a5e5SHong Zhang 
1014062a5e5SHong Zhang   PetscFunctionBegin;
1024062a5e5SHong Zhang   ierr = PetscObjectGetComm((PetscObject)networkdm,&comm);CHKERRQ(ierr);
103ffc4695bSBarry Smith   ierr = MPI_Comm_size(comm,&size);CHKERRMPI(ierr);
104ffc4695bSBarry Smith   ierr = MPI_Comm_rank(comm,&rank);CHKERRMPI(ierr);
1054062a5e5SHong Zhang 
1064062a5e5SHong Zhang   ierr = DMGetLocalVector(networkdm,&localX);CHKERRQ(ierr);
1074062a5e5SHong Zhang   ierr = DMGlobalToLocalBegin(networkdm,X,INSERT_VALUES,localX);CHKERRQ(ierr);
1084062a5e5SHong Zhang   ierr = DMGlobalToLocalEnd(networkdm,X,INSERT_VALUES,localX);CHKERRQ(ierr);
1094062a5e5SHong Zhang   ierr = VecGetArrayRead(localX,&xv);CHKERRQ(ierr);
1104062a5e5SHong Zhang 
1114062a5e5SHong Zhang   ierr = VecGetLocalSize(localX,&len_loc);CHKERRQ(ierr);
1124062a5e5SHong Zhang 
113e8c2e809SHong Zhang   ierr = DMNetworkGetEdgeRange(networkdm,&eStart,&eEnd);CHKERRQ(ierr);
1144062a5e5SHong Zhang   ierr = DMNetworkGetVertexRange(networkdm,&vStart,&vEnd);CHKERRQ(ierr);
115e8c2e809SHong Zhang   len_loc += 2*(1 + eEnd-eStart + vEnd-vStart);
1164062a5e5SHong Zhang 
117e85e6aecSHong Zhang   /* values = [nedges, nvertices; id, nvar, xedge; ...; id, nvars, xvertex;...], to be sent to proc[0] */
118ffc4695bSBarry Smith   ierr = MPI_Allreduce(&len_loc,&len,1,MPIU_INT,MPI_MAX,comm);CHKERRMPI(ierr);
1194062a5e5SHong Zhang   ierr = PetscCalloc1(len,&values);CHKERRQ(ierr);
1204062a5e5SHong Zhang 
121dd400576SPatrick Sanan   if (rank == 0) {
1224062a5e5SHong Zhang     ierr = PetscViewerASCIIPrintf(viewer,"Process [%d]\n",rank);CHKERRQ(ierr);
1234062a5e5SHong Zhang   }
1244062a5e5SHong Zhang 
1254062a5e5SHong Zhang   /* iterate over edges */
1264062a5e5SHong Zhang   k = 2;
127e8c2e809SHong Zhang   for (e=eStart; e<eEnd; e++) {
1282bf73ac6SHong Zhang     ierr = DMNetworkGetComponent(networkdm,e,ALL_COMPONENTS,NULL,NULL,&nvar);CHKERRQ(ierr);
1294062a5e5SHong Zhang     if (!nvar) continue;
1304062a5e5SHong Zhang 
1312bf73ac6SHong Zhang     ierr = DMNetworkGetLocalVecOffset(networkdm,e,ALL_COMPONENTS,&offset);CHKERRQ(ierr);
132e85e6aecSHong Zhang     ierr = DMNetworkGetGlobalEdgeIndex(networkdm,e,&id);CHKERRQ(ierr);
13362aa33baSHong Zhang 
134dd400576SPatrick Sanan     if (rank == 0) { /* print its own entries */
135*5c6496baSHong Zhang       ierr = PetscViewerASCIIPrintf(viewer,"  Edge %" PetscInt_FMT ":\n",id);CHKERRQ(ierr);
136a81b7fe4SHong Zhang       ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr);
137a81b7fe4SHong Zhang     } else {
1387b6afd5bSHong Zhang       values[0]  += 1; /* number of edges */
1397b6afd5bSHong Zhang       values[k++] = id;
1407b6afd5bSHong Zhang       values[k++] = nvar;
1417b6afd5bSHong Zhang       for (i=offset; i< offset+nvar; i++) values[k++] = xv[i];
1424062a5e5SHong Zhang     }
1434062a5e5SHong Zhang   }
1444062a5e5SHong Zhang 
1454062a5e5SHong Zhang   /* iterate over vertices */
1464062a5e5SHong Zhang   for (v=vStart; v<vEnd; v++) {
1474062a5e5SHong Zhang     ierr = DMNetworkIsGhostVertex(networkdm,v,&ghostvtex);CHKERRQ(ierr);
1484062a5e5SHong Zhang     if (ghostvtex) continue;
1492bf73ac6SHong Zhang     ierr = DMNetworkGetComponent(networkdm,v,ALL_COMPONENTS,NULL,NULL,&nvar);CHKERRQ(ierr);
1504062a5e5SHong Zhang     if (!nvar) continue;
1514062a5e5SHong Zhang 
1522bf73ac6SHong Zhang     ierr = DMNetworkGetLocalVecOffset(networkdm,v,ALL_COMPONENTS,&offset);CHKERRQ(ierr);
153e85e6aecSHong Zhang     ierr = DMNetworkGetGlobalVertexIndex(networkdm,v,&id);CHKERRQ(ierr);
1544062a5e5SHong Zhang 
155dd400576SPatrick Sanan     if (rank == 0) {
156*5c6496baSHong Zhang       ierr = PetscViewerASCIIPrintf(viewer,"  Vertex %" PetscInt_FMT ":\n",id);CHKERRQ(ierr);
157a81b7fe4SHong Zhang       ierr = VecArrayPrint_private(viewer,nvar,xv+offset);CHKERRQ(ierr);
1584062a5e5SHong Zhang     } else {
1597b6afd5bSHong Zhang       values[1]  += 1; /* number of vertices */
1607b6afd5bSHong Zhang       values[k++] = id;
1617b6afd5bSHong Zhang       values[k++] = nvar;
1627b6afd5bSHong Zhang       for (i=offset; i< offset+nvar; i++) values[k++] = xv[i];
1634062a5e5SHong Zhang     }
1644062a5e5SHong Zhang   }
1654062a5e5SHong Zhang 
166dd400576SPatrick Sanan   if (rank == 0) {
1674062a5e5SHong Zhang     /* proc[0] receives and prints messages */
1684062a5e5SHong Zhang     for (j=1; j<size; j++) {
1694062a5e5SHong Zhang       ierr = PetscViewerASCIIPrintf(viewer,"Process [%d]\n",j);CHKERRQ(ierr);
1704062a5e5SHong Zhang 
171ffc4695bSBarry Smith       ierr = MPI_Recv(values,(PetscMPIInt)len,MPIU_SCALAR,j,tag,comm,&status);CHKERRMPI(ierr);
1724062a5e5SHong Zhang 
173dde233f4SSatish Balay       ne = (PetscInt)PetscAbsScalar(values[0]);
174dde233f4SSatish Balay       nv = (PetscInt)PetscAbsScalar(values[1]);
1754062a5e5SHong Zhang 
1764062a5e5SHong Zhang       /* print received edges */
1774062a5e5SHong Zhang       k = 2;
1784062a5e5SHong Zhang       for (i=0; i<ne; i++) {
179dde233f4SSatish Balay         id   = (PetscInt)PetscAbsScalar(values[k++]);
180dde233f4SSatish Balay         nvar = (PetscInt)PetscAbsScalar(values[k++]);
181*5c6496baSHong Zhang         ierr = PetscViewerASCIIPrintf(viewer,"  Edge %" PetscInt_FMT ":\n",id);CHKERRQ(ierr);
182a81b7fe4SHong Zhang         ierr = VecArrayPrint_private(viewer,nvar,values+k);CHKERRQ(ierr);
183a81b7fe4SHong Zhang         k   += nvar;
1844062a5e5SHong Zhang       }
1854062a5e5SHong Zhang 
1864062a5e5SHong Zhang       /* print received vertices */
1874062a5e5SHong Zhang       for (i=0; i<nv; i++) {
188dde233f4SSatish Balay         id   = (PetscInt)PetscAbsScalar(values[k++]);
189dde233f4SSatish Balay         nvar = (PetscInt)PetscAbsScalar(values[k++]);
190*5c6496baSHong Zhang         ierr = PetscViewerASCIIPrintf(viewer,"  Vertex %" PetscInt_FMT ":\n",id);CHKERRQ(ierr);
191a81b7fe4SHong Zhang         ierr = VecArrayPrint_private(viewer,nvar,values+k);CHKERRQ(ierr);
192a81b7fe4SHong Zhang         k   += nvar;
1934062a5e5SHong Zhang       }
1944062a5e5SHong Zhang     }
1954062a5e5SHong Zhang   } else {
1964062a5e5SHong Zhang     /* sends values to proc[0] */
197ffc4695bSBarry Smith     ierr = MPI_Send((void*)values,k,MPIU_SCALAR,0,tag,comm);CHKERRMPI(ierr);
1984062a5e5SHong Zhang   }
1994062a5e5SHong Zhang 
2004062a5e5SHong Zhang   ierr = PetscFree(values);CHKERRQ(ierr);
2014062a5e5SHong Zhang   ierr = VecRestoreArrayRead(localX,&xv);CHKERRQ(ierr);
2024062a5e5SHong Zhang   ierr = DMRestoreLocalVector(networkdm,&localX);CHKERRQ(ierr);
2034062a5e5SHong Zhang   PetscFunctionReturn(0);
2044062a5e5SHong Zhang }
2054062a5e5SHong Zhang 
20695af8c53SHong Zhang PETSC_EXTERN PetscErrorCode VecView_MPI(Vec,PetscViewer);
207a6c4b7b7SHong Zhang 
2084dc485aaSHong Zhang PetscErrorCode VecView_Network(Vec v,PetscViewer viewer)
2094dc485aaSHong Zhang {
2104dc485aaSHong Zhang   DM             dm;
2114dc485aaSHong Zhang   PetscErrorCode ierr;
2124dc485aaSHong Zhang   PetscBool      isseq;
213a6c4b7b7SHong Zhang   PetscBool      iascii;
2144dc485aaSHong Zhang 
2154dc485aaSHong Zhang   PetscFunctionBegin;
2164dc485aaSHong Zhang   ierr = VecGetDM(v,&dm);CHKERRQ(ierr);
217*5c6496baSHong Zhang   PetscCheck(dm,PetscObjectComm((PetscObject)v),PETSC_ERR_ARG_WRONG,"Vector not generated from a DM");
218a6c4b7b7SHong Zhang   ierr = PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&iascii);CHKERRQ(ierr);
2194dc485aaSHong Zhang   ierr = PetscObjectTypeCompare((PetscObject)v,VECSEQ,&isseq);CHKERRQ(ierr);
220a6c4b7b7SHong Zhang 
221a6c4b7b7SHong Zhang   /* Use VecView_Network if the viewer is ASCII; use VecView_Seq/MPI for other viewer formats */
222a6c4b7b7SHong Zhang   if (iascii) {
2234dc485aaSHong Zhang     if (isseq) {
2244dc485aaSHong Zhang       ierr = VecView_Network_Seq(dm,v,viewer);CHKERRQ(ierr);
2254dc485aaSHong Zhang     } else {
2264062a5e5SHong Zhang       ierr = VecView_Network_MPI(dm,v,viewer);CHKERRQ(ierr);
2274dc485aaSHong Zhang     }
228a6c4b7b7SHong Zhang   } else {
229a6c4b7b7SHong Zhang     if (isseq) {
230a6c4b7b7SHong Zhang       ierr = VecView_Seq(v,viewer);CHKERRQ(ierr);
231a6c4b7b7SHong Zhang     } else {
232a6c4b7b7SHong Zhang       ierr = VecView_MPI(v,viewer);CHKERRQ(ierr);
233a6c4b7b7SHong Zhang     }
234a6c4b7b7SHong Zhang   }
2354dc485aaSHong Zhang   PetscFunctionReturn(0);
2364dc485aaSHong Zhang }
2375f2c45f1SShri Abhyankar 
2385f2c45f1SShri Abhyankar static PetscErrorCode DMCreateGlobalVector_Network(DM dm,Vec *vec)
2395f2c45f1SShri Abhyankar {
2405f2c45f1SShri Abhyankar   PetscErrorCode ierr;
2415f2c45f1SShri Abhyankar   DM_Network     *network = (DM_Network*) dm->data;
2425f2c45f1SShri Abhyankar 
2435f2c45f1SShri Abhyankar   PetscFunctionBegin;
2445f2c45f1SShri Abhyankar   ierr = DMCreateGlobalVector(network->plex,vec);CHKERRQ(ierr);
2454dc485aaSHong Zhang   ierr = VecSetOperation(*vec, VECOP_VIEW, (void (*)(void)) VecView_Network);CHKERRQ(ierr);
2465f2c45f1SShri Abhyankar   ierr = VecSetDM(*vec,dm);CHKERRQ(ierr);
2475f2c45f1SShri Abhyankar   PetscFunctionReturn(0);
2485f2c45f1SShri Abhyankar }
2495f2c45f1SShri Abhyankar 
2505f2c45f1SShri Abhyankar static PetscErrorCode DMCreateLocalVector_Network(DM dm,Vec *vec)
2515f2c45f1SShri Abhyankar {
2525f2c45f1SShri Abhyankar   PetscErrorCode ierr;
2535f2c45f1SShri Abhyankar   DM_Network     *network = (DM_Network*) dm->data;
2545f2c45f1SShri Abhyankar 
2555f2c45f1SShri Abhyankar   PetscFunctionBegin;
2565f2c45f1SShri Abhyankar   ierr = DMCreateLocalVector(network->plex,vec);CHKERRQ(ierr);
2575f2c45f1SShri Abhyankar   ierr = VecSetDM(*vec,dm);CHKERRQ(ierr);
2585f2c45f1SShri Abhyankar   PetscFunctionReturn(0);
2595f2c45f1SShri Abhyankar }
2605f2c45f1SShri Abhyankar 
2615f2c45f1SShri Abhyankar PetscErrorCode DMInitialize_Network(DM dm)
2625f2c45f1SShri Abhyankar {
263659a9eadSHong Zhang   PetscErrorCode ierr;
2645f2c45f1SShri Abhyankar 
2655f2c45f1SShri Abhyankar   PetscFunctionBegin;
2662e4cff2eSHong Zhang   ierr = DMSetDimension(dm,1);CHKERRQ(ierr);
267caf410d2SHong Zhang   dm->ops->view                            = DMView_Network;
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;
276ea78f98cSLisandro Dalcin   dm->ops->getcoloring                     = NULL;
2775f2c45f1SShri Abhyankar   dm->ops->creatematrix                    = DMCreateMatrix_Network;
278ea78f98cSLisandro Dalcin   dm->ops->createinterpolation             = NULL;
279ea78f98cSLisandro Dalcin   dm->ops->createinjection                 = NULL;
280ea78f98cSLisandro Dalcin   dm->ops->refine                          = NULL;
281ea78f98cSLisandro Dalcin   dm->ops->coarsen                         = NULL;
282ea78f98cSLisandro Dalcin   dm->ops->refinehierarchy                 = NULL;
283ea78f98cSLisandro Dalcin   dm->ops->coarsenhierarchy                = NULL;
2845f2c45f1SShri Abhyankar   dm->ops->globaltolocalbegin              = DMGlobalToLocalBegin_Network;
2855f2c45f1SShri Abhyankar   dm->ops->globaltolocalend                = DMGlobalToLocalEnd_Network;
2865f2c45f1SShri Abhyankar   dm->ops->localtoglobalbegin              = DMLocalToGlobalBegin_Network;
2875f2c45f1SShri Abhyankar   dm->ops->localtoglobalend                = DMLocalToGlobalEnd_Network;
2885f2c45f1SShri Abhyankar   dm->ops->destroy                         = DMDestroy_Network;
2895f2c45f1SShri Abhyankar   dm->ops->createsubdm                     = NULL;
2905f2c45f1SShri Abhyankar   dm->ops->locatepoints                    = NULL;
2915f2c45f1SShri Abhyankar   PetscFunctionReturn(0);
2925f2c45f1SShri Abhyankar }
2935f2c45f1SShri Abhyankar 
2948415c774SShri Abhyankar PetscErrorCode DMClone_Network(DM dm, DM *newdm)
2958415c774SShri Abhyankar {
2968415c774SShri Abhyankar   DM_Network     *network = (DM_Network *) dm->data;
2978415c774SShri Abhyankar   PetscErrorCode ierr;
2988415c774SShri Abhyankar 
2998415c774SShri Abhyankar   PetscFunctionBegin;
3008415c774SShri Abhyankar   network->refct++;
3018415c774SShri Abhyankar   (*newdm)->data = network;
3028415c774SShri Abhyankar   ierr = PetscObjectChangeTypeName((PetscObject) *newdm, DMNETWORK);CHKERRQ(ierr);
3038415c774SShri Abhyankar   ierr = DMInitialize_Network(*newdm);CHKERRQ(ierr);
3048415c774SShri Abhyankar   PetscFunctionReturn(0);
3058415c774SShri Abhyankar }
3068415c774SShri Abhyankar 
3075f2c45f1SShri Abhyankar /*MC
3085f2c45f1SShri Abhyankar   DMNETWORK = "network" - A DM object that encapsulates an unstructured network. The implementation is based on the DM object
3095f2c45f1SShri Abhyankar                           DMPlex that manages unstructured grids. Distributed networks use a non-overlapping partitioning of
3105f2c45f1SShri Abhyankar                           the edges. In the local representation, Vecs contain all unknowns in the interior and shared boundary.
3115f2c45f1SShri Abhyankar                           This is specified by a PetscSection object. Ownership in the global representation is determined by
3125f2c45f1SShri Abhyankar                           ownership of the underlying DMPlex points. This is specified by another PetscSection object.
3135f2c45f1SShri Abhyankar 
3145f2c45f1SShri Abhyankar   Level: intermediate
3155f2c45f1SShri Abhyankar 
3165f2c45f1SShri Abhyankar .seealso: DMType, DMNetworkCreate(), DMCreate(), DMSetType()
3175f2c45f1SShri Abhyankar M*/
3185f2c45f1SShri Abhyankar 
3195f2c45f1SShri Abhyankar PETSC_EXTERN PetscErrorCode DMCreate_Network(DM dm)
3205f2c45f1SShri Abhyankar {
3215f2c45f1SShri Abhyankar   DM_Network     *network;
3225f2c45f1SShri Abhyankar   PetscErrorCode ierr;
3235f2c45f1SShri Abhyankar 
3245f2c45f1SShri Abhyankar   PetscFunctionBegin;
3255f2c45f1SShri Abhyankar   PetscValidHeaderSpecific(dm, DM_CLASSID, 1);
3265f2c45f1SShri Abhyankar   ierr     = PetscNewLog(dm,&network);CHKERRQ(ierr);
3275f2c45f1SShri Abhyankar   dm->data = network;
3285f2c45f1SShri Abhyankar 
3295f2c45f1SShri Abhyankar   network->refct     = 1;
330e2aaf10cSShri Abhyankar   network->NVertices = 0;
331e2aaf10cSShri Abhyankar   network->NEdges    = 0;
332e2aaf10cSShri Abhyankar   network->nVertices = 0;
333e2aaf10cSShri Abhyankar   network->nEdges    = 0;
334e2aaf10cSShri Abhyankar   network->nsubnet   = 0;
3355f2c45f1SShri Abhyankar 
33654dfd506SHong Zhang   network->max_comps_registered = 20;
33754dfd506SHong Zhang   network->component            = NULL;
33854dfd506SHong Zhang   network->header               = NULL;
33954dfd506SHong Zhang   network->cvalue               = NULL;
34013c2a604SAdrian Maldonado 
3415f2c45f1SShri Abhyankar   ierr = DMInitialize_Network(dm);CHKERRQ(ierr);
3425f2c45f1SShri Abhyankar   PetscFunctionReturn(0);
3435f2c45f1SShri Abhyankar }
3445f2c45f1SShri Abhyankar 
3455f2c45f1SShri Abhyankar /*@
3465f2c45f1SShri Abhyankar   DMNetworkCreate - Creates a DMNetwork object, which encapsulates an unstructured network.
3475f2c45f1SShri Abhyankar 
348d083f849SBarry Smith   Collective
3495f2c45f1SShri Abhyankar 
3505f2c45f1SShri Abhyankar   Input Parameter:
3515f2c45f1SShri Abhyankar . comm - The communicator for the DMNetwork object
3525f2c45f1SShri Abhyankar 
3535f2c45f1SShri Abhyankar   Output Parameter:
3545f2c45f1SShri Abhyankar . network  - The DMNetwork object
3555f2c45f1SShri Abhyankar 
3565f2c45f1SShri Abhyankar   Level: beginner
3575f2c45f1SShri Abhyankar 
3585f2c45f1SShri Abhyankar @*/
3595f2c45f1SShri Abhyankar PetscErrorCode DMNetworkCreate(MPI_Comm comm, DM *network)
3605f2c45f1SShri Abhyankar {
3615f2c45f1SShri Abhyankar   PetscErrorCode ierr;
3625f2c45f1SShri Abhyankar 
3635f2c45f1SShri Abhyankar   PetscFunctionBegin;
3645f2c45f1SShri Abhyankar   PetscValidPointer(network,2);
3655f2c45f1SShri Abhyankar   ierr = DMCreate(comm, network);CHKERRQ(ierr);
3665f2c45f1SShri Abhyankar   ierr = DMSetType(*network, DMNETWORK);CHKERRQ(ierr);
3675f2c45f1SShri Abhyankar   PetscFunctionReturn(0);
3685f2c45f1SShri Abhyankar }
369