https://mooseframework.inl.gov
AddTimeDependentReactionSolverAction.C
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://mooseframework.inl.gov
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
12 #include "FEProblem.h"
13 
14 registerMooseAction("GeochemistryApp", AddTimeDependentReactionSolverAction, "setup_mesh");
15 registerMooseAction("GeochemistryApp", AddTimeDependentReactionSolverAction, "init_mesh");
16 registerMooseAction("GeochemistryApp", AddTimeDependentReactionSolverAction, "create_problem");
17 registerMooseAction("GeochemistryApp", AddTimeDependentReactionSolverAction, "add_output");
18 registerMooseAction("GeochemistryApp", AddTimeDependentReactionSolverAction, "add_user_object");
19 registerMooseAction("GeochemistryApp",
21  "add_geochemistry_molality_aux");
22 registerMooseAction("GeochemistryApp",
24  "add_geochemistry_reactor");
25 
28 {
31  params.addClassDescription(
32  "Action that sets up a time-dependent equilibrium reaction solver. This creates creates a "
33  "time-dependent geochemistry solver, and adds AuxVariables corresonding to the molalities, "
34  "etc");
35 
36  return params;
37 }
38 
40  const InputParameters & params)
42 {
43 }
44 
45 void
47 {
48  // create Output and Aux objects
50 
51  // Set up an arbitrary mesh
52  if (_current_task == "setup_mesh")
53  {
54  const std::string class_name = "GeneratedMesh";
55  InputParameters params = _factory.getValidParams(class_name);
56  params.set<MooseEnum>("dim") = "1";
57  _mesh = _factory.create<MooseMesh>(class_name, "mesh", params);
58  }
59  // Initialize the arbitrary mesh
60  else if (_current_task == "init_mesh")
61  {
62  _mesh->init();
63  }
64  // Create a "solve=false" FEProblem, if appropriate
65  else if (_current_task == "create_problem")
66  {
67  const std::string class_name = "FEProblem";
68  InputParameters params = _factory.getValidParams(class_name);
69  params.set<MooseMesh *>("mesh") = _mesh.get();
70  params.set<bool>("use_nonlinear") = true;
71  params.set<bool>("solve") = getParam<bool>("include_moose_solve");
72  _problem = _factory.create<FEProblemBase>(class_name, "Problem", params);
73  _problem->setKernelCoverageCheck(getParam<bool>("include_moose_solve")
76  }
77  else if (_current_task == "add_geochemistry_reactor")
78  {
79  const std::string class_name = "GeochemistryTimeDependentReactor";
80  auto params = _factory.getValidParams(class_name);
81  // Only pass parameters that were supplied to this action
82  if (isParamValid("block"))
83  params.set<std::vector<SubdomainName>>("block") =
84  getParam<std::vector<SubdomainName>>("block");
85  if (isParamValid("boundary"))
86  params.set<std::vector<BoundaryName>>("boundary") =
87  getParam<std::vector<BoundaryName>>("boundary");
88  params.set<UserObjectName>("model_definition") = getParam<UserObjectName>("model_definition");
89  if (isParamValid("swap_out_of_basis"))
90  params.set<std::vector<std::string>>("swap_out_of_basis") =
91  getParam<std::vector<std::string>>("swap_out_of_basis");
92  if (isParamValid("swap_into_basis"))
93  params.set<std::vector<std::string>>("swap_into_basis") =
94  getParam<std::vector<std::string>>("swap_into_basis");
95  params.set<MultiMooseEnum>("constraint_meaning") =
96  getParam<MultiMooseEnum>("constraint_meaning");
97  params.set<std::vector<std::string>>("constraint_species") =
98  getParam<std::vector<std::string>>("constraint_species");
99  params.set<std::vector<Real>>("constraint_value") =
100  getParam<std::vector<Real>>("constraint_value");
101  params.set<MultiMooseEnum>("constraint_unit") = getParam<MultiMooseEnum>("constraint_unit");
102  params.set<Real>("max_ionic_strength") = getParam<Real>("max_ionic_strength");
103  params.set<unsigned>("extra_iterations_to_make_consistent") =
104  getParam<unsigned>("extra_iterations_to_make_consistent");
105  params.applySpecificParameters(parameters(), {"temperature"});
106  params.applySpecificParameters(parameters(), {"cold_temperature"});
107  params.set<unsigned>("heating_increments") = getParam<unsigned>("heating_increments");
108  params.set<Real>("stoichiometry_tolerance") = getParam<Real>("stoichiometry_tolerance");
109  params.set<std::string>("charge_balance_species") =
110  getParam<std::string>("charge_balance_species");
111  if (isParamValid("prevent_precipitation"))
112  params.set<std::vector<std::string>>("prevent_precipitation") =
113  getParam<std::vector<std::string>>("prevent_precipitation");
114  params.set<Real>("abs_tol") = getParam<Real>("abs_tol");
115  params.set<Real>("rel_tol") = getParam<Real>("rel_tol");
116  params.set<Real>("min_initial_molality") = getParam<Real>("min_initial_molality");
117  params.set<unsigned>("max_iter") = getParam<unsigned>("max_iter");
118  params.set<Real>("max_initial_residual") = getParam<Real>("max_initial_residual");
119  params.set<Real>("swap_threshold") = getParam<Real>("swap_threshold");
120  params.set<unsigned>("max_swaps_allowed") = getParam<unsigned>("max_swaps_allowed");
121  params.set<unsigned>("ramp_max_ionic_strength_initial") =
122  getParam<unsigned>("ramp_max_ionic_strength_initial");
123  params.set<unsigned>("ramp_max_ionic_strength_subsequent") =
124  getParam<unsigned>("ramp_max_ionic_strength_subsequent");
125  params.set<bool>("ionic_str_using_basis_only") = getParam<bool>("ionic_str_using_basis_only");
126  params.set<bool>("stoichiometric_ionic_str_using_Cl_only") =
127  getParam<bool>("stoichiometric_ionic_str_using_Cl_only");
128  params.set<Real>("close_system_at_time") = getParam<Real>("close_system_at_time");
129  if (isParamValid("remove_fixed_activity_name"))
130  params.set<std::vector<std::string>>("remove_fixed_activity_name") =
131  getParam<std::vector<std::string>>("remove_fixed_activity_name");
132  if (isParamValid("remove_fixed_activity_time"))
133  params.set<std::vector<Real>>("remove_fixed_activity_time") =
134  getParam<std::vector<Real>>("remove_fixed_activity_time");
135  if (isParamValid("source_species_names"))
136  params.set<std::vector<std::string>>("source_species_names") =
137  getParam<std::vector<std::string>>("source_species_names");
138  if (isParamValid("source_species_rates"))
139  params.applySpecificParameters(parameters(), {"source_species_rates"});
140  if (isParamValid("controlled_activity_name"))
141  params.set<std::vector<std::string>>("controlled_activity_name") =
142  getParam<std::vector<std::string>>("controlled_activity_name");
143  if (isParamValid("controlled_activity_value"))
144  params.applySpecificParameters(parameters(), {"controlled_activity_value"});
145  params.applySpecificParameters(parameters(), {"mode"});
146  params.set<Real>("initial_temperature") = getParam<Real>("initial_temperature");
147  params.set<bool>("evaluate_kinetic_rates_always") =
148  getParam<bool>("evaluate_kinetic_rates_always");
149  if (isParamValid("kinetic_species_name"))
150  params.set<std::vector<std::string>>("kinetic_species_name") =
151  getParam<std::vector<std::string>>("kinetic_species_name");
152  if (isParamValid("kinetic_species_initial_value"))
153  params.set<std::vector<Real>>("kinetic_species_initial_value") =
154  getParam<std::vector<Real>>("kinetic_species_initial_value");
155  if (isParamValid("kinetic_species_unit"))
156  params.set<MultiMooseEnum>("kinetic_species_unit") =
157  getParam<MultiMooseEnum>("kinetic_species_unit");
158  params.set<ExecFlagEnum>("execute_on") = {EXEC_TIMESTEP_END};
159  _problem->addUserObject(
160  class_name, getParam<UserObjectName>("geochemistry_reactor_name"), params);
161  }
162 }
static InputParameters validParams()
T & set(const std::string &name, bool quiet_mode=false)
std::shared_ptr< MooseObject > create(const std::string &obj_name, const std::string &name, const InputParameters &parameters, THREAD_ID tid=0, bool print_deprecated=true)
InputParameters getValidParams(const std::string &name) const
AddTimeDependentReactionSolverAction(const InputParameters &parameters)
const ExecFlagType EXEC_TIMESTEP_END
bool isParamValid(const std::string &name) const
Factory & _factory
const T & getParam(const std::string &name) const
const std::string & _current_task
Action that sets up a time-dependent equilibrium reaction solver.
std::shared_ptr< MooseMesh > & _mesh
static InputParameters sharedParams()
params that are shared with AddTimeDependentReactionSolverAction
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
void addClassDescription(const std::string &doc_string)
std::shared_ptr< FEProblemBase > & _problem
const InputParameters & parameters() const
Action that sets up GeochemistryConsoleOutput and various AuxVariables.
registerMooseAction("GeochemistryApp", AddTimeDependentReactionSolverAction, "setup_mesh")