https://mooseframework.inl.gov
Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Static Public Attributes | Protected Member Functions | Static Protected Member Functions | Protected Attributes | List of all members
JacobianTest1PhaseAction Class Reference

Action for setting up a Jacobian test for 1-phase flow. More...

#include <JacobianTest1PhaseAction.h>

Inheritance diagram for JacobianTest1PhaseAction:
[legend]

Public Types

typedef DataFileName DataFileParameterType
 

Public Member Functions

 JacobianTest1PhaseAction (const InputParameters &params)
 
virtual void act ()
 
void timedAct ()
 
virtual void addRelationshipManagers (Moose::RelationshipManagerType when_type)
 
MooseObjectName uniqueActionName () const
 
const std::string & specificTaskName () const
 
const std::set< std::string > & getAllTasks () const
 
void appendTask (const std::string &task)
 
MooseAppgetMooseApp () const
 
const std::string & type () const
 
virtual const std::string & name () const
 
std::string typeAndName () const
 
std::string errorPrefix (const std::string &error_type) const
 
void callMooseError (std::string msg, const bool with_prefix) const
 
MooseObjectParameterName uniqueParameterName (const std::string &parameter_name) const
 
const InputParametersparameters () const
 
MooseObjectName uniqueName () const
 
const T & getParam (const std::string &name) const
 
std::vector< std::pair< T1, T2 > > getParam (const std::string &param1, const std::string &param2) const
 
const T * queryParam (const std::string &name) const
 
const T & getRenamedParam (const std::string &old_name, const std::string &new_name) const
 
getCheckedPointerParam (const std::string &name, const std::string &error_string="") const
 
bool isParamValid (const std::string &name) const
 
bool isParamSetByUser (const std::string &nm) const
 
void paramError (const std::string &param, Args... args) const
 
void paramWarning (const std::string &param, Args... args) const
 
void paramInfo (const std::string &param, Args... args) const
 
void connectControllableParams (const std::string &parameter, const std::string &object_type, const std::string &object_name, const std::string &object_parameter) const
 
void mooseError (Args &&... args) const
 
void mooseErrorNonPrefixed (Args &&... args) const
 
