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

Base class for a Physics that creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible Navier Stokes finite volume flow simulation. More...

#include <WCNSFVTurbulencePhysicsBase.h>

Inheritance diagram for WCNSFVTurbulencePhysicsBase:
[legend]

Public Types

typedef DataFileName DataFileParameterType
 

Public Member Functions

 WCNSFVTurbulencePhysicsBase (const InputParameters &parameters)
 
bool hasTurbulenceModel () const
 Whether a turbulence model is in use. More...
 
std::vector< BoundaryName > turbulenceWalls () const
 The names of the boundaries with turbulence wall functions. More...
 
MooseEnum turbulenceEpsilonWallTreatment () const
 The turbulence epsilon wall treatment (same for all turbulence walls currently) More...
 
MooseEnum turbulenceTemperatureWallTreatment () const
 The turbulence temperature wall treatment (same for all turbulence walls currently) More...
 
MooseFunctorName tkeName () const
 The name of the turbulent kinetic energy variable. More...
 
virtual void act () override final
 
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
 
const WCNSFVFlowPhysicsBasegetCoupledFlowPhysics () const
 
const WCNSFVTurbulencePhysicsBasegetCoupledTurbulencePhysics () const
 
MooseFunctorName getPorosityFunctorName (bool smoothed) const
 Return the porosity functor name. More...
 
const MooseFunctorName & densityName () const
 
const MooseFunctorName & dynamicViscosityName () 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

virtual void actOnAdditionalTasks () override
 
void retrieveCoupledPhysics ()
 Retrieve the other WCNSFVPhysics at play in the simulation to be able to add the relevant terms (turbulent diffusion notably) More...
 
virtual void addSolverVariables () override=0
 
virtual void addAuxiliaryVariables () override
 
virtual void addFVKernels () override=0
 
virtual void addFVBCs () override=0
 
virtual void addAuxiliaryKernels () override
 
virtual void addInitialConditions () override
 
virtual void addMaterials () override
 
bool usingNavierStokesFVSyntax () const
 Detects if we are using the new Physics syntax or the old NavierStokesFV action. More...
 
InputParameters getAdditionalRMParams () const override
 Parameters to change or add relationship managers. More...
 
virtual unsigned short getNumberAlgebraicGhostingLayersNeeded () const =0
 Return the number of ghosting layers needed. More...
 
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 MooseEnum _turbulence_model
 Turbulence model to create the equation(s) for. More...
 
bool _has_flow_equations
 
bool _has_energy_equation
 
bool _has_scalar_equations
 
const WCNSFVFluidHeatTransferPhysicsBase_fluid_energy_physics
 The heat advection physics to add turbulent mixing for. More...
 
const WCNSFVScalarTransportPhysicsBase_scalar_transport_physics
 The scalar advection physics to add turbulent mixing for. More...
 
std::vector< BoundaryName > _turbulence_walls
 List of boundaries to act as walls for turbulence models. More...
 
MooseEnum _wall_treatment_eps
 Turbulence wall treatment for epsilon (same for all walls currently) More...
 
MooseEnum _wall_treatment_temp
 Turbulence wall treatment for temperature (same for all walls currently) More...
 
const VariableName _tke_name
 Name of the turbulent kinetic energy. More...
 
const VariableName _tked_name
 Name of the turbulent kinetic energy dissipation. More...
 
const VariableName _turbulent_viscosity_name = NS::mu_t
 Name of the turbulence viscosity auxiliary variable (or property) More...
 
bool _define_variables
 Whether to define variables if they do not exist. 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
 
const NavierStokesPhysicsBase_advection_physics
 The Physics class using this helper. More...
 
const WCNSFVFlowPhysicsBase_flow_equations_physics
 Flow physics. More...
 
const WCNSFVTurbulencePhysicsBase_turbulence_physics
 Turbulence. More...
 
bool _has_turbulence_model
 Because of the Modules/navierStokesFV syntax, a turbulence physics often exists without a model we save (_turbulence_physics && _turbulence_physics->hasTurbulenceModel()) in this attribute. More...
 
const MooseEnum _compressibility
 Compressibility type, can be compressible, incompressible or weakly-compressible. More...
 
const bool _porous_medium_treatment
 Switch to show if porous medium treatment is requested or not. More...
 
const std::vector< std::string > _velocity_names
 Velocity names. More...
 
const NonlinearVariableName _pressure_name
 Pressure name. More...
 
const MooseFunctorName _density_name
 Name of the density material property. More...
 
const MooseFunctorName _dynamic_viscosity_name
 Name of the dynamic viscosity material property. More...
 
const MooseEnum _velocity_interpolation
 The velocity / momentum face interpolation method for advecting other quantities. More...
 

Detailed Description

Base class for a Physics that creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible Navier Stokes finite volume flow simulation.

Definition at line 34 of file WCNSFVTurbulencePhysicsBase.h.

Constructor & Destructor Documentation

◆ WCNSFVTurbulencePhysicsBase()

WCNSFVTurbulencePhysicsBase::WCNSFVTurbulencePhysicsBase ( const InputParameters parameters)

Definition at line 154 of file WCNSFVTurbulencePhysicsBase.C.

157  _turbulence_model(getParam<MooseEnum>("turbulence_handling")),
158  _turbulence_walls(getParam<std::vector<BoundaryName>>("turbulence_walls")),
159  _wall_treatment_eps(getParam<MooseEnum>("wall_treatment_eps")),
160  _wall_treatment_temp(getParam<MooseEnum>("wall_treatment_T")),
161  _tke_name(getParam<MooseFunctorName>("tke_name")),
162  _tked_name(getParam<MooseFunctorName>("tked_name"))
163 {
164  if (_verbose && _turbulence_model != "none")
165  _console << "Creating a " << std::string(_turbulence_model) << " turbulence model."
166  << std::endl;
167 
168  // Keep track of the variable names, for loading variables from files notably
169  if (_turbulence_model == "k-epsilon")
170  {
173  if (getParam<bool>("mu_t_as_aux_variable"))
175  if (getParam<bool>("k_t_as_aux_variable"))
177  }
178 
179  // Parameter checks
180  if (_turbulence_model == "none")
181  errorInconsistentDependentParameter("turbulence_handling", "none", {"turbulence_walls"});
182  if (_turbulence_model != "k-epsilon")
183  {
184  errorDependentParameter("turbulence_handling",
185  "k-epsilon",
186  {"C_mu",
187  "C1_eps",
188  "C2_eps",
189  "bulk_wall_treatment",
190  "tke_scaling",
191  "tke_face_interpolation",
192  "tke_two_term_bc_expansion",
193  "tked_scaling",
194  "tked_face_interpolation",
195  "tked_two_term_bc_expansion",
196  "turbulent_viscosity_two_term_bc_expansion"});
197  checkSecondParamSetOnlyIfFirstOneTrue("mu_t_as_aux_variable", "initial_mu_t");
198  }
199 }
const VariableName _turbulent_viscosity_name
Name of the turbulence viscosity auxiliary variable (or property)
MooseEnum _wall_treatment_temp
Turbulence wall treatment for temperature (same for all walls currently)
const T & getParam(const std::string &name) const
const VariableName _tked_name
Name of the turbulent kinetic energy dissipation.
const InputParameters & parameters() const
WCNSFVCoupledAdvectionPhysicsHelper(const NavierStokesPhysicsBase *derived_physics)
const bool _verbose
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
std::vector< BoundaryName > _turbulence_walls
List of boundaries to act as walls for turbulence models.
void errorDependentParameter(const std::string &param1, const std::string &value_not_set, const std::vector< std::string > &dependent_params) const
void saveAuxVariableName(const VariableName &var_name)
const VariableName _tke_name
Name of the turbulent kinetic energy.
NavierStokesPhysicsBase(const InputParameters &parameters)
void errorInconsistentDependentParameter(const std::string &param1, const std::string &value_set, const std::vector< std::string > &dependent_params) const
const ConsoleStream _console
void checkSecondParamSetOnlyIfFirstOneTrue(const std::string &param1, const std::string &param2) const
static const std::string k_t
Definition: NS.h:136
MooseEnum _wall_treatment_eps
Turbulence wall treatment for epsilon (same for all walls currently)
void saveSolverVariableName(const VariableName &var_name)

