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

Creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible Navier Stokes finite volume flow simulation. More...

#include <WCNSLinearFVTurbulencePhysics.h>

Inheritance diagram for WCNSLinearFVTurbulencePhysics:
[legend]

Public Types

typedef DataFileName DataFileParameterType
 

Public Member Functions

 WCNSLinearFVTurbulencePhysics (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 initializePhysicsAdditional () override
 
unsigned short getNumberAlgebraicGhostingLayersNeeded () const override
 Return the number of ghosting layers needed. More...
 
virtual void checkIntegrity () const override
 
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 addAuxiliaryVariables () override
 
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...
 
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
 
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...
 

Private Member Functions

virtual void addSolverVariables () override
 
virtual void addFVKernels () override
 
virtual void addFVBCs () override
 
virtual void addFunctorMaterials () override
 
void addKEpsilonTimeDerivatives ()
 Functions adding kernels for the k-epsilon to the k-epsilon equations. More...
 
void addKEpsilonAdvection ()
 
void addKEpsilonDiffusion ()
 
void addKEpsilonSink ()
 

Detailed Description

Creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible Navier Stokes finite volume flow simulation.

Definition at line 19 of file WCNSLinearFVTurbulencePhysics.h.

Constructor & Destructor Documentation

◆ WCNSLinearFVTurbulencePhysics()

WCNSLinearFVTurbulencePhysics::WCNSLinearFVTurbulencePhysics ( const InputParameters parameters)

Definition at line 64 of file WCNSLinearFVTurbulencePhysics.C.

66 {
67  if (_turbulence_model != "k-epsilon")
68  errorDependentParameter("turbulence_handling", "k-epsilon", {"use_nonorthogonal_correction"});
69  if (_turbulence_model == "mixing-length")
70  paramError("turbulence_handling",
71  "Mixing length is not implemented for the linear finite volume discretization");
72 }
void paramError(const std::string &param, Args... args) const
const InputParameters & parameters() const
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
void errorDependentParameter(const std::string &param1, const std::string &value_not_set, const std::vector< std::string > &dependent_params) const
WCNSFVTurbulencePhysicsBase(const InputParameters &parameters)

Member Function Documentation

◆ actOnAdditionalTasks()

void WCNSFVTurbulencePhysicsBase::actOnAdditionalTasks ( )
overrideprotectedvirtualinherited

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 ( )
overrideprotectedvirtualinherited

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 ( )
overrideprotectedvirtualinherited

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

◆ addFunctorMaterials()

void WCNSLinearFVTurbulencePhysics::addFunctorMaterials ( )
overrideprivatevirtual

Reimplemented from PhysicsBase.

Definition at line 290 of file WCNSLinearFVTurbulencePhysics.C.

291 {
292  // Functor materials for the diffusion coefficients
293  if (_turbulence_model == "k-epsilon")
294  {
295  // Since sigma_k = 1 in the standard k-epsilon, this is often unnecessary
296  const std::string mat_type = "FunctorEffectiveDynamicViscosity";
297  InputParameters params = getFactory().getValidParams(mat_type);
298  assignBlocks(params, _blocks);
299  params.set<MooseFunctorName>("property_name") = "mu_eff_tke";
300  params.set<MooseFunctorName>(NS::mu) = _flow_equations_physics->dynamicViscosityName();
301  params.set<MooseFunctorName>(NS::mu_t) = _turbulent_viscosity_name;
302  params.set<MooseFunctorName>(NS::mu_t + "_inverse_factor") =
303  getParam<MooseFunctorName>("sigma_k");
304  getProblem().addMaterial(mat_type, prefix() + "mu_eff_tke", params);
305 
306  params.set<MooseFunctorName>("property_name") = "mu_eff_tked";
307  params.set<MooseFunctorName>(NS::mu_t + "_inverse_factor") =
308  getParam<MooseFunctorName>("sigma_eps");
309  getProblem().addMaterial(mat_type, prefix() + "mu_eff_tked", params);
310  }
311 }
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.
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)
InputParameters getValidParams(const std::string &name) const
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
static const std::string mu
Definition: NS.h:127
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ addFVBCs()

void WCNSLinearFVTurbulencePhysics::addFVBCs ( )
overrideprivatevirtual

Implements WCNSFVTurbulencePhysicsBase.

Definition at line 263 of file WCNSLinearFVTurbulencePhysics.C.

