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 | Private Attributes | List of all members
PNSFVSolidHeatTransferPhysics Class Referencefinal

Creates all the objects needed to solve the porous media solid energy equation. More...

#include <PNSFVSolidHeatTransferPhysics.h>

Inheritance diagram for PNSFVSolidHeatTransferPhysics:
[legend]

Public Types

typedef DataFileName DataFileParameterType
 

Public Member Functions

 PNSFVSolidHeatTransferPhysics (const InputParameters &parameters)
 
virtual void addFVBCs () override
 
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
 
virtual void addComponent (const ActionComponent &component)
 
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 VariableName & _temperature_name
 Name of the temperature variable. 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
 
virtual void addFVKernels () override
 
virtual void addMaterials () override
 
virtual InputParameters getAdditionalRMParams () const override
 
void addPINSSolidEnergyTimeKernels ()
 Functions adding kernels for the solid energy equation. More...
 
void addPINSSolidEnergyHeatConductionKernels ()
 
void addPINSSolidEnergyAmbientConvection ()
 
void addPINSSolidEnergyExternalHeatSource ()
 
bool processThermalConductivity ()
 Process thermal conductivity (multiple functor input options are available). More...
 
void checkFluidAndSolidHeatTransferPhysicsParameters () const
 Battery of additional checks on parameters. More...
 

Private Attributes

const NonlinearVariableName _solid_temperature_name
 Solid temperature name. More...
 
const NonlinearVariableName _fluid_temperature_name
 Fluid temperature name. More...
 
const MooseFunctorName _porosity_name
 Name of the porosity functor (usually material property) More...
 
const MooseFunctorName _density_name
 Name of the density functor (usually material property) More...
 
const MooseFunctorName _specific_heat_name
 Name of the specific heat functor (usually material property) More...
 
std::vector< std::vector< SubdomainName > > _thermal_conductivity_blocks
 Vector of subdomain groups where we want to have different thermal conduction. More...
 
std::vector< MooseFunctorName > _thermal_conductivity_name
 Name of the thermal conductivity functor for each block-group. More...
 
std::vector< std::vector< SubdomainName > > _ambient_convection_blocks
 Vector of subdomain groups where we want to have different ambient convection. More...
 
std::vector< MooseFunctorName > _ambient_convection_alpha
 Name of the ambient convection heat transfer coefficients for each block-group. More...
 
std::vector< MooseFunctorName > _ambient_temperature
 Name of the solid domain temperature for each block-group. More...
 

Detailed Description

Creates all the objects needed to solve the porous media solid energy equation.

Definition at line 18 of file PNSFVSolidHeatTransferPhysics.h.

Constructor & Destructor Documentation

◆ PNSFVSolidHeatTransferPhysics()

PNSFVSolidHeatTransferPhysics::PNSFVSolidHeatTransferPhysics ( const InputParameters parameters)

Definition at line 125 of file PNSFVSolidHeatTransferPhysics.C.

127  _solid_temperature_name(getParam<VariableName>("solid_temperature_variable")),
128  _fluid_temperature_name(getParam<NonlinearVariableName>("fluid_temperature_variable")),
129  _porosity_name(getParam<MooseFunctorName>(NS::porosity)),
130  _density_name(getParam<MooseFunctorName>("rho_solid")),
131  _specific_heat_name(getParam<MooseFunctorName>("cp_solid")),
133  parameters.isParamValid("thermal_conductivity_blocks")
134  ? getParam<std::vector<std::vector<SubdomainName>>>("thermal_conductivity_blocks")
135  : std::vector<std::vector<SubdomainName>>()),
137  getParam<std::vector<MooseFunctorName>>("thermal_conductivity_solid")),
139  getParam<std::vector<std::vector<SubdomainName>>>("ambient_convection_blocks")),
140  _ambient_convection_alpha(getParam<std::vector<MooseFunctorName>>("ambient_convection_alpha")),
141  _ambient_temperature(getParam<std::vector<MooseFunctorName>>("ambient_convection_temperature"))
142 {
144 
145  // Parameter checks
146  if (getParam<std::vector<MooseFunctorName>>("ambient_convection_temperature").size() != 1)
147  checkVectorParamsSameLengthIfSet<MooseFunctorName, MooseFunctorName>(
148  "ambient_convection_alpha", "ambient_convection_temperature");
149  checkSecondParamSetOnlyIfFirstOneSet("external_heat_source", "external_heat_source_coeff");
151  paramError("solid_temperature_variable",
152  "Solid and fluid cannot share the same temperature variable");
153  // More parameter checks in ambient convection creation
154 }
void paramError(const std::string &param, Args... args) const
const T & getParam(const std::string &name) const
const InputParameters & parameters() const
std::vector< MooseFunctorName > _thermal_conductivity_name
Name of the thermal conductivity functor for each block-group.
void checkSecondParamSetOnlyIfFirstOneSet(const std::string &param1, const std::string &param2) const
static const std::string porosity
Definition: NS.h:108
std::vector< MooseFunctorName > _ambient_convection_alpha
Name of the ambient convection heat transfer coefficients for each block-group.
const MooseFunctorName _specific_heat_name
Name of the specific heat functor (usually material property)
HeatConductionFV(const InputParameters &parameters)
const NonlinearVariableName _solid_temperature_name
Solid temperature name.
std::vector< std::vector< SubdomainName > > _thermal_conductivity_blocks
Vector of subdomain groups where we want to have different thermal conduction.
std::vector< MooseFunctorName > _ambient_temperature
Name of the solid domain temperature for each block-group.
const NonlinearVariableName _fluid_temperature_name
Fluid temperature name.
const MooseFunctorName _porosity_name
Name of the porosity functor (usually material property)
const MooseFunctorName _density_name
Name of the density functor (usually material property)
void saveSolverVariableName(const VariableName &var_name)
std::vector< std::vector< SubdomainName > > _ambient_convection_blocks
Vector of subdomain groups where we want to have different ambient convection.
bool isParamValid(const std::string &name) const

