20 "Sets a field variable value to the evaluation of a parsed expression.");
23 "function",
"FunctionExpression",
"Parsed function expression to compute");
25 params.
addCoupledVar(
"args",
"Vector of coupled variable names");
28 params.
addParam<std::vector<MaterialPropertyName>>(
29 "material_properties", {},
"Material properties (Real-valued) in the expression");
30 params.
addParam<std::vector<MaterialPropertyName>>(
31 "ad_material_properties", {},
"AD material properties (ADReal-valued) in the expression");
36 "Make coordinate (x,y,z) and time (t) variables available in the function expression.");
37 params.
addParam<std::vector<std::string>>(
40 "Vector of constants used in the parsed function (use this for kB etc.)");
41 params.
addParam<std::vector<std::string>>(
42 "constant_expressions",
44 "Vector of values for the constants in constant_names (can be an FParser expression)");
45 params.
addParam<std::vector<MooseFunctorName>>(
46 "functor_names", {},
"Functors to use in the parsed expression");
47 params.
addParam<std::vector<std::string>>(
50 "Symbolic name to use for each functor in 'functor_names' in the parsed expression. If not " 51 "provided, then the actual functor names will be used in the parsed expression.");
59 _function(getParam<
std::string>(
"expression")),
60 _nargs(coupledComponents(
"coupled_variables")),
61 _args(coupledValues(
"coupled_variables")),
62 _matprop_names(getParam<
std::vector<MaterialPropertyName>>(
"material_properties")),
63 _ad_matprop_names(getParam<
std::vector<MaterialPropertyName>>(
"ad_material_properties")),
64 _n_matprops(_matprop_names.size()),
65 _n_ad_matprops(_ad_matprop_names.size()),
66 _use_xyzt(getParam<bool>(
"use_xyzt")),
67 _xyzt({
"x",
"y",
"z",
"t"}),
68 _functor_names(getParam<std::vector<MooseFunctorName>>(
"functor_names")),
69 _n_functors(_functor_names.size()),
70 _functor_symbols(getParam<std::vector<std::string>>(
"functor_symbols"))
74 _coupled_variable_names.push_back(getFieldVar(
"coupled_variables", i)->
name());
77 if (!_functor_symbols.empty() && (_functor_symbols.size() != _n_functors))
78 paramError(
"functor_symbols",
"functor_symbols must be the same length as functor_names.");
80 validateFunctorSymbols();
81 validateFunctorNames();
84 std::string variables;
87 for (
const auto i :
index_range(_coupled_variable_names))
88 variables += (i == 0 ?
"" :
",") + _coupled_variable_names[i];
91 if (_functor_symbols.size())
92 for (
const auto & symbol : _functor_symbols)
93 variables += (variables.empty() ?
"" :
",") + symbol;
95 for (
const auto & name : _functor_names)
96 variables += (variables.empty() ?
"" :
",") + name;
99 for (
const auto & matprop : _matprop_names)
100 variables += (variables.empty() ?
"" :
",") + matprop;
101 for (
const auto & matprop : _ad_matprop_names)
102 variables += (variables.empty() ?
"" :
",") + matprop;
103 if (isNodal() && (_matprop_names.size() || _ad_matprop_names.size()))
104 mooseError(
"Material properties cannot be retrieved in a nodal auxkernel. Use a different " 105 "auxiliary variable family.");
109 for (
auto & v : _xyzt)
110 variables += (variables.empty() ?
"" :
",") + v;
113 _func_F = std::make_shared<SymFunction>();
114 parsedFunctionSetup(_func_F,
117 getParam<std::vector<std::string>>(
"constant_names"),
118 getParam<std::vector<std::string>>(
"constant_expressions"),
122 _func_params.resize(_nargs + _n_functors + _n_matprops + _n_ad_matprops + (_use_xyzt ? 4 : 0));
125 for (
const auto & name : _matprop_names)
126 _matprops.push_back(&getMaterialProperty<Real>(name));
127 for (
const auto & name : _ad_matprop_names)
128 _ad_matprops.push_back(&getADMaterialProperty<Real>(name));
131 for (
const auto & name : _functor_names)
132 _functors.push_back(&getFunctor<Real>(name));
std::string name(const ElemQuality q)
void validateFunctorNames()
Function to validate the names in _functor_names.
GenericReal< is_ad > evaluate(SymFunctionPtr &, const std::string &object_name="")
Evaluate FParser object and check EvalError.
static const std::set< SubdomainID > undefined_subdomain_connection
A static member that can be used when the connection of a node to subdomains is unknown.
const unsigned int _nargs
coupled variables
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
const Node *const & _current_node
Current node (valid only for nodal kernels)
Moose::StateArg determineState() const
Create a functor state argument that corresponds to the implicit state of this object.
std::vector< const Moose::Functor< Real > * > _functors
Vector of pointers to functors.
static constexpr std::size_t dim
This is the dimension of all vector and tensor datastructures used in MOOSE.
const bool _use_xyzt
import coordinates and time
const std::vector< MooseFunctorName > & _functor_names
Functors to use in the parsed expression.
std::vector< const ADMaterialProperty< Real > * > _ad_matprops
AuxKernel that evaluates a parsed function expression.
SymFunctionPtr _func_F
function parser object to compute the local value of the aux-variable
const std::vector< std::string > _functor_symbols
Symbolic name to use for each functor.
const unsigned int _n_matprops
const unsigned int _n_functors
Number of functors.
Argument for requesting functor evaluation at a quadrature point location in an element.
std::vector< const MaterialProperty< Real > * > _matprops
registerMooseObject("MooseApp", ParsedAux)
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const QBase *const & _qrule
Quadrature rule being used.
std::vector< GenericReal< is_ad > > _func_params
Array to stage the parameters passed to the functions when calling Eval.
IntRange< T > make_range(T beg, T end)
const Elem *const & _current_elem
Current element (valid only for elemental kernels)
unsigned int _qp
Quadrature point index.
const std::vector< const VariableValue * > _args
static InputParameters validParams()
static InputParameters validParams()
static InputParameters validParams()
void validateGenericVectorNames(const std::vector< T > &names_vec, const std::string ¶m_name)
Function to ensure vector entries (names) do not overlap with xyzt or coupled variable names...
const unsigned int _n_ad_matprops
ParsedAux(const InputParameters ¶meters)
virtual Real computeValue() override
Compute and return the value of the aux variable.
const MooseArray< Point > & _q_point
Active quadrature points.
auto index_range(const T &sizable)
void validateFunctorSymbols()
Function to validate the symbols in _functor_symbols.
bool isNodal() const
Nodal or elemental kernel?