https://mooseframework.inl.gov
Functions
NonlinearSystemBase.C File Reference

Go to the source code of this file.

Functions

EXTERN_C_BEGIN PetscErrorCode DMCreate_Moose (DM)
 

Function Documentation

◆ DMCreate_Moose()

EXTERN_C_BEGIN PetscErrorCode DMCreate_Moose ( DM  )

Definition at line 2056 of file PetscDMMoose.C.

Referenced by DMMooseRegisterAll().

2057 {
2058  DM_Moose * dmm;
2059 
2061  PetscValidHeaderSpecific(dm, DM_CLASSID, 1);
2062 #if PETSC_RELEASE_LESS_THAN(3, 18, 0)
2063  LibmeshPetscCallQ(PetscNewLog(dm, &dmm));
2064 #else // PetscNewLog was deprecated
2065  LibmeshPetscCallQ(PetscNew(&dmm));
2066 #endif
2067  dm->data = dmm;
2068 
2069  dmm->_name = new (std::string);
2070  dmm->_var_ids = new (std::map<std::string, unsigned int>);
2071  dmm->_block_ids = new (std::map<std::string, subdomain_id_type>);
2072  dmm->_var_names = new (std::map<unsigned int, std::string>);
2073  dmm->_block_names = new (std::map<unsigned int, std::string>);
2074  dmm->_side_ids = new (std::map<std::string, BoundaryID>);
2075  dmm->_side_names = new (std::map<BoundaryID, std::string>);
2076  dmm->_unside_ids = new (std::map<std::string, BoundaryID>);
2077  dmm->_unside_names = new (std::map<BoundaryID, std::string>);
2078  dmm->_unside_by_var_set = new (std::set<std::pair<BoundaryID, unsigned int>>);
2079  dmm->_contact_names = new (std::map<DM_Moose::ContactID, DM_Moose::ContactName>);
2080  dmm->_uncontact_names = new (std::map<DM_Moose::ContactID, DM_Moose::ContactName>);
2081  dmm->_contact_displaced = new (std::map<DM_Moose::ContactName, PetscBool>);
2082  dmm->_uncontact_displaced = new (std::map<DM_Moose::ContactName, PetscBool>);
2083 
2084  dmm->_splits = new (std::map<std::string, DM_Moose::SplitInfo>);
2085 
2086  dmm->_print_embedding = PETSC_FALSE;
2087 
2088  dm->ops->createglobalvector = DMCreateGlobalVector_Moose;
2089  dm->ops->createlocalvector = 0; // DMCreateLocalVector_Moose;
2090  dm->ops->getcoloring = 0; // DMGetColoring_Moose;
2091  dm->ops->creatematrix = DMCreateMatrix_Moose;
2092  dm->ops->createinterpolation = 0; // DMCreateInterpolation_Moose;
2093 
2094  dm->ops->refine = 0; // DMRefine_Moose;
2095  dm->ops->coarsen = 0; // DMCoarsen_Moose;
2096 #if PETSC_RELEASE_LESS_THAN(3, 12, 0)
2097  dm->ops->getinjection = 0; // DMGetInjection_Moose;
2098  dm->ops->getaggregates = 0; // DMGetAggregates_Moose;
2099 #else
2100  dm->ops->createinjection = 0;
2101 #endif
2102 
2103  dm->ops->createfielddecomposition = DMCreateFieldDecomposition_Moose;
2104  dm->ops->createdomaindecomposition = DMCreateDomainDecomposition_Moose;
2105 
2106  dm->ops->destroy = DMDestroy_Moose;
2107  dm->ops->view = DMView_Moose;
2108  dm->ops->setfromoptions = DMSetFromOptions_Moose;
2109  dm->ops->setup = DMSetUp_Moose;
2110  PetscFunctionReturn(PETSC_SUCCESS);
2111 }
static PetscErrorCode DMSetUp_Moose(DM dm)
std::set< std::pair< BoundaryID, unsigned int > > * _unside_by_var_set
Definition: PetscDMMoose.C:72
std::map< BoundaryID, std::string > * _side_names
Definition: PetscDMMoose.C:66
std::map< ContactName, PetscBool > * _contact_displaced
Definition: PetscDMMoose.C:82
PetscErrorCode DMSetFromOptions_Moose(DM dm, PetscOptionItems) PetscErrorCode DMSetFromOptions_Moose(DM dm
std::map< std::string, BoundaryID > * _side_ids
Definition: PetscDMMoose.C:67
std::string * _name
The name of this DM.
Definition: PetscDMMoose.C:103
PetscErrorCode PetscOptionItems *PetscErrorCode DM dm
PetscFunctionBegin
std::map< ContactName, PetscBool > * _uncontact_displaced
Definition: PetscDMMoose.C:83
LibmeshPetscCallQ(DMMooseValidityCheck(dm))
std::map< std::string, unsigned int > * _var_ids
Definition: PetscDMMoose.C:58
std::map< unsigned int, std::string > * _var_names
Definition: PetscDMMoose.C:59
static PetscErrorCode DMView_Moose(DM dm, PetscViewer viewer)
std::map< ContactID, ContactName > * _uncontact_names
Definition: PetscDMMoose.C:81
PetscFunctionReturn(PETSC_SUCCESS)
std::map< std::string, SplitInfo > * _splits
Definition: PetscDMMoose.C:97
static PetscErrorCode DMCreateFieldDecomposition_Moose(DM dm, PetscInt *len, char ***namelist, IS **islist, DM **dmlist)
Definition: PetscDMMoose.C:819
std::map< std::string, BoundaryID > * _unside_ids
Definition: PetscDMMoose.C:69
PetscBool _print_embedding
Definition: PetscDMMoose.C:100
std::map< std::string, subdomain_id_type > * _block_ids
Definition: PetscDMMoose.C:62
static PetscErrorCode DMCreateGlobalVector_Moose(DM dm, Vec *x)
std::map< ContactID, ContactName > * _contact_names
Definition: PetscDMMoose.C:79
static PetscErrorCode DMDestroy_Moose(DM dm)
static PetscErrorCode DMCreateDomainDecomposition_Moose(DM dm, PetscInt *len, char ***namelist, IS **innerislist, IS **outerislist, DM **dmlist)
Definition: PetscDMMoose.C:931
static PetscErrorCode DMCreateMatrix_Moose(DM dm, Mat *A)
std::map< BoundaryID, std::string > * _unside_names
Definition: PetscDMMoose.C:70
std::map< unsigned int, std::string > * _block_names
Definition: PetscDMMoose.C:63