Member Function Documentation

◆ addFVBCs()

void HeatConductionFV::addFVBCs ( )
overridevirtualinherited

Reimplemented from PhysicsBase.

Definition at line 137 of file HeatConductionFV.C.

138 {
139  // We dont need to add anything for insulated boundaries, 0 flux is the default boundary condition
140  if (isParamValid("heat_flux_boundaries"))
141  {
142  const std::string bc_type = "FVFunctorNeumannBC";
143  InputParameters params = getFactory().getValidParams(bc_type);
144  params.set<NonlinearVariableName>("variable") = _temperature_name;
145 
146  const auto & heat_flux_boundaries = getParam<std::vector<BoundaryName>>("heat_flux_boundaries");
147  const auto & boundary_heat_fluxes =
148  getParam<std::vector<MooseFunctorName>>("boundary_heat_fluxes");
149  // Optimization if all the same
150  if (std::set<MooseFunctorName>(boundary_heat_fluxes.begin(), boundary_heat_fluxes.end())
151  .size() == 1 &&
152  heat_flux_boundaries.size() > 1)
153  {
154  params.set<std::vector<BoundaryName>>("boundary") = heat_flux_boundaries;
155  params.set<MooseFunctorName>("functor") = boundary_heat_fluxes[0];
156  getProblem().addFVBC(bc_type, prefix() + _temperature_name + "_heat_flux_bc_all", params);
157  }
158  else
159  {
160  for (const auto i : index_range(heat_flux_boundaries))
161  {
162  params.set<std::vector<BoundaryName>>("boundary") = {heat_flux_boundaries[i]};
163  params.set<MooseFunctorName>("functor") = boundary_heat_fluxes[i];
164  getProblem().addFVBC(bc_type,
165  prefix() + _temperature_name + "_heat_flux_bc_" +
166  heat_flux_boundaries[i],
167  params);
168  }
169  }
170  }
171  if (isParamValid("fixed_temperature_boundaries"))
172  {
173  const std::string bc_type = "FVFunctorDirichletBC";
174  InputParameters params = getFactory().getValidParams(bc_type);
175  params.set<NonlinearVariableName>("variable") = _temperature_name;
176 
177  const auto & temperature_boundaries =
178  getParam<std::vector<BoundaryName>>("fixed_temperature_boundaries");
179  const auto & boundary_temperatures =
180  getParam<std::vector<MooseFunctorName>>("boundary_temperatures");
181  // Optimization if all the same
182  if (std::set<MooseFunctorName>(boundary_temperatures.begin(), boundary_temperatures.end())
183  .size() == 1 &&
184  temperature_boundaries.size() > 1)
185  {
186  params.set<std::vector<BoundaryName>>("boundary") = temperature_boundaries;
187  params.set<MooseFunctorName>("functor") = boundary_temperatures[0];
188  getProblem().addFVBC(bc_type, prefix() + _temperature_name + "_dirichlet_bc_all", params);
189  }
190  else
191  {
192  for (const auto i : index_range(temperature_boundaries))
193  {
194  params.set<std::vector<BoundaryName>>("boundary") = {temperature_boundaries[i]};
195  params.set<MooseFunctorName>("functor") = boundary_temperatures[i];
196  getProblem().addFVBC(bc_type,
197  prefix() + _temperature_name + "_dirichlet_bc_" +
198  temperature_boundaries[i],
199  params);
200  }
201  }
202  }
203  if (isParamValid("fixed_convection_boundaries"))
204  {
205  const std::string bc_type = "FVFunctorConvectiveHeatFluxBC";
206  InputParameters params = getFactory().getValidParams(bc_type);
207  params.set<NonlinearVariableName>("variable") = _temperature_name;
208  params.set<bool>("is_solid") = true;
209  params.set<MooseFunctorName>("T_solid") = _temperature_name;
210 
211  const auto & convective_boundaries =
212  getParam<std::vector<BoundaryName>>("fixed_convection_boundaries");
213  const auto & boundary_T_fluid =
214  getParam<std::vector<MooseFunctorName>>("fixed_convection_T_fluid");
215  const auto & boundary_htc = getParam<std::vector<MooseFunctorName>>("fixed_convection_htc");
216  // Optimization if all the same
217  if (std::set<MooseFunctorName>(boundary_T_fluid.begin(), boundary_T_fluid.end()).size() == 1 &&
218  std::set<MooseFunctorName>(boundary_htc.begin(), boundary_htc.end()).size() == 1 &&
219  convective_boundaries.size() > 1)
220  {
221  params.set<std::vector<BoundaryName>>("boundary") = convective_boundaries;
222  params.set<MooseFunctorName>("T_bulk") = boundary_T_fluid[0];
223  params.set<MooseFunctorName>("heat_transfer_coefficient") = boundary_htc[0];
225  bc_type, prefix() + _temperature_name + "_fixed_convection_bc_all", params);
226  }
227  else
228  {
229  for (const auto i : index_range(convective_boundaries))
230  {
231  params.set<std::vector<BoundaryName>>("boundary") = {convective_boundaries[i]};
232  params.set<MooseFunctorName>("T_bulk") = boundary_T_fluid[i];
233  params.set<MooseFunctorName>("heat_transfer_coefficient") = boundary_htc[i];
234  getProblem().addFVBC(bc_type,
235  prefix() + _temperature_name + "_fixed_convection_bc_" +
236  convective_boundaries[i],
237  params);
238  }
239  }
240  }
241 }
std::string prefix() const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
virtual FEProblemBase & getProblem()
bool isParamValid(const std::string &name) const
const VariableName & _temperature_name
Name of the temperature variable.
virtual void addFVBC(const std::string &fv_bc_name, const std::string &name, InputParameters &parameters)
auto index_range(const T &sizable)