Member Function Documentation

◆ actOnAdditionalTasks()

void WCNSFVTurbulencePhysicsBase::actOnAdditionalTasks ( )
overrideprotectedvirtual

Reimplemented from PhysicsBase.

Definition at line 202 of file WCNSFVTurbulencePhysicsBase.C.

203 {
204  // Other Physics may not exist or be initialized at construction time, so
205  // we retrieve them now, on this task which occurs after 'init_physics'
206  if (_current_task == "get_turbulence_physics")
208 }
void retrieveCoupledPhysics()
Retrieve the other WCNSFVPhysics at play in the simulation to be able to add the relevant terms (turb...
const std::string & _current_task

◆ addAuxiliaryKernels()

void WCNSFVTurbulencePhysicsBase::addAuxiliaryKernels ( )
overrideprotectedvirtual

Reimplemented from PhysicsBase.

Reimplemented in WCNSFVTurbulencePhysics.

Definition at line 377 of file WCNSFVTurbulencePhysicsBase.C.

Referenced by WCNSFVTurbulencePhysics::addAuxiliaryKernels().

378 {
379  const std::string u_names[3] = {"u", "v", "w"};
380  // Not future-proof
381  const bool is_linear = dynamic_cast<WCNSLinearFVTurbulencePhysics *>(this);
382 
383  if (_turbulence_model == "k-epsilon" && getParam<bool>("mu_t_as_aux_variable"))
384  {
385  auto params = getFactory().getValidParams("kEpsilonViscosityAux");
386  assignBlocks(params, _blocks);
387 
388  params.set<AuxVariableName>("variable") = _turbulent_viscosity_name;
389  params.set<MooseFunctorName>(NS::density) = _flow_equations_physics->densityName();
390  params.set<MooseFunctorName>(NS::mu) = _flow_equations_physics->dynamicViscosityName();
391  params.set<MooseFunctorName>(NS::TKE) = _tke_name;
392  params.set<MooseFunctorName>(NS::TKED) = _tked_name;
393  params.set<std::vector<BoundaryName>>("walls") = _turbulence_walls;
394  params.set<MooseEnum>("wall_treatment") = _wall_treatment_eps;
395  for (const auto d : make_range(dimension()))
396  params.set<MooseFunctorName>(u_names[d]) = _velocity_names[d];
397 
398  params.set<bool>("newton_solve") = !is_linear;
399  params.applySpecificParameters(parameters(), {"C_mu", "bulk_wall_treatment", "mu_t_ratio_max"});
400  params.set<ExecFlagEnum>("execute_on") = {EXEC_NONLINEAR};
401 
402  getProblem().addAuxKernel("kEpsilonViscosityAux", name() + "_viscosity_aux", params);
403  }
404  if (_turbulence_model == "k-epsilon" && _has_energy_equation &&
405  getParam<bool>("k_t_as_aux_variable"))
406  {
407  auto params = getFactory().getValidParams("TurbulentConductivityAux");
408  assignBlocks(params, _blocks);
409  params.set<AuxVariableName>("variable") = NS::k_t;
410  params.set<MooseFunctorName>(NS::cp) = _fluid_energy_physics->getSpecificHeatName();
411  params.set<MooseFunctorName>(NS::mu_t) = _turbulent_viscosity_name;
412  params.applySpecificParameters(parameters(), {"Pr_t"});
414  "TurbulentConductivityAux", name() + "_thermal_conductivity_aux", params);
415  }
416 }
const VariableName _turbulent_viscosity_name
Name of the turbulence viscosity auxiliary variable (or property)
static const std::string mu_t
Definition: NS.h:129
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
const MooseFunctorName & dynamicViscosityName() const
Return the name of the dynamic viscosity functor.
Factory & getFactory()
const VariableName _tked_name
Name of the turbulent kinetic energy dissipation.
const InputParameters & parameters() const
static const std::string density
Definition: NS.h:34
InputParameters getValidParams(const std::string &name) const
static const std::string TKE
Definition: NS.h:180
virtual void addAuxKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
std::vector< SubdomainName > _blocks
unsigned int dimension() const
const MooseFunctorName & densityName() const
Return the name of the density functor.
std::vector< BoundaryName > _turbulence_walls
List of boundaries to act as walls for turbulence models.
virtual FEProblemBase & getProblem()
static const std::string cp
Definition: NS.h:125
Creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible N...
const std::string & name() const
const MooseFunctorName & getSpecificHeatName() const
Get the name of the specific heat material property.
static const std::string mu
Definition: NS.h:127
const VariableName _tke_name
Name of the turbulent kinetic energy.
const WCNSFVFluidHeatTransferPhysicsBase * _fluid_energy_physics
The heat advection physics to add turbulent mixing for.
const std::vector< std::string > _velocity_names
Velocity names.
const ExecFlagType EXEC_NONLINEAR
IntRange< T > make_range(T beg, T end)
static const std::string TKED
Definition: NS.h:181
static const std::string k_t
Definition: NS.h:136
MooseEnum _wall_treatment_eps
Turbulence wall treatment for epsilon (same for all walls currently)
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ addAuxiliaryVariables()

void WCNSFVTurbulencePhysicsBase::addAuxiliaryVariables ( )
overrideprotectedvirtual

Reimplemented from PhysicsBase.

Reimplemented in WCNSFVTurbulencePhysics.

Definition at line 349 of file WCNSFVTurbulencePhysicsBase.C.

Referenced by WCNSFVTurbulencePhysics::addAuxiliaryVariables().