void mooseDocumentedError (const std::string &repo_name, const unsigned int issue_num, Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseInfo (Args &&... args) const
 
std::string getDataFileName (const std::string &param) const
 
std::string getDataFileNameByName (const std::string &relative_path) const
 
std::string getDataFilePath (const std::string &relative_path) const
 
PerfGraphperfGraph ()
 
const Parallel::Communicator & comm () const
 
processor_id_type n_processors () const
 
processor_id_type processor_id () const
 

Static Public Member Functions

static InputParameters validParams ()
 

Public Attributes

const ConsoleStream _console
 

Static Public Attributes

static constexpr auto SYSTEM
 
static constexpr auto NAME
 

Protected Member Functions

virtual void addInitialConditions () override
 
virtual void addSolutionVariables () override
 
virtual void addAuxVariables () override
 Adds aux variables. More...
 
virtual void addMaterials () override
 
virtual void addUserObjects () override
 
virtual void addPreconditioner () override
 Adds the preconditioner. More...
 
void addMeshInternal (const unsigned int &nx)
 Adds the mesh with a provided number of elements in x direction. More...
 
virtual void addObjects ()
 Adds all non-mesh objects. More...
 
void addScalarVariables (const std::vector< VariableName > &names, const std::vector< FunctionName > &values)
 Adds scalar variables. More...
 
void addSolutionVariable (const VariableName &var_name, const std::string &family="LAGRANGE", const std::string &order="FIRST", const Real &scaling=1.0)
 Adds a solution variable. More...
 
void addAuxVariable (const VariableName &var_name, const std::string &fe_family, const std::string &fe_order)
 Adds an aux variable. More...
 
void addConstantIC (const VariableName &var_name, const Real &value)
 Adds a constant initial condition. More...
 
void addFunctionIC (const VariableName &var_name, const FunctionName &function_name)
 Adds a function initial condition. More...
 
virtual void addMesh ()
 Adds the mesh. More...
 
virtual void addExecutioner ()
 Adds the executioner. More...
 
virtual void addOutput ()
 Add output. More...
 
bool addRelationshipManagers (Moose::RelationshipManagerType when_type, const InputParameters &moose_object_pars)
 
void associateWithParameter (const std::string &param_name, InputParameters &params) const
 
void associateWithParameter (const InputParameters &from_params, const std::string &param_name, InputParameters &params) const
 
const T & getMeshProperty (const std::string &data_name, const std::string &prefix)
 
const T & getMeshProperty (const std::string &data_name)
 
bool hasMeshProperty (const std::string &data_name, const std::string &prefix) const
 
bool hasMeshProperty (const std::string &data_name, const std::string &prefix) const
 
bool hasMeshProperty (const std::string &data_name) const
 
bool hasMeshProperty (const std::string &data_name) const
 
std::string meshPropertyName (const std::string &data_name) const
 
PerfID registerTimedSection (const std::string &section_name, const unsigned int level) const
 
PerfID registerTimedSection (const std::string &section_name, const unsigned int level, const std::string &live_message, const bool print_dots=true) const
 
std::string timedSectionName (const std::string &section_name) const
 
virtual void addNonConstantAuxVariables () override
 
void addSolutionVariable (const VariableName &var_name, const Real &scaling=1.0)
 Adds a solution variable. More...
 
void addAuxVariable (const VariableName &var_name)
 Adds an aux variable. More...
 
void addFunctionIC (const VariableName &var_name, const FunctionName &function_name)
 Adds a function initial condition. More...
 
template<typename T >
const T & getParam (const std::string &name) const
 Retrieves a parameter. More...
 

Static Protected Member Functions

static std::string meshPropertyName (const std::string &data_name, const std::string &prefix)
 

Protected Attributes

const std::string _snes_test_err
 Finite differencing parameter. More...
 
bool _default_use_transient_executioner
 Default for option to use a transient executioner. More...
 
const std::vector< VariableName > _scalar_variables
 List of scalar variables to add. More...
 
const std::vector< FunctionName > _scalar_variable_values
 List of values for the scalar variables to add. More...
 
const std::vector< VariableName > _aux_variables
 List of aux variables to add. More...
 
const std::vector< FunctionName > _aux_variable_values
 List of function names for aux variables to add. More...
 
const std::vector< std::string > _mat_property_names
 List of material properties to add. More...
 
const std::vector< FunctionName > _mat_property_values
 List of function names for material properties to add. More...
 
const std::string _fe_family
 Default FE family. More...
 
const std::string _fe_order
 Default FE order. More...
 
const bool & _ad
 True for setting up testing with AD, false otherwise. More...
 
std::string _registered_identifier
 
std::string _specific_task_name
 
std::set< std::string > _all_tasks
 
ActionWarehouse_awh
 
const std::string & _current_task
 
std::shared_ptr< MooseMesh > & _mesh
 
std::shared_ptr< MooseMesh > & _displaced_mesh
 
std::shared_ptr< FEProblemBase > & _problem
 
PerfID _act_timer
 
MooseApp_app
 
const std::string _type
 
const std::string _name
 
const InputParameters_pars
 
Factory_factory
 
ActionFactory_action_factory
 
MooseApp_pg_moose_app
 
const std::string _prefix
 
const Parallel::Communicator & _communicator
 
const FunctionName _p_fn
 Pressure function name. More...
 
const FunctionName _T_fn
 Temperature function name. More...
 
const FunctionName _vel_fn
 Velocity function name. More...
 
const FunctionName _A_fn
 Area function name. More...
 
const FunctionName _D_h_fn
 Hydraulic diameter function name. More...
 
const UserObjectName _fp_1phase_name
 Single-phase fluid properties object name. More...
 
const VariableName _unity_name
 Name of unity. More...
 
const VariableName _A_name
 Name of area variable. More...
 
const VariableName _D_h_name
 Name of the hydraulic diameter. More...
 
const VariableName _rhoA_name
 Name of rho*A variable. More...
 
const VariableName _rhouA_name
 Name of rho*u*A variable. More...
 
const VariableName _rhoEA_name
 Name of rho*E*A variable. More...
 
const VariableName _rho_name
 Name of rho variable. More...
 
const VariableName _vel_name
 Name of velocity variable. More...
 
const VariableName _p_name
 Name of pressure variable. More...
 
const VariableName _T_name
 Name of temperature variable. More...
 
const VariableName _v_name
 Name of specific volume variable. More...
 
const VariableName _e_name
 Name of specific internal energy variable. More...
 
const VariableName _H_name
 Name of specific total enthalpy variable. More...
 
const VariableName _mu_name
 Name of dynamic viscosity variable. More...
 
const bool & _ad
 True for setting up testing with AD, false otherwise. More...
 
const InputParameters_this_params
 
MooseApp_this_app
 
ActionFactory_this_action_factory
 
ActionWarehouse_this_action_warehouse
 
MooseEnum _fe_family
 
MooseEnum _fe_order
 
const Real_gravity_magnitude
 Gravitational acceleration magnitude. More...
 

Detailed Description

Action for setting up a Jacobian test for 1-phase flow.

Definition at line 18 of file JacobianTest1PhaseAction.h.

Constructor & Destructor Documentation

◆ JacobianTest1PhaseAction()

JacobianTest1PhaseAction::JacobianTest1PhaseAction ( const InputParameters params)

Definition at line 27 of file JacobianTest1PhaseAction.C.

28  : JacobianTestAction(params), FlowModelSetup1Phase(params)
29 {
30 }
JacobianTestAction(const InputParameters &params)
FlowModelSetup1Phase(const InputParameters &params)

Member Function Documentation

◆ act()

void TestAction::act ( )
virtualinherited

Implements Action.

Definition at line 75 of file TestAction.C.

76 {
77  if (_current_task == "meta_action")
78  {
79  if (getParam<bool>("generate_mesh"))
80  addMesh();
81 
82  addObjects();
83 
84  {
85  const std::string class_name = "CreateProblemAction";
86  auto action_params = _action_factory.getValidParams(class_name);
87  action_params.set<std::string>("type") = "FEProblem";
88 
89  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
90  _action_factory.create(class_name, "fe_problem", action_params));
91 
92  action->getObjectParams().set<MooseEnum>("kernel_coverage_check") = "false";
93  _awh.addActionBlock(action);
94  }
95  }
96 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
virtual void addObjects()
Adds all non-mesh objects.
Definition: TestAction.C:140
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
const std::string & _current_task
ActionFactory & _action_factory
virtual void addMesh()
Adds the mesh.
Definition: TestAction.C:99

◆ addAuxVariable() [1/2]

void FlowModelSetup::addAuxVariable ( const VariableName &  var_name)
protectedinherited

Adds an aux variable.

Parameters
[in]var_namename of the variable to add

Definition at line 56 of file FlowModelSetup.C.

Referenced by ClosureTest1PhaseAction::addAuxVariables(), and FlowModelSetup1Phase::addNonConstantAuxVariables().

57 {
58  const std::string class_name = "AddAuxVariableAction";
60 
61  std::shared_ptr<Action> action =
62  std::static_pointer_cast<Action>(_this_action_factory.create(class_name, var_name, params));
63 
65 }
InputParameters getValidParams(const std::string &name)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
ActionWarehouse & _this_action_warehouse
ActionFactory & _this_action_factory

◆ addAuxVariable() [2/2]

void TestAction::addAuxVariable ( const VariableName &  var_name,
const std::string &  fe_family,
const std::string &  fe_order 
)
protectedinherited

Adds an aux variable.

Parameters
[in]var_namename of the variable to add
[in]fe_familyfinite element family
[in]fe_orderfinite element order

Definition at line 248 of file TestAction.C.

Referenced by ClosureTestAction::addAuxVariables(), JacobianTest1PhaseRDGAction::addAuxVariables(), TestAction::addAuxVariables(), ClosureTestAction::setupADOutput(), and ClosureTestAction::setupOutput().

251 {
252  const std::string class_name = "AddAuxVariableAction";
253  InputParameters params = _action_factory.getValidParams(class_name);
254 
255  params.set<MooseEnum>("family") = fe_family;
256  params.set<MooseEnum>("order") = fe_order;
257 
258  std::shared_ptr<Action> action =
259  std::static_pointer_cast<Action>(_action_factory.create(class_name, var_name, params));
260 
261  _awh.addActionBlock(action);
262 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
ActionFactory & _action_factory

◆ addAuxVariables()

void JacobianTest1PhaseAction::addAuxVariables ( )
overrideprotectedvirtual

Adds aux variables.

Reimplemented from TestAction.

Definition at line 45 of file JacobianTest1PhaseAction.C.

46 {
49 }
virtual void addAuxVariables()
Adds aux variables.
Definition: TestAction.C:180
virtual void addNonConstantAuxVariables() override

◆ addConstantIC()

void TestAction::addConstantIC ( const VariableName &  var_name,
const Real value 
)
protectedinherited

Adds a constant initial condition.

Parameters
[in]var_namename of the variable for which to add initial condition
[in]valuevalue of the initial condition

Definition at line 265 of file TestAction.C.

Referenced by JacobianTest1PhaseRDGAction::addSolutionVariables().

266 {
267  const std::string class_name = "AddInitialConditionAction";
268  InputParameters params = _action_factory.getValidParams(class_name);
269  params.set<std::string>("type") = "ConstantIC";
270 
271  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
272  _action_factory.create(class_name, var_name + "_IC", params));
273 
274  action->getObjectParams().set<VariableName>("variable") = var_name;
275  action->getObjectParams().set<Real>("value") = value;
276 
277  _awh.addActionBlock(action);
278 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
ActionFactory & _action_factory
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real

◆ addExecutioner()

void TestAction::addExecutioner ( )
protectedvirtualinherited

Adds the executioner.

Definition at line 302 of file TestAction.C.

Referenced by TestAction::addObjects().

303 {
304  const std::string class_name = "CreateExecutionerAction";
305 
306  // determine whether to use a transient executioner - different derived
307  // classes have different defaults: the declared default is irrelevant
308  bool use_transient_executioner;
309  if (isParamValid("use_transient_executioner"))
310  use_transient_executioner = getParam<bool>("use_transient_executioner");
311  else
312  use_transient_executioner = _default_use_transient_executioner;
313 
314  // Due to more consistent divergence status reporting in PETSc (as of 5f3c5e7a), users should have
315  // the option to abort on the first fail if desired. Otherwise Jacobian testing, for example, could
316  // fail in undesired ways, even if the Jacobian test achieves a passing result.
317  bool abort_on_solve_fail = getParam<bool>("abort_on_solve_fail");
318 
319  // if a time kernel is being tested, then use a transient executioner instead of steady
320  if (use_transient_executioner)
321  {
322  InputParameters params = _action_factory.getValidParams(class_name);
323  params.set<std::string>("type") = "Transient";
324 
325  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
326  _action_factory.create(class_name, "executioner", params));
327 
328  action->getObjectParams().set<unsigned int>("num_steps") = 1;
329 
330  if (abort_on_solve_fail)
331  action->getObjectParams().set<bool>("abort_on_solve_fail") = abort_on_solve_fail;
332 
333  _awh.addActionBlock(action);
334  }
335  else
336  {
337  InputParameters params = _action_factory.getValidParams(class_name);
338  params.set<std::string>("type") = "Steady";
339 
340  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
341  _action_factory.create(class_name, "executioner", params));
342 
343  if (abort_on_solve_fail)
344  action->getObjectParams().set<bool>("abort_on_solve_fail") = abort_on_solve_fail;
345 
346  _awh.addActionBlock(action);
347  }
348 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
bool isParamValid(const std::string &name) const
InputParameters & getObjectParams()
ActionFactory & _action_factory
bool _default_use_transient_executioner
Default for option to use a transient executioner.
Definition: TestAction.h:132

◆ addFunctionIC() [1/2]

void FlowModelSetup::addFunctionIC ( const VariableName &  var_name,
const FunctionName &  function_name 
)
protectedinherited

Adds a function initial condition.

Parameters
[in]var_namename of the variable for which to add initial condition
[in]function_namenames of the IC function

Definition at line 68 of file FlowModelSetup.C.

Referenced by FlowModelSetup1Phase::addInitialConditions().

69 {
70  const std::string class_name = "AddInitialConditionAction";
72  params.set<std::string>("type") = "FunctionIC";
73 
74  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
75  _this_action_factory.create(class_name, var_name + "_IC", params));
76 
77  action->getObjectParams().set<VariableName>("variable") = var_name;
78  action->getObjectParams().set<FunctionName>("function") = function_name;
79 
81 }
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
ActionWarehouse & _this_action_warehouse
ActionFactory & _this_action_factory