◆ addFVKernels()

void PNSFVSolidHeatTransferPhysics::addFVKernels ( )
overrideprivatevirtual

Reimplemented from HeatConductionFV.

Definition at line 179 of file PNSFVSolidHeatTransferPhysics.C.

180 {
181  // Check this physics against others
183 
184  if (isTransient())
186 
188  if (getParam<std::vector<MooseFunctorName>>("ambient_convection_alpha").size())
190  if (isParamValid("external_heat_source"))
192 }
const T & getParam(const std::string &name) const
void checkFluidAndSolidHeatTransferPhysicsParameters() const
Battery of additional checks on parameters.
void addPINSSolidEnergyTimeKernels()
Functions adding kernels for the solid energy equation.
bool isParamValid(const std::string &name) const
bool isTransient() const

◆ addMaterials()

void PNSFVSolidHeatTransferPhysics::addMaterials ( )
overrideprivatevirtual

Reimplemented from PhysicsBase.

Definition at line 372 of file PNSFVSolidHeatTransferPhysics.C.

373 {
374  if (!getParam<bool>("use_external_enthalpy_material"))
375  {
376  InputParameters params = getFactory().getValidParams("INSFVEnthalpyFunctorMaterial");
377  assignBlocks(params, _blocks);
378 
379  params.set<MooseFunctorName>(NS::density) = _density_name;
380  params.set<MooseFunctorName>(NS::cp) = _specific_heat_name;
381  params.set<MooseFunctorName>("temperature") = _solid_temperature_name;
382  params.set<MaterialPropertyName>("declare_suffix") = "solid";
383 
385  "INSFVEnthalpyFunctorMaterial", prefix() + "ins_enthalpy_material", params);
386  }
387 
388  // Combine the functors (combining scalars and vectors is not currently supported)
389  if (_thermal_conductivity_name.size() > 1)
390  {
391  const auto vector_conductivity = processThermalConductivity();
392  const auto combiner_functor = vector_conductivity ? "PiecewiseByBlockVectorFunctorMaterial"
393  : "PiecewiseByBlockFunctorMaterial";
394  InputParameters params = getFactory().getValidParams(combiner_functor);
395  params.set<MooseFunctorName>("prop_name") = prefix() + "combined_thermal_conductivity";
396  std::vector<SubdomainName> blocks_list;
397  std::map<std::string, std::string> blocks_to_functors;
398  for (const auto i : index_range(_thermal_conductivity_name))
399  {
400  for (const auto & block : _thermal_conductivity_blocks[i])
401  {
402  blocks_list.push_back(block);
403  blocks_to_functors.insert(
404  std::pair<std::string, std::string>(block, _thermal_conductivity_name[i]));
405  }
406  }
407  params.set<std::vector<SubdomainName>>("block") = blocks_list;
408  params.set<std::map<std::string, std::string>>("subdomain_to_prop_value") = blocks_to_functors;
409  getProblem().addMaterial(combiner_functor, prefix() + "thermal_conductivity_combiner", params);
410  }
411 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
virtual void addMaterial(const std::string &material_name, const std::string &name, InputParameters &parameters)
T & set(const std::string &name, bool quiet_mode=false)
static const std::string density
Definition: NS.h:34
InputParameters getValidParams(const std::string &name) const
std::vector< SubdomainName > _blocks
std::vector< MooseFunctorName > _thermal_conductivity_name
Name of the thermal conductivity functor for each block-group.
virtual FEProblemBase & getProblem()
static const std::string cp
Definition: NS.h:125
bool processThermalConductivity()
Process thermal conductivity (multiple functor input options are available).
const MooseFunctorName _specific_heat_name
Name of the specific heat functor (usually material property)
const NonlinearVariableName _solid_temperature_name
Solid temperature name.
std::vector< std::vector< SubdomainName > > _thermal_conductivity_blocks
Vector of subdomain groups where we want to have different thermal conduction.
const MooseFunctorName _density_name
Name of the density functor (usually material property)
auto index_range(const T &sizable)

◆ addPINSSolidEnergyAmbientConvection()

void PNSFVSolidHeatTransferPhysics::addPINSSolidEnergyAmbientConvection ( )
private

Definition at line 262 of file PNSFVSolidHeatTransferPhysics.C.

Referenced by addFVKernels().

