10 #ifdef MOOSE_MFEM_ENABLED 21 "Convenience class to construct vector finite element spaces, abstracting away some of the " 22 "mathematical complexity of specifying the dimensions.");
23 MooseEnum fec_types(
"H1 ND RT L2",
"H1",
true);
24 params.
addParam<
MooseEnum>(
"fec_type", fec_types,
"Specifies the family of FE shape functions.");
25 params.
addParam<std::string>(
"closed_basis",
27 "Specifies the closed quadrature basis used for vector elements.");
28 params.
addParam<std::string>(
"open_basis",
30 "Specifies the open quadrature basis used for vector elements.");
33 "The number of components of the vectors in reference space. Zero " 34 "(the default) means it will be the same as the problem dimension. " 35 "Note that MFEM does not currently support 2D vectors in 1D space " 36 "for ND and RT elements.");
43 _range_dim(parameters.
get<
int>(
"range_dim"))
56 std::to_string(
_range_dim) +
"D vectors in " + std::to_string(pdim) +
"D space.");
57 actual_type +=
"_R" + std::to_string(pdim) +
"D";
60 const char cb = mfem::BasisType::GetChar(
getBasis(getParam<std::string>(
"closed_basis")));
61 const std::string closed_basis(1, cb);
62 const char ob = mfem::BasisType::GetChar(
getBasis(getParam<std::string>(
"open_basis")));
63 const std::string open_basis(1, ob);
67 const std::string basis =
68 (closed_basis + open_basis ==
"Gg" ?
"" :
"@" + closed_basis + open_basis);
70 return actual_type + basis +
"_" + std::to_string(pdim) +
"D_P" + std::to_string(
_fec_order);
MFEMVectorFESpace(const InputParameters ¶meters)
static InputParameters validParams()
T * get(const std::unique_ptr< T > &u)
The MooseUtils::get() specializations are used to support making forwards-compatible code changes fro...
virtual int getVDim() const override
Get the number of degrees of freedom per basis function needed in this finite element space...
registerMooseObject("MooseApp", MFEMVectorFESpace)
virtual std::string getFECName() const override
Get the name of the desired FECollection.
int getBasis(const std::string &basis_name) const
Get the quadrature basis enum associated with the given name.
const std::string _fec_type
Name of the family of finite element collections to use.
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
const int _fec_order
Order of the basis functions in the finite element collection.
void mooseError(Args &&... args) const
Emits an error prefixed with object name and type.
static InputParameters validParams()
int getProblemDim() const
Returns the dimension of the problem (i.e., the highest dimension of the reference elements in the me...
void ErrorVector unsigned int
Class with common parameters for MFEMVectorFESpace and MFEMScalarFESpace.
const int _range_dim
The number of vector components in the reference space.