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 | Private Member Functions | List of all members
ReactionNetworkPhysicsBase Class Reference

Base class to host all common parameters and attributes of Physics actions to solve equations for multiple species involved in chemical reactions. More...

#include <ReactionNetworkPhysicsBase.h>

Inheritance diagram for ReactionNetworkPhysicsBase:
[legend]

Public Types

typedef DataFileName DataFileParameterType
 

Public Member Functions

 ReactionNetworkPhysicsBase (const InputParameters &parameters)
 
void addComponent (const ActionComponent &component) override
 
virtual InputParameters getAdditionalRMParams () const
 
virtual void act () override final
 
virtual void actOnAdditionalTasks ()
 
void addBlocks (const std::vector< SubdomainName > &blocks)
 
void addBlocksById (const std::vector< SubdomainID > &block_ids)
 
const std::vector< SubdomainName > & blocks () const
 
bool checkBlockRestrictionIdentical (const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
 
bool hasBlocks (const std::vector< SubdomainName > &blocks) const
 
const TgetCoupledPhysics (const PhysicsName &phys_name, const bool allow_fail=false) const
 
const std::vector< T *> getCoupledPhysics (const bool allow_fail=false) const
 
unsigned int dimension () const
 
const ActionComponentgetActionComponent (const ComponentName &comp_name) const
 
void checkComponentType (const ActionComponent &component) const
 
const std::vector< VariableName > & solverVariableNames () const
 
const std::vector< VariableName > & auxVariableNames () const
 
void timedAct ()
 
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
 
const std::string & name () const
 
std::string typeAndName () const
 
MooseObjectParameterName uniqueParameterName (const std::string &parameter_name) const
 
MooseObjectName uniqueName () const
 
const InputParametersparameters () const
 
const hit::Node * getHitNode () const
 
bool hasBase () const
 
const std::string & getBase () const
 
const TgetParam (const std::string &name) const
 
std::vector< std::pair< T1, T2 > > getParam (const std::string &param1, const std::string &param2) const
 
const TqueryParam (const std::string &name) const
 
const TgetRenamedParam (const std::string &old_name, const std::string &new_name) const
 
T getCheckedPointerParam (const std::string &name, const std::string &error_string="") const
 
bool haveParameter (const std::string &name) const
 
bool isParamValid (const std::string &name) const
 
bool isParamSetByUser (const std::string &name) const
 
void connectControllableParams (const std::string &parameter, const std::string &object_type, const std::string &object_name, const std::string &object_parameter) const
 
void paramError (const std::string &param, Args... args) const
 
void paramWarning (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
 
std::string messagePrefix (const bool hit_prefix=true) const
 
std::string errorPrefix (const std::string &) const
 
void mooseError (Args &&... args) const
 
void mooseDocumentedError (const std::string &repo_name, const unsigned int issue_num, Args &&... args) const
 
void mooseErrorNonPrefixed (Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseDeprecatedNoTrace (Args &&... args) const
 
void mooseInfo (Args &&... args) const
 
void callMooseError (std::string msg, const bool with_prefix, const hit::Node *node=nullptr, const bool show_trace=true) 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 ()
 
void assertParamDefined (const std::string &libmesh_dbg_var(param)) const
 
const Parallel::Communicator & comm () const
 
processor_id_type n_processors () const
 
processor_id_type processor_id () const
 

Static Public Member Functions

static InputParameters validParams ()
 
static void callMooseError (MooseApp *const app, const InputParameters &params, std::string msg, const bool with_prefix, const hit::Node *node, const bool show_trace=true)
 

Public Attributes

 usingCombinedWarningSolutionWarnings
 
const ConsoleStream _console
 

Static Public Attributes

static const std::string unique_action_name_param
 
static const std::string type_param
 
static const std::string name_param
 
static const std::string unique_name_param
 
static const std::string app_param
 
static const std::string moose_base_param
 
static const std::string kokkos_object_param
 
static constexpr auto SYSTEM
 
static constexpr auto NAME
 

Protected Member Functions

void assertParamDefined (const std::string &param) const
 
bool isTransient () const
 
FactorygetFactory ()
 
FactorygetFactory () const
 
virtual FEProblemBasegetProblem ()
 
virtual const FEProblemBasegetProblem () const
 
void prepareCopyVariablesFromMesh () const
 
void copyVariablesFromMesh (const std::vector< VariableName > &variables_to_copy, bool are_nonlinear=true)
 
std::string prefix () const
 
void saveSolverVariableName (const VariableName &var_name)
 
void saveAuxVariableName (const VariableName &var_name)
 
bool variableExists (const VariableName &var_name, bool error_if_aux) const
 
bool solverVariableExists (const VariableName &var_name) const
 
const SolverSystemName & getSolverSystem (unsigned int variable_index) const
 
const SolverSystemName & getSolverSystem (const VariableName &variable_name) const
 
void addRequiredPhysicsTask (const std::string &task)
 
void assignBlocks (InputParameters &params, const std::vector< SubdomainName > &blocks) const
 
bool allMeshBlocks (const std::vector< SubdomainName > &blocks) const
 
bool allMeshBlocks (const std::set< SubdomainName > &blocks) const
 
std::set< SubdomainIDgetSubdomainIDs (const std::set< SubdomainName > &blocks) const
 
std::vector< std::string > getSubdomainNamesAndIDs (const std::set< SubdomainID > &blocks) const
 
void addPetscPairsToPetscOptions (const std::vector< std::pair< MooseEnumItem, std::string >> &petsc_pair_options)
 
bool isVariableFV (const VariableName &var_name) const
 
bool isVariableScalar (const VariableName &var_name) const
 
bool shouldCreateVariable (const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool error_if_aux)
 
bool shouldCreateIC (const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool ic_is_default_ic, const bool error_if_already_defined) const
 
bool shouldCreateTimeDerivative (const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool error_if_already_defined) const
 
void reportPotentiallyMissedParameters (const std::vector< std::string > &param_names, const std::string &object_type, const std::string &object_name="") const
 
virtual void checkIntegrity () const
 
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 TgetMeshProperty (const std::string &data_name, const std::string &prefix)
 
const TgetMeshProperty (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
 
void flagInvalidSolutionInternal (const InvalidSolutionID invalid_solution_id) const
 
InvalidSolutionID registerInvalidSolutionInternal (const std::string &message, const bool warning) const
 
void checkParamsBothSetOrNotSet (const std::string &param1, const std::string &param2) const
 
void checkSecondParamSetOnlyIfFirstOneTrue (const std::string &param1, const std::string &param2) const
 
void checkSecondParamSetOnlyIfFirstOneSet (const std::string &param1, const std::string &param2) const
 
void checkSecondParamNotSetIfFirstOneSet (const std::string &param1, const std::string &param2) const
 
void checkVectorParamsSameLength (const std::string &param1, const std::string &param2) const
 
void checkVectorParamAndMultiMooseEnumLength (const std::string &param1, const std::string &param2) const
 
void checkTwoDVectorParamsSameLength (const std::string &param1, const std::string &param2) const
 
void checkVectorParamsNoOverlap (const std::vector< std::string > &param_vecs) const
 
void checkTwoDVectorParamsNoRespectiveOverlap (const std::vector< std::string > &param_vecs) const
 
void checkTwoDVectorParamInnerSameLengthAsOneDVector (const std::string &param1, const std::string &param2) const
 
void checkTwoDVectorParamMultiMooseEnumSameLength (const std::string &param1, const std::string &param2, const bool error_for_param2) const
 
void checkVectorParamNotEmpty (const std::string &param1) const
 
void checkVectorParamsSameLengthIfSet (const std::string &param1, const std::string &param2, const bool ignore_empty_default_param2=false) const
 
void checkVectorParamLengthSameAsCombinedOthers (const std::string &param1, const std::string &param2, const std::string &param3) const
 
void checkBlockwiseConsistency (const std::string &block_param_name, const std::vector< std::string > &parameter_names) const
 
bool parameterConsistent (const InputParameters &other_param, const std::string &param_name) const
 
void warnInconsistent (const InputParameters &parameters, const std::string &param_name) const
 
void errorDependentParameter (const std::string &param1, const std::string &value_not_set, const std::vector< std::string > &dependent_params) const
 
void errorInconsistentDependentParameter (const std::string &param1, const std::string &value_set, const std::vector< std::string > &dependent_params) const
 

Static Protected Member Functions

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

Protected Attributes

const std::vector< VariableName > & _solver_species
 Name of the species variables to solve for in the reaction network. More...
 
const unsigned int _num_solver_species
 Number of species to solve for. More...
 
const std::vector< AuxVariableName > & _aux_species
 Name of the species variables that can be computed without additional solves, simply auxkernels. More...
 
const unsigned int _num_aux_species
 Number of auxiliary species. More...
 
std::vector< std::string > _reactions_input
 Reaction network as a vector of lines for pretty output. More...
 
const std::vector< ReactionNetworkUtils::Reaction_reactions
 Reaction network after being parsed in initializePhysics() More...
 
const unsigned int _num_reactions
 Number of reactions involved in the network. More...
 
std::vector< SolverSystemName > _system_names
 
std::vector< unsigned int_system_numbers
 
const bool _verbose
 
const MooseEnum_preconditioning
 
std::vector< SubdomainName > _blocks
 
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
 
Factory_factory
 
ActionFactory_action_factory
 
const std::string & _type
 
const std::string & _name
 
const InputParameters_pars
 
MooseApp_pg_moose_app
 
const std::string _prefix
 
const Parallel::Communicator & _communicator
 

Private Member Functions

virtual void addSolverVariables () override
 Add solver variables (currently coded for CGFE) More...
 
virtual void addAuxiliaryVariables () override
 Add nodal auxiliary variables. More...
 
virtual void addPreconditioning () override
 Add default preconditioning options (not implemented at this time) More...
 
virtual void addInitialConditions () override
 Add initial conditions for the solver variable (auxiliary not implemented) More...
 

Detailed Description

Base class to host all common parameters and attributes of Physics actions to solve equations for multiple species involved in chemical reactions.

For example, reaction kinetics, but also, equilibrium.

Definition at line 28 of file ReactionNetworkPhysicsBase.h.

Constructor & Destructor Documentation

◆ ReactionNetworkPhysicsBase()

ReactionNetworkPhysicsBase::ReactionNetworkPhysicsBase ( const InputParameters parameters)

Definition at line 39 of file ReactionNetworkPhysicsBase.C.

41  _solver_species(getParam<std::vector<VariableName>>("solver_variables")),
43  _aux_species(getParam<std::vector<AuxVariableName>>("auxiliary_variables")),
45  _reactions(
46  ReactionNetworkUtils::parseReactionNetwork(getParam<std::string>("reactions"), _verbose)),
48 {
49  // Keep track of variables
50  for (const auto & var_name : _solver_species)
51  saveSolverVariableName(var_name);
52  for (const auto & var_name : _aux_species)
53  saveAuxVariableName(var_name);
54 
55  // Parameter checking
56  if (isParamValid("initial_conditions"))
57  checkVectorParamsSameLength<VariableName, MooseFunctorName>("solver_variables",
58  "initial_conditions");
59  if (isParamValid("equation_scaling"))
60  checkVectorParamsSameLength<VariableName, Real>("solver_variables", "equation_scaling");
61 
62  addRequiredPhysicsTask("add_ic");
63  addRequiredPhysicsTask("add_variable");
64  addRequiredPhysicsTask("add_aux_variable");
65  addRequiredPhysicsTask("init_physics");
66 
67  // Parse the lines in the reaction
68  std::stringstream reactions_param(getParam<std::string>("reactions"));
69  std::string line;
70  while (std::getline(reactions_param, line, '\n'))
71  _reactions_input.push_back(line);
72  mooseAssert(_num_reactions == _reactions_input.size(),
73  "Should be the same size. Extra line break in the reaction network?");
74 }
const std::vector< ReactionNetworkUtils::Reaction > _reactions
Reaction network after being parsed in initializePhysics()
const T & getParam(const std::string &name) const
std::vector< std::string > _reactions_input
Reaction network as a vector of lines for pretty output.
void addRequiredPhysicsTask(const std::string &task)
const unsigned int _num_reactions
Number of reactions involved in the network.
const InputParameters & parameters() const
const unsigned int _num_aux_species
Number of auxiliary species.
const std::vector< VariableName > & _solver_species
Name of the species variables to solve for in the reaction network.
const bool _verbose
void saveAuxVariableName(const VariableName &var_name)
const std::vector< AuxVariableName > & _aux_species
Name of the species variables that can be computed without additional solves, simply auxkernels...
PhysicsBase(const InputParameters &parameters)
std::vector< Reaction > parseReactionNetwork(const std::string &reaction_network_string, bool output_to_cout)
Parses the reaction network from a string form to a vector a Reaction.
bool isParamValid(const std::string &name) const
const unsigned int _num_solver_species
Number of species to solve for.
void saveSolverVariableName(const VariableName &var_name)

Member Function Documentation

◆ addAuxiliaryVariables()

void ReactionNetworkPhysicsBase::addAuxiliaryVariables ( )
overrideprivatevirtual

Add nodal auxiliary variables.

Reimplemented from PhysicsBase.

Definition at line 105 of file ReactionNetworkPhysicsBase.C.

106 {
107  for (const auto i : index_range(_aux_species))
108  {
109  const auto & var_name = _aux_species[i];
110  // If the variable was added outside the Physics
111  if (variableExists(var_name, /*error_if_aux*/ false))
112  {
113  reportPotentiallyMissedParameters({"variable_order"}, "MooseVariable", var_name);
114  continue;
115  }
116 
117  const std::string variable_type = "MooseVariable";
118  InputParameters params = getFactory().getValidParams(variable_type);
119  params.set<MooseEnum>("order") = getParam<MooseEnum>("variable_order");
120  assignBlocks(params, _blocks);
121  getProblem().addAuxVariable(variable_type, var_name, params);
122  }
123 }
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
void reportPotentiallyMissedParameters(const std::vector< std::string > &param_names, const std::string &object_type, const std::string &object_name="") const
virtual void addAuxVariable(const std::string &var_type, const std::string &var_name, InputParameters &params)
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
const std::vector< AuxVariableName > & _aux_species
Name of the species variables that can be computed without additional solves, simply auxkernels...
bool variableExists(const VariableName &var_name, bool error_if_aux) const
auto index_range(const T &sizable)

◆ addComponent()

void ReactionNetworkPhysicsBase::addComponent ( const ActionComponent component)
overridevirtual

Reimplemented from PhysicsBase.

Definition at line 133 of file ReactionNetworkPhysicsBase.C.

134 {
135  for (const auto & block : component.blocks())
136  _blocks.push_back(block);
137 }
static const std::string component
Definition: NS.h:157
std::vector< SubdomainName > _blocks

◆ addInitialConditions()

void ReactionNetworkPhysicsBase::addInitialConditions ( )
overrideprivatevirtual

Add initial conditions for the solver variable (auxiliary not implemented)

Reimplemented from PhysicsBase.

Definition at line 140 of file ReactionNetworkPhysicsBase.C.

141 {
142  InputParameters params = getFactory().getValidParams("FunctorIC");
143  assignBlocks(params, _blocks);
144  std::vector<MooseFunctorName> empty_functor_vector;
145  const auto & initial_functors =
146  isParamValid("initial_conditions")
147  ? getParam<std::vector<MooseFunctorName>>("initial_conditions")
148  : empty_functor_vector;
149 
150  for (const auto i : index_range(_solver_species))
151  {
152  const auto & var_name = _solver_species[i];
153  // always obey the user specification of initial conditions
154  // Base class does not have a default but derived classes could set one
155  if (isParamValid("initial_conditions") &&
156  shouldCreateIC(var_name,
157  _blocks,
158  /*whether IC is a default*/ !isParamSetByUser("initial_conditions"),
159  /*error if already an IC*/ true))
160  {
161  params.set<VariableName>("variable") = var_name;
162  params.set<MooseFunctorName>("functor") = initial_functors[i];
163  getProblem().addInitialCondition("FunctorIC", prefix() + var_name + "_ic", params);
164  }
165  }
166 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
const std::vector< VariableName > & _solver_species
Name of the species variables to solve for in the reaction network.
bool shouldCreateIC(const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool ic_is_default_ic, const bool error_if_already_defined) const
std::vector< SubdomainName > _blocks
virtual void addInitialCondition(const std::string &ic_name, const std::string &name, InputParameters &parameters)
virtual FEProblemBase & getProblem()
bool isParamValid(const std::string &name) const
bool isParamSetByUser(const std::string &name) const
auto index_range(const T &sizable)

◆ addPreconditioning()

void ReactionNetworkPhysicsBase::addPreconditioning ( )
overrideprivatevirtual

Add default preconditioning options (not implemented at this time)

Reimplemented from PhysicsBase.

Definition at line 126 of file ReactionNetworkPhysicsBase.C.

127 {
128  // TODO: identify fully independent or sequential groups in the reaction network
129  // Solve using a segregated approach in the order of the sequence
130 }

◆ addSolverVariables()

void ReactionNetworkPhysicsBase::addSolverVariables ( )
overrideprivatevirtual

Add solver variables (currently coded for CGFE)

Reimplemented from PhysicsBase.

Definition at line 77 of file ReactionNetworkPhysicsBase.C.

78 {
79  for (const auto i : index_range(_solver_species))
80  {
81  const auto & var_name = _solver_species[i];
82  // If the variable was added outside the Physics
83  if (variableExists(var_name, /*error_if_aux*/ true))
84  {
86  {"variable_order", "system_names", "equation_scaling"}, "MooseVariable", var_name);
87  continue;
88  }
89 
90  const std::string variable_type = "MooseVariable";
91  InputParameters params = getFactory().getValidParams(variable_type);
92  params.set<MooseEnum>("order") = getParam<MooseEnum>("variable_order");
93  if (isParamValid("equation_scaling"))
94  // all our variables have a single component
95  params.set<std::vector<Real>>("scaling") = {
96  getParam<std::vector<Real>>("equation_scaling")[i]};
97  assignBlocks(params, _blocks);
98  params.set<SolverSystemName>("solver_sys") = getSolverSystem(var_name);
99 
100  getProblem().addVariable(variable_type, var_name, params);
101  }
102 }
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
void reportPotentiallyMissedParameters(const std::vector< std::string > &param_names, const std::string &object_type, const std::string &object_name="") const
const std::vector< VariableName > & _solver_species
Name of the species variables to solve for in the reaction network.
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
const SolverSystemName & getSolverSystem(unsigned int variable_index) const
virtual void addVariable(const std::string &var_type, const std::string &var_name, InputParameters &params)
bool variableExists(const VariableName &var_name, bool error_if_aux) const
bool isParamValid(const std::string &name) const
auto index_range(const T &sizable)

◆ validParams()

InputParameters ReactionNetworkPhysicsBase::validParams ( )
static

Definition at line 14 of file ReactionNetworkPhysicsBase.C.

Referenced by AqueousReactionsEquilibriumPhysics::validParams().

15 {
17  params.addClassDescription("Base class to create a reaction network Physics from.");
18 
19  // Variables parameters
20  params.addRequiredParam<std::vector<VariableName>>("solver_variables", "Species to solve for");
21  params.addRequiredParam<std::vector<AuxVariableName>>(
22  "auxiliary_variables",
23  "Additional species to output the concentration of, which do not require an additional "
24  "equation to obtain");
25  params.transferParam<MooseEnum>(MooseVariableBase::validParams(), "order", "variable_order");
26  params.addParam<std::vector<Real>>("equation_scaling",
27  "Scaling factor to apply to each equation");
28 
29  // Initial conditions
30  params.addParam<std::vector<MooseFunctorName>>("initial_conditions",
31  "Initial conditions for the species to solve for");
32 
33  // Reaction network
34  params.addParam<std::string>("reactions", "The list of chemical reactions");
35 
36  return params;
37 }
static InputParameters validParams()
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
void addRequiredParam(const std::string &name, const std::string &doc_string)
void transferParam(const InputParameters &source_param, const std::string &name, const std::string &new_name="", const std::string &new_description="")
static InputParameters validParams()
void addClassDescription(const std::string &doc_string)

Member Data Documentation

◆ _aux_species

const std::vector<AuxVariableName>& ReactionNetworkPhysicsBase::_aux_species
protected

Name of the species variables that can be computed without additional solves, simply auxkernels.

Definition at line 43 of file ReactionNetworkPhysicsBase.h.

Referenced by AqueousReactionsEquilibriumPhysics::addAuxiliaryKernels(), addAuxiliaryVariables(), and ReactionNetworkPhysicsBase().

◆ _num_aux_species

const unsigned int ReactionNetworkPhysicsBase::_num_aux_species
protected

Number of auxiliary species.

Definition at line 45 of file ReactionNetworkPhysicsBase.h.

◆ _num_reactions

const unsigned int ReactionNetworkPhysicsBase::_num_reactions
protected

◆ _num_solver_species

const unsigned int ReactionNetworkPhysicsBase::_num_solver_species
protected

Number of species to solve for.

Definition at line 41 of file ReactionNetworkPhysicsBase.h.

◆ _reactions

const std::vector<ReactionNetworkUtils::Reaction> ReactionNetworkPhysicsBase::_reactions
protected

Reaction network after being parsed in initializePhysics()

Definition at line 49 of file ReactionNetworkPhysicsBase.h.

Referenced by AqueousReactionsEquilibriumPhysics::AqueousReactionsEquilibriumPhysics().

◆ _reactions_input

std::vector<std::string> ReactionNetworkPhysicsBase::_reactions_input
protected

Reaction network as a vector of lines for pretty output.

Definition at line 47 of file ReactionNetworkPhysicsBase.h.

Referenced by AqueousReactionsEquilibriumPhysics::AqueousReactionsEquilibriumPhysics(), and ReactionNetworkPhysicsBase().

◆ _solver_species

const std::vector<VariableName>& ReactionNetworkPhysicsBase::_solver_species
protected

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