263 {
264  const auto num_convection_blocks = _ambient_convection_blocks.size();
265  const auto num_used_blocks = num_convection_blocks ? num_convection_blocks : 1;
266 
267  // Check parameter. Late check in case the block was added by a Component
268  if (num_used_blocks != _ambient_convection_alpha.size())
269  paramError("ambient_convection_alpha",
270  "Number of ambient convection heat transfer coefficients (" +
271  std::to_string(_ambient_convection_alpha.size()) +
272  ") should match the number of "
273  "blocks (" +
274  std::to_string(num_convection_blocks) + ") each HTC is defined on.");
275 
276  const auto kernel_type = "PINSFVEnergyAmbientConvection";
277  InputParameters params = getFactory().getValidParams(kernel_type);
278  params.set<NonlinearVariableName>("variable") = _solid_temperature_name;
279  params.set<MooseFunctorName>(NS::T_solid) = _solid_temperature_name;
280  params.set<bool>("is_solid") = true;
281 
282  for (const auto block_i : make_range(num_used_blocks))
283  {
284  std::string block_name = "";
285  if (num_convection_blocks)
286  {
287  params.set<std::vector<SubdomainName>>("block") = _ambient_convection_blocks[block_i];
288  block_name = Moose::stringify(_ambient_convection_blocks[block_i]);
289  }
290  else
291  {
292  assignBlocks(params, _blocks);
293  block_name = std::to_string(block_i);
294  }
295 
296  params.set<MooseFunctorName>("h_solid_fluid") = _ambient_convection_alpha[block_i];
297  if (_ambient_temperature.size() > 1)
298  params.set<MooseFunctorName>(NS::T_fluid) = _ambient_temperature[block_i];
299  else
300  params.set<MooseFunctorName>(NS::T_fluid) = _ambient_temperature[0];
301 
302  getProblem().addFVKernel(kernel_type, prefix() + "ambient_convection_" + block_name, params);
303  }
304 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
void paramError(const std::string &param, Args... args) const
static const std::string T_solid
Definition: NS.h:111
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
std::vector< MooseFunctorName > _ambient_convection_alpha
Name of the ambient convection heat transfer coefficients for each block-group.
static const std::string T_fluid
Definition: NS.h:110
std::string stringify(const T &t)
const NonlinearVariableName _solid_temperature_name
Solid temperature name.
std::vector< MooseFunctorName > _ambient_temperature
Name of the solid domain temperature for each block-group.
IntRange< T > make_range(T beg, T end)
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
std::vector< std::vector< SubdomainName > > _ambient_convection_blocks
Vector of subdomain groups where we want to have different ambient convection.

◆ addPINSSolidEnergyExternalHeatSource()

void PNSFVSolidHeatTransferPhysics::addPINSSolidEnergyExternalHeatSource ( )
private

Definition at line 307 of file PNSFVSolidHeatTransferPhysics.C.

Referenced by addFVKernels().

308 {
309  const std::string kernel_type = "FVCoupledForce";
310  InputParameters params = getFactory().getValidParams(kernel_type);
311  params.set<NonlinearVariableName>("variable") = _solid_temperature_name;
312  const auto & source_blocks = getParam<std::vector<SubdomainName>>("external_heat_source_blocks");
313  if (source_blocks.size())
314  assignBlocks(params, source_blocks);
315  else
316  assignBlocks(params, _blocks);
317  params.set<MooseFunctorName>("v") = getParam<MooseFunctorName>("external_heat_source");
318  params.set<Real>("coef") = getParam<Real>("external_heat_source_coeff");
319 
320  getProblem().addFVKernel(kernel_type, prefix() + "external_heat_source", params);
321 }
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
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
const NonlinearVariableName _solid_temperature_name
Solid temperature name.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)

◆ addPINSSolidEnergyHeatConductionKernels()

void PNSFVSolidHeatTransferPhysics::addPINSSolidEnergyHeatConductionKernels ( )
private

Definition at line 229 of file PNSFVSolidHeatTransferPhysics.C.

Referenced by addFVKernels().

230 {
231  const auto vector_conductivity = processThermalConductivity();
232 
233  const auto kernel_type =
234  vector_conductivity ? "PINSFVEnergyAnisotropicDiffusion" : "PINSFVEnergyDiffusion";
235 
236  InputParameters params = getFactory().getValidParams(kernel_type);
237  params.set<NonlinearVariableName>("variable") = _solid_temperature_name;
238  params.set<MooseFunctorName>(NS::porosity) = _porosity_name;
239 
240  // Set block restrictions
241  const bool combined = _thermal_conductivity_blocks.size() > 1;
242  std::vector<SubdomainName> thermal_conductivity_blocks;
243  for (const auto & block_group : _thermal_conductivity_blocks)
244  thermal_conductivity_blocks.insert(thermal_conductivity_blocks.end(),
245  std::make_move_iterator(block_group.begin()),
246  std::make_move_iterator(block_group.end()));
247  const auto block_names =
248  _thermal_conductivity_blocks.size() ? thermal_conductivity_blocks : _blocks;
249  assignBlocks(params, block_names);
250 
251  // Set thermal conductivity
252  const auto conductivity_name = vector_conductivity ? NS::kappa : NS::k;
253  if (combined)
254  params.set<MooseFunctorName>(conductivity_name) = prefix() + "combined_thermal_conductivity";
255  else
256  params.set<MooseFunctorName>(conductivity_name) = _thermal_conductivity_name[0];
257 
258  getProblem().addFVKernel(kernel_type, prefix() + "pins_energy_diffusion", params);
259 }
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
std::vector< SubdomainName > _blocks
std::vector< MooseFunctorName > _thermal_conductivity_name
Name of the thermal conductivity functor for each block-group.
virtual FEProblemBase & getProblem()
static const std::string porosity
Definition: NS.h:108
bool processThermalConductivity()
Process thermal conductivity (multiple functor input options are available).
const NonlinearVariableName _solid_temperature_name
Solid temperature name.
std::vector< std::vector< SubdomainName > > _thermal_conductivity_blocks
Vector of subdomain groups where we want to have different thermal conduction.
static const std::string kappa
Definition: NS.h:120
const MooseFunctorName _porosity_name
Name of the porosity functor (usually material property)
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
static const std::string k
Definition: NS.h:134