264 {
265  const std::string u_names[3] = {"u", "v", "w"};
266 
267  if (_turbulence_model == "k-epsilon" && getParam<bool>("mu_t_as_aux_variable"))
268  {
269  mooseAssert(_flow_equations_physics, "Should have a flow equation physics");
270  const std::string bc_type = "LinearFVTurbulentViscosityWallFunctionBC";
271  InputParameters params = getFactory().getValidParams(bc_type);
272  params.set<std::vector<BoundaryName>>("boundary") = _turbulence_walls;
273  params.set<LinearVariableName>("variable") = _turbulent_viscosity_name;
274  params.set<MooseFunctorName>(NS::density) = _flow_equations_physics->densityName();
275  params.set<MooseFunctorName>(NS::mu) = _flow_equations_physics->dynamicViscosityName();
276  params.set<MooseFunctorName>(NS::TKE) = _tke_name;
277  params.set<Real>("C_mu") = getParam<Real>("C_mu");
278  params.set<MooseEnum>("wall_treatment") = _wall_treatment_eps;
279  for (const auto d : make_range(dimension()))
280  params.set<MooseFunctorName>(u_names[d]) = _velocity_names[d];
281 
282  getProblem().addLinearFVBC(bc_type, prefix() + "turbulence_walls", params);
283  // Energy wall function boundary conditions are added in the WCNSFVFluidEnergyPhysics
284  // because it facilitates counting the number of walls, specifying energy wall functors
285  // the same way as for boundary conditions
286  }
287 }
std::string prefix() const
const VariableName _turbulent_viscosity_name
Name of the turbulence viscosity auxiliary variable (or property)
const MooseFunctorName & dynamicViscosityName() const
Return the name of the dynamic viscosity functor.
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
static const std::string TKE
Definition: NS.h:180
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
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 mu
Definition: NS.h:127
const VariableName _tke_name
Name of the turbulent kinetic energy.
const std::vector< std::string > _velocity_names
Velocity names.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
virtual void addLinearFVBC(const std::string &fv_bc_name, const std::string &name, InputParameters &parameters)
IntRange< T > make_range(T beg, T end)
MooseEnum _wall_treatment_eps
Turbulence wall treatment for epsilon (same for all walls currently)
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ addFVKernels()

void WCNSLinearFVTurbulencePhysics::addFVKernels ( )
overrideprivatevirtual

Implements WCNSFVTurbulencePhysicsBase.

Definition at line 139 of file WCNSLinearFVTurbulencePhysics.C.

140 {
141  if (_turbulence_model == "none")
142  return;
143 
144  // For linear FV discretization:
145  // We have to add the kernel in the flow/heat/scalar physics with mu_eff instead of two kernels
146  // one with mu, one with mu_turb, and chose one of the two to NOT have the advective term
147  // Also, flux boundary conditions would be executed twice with two kernels
148 
149  // Turbulence models with their own set of equations
150  if (_turbulence_model == "k-epsilon")
151  {
152  if (isTransient())
156  addKEpsilonSink();
157  }
158 }
void addKEpsilonTimeDerivatives()
Functions adding kernels for the k-epsilon to the k-epsilon equations.
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
bool isTransient() const

◆ addInitialConditions()

void WCNSFVTurbulencePhysicsBase::addInitialConditions ( )
overrideprotectedvirtualinherited

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.

◆ addKEpsilonAdvection()

void WCNSLinearFVTurbulencePhysics::addKEpsilonAdvection ( )
private

Definition at line 177 of file WCNSLinearFVTurbulencePhysics.C.

Referenced by addFVKernels().