350 {
351  // Not future-proof
352  const bool is_linear = dynamic_cast<WCNSLinearFVTurbulencePhysics *>(this);
353  const auto var_type = is_linear ? "MooseLinearVariableFVReal" : "MooseVariableFVReal";
354 
355  if (_turbulence_model == "k-epsilon" && getParam<bool>("mu_t_as_aux_variable"))
356  {
357  auto params = getFactory().getValidParams(var_type);
358  assignBlocks(params, _blocks);
359  if (!is_linear && isParamValid("turbulent_viscosity_two_term_bc_expansion"))
360  params.set<bool>("two_term_boundary_expansion") =
361  getParam<bool>("turbulent_viscosity_two_term_bc_expansion");
362  if (!shouldCreateVariable(_turbulent_viscosity_name, _blocks, /*error if aux*/ false))
363  reportPotentiallyMissedParameters({"turbulent_viscosity_two_term_bc_expansion"}, var_type);
364  else
366  }
367  if (_turbulence_model == "k-epsilon" && getParam<bool>("k_t_as_aux_variable"))
368  {
369  auto params = getFactory().getValidParams(var_type);
370  assignBlocks(params, _blocks);
371  if (shouldCreateVariable(NS::k_t, _blocks, /*error if aux*/ false))
372  getProblem().addAuxVariable(var_type, NS::k_t, params);
373  }
374 }
const VariableName _turbulent_viscosity_name
Name of the turbulence viscosity auxiliary variable (or property)
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
bool shouldCreateVariable(const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool error_if_aux)
Factory & getFactory()
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)
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
Creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible N...
bool isParamValid(const std::string &name) const
static const std::string k_t
Definition: NS.h:136

◆ addFVBCs()

virtual void WCNSFVTurbulencePhysicsBase::addFVBCs ( )
overrideprotectedpure virtual

Reimplemented from PhysicsBase.

Implemented in WCNSFVTurbulencePhysics, and WCNSLinearFVTurbulencePhysics.

◆ addFVKernels()

virtual void WCNSFVTurbulencePhysicsBase::addFVKernels ( )
overrideprotectedpure virtual

Reimplemented from PhysicsBase.

Implemented in WCNSFVTurbulencePhysics, and WCNSLinearFVTurbulencePhysics.

◆ addInitialConditions()

void WCNSFVTurbulencePhysicsBase::addInitialConditions ( )
overrideprotectedvirtual

Reimplemented from PhysicsBase.

Definition at line 282 of file WCNSFVTurbulencePhysicsBase.C.

283 {
284  if (_turbulence_model == "mixing-length" || _turbulence_model == "none")
285  return;
286  const std::string ic_type = "FVFunctionIC";
287  InputParameters params = getFactory().getValidParams(ic_type);
288 
289  // Parameter checking: error if initial conditions are provided but not going to be used
290  if ((getParam<bool>("initialize_variables_from_mesh_file") || !_define_variables) &&
291  ((getParam<bool>("mu_t_as_aux_variable") && isParamValid("initial_mu_t")) ||
292  isParamSetByUser("initial_tke") || isParamSetByUser("initial_tked")))
293  mooseError("inital_mu_t/tke/tked should not be provided if we are restarting from a mesh file "
294  "or not defining variables in the Physics");
295 
296  // do not set initial conditions if we are not defining variables
297  if (!_define_variables)
298  return;
299  // on regular restarts (from checkpoint), we obey the user specification of initial conditions
300 
301  if (getParam<bool>("mu_t_as_aux_variable"))
302  {
303  const auto rho_name = _flow_equations_physics->densityName();
304  // If the user provided an initial value, we use that
305  if (isParamValid("initial_mu_t"))
306  params.set<FunctionName>("function") = getParam<FunctionName>("initial_mu_t");
307  // If we can compute the initialization value from the user parameters, we do that
308  else if (MooseUtils::isFloat(rho_name) &&
309  MooseUtils::isFloat(getParam<FunctionName>("initial_tke")) &&
310  MooseUtils::isFloat(getParam<FunctionName>("initial_tked")))
311  params.set<FunctionName>("function") =
312  std::to_string(std::atof(rho_name.c_str()) * getParam<Real>("C_mu") *
313  std::pow(std::atof(getParam<FunctionName>("initial_tke").c_str()), 2) /
314  std::atof(getParam<FunctionName>("initial_tked").c_str()));
315  else
316  paramError("initial_mu_t",
317  "Initial turbulent viscosity should be provided. A sensible value is "
318  "rho * C_mu TKE_initial^2 / TKED_initial");
319 
320  params.set<VariableName>("variable") = _turbulent_viscosity_name;
321  // Always obey the user specification of an initial condition
323  _blocks,
324  /*whether IC is a default*/ !isParamSetByUser("initial_mu_t"),
325  /*error if already an IC*/ isParamSetByUser("initial_mu_t")))
326  getProblem().addFVInitialCondition(ic_type, prefix() + "initial_mu_turb", params);
327  }
328  else if (isParamSetByUser("initial_mu_t"))
329  paramError("initial_mu_t",
330  "This parameter can only be specified if 'mu_t_as_aux_variable=true'");
331 
332  params.set<VariableName>("variable") = _tke_name;
333  params.set<FunctionName>("function") = getParam<FunctionName>("initial_tke");
335  _blocks,
336  /*whether IC is a default*/ !isParamSetByUser("initial_tke"),
337  /*error if already an IC*/ isParamSetByUser("initial_tke")))
338  getProblem().addFVInitialCondition(ic_type, prefix() + "initial_tke", params);
339  params.set<VariableName>("variable") = _tked_name;
340  params.set<FunctionName>("function") = getParam<FunctionName>("initial_tked");
342  _blocks,
343  /*whether IC is a default*/ !isParamSetByUser("initial_tked"),
344  /*error if already an IC*/ isParamSetByUser("initial_tked")))
345  getProblem().addFVInitialCondition(ic_type, prefix() + "initial_tked", params);
346 }
std::string prefix() const
virtual void addFVInitialCondition(const std::string &ic_name, const std::string &name, InputParameters &parameters)
const VariableName _turbulent_viscosity_name
Name of the turbulence viscosity auxiliary variable (or property)
Factory & getFactory()
void paramError(const std::string &param, Args... args) const
const VariableName _tked_name
Name of the turbulent kinetic energy dissipation.
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
bool shouldCreateIC(const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool ic_is_default_ic, const bool error_if_already_defined) const
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
std::vector< SubdomainName > _blocks
const MooseFunctorName & densityName() const
Return the name of the density functor.
virtual FEProblemBase & getProblem()
const VariableName _tke_name
Name of the turbulent kinetic energy.
bool _define_variables
Whether to define variables if they do not exist.
void mooseError(Args &&... args) const
bool isParamValid(const std::string &name) const
bool isParamSetByUser(const std::string &name) const
MooseUnits pow(const MooseUnits &, int)
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ addMaterials()

void WCNSFVTurbulencePhysicsBase::addMaterials ( )
overrideprotectedvirtual

Reimplemented from PhysicsBase.

Reimplemented in WCNSFVTurbulencePhysics.

Definition at line 419 of file WCNSFVTurbulencePhysicsBase.C.

Referenced by WCNSFVTurbulencePhysics::addMaterials().

