#if !defined(__PETSCDMDA_H) #define __PETSCDMDA_H #include "petscdm.h" #include "petscpf.h" #include "petscao.h" PETSC_EXTERN_CXX_BEGIN /*E DMDAStencilType - Determines if the stencil extends only along the coordinate directions, or also to the northeast, northwest etc Level: beginner .seealso: DMDACreate1d(), DMDACreate2d(), DMDACreate3d(), DMDACreate() E*/ typedef enum { DMDA_STENCIL_STAR,DMDA_STENCIL_BOX } DMDAStencilType; /*MC DMDA_STENCIL_STAR - "Star"-type stencil. In logical grid coordinates, only (i,j,k), (i+s,j,k), (i,j+s,k), (i,j,k+s) are in the stencil NOT, for example, (i+s,j+s,k) Level: beginner .seealso: DMDA_STENCIL_BOX, DMDAStencilType M*/ /*MC DMDA_STENCIL_BOX - "Box"-type stencil. In logical grid coordinates, any of (i,j,k), (i+s,j+r,k+t) may be in the stencil. Level: beginner .seealso: DMDA_STENCIL_STAR, DMDAStencilType M*/ /*E DMDABoundaryType - Describes the choice for fill of ghost cells on domain boundaries. Level: beginner A boundary may be of type DMDA_BOUNDARY_NONE (no ghost nodes), DMDA_BOUNDARY_GHOST (ghost nodes exist but aren't filled), DMDA_BOUNDARY_MIRROR (not yet implemented), or DMDA_BOUNDARY_PERIODIC (ghost nodes filled by the opposite edge of the domain). .seealso: DMDASetBoundaryType(), DMDACreate1d(), DMDACreate2d(), DMDACreate3d(), DMDACreate() E*/ typedef enum { DMDA_BOUNDARY_NONE, DMDA_BOUNDARY_GHOSTED, DMDA_BOUNDARY_MIRROR, DMDA_BOUNDARY_PERIODIC } DMDABoundaryType; extern const char *DMDABoundaryTypes[]; /*E DMDAInterpolationType - Defines the type of interpolation that will be returned by DMGetInterpolation. Level: beginner .seealso: DMDACreate1d(), DMDACreate2d(), DMDACreate3d(), DMGetInterpolation(), DMDASetInterpolationType(), DMDACreate() E*/ typedef enum { DMDA_Q0, DMDA_Q1 } DMDAInterpolationType; extern PetscErrorCode DMDASetInterpolationType(DM,DMDAInterpolationType); extern PetscErrorCode DMDAGetInterpolationType(DM,DMDAInterpolationType*); /*E DMDAElementType - Defines the type of elements that will be returned by DMDAGetElements() Level: beginner .seealso: DMDACreate1d(), DMDACreate2d(), DMDACreate3d(), DMGetInterpolation(), DMDASetInterpolationType(), DMDASetElementType(), DMDAGetElements(), DMDARestoreElements(), DMDACreate() E*/ typedef enum { DMDA_ELEMENT_P1, DMDA_ELEMENT_Q1 } DMDAElementType; extern PetscErrorCode DMDASetElementType(DM,DMDAElementType); extern PetscErrorCode DMDAGetElementType(DM,DMDAElementType*); extern PetscErrorCode DMDAGetElements(DM,PetscInt *,PetscInt *,const PetscInt*[]); extern PetscErrorCode DMDARestoreElements(DM,PetscInt *,PetscInt *,const PetscInt*[]); typedef enum { DMDA_X,DMDA_Y,DMDA_Z } DMDADirection; #define MATSEQUSFFT "sequsfft" extern PetscErrorCode DMDACreate(MPI_Comm,DM*); extern PetscErrorCode DMDASetDim(DM,PetscInt); extern PetscErrorCode DMDASetSizes(DM,PetscInt,PetscInt,PetscInt); extern PetscErrorCode DMDACreate1d(MPI_Comm,DMDABoundaryType,PetscInt,PetscInt,PetscInt,const PetscInt[],DM *); extern PetscErrorCode DMDACreate2d(MPI_Comm,DMDABoundaryType,DMDABoundaryType,DMDAStencilType,PetscInt,PetscInt,PetscInt,PetscInt,PetscInt,PetscInt,const PetscInt[],const PetscInt[],DM*); extern PetscErrorCode DMDACreate3d(MPI_Comm,DMDABoundaryType,DMDABoundaryType,DMDABoundaryType,DMDAStencilType,PetscInt,PetscInt,PetscInt,PetscInt,PetscInt,PetscInt,PetscInt,PetscInt,const PetscInt[],const PetscInt[],const PetscInt[],DM*); extern PetscErrorCode DMDAGlobalToNaturalBegin(DM,Vec,InsertMode,Vec); extern PetscErrorCode DMDAGlobalToNaturalEnd(DM,Vec,InsertMode,Vec); extern PetscErrorCode DMDANaturalToGlobalBegin(DM,Vec,InsertMode,Vec); extern PetscErrorCode DMDANaturalToGlobalEnd(DM,Vec,InsertMode,Vec); extern PetscErrorCode DMDALocalToLocalBegin(DM,Vec,InsertMode,Vec); extern PetscErrorCode DMDALocalToLocalEnd(DM,Vec,InsertMode,Vec); extern PetscErrorCode DMDACreateNaturalVector(DM,Vec *); extern PetscErrorCode DMDAGetCorners(DM,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*); extern PetscErrorCode DMDAGetGhostCorners(DM,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*); extern PetscErrorCode DMDAGetInfo(DM,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*,PetscInt*,DMDABoundaryType*,DMDABoundaryType*,DMDABoundaryType*,DMDAStencilType*); extern PetscErrorCode DMDAGetProcessorSubset(DM,DMDADirection,PetscInt,MPI_Comm*); extern PetscErrorCode DMDAGetProcessorSubsets(DM,DMDADirection,MPI_Comm*); extern PetscErrorCode DMDAGlobalToNaturalAllCreate(DM,VecScatter*); extern PetscErrorCode DMDANaturalAllToGlobalCreate(DM,VecScatter*); extern PetscErrorCode DMDAGetGlobalIndices(DM,PetscInt*,PetscInt**); extern PetscErrorCode DMDAGetScatter(DM,VecScatter*,VecScatter*,VecScatter*); extern PetscErrorCode DMDAGetNeighbors(DM,const PetscMPIInt**); extern PetscErrorCode DMDAGetAO(DM,AO*); extern PetscErrorCode DMDASetCoordinates(DM,Vec); extern PetscErrorCode DMDASetGhostedCoordinates(DM,Vec); extern PetscErrorCode DMDAGetCoordinates(DM,Vec *); extern PetscErrorCode DMDAGetGhostedCoordinates(DM,Vec *); extern PetscErrorCode DMDAGetCoordinateDA(DM,DM *); extern PetscErrorCode DMDASetUniformCoordinates(DM,PetscReal,PetscReal,PetscReal,PetscReal,PetscReal,PetscReal); extern PetscErrorCode DMDAGetBoundingBox(DM,PetscReal[],PetscReal[]); extern PetscErrorCode DMDAGetLocalBoundingBox(DM,PetscReal[],PetscReal[]); /* function to wrap coordinates around boundary */ extern PetscErrorCode DMDAMapCoordsToPeriodicDomain(DM,PetscScalar*,PetscScalar*); extern PetscErrorCode DMDAGetReducedDA(DM,PetscInt,DM*); extern PetscErrorCode DMDASetFieldName(DM,PetscInt,const char[]); extern PetscErrorCode DMDAGetFieldName(DM,PetscInt,const char**); extern PetscErrorCode DMDASetBoundaryType(DM,DMDABoundaryType,DMDABoundaryType,DMDABoundaryType); extern PetscErrorCode DMDASetDof(DM, PetscInt); extern PetscErrorCode DMDASetStencilWidth(DM, PetscInt); extern PetscErrorCode DMDASetOwnershipRanges(DM,const PetscInt[],const PetscInt[],const PetscInt[]); extern PetscErrorCode DMDAGetOwnershipRanges(DM,const PetscInt**,const PetscInt**,const PetscInt**); extern PetscErrorCode DMDASetNumProcs(DM, PetscInt, PetscInt, PetscInt); extern PetscErrorCode DMDASetStencilType(DM, DMDAStencilType); extern PetscErrorCode DMDAVecGetArray(DM,Vec,void *); extern PetscErrorCode DMDAVecRestoreArray(DM,Vec,void *); extern PetscErrorCode DMDAVecGetArrayDOF(DM,Vec,void *); extern PetscErrorCode DMDAVecRestoreArrayDOF(DM,Vec,void *); extern PetscErrorCode DMDASplitComm2d(MPI_Comm,PetscInt,PetscInt,PetscInt,MPI_Comm*); /*S DMDALocalInfo - C struct that contains information about a structured grid and a processors logical location in it. Level: beginner Concepts: distributed array Developer note: Then entries in this struct are int instead of PetscInt so that the elements may be extracted in Fortran as if from an integer array .seealso: DMDACreate1d(), DMDACreate2d(), DMDACreate3d(), DMDestroy(), DM, DMDAGetLocalInfo(), DMDAGetInfo() S*/ typedef struct { PetscInt dim,dof,sw; PetscInt mx,my,mz; /* global number of grid points in each direction */ PetscInt xs,ys,zs; /* starting point of this processor, excluding ghosts */ PetscInt xm,ym,zm; /* number of grid points on this processor, excluding ghosts */ PetscInt gxs,gys,gzs; /* starting point of this processor including ghosts */ PetscInt gxm,gym,gzm; /* number of grid points on this processor including ghosts */ DMDABoundaryType bx,by,bz; /* type of ghost nodes at boundary */ DMDAStencilType st; DM da; } DMDALocalInfo; /*MC DMDAForEachPointBegin2d - Starts a loop over the local part of a two dimensional DMDA Synopsis: void DMDAForEachPointBegin2d(DALocalInfo *info,PetscInt i,PetscInt j); Not Collective Level: intermediate .seealso: DMDAForEachPointEnd2d(), DMDAVecGetArray() M*/ #define DMDAForEachPointBegin2d(info,i,j) {\ PetscInt _xints = info->xs,_xinte = info->xs+info->xm,_yints = info->ys,_yinte = info->ys+info->ym;\ for (j=_yints; j<_yinte; j++) {\ for (i=_xints; i<_xinte; i++) {\ /*MC DMDAForEachPointEnd2d - Ends a loop over the local part of a two dimensional DMDA Synopsis: void DMDAForEachPointEnd2d; Not Collective Level: intermediate .seealso: DMDAForEachPointBegin2d(), DMDAVecGetArray() M*/ #define DMDAForEachPointEnd2d }}} /*MC DMDACoor2d - Structure for holding 2d (x and y) coordinates. Level: intermediate Sample Usage: DMDACoor2d **coors; Vec vcoors; DM cda; DMDAGetCoordinates(da,&vcoors); DMDAGetCoordinateDA(da,&cda); DMDAVecGetArray(cda,vcoors,&coors); DMDAGetCorners(cda,&mstart,&nstart,0,&m,&n,0) for (i=mstart; i