178 {
179  const std::string kernel_type = "LinearFVTurbulentAdvection";
180  InputParameters params = getFactory().getValidParams(kernel_type);
181 
182  assignBlocks(params, _blocks);
183 
184  params.set<UserObjectName>("rhie_chow_user_object") = _flow_equations_physics->rhieChowUOName();
185  params.set<MooseEnum>("advected_interp_method") =
186  getParam<MooseEnum>("tke_advection_interpolation");
187  params.set<LinearVariableName>("variable") = _tke_name;
188  getProblem().addLinearFVKernel(kernel_type, prefix() + "tke_advection", params);
189  params.set<LinearVariableName>("variable") = _tked_name;
190  params.set<std::vector<BoundaryName>>("walls") = _turbulence_walls;
191  params.set<MooseEnum>("advected_interp_method") =
192  getParam<MooseEnum>("tked_advection_interpolation");
193  getProblem().addLinearFVKernel(kernel_type, prefix() + "tked_advection", params);
194 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
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
std::vector< SubdomainName > _blocks
std::vector< BoundaryName > _turbulence_walls
List of boundaries to act as walls for turbulence models.
virtual FEProblemBase & getProblem()
const VariableName _tke_name
Name of the turbulent kinetic energy.
virtual void addLinearFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
const UserObjectName & rhieChowUOName() const
Return the name of the Rhie Chow user object.
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ addKEpsilonDiffusion()

void WCNSLinearFVTurbulencePhysics::addKEpsilonDiffusion ( )
private

Definition at line 197 of file WCNSLinearFVTurbulencePhysics.C.

Referenced by addFVKernels().

198 {
199  {
200  const std::string kernel_type = "LinearFVTurbulentDiffusion";
201  InputParameters params = getFactory().getValidParams(kernel_type);
202  assignBlocks(params, _blocks);
203  params.set<bool>("use_nonorthogonal_correction") =
204  getParam<bool>("use_nonorthogonal_correction");
205 
206  // Note: we have to use a single diffusion kernel in case we have a flux BC so it is not applied
207  // twice
208  params.set<LinearVariableName>("variable") = _tke_name;
209  params.set<MooseFunctorName>("diffusion_coeff") = "mu_eff_tke";
210  getProblem().addLinearFVKernel(kernel_type, prefix() + "tke_diffusion_mu", params);
211 
212  params.set<std::vector<BoundaryName>>("walls") = _turbulence_walls;
213  params.set<LinearVariableName>("variable") = _tked_name;
214  params.set<MooseFunctorName>("diffusion_coeff") = "mu_eff_tked";
215  getProblem().addLinearFVKernel(kernel_type, prefix() + "tked_diffusion_mu", params);
216  }
217 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
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
std::vector< SubdomainName > _blocks
std::vector< BoundaryName > _turbulence_walls
List of boundaries to act as walls for turbulence models.
virtual FEProblemBase & getProblem()
const VariableName _tke_name
Name of the turbulent kinetic energy.
virtual void addLinearFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)

◆ addKEpsilonSink()

void WCNSLinearFVTurbulencePhysics::addKEpsilonSink ( )
private

Definition at line 220 of file WCNSLinearFVTurbulencePhysics.C.

Referenced by addFVKernels().

221 {
222  const std::string u_names[3] = {"u", "v", "w"};
223  {
224  const std::string kernel_type = "LinearFVTKESourceSink";
225  InputParameters params = getFactory().getValidParams(kernel_type);
226  assignBlocks(params, _blocks);
227  params.set<LinearVariableName>("variable") = _tke_name;
228  params.set<MooseFunctorName>(NS::TKED) = _tked_name;
229  params.set<MooseFunctorName>(NS::density) = _flow_equations_physics->densityName();
230  params.set<MooseFunctorName>(NS::mu) = _flow_equations_physics->dynamicViscosityName();
231  params.set<MooseFunctorName>(NS::mu_t) = _turbulent_viscosity_name;
232  params.set<Real>("C_mu") = getParam<Real>("C_mu");
233  params.set<Real>("C_pl") = getParam<Real>("C_pl");
234  params.set<std::vector<BoundaryName>>("walls") = _turbulence_walls;
235  params.set<MooseEnum>("wall_treatment") = _wall_treatment_eps;
236  for (const auto d : make_range(dimension()))
237  params.set<MooseFunctorName>(u_names[d]) = _velocity_names[d];
238  getProblem().addLinearFVKernel(kernel_type, prefix() + "tke_source_sink", params);
239  }
240 
241  {
242  const std::string kernel_type = "LinearFVTKEDSourceSink";
243  InputParameters params = getFactory().getValidParams(kernel_type);
244  assignBlocks(params, _blocks);
245  params.set<LinearVariableName>("variable") = _tked_name;
246  params.set<MooseFunctorName>(NS::TKE) = _tke_name;
247  params.set<MooseFunctorName>(NS::density) = _flow_equations_physics->densityName();
248  params.set<MooseFunctorName>(NS::mu) = _flow_equations_physics->dynamicViscosityName();
249  params.set<MooseFunctorName>(NS::mu_t) = _turbulent_viscosity_name;
250  params.set<std::vector<BoundaryName>>("walls") = _turbulence_walls;
251  params.set<MooseEnum>("wall_treatment") = _wall_treatment_eps;
252  params.set<MooseFunctorName>("C1_eps") = getParam<MooseFunctorName>("C1_eps");
253  params.set<MooseFunctorName>("C2_eps") = getParam<MooseFunctorName>("C2_eps");
254  params.set<Real>("C_mu") = getParam<Real>("C_mu");
255  params.set<Real>("C_pl") = getParam<Real>("C_pl");
256  for (const auto d : make_range(dimension()))
257  params.set<MooseFunctorName>(u_names[d]) = _velocity_names[d];
258  getProblem().addLinearFVKernel(kernel_type, prefix() + "tked_source_sink", params);
259  }
260 }
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.
Factory & getFactory()
const VariableName _tked_name
Name of the turbulent kinetic energy dissipation.
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
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 mu
Definition: NS.h:127
const VariableName _tke_name
Name of the turbulent kinetic energy.
const std::vector< std::string > _velocity_names
Velocity names.
virtual void addLinearFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
IntRange< T > make_range(T beg, T end)
static const std::string TKED
Definition: NS.h:181
MooseEnum _wall_treatment_eps
Turbulence wall treatment for epsilon (same for all walls currently)
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ addKEpsilonTimeDerivatives()

void WCNSLinearFVTurbulencePhysics::addKEpsilonTimeDerivatives ( )
private

Functions adding kernels for the k-epsilon to the k-epsilon equations.

Definition at line 161 of file WCNSLinearFVTurbulencePhysics.C.

Referenced by addFVKernels().

162 {
163  const std::string kernel_type = "LinearFVTimeDerivative";
164  InputParameters params = getFactory().getValidParams(kernel_type);
165  assignBlocks(params, _blocks);
166 
167  params.set<LinearVariableName>("variable") = _tke_name;
168  params.set<MooseFunctorName>("factor") = _flow_equations_physics->densityName();
169  if (shouldCreateTimeDerivative(_tke_name, _blocks, /*error if already defined*/ false))
170  getProblem().addLinearFVKernel(kernel_type, prefix() + "tke_time", params);
171  params.set<LinearVariableName>("variable") = _tked_name;
172  if (shouldCreateTimeDerivative(_tked_name, _blocks, /*error if already defined*/ false))
173  getProblem().addLinearFVKernel(kernel_type, prefix() + "tked_time", params);
174 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
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 shouldCreateTimeDerivative(const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool error_if_already_defined) const
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.
virtual void addLinearFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ addMaterials()

void WCNSFVTurbulencePhysicsBase::addMaterials ( )
overrideprotectedvirtualinherited

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()

void WCNSLinearFVTurbulencePhysics::addSolverVariables ( )
overrideprivatevirtual

Implements WCNSFVTurbulencePhysicsBase.

Definition at line 93 of file WCNSLinearFVTurbulencePhysics.C.

94 {
95  if (_turbulence_model == "mixing-length" || _turbulence_model == "none")
96  return;
97  else if (_turbulence_model == "k-epsilon")
98  {
99  // Dont add if the user already defined the variable
100  // Add turbulent kinetic energy variable
101  if (!shouldCreateVariable(_tke_name, _blocks, /*error if aux*/ true))
102  reportPotentiallyMissedParameters({"system_names"}, "MooseLinearVariableFVReal");
103  else if (_define_variables)
104  {
105  std::string variable_type = "MooseLinearVariableFVReal";
106 
107  auto params = getFactory().getValidParams(variable_type);
108  assignBlocks(params, _blocks);
109  params.set<SolverSystemName>("solver_sys") = getSolverSystem(_tke_name);
110 
111  getProblem().addVariable(variable_type, _tke_name, params);
112  }
113  else
114  paramError("turbulence_kinetic_energy_variable",
115  "Variable (" + _tke_name +
116  ") supplied to the WCNSLinearFVTurbulencePhysics does not exist!");
117 
118  // Add turbulent kinetic energy dissipation variable
119  if (!shouldCreateVariable(_tked_name, _blocks, /*error if aux*/ true))
120  reportPotentiallyMissedParameters({"system_names"}, "MooseLinearVariableFVReal");
121  else if (_define_variables)
122  {
123  std::string variable_type = "MooseLinearVariableFVReal";
124 
125  auto params = getFactory().getValidParams(variable_type);
126  assignBlocks(params, _blocks);
127  params.set<SolverSystemName>("solver_sys") = getSolverSystem(_tked_name);
128 
129  getProblem().addVariable(variable_type, _tked_name, params);
130  }
131  else
132  paramError("turbulence_kinetic_energy_dissipation_variable",
133  "Variable (" + _tked_name +
134  ") supplied to the WCNSLinearFVTurbulencePhysics does not exist!");
135  }
136 }
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()
void paramError(const std::string &param, Args... args) const
const VariableName _tked_name
Name of the turbulent kinetic energy dissipation.
InputParameters getValidParams(const std::string &name) const
void reportPotentiallyMissedParameters(const std::vector< std::string > &param_names, const std::string &object_type, const std::string &object_name="") const
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
const SolverSystemName & getSolverSystem(unsigned int variable_index) const
const VariableName _tke_name
Name of the turbulent kinetic energy.
virtual void addVariable(const std::string &var_type, const std::string &var_name, InputParameters &params)
bool _define_variables
Whether to define variables if they do not exist.

◆ checkIntegrity()

void WCNSLinearFVTurbulencePhysics::checkIntegrity ( ) const
overrideprotectedvirtual

Reimplemented from PhysicsBase.

Definition at line 82 of file WCNSLinearFVTurbulencePhysics.C.

83 {
85 
87  !_flow_equations_physics->getParam<bool>("include_deviatoric_stress"))
89  "include_deviatoric_stress", "This should be set to true when using a turbulence model");
90 }
const T & getParam(const std::string &name) const
virtual void checkIntegrity() const
void paramWarning(const std::string &param, Args... args) const
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ 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()