◆ addFunctionIC() [2/2]

void TestAction::addFunctionIC ( const VariableName &  var_name,
const FunctionName &  function_name 
)
protectedinherited

Adds a function initial condition.

Parameters
[in]var_namename of the variable for which to add initial condition
[in]function_namenames of the IC function

Definition at line 281 of file TestAction.C.

Referenced by JacobianTest1PhaseRDGAction::addAuxVariables(), TestAction::addAuxVariables(), ClosureTestAction::addInitialConditions(), JacobianTestGeneralAction::addSolutionVariables(), and JacobianTest1PhaseRDGAction::addSolutionVariablesRiemannIC().

282 {
283  const std::string class_name = "AddInitialConditionAction";
284  InputParameters params = _action_factory.getValidParams(class_name);
285  params.set<std::string>("type") = "FunctionIC";
286 
287  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
288  _action_factory.create(class_name, var_name + "_IC", params));
289 
290  action->getObjectParams().set<VariableName>("variable") = var_name;
291  action->getObjectParams().set<FunctionName>("function") = function_name;
292 
293  _awh.addActionBlock(action);
294 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
ActionFactory & _action_factory

◆ addInitialConditions()

void JacobianTest1PhaseAction::addInitialConditions ( )
overrideprotectedvirtual

Reimplemented from FlowModelSetup1Phase.