◆ addPINSSolidEnergyTimeKernels()

void PNSFVSolidHeatTransferPhysics::addPINSSolidEnergyTimeKernels ( )
private

Functions adding kernels for the solid energy equation.

Definition at line 195 of file PNSFVSolidHeatTransferPhysics.C.

Referenced by addFVKernels().

196 {
197  const auto kernel_type = "PINSFVEnergyTimeDerivative";
198  const auto kernel_name = prefix() + "pins_solid_energy_time";
199 
200  InputParameters params = getFactory().getValidParams(kernel_type);
201  assignBlocks(params, _blocks);
202  params.set<NonlinearVariableName>("variable") = _solid_temperature_name;
203  params.set<MooseFunctorName>(NS::density) = _density_name;
204 
205  // The '_solid' suffix has been declared when creating the INSFVEnthalpyMaterial
206  // only for thermal functor material properties
207  // Using this derivative we can model non-constant specific heat
209  /*thread_id=*/0))
210  params.set<MooseFunctorName>(NS::time_deriv(NS::specific_enthalpy)) =
212  else
213  params.set<MooseFunctorName>(NS::cp) = _specific_heat_name;
214 
215  params.set<MooseFunctorName>(NS::porosity) = _porosity_name;
216  // If modeling a variable density
218  /*thread_id=*/0))
219  {
220  params.set<MooseFunctorName>(NS::time_deriv(NS::density)) = NS::time_deriv(_density_name);
221  params.set<MooseFunctorName>(NS::specific_enthalpy) = NS::specific_enthalpy + "_solid";
222  }
223  params.set<bool>("is_solid") = true;
224 
225  getProblem().addFVKernel(kernel_type, kernel_name, params);
226 }
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)
static const std::string density
Definition: NS.h:34
InputParameters getValidParams(const std::string &name) const
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
static const std::string porosity
Definition: NS.h:108
static const std::string cp
Definition: NS.h:125
const MooseFunctorName _specific_heat_name
Name of the specific heat functor (usually material property)
const NonlinearVariableName _solid_temperature_name
Solid temperature name.
const MooseFunctorName _porosity_name
Name of the porosity functor (usually material property)
const MooseFunctorName _density_name
Name of the density functor (usually material property)
bool hasFunctor(const std::string &name, const THREAD_ID tid) const
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
std::string time_deriv(const std::string &var)
Definition: NS.h:98
static const std::string specific_enthalpy
Definition: NS.h:69

◆ addSolverVariables()

void PNSFVSolidHeatTransferPhysics::addSolverVariables ( )
overrideprivatevirtual

Reimplemented from HeatConductionFV.

Definition at line 157 of file PNSFVSolidHeatTransferPhysics.C.