unsigned short WCNSLinearFVTurbulencePhysics::getNumberAlgebraicGhostingLayersNeeded ( ) const
overrideprotectedvirtual

Return the number of ghosting layers needed.

Implements NavierStokesPhysicsBase.

Definition at line 314 of file WCNSLinearFVTurbulencePhysics.C.

315 {
317 }
unsigned short getNumberAlgebraicGhostingLayersNeeded() const override
Return the number of algebraic ghosting layers needed.
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.

◆ 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
inlineinherited

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.

◆ initializePhysicsAdditional()

void WCNSLinearFVTurbulencePhysics::initializePhysicsAdditional ( )
overrideprotectedvirtual

Reimplemented from PhysicsBase.

Definition at line 75 of file WCNSLinearFVTurbulencePhysics.C.

76 {
77  if (_turbulence_model == "k-epsilon")
79 }
const MooseEnum _turbulence_model
Turbulence model to create the equation(s) for.
virtual FEProblemBase & getProblem()
void needSolutionState(unsigned int oldest_needed, Moose::SolutionIterationType iteration_type)

◆ retrieveCoupledPhysics()

void WCNSFVTurbulencePhysicsBase::retrieveCoupledPhysics ( )
protectedinherited

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 WCNSFVTurbulencePhysicsBase::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
inlineinherited

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
inlineinherited

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
inlineinherited

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
inlineinherited

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 WCNSLinearFVTurbulencePhysics::validParams ( )
static