420 {
421  // Not future-proof
422  const bool is_linear = dynamic_cast<WCNSLinearFVTurbulencePhysics *>(this);
423  if (_turbulence_model == "k-epsilon")
424  {
425  if (!getProblem().hasFunctor(NS::mu_eff, /*thread_id=*/0))
426  {
427  const auto mat_type =
428  is_linear ? "FunctorEffectiveDynamicViscosity" : "ADFunctorEffectiveDynamicViscosity";
429  InputParameters params = getFactory().getValidParams(mat_type);
430  assignBlocks(params, _blocks);
431  params.set<MooseFunctorName>("property_name") = NS::mu_eff;
432  params.set<MooseFunctorName>(NS::mu) = _flow_equations_physics->dynamicViscosityName();
433  params.set<MooseFunctorName>(NS::mu_t) = _turbulent_viscosity_name;
434  params.set<MooseFunctorName>(NS::mu_t + "_inverse_factor") = "1";
435  getProblem().addMaterial(mat_type, prefix() + "effective_viscosity", params);
436  }
437  if (!getParam<bool>("mu_t_as_aux_variable"))
438  {
439  InputParameters params = getFactory().getValidParams("INSFVkEpsilonViscosityFunctorMaterial");
440  params.set<MooseFunctorName>(NS::TKE) = _tke_name;
441  params.set<MooseFunctorName>(NS::TKED) = _tked_name;
442  params.set<MooseFunctorName>(NS::density) = _density_name;
443  params.set<ExecFlagEnum>("execute_on") = {EXEC_NONLINEAR};
444  if (getParam<bool>("output_mu_t"))
445  params.set<std::vector<OutputName>>("outputs") = {"all"};
447  "INSFVkEpsilonViscosityFunctorMaterial", prefix() + "compute_mu_t", params);
448  }
449 
450  if (_has_energy_equation && !getProblem().hasFunctor(NS::k_t, /*thread_id=*/0))
451  {
452  mooseAssert(!getParam<bool>("k_t_as_aux_variable"), "k_t should not exist");
453  const auto object_type = is_linear ? "ParsedFunctorMaterial" : "ADParsedFunctorMaterial";
454  InputParameters params = getFactory().getValidParams(object_type);
455  assignBlocks(params, _blocks);
456  const auto mu_t_name = NS::mu_t;
457  const auto cp_name = _fluid_energy_physics->getSpecificHeatName();
458  const auto Pr_t_name = getParam<MooseFunctorName>("Pr_t");
459 
460  // Avoid defining floats as functors in the parsed expression
461  if (!MooseUtils::isFloat(cp_name) && !MooseUtils::isFloat(Pr_t_name))
462  params.set<std::vector<std::string>>("functor_names") = {cp_name, Pr_t_name, mu_t_name};
463  else if (MooseUtils::isFloat(cp_name) && !MooseUtils::isFloat(Pr_t_name))
464  params.set<std::vector<std::string>>("functor_names") = {Pr_t_name, mu_t_name};
465  else if (!MooseUtils::isFloat(cp_name) && MooseUtils::isFloat(Pr_t_name))
466  params.set<std::vector<std::string>>("functor_names") = {cp_name, mu_t_name};
467  else
468  params.set<std::vector<std::string>>("functor_names") = {mu_t_name};
469 
470  params.set<std::string>("expression") = mu_t_name + "*" + cp_name + "/" + Pr_t_name;
471  params.set<std::string>("property_name") = NS::k_t;
472  params.set<ExecFlagEnum>("execute_on") = {EXEC_NONLINEAR};
473  params.set<std::vector<OutputName>>("outputs") = {"all"};
474  getProblem().addMaterial(object_type, prefix() + "turbulent_heat_eff_conductivity", params);
475  }
476 
478  {
479  const auto scalar_diffs = _scalar_transport_physics->getParam<std::vector<MooseFunctorName>>(
480  "passive_scalar_diffusivity");
481  const auto mat_type =
482  is_linear ? "FunctorEffectiveDynamicViscosity" : "ADFunctorEffectiveDynamicViscosity";
483  InputParameters params = getFactory().getValidParams(mat_type);
484  params.set<MooseFunctorName>(NS::mu) = _flow_equations_physics->dynamicViscosityName();
485  params.set<MooseFunctorName>(NS::mu_t) = _turbulent_viscosity_name;
486  const auto & rho_name = _flow_equations_physics->densityName();
487  params.set<MooseFunctorName>(NS::mu_t + "_inverse_factor") = rho_name;
488  const auto turbulent_schmidt_number = getParam<std::vector<Real>>("Sc_t");
489  assignBlocks(params, _blocks);
490  // LinearFV can only use 1 diffusion kernel per equation, so we create N_scalars mu_effs
491  if (is_linear)
492  for (const auto i : index_range(scalar_diffs))
493  {
494  if (!getProblem().hasFunctor(scalar_diffs[i] + "_eff", /*thread_id=*/0))
495  {
496  params.set<MooseFunctorName>("property_name") = scalar_diffs[i] + "_plus_mut/Sc_t";
497  params.set<bool>("add_dynamic_viscosity") = true;
498  params.set<Real>(NS::mu_t + "_extra_inverse_factor") =
499  (turbulent_schmidt_number.size() == 1 ? turbulent_schmidt_number[0]
500  : turbulent_schmidt_number[i]);
502  mat_type, prefix() + "mu_eff_passive_scalar_" + std::to_string(i), params);
503  }
504  }
505  // WCNSFV can add multiple diffusion kernels
506  else
507  {
508  params.set<MooseFunctorName>("property_name") = "mu_t_passive_scalar";
509  params.set<bool>("add_dynamic_viscosity") = false;
510  if (turbulent_schmidt_number.size() != 1)
511  paramError("passive_scalar_schmidt_number",
512  "A single passive scalar turbulent Schmidt number can and must be specified "
513  "with k-epsilon and the WCNSFV discretization.");
514  params.set<Real>(NS::mu_t + "_extra_inverse_factor") = turbulent_schmidt_number[0];
515  getProblem().addMaterial(mat_type, prefix() + "mu_t_passive_scalars", params);
516  }
517  }
518  }
519 }
std::string prefix() const
const VariableName _turbulent_viscosity_name
Name of the turbulence viscosity auxiliary variable (or property)
static const std::string mu_t
Definition: NS.h:129
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
const MooseFunctorName & dynamicViscosityName() const
Return the name of the dynamic viscosity functor.
const MooseFunctorName _density_name
Name of the density material property.
Factory & getFactory()
void paramError(const std::string &param, Args... args) const
const T & getParam(const std::string &name) const
const VariableName _tked_name
Name of the turbulent kinetic energy dissipation.
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
static const std::string TKE
Definition: NS.h:180
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
std::vector< SubdomainName > _blocks
const MooseFunctorName & densityName() const
Return the name of the density functor.
virtual FEProblemBase & getProblem()
Creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible N...
const MooseFunctorName & getSpecificHeatName() const
Get the name of the specific heat material property.
static const std::string mu
Definition: NS.h:127
const VariableName _tke_name
Name of the turbulent kinetic energy.
const WCNSFVFluidHeatTransferPhysicsBase * _fluid_energy_physics
The heat advection physics to add turbulent mixing for.
static const std::string mu_eff
Definition: NS.h:133
const ExecFlagType EXEC_NONLINEAR
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
static const std::string TKED
Definition: NS.h:181
const WCNSFVScalarTransportPhysicsBase * _scalar_transport_physics
The scalar advection physics to add turbulent mixing for.
bool hasFunctor(const std::string &name, const THREAD_ID tid) const
static const std::string k_t
Definition: NS.h:136
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.
auto index_range(const T &sizable)