158 {
159  // Dont add if the user already defined the variable
161  /*error_if_aux=*/true))
163  getProblem().getVariable(0, _solid_temperature_name).blocks());
164  else
165  {
166  auto params = getFactory().getValidParams("INSFVEnergyVariable");
167  assignBlocks(params, _blocks);
168  params.set<SolverSystemName>("solver_sys") = getSolverSystem(_solid_temperature_name);
169  params.set<std::vector<Real>>("scaling") = {getParam<Real>("temperature_scaling")};
170  params.set<MooseEnum>("face_interp_method") =
171  getParam<MooseEnum>("solid_temperature_face_interpolation");
172  params.set<bool>("two_term_boundary_expansion") =
173  getParam<bool>("solid_temperature_two_term_bc_expansion");
174  getProblem().addVariable("INSFVEnergyVariable", _solid_temperature_name, params);
175  }
176 }
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
InputParameters getValidParams(const std::string &name) const
const std::vector< SubdomainName > & blocks() const
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 checkBlockRestrictionIdentical(const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
const NonlinearVariableName _solid_temperature_name
Solid temperature name.

◆ checkFluidAndSolidHeatTransferPhysicsParameters()

void PNSFVSolidHeatTransferPhysics::checkFluidAndSolidHeatTransferPhysicsParameters ( ) const
private

Battery of additional checks on parameters.

Definition at line 430 of file PNSFVSolidHeatTransferPhysics.C.

Referenced by addFVKernels().

431 {
432  // Get a pointer to a flow physics and a heat transfer physics on the same blocks, if it exists
433  const WCNSFVFlowPhysics * flow_physics = nullptr;
434  const WCNSFVFluidHeatTransferPhysics * fluid_energy_physics = nullptr;
435  const auto all_flow_physics = getCoupledPhysics<const WCNSFVFlowPhysics>(/*allow_fail=*/true);
436  for (const auto physics : all_flow_physics)
438  physics->name(), physics->blocks(), /*error_if_not_identical=*/false))
439  {
440  if (flow_physics)
441  mooseError("Two Fluid flow physics detected on the same blocks as the solid heat transfer "
442  "physics");
443  flow_physics = physics;
444  }
445  const auto all_fluid_energy_physics =
446  getCoupledPhysics<const WCNSFVFluidHeatTransferPhysics>(/*allow_fail=*/true);
447  for (const auto physics : all_fluid_energy_physics)
449  physics->name(), physics->blocks(), /*error_if_not_identical=*/false))
450  {
451  if (fluid_energy_physics)
452  mooseError("Two fluid heat transfer physics detected on the same blocks as the solid heat "
453  "transfer physics");
454  fluid_energy_physics = physics;
455  }
456 
457  if (!fluid_energy_physics && !flow_physics)
458  return;
459 
460  // Check that the parameters seem reasonable
461  // Different material properties
462  // TODO: Does this error on numbers?
463  if (flow_physics && flow_physics->densityName() == _density_name)
464  paramError("rho_solid", "Fluid and solid density should be different");
465  if (fluid_energy_physics && fluid_energy_physics->getSpecificHeatName() == _specific_heat_name)
466  paramError("cp_solid", "Fluid and solid specific heat should be different");
467 
468  // Check ambient convection parameters
469  if (fluid_energy_physics)
470  {
471  // The blocks should match
472  // We only use a warning in case the blocks are matching, just specified differently
473  // in the vector of vectors
474  auto fluid_convection_blocks = fluid_energy_physics->getAmbientConvectionBlocks();
475  std::sort(fluid_convection_blocks.begin(), fluid_convection_blocks.end());
476  std::vector<std::vector<SubdomainName>> copy_solid_blocks = _ambient_convection_blocks;
477  std::sort(copy_solid_blocks.begin(), copy_solid_blocks.end());
478  if (fluid_convection_blocks != _ambient_convection_blocks)
479  paramWarning("Ambient convection blocks in the solid phase :" +
480  Moose::stringify(_ambient_convection_blocks) + " and in the fluid phase " +
481  Moose::stringify(fluid_convection_blocks) + " do not seem to match.");
482 
483  // The coefficients should also match
484  auto fluid_convection_coeffs = fluid_energy_physics->getAmbientConvectionHTCs();
485  fluid_convection_blocks = fluid_energy_physics->getAmbientConvectionBlocks();
486  for (const auto i : index_range(fluid_energy_physics->getAmbientConvectionBlocks()))
487  for (const auto j : index_range(_ambient_convection_blocks))
488  if (fluid_convection_blocks[i] == _ambient_convection_blocks[j] &&
489  fluid_convection_coeffs[i] != _ambient_convection_alpha[j])
490  paramWarning("Ambient convection HTCs in the solid phase :" +
491  Moose::stringify(_ambient_convection_alpha) + " and in the fluid phase " +
492  Moose::stringify(fluid_convection_coeffs) + " do not seem to match.");
493  }
494 }
Creates all the objects needed to solve the Navier Stokes energy equation.
void paramError(const std::string &param, Args... args) const
Creates all the objects needed to solve the Navier Stokes mass and momentum equations.
const MooseFunctorName & densityName() const
Return the name of the density functor.
std::vector< MooseFunctorName > _ambient_convection_alpha
Name of the ambient convection heat transfer coefficients for each block-group.
const MooseFunctorName & getSpecificHeatName() const
Get the name of the specific heat material property.
const MooseFunctorName _specific_heat_name
Name of the specific heat functor (usually material property)
std::string stringify(const T &t)
bool checkBlockRestrictionIdentical(const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
const std::vector< MooseFunctorName > & getAmbientConvectionHTCs() const
Name of the ambient convection heat transfer coefficients for each block-group.
void mooseError(Args &&... args) const
const MooseFunctorName _density_name
Name of the density functor (usually material property)
static const std::complex< double > j(0, 1)
Complex number "j" (also known as "i")
void paramWarning(const std::string &param, Args... args) const
auto index_range(const T &sizable)
std::vector< std::vector< SubdomainName > > _ambient_convection_blocks
Vector of subdomain groups where we want to have different ambient convection.
const std::vector< std::vector< SubdomainName > > & getAmbientConvectionBlocks() const
Get the ambient convection parameters for parameter checking.

◆ getAdditionalRMParams()

InputParameters PNSFVSolidHeatTransferPhysics::getAdditionalRMParams ( ) const
overrideprivatevirtual

Reimplemented from PhysicsBase.

Definition at line 414 of file PNSFVSolidHeatTransferPhysics.C.

415 {
416  unsigned short necessary_layers = getParam<unsigned short>("ghost_layers");
417  if (getParam<MooseEnum>("solid_temperature_face_interpolation") == "skewness-corrected")
418  necessary_layers = std::max(necessary_layers, (unsigned short)3);
419 
420  // Just an object that has a ghost_layers parameter and performs geometric, algebraic, and
421  // coupling ghosting
422  const std::string kernel_type = "INSFVMixingLengthReynoldsStress";
423  InputParameters params = getFactory().getValidParams(kernel_type);
424  params.template set<unsigned short>("ghost_layers") = necessary_layers;
425 
426  return params;
427 }
Factory & getFactory()
InputParameters getValidParams(const std::string &name) const

◆ processThermalConductivity()

bool PNSFVSolidHeatTransferPhysics::processThermalConductivity ( )
private

Process thermal conductivity (multiple functor input options are available).

Return true if we have vector thermal conductivity and false if scalar

Definition at line 324 of file PNSFVSolidHeatTransferPhysics.C.

Referenced by addMaterials(), and addPINSSolidEnergyHeatConductionKernels().

325 {
326  if (isParamValid("thermal_conductivity_blocks"))
327  checkBlockwiseConsistency<MooseFunctorName>("thermal_conductivity_blocks",
328  {"thermal_conductivity_solid"});
329  bool have_scalar = false;
330  bool have_vector = false;
331 
332  for (const auto i : index_range(_thermal_conductivity_name))
333  {
334  // First, check if the name is just a number (only in case of isotropic conduction)
336  have_scalar = true;
337  // Now we determine what kind of functor we are dealing with
338  else
339  {
341  /*thread_id=*/0))
342  have_scalar = true;
343  else
344  {
346  /*thread_id=*/0))
347  have_vector = true;
349  /*thread_id=*/0))
350  paramError("thermal_conductivity_solid",
351  "We only allow functor of type (AD)Real or (AD)RealVectorValue for thermal "
352  "conductivity! Functor '" +
353  _thermal_conductivity_name[i] + "' is not of the requested type.");
354  else
355  // If another Physics is creating this functor, we could be running into an order of
356  // creation problem
357  paramWarning("thermal_conductivity_solid",
358  "Functor '" + _thermal_conductivity_name[i] +
359  "' was not found in the Problem. Did you mispell it?");
360  }
361  }
362  }
363 
364  if (have_vector && (have_vector == have_scalar))
365  paramError("thermal_conductivity_solid",
366  "The entries on thermal conductivity shall either be scalars or vectors, mixing "
367  "them is not supported!");
368  return have_vector;
369 }
void paramError(const std::string &param, Args... args) const
DualNumber< Real, DNDerivativeType, false > ADReal
std::vector< MooseFunctorName > _thermal_conductivity_name
Name of the thermal conductivity functor for each block-group.
virtual FEProblemBase & getProblem()
bool hasFunctorWithType(const std::string &name, const THREAD_ID tid) const
bool isParamValid(const std::string &name) const
void paramWarning(const std::string &param, Args... args) const
bool hasFunctor(const std::string &name, const THREAD_ID tid) const
bool parsesToReal(const std::string &input, Real *parsed_real)
auto index_range(const T &sizable)