Definition at line 23 of file WCNSLinearFVTurbulencePhysics.C.

24 {
26  params.addClassDescription(
27  "Define a turbulence model for an incompressible or weakly-compressible Navier Stokes "
28  "flow with a linear finite volume discretization");
29 
30  params.addParam<std::vector<SolverSystemName>>(
31  "system_names",
32  {"TKE_system", "TKED_system"},
33  "Names of the linear solver systems for each equation. Default is set for K-Epsilon and "
34  "should be adapted for other models");
35 
36  // Not an option
37  params.addParam<bool>("mu_t_as_aux_variable",
38  true,
39  "Whether to use an auxiliary variable instead of a functor material "
40  "property for the turbulent viscosity");
41  params.suppressParameter<bool>("mu_t_as_aux_variable");
42  params.suppressParameter<bool>("turbulent_viscosity_two_term_bc_expansion");
43 
44  // Could be implemented when boundary conditions are implemented in turbulence physics
45  params.suppressParameter<bool>("tke_two_term_bc_expansion");
46  params.suppressParameter<bool>("tked_two_term_bc_expansion");
47 
48  // Not implemented
49  params.suppressParameter<MooseEnum>("wall_treatment_T");
50  params.suppressParameter<MooseEnum>("tke_face_interpolation");
51  params.suppressParameter<MooseEnum>("tked_face_interpolation");
52 
53  // LinearFV-specific parameters
54  params.addParam<bool>(
55  "use_nonorthogonal_correction",
56  true,
57  "Whether to use a non-orthogonal correction. This can potentially slow down convergence "
58  ", but reduces numerical dispersion on non-orthogonal meshes. Can be safely turned off on "
59  "orthogonal meshes.");
60  params.addParamNamesToGroup("use_nonorthogonal_correction", "Numerical scheme");
61  return params;
62 }
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
void suppressParameter(const std::string &name)
void addClassDescription(const std::string &doc_string)
static InputParameters validParams()
void addParamNamesToGroup(const std::string &space_delim_names, const std::string group_name)

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(), WCNSFVTurbulencePhysicsBase::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(), addFunctorMaterials(), WCNSFVTurbulencePhysics::addFVBCs(), addFVBCs(), WCNSLinearFVTwoPhaseMixturePhysics::addFVKernels(), WCNSFVTwoPhaseMixturePhysics::addFVKernels(), WCNSFVFluidHeatTransferPhysicsBase::addInitialConditions(), WCNSFVTurbulencePhysicsBase::addInitialConditions(), addKEpsilonAdvection(), WCNSFVTurbulencePhysics::addKEpsilonAdvection(), WCNSFVTurbulencePhysics::addKEpsilonDiffusion(), addKEpsilonSink(), WCNSFVTurbulencePhysics::addKEpsilonSink(), addKEpsilonTimeDerivatives(), WCNSFVFluidHeatTransferPhysics::addMaterials(), WCNSLinearFVFluidHeatTransferPhysics::addMaterials(), WCNSLinearFVTwoPhaseMixturePhysics::addMaterials(), WCNSFVTurbulencePhysicsBase::addMaterials(), WCNSLinearFVTwoPhaseMixturePhysics::addPhaseDriftFluxTerm(), WCNSFVTwoPhaseMixturePhysics::addPhaseDriftFluxTerm(), WCNSLinearFVScalarTransportPhysics::addScalarAdvectionKernels(), WCNSFVScalarTransportPhysics::addScalarAdvectionKernels(), WCNSLinearFVScalarTransportPhysics::addScalarInletBC(), WCNSFVScalarTransportPhysics::addScalarInletBC(), WCNSLinearFVScalarTransportPhysics::addScalarOutletBC(), checkIntegrity(), WCNSLinearFVTwoPhaseMixturePhysics::checkIntegrity(), WCNSFVTurbulencePhysics::getNumberAlgebraicGhostingLayersNeeded(), getNumberAlgebraicGhostingLayersNeeded(), WCNSFVFluidHeatTransferPhysicsBase::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVScalarTransportPhysicsBase::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVCoupledAdvectionPhysicsHelper::getPorosityFunctorName(), WCNSFVTurbulencePhysicsBase::retrieveCoupledPhysics(), WCNSFVFluidHeatTransferPhysicsBase::WCNSFVFluidHeatTransferPhysicsBase(), WCNSFVTwoPhaseMixturePhysics::WCNSFVTwoPhaseMixturePhysics(), WCNSLinearFVScalarTransportPhysics::WCNSLinearFVScalarTransportPhysics(), and WCNSLinearFVTwoPhaseMixturePhysics::WCNSLinearFVTwoPhaseMixturePhysics().