◆ addSolverVariables()

virtual void WCNSFVTurbulencePhysicsBase::addSolverVariables ( )
overrideprotectedpure virtual

Reimplemented from PhysicsBase.

Implemented in WCNSLinearFVTurbulencePhysics, and WCNSFVTurbulencePhysics.

◆ densityName()

const MooseFunctorName& WCNSFVCoupledAdvectionPhysicsHelper::densityName ( ) const
inlineinherited

◆ dynamicViscosityName()

const MooseFunctorName& WCNSFVCoupledAdvectionPhysicsHelper::dynamicViscosityName ( ) const
inlineinherited

Definition at line 37 of file WCNSFVCoupledAdvectionPhysicsHelper.h.

37 { return _dynamic_viscosity_name; }
const MooseFunctorName _dynamic_viscosity_name
Name of the dynamic viscosity material property.

◆ getAdditionalRMParams()

InputParameters NavierStokesPhysicsBase::getAdditionalRMParams ( ) const
overrideprotectedvirtualinherited

Parameters to change or add relationship managers.

Reimplemented from PhysicsBase.

Definition at line 42 of file NavierStokesPhysicsBase.C.

43 {
44  unsigned short necessary_layers = getParam<unsigned short>("ghost_layers");
45  necessary_layers = std::max(necessary_layers, getNumberAlgebraicGhostingLayersNeeded());
46 
47  // Just an object that has a ghost_layers parameter
48  const std::string kernel_type = "INSFVMixingLengthReynoldsStress";
49  InputParameters params = getFactory().getValidParams(kernel_type);
50  params.template set<unsigned short>("ghost_layers") = necessary_layers;
51 
52  return params;
53 }
Factory & getFactory()
InputParameters getValidParams(const std::string &name) const
virtual unsigned short getNumberAlgebraicGhostingLayersNeeded() const =0
Return the number of ghosting layers needed.

◆ getCoupledFlowPhysics()

const WCNSFVFlowPhysicsBase * WCNSFVCoupledAdvectionPhysicsHelper::getCoupledFlowPhysics ( ) const
inherited

Definition at line 53 of file WCNSFVCoupledAdvectionPhysicsHelper.C.