Definition at line 33 of file JacobianTest1PhaseAction.C.

34 {
36 }
virtual void addInitialConditions() override

◆ addMaterials()

void JacobianTest1PhaseAction::addMaterials ( )
overrideprotectedvirtual

Reimplemented from FlowModelSetup1Phase.

Definition at line 52 of file JacobianTest1PhaseAction.C.

53 {
56 }
virtual void addMaterials() override
virtual void addMaterials()
Adds materials.
Definition: TestAction.C:214

◆ addMesh()

void TestAction::addMesh ( )
protectedvirtualinherited

Adds the mesh.

Reimplemented in JacobianTest1PhaseRDGAction.

Definition at line 99 of file TestAction.C.

Referenced by TestAction::act().

100 {
101  addMeshInternal(1);
102 }
void addMeshInternal(const unsigned int &nx)
Adds the mesh with a provided number of elements in x direction.
Definition: TestAction.C:105

◆ addMeshInternal()

void TestAction::addMeshInternal ( const unsigned int nx)
protectedinherited

Adds the mesh with a provided number of elements in x direction.

Parameters
[in]nxnumber of elements in x direction

Definition at line 105 of file TestAction.C.

Referenced by JacobianTest1PhaseRDGAction::addMesh(), and TestAction::addMesh().

106 {
107  std::vector<std::string> setup_mesh_tasks{"setup_mesh", "set_mesh_base", "init_mesh"};
108  for (const std::string & task : setup_mesh_tasks)
109  {
110  const std::string class_name = "SetupMeshAction";
111  InputParameters params = _action_factory.getValidParams(class_name);
112  params.set<std::string>("type") = "GeneratedMesh";
113  params.set<std::string>("task") = task;
114 
115  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
116  _action_factory.create(class_name, task, params));
117 
118  action->getObjectParams().set<MooseEnum>("dim") = 1;
119  action->getObjectParams().set<unsigned int>("nx") = nx;
120  action->getObjectParams().set<bool>("allow_renumbering") = false;
121 
122  _awh.addActionBlock(action);
123  }
124 
125  std::vector<std::string> setup_mesh_complete_tasks{"prepare_mesh", "setup_mesh_complete"};
126  for (const std::string & task : setup_mesh_complete_tasks)
127  {
128  const std::string class_name = "SetupMeshCompleteAction";
129  InputParameters params = _action_factory.getValidParams(class_name);
130  params.set<std::string>("task") = task;
131 
132  std::shared_ptr<Action> action =
133  std::static_pointer_cast<Action>(_action_factory.create(class_name, task, params));
134 
135  _awh.addActionBlock(action);
136  }
137 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
ActionFactory & _action_factory

◆ addNonConstantAuxVariables()

void FlowModelSetup1Phase::addNonConstantAuxVariables ( )
overrideprotectedvirtualinherited

Implements FlowModelSetup.

Definition at line 192 of file FlowModelSetup1Phase.C.

Referenced by ClosureTest1PhaseAction::addAuxVariables(), and addAuxVariables().

