20 #include "libmesh/variable.h" 21 #include "libmesh/dof_map.h" 22 #include "libmesh/system.h" 23 #include "libmesh/fe_type.h" 24 #include "libmesh/string_to_enum.h" 39 "CONSTANT FIRST SECOND THIRD FOURTH FIFTH SIXTH SEVENTH EIGHTH NINTH TENTH ELEVENTH TWELFTH " 40 "THIRTEENTH FOURTEENTH FIFTEENTH SIXTEENTH SEVENTEENTH EIGHTTEENTH NINETEENTH TWENTIETH " 41 "TWENTYFIRST TWENTYSECOND TWENTYTHIRD TWENTYFOURTH TWENTYFIFTH TWENTYSIXTH TWENTYSEVENTH " 42 "TWENTYEIGHTH TWENTYNINTH THIRTIETH THIRTYFIRST THIRTYSECOND THIRTYTHIRD THIRTYFOURTH " 43 "THIRTYFIFTH THIRTYSIXTH THIRTYSEVENTH THIRTYEIGHTH THIRTYNINTH FORTIETH FORTYFIRST " 44 "FORTYSECOND FORTYTHIRD",
49 "Order of the FE shape function to use for this variable (additional " 50 "orders not listed here are allowed, depending on the family).");
55 "family", family,
"Specifies the family of FE shape functions to use for this variable.");
59 "components", 1,
"components>0",
"Number of components for an array variable");
62 params.
addParam<std::vector<Real>>(
"scaling",
63 "Specifies a scaling factor to apply to this variable");
64 params.
addParam<
bool>(
"eigen",
false,
"True to make this variable an eigen variable");
65 params.
addParam<
bool>(
"fv",
false,
"True to make this variable a finite volume variable");
68 "True to make this variable a array variable regardless of number of " 69 "components. If 'components' > 1, this will automatically be set to true.");
71 params.
addParam<std::vector<std::string>>(
72 "array_var_component_names",
73 "Only for use with array variables, allows setting custom names for each array variable " 74 "component. If this not set, the default name for each array variable componenet is " 75 "`base_name`+'_'+component number. If used, a name must be provided for each component and " 76 "the values are used to name the components as `base_name`+'_'+ " 77 "`array_var_component_names[component]`.");
79 params.
addParam<SolverSystemName>(
"solver_sys",
81 "If this variable is a solver variable, this is the " 82 "solver system to which it should be added.");
84 "disable_p_refinement",
85 "True to disable p-refinement for this variable. Note that because this happens on the " 86 "family basis, users need to have this flag consistently set for all variables in the same " 87 "family. Currently MOOSE disables p-refinement for variables in the following families by " 88 "default: LAGRANGE NEDELEC_ONE RAVIART_THOMAS LAGRANGE_VEC CLOUGH BERNSTEIN and " 89 "RATIONAL_BERNSTEIN.");
93 params.
addParam<
bool>(
"use_dual",
false,
"True to use dual basis for Lagrange multipliers");
106 "Base class for Moose variables. This should never be the terminal object type");
115 _sys(*getParam<
SystemBase *>(
"_system_base")),
118 _var_num(getParam<unsigned
int>(
"_var_num")),
119 _is_eigen(getParam<bool>(
"eigen")),
121 _subproblem(_sys.subproblem()),
122 _variable(_sys.system().variable(_var_num)),
123 _assembly(_subproblem.assembly(getParam<
THREAD_ID>(
"_tid"),
125 _dof_map(_sys.dofMap()),
126 _mesh(_subproblem.
mesh()),
128 _count(getParam<unsigned
int>(
"components")),
129 _scaling_factor(_count, 1.0),
130 _use_dual(getParam<bool>(
"use_dual"))
133 : std::vector<Real>(
_count, 1.));
134 if (getParam<bool>(
"fv") && getParam<bool>(
"eigen"))
135 paramError(
"eigen",
"finite volume (fv=true) variables do not have eigen support");
137 paramError(
"family",
"finite volume (fv=true) variables must be have MONOMIAL family");
139 paramError(
"order",
"finite volume (fv=true) variables currently support CONST order only");
144 std::size_t found = name0.find_last_of(
"_");
145 if (found == std::string::npos)
146 mooseError(
"Error creating ArrayMooseVariable name with base name ", name0);
148 const auto & name_endings = getParam<std::vector<std::string>>(
"array_var_component_names");
149 for (
const auto &
name : name_endings)
157 "Component size of normal variable (_count) must be one. This is not the case for '" +
164 "An inconsistent numer of names or no names were provided for array variable components");
166 mooseAssert(
isArray(),
"Must be true with component > 1");
175 "' no subdomain is defined.");
179 for (
auto it = ++blk_ids.begin(); it != blk_ids.end(); ++it)
181 mooseError(
"A user should not specify a mix of lower-dimensional and higher-dimensional " 182 "blocks for variable '" +
184 "recognised as lower-dimensional, but is also defined for the " +
185 (
_is_lower_d ?
"higher" :
"lower") +
"-dimensional block '" +
196 "Requested array variable component number is greater than the number of component names.");
200 const std::vector<dof_id_type> &
207 mooseError(
"VariableAllDoFMap not prepared for ",
209 " . Check nonlocal coupling requirement for the variable.");
218 std::vector<dof_id_type>
220 unsigned int component)
const 222 std::vector<dof_id_type> new_dof_indices(dof_indices);
226 for (
auto &
id : new_dof_indices)
230 unsigned int n = dof_indices.size();
231 for (
auto &
id : new_dof_indices)
235 return new_dof_indices;
241 mooseAssert(factor.size() ==
_count,
"Inconsistent scaling factor size");
253 [](
const Real element) {
static InputParameters validParams()
virtual bool isNodal() const
Is this variable nodal.
static InputParameters validParams()
std::vector< dof_id_type > componentDofIndices(const std::vector< dof_id_type > &dof_indices, unsigned int component) const
Obtain DoF indices of a component with the indices of the 0th component.
const Variable & variable(unsigned int var) const
virtual void haveADObjects(bool have_ad_objects)
Method for setting whether we have any ad objects.
bool absoluteFuzzyEqual(const T &var1, const T2 &var2, const T3 &tol=libMesh::TOLERANCE *libMesh::TOLERANCE)
Function to check whether two variables are equal within an absolute tolerance.
static InputParameters validParams()
std::vector< std::string > _array_var_component_names
Array variable names when the variable is an array variable.
bool _is_lower_d
Whether this variable lives on lower dimensional blocks.
virtual libMesh::System & system()=0
Get the reference to the libMesh system.
A class to provide an common interface to objects requiring "outputs" option.
const std::string & name() const override
Get the variable name.
std::string _var_name
Variable name.
virtual const std::set< SubdomainID > & blockIDs() const
Return the block subdomain ids for this object Note, if this is not block restricted, this function returns all mesh subdomain ids.
virtual bool blockRestricted() const
Returns true if this object has been restricted to a block.
void addScalingVector()
Add the scaling factor vector to the system.
The following methods are specializations for using the libMesh::Parallel::packed_range_* routines fo...
Base class for a system (of equations)
void initialSetup() override
Gets called at the beginning of the simulation before this object is asked to do its job...
Specialization of SubProblem for solving nonlinear equations plus auxiliary equations.
const std::string & getSubdomainName(SubdomainID subdomain_id) const
Return the name of a block given an id.
static MooseEnum getNonlinearVariableFamilies()
Get the possible variable families.
bool isLowerD(const SubdomainID subdomain_id) const
static InputParameters validParams()
bool isParamValid(const std::string &name) const
Test if the supplied parameter is valid.
std::map< std::string, std::vector< dof_id_type > > _var_dof_map
registerMooseObject("MooseApp", MooseVariableBase)
SubProblem & _subproblem
Problem this variable is part of.
libMesh::FEType _fe_type
The FEType associated with this variable.
Every object that can be built by the factory should be derived from this class.
SystemBase & _sys
System this variable is part of.
T string_to_enum(const std::string &s)
VarKindType
Framework-wide stuff.
SubProblem & subproblem()
std::vector< Real > _scaling_factor
scaling factor for this variable
virtual bool isArray() const
const T & getParam(const std::string &name) const
Retrieve a parameter for the object.
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
Moose::VarKindType _var_kind
Variable type (see MooseTypes.h)
Real scalingFactor() const
Get the scaling factor for this variable.
virtual void automaticScaling(bool automatic_scaling)
Automatic scaling setter.
const unsigned int _count
Number of variables in the array.
void paramError(const std::string ¶m, Args... args) const
Emits an error prefixed with the file and line number of the given param (from the input file) along ...
MooseMesh & _mesh
mesh the variable is active in
libMesh::Order order() const
Get the order of this variable Note: Order enum can be implicitly converted to unsigned int...
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const std::vector< dof_id_type > & allDofIndices() const
Get all global dofindices for the variable.
unsigned int _var_num
variable number (from libMesh)
const std::string & arrayVariableComponent(const unsigned int i) const
Returns the variable name of a component of an array variable.
An interface that restricts an object to subdomains via the 'blocks' input parameter.
IntRange< T > make_range(T beg, T end)
void mooseError(Args &&... args) const
Emits an error prefixed with object name and type.
MOOSE now contains C++17 code, so give a reasonable error message stating what the user can do to add...
const std::string & name() const
static InputParameters validParams()
void ErrorVector unsigned int
MooseVariableBase(const InputParameters ¶meters)