Actual source code: petscdmplextypes.h

  1: #pragma once

  3: /* SUBMANSEC = DMPlex */

  5: /*E
  6:   DMPlexShape - The domain shape used for automatic mesh creation.

  8:   Values:
  9: + `DM_SHAPE_BOX`         - The tensor product of intervals in dimension d
 10: . `DM_SHAPE_BOX_SURFACE` - The surface of a box in dimension d+1
 11: . `DM_SHAPE_BALL`        - The d-dimensional ball
 12: . `DM_SHAPE_SPHERE`      - The surface of the (d+1)-dimensional ball
 13: . `DM_SHAPE_CYLINDER`    - The tensor product of the interval and disk
 14: . `DM_SHAPE_SCHWARZ_P`   - The Schwarz-P triply periodic minimal surface
 15: . `DM_SHAPE_GYROID`      - The Gyroid triply periodic minimal surface
 16: . `DM_SHAPE_DOUBLET`     - The mesh of two cells of a specified type
 17: . `DM_SHAPE_ANNULUS`     - The area between two concentric spheres in dimension d
 18: - `DM_SHAPE_HYPERCUBIC`  - The skeleton of the tensor product of the intervals

 20:   Level: beginner

 22: .seealso: [](ch_dmbase), `DMPLEX`, `DMPlexGetCellRefiner()`, `DMPlexSetCellRefiner()`, `DMRefine()`, `DMPolytopeType`, `DMPlexCoordMap`
 23: E*/
 24: typedef enum {
 25:   DM_SHAPE_BOX,
 26:   DM_SHAPE_BOX_SURFACE,
 27:   DM_SHAPE_BALL,
 28:   DM_SHAPE_SPHERE,
 29:   DM_SHAPE_CYLINDER,
 30:   DM_SHAPE_SCHWARZ_P,
 31:   DM_SHAPE_GYROID,
 32:   DM_SHAPE_DOUBLET,
 33:   DM_SHAPE_ANNULUS,
 34:   DM_SHAPE_HYPERCUBIC,
 35:   DM_SHAPE_ZBOX,
 36:   DM_SHAPE_UNKNOWN
 37: } DMPlexShape;
 38: PETSC_EXTERN const char *const DMPlexShapes[];

 40: /*E
 41:   DMPlexCoordMap - The coordinate mapping used for automatic mesh creation.

 43:   Values:
 44: + `DM_COORD_MAP_NONE`    - The identity map
 45: . `DM_COORD_MAP_SHEAR`   - The shear (additive) map along some dimension
 46: . `DM_COORD_MAP_FLARE`   - The flare (multiplicative) map along some dimension
 47: . `DM_COORD_MAP_ANNULUS` - The map from a rectangle to an annulus
 48: - `DM_COORD_MAP_SHELL`   - The map from a rectangular solid to an spherical shell

 50:   Level: beginner

 52: .seealso: [](ch_dmbase), `DMPLEX`, `DMPlexGetCellRefiner()`, `DMPlexSetCellRefiner()`, `DMRefine()`, `DMPolytopeType`, `DMPlexShape`
 53: E*/
 54: typedef enum {
 55:   DM_COORD_MAP_NONE,
 56:   DM_COORD_MAP_SHEAR,
 57:   DM_COORD_MAP_FLARE,
 58:   DM_COORD_MAP_ANNULUS,
 59:   DM_COORD_MAP_SHELL,
 60:   DM_COORD_MAP_UNKNOWN
 61: } DMPlexCoordMap;
 62: PETSC_EXTERN const char *const DMPlexCoordMaps[];

 64: /*E
 65:   DMPlexCSRAlgorithm - The algorithm for building the adjacency graph in CSR format, usually for a mesh partitioner

 67:   Values:
 68: + `DM_PLEX_CSR_MAT`     - Use `MatPartitioning` by first making a matrix
 69: . `DM_PLEX_CSR_GRAPH`   - Use the original `DMPLEX` and communicate along the boundary
 70: - `DM_PLEX_CSR_OVERLAP` - Build an overlapped `DMPLEX` and then locally compute

 72:   Level: beginner

 74: .seealso: [](ch_dmbase), `DMPLEX`, `DMPlexCreatePartitionerGraph()`, `PetscPartitionerDMPlexPartition()`, `DMPlexDistribute()`
 75: E*/
 76: typedef enum {
 77:   DM_PLEX_CSR_MAT,
 78:   DM_PLEX_CSR_GRAPH,
 79:   DM_PLEX_CSR_OVERLAP
 80: } DMPlexCSRAlgorithm;
 81: PETSC_EXTERN const char *const DMPlexCSRAlgorithms[];

 83: typedef struct _p_DMPlexPointQueue *DMPlexPointQueue;
 84: struct _p_DMPlexPointQueue {
 85:   PetscInt  size;   /* Size of the storage array */
 86:   PetscInt *points; /* Array of mesh points */
 87:   PetscInt  front;  /* Index of the front of the queue */
 88:   PetscInt  back;   /* Index of the back of the queue */
 89:   PetscInt  num;    /* Number of enqueued points */
 90: };