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
WCNSFVScalarTransportPhysics Class Reference

Creates all the objects needed to solve the Navier Stokes scalar transport equations using the nonlinear finite volume weakly-compressible discretization (WCNSFV) More...

#include <WCNSFVScalarTransportPhysics.h>

Inheritance diagram for WCNSFVScalarTransportPhysics:
[legend]

Public Types

typedef DataFileName DataFileParameterType
 

Public Member Functions

 WCNSFVScalarTransportPhysics (const InputParameters &parameters)
 
const std::vector< NonlinearVariableName > & getAdvectedScalarNames () const
 Get the names of the advected scalar quantity variables. More...
 
bool hasScalarEquations () const
 Whether the physics is actually creating the scalar advection equations. More...
 
virtual void act () override final
 
virtual void actOnAdditionalTasks ()
 
void addBlocks (const std::vector< SubdomainName > &blocks)
 
void addBlocksById (const std::vector< SubdomainID > &block_ids)
 
const std::vector< SubdomainName > & blocks () const
 
bool checkBlockRestrictionIdentical (const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
 
const T * getCoupledPhysics (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
 
virtual const std::string & name () const
 
std::string typeAndName () const
 
std::string errorPrefix (const std::string &error_type) const
 
void callMooseError (std::string msg, const bool with_prefix) const
 
MooseObjectParameterName uniqueParameterName (const std::string &parameter_name) const
 
const InputParametersparameters () const
 
MooseObjectName uniqueName () const
 
const T & getParam (const std::string &name) const
 
std::vector< std::pair< T1, T2 > > getParam (const std::string &param1, const std::string &param2) const
 
const T * queryParam (const std::string &name) const
 
const T & getRenamedParam (const std::string &old_name, const std::string &new_name) const
 
getCheckedPointerParam (const std::string &name, const std::string &error_string="") const
 
bool isParamValid (const std::string &name) const
 
bool isParamSetByUser (const std::string &nm) const
 
void paramError (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
 
void connectControllableParams (const std::string &parameter, const std::string &object_type, const std::string &object_name, const std::string &object_parameter) const
 
void mooseError (Args &&... args) const
 
void mooseErrorNonPrefixed (Args &&... args) const
 
void mooseDocumentedError (const std::string &repo_name, const unsigned int issue_num, Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseInfo (Args &&... args) 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 WCNSFVTurbulencePhysicsgetCoupledTurbulencePhysics () 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 ()
 

Public Attributes

const ConsoleStream _console
 

Static Public Attributes

static constexpr auto SYSTEM
 
static constexpr auto NAME
 

Protected Member Functions

virtual void addFVKernels () override
 
virtual void addFVBCs () override
 
virtual void setSlipVelocityParams (InputParameters &) const
 
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
 
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 T & getMeshProperty (const std::string &data_name, const std::string &prefix)
 
const T & getMeshProperty (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 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

std::vector< NonlinearVariableName > _passive_scalar_names
 Names of the passive scalar variables. More...
 
const bool _has_scalar_equation
 A boolean to help compatibility with the old Modules/NavierStokesFV syntax or to deliberately skip adding the equations (for example for mixtures with a stationary phase) More...
 
MultiMooseEnum _passive_scalar_inlet_types
 Passive scalar inlet boundary types. More...
 
std::vector< std::vector< MooseFunctorName > > _passive_scalar_inlet_functors
 Functors describing the inlet boundary values. See passive_scalar_inlet_types for what the functors actually represent. More...
 
std::vector< MooseFunctorName > _passive_scalar_sources
 Functors for the passive scalar sources. Indexing is scalar variable index. More...
 
std::vector< std::vector< MooseFunctorName > > _passive_scalar_coupled_sources
 Functors for the passive scalar (coupled) sources. Inner indexing is scalar variable index. More...
 
std::vector< std::vector< Real > > _passive_scalar_sources_coef
 Coefficients multiplying for the passive scalar sources. Inner indexing is scalar variable index. 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
 
const std::string _type
 
const std::string _name
 
const InputParameters_pars
 
Factory_factory
 
ActionFactory_action_factory
 
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 WCNSFVTurbulencePhysics_turbulence_physics
 Turbulence. 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 addScalarTimeKernels () override
 Functions adding kernels for the incompressible / weakly-compressible scalar transport equation If the material properties are not constant, some of these can be used for weakly-compressible simulations as well. More...
 
virtual void addScalarDiffusionKernels () override
 
virtual void addScalarAdvectionKernels () override
 
virtual void addScalarSourceKernels () override
 Equivalent of NSFVAction addScalarCoupledSourceKernels. More...
 
virtual void addScalarInletBC () override
 Functions adding boundary conditions for the incompressible simulation. More...
 
virtual void addScalarWallBC () override
 
virtual void addScalarOutletBC () override
 

Detailed Description

Creates all the objects needed to solve the Navier Stokes scalar transport equations using the nonlinear finite volume weakly-compressible discretization (WCNSFV)

Definition at line 24 of file WCNSFVScalarTransportPhysics.h.

Constructor & Destructor Documentation

◆ WCNSFVScalarTransportPhysics()

WCNSFVScalarTransportPhysics::WCNSFVScalarTransportPhysics ( const InputParameters parameters)

Definition at line 29 of file WCNSFVScalarTransportPhysics.C.

31 {
32 }
WCNSFVScalarTransportPhysicsBase(const InputParameters &parameters)
const InputParameters & parameters() const

Member Function Documentation

◆ addFVBCs()

void WCNSFVScalarTransportPhysicsBase::addFVBCs ( )
overrideprotectedvirtualinherited

Reimplemented from PhysicsBase.

Definition at line 130 of file WCNSFVScalarTransportPhysicsBase.C.

131 {
132  // For compatibility with Modules/NavierStokesFV syntax
134  return;
135 
137  // There is typically no wall flux of passive scalars, similarly we rarely know
138  // their concentrations at the outlet at the beginning of the simulation
139  // TODO: we will know the outlet values in case of flow reversal. Implement scalar outlet
140  addScalarWallBC();
142 }
const bool _has_scalar_equation
A boolean to help compatibility with the old Modules/NavierStokesFV syntax or to deliberately skip ad...
virtual void addScalarInletBC()=0
Functions adding boundary conditions for the scalar conservation equations.
virtual void addScalarOutletBC()=0

◆ addFVKernels()

void WCNSFVScalarTransportPhysicsBase::addFVKernels ( )
overrideprotectedvirtualinherited

Reimplemented from PhysicsBase.

Reimplemented in WCNSFVTwoPhaseMixturePhysics, and WCNSLinearFVTwoPhaseMixturePhysics.

Definition at line 114 of file WCNSFVScalarTransportPhysicsBase.C.

Referenced by WCNSLinearFVTwoPhaseMixturePhysics::addFVKernels(), and WCNSFVTwoPhaseMixturePhysics::addFVKernels().

115 {
116  // For compatibility with Modules/NavierStokesFV syntax
118  return;
119 
120  if (isTransient())
122 
127 }
virtual void addScalarAdvectionKernels()=0
std::vector< std::vector< MooseFunctorName > > _passive_scalar_coupled_sources
Functors for the passive scalar (coupled) sources. Inner indexing is scalar variable index...
std::vector< MooseFunctorName > _passive_scalar_sources
Functors for the passive scalar sources. Indexing is scalar variable index.
virtual void addScalarSourceKernels()=0
Equivalent of NSFVAction addScalarCoupledSourceKernels.
virtual void addScalarDiffusionKernels()=0
const bool _has_scalar_equation
A boolean to help compatibility with the old Modules/NavierStokesFV syntax or to deliberately skip ad...
virtual void addScalarTimeKernels()=0
Functions adding kernels for the incompressible / weakly-compressible scalar transport equation...
bool isTransient() const

◆ addScalarAdvectionKernels()

void WCNSFVScalarTransportPhysics::addScalarAdvectionKernels ( )
overrideprivatevirtual

Implements WCNSFVScalarTransportPhysicsBase.

Definition at line 83 of file WCNSFVScalarTransportPhysics.C.

84 {
85  const std::string kernel_type =
86  _porous_medium_treatment ? "PINSFVScalarFieldAdvection" : "INSFVScalarFieldAdvection";
87  InputParameters params = getFactory().getValidParams(kernel_type);
88 
89  assignBlocks(params, _blocks);
90  params.set<MooseEnum>("velocity_interp_method") = _velocity_interpolation;
91  params.set<UserObjectName>("rhie_chow_user_object") = _flow_equations_physics->rhieChowUOName();
92  params.set<MooseEnum>("advected_interp_method") =
93  getParam<MooseEnum>("passive_scalar_advection_interpolation");
94  setSlipVelocityParams(params);
96  params.set<MooseFunctorName>(NS::porosity) =
98 
99  for (const auto & vname : _passive_scalar_names)
100  {
101  params.set<NonlinearVariableName>("variable") = vname;
102  getProblem().addFVKernel(kernel_type, prefix() + "ins_" + vname + "_advection", params);
103  }
104 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
std::vector< NonlinearVariableName > _passive_scalar_names
Names of the passive scalar variables.
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
static const std::string porosity
Definition: NS.h:104
virtual UserObjectName rhieChowUOName() const =0
Return the name of the Rhie Chow user object.
MooseFunctorName getPorosityFunctorName(const bool smoothed) const
const bool _porous_medium_treatment
Switch to show if porous medium treatment is requested or not.
virtual void setSlipVelocityParams(InputParameters &) const
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.
const MooseEnum _velocity_interpolation
The velocity / momentum face interpolation method for advecting other quantities. ...

◆ addScalarDiffusionKernels()

void WCNSFVScalarTransportPhysics::addScalarDiffusionKernels ( )
overrideprivatevirtual

Implements WCNSFVScalarTransportPhysicsBase.

Definition at line 107 of file WCNSFVScalarTransportPhysics.C.

108 {
109  // Direct specification of diffusion term
110  const auto passive_scalar_diffusivities =
111  getParam<std::vector<MooseFunctorName>>("passive_scalar_diffusivity");
112 
113  if (passive_scalar_diffusivities.size())
114  {
115  const std::string kernel_type = "FVDiffusion";
116  InputParameters params = getFactory().getValidParams(kernel_type);
117  assignBlocks(params, _blocks);
118  for (const auto name_i : index_range(_passive_scalar_names))
119  {
120  params.set<NonlinearVariableName>("variable") = _passive_scalar_names[name_i];
121  params.set<MooseFunctorName>("coeff") = passive_scalar_diffusivities[name_i];
123  kernel_type, prefix() + "ins_" + _passive_scalar_names[name_i] + "_diffusion", params);
124  }
125  }
126 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
std::vector< NonlinearVariableName > _passive_scalar_names
Names of the passive scalar variables.
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
auto index_range(const T &sizable)

◆ addScalarInletBC()

void WCNSFVScalarTransportPhysics::addScalarInletBC ( )
overrideprivatevirtual

Functions adding boundary conditions for the incompressible simulation.

These are used for weakly-compressible simulations as well.

Implements WCNSFVScalarTransportPhysicsBase.

Definition at line 162 of file WCNSFVScalarTransportPhysics.C.

163 {
164  const auto & inlet_boundaries = _flow_equations_physics->getInletBoundaries();
165  if (inlet_boundaries.empty())
166  return;
167 
168  // Boundary checks
169  // TODO: once we have vectors of MooseEnum, we could use the same templated check for types and
170  // functors
171  if (inlet_boundaries.size() * _passive_scalar_names.size() != _passive_scalar_inlet_types.size())
172  paramError(
173  "passive_scalar_inlet_types",
174  "The number of scalar inlet types (" + std::to_string(_passive_scalar_inlet_types.size()) +
175  ") is not equal to the number of inlet boundaries (" +
176  std::to_string(inlet_boundaries.size()) + ") times the number of passive scalars (" +
177  std::to_string(_passive_scalar_names.size()) + ")");
179  paramError("passive_scalar_inlet_functors",
180  "The number of groups of inlet functors (" +
181  std::to_string(_passive_scalar_inlet_functors.size()) +
182  ") is not equal to the number of passive scalars (" +
183  std::to_string(_passive_scalar_names.size()) + ")");
184 
185  for (const auto name_i : index_range(_passive_scalar_names))
186  {
187  if (inlet_boundaries.size() != _passive_scalar_inlet_functors[name_i].size())
188  paramError("passive_scalar_inlet_functors",
189  "The number of inlet boundary functors for scalar '" +
190  _passive_scalar_names[name_i] +
191  "' does not match the number of inlet boundaries (" +
192  std::to_string(_passive_scalar_inlet_functors[name_i].size()) + ")");
193 
194  unsigned int flux_bc_counter = 0;
195  unsigned int num_inlets = inlet_boundaries.size();
196  for (unsigned int bc_ind = 0; bc_ind < num_inlets; ++bc_ind)
197  {
198  if (_passive_scalar_inlet_types[name_i * num_inlets + bc_ind] == "fixed-value")
199  {
200  const std::string bc_type = "FVFunctionDirichletBC";
201  InputParameters params = getFactory().getValidParams(bc_type);
202  params.set<NonlinearVariableName>("variable") = _passive_scalar_names[name_i];
203  params.set<FunctionName>("function") = _passive_scalar_inlet_functors[name_i][bc_ind];
204  params.set<std::vector<BoundaryName>>("boundary") = {inlet_boundaries[bc_ind]};
205 
207  bc_type, _passive_scalar_names[name_i] + "_" + inlet_boundaries[bc_ind], params);
208  }
209  else if (_passive_scalar_inlet_types[name_i * num_inlets + bc_ind] == "flux-mass" ||
210  _passive_scalar_inlet_types[name_i * num_inlets + bc_ind] == "flux-velocity")
211  {
212  const auto flux_inlet_directions = _flow_equations_physics->getFluxInletDirections();
213  const auto flux_inlet_pps = _flow_equations_physics->getFluxInletPPs();
214 
215  const std::string bc_type = "WCNSFVScalarFluxBC";
216  InputParameters params = getFactory().getValidParams(bc_type);
217  params.set<NonlinearVariableName>("variable") = _passive_scalar_names[name_i];
218  params.set<MooseFunctorName>("passive_scalar") = _passive_scalar_names[name_i];
219  if (flux_inlet_directions.size())
220  params.set<Point>("direction") = flux_inlet_directions[flux_bc_counter];
221  if (_passive_scalar_inlet_types[name_i * num_inlets + bc_ind] == "flux-mass")
222  {
223  params.set<PostprocessorName>("mdot_pp") = flux_inlet_pps[flux_bc_counter];
224  params.set<PostprocessorName>("area_pp") = "area_pp_" + inlet_boundaries[bc_ind];
225  }
226  else
227  params.set<PostprocessorName>("velocity_pp") = flux_inlet_pps[flux_bc_counter];
228 
229  params.set<MooseFunctorName>(NS::density) = _density_name;
230  params.set<PostprocessorName>("scalar_value_pp") =
231  _passive_scalar_inlet_functors[name_i][bc_ind];
232  params.set<std::vector<BoundaryName>>("boundary") = {inlet_boundaries[bc_ind]};
233 
234  params.set<MooseFunctorName>(NS::velocity_x) = _velocity_names[0];
235  if (dimension() > 1)
236  params.set<MooseFunctorName>(NS::velocity_y) = _velocity_names[1];
237  if (dimension() > 2)
238  params.set<MooseFunctorName>(NS::velocity_z) = _velocity_names[2];
239 
240  getProblem().addFVBC(bc_type,
241  prefix() + _passive_scalar_names[name_i] + "_" +
242  inlet_boundaries[bc_ind],
243  params);
244  flux_bc_counter += 1;
245  }
246  }
247  }
248 }
std::string prefix() const
const MooseFunctorName _density_name
Name of the density material property.
Factory & getFactory()
const std::vector< BoundaryName > & getInletBoundaries() const
Get the inlet boundaries.
T & set(const std::string &name, bool quiet_mode=false)
static const std::string velocity_z
Definition: NS.h:48
static const std::string density
Definition: NS.h:33
InputParameters getValidParams(const std::string &name) const
unsigned int size() const
std::vector< NonlinearVariableName > _passive_scalar_names
Names of the passive scalar variables.
static const std::string velocity_x
Definition: NS.h:46
unsigned int dimension() const
std::vector< std::vector< MooseFunctorName > > _passive_scalar_inlet_functors
Functors describing the inlet boundary values. See passive_scalar_inlet_types for what the functors a...
virtual FEProblemBase & getProblem()
const std::vector< PostprocessorName > & getFluxInletPPs() const
Get the inlet flux postprocessor if using a flux inlet.
static const std::string velocity_y
Definition: NS.h:47
void paramError(const std::string &param, Args... args) const
const std::vector< std::string > _velocity_names
Velocity names.
MultiMooseEnum _passive_scalar_inlet_types
Passive scalar inlet boundary types.
const std::vector< Point > & getFluxInletDirections() const
Get the inlet direction if using a flux inlet.
virtual void addFVBC(const std::string &fv_bc_name, const std::string &name, InputParameters &parameters)
const WCNSFVFlowPhysicsBase * _flow_equations_physics
Flow physics.
auto index_range(const T &sizable)

◆ addScalarOutletBC()

void WCNSFVScalarTransportPhysics::addScalarOutletBC ( )
overrideprivatevirtual

Implements WCNSFVScalarTransportPhysicsBase.

Definition at line 251 of file WCNSFVScalarTransportPhysics.C.

252 {
253  // Advection outlet is naturally handled by the advection flux kernel
254  return;
255 }

◆ addScalarSourceKernels()

void WCNSFVScalarTransportPhysics::addScalarSourceKernels ( )
overrideprivatevirtual

Equivalent of NSFVAction addScalarCoupledSourceKernels.

Implements WCNSFVScalarTransportPhysicsBase.

Definition at line 129 of file WCNSFVScalarTransportPhysics.C.

130 {
131  const std::string kernel_type = "FVCoupledForce";
132  InputParameters params = getFactory().getValidParams(kernel_type);
133  assignBlocks(params, _blocks);
134 
135  for (const auto scalar_i : index_range(_passive_scalar_names))
136  {
137  params.set<NonlinearVariableName>("variable") = _passive_scalar_names[scalar_i];
138  if (_passive_scalar_sources.size())
139  {
140  // Added for backward compatibility with former Modules/NavierStokesFV syntax
141  params.set<MooseFunctorName>("v") = _passive_scalar_sources[scalar_i];
143  kernel_type, prefix() + "ins_" + _passive_scalar_names[scalar_i] + "_source", params);
144  }
145 
146  // Sufficient for all intents and purposes
148  for (const auto i : index_range(_passive_scalar_coupled_sources[scalar_i]))
149  {
150  params.set<MooseFunctorName>("v") = _passive_scalar_coupled_sources[scalar_i][i];
151  if (_passive_scalar_sources_coef.size())
152  params.set<Real>("coef") = _passive_scalar_sources_coef[scalar_i][i];
153  getProblem().addFVKernel(kernel_type,
154  prefix() + "ins_" + _passive_scalar_names[scalar_i] +
155  "_coupled_source_" + std::to_string(i),
156  params);
157  }
158  }
159 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
std::vector< NonlinearVariableName > _passive_scalar_names
Names of the passive scalar variables.
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
std::vector< std::vector< Real > > _passive_scalar_sources_coef
Coefficients multiplying for the passive scalar sources. Inner indexing is scalar variable index...
std::vector< std::vector< MooseFunctorName > > _passive_scalar_coupled_sources
Functors for the passive scalar (coupled) sources. Inner indexing is scalar variable index...
std::vector< MooseFunctorName > _passive_scalar_sources
Functors for the passive scalar sources. Indexing is scalar variable index.
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
auto index_range(const T &sizable)

◆ addScalarTimeKernels()

void WCNSFVScalarTransportPhysics::addScalarTimeKernels ( )
overrideprivatevirtual

Functions adding kernels for the incompressible / weakly-compressible scalar transport equation If the material properties are not constant, some of these can be used for weakly-compressible simulations as well.

Implements WCNSFVScalarTransportPhysicsBase.

Definition at line 68 of file WCNSFVScalarTransportPhysics.C.

69 {
70  for (const auto & vname : _passive_scalar_names)
71  {
72  const std::string kernel_type = "FVFunctorTimeKernel";
73  InputParameters params = getFactory().getValidParams(kernel_type);
74  assignBlocks(params, _blocks);
75  params.set<NonlinearVariableName>("variable") = vname;
76 
77  if (shouldCreateTimeDerivative(vname, _blocks, /* error if already defined */ false))
78  getProblem().addFVKernel(kernel_type, prefix() + "ins_" + vname + "_time", params);
79  }
80 }
std::string prefix() const
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
Factory & getFactory()
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
std::vector< NonlinearVariableName > _passive_scalar_names
Names of the passive scalar variables.
bool shouldCreateTimeDerivative(const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool error_if_already_defined) const
std::vector< SubdomainName > _blocks
virtual FEProblemBase & getProblem()
virtual void addFVKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)

◆ addScalarWallBC()

virtual void WCNSFVScalarTransportPhysics::addScalarWallBC ( )
inlineoverrideprivatevirtual

Implements WCNSFVScalarTransportPhysicsBase.

Definition at line 49 of file WCNSFVScalarTransportPhysics.h.

49 {}

◆ addSolverVariables()

void WCNSFVScalarTransportPhysics::addSolverVariables ( )
overrideprivatevirtual

Reimplemented from PhysicsBase.

Definition at line 35 of file WCNSFVScalarTransportPhysics.C.

36 {
37  // For compatibility with Modules/NavierStokesFV syntax
39  return;
40 
41  auto params = getFactory().getValidParams("INSFVScalarFieldVariable");
42  assignBlocks(params, _blocks);
43  params.set<MooseEnum>("face_interp_method") =
44  getParam<MooseEnum>("passive_scalar_face_interpolation");
45  params.set<bool>("two_term_boundary_expansion") =
46  getParam<bool>("passive_scalar_two_term_bc_expansion");
47 
48  for (const auto name_i : index_range(_passive_scalar_names))
49  {
50  // Dont add if the user already defined the variable
51  if (!shouldCreateVariable(_passive_scalar_names[name_i], _blocks, /*error if aux*/ true))
52  {
53  reportPotentiallyMissedParameters({"system_names", "passive_scalar_scaling"},
54  "INSFVScalarFieldVariable");
55  continue;
56  }
57 
58  params.set<SolverSystemName>("solver_sys") = getSolverSystem(name_i);
59  if (isParamValid("passive_scalar_scaling"))
60  params.set<std::vector<Real>>("scaling") = {
61  getParam<std::vector<Real>>("passive_scalar_scaling")[name_i]};
62 
63  getProblem().addVariable("INSFVScalarFieldVariable", _passive_scalar_names[name_i], params);
64  }
65 }
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
std::vector< NonlinearVariableName > _passive_scalar_names
Names of the passive scalar variables.
std::vector< SubdomainName > _blocks
bool isParamValid(const std::string &name) const
virtual FEProblemBase & getProblem()
const SolverSystemName & getSolverSystem(unsigned int variable_index) const
virtual void addVariable(const std::string &var_type, const std::string &var_name, InputParameters &params)
void reportPotentiallyMissedParameters(const std::vector< std::string > &param_names, const std::string &object_type) const
const bool _has_scalar_equation
A boolean to help compatibility with the old Modules/NavierStokesFV syntax or to deliberately skip ad...
auto index_range(const T &sizable)

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

◆ getAdvectedScalarNames()

const std::vector<NonlinearVariableName>& WCNSFVScalarTransportPhysicsBase::getAdvectedScalarNames ( ) const
inlineinherited

Get the names of the advected scalar quantity variables.

Definition at line 33 of file WCNSFVScalarTransportPhysicsBase.h.

Referenced by WCNSFVTurbulencePhysics::addScalarAdvectionTurbulenceKernels().

34  {
35  return _passive_scalar_names;
36  }
std::vector< NonlinearVariableName > _passive_scalar_names
Names of the passive scalar variables.

◆ 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 }
void mooseError(Args &&... args)
const T * getCoupledPhysics(const PhysicsName &phys_name, const bool allow_fail=false) const
bool isParamValid(const std::string &name) const
Base class for Physics which create the Navier Stokes flow equations.
const T & getParam(const std::string &name) const
bool checkBlockRestrictionIdentical(const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
const NavierStokesPhysicsBase * _advection_physics
The Physics class using this helper.

◆ getCoupledTurbulencePhysics()

const WCNSFVTurbulencePhysics * WCNSFVCoupledAdvectionPhysicsHelper::getCoupledTurbulencePhysics ( ) const
inherited

Definition at line 77 of file WCNSFVCoupledAdvectionPhysicsHelper.C.

Referenced by 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 }
Creates all the objects needed to add a turbulence model to an incompressible / weakly-compressible N...
const T * getCoupledPhysics(const PhysicsName &phys_name, const bool allow_fail=false) const
bool isParamValid(const std::string &name) const
const T & getParam(const std::string &name) const
bool checkBlockRestrictionIdentical(const std::string &object_name, const std::vector< SubdomainName > &blocks, const bool error_if_not_identical=true) const
const NavierStokesPhysicsBase * _advection_physics
The Physics class using this helper.

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

◆ hasScalarEquations()

bool WCNSFVScalarTransportPhysicsBase::hasScalarEquations ( ) const
inlineinherited

Whether the physics is actually creating the scalar advection equations.

Definition at line 39 of file WCNSFVScalarTransportPhysicsBase.h.

Referenced by WCNSFVTurbulencePhysics::retrieveCoupledPhysics().

39 { return _has_scalar_equation; }
const bool _has_scalar_equation
A boolean to help compatibility with the old Modules/NavierStokesFV syntax or to deliberately skip ad...

◆ setSlipVelocityParams()

virtual void WCNSFVScalarTransportPhysicsBase::setSlipVelocityParams ( InputParameters ) const
inlineprotectedvirtualinherited

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

Definition at line 19 of file WCNSFVScalarTransportPhysics.C.

Referenced by WCNSFVTwoPhaseMixturePhysics::validParams().

20 {
22  params.addClassDescription("Define the Navier Stokes weakly-compressible scalar field transport "
23  "equation(s) using the nonlinear finite volume discretization");
24  params.transferParam<MooseEnum>(NSFVBase::validParams(), "passive_scalar_face_interpolation");
25  params.addParamNamesToGroup("passive_scalar_face_interpolation", "Numerical scheme");
26  return params;
27 }
static InputParameters validParams()
Definition: NSFVBase.C:368
void transferParam(const InputParameters &source_param, const std::string &name, const std::string &new_name="", const std::string &new_description="")
void addClassDescription(const std::string &doc_string)
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 48 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(), WCNSFVTurbulencePhysics::addAuxiliaryKernels(), WCNSFVFluidHeatTransferPhysics::addEnergyAdvectionKernels(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyAdvectionKernels(), WCNSFVFluidHeatTransferPhysics::addEnergyHeatConductionKernels(), WCNSFVFluidHeatTransferPhysics::addEnergyInletBC(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyInletBC(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyOutletBC(), WCNSFVFluidHeatTransferPhysics::addEnergySeparatorBC(), WCNSFVFluidHeatTransferPhysics::addEnergyTimeKernels(), WCNSLinearFVFluidHeatTransferPhysics::addEnergyWallBC(), WCNSFVFluidHeatTransferPhysics::addEnergyWallBC(), WCNSFVTurbulencePhysics::addFlowTurbulenceKernels(), WCNSFVTurbulencePhysics::addFluidEnergyTurbulenceKernels(), WCNSFVTurbulencePhysics::addFVBCs(), WCNSLinearFVTwoPhaseMixturePhysics::addFVKernels(), WCNSFVTwoPhaseMixturePhysics::addFVKernels(), WCNSFVTurbulencePhysics::addInitialConditions(), WCNSFVTurbulencePhysics::addKEpsilonAdvection(), WCNSFVTurbulencePhysics::addKEpsilonDiffusion(), WCNSFVTurbulencePhysics::addKEpsilonSink(), WCNSLinearFVTwoPhaseMixturePhysics::addMaterials(), WCNSFVTwoPhaseMixturePhysics::addMaterials(), WCNSFVTurbulencePhysics::addMaterials(), WCNSFVFluidHeatTransferPhysicsBase::addMaterials(), WCNSLinearFVTwoPhaseMixturePhysics::addPhaseDriftFluxTerm(), WCNSFVTwoPhaseMixturePhysics::addPhaseDriftFluxTerm(), WCNSLinearFVScalarTransportPhysics::addScalarAdvectionKernels(), addScalarAdvectionKernels(), WCNSLinearFVScalarTransportPhysics::addScalarInletBC(), addScalarInletBC(), WCNSLinearFVScalarTransportPhysics::addScalarOutletBC(), WCNSLinearFVTwoPhaseMixturePhysics::checkIntegrity(), WCNSFVTurbulencePhysics::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVFluidHeatTransferPhysicsBase::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVScalarTransportPhysicsBase::getNumberAlgebraicGhostingLayersNeeded(), WCNSFVCoupledAdvectionPhysicsHelper::getPorosityFunctorName(), WCNSFVTurbulencePhysics::retrieveCoupledPhysics(), WCNSFVFluidHeatTransferPhysicsBase::WCNSFVFluidHeatTransferPhysicsBase(), WCNSFVTwoPhaseMixturePhysics::WCNSFVTwoPhaseMixturePhysics(), WCNSLinearFVScalarTransportPhysics::WCNSLinearFVScalarTransportPhysics(), and WCNSLinearFVTwoPhaseMixturePhysics::WCNSLinearFVTwoPhaseMixturePhysics().

◆ _has_scalar_equation

const bool WCNSFVScalarTransportPhysicsBase::_has_scalar_equation
protectedinherited

◆ _passive_scalar_coupled_sources

std::vector<std::vector<MooseFunctorName> > WCNSFVScalarTransportPhysicsBase::_passive_scalar_coupled_sources
protectedinherited

Functors for the passive scalar (coupled) sources. Inner indexing is scalar variable index.

Definition at line 60 of file WCNSFVScalarTransportPhysicsBase.h.

Referenced by WCNSFVScalarTransportPhysicsBase::addFVKernels(), WCNSLinearFVScalarTransportPhysics::addScalarSourceKernels(), and addScalarSourceKernels().

◆ _passive_scalar_inlet_functors

std::vector<std::vector<MooseFunctorName> > WCNSFVScalarTransportPhysicsBase::_passive_scalar_inlet_functors
protectedinherited

◆ _passive_scalar_inlet_types

MultiMooseEnum WCNSFVScalarTransportPhysicsBase::_passive_scalar_inlet_types
protectedinherited

Passive scalar inlet boundary types.

Definition at line 53 of file WCNSFVScalarTransportPhysicsBase.h.

Referenced by WCNSLinearFVScalarTransportPhysics::addScalarInletBC(), and addScalarInletBC().

◆ _passive_scalar_names

std::vector<NonlinearVariableName> WCNSFVScalarTransportPhysicsBase::_passive_scalar_names
protectedinherited

◆ _passive_scalar_sources

std::vector<MooseFunctorName> WCNSFVScalarTransportPhysicsBase::_passive_scalar_sources
protectedinherited

Functors for the passive scalar sources. Indexing is scalar variable index.

Definition at line 58 of file WCNSFVScalarTransportPhysicsBase.h.

Referenced by WCNSFVScalarTransportPhysicsBase::addFVKernels(), WCNSLinearFVScalarTransportPhysics::addScalarSourceKernels(), and addScalarSourceKernels().

◆ _passive_scalar_sources_coef

std::vector<std::vector<Real> > WCNSFVScalarTransportPhysicsBase::_passive_scalar_sources_coef
protectedinherited

Coefficients multiplying for the passive scalar sources. Inner indexing is scalar variable index.

Definition at line 62 of file WCNSFVScalarTransportPhysicsBase.h.

Referenced by WCNSLinearFVScalarTransportPhysics::addScalarSourceKernels(), addScalarSourceKernels(), and WCNSFVScalarTransportPhysicsBase::WCNSFVScalarTransportPhysicsBase().

◆ _porous_medium_treatment

const bool WCNSFVCoupledAdvectionPhysicsHelper::_porous_medium_treatment
protectedinherited

◆ _pressure_name

const NonlinearVariableName WCNSFVCoupledAdvectionPhysicsHelper::_pressure_name
protectedinherited

Pressure name.

Definition at line 56 of file WCNSFVCoupledAdvectionPhysicsHelper.h.

◆ _turbulence_physics

const WCNSFVTurbulencePhysics* WCNSFVCoupledAdvectionPhysicsHelper::_turbulence_physics
protectedinherited

◆ _velocity_interpolation

const MooseEnum WCNSFVCoupledAdvectionPhysicsHelper::_velocity_interpolation
protectedinherited

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

Definition at line 64 of file WCNSFVCoupledAdvectionPhysicsHelper.h.

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

◆ _velocity_names

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

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