◆ validParams()

InputParameters PNSFVSolidHeatTransferPhysics::validParams ( )
static

Definition at line 25 of file PNSFVSolidHeatTransferPhysics.C.

26 {
28  params.addClassDescription("Define the Navier Stokes porous media solid energy equation");
29 
30  // These boundary conditions parameters are not implemented yet
31  params.suppressParameter<std::vector<BoundaryName>>("fixed_convection_boundaries");
32  params.suppressParameter<std::vector<MooseFunctorName>>("fixed_convection_T_fluid");
33  params.suppressParameter<std::vector<MooseFunctorName>>("fixed_convection_htc");
34 
35  // Swap out some parameters, base class is not specific to porous media
36  // Variables
37  params.renameParam("temperature_name",
38  "solid_temperature_variable",
39  "Name of the solid phase temperature variable");
40  params.set<VariableName>("solid_temperature_variable") = NS::T_solid;
41  params.addParam<NonlinearVariableName>(
42  "fluid_temperature_variable", NS::T_fluid, "Name of the fluid temperature variable");
43  MooseEnum face_interpol_types("average skewness-corrected", "average");
44  params.addParam<MooseEnum>(
45  "solid_temperature_face_interpolation",
46  face_interpol_types,
47  "The numerical scheme to interpolate the temperature/energy to the "
48  "face for conduction (separate from the advected quantity interpolation).");
49  params.addParam<bool>(
50  "solid_temperature_two_term_bc_expansion",
51  true,
52  "If a two-term Taylor expansion is needed for the determination of the boundary values"
53  "of the temperature/energy.");
54 
55  // Porous media parameters
56  // TODO: ensure consistency with fluid energy physics
57  params.transferParam<MooseFunctorName>(NSFVBase::validParams(), "porosity");
58 
59  // Material properties
60  params.suppressParameter<MaterialPropertyName>("specific_heat");
61  params.addParam<MooseFunctorName>("cp_solid", NS::cp + "_solid", "Specific heat functor");
62  params.suppressParameter<MaterialPropertyName>("density");
63  params.addParam<MooseFunctorName>("rho_solid", NS::density + "_solid", "Density functor");
64  params.addParam<std::vector<std::vector<SubdomainName>>>(
65  "thermal_conductivity_blocks", "Blocks which each thermal conductivity is defined");
66  params.suppressParameter<MooseFunctorName>("thermal_conductivity_functor");
67  params.addRequiredParam<std::vector<MooseFunctorName>>(
68  "thermal_conductivity_solid",
69  "Thermal conductivity, which may have different names depending on the subdomain");
70 
71  // Ambient convection with the liquid phase parameters
72  params.addParam<std::vector<std::vector<SubdomainName>>>(
73  "ambient_convection_blocks", {}, "The blocks where the ambient convection is present.");
74  params.addParam<std::vector<MooseFunctorName>>(
75  "ambient_convection_alpha",
76  {},
77  "The heat exchange coefficients for each block in 'ambient_convection_blocks'.");
78  params.addParam<std::vector<MooseFunctorName>>(
79  "ambient_convection_temperature",
80  {NS::T_fluid},
81  "The fluid temperature for each block in 'ambient_convection_blocks'.");
82 
83  // Heat source in solid porous medium parameters
84  params.addParam<std::vector<SubdomainName>>("external_heat_source_blocks",
85  std::vector<SubdomainName>(),
86  "The blocks where the heat source is present.");
87  params.addParam<MooseFunctorName>(
88  "external_heat_source",
89  "The name of a functor which contains the external heat source for the energy equation.");
90  params.addParam<Real>(
91  "external_heat_source_coeff", 1.0, "Multiplier for the coupled heat source term.");
92  params.addParam<bool>("use_external_enthalpy_material",
93  false,
94  "To indicate if the enthalpy material is set up outside of the action.");
95 
96  params.suppressParameter<VariableName>("heat_source_var");
97  params.suppressParameter<std::vector<SubdomainName>>("heat_source_blocks");
98 
99  // Numerical scheme
100  params.addParam<unsigned short>(
101  "ghost_layers", 2, "Number of layers of elements to ghost near process domain boundaries");
102  // Preconditioning has not been derived for NSFV + porous heat transfer at this point
103  MooseEnum pc_options("default none", "none");
104  params.set<MooseEnum>("preconditioning") = pc_options;
105  params.suppressParameter<MooseEnum>("preconditioning");
106 
107  // Parameter groups
108  params.addParamNamesToGroup("rho_solid cp_solid thermal_conductivity_solid "
109  "thermal_conductivity_blocks use_external_enthalpy_material",
110  "Material properties");
111  params.addParamNamesToGroup("ambient_convection_alpha ambient_convection_blocks "
112  "ambient_convection_temperature",
113  "Ambient convection");
114  params.addParamNamesToGroup(
115  "external_heat_source_blocks external_heat_source external_heat_source_coeff",
116  "Solid porous medium heat source");
117  params.addParamNamesToGroup(
118  "solid_temperature_face_interpolation solid_temperature_two_term_bc_expansion",
119  "Numerical scheme");
120  params.addParamNamesToGroup("ghost_layers", "Advanced");
121 
122  return params;
123 }
static InputParameters validParams()
Definition: NSFVBase.C:371
void renameParam(const std::string &old_name, const std::string &new_name, const std::string &new_docstring)
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
static const std::string T_solid
Definition: NS.h:111
T & set(const std::string &name, bool quiet_mode=false)
static const std::string density
Definition: NS.h:34
void addRequiredParam(const std::string &name, const std::string &doc_string)
void suppressParameter(const std::string &name)
static const std::string cp
Definition: NS.h:125
static const std::string T_fluid
Definition: NS.h:110
void transferParam(const InputParameters &source_param, const std::string &name, const std::string &new_name="", const std::string &new_description="")
static InputParameters validParams()
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
void addClassDescription(const std::string &doc_string)
void addParamNamesToGroup(const std::string &space_delim_names, const std::string group_name)

