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 2080 of file PetscDMMoose.C.

Referenced by DMMooseRegisterAll().

2081 {
2082  DM_Moose * dmm;
2083 
2085  PetscValidHeaderSpecific(dm, DM_CLASSID, 1);
2086 #if PETSC_RELEASE_LESS_THAN(3, 18, 0)
2087  LibmeshPetscCallQ(PetscNewLog(dm, &dmm));
2088 #else // PetscNewLog was deprecated
2089  LibmeshPetscCallQ(PetscNew(&dmm));
2090 #endif
2091  dm->data = dmm;
2092 
2093  dmm->_name = new (std::string);
2094  dmm->_var_ids = new (std::map<std::string, unsigned int>);
2095  dmm->_block_ids = new (std::map<std::string, subdomain_id_type>);
2096  dmm->_var_names = new (std::map<unsigned int, std::string>);
2097  dmm->_block_names = new (std::map<unsigned int, std::string>);
2098  dmm->_side_ids = new (std::map<std::string, BoundaryID>);
2099  dmm->_side_names = new (std::map<BoundaryID, std::string>);
2100  dmm->_unside_ids = new (std::map<std::string, BoundaryID>);
2101  dmm->_unside_names = new (std::map<BoundaryID, std::string>);
2102  dmm->_unside_by_var_set = new (std::set<std::pair<BoundaryID, unsigned int>>);
2103  dmm->_contact_names = new (std::map<DM_Moose::ContactID, DM_Moose::ContactName>);
2104  dmm->_uncontact_names = new (std::map<DM_Moose::ContactID, DM_Moose::ContactName>);
2105  dmm->_contact_displaced = new (std::map<DM_Moose::ContactName, PetscBool>);
2106  dmm->_uncontact_displaced = new (std::map<DM_Moose::ContactName, PetscBool>);
2107 
2108  dmm->_splits = new (std::map<std::string, DM_Moose::SplitInfo>);
2109 
2110  dmm->_print_embedding = PETSC_FALSE;
2111 
2112  dm->ops->createglobalvector = DMCreateGlobalVector_Moose;
2113  dm->ops->createlocalvector = 0; // DMCreateLocalVector_Moose;
2114  dm->ops->getcoloring = 0; // DMGetColoring_Moose;
2115  dm->ops->creatematrix = DMCreateMatrix_Moose;
2116  dm->ops->createinterpolation = 0; // DMCreateInterpolation_Moose;
2117 
2118  dm->ops->refine = 0; // DMRefine_Moose;
2119  dm->ops->coarsen = 0; // DMCoarsen_Moose;
2120 #if PETSC_RELEASE_LESS_THAN(3, 12, 0)
2121  dm->ops->getinjection = 0; // DMGetInjection_Moose;
2122  dm->ops->getaggregates = 0; // DMGetAggregates_Moose;
2123 #else
2124  dm->ops->createinjection = 0;
2125 #endif
2126 
2127  dm->ops->createfielddecomposition = DMCreateFieldDecomposition_Moose;
2128  dm->ops->createdomaindecomposition = DMCreateDomainDecomposition_Moose;
2129 
2130  dm->ops->destroy = DMDestroy_Moose;
2131  dm->ops->view = DMView_Moose;
2132  dm->ops->setfromoptions = DMSetFromOptions_Moose;
2133  dm->ops->setup = DMSetUp_Moose;
2134  PetscFunctionReturn(PETSC_SUCCESS);
2135 }
static PetscErrorCode DMSetUp_Moose(DM dm)
std::set< std::pair< BoundaryID, unsigned int > > * _unside_by_var_set
Definition: PetscDMMoose.C:74
std::map< BoundaryID, std::string > * _side_names
Definition: PetscDMMoose.C:68
std::map< ContactName, PetscBool > * _contact_displaced
Definition: PetscDMMoose.C:84
PetscErrorCode DMSetFromOptions_Moose(DM dm, PetscOptionItems) PetscErrorCode DMSetFromOptions_Moose(DM dm
std::map< std::string, BoundaryID > * _side_ids
Definition: PetscDMMoose.C:69
std::string * _name
The name of this DM.
Definition: PetscDMMoose.C:105
PetscErrorCode PetscOptionItems *PetscErrorCode DM dm
PetscFunctionBegin
std::map< ContactName, PetscBool > * _uncontact_displaced
Definition: PetscDMMoose.C:85
LibmeshPetscCallQ(DMMooseValidityCheck(dm))
std::map< std::string, unsigned int > * _var_ids
Definition: PetscDMMoose.C:60
std::map< unsigned int, std::string > * _var_names
Definition: PetscDMMoose.C:61
static PetscErrorCode DMView_Moose(DM dm, PetscViewer viewer)
std::map< ContactID, ContactName > * _uncontact_names
Definition: PetscDMMoose.C:83
PetscFunctionReturn(PETSC_SUCCESS)
std::map< std::string, SplitInfo > * _splits
Definition: PetscDMMoose.C:99
static PetscErrorCode DMCreateFieldDecomposition_Moose(DM dm, PetscInt *len, char ***namelist, IS **islist, DM **dmlist)
Definition: PetscDMMoose.C:849
std::map< std::string, BoundaryID > * _unside_ids
Definition: PetscDMMoose.C:71
PetscBool _print_embedding
Definition: PetscDMMoose.C:102
std::map< std::string, subdomain_id_type > * _block_ids
Definition: PetscDMMoose.C:64
static PetscErrorCode DMCreateGlobalVector_Moose(DM dm, Vec *x)
std::map< ContactID, ContactName > * _contact_names
Definition: PetscDMMoose.C:81
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:960
static PetscErrorCode DMCreateMatrix_Moose(DM dm, Mat *A)
std::map< BoundaryID, std::string > * _unside_names
Definition: PetscDMMoose.C:72
std::map< unsigned int, std::string > * _block_names
Definition: PetscDMMoose.C:65