193 {
194  // area
196  {
197  const std::string class_name = "AddKernelAction";
199  params.set<std::string>("type") = "FunctionAux";
200  params.set<std::string>("task") = "add_aux_kernel";
201 
202  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
203  _this_action_factory.create(class_name, _A_name + "_aux", params));
204 
205  action->getObjectParams().set<AuxVariableName>("variable") = _A_name;
206  action->getObjectParams().set<FunctionName>("function") = _A_fn;
207 
209  }
210 
211  // rho
213  {
214  const std::string class_name = "AddKernelAction";
216  params.set<std::string>("type") = "QuotientAux";
217  params.set<std::string>("task") = "add_aux_kernel";
218 
219  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
220  _this_action_factory.create(class_name, _rho_name + "_aux", params));
221 
222  action->getObjectParams().set<AuxVariableName>("variable") = _rho_name;
223  action->getObjectParams().set<std::vector<VariableName>>("numerator") = {_rhoA_name};
224  action->getObjectParams().set<std::vector<VariableName>>("denominator") = {_A_name};
225 
227  }
228 
229  // velocity
231  {
232  const std::string class_name = "AddKernelAction";
234  params.set<std::string>("type") = "QuotientAux";
235  params.set<std::string>("task") = "add_aux_kernel";
236 
237  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
238  _this_action_factory.create(class_name, _vel_name + "_aux", params));
239 
240  action->getObjectParams().set<AuxVariableName>("variable") = _vel_name;
241  action->getObjectParams().set<std::vector<VariableName>>("numerator") = {_rhouA_name};
242  action->getObjectParams().set<std::vector<VariableName>>("denominator") = {_rhoA_name};
243 
245  }
246 
247  // pressure
249  {
250  const std::string class_name = "AddKernelAction";
252  params.set<std::string>("type") = "PressureAux";
253  params.set<std::string>("task") = "add_aux_kernel";
254 
255  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
256  _this_action_factory.create(class_name, _p_name + "_aux", params));
257 
258  action->getObjectParams().set<AuxVariableName>("variable") = _p_name;
259  action->getObjectParams().set<std::vector<VariableName>>("e") = {_e_name};
260  action->getObjectParams().set<std::vector<VariableName>>("v") = {_v_name};
261  action->getObjectParams().set<UserObjectName>("fp") = _fp_1phase_name;
262 
264  }
265 
266  // temperature
268  {
269  const std::string class_name = "AddKernelAction";
271  params.set<std::string>("type") = "TemperatureAux";
272  params.set<std::string>("task") = "add_aux_kernel";
273 
274  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
275  _this_action_factory.create(class_name, _T_name + "_aux", params));
276 
277  action->getObjectParams().set<AuxVariableName>("variable") = _T_name;
278  action->getObjectParams().set<std::vector<VariableName>>("e") = {_e_name};
279  action->getObjectParams().set<std::vector<VariableName>>("v") = {_v_name};
280  action->getObjectParams().set<UserObjectName>("fp") = _fp_1phase_name;
281 
283  }
284 
285  // specific volume
287  {
288  const std::string class_name = "AddKernelAction";
290  params.set<std::string>("type") = "THMSpecificVolumeAux";
291  params.set<std::string>("task") = "add_aux_kernel";
292 
293  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
294  _this_action_factory.create(class_name, _v_name + "_aux", params));
295 
296  action->getObjectParams().set<AuxVariableName>("variable") = _v_name;
297  action->getObjectParams().set<std::vector<VariableName>>("rhoA") = {_rhoA_name};
298  action->getObjectParams().set<std::vector<VariableName>>("A") = {_A_name};
299 
301  }
302 
303  // specific internal energy
305  {
306  const std::string class_name = "AddKernelAction";
308  params.set<std::string>("type") = "THMSpecificInternalEnergyAux";
309  params.set<std::string>("task") = "add_aux_kernel";
310 
311  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
312  _this_action_factory.create(class_name, _e_name + "_aux", params));
313 
314  action->getObjectParams().set<AuxVariableName>("variable") = _e_name;
315  action->getObjectParams().set<std::vector<VariableName>>("rhoA") = {_rhoA_name};
316  action->getObjectParams().set<std::vector<VariableName>>("rhouA") = {_rhouA_name};
317  action->getObjectParams().set<std::vector<VariableName>>("rhoEA") = {_rhoEA_name};
318 
320  }
321 
322  // specific total enthalpy
324  {
325  const std::string class_name = "AddKernelAction";
327  params.set<std::string>("type") = "SpecificTotalEnthalpyAux";
328  params.set<std::string>("task") = "add_aux_kernel";
329 
330  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
331  _this_action_factory.create(class_name, _H_name + "_aux", params));
332 
333  action->getObjectParams().set<AuxVariableName>("variable") = _H_name;
334  action->getObjectParams().set<std::vector<VariableName>>("rhoA") = {_rhoA_name};
335  action->getObjectParams().set<std::vector<VariableName>>("rhoEA") = {_rhoEA_name};
336  action->getObjectParams().set<std::vector<VariableName>>("p") = {_p_name};
337  action->getObjectParams().set<std::vector<VariableName>>("A") = {_A_name};
338 
340  }
341 }
const VariableName _rhoA_name
Name of rho*A variable.
const VariableName _A_name
Name of area variable.
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addAuxVariable(const VariableName &var_name)
Adds an aux variable.
const VariableName _p_name
Name of pressure variable.
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
const VariableName _v_name
Name of specific volume variable.
const VariableName _rho_name
Name of rho variable.
const VariableName _rhouA_name
Name of rho*u*A variable.
const UserObjectName _fp_1phase_name
Single-phase fluid properties object name.
const VariableName _e_name
Name of specific internal energy variable.
const FunctionName _A_fn
Area function name.
ActionWarehouse & _this_action_warehouse
ActionFactory & _this_action_factory
const VariableName _rhoEA_name
Name of rho*E*A variable.
const VariableName _H_name
Name of specific total enthalpy variable.
const VariableName _vel_name
Name of velocity variable.
const VariableName _T_name
Name of temperature variable.

