1*5754ecacSJeremy L Thompson #ifndef setupdm_h 2*5754ecacSJeremy L Thompson #define setupdm_h 3*5754ecacSJeremy L Thompson 4*5754ecacSJeremy L Thompson #include <ceed.h> 5*5754ecacSJeremy L Thompson #include <petsc.h> 6*5754ecacSJeremy L Thompson #include <petscdmplex.h> 7*5754ecacSJeremy L Thompson #include <petscfe.h> 8*5754ecacSJeremy L Thompson #include "../include/structs.h" 9*5754ecacSJeremy L Thompson 10*5754ecacSJeremy L Thompson // ----------------------------------------------------------------------------- 11*5754ecacSJeremy L Thompson // Setup DM 12*5754ecacSJeremy L Thompson // ----------------------------------------------------------------------------- 13*5754ecacSJeremy L Thompson PetscErrorCode CreateBCLabel(DM dm, const char name[]); 14*5754ecacSJeremy L Thompson 15*5754ecacSJeremy L Thompson // Create FE by degree 16*5754ecacSJeremy L Thompson PetscErrorCode PetscFECreateByDegree(DM dm, PetscInt dim, PetscInt Nc, 17*5754ecacSJeremy L Thompson PetscBool is_simplex, const char prefix[], 18*5754ecacSJeremy L Thompson PetscInt order, PetscFE *fem); 19*5754ecacSJeremy L Thompson 20*5754ecacSJeremy L Thompson // Read mesh and distribute DM in parallel 21*5754ecacSJeremy L Thompson PetscErrorCode CreateDistributedDM(MPI_Comm comm, AppCtx app_ctx, DM *dm); 22*5754ecacSJeremy L Thompson 23*5754ecacSJeremy L Thompson // Setup DM with FE space of appropriate degree 24*5754ecacSJeremy L Thompson PetscErrorCode SetupDMByDegree(DM dm, AppCtx app_ctx, PetscInt order, 25*5754ecacSJeremy L Thompson PetscBool boundary, PetscInt num_comp_u); 26*5754ecacSJeremy L Thompson 27*5754ecacSJeremy L Thompson #endif // setupdm_h 28