◆ _fluid_energy_physics

const WCNSFVFluidHeatTransferPhysicsBase* WCNSFVTurbulencePhysicsBase::_fluid_energy_physics
protectedinherited

◆ _has_energy_equation

bool WCNSFVTurbulencePhysicsBase::_has_energy_equation
protectedinherited

◆ _has_flow_equations

bool WCNSFVTurbulencePhysicsBase::_has_flow_equations
protectedinherited

◆ _has_scalar_equations

bool WCNSFVTurbulencePhysicsBase::_has_scalar_equations
protectedinherited

◆ _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
protectedinherited

◆ _tke_name

const VariableName WCNSFVTurbulencePhysicsBase::_tke_name
protectedinherited

◆ _tked_name

const VariableName WCNSFVTurbulencePhysicsBase::_tked_name
protectedinherited

◆ _turbulence_model

const MooseEnum WCNSFVTurbulencePhysicsBase::_turbulence_model
protectedinherited

◆ _turbulence_physics

const WCNSFVTurbulencePhysicsBase* WCNSFVCoupledAdvectionPhysicsHelper::_turbulence_physics
protectedinherited

◆ _turbulence_walls

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

◆ _turbulent_viscosity_name

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

◆ _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
protectedinherited

◆ _wall_treatment_temp

MooseEnum WCNSFVTurbulencePhysicsBase::_wall_treatment_temp
protectedinherited

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

Definition at line 84 of file WCNSFVTurbulencePhysicsBase.h.

Referenced by WCNSFVTurbulencePhysicsBase::turbulenceTemperatureWallTreatment().


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