54 {
55  // User passed it, just use that
56  if (_advection_physics->isParamValid("coupled_flow_physics"))
58  _advection_physics->getParam<PhysicsName>("coupled_flow_physics"));
59  // Look for any physics of the right type, and check the block restriction
60  else
61  {
62  const auto all_flow_physics =
64  for (const auto physics : all_flow_physics)
66  physics->name(), physics->blocks(), /*error_if_not_identical=*/false))
67  {
68  return physics;
69  }
70  }
71  mooseError("No coupled flow Physics found of type derived from 'WCNSFVFlowPhysicsBase'. Use the "
72  "'coupled_flow_physics' parameter to give the name of the desired "
73  "WCNSFVFlowPhysicsBase-derived Physics to couple with");
74 }
const T & getParam(const std::string &name) const
void mooseError(Args &&... args)
const T * getCoupledPhysics(const PhysicsName &phys_name, const bool allow_fail=false) const
Base class for Physics which create the Navier Stokes flow equations.
bool checkBlockRestrictionIdentical(const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
bool isParamValid(const std::string &name) const
const NavierStokesPhysicsBase * _advection_physics
The Physics class using this helper.

◆ getCoupledTurbulencePhysics()

const WCNSFVTurbulencePhysicsBase * WCNSFVCoupledAdvectionPhysicsHelper::getCoupledTurbulencePhysics ( ) const
inherited

Definition at line 77 of file WCNSFVCoupledAdvectionPhysicsHelper.C.

Referenced by WCNSFVScalarTransportPhysicsBase::actOnAdditionalTasks(), and WCNSFVFluidHeatTransferPhysicsBase::actOnAdditionalTasks().

78 {
79  // User passed it, just use that
80  if (_advection_physics->isParamValid("coupled_turbulence_physics"))
82  _advection_physics->getParam<PhysicsName>("coupled_turbulence_physics"));
83  // Look for any physics of the right type, and check the block restriction
84  else
85  {
86  const auto all_turbulence_physics =
88  for (const auto physics : all_turbulence_physics)
90  physics->name(), physics->blocks(), /*error_if_not_identical=*/false))
91  return physics;
92  }
93  // Did not find one
94  return nullptr;
95 }
Base class for a Physics that creates all the objects needed to add a turbulence model to an incompre...
const T & getParam(const std::string &name) const
const T * getCoupledPhysics(const PhysicsName &phys_name, const bool allow_fail=false) const
bool checkBlockRestrictionIdentical(const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
bool isParamValid(const std::string &name) const
const NavierStokesPhysicsBase * _advection_physics
The Physics class using this helper.

◆ getNumberAlgebraicGhostingLayersNeeded()

virtual unsigned short NavierStokesPhysicsBase::getNumberAlgebraicGhostingLayersNeeded ( ) const
protectedpure virtualinherited

◆ getPorosityFunctorName()

MooseFunctorName WCNSFVCoupledAdvectionPhysicsHelper::getPorosityFunctorName ( bool  smoothed) const
inherited

Return the porosity functor name.

It is important to forward to the Physics so we do not get the smoothing status wrong

Definition at line 47 of file WCNSFVCoupledAdvectionPhysicsHelper.C.

48 {
50 }
MooseFunctorName getPorosityFunctorName(const bool smoothed) const
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ hasTurbulenceModel()

bool WCNSFVTurbulencePhysicsBase::hasTurbulenceModel ( ) const
inline

Whether a turbulence model is in use.

Definition at line 43 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by WCNSFVScalarTransportPhysicsBase::actOnAdditionalTasks(), WCNSFVFluidHeatTransferPhysicsBase::actOnAdditionalTasks(), and WCNSFVFlowPhysicsBase::hasTurbulencePhysics().

43 { return _turbulence_model != "none"; }
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.

◆ retrieveCoupledPhysics()

void WCNSFVTurbulencePhysicsBase::retrieveCoupledPhysics ( )
protected

Retrieve the other WCNSFVPhysics at play in the simulation to be able to add the relevant terms (turbulent diffusion notably)

Definition at line 211 of file WCNSFVTurbulencePhysicsBase.C.

Referenced by actOnAdditionalTasks().

212 {
213  // _flow_equations_physics is initialized by 'WCNSFVCoupledAdvectionPhysicsHelper'
215  _has_flow_equations = true;
216  else
217  _has_flow_equations = false;
218 
219  // Sanity check for interaction for fluid heat transfer physics
220  if (isParamValid("fluid_heat_transfer_physics") && _turbulence_model != "none")
221  {
222  _fluid_energy_physics = getCoupledPhysics<WCNSFVFluidHeatTransferPhysicsBase>(
223  getParam<PhysicsName>("fluid_heat_transfer_physics"), true);
224  // Check for a missing parameter / do not support isolated physics for now
225  if (!_fluid_energy_physics &&
226  !getCoupledPhysics<const WCNSFVFluidHeatTransferPhysicsBase>(true).empty())
227  paramError("fluid_heat_transfer_physics",
228  "We currently do not support creating both turbulence physics and fluid heat "
229  "transfer physics that are not coupled together. Use "
230  "'fluid_heat_transfer_physics' to explicitly specify the coupling");
232  _has_energy_equation = true;
233  else
234  _has_energy_equation = false;
235  }
236  else
237  {
238  _has_energy_equation = false;
239  _fluid_energy_physics = nullptr;
240  }
241 
242  // Sanity check for interaction with scalar transport physics
243  if (isParamValid("scalar_transport_physics") && _turbulence_model != "none")
244  {
245  _scalar_transport_physics = getCoupledPhysics<WCNSFVScalarTransportPhysicsBase>(
246  getParam<PhysicsName>("scalar_transport_physics"), true);
248  !getCoupledPhysics<const WCNSFVScalarTransportPhysicsBase>(true).empty())
249  paramError(
250  "scalar_transport_physics",
251  "We currently do not support creating both turbulence physics and scalar transport "
252  "physics that are not coupled together");
254  _has_scalar_equations = true;
255  else
256  _has_scalar_equations = false;
257  }
258  else
259  {
260  _has_scalar_equations = false;
261  _scalar_transport_physics = nullptr;
262  }
263 
264  // To help remediate the danger of the parameter setup
265  if (_verbose)
266  {
268  mooseInfoRepeated("Coupling turbulence physics with fluid heat transfer physics " +
270  else
271  mooseInfoRepeated("No fluid heat transfer equation considered by this turbulence "
272  "physics.");
274  mooseInfoRepeated("Coupling turbulence physics with scalar transport physics " +
276  else
277  mooseInfoRepeated("No scalar transport equations considered by this turbulence physics.");
278  }
279 }
bool hasFlowEquations() const
Whether the physics is actually creating the flow equations.
void paramError(const std::string &param, Args... args) const
void mooseInfoRepeated(Args &&... args)
const bool _verbose
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
bool hasScalarEquations() const
Whether the physics is actually creating the scalar advection equations.
const std::string & name() const
bool hasEnergyEquation() const
Whether the physics is actually creating the heat equation.
const WCNSFVFluidHeatTransferPhysicsBase * _fluid_energy_physics
The heat advection physics to add turbulent mixing for.
const WCNSFVScalarTransportPhysicsBase * _scalar_transport_physics
The scalar advection physics to add turbulent mixing for.
bool isParamValid(const std::string &name) const
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ tkeName()

MooseFunctorName WCNSFVTurbulencePhysicsBase::tkeName ( ) const
inline

The name of the turbulent kinetic energy variable.

Definition at line 51 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by WCNSFVFluidHeatTransferPhysics::addEnergyWallBC().

51 { return _tke_name; }
const VariableName _tke_name
Name of the turbulent kinetic energy.

◆ turbulenceEpsilonWallTreatment()

MooseEnum WCNSFVTurbulencePhysicsBase::turbulenceEpsilonWallTreatment ( ) const
inline

The turbulence epsilon wall treatment (same for all turbulence walls currently)

Definition at line 47 of file WCNSFVTurbulencePhysicsBase.h.

47 { return _wall_treatment_eps; }
MooseEnum _wall_treatment_eps
Turbulence wall treatment for epsilon (same for all walls currently)

◆ turbulenceTemperatureWallTreatment()

MooseEnum WCNSFVTurbulencePhysicsBase::turbulenceTemperatureWallTreatment ( ) const
inline

The turbulence temperature wall treatment (same for all turbulence walls currently)

Definition at line 49 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by WCNSFVFluidHeatTransferPhysics::addEnergyWallBC().

49 { return _wall_treatment_temp; }
MooseEnum _wall_treatment_temp
Turbulence wall treatment for temperature (same for all walls currently)

◆ turbulenceWalls()

std::vector<BoundaryName> WCNSFVTurbulencePhysicsBase::turbulenceWalls ( ) const
inline

The names of the boundaries with turbulence wall functions.

Definition at line 45 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by WCNSFVFluidHeatTransferPhysics::addEnergyWallBC().

45 { return _turbulence_walls; }
std::vector< BoundaryName > _turbulence_walls
List of boundaries to act as walls for turbulence models.

◆ usingNavierStokesFVSyntax()

bool NavierStokesPhysicsBase::usingNavierStokesFVSyntax ( ) const
inlineprotectedinherited

Detects if we are using the new Physics syntax or the old NavierStokesFV action.

Definition at line 32 of file NavierStokesPhysicsBase.h.

33  {
34  return (parameters().get<std::string>("registered_identifier") == "Modules/NavierStokesFV");
35  }
const InputParameters & parameters() const

◆ validParams()

InputParameters WCNSFVTurbulencePhysicsBase::validParams ( )
static

Definition at line 22 of file WCNSFVTurbulencePhysicsBase.C.

Referenced by WCNSFVTurbulencePhysics::validParams(), and WCNSLinearFVTurbulencePhysics::validParams().

23 {
26  params.addClassDescription(
27  "Define a turbulence model for a incompressible or weakly-compressible Navier Stokes "
28  "flow with a finite volume discretization");
29 
30  MooseEnum turbulence_type("mixing-length k-epsilon none", "none");
31  params.addParam<MooseEnum>(
32  "turbulence_handling",
33  turbulence_type,
34  "The way turbulent diffusivities are determined in the turbulent regime.");
36 
37  params.deprecateParam("mixing_length_walls", "turbulence_walls", "");
38 
39  // Not implemented, re-enable with k-epsilon
40  params.suppressParameter<MooseEnum>("preconditioning");
41 
42  // K-Epsilon parameters
43  params.addParam<MooseFunctorName>(
44  "tke_name", NS::TKE, "Name of the turbulent kinetic energy variable");
45  params.addParam<MooseFunctorName>(
46  "tked_name", NS::TKED, "Name of the turbulent kinetic energy dissipation variable");
47  params.addParam<FunctionName>(
48  "initial_tke", "0", "Initial value for the turbulence kinetic energy");
49  params.addParam<FunctionName>(
50  "initial_tked", "0", "Initial value for the turbulence kinetic energy dissipation");
51  params.addParam<FunctionName>("initial_mu_t", "Initial value for the turbulence viscosity");
52 
53  params.addParam<MooseFunctorName>(
54  "C1_eps", "C1 coefficient for the turbulent kinetic energy dissipation equation");
55  params.addParam<MooseFunctorName>(
56  "C2_eps", "C2 coefficient for the turbulent kinetic energy dissipation equation");
57  params.addParam<MooseFunctorName>(
58  "sigma_k", "Scaling coefficient for the turbulent kinetic energy diffusion term");
59  params.addParam<MooseFunctorName>(
60  "sigma_eps",
61  "Scaling coefficient for the turbulent kinetic energy dissipation diffusion term");
62  params.addParam<MooseFunctorName>(
63  NS::turbulent_Prandtl, NS::turbulent_Prandtl, "Turbulent Prandtl number");
64  params.transferParam<Real>(INSFVTKESourceSink::validParams(), "C_pl");
65  params.transferParam<Real>(kEpsilonViscosityAux::validParams(), "mu_t_ratio_max");
66 
67  // Boundary parameters
68  params.addParam<bool>("bulk_wall_treatment", true, "Whether to treat the wall cell as bulk");
69  MooseEnum wall_treatment("eq_newton eq_incremental eq_linearized neq", "neq");
70  params.addParam<MooseEnum>("wall_treatment_eps",
71  wall_treatment,
72  "The method used for computing the epsilon wall functions and the "
73  "turbulence viscosity wall functions");
74  params.addParam<MooseEnum>("wall_treatment_T",
75  wall_treatment,
76  "The method used for computing the temperature wall functions");
77  params.transferParam<Real>(INSFVTurbulentViscosityWallFunction::validParams(), "C_mu");
78 
79  // K-Epsilon numerical scheme parameters
80  MooseEnum face_interpol_types("average skewness-corrected", "average");
81  MooseEnum adv_interpol_types("average upwind", "upwind");
82  params.addParam<MooseEnum>("tke_face_interpolation",
83  face_interpol_types,
84  "The numerical scheme to interpolate the TKE to the "
85  "face (separate from the advected quantity interpolation).");
86  params.addParam<MooseEnum>("tke_advection_interpolation",
87  adv_interpol_types,
88  "The numerical scheme to interpolate the TKE to the "
89  "face when in the advection kernel.");
90  params.addParam<bool>(
91  "tke_two_term_bc_expansion",
92  false,
93  "If a two-term Taylor expansion is needed for the determination of the boundary values"
94  "of the turbulent kinetic energy.");
95 
96  params.addParam<MooseEnum>("tked_face_interpolation",
97  face_interpol_types,
98  "The numerical scheme to interpolate the TKED to the "
99  "face (separate from the advected quantity interpolation).");
100  params.addParam<MooseEnum>("tked_advection_interpolation",
101  adv_interpol_types,
102  "The numerical scheme to interpolate the TKED to the "
103  "face when in the advection kernel.");
104  params.addParam<bool>(
105  "tked_two_term_bc_expansion",
106  false,
107  "If a two-term Taylor expansion is needed for the determination of the boundary values"
108  "of the turbulent kinetic energy dissipation.");
109  params.addParam<bool>(
110  "turbulent_viscosity_two_term_bc_expansion",
111  true,
112  "If a two-term Taylor expansion is needed for the determination of the boundary values"
113  "of the turbulent viscosity.");
114  params.addParam<bool>("mu_t_as_aux_variable",
115  false,
116  "Whether to use an auxiliary variable instead of a functor material "
117  "property for the turbulent viscosity");
118  params.addParam<bool>("output_mu_t", true, "Whether to add mu_t to the field outputs");
119  params.addParam<bool>("k_t_as_aux_variable",
120  false,
121  "Whether to use an auxiliary variable for the turbulent conductivity");
122 
123  // Add the coupled physics
124  // TODO Remove the defaults once NavierStokesFV action is removed
125  // It is a little risky right now because the user could forget to pass the parameter and
126  // be missing the influence of turbulence on either of these physics. There is a check in the
127  // constructor to present this from happening
128  params.addParam<PhysicsName>(
129  "fluid_heat_transfer_physics",
130  "NavierStokesFV",
131  "WCNS(Linear)FVFluidHeatTransferPhysics generating the heat advection equations");
132  params.addParam<PhysicsName>(
133  "scalar_transport_physics",
134  "NavierStokesFV",
135  "WCNS(Linear)FVScalarTransportPhysics generating the scalar advection equations");
136 
137  // Parameter groups
138  params.addParamNamesToGroup("fluid_heat_transfer_physics turbulent_prandtl "
139  "scalar_transport_physics Sc_t",
140  "Coupled Physics");
141  params.addParamNamesToGroup("initial_tke initial_tked C1_eps C2_eps sigma_k sigma_eps",
142  "K-Epsilon model");
143  params.addParamNamesToGroup("C_mu bulk_wall_treatment wall_treatment_eps wall_treatment_T",
144  "K-Epsilon wall function");
145  params.addParamNamesToGroup("tke_face_interpolation tke_two_term_bc_expansion "
146  "tked_face_interpolation tked_two_term_bc_expansion "
147  "turbulent_viscosity_two_term_bc_expansion "
148  "mu_t_as_aux_variable k_t_as_aux_variable",
149  "K-Epsilon model numerical");
150 
151  return params;
152 }
static const std::string turbulent_Prandtl
Definition: NS.h:142
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
static const std::string TKE
Definition: NS.h:180
static InputParameters commonTurbulenceParams()
Definition: NSFVBase.C:331
static InputParameters validParams()
static InputParameters validParams()
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
static const std::string TKED
Definition: NS.h:181
void addClassDescription(const std::string &doc_string)
static InputParameters validParams()

Member Data Documentation

◆ _advection_physics

const NavierStokesPhysicsBase* WCNSFVCoupledAdvectionPhysicsHelper::_advection_physics
protectedinherited

◆ _compressibility

const MooseEnum WCNSFVCoupledAdvectionPhysicsHelper::_compressibility
protectedinherited

Compressibility type, can be compressible, incompressible or weakly-compressible.

Definition at line 51 of file WCNSFVCoupledAdvectionPhysicsHelper.h.

Referenced by WCNSFVFluidHeatTransferPhysics::addEnergyTimeKernels().

◆ _define_variables

bool NavierStokesPhysicsBase::_define_variables
protectedinherited

◆ _density_name

const MooseFunctorName WCNSFVCoupledAdvectionPhysicsHelper::_density_name
protectedinherited

◆ _dynamic_viscosity_name

const MooseFunctorName WCNSFVCoupledAdvectionPhysicsHelper::_dynamic_viscosity_name
protectedinherited

◆ _flow_equations_physics

const WCNSFVFlowPhysicsBase* WCNSFVCoupledAdvectionPhysicsHelper::_flow_equations_physics
protectedinherited

Flow physics.

Definition at line 43 of file WCNSFVCoupledAdvectionPhysicsHelper.h.

Referenced by WCNSFVTwoPhaseMixturePhysics::addAdvectionSlipTerm(), addAuxiliaryKernels(), WCNSFVTurbulencePhysics::addAxisymmetricTurbulentViscousSource(), WCNSFVFluidHeatTransferPhysics::addEnergyAdvectionKernels(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyAdvectionKernels(), WCNSFVFluidHeatTransferPhysics::addEnergyHeatConductionKernels(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyInletBC(), WCNSFVFluidHeatTransferPhysics::addEnergyInletBC(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyOutletBC(), WCNSFVFluidHeatTransferPhysics::addEnergySeparatorBC(), WCNSFVFluidHeatTransferPhysics::addEnergyTimeKernels(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyWallBC(), WCNSFVFluidHeatTransferPhysics::addEnergyWallBC(), WCNSFVTurbulencePhysics::addFlowTurbulenceKernels(), WCNSFVTurbulencePhysics::addFluidEnergyTurbulenceKernels(), WCNSFVTwoPhaseMixturePhysics::addFunctorMaterials(), WCNSLinearFVTurbulencePhysics::addFunctorMaterials(), WCNSFVTurbulencePhysics::addFVBCs(), WCNSLinearFVTurbulencePhysics::addFVBCs(), WCNSLinearFVTwoPhaseMixturePhysics::addFVKernels(), WCNSFVTwoPhaseMixturePhysics::addFVKernels(), WCNSFVFluidHeatTransferPhysicsBase::addInitialConditions(), addInitialConditions(), WCNSLinearFVTurbulencePhysics::addKEpsilonAdvection(), WCNSFVTurbulencePhysics::addKEpsilonAdvection(), WCNSFVTurbulencePhysics::addKEpsilonDiffusion(), WCNSLinearFVTurbulencePhysics::addKEpsilonSink(), WCNSFVTurbulencePhysics::addKEpsilonSink(), WCNSLinearFVTurbulencePhysics::addKEpsilonTimeDerivatives(), WCNSFVFluidHeatTransferPhysics::addMaterials(), WCNSLinearFVFluidHeatTransferPhysics::addMaterials(), WCNSLinearFVTwoPhaseMixturePhysics::addMaterials(), addMaterials(), WCNSLinearFVTwoPhaseMixturePhysics::addPhaseDriftFluxTerm(), WCNSFVTwoPhaseMixturePhysics::addPhaseDriftFluxTerm(), WCNSLinearFVScalarTransportPhysics::addScalarAdvectionKernels(), WCNSFVScalarTransportPhysics::addScalarAdvectionKernels(), WCNSLinearFVScalarTransportPhysics::addScalarInletBC(), WCNSFVScalarTransportPhysics::addScalarInletBC(), WCNSLinearFVScalarTransportPhysics::addScalarOutletBC(), WCNSLinearFVTurbulencePhysics::checkIntegrity(), WCNSLinearFVTwoPhaseMixturePhysics::checkIntegrity(), WCNSFVTurbulencePhysics::getNumberAlgebraicGhostingLayersNeeded(), WCNSLinearFVTurbulencePhysics::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVFluidHeatTransferPhysicsBase::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVScalarTransportPhysicsBase::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVCoupledAdvectionPhysicsHelper::getPorosityFunctorName(), retrieveCoupledPhysics(), WCNSFVFluidHeatTransferPhysicsBase::WCNSFVFluidHeatTransferPhysicsBase(), WCNSFVTwoPhaseMixturePhysics::WCNSFVTwoPhaseMixturePhysics(), WCNSLinearFVScalarTransportPhysics::WCNSLinearFVScalarTransportPhysics(), and WCNSLinearFVTwoPhaseMixturePhysics::WCNSLinearFVTwoPhaseMixturePhysics().

◆ _fluid_energy_physics

const WCNSFVFluidHeatTransferPhysicsBase* WCNSFVTurbulencePhysicsBase::_fluid_energy_physics
protected

The heat advection physics to add turbulent mixing for.

Definition at line 75 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by addAuxiliaryKernels(), WCNSFVTurbulencePhysics::addFluidEnergyTurbulenceKernels(), addMaterials(), and retrieveCoupledPhysics().

◆ _has_energy_equation

bool WCNSFVTurbulencePhysicsBase::_has_energy_equation
protected

◆ _has_flow_equations

bool WCNSFVTurbulencePhysicsBase::_has_flow_equations
protected

◆ _has_scalar_equations

bool WCNSFVTurbulencePhysicsBase::_has_scalar_equations
protected

◆ _has_turbulence_model

bool WCNSFVCoupledAdvectionPhysicsHelper::_has_turbulence_model
protectedinherited

◆ _porous_medium_treatment

const bool WCNSFVCoupledAdvectionPhysicsHelper::_porous_medium_treatment
protectedinherited

◆ _pressure_name

const NonlinearVariableName WCNSFVCoupledAdvectionPhysicsHelper::_pressure_name
protectedinherited

Pressure name.

Definition at line 59 of file WCNSFVCoupledAdvectionPhysicsHelper.h.

◆ _scalar_transport_physics

const WCNSFVScalarTransportPhysicsBase* WCNSFVTurbulencePhysicsBase::_scalar_transport_physics
protected

The scalar advection physics to add turbulent mixing for.

Definition at line 77 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by addMaterials(), WCNSFVTurbulencePhysics::addScalarAdvectionTurbulenceKernels(), and retrieveCoupledPhysics().

◆ _tke_name

const VariableName WCNSFVTurbulencePhysicsBase::_tke_name
protected

◆ _tked_name

const VariableName WCNSFVTurbulencePhysicsBase::_tked_name
protected

◆ _turbulence_model

const MooseEnum WCNSFVTurbulencePhysicsBase::_turbulence_model
protected

◆ _turbulence_physics

const WCNSFVTurbulencePhysicsBase* WCNSFVCoupledAdvectionPhysicsHelper::_turbulence_physics
protectedinherited

◆ _turbulence_walls

std::vector<BoundaryName> WCNSFVTurbulencePhysicsBase::_turbulence_walls
protected

◆ _turbulent_viscosity_name

const VariableName WCNSFVTurbulencePhysicsBase::_turbulent_viscosity_name = NS::mu_t
protected

◆ _velocity_interpolation

const MooseEnum WCNSFVCoupledAdvectionPhysicsHelper::_velocity_interpolation
protectedinherited

The velocity / momentum face interpolation method for advecting other quantities.

Definition at line 67 of file WCNSFVCoupledAdvectionPhysicsHelper.h.

Referenced by WCNSFVFluidHeatTransferPhysics::addEnergyAdvectionKernels(), WCNSFVTurbulencePhysics::addKEpsilonAdvection(), and WCNSFVScalarTransportPhysics::addScalarAdvectionKernels().

◆ _velocity_names

const std::vector<std::string> WCNSFVCoupledAdvectionPhysicsHelper::_velocity_names
protectedinherited

◆ _wall_treatment_eps

MooseEnum WCNSFVTurbulencePhysicsBase::_wall_treatment_eps
protected

◆ _wall_treatment_temp

MooseEnum WCNSFVTurbulencePhysicsBase::_wall_treatment_temp
protected

Turbulence wall treatment for temperature (same for all walls currently)

Definition at line 84 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by turbulenceTemperatureWallTreatment().


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