Member Data Documentation

◆ _ambient_convection_alpha

std::vector<MooseFunctorName> PNSFVSolidHeatTransferPhysics::_ambient_convection_alpha
private

Name of the ambient convection heat transfer coefficients for each block-group.

Definition at line 71 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addPINSSolidEnergyAmbientConvection(), and checkFluidAndSolidHeatTransferPhysicsParameters().

◆ _ambient_convection_blocks

std::vector<std::vector<SubdomainName> > PNSFVSolidHeatTransferPhysics::_ambient_convection_blocks
private

Vector of subdomain groups where we want to have different ambient convection.

Definition at line 69 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addPINSSolidEnergyAmbientConvection(), and checkFluidAndSolidHeatTransferPhysicsParameters().

◆ _ambient_temperature

std::vector<MooseFunctorName> PNSFVSolidHeatTransferPhysics::_ambient_temperature
private

Name of the solid domain temperature for each block-group.

Definition at line 73 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addPINSSolidEnergyAmbientConvection().

◆ _density_name

const MooseFunctorName PNSFVSolidHeatTransferPhysics::_density_name
private

Name of the density functor (usually material property)

Definition at line 60 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addMaterials(), addPINSSolidEnergyTimeKernels(), and checkFluidAndSolidHeatTransferPhysicsParameters().

◆ _fluid_temperature_name

const NonlinearVariableName PNSFVSolidHeatTransferPhysics::_fluid_temperature_name
private

Fluid temperature name.

Definition at line 56 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by PNSFVSolidHeatTransferPhysics().

◆ _porosity_name

const MooseFunctorName PNSFVSolidHeatTransferPhysics::_porosity_name
private

Name of the porosity functor (usually material property)

Definition at line 58 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addPINSSolidEnergyHeatConductionKernels(), and addPINSSolidEnergyTimeKernels().

◆ _solid_temperature_name

const NonlinearVariableName PNSFVSolidHeatTransferPhysics::_solid_temperature_name
private

◆ _specific_heat_name

const MooseFunctorName PNSFVSolidHeatTransferPhysics::_specific_heat_name
private

Name of the specific heat functor (usually material property)

Definition at line 62 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addMaterials(), addPINSSolidEnergyTimeKernels(), and checkFluidAndSolidHeatTransferPhysicsParameters().

◆ _temperature_name

const VariableName& HeatConductionPhysicsBase::_temperature_name
protectedinherited

◆ _thermal_conductivity_blocks

std::vector<std::vector<SubdomainName> > PNSFVSolidHeatTransferPhysics::_thermal_conductivity_blocks
private

Vector of subdomain groups where we want to have different thermal conduction.

Definition at line 64 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addMaterials(), and addPINSSolidEnergyHeatConductionKernels().

◆ _thermal_conductivity_name

std::vector<MooseFunctorName> PNSFVSolidHeatTransferPhysics::_thermal_conductivity_name
private

Name of the thermal conductivity functor for each block-group.

Definition at line 66 of file PNSFVSolidHeatTransferPhysics.h.

Referenced by addMaterials(), addPINSSolidEnergyHeatConductionKernels(), and processThermalConductivity().


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