◆ addObjects()

void TestAction::addObjects ( )
protectedvirtualinherited

Adds all non-mesh objects.

Reimplemented in JacobianTest1PhaseRDGAction.

Definition at line 140 of file TestAction.C.

Referenced by TestAction::act(), and JacobianTest1PhaseRDGAction::addObjects().

141 {
144  addAuxVariables();
146  addUserObjects();
147  addMaterials();
149  addExecutioner();
150  addOutput();
151 }
void addScalarVariables(const std::vector< VariableName > &names, const std::vector< FunctionName > &values)
Adds scalar variables.
Definition: TestAction.C:154
virtual void addPreconditioner()
Adds the preconditioner.
Definition: TestAction.C:297
virtual void addAuxVariables()
Adds aux variables.
Definition: TestAction.C:180
virtual void addInitialConditions()=0
Adds the initial conditions.
virtual void addExecutioner()
Adds the executioner.
Definition: TestAction.C:302
virtual void addOutput()
Add output.
Definition: TestAction.C:351
const std::vector< VariableName > _scalar_variables
List of scalar variables to add.
Definition: TestAction.h:135
virtual void addMaterials()
Adds materials.
Definition: TestAction.C:214
virtual void addSolutionVariables()=0
Adds the solution variables.
const std::vector< FunctionName > _scalar_variable_values
List of values for the scalar variables to add.
Definition: TestAction.h:137
virtual void addUserObjects()=0
Adds user objects.

◆ addOutput()

void TestAction::addOutput ( )
protectedvirtualinherited

Add output.

Reimplemented in ClosureTestAction.

Definition at line 351 of file TestAction.C.

Referenced by TestAction::addObjects().

352 {
353 }

◆ addPreconditioner()

void JacobianTestAction::addPreconditioner ( )
overrideprotectedvirtualinherited

Adds the preconditioner.

Reimplemented from TestAction.

Definition at line 34 of file JacobianTestAction.C.

35 {
36  const std::string class_name = "SetupPreconditionerAction";
37  InputParameters params = _action_factory.getValidParams(class_name);
38  params.set<std::string>("type") = "SMP";
39 
40  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
41  _action_factory.create(class_name, "smp", params));
42 
43  action->getObjectParams().set<bool>("full") = true;
44  action->getObjectParams().set<MooseEnum>("solve_type") = "newton";
45 #if PETSC_VERSION_LESS_THAN(3, 9, 0)
46  action->getObjectParams().set<MultiMooseEnum>("petsc_options_iname") =
47  "-snes_type -snes_test_err";
48  action->getObjectParams().set<std::vector<std::string>>("petsc_options_value") = {"test",
50 #else
51  action->getObjectParams().set<MultiMooseEnum>("petsc_options") = "-snes_test_jacobian";
52  action->getObjectParams().set<MultiMooseEnum>("petsc_options_iname") = "-snes_test_err";
53  action->getObjectParams().set<std::vector<std::string>>("petsc_options_value") = {_snes_test_err};
54 #endif
55 
56  _awh.addActionBlock(action);
57 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
const std::string _snes_test_err
Finite differencing parameter.
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
ActionFactory & _action_factory

◆ addScalarVariables()

void TestAction::addScalarVariables ( const std::vector< VariableName > &  names,
const std::vector< FunctionName > &  values 
)
protectedinherited

Adds scalar variables.

Parameters
[in]namesnames of the variables to add
[in]valuesvalues of the variables to add

Definition at line 154 of file TestAction.C.

Referenced by TestAction::addObjects().

156 {
157  for (unsigned int i = 0; i < names.size(); ++i)
158  {
159  // add the scalar variable
160  addSolutionVariable(names[i], "SCALAR", "FIRST");
161 
162  // add its IC
163  {
164  const std::string class_name = "AddInitialConditionAction";
165  InputParameters params = _action_factory.getValidParams(class_name);
166  params.set<std::string>("type") = "FunctionScalarIC";
167 
168  std::shared_ptr<MooseObjectAction> action = std::static_pointer_cast<MooseObjectAction>(
169  _action_factory.create(class_name, names[i] + "_IC", params));
170 
171  action->getObjectParams().set<VariableName>("variable") = names[i];
172  action->getObjectParams().set<std::vector<FunctionName>>("function") = {values[i]};
173 
174  _awh.addActionBlock(action);
175  }
176  }
177 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
InputParameters & getObjectParams()
void addSolutionVariable(const VariableName &var_name, const std::string &family="LAGRANGE", const std::string &order="FIRST", const Real &scaling=1.0)
Adds a solution variable.
Definition: TestAction.C:230
ActionFactory & _action_factory

◆ addSolutionVariable() [1/2]

void FlowModelSetup::addSolutionVariable ( const VariableName &  var_name,
const Real scaling = 1.0 
)
protectedinherited

Adds a solution variable.

Parameters
[in]var_namename of the variable to add
[in]scalingscaling factor to apply to variable

Definition at line 41 of file FlowModelSetup.C.

Referenced by FlowModelSetup1Phase::addSolutionVariables().

42 {
43  const std::string class_name = "AddVariableAction";
45  params.set<std::vector<Real>>("scaling") = {scaling};
46  params.set<MooseEnum>("family") = _fe_family;
47  params.set<MooseEnum>("order") = _fe_order;
48 
49  std::shared_ptr<Action> action =
50  std::static_pointer_cast<Action>(_this_action_factory.create(class_name, var_name, params));
51 
53 }
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
ActionWarehouse & _this_action_warehouse
ActionFactory & _this_action_factory
MooseEnum _fe_order
MooseEnum _fe_family

◆ addSolutionVariable() [2/2]

void TestAction::addSolutionVariable ( const VariableName &  var_name,
const std::string &  family = "LAGRANGE",
const std::string &  order = "FIRST",
const Real scaling = 1.0 
)
protectedinherited

Adds a solution variable.

Parameters
[in]var_namename of the variable to add
[in]familyvariable family
[in]ordervariable order
[in]scalingscaling factor to apply to variable

Definition at line 230 of file TestAction.C.

Referenced by TestAction::addScalarVariables(), ClosureTestAction::addSolutionVariables(), JacobianTest1PhaseRDGAction::addSolutionVariables(), JacobianTestGeneralAction::addSolutionVariables(), and JacobianTest1PhaseRDGAction::addSolutionVariablesRiemannIC().

234 {
235  const std::string class_name = "AddVariableAction";
236  InputParameters params = _action_factory.getValidParams(class_name);
237  params.set<MooseEnum>("family") = family;
238  params.set<MooseEnum>("order") = order;
239  params.set<std::vector<Real>>("scaling") = {scaling};
240 
241  std::shared_ptr<Action> action =
242  std::static_pointer_cast<Action>(_action_factory.create(class_name, var_name, params));
243 
244  _awh.addActionBlock(action);
245 }
ActionWarehouse & _awh
InputParameters getValidParams(const std::string &name)
T & set(const std::string &name, bool quiet_mode=false)
void addActionBlock(std::shared_ptr< Action > blk)
std::shared_ptr< Action > create(const std::string &action, const std::string &action_name, InputParameters &parameters)
ActionFactory & _action_factory

◆ addSolutionVariables()

void JacobianTest1PhaseAction::addSolutionVariables ( )
overrideprotectedvirtual

Reimplemented from FlowModelSetup1Phase.

Definition at line 39 of file JacobianTest1PhaseAction.C.

40 {
42 }
virtual void addSolutionVariables() override

◆ addUserObjects()

void JacobianTest1PhaseAction::addUserObjects ( )
overrideprotectedvirtual

Reimplemented from FlowModelSetup1Phase.

Definition at line 59 of file JacobianTest1PhaseAction.C.

60 {
62 }
virtual void addUserObjects() override

◆ getParam()

template<typename T >
const T & FlowModelSetup::getParam ( const std::string &  name) const
protectedinherited

Retrieves a parameter.

Parameters
[in]namename of the parameter
Returns
value of the parameter

Definition at line 82 of file FlowModelSetup.h.

83 {
84  return InputParameters::getParamHelper(name, _this_params, static_cast<T *>(0));
85 }
const std::string name
Definition: Setup.h:20
const InputParameters & _this_params
const MooseEnum & getParamHelper(const std::string &name, const InputParameters &pars, const MooseEnum *, const MooseBase *moose_base)

◆ validParams()

InputParameters JacobianTest1PhaseAction::validParams ( )
static

Definition at line 15 of file JacobianTest1PhaseAction.C.

16 {
20 
21  params.set<std::string>("fe_family") = "LAGRANGE";
22  params.set<std::string>("fe_order") = "FIRST";
23 
24  return params;
25 }
static InputParameters validParams()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters emptyInputParameters()
static InputParameters validParams()

Member Data Documentation

◆ _A_fn

const FunctionName FlowModelSetup1Phase::_A_fn
protectedinherited

◆ _A_name

const VariableName FlowModelSetup1Phase::_A_name
protectedinherited

◆ _ad [1/2]

const bool& FlowModelSetup1Phase::_ad
protectedinherited

True for setting up testing with AD, false otherwise.

Definition at line 73 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addMaterials().

◆ _ad [2/2]

const bool& TestAction::_ad
protectedinherited

True for setting up testing with AD, false otherwise.

Definition at line 154 of file TestAction.h.

Referenced by ClosureTestAction::addMaterials(), and JacobianTest1PhaseRDGAction::addMaterials().

◆ _aux_variable_values

const std::vector<FunctionName> TestAction::_aux_variable_values
protectedinherited

List of function names for aux variables to add.

Definition at line 142 of file TestAction.h.

Referenced by TestAction::addAuxVariables(), and TestAction::TestAction().

◆ _aux_variables

const std::vector<VariableName> TestAction::_aux_variables
protectedinherited

List of aux variables to add.

Definition at line 140 of file TestAction.h.

Referenced by TestAction::addAuxVariables(), and TestAction::TestAction().

◆ _D_h_fn

const FunctionName FlowModelSetup1Phase::_D_h_fn
protectedinherited

Hydraulic diameter function name.

Definition at line 38 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addMaterials().

◆ _D_h_name

const VariableName FlowModelSetup1Phase::_D_h_name
protectedinherited

Name of the hydraulic diameter.

Definition at line 48 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addMaterials().

◆ _default_use_transient_executioner

bool TestAction::_default_use_transient_executioner
protectedinherited

Default for option to use a transient executioner.

Definition at line 132 of file TestAction.h.

Referenced by TestAction::addExecutioner(), and ClosureTestAction::ClosureTestAction().

◆ _e_name

const VariableName FlowModelSetup1Phase::_e_name
protectedinherited

◆ _fe_family [1/2]

MooseEnum FlowModelSetup::_fe_family
protectedinherited

Definition at line 70 of file FlowModelSetup.h.

Referenced by FlowModelSetup::addSolutionVariable().

◆ _fe_family [2/2]

const std::string TestAction::_fe_family
protectedinherited

◆ _fe_order [1/2]

MooseEnum FlowModelSetup::_fe_order
protectedinherited

◆ _fe_order [2/2]

const std::string TestAction::_fe_order
protectedinherited

◆ _fp_1phase_name

const UserObjectName FlowModelSetup1Phase::_fp_1phase_name
protectedinherited

◆ _gravity_magnitude

const Real& FlowModelSetup::_gravity_magnitude
protectedinherited

Gravitational acceleration magnitude.

Definition at line 74 of file FlowModelSetup.h.

◆ _H_name

const VariableName FlowModelSetup1Phase::_H_name
protectedinherited

Name of specific total enthalpy variable.

Definition at line 68 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addInitialConditions(), and FlowModelSetup1Phase::addNonConstantAuxVariables().

◆ _mat_property_names

const std::vector<std::string> TestAction::_mat_property_names
protectedinherited

List of material properties to add.

Definition at line 145 of file TestAction.h.

Referenced by TestAction::addMaterials(), and TestAction::TestAction().

◆ _mat_property_values

const std::vector<FunctionName> TestAction::_mat_property_values
protectedinherited

List of function names for material properties to add.

Definition at line 147 of file TestAction.h.

Referenced by TestAction::addMaterials(), and TestAction::TestAction().

◆ _mu_name

const VariableName FlowModelSetup1Phase::_mu_name
protectedinherited

Name of dynamic viscosity variable.

Definition at line 70 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addMaterials().

◆ _p_fn

const FunctionName FlowModelSetup1Phase::_p_fn
protectedinherited

Pressure function name.

Definition at line 30 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addInitialConditions().

◆ _p_name

const VariableName FlowModelSetup1Phase::_p_name
protectedinherited

Name of pressure variable.

Definition at line 60 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addInitialConditions(), and FlowModelSetup1Phase::addNonConstantAuxVariables().

◆ _rho_name

const VariableName FlowModelSetup1Phase::_rho_name
protectedinherited

◆ _rhoA_name

const VariableName FlowModelSetup1Phase::_rhoA_name
protectedinherited

◆ _rhoEA_name

const VariableName FlowModelSetup1Phase::_rhoEA_name
protectedinherited

◆ _rhouA_name

const VariableName FlowModelSetup1Phase::_rhouA_name
protectedinherited

◆ _scalar_variable_values

const std::vector<FunctionName> TestAction::_scalar_variable_values
protectedinherited

List of values for the scalar variables to add.

Definition at line 137 of file TestAction.h.

Referenced by TestAction::addObjects(), and TestAction::TestAction().

◆ _scalar_variables

const std::vector<VariableName> TestAction::_scalar_variables
protectedinherited

List of scalar variables to add.

Definition at line 135 of file TestAction.h.

Referenced by TestAction::addObjects(), and TestAction::TestAction().

◆ _snes_test_err

const std::string JacobianTestAction::_snes_test_err
protectedinherited

Finite differencing parameter.

Definition at line 26 of file JacobianTestAction.h.

Referenced by JacobianTestAction::addPreconditioner().

◆ _T_fn

const FunctionName FlowModelSetup1Phase::_T_fn
protectedinherited

Temperature function name.

Definition at line 32 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addInitialConditions().

◆ _T_name

const VariableName FlowModelSetup1Phase::_T_name
protectedinherited

Name of temperature variable.

Definition at line 62 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addInitialConditions(), and FlowModelSetup1Phase::addNonConstantAuxVariables().

◆ _this_action_factory

ActionFactory& FlowModelSetup::_this_action_factory
protectedinherited

◆ _this_action_warehouse

ActionWarehouse& FlowModelSetup::_this_action_warehouse
protectedinherited

◆ _this_app

MooseApp& FlowModelSetup::_this_app
protectedinherited

Definition at line 66 of file FlowModelSetup.h.

◆ _this_params

const InputParameters& FlowModelSetup::_this_params
protectedinherited

Definition at line 65 of file FlowModelSetup.h.

Referenced by FlowModelSetup::getParam().

◆ _unity_name

const VariableName FlowModelSetup1Phase::_unity_name
protectedinherited

Name of unity.

Definition at line 44 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addMaterials().

◆ _v_name

const VariableName FlowModelSetup1Phase::_v_name
protectedinherited

◆ _vel_fn

const FunctionName FlowModelSetup1Phase::_vel_fn
protectedinherited

Velocity function name.

Definition at line 34 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addInitialConditions().

◆ _vel_name

const VariableName FlowModelSetup1Phase::_vel_name
protectedinherited

Name of velocity variable.

Definition at line 58 of file FlowModelSetup1Phase.h.

Referenced by FlowModelSetup1Phase::addInitialConditions(), and FlowModelSetup1Phase::addNonConstantAuxVariables().


The documentation for this class was generated from the following files: