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

Kernel that implements the stress tensor and advection terms for the momentum equation. More...

#include <LinearWCNSFVMomentumFlux.h>

Inheritance diagram for LinearWCNSFVMomentumFlux:
[legend]

Public Types

enum  ResidualTagType { ResidualTagType::NonReference, ResidualTagType::Reference }
 
typedef DataFileName DataFileParameterType
 

Public Member Functions

 LinearWCNSFVMomentumFlux (const InputParameters &params)
 Class constructor. More...
 
virtual Real computeElemMatrixContribution () override
 
virtual Real computeNeighborMatrixContribution () override
 
virtual Real computeElemRightHandSideContribution () override
 
virtual Real computeNeighborRightHandSideContribution () override
 
virtual Real computeBoundaryMatrixContribution (const LinearFVBoundaryCondition &bc) override
 
virtual Real computeBoundaryRHSContribution (const LinearFVBoundaryCondition &bc) override
 
virtual void setupFaceData (const FaceInfo *face_info) override
 Set the current FaceInfo object. More...
 
virtual void addMatrixContribution () override
 
virtual void addRightHandSideContribution () override
 
virtual bool hasFaceSide (const FaceInfo &fi, bool fi_elem_side) const override
 
void setCurrentFaceArea (const Real area)
 
virtual const MooseLinearVariableFV< Real > & variable () const override
 
void linkTaggedVectorsAndMatrices (const std::set< TagID > &vector_tags, const std::set< TagID > &matrix_tags)
 
virtual bool enabled () const
 
std::shared_ptr< MooseObjectgetSharedPtr ()
 
std::shared_ptr< const MooseObjectgetSharedPtr () const
 
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
 
virtual void initialSetup ()
 
virtual void timestepSetup ()
 
virtual void jacobianSetup ()
 
virtual void residualSetup ()
 
virtual void subdomainSetup ()
 
virtual void customSetup (const ExecFlagType &)
 
const ExecFlagEnumgetExecuteOnEnum () const
 
const FunctiongetFunction (const std::string &name) const
 
const FunctiongetFunctionByName (const FunctionName &name) const
 
bool hasFunction (const std::string &param_name) const
 
bool hasFunctionByName (const FunctionName &name) const
 
UserObjectName getUserObjectName (const std::string &param_name) const
 
const T & getUserObject (const std::string &param_name, bool is_dependency=true) const
 
const T & getUserObjectByName (const UserObjectName &object_name, bool is_dependency=true) const
 
const UserObjectgetUserObjectBase (const std::string &param_name, bool is_dependency=true) const
 
const UserObjectgetUserObjectBaseByName (const UserObjectName &object_name, bool is_dependency=true) const
 
bool isImplicit ()
 
Moose::StateArg determineState () const
 
bool isDefaultPostprocessorValue (const std::string &param_name, const unsigned int index=0) const
 
bool hasPostprocessor (const std::string &param_name, const unsigned int index=0) const
 
bool hasPostprocessorByName (const PostprocessorName &name) const
 
std::size_t coupledPostprocessors (const std::string &param_name) const
 
const PostprocessorName & getPostprocessorName (const std::string &param_name, const unsigned int index=0) const
 
const VectorPostprocessorValuegetVectorPostprocessorValue (const std::string &param_name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValue (const std::string &param_name, const std::string &vector_name, bool needs_broadcast) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueByName (const VectorPostprocessorName &name, const std::string &vector_name, bool needs_broadcast) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOld (const std::string &param_name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOld (const std::string &param_name, const std::string &vector_name, bool needs_broadcast) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOldByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
const VectorPostprocessorValuegetVectorPostprocessorValueOldByName (const VectorPostprocessorName &name, const std::string &vector_name, bool needs_broadcast) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValue (const std::string &param_name, const std::string &vector_name) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValueByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValueOld (const std::string &param_name, const std::string &vector_name) const
 
const ScatterVectorPostprocessorValuegetScatterVectorPostprocessorValueOldByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
bool hasVectorPostprocessor (const std::string &param_name, const std::string &vector_name) const
 
bool hasVectorPostprocessor (const std::string &param_name) const
 
bool hasVectorPostprocessorByName (const VectorPostprocessorName &name, const std::string &vector_name) const
 
bool hasVectorPostprocessorByName (const VectorPostprocessorName &name) const
 
const VectorPostprocessorName & getVectorPostprocessorName (const std::string &param_name) const
 
void setRandomResetFrequency (ExecFlagType exec_flag)
 
unsigned long getRandomLong () const
 
Real getRandomReal () const
 
unsigned int getSeed (std::size_t id)
 
unsigned int getMasterSeed () const
 
bool isNodal () const
 
ExecFlagType getResetOnTime () const
 
void setRandomDataPointer (RandomData *random_data)
 
virtual void meshChanged ()
 
void useVectorTag (const TagName &tag_name, VectorTagsKey)
 
void useVectorTag (TagID tag_id, VectorTagsKey)
 
void useMatrixTag (const TagName &tag_name, MatrixTagsKey)
 
void useMatrixTag (TagID tag_id, MatrixTagsKey)
 
bool isVectorTagged ()
 
bool isMatrixTagged ()
 
bool hasVectorTags () const
 
const std::set< TagID > & getVectorTags (VectorTagsKey) const
 
const std::set< TagID > & getMatrixTags (MatrixTagsKey) const
 
const std::vector< SubdomainName > & blocks () const
 
unsigned int numBlocks () const
 
virtual const std::set< SubdomainID > & blockIDs () const
 
unsigned int blocksMaxDimension () const
 
bool hasBlocks (const SubdomainName &name) const
 
bool hasBlocks (const std::vector< SubdomainName > &names) const
 
bool hasBlocks (const std::set< SubdomainName > &names) const
 
bool hasBlocks (SubdomainID id) const
 
bool hasBlocks (const std::vector< SubdomainID > &ids) const
 
bool hasBlocks (const std::set< SubdomainID > &ids) const
 
bool isBlockSubset (const std::set< SubdomainID > &ids) const
 
bool isBlockSubset (const std::vector< SubdomainID > &ids) const
 
bool hasBlockMaterialProperty (const std::string &prop_name)
 
const std::set< SubdomainID > & meshBlockIDs () const
 
virtual bool blockRestricted () const
 
virtual void checkVariable (const MooseVariableFieldBase &variable) const
 
MooseVariableBasemooseVariableBase () const
 
MooseVariableField< Real > & mooseVariableField ()
 
MooseVariableFE< Real > * mooseVariable () const
 
MooseVariableFV< Real > * mooseVariableFV () const
 
MooseLinearVariableFV< Real > * mooseLinearVariableFV () const
 
const std::set< MooseVariableFieldBase *> & getMooseVariableDependencies () const
 
std::set< MooseVariableFieldBase *> checkAllVariables (const DofObjectType &dof_object, const std::set< MooseVariableFieldBase * > &vars_to_omit={})
 
std::set< MooseVariableFieldBase *> checkVariables (const DofObjectType &dof_object, const std::set< MooseVariableFieldBase * > &vars_to_check)
 
void addMooseVariableDependency (MooseVariableFieldBase *var)
 
void addMooseVariableDependency (const std::vector< MooseVariableFieldBase * > &vars)
 
Moose::FaceArg makeFace (const FaceInfo &fi, const Moose::FV::LimiterType limiter_type, const bool elem_is_upwind, const bool correct_skewness=false, const Moose::StateArg *state_limiter=nullptr) const
 
Moose::FaceArg makeCDFace (const FaceInfo &fi, const bool correct_skewness=false) const
 
bool hasUserObject (const std::string &param_name) const
 
bool hasUserObject (const std::string &param_name) const
 
bool hasUserObject (const std::string &param_name) const
 
bool hasUserObject (const std::string &param_name) const
 
bool hasUserObjectByName (const UserObjectName &object_name) const
 
bool hasUserObjectByName (const UserObjectName &object_name) const
 
bool hasUserObjectByName (const UserObjectName &object_name) const
 
bool hasUserObjectByName (const UserObjectName &object_name) const
 
const PostprocessorValuegetPostprocessorValue (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValue (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOld (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOld (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOlder (const std::string &param_name, const unsigned int index=0) const
 
const PostprocessorValuegetPostprocessorValueOlder (const std::string &param_name, const unsigned int index=0) const
 
virtual const PostprocessorValuegetPostprocessorValueByName (const PostprocessorName &name) const
 
virtual const PostprocessorValuegetPostprocessorValueByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOldByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOldByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOlderByName (const PostprocessorName &name) const
 
const PostprocessorValuegetPostprocessorValueOlderByName (const PostprocessorName &name) const
 
bool isVectorPostprocessorDistributed (const std::string &param_name) const
 
bool isVectorPostprocessorDistributed (const std::string &param_name) const
 
bool isVectorPostprocessorDistributedByName (const VectorPostprocessorName &name) const
 
bool isVectorPostprocessorDistributedByName (const VectorPostprocessorName &name) const
 
const Parallel::Communicator & comm () const
 
processor_id_type n_processors () const
 
processor_id_type processor_id () const
 

Static Public Member Functions

static InputParameters validParams ()
 
static std::string deduceFunctorName (const std::string &name, const InputParameters &params)
 
static void setRMParamsAdvection (const InputParameters &obj_params, InputParameters &rm_params, const unsigned short conditional_extended_layers)
 
static void setRMParamsDiffusion (const InputParameters &obj_params, InputParameters &rm_params, const unsigned short conditional_extended_layers)
 

Public Attributes

const ConsoleStream _console
 

Protected Member Functions

Real computeInternalAdvectionElemMatrixContribution ()
 Computes the matrix contribution of the advective flux on the element side of current face when the face is an internal face (doesn't have associated boundary conditions). More...
 
Real computeInternalAdvectionNeighborMatrixContribution ()
 Computes the matrix contribution of the advective flux on the neighbor side of current face when the face is an internal face (doesn't have associated boundary conditions). More...
 
Real computeInternalStressMatrixContribution ()
 Computes the matrix contribution of the stress term on the current face when the face is an internal face (doesn't have associated boundary conditions). More...
 
Real computeInternalStressRHSContribution ()
 Computes the right hand side contribution of the stress term on the current face when the face is an internal face (doesn't have associated boundary conditions). More...
 
Real computeStressBoundaryMatrixContribution (const LinearFVAdvectionDiffusionBC *bc)
 Computes the matrix contributions of the boundary conditions resulting from the stress tensor. More...
 
Real computeStressBoundaryRHSContribution (const LinearFVAdvectionDiffusionBC *bc)
 Computes the right hand side contributions of the boundary conditions resulting from the stress tensor. More...
 
Real computeAdvectionBoundaryMatrixContribution (const LinearFVAdvectionDiffusionBC *bc)
 Computes the matrix contributions of the boundary conditions resulting from the advection term. More...
 
Real computeAdvectionBoundaryRHSContribution (const LinearFVAdvectionDiffusionBC *bc)
 Computes the right hand side contributions of the boundary conditions resulting from the advection term. More...
 
std::string deduceFunctorName (const std::string &name) const
 
Moose::FaceArg singleSidedFaceArg (const FaceInfo *fi, Moose::FV::LimiterType limiter_type=Moose::FV::LimiterType::CentralDifference, bool correct_skewness=false) const
 
virtual void addUserObjectDependencyHelper (const UserObject &) const
 
virtual void addPostprocessorDependencyHelper (const PostprocessorName &) const
 
virtual void addVectorPostprocessorDependencyHelper (const VectorPostprocessorName &) const
 
T & declareRestartableData (const std::string &data_name, Args &&... args)
 
ManagedValue< T > declareManagedRestartableDataWithContext (const std::string &data_name, void *context, Args &&... args)
 
const T & getRestartableData (const std::string &data_name) const
 
T & declareRestartableDataWithContext (const std::string &data_name, void *context, Args &&... args)
 
T & declareRecoverableData (const std::string &data_name, Args &&... args)
 
T & declareRestartableDataWithObjectName (const std::string &data_name, const std::string &object_name, Args &&... args)
 
T & declareRestartableDataWithObjectNameWithContext (const std::string &data_name, const std::string &object_name, void *context, Args &&... args)
 
std::string restartableName (const std::string &data_name) const
 
void prepareVectorTag (Assembly &assembly, unsigned int ivar)
 
void prepareVectorTag (Assembly &assembly, unsigned int ivar, ResidualTagType tag_type)
 
void prepareVectorTag (Assembly &assembly, unsigned int ivar, ResidualTagType tag_type)
 
void prepareVectorTag (Assembly &assembly, unsigned int ivar, ResidualTagType tag_type)
 
void prepareVectorTag (Assembly &assembly, unsigned int ivar, ResidualTagType tag_type)
 
void prepareVectorTagNeighbor (Assembly &assembly, unsigned int ivar)
 
void prepareVectorTagLower (Assembly &assembly, unsigned int ivar)
 
void prepareMatrixTag (Assembly &assembly, unsigned int ivar, unsigned int jvar)
 
void prepareMatrixTag (Assembly &assembly, unsigned int ivar, unsigned int jvar, DenseMatrix< Number > &k) const
 
void prepareMatrixTagNonlocal (Assembly &assembly, unsigned int ivar, unsigned int jvar)
 
void prepareMatrixTagNeighbor (Assembly &assembly, unsigned int ivar, unsigned int jvar, Moose::DGJacobianType type)
 
void prepareMatrixTagNeighbor (Assembly &assembly, unsigned int ivar, unsigned int jvar, Moose::DGJacobianType type, DenseMatrix< Number > &k) const
 
void prepareMatrixTagLower (Assembly &assembly, unsigned int ivar, unsigned int jvar, Moose::ConstraintJacobianType type)
 
void accumulateTaggedLocalResidual ()
 
void assignTaggedLocalResidual ()
 
void accumulateTaggedLocalMatrix ()
 
void accumulateTaggedLocalMatrix (Assembly &assembly, unsigned int ivar, unsigned int jvar, const DenseMatrix< Number > &k)
 
void accumulateTaggedLocalMatrix (Assembly &assembly, unsigned int ivar, unsigned int jvar, Moose::DGJacobianType type, const DenseMatrix< Number > &k)
 
void accumulateTaggedNonlocalMatrix ()
 
void assignTaggedLocalMatrix ()
 
void addResiduals (Assembly &assembly, const Residuals &residuals, const Indices &dof_indices, Real scaling_factor)
 
void addResiduals (Assembly &assembly, const DenseVector< T > &residuals, const Indices &dof_indices, Real scaling_factor)
 
void addResiduals (Assembly &assembly, const ADResidualsPacket &packet)
 
void addResidualsAndJacobian (Assembly &assembly, const Residuals &residuals, const Indices &dof_indices, Real scaling_factor)
 
void addResidualsAndJacobian (Assembly &assembly, const ADResidualsPacket &packet)
 
void addJacobian (Assembly &assembly, const Residuals &residuals, const Indices &dof_indices, Real scaling_factor)
 
void addJacobian (Assembly &assembly, const ADResidualsPacket &packet)
 
void addJacobian (Assembly &assembly, DenseMatrix< Real > &local_k, const std::vector< dof_id_type > &row_indices, const std::vector< dof_id_type > &column_indices, Real scaling_factor)
 
void addResidualsWithoutConstraints (Assembly &assembly, const Residuals &residuals, const Indices &dof_indices, Real scaling_factor)
 
void addResidualsAndJacobianWithoutConstraints (Assembly &assembly, const Residuals &residuals, const Indices &dof_indices, Real scaling_factor)
 
void addJacobianWithoutConstraints (Assembly &assembly, const Residuals &residuals, const Indices &dof_indices, Real scaling_factor)
 
void addJacobianElement (Assembly &assembly, Real value, dof_id_type row_index, dof_id_type column_index, Real scaling_factor)
 
void setResidual (SystemBase &sys, const T &residual, MooseVariableFE< T > &var)
 
void setResidual (SystemBase &sys, Real residual, dof_id_type dof_index)
 
void setResidual (SystemBase &sys, SetResidualFunctor set_residual_functor)
 
virtual bool hasBlockMaterialPropertyHelper (const std::string &prop_name)
 
void initializeBlockRestrictable (const MooseObject *moose_object)
 
Moose::CoordinateSystemType getBlockCoordSystem ()
 
const Moose::Functor< T > & getFunctor (const std::string &name)
 
const Moose::Functor< T > & getFunctor (const std::string &name, THREAD_ID tid)
 
const Moose::Functor< T > & getFunctor (const std::string &name, SubProblem &subproblem)
 
const Moose::Functor< T > & getFunctor (const std::string &name, SubProblem &subproblem, THREAD_ID tid)
 
bool isFunctor (const std::string &name) const
 
bool isFunctor (const std::string &name, const SubProblem &subproblem) const
 
Moose::ElemArg makeElemArg (const Elem *elem, bool correct_skewnewss=false) const
 
void checkFunctorSupportsSideIntegration (const std::string &name, bool qp_integration)
 
virtual const OutputTools< Real >::VariableValuevalue ()
 
virtual const OutputTools< Real >::VariableValuevalueOld ()
 
virtual const OutputTools< Real >::VariableValuevalueOlder ()
 
virtual const OutputTools< Real >::VariableValuedot ()
 
virtual const OutputTools< Real >::VariableValuedotDot ()
 
virtual const OutputTools< Real >::VariableValuedotOld ()
 
virtual const OutputTools< Real >::VariableValuedotDotOld ()
 
virtual const VariableValuedotDu ()
 
virtual const VariableValuedotDotDu ()
 
virtual const OutputTools< Real >::VariableGradientgradient ()
 
virtual const OutputTools< Real >::VariableGradientgradientOld ()
 
virtual const OutputTools< Real >::VariableGradientgradientOlder ()
 
virtual const OutputTools< Real >::VariableSecondsecond ()
 
virtual const OutputTools< Real >::VariableSecondsecondOld ()
 
virtual const OutputTools< Real >::VariableSecondsecondOlder ()
 
virtual const OutputTools< Real >::VariableTestSecondsecondTest ()
 
virtual const OutputTools< Real >::VariableTestSecondsecondTestFace ()
 
virtual const OutputTools< Real >::VariablePhiSecondsecondPhi ()
 
virtual const OutputTools< Real >::VariablePhiSecondsecondPhiFace ()
 

Protected Attributes

const unsigned int _dim
 The dimension of the mesh. More...
 
const RhieChowMassFlux_mass_flux_provider
 The Rhie-Chow user object that provides us with the face velocity. More...
 
const Moose::Functor< Real > & _mu
 The functor for the dynamic viscosity. More...
 
const bool _use_nonorthogonal_correction
 Switch to enable/disable nonorthogonal correction in the stress term. More...
 
const bool _use_deviatoric_terms
 Switch to enable/disable deviatoric parts in the stress term. More...
 
std::pair< Real, Real_advected_interp_coeffs
 Container for the current advected interpolation coefficients on the face to make sure we don't compute it multiple times for different terms. More...
 
Real _face_mass_flux
 Container for the mass flux on the face which will be reused in the advection term's matrix and right hand side contribution. More...
 
Real _stress_matrix_contribution
 The cached matrix contribution. More...
 
Real _stress_rhs_contribution
 The cached right hand side contribution. More...
 
Moose::FV::InterpMethod _advected_interp_method
 The interpolation method to use for the advected quantity. More...
 
const unsigned int _index
 Index x|y|z, this is mainly to handle the deviatoric parts correctly in in the stress term. More...
 
const MooseLinearVariableFVReal *const _u_var
 Velocity in direction x. More...
 
const MooseLinearVariableFVReal *const _v_var
 Velocity in direction y. More...
 
const MooseLinearVariableFVReal *const _w_var
 Velocity in direction z. More...
 
const FaceInfo_current_face_info
 
Real _current_face_area
 
FaceInfo::VarFaceNeighbors _current_face_type
 
bool _cached_matrix_contribution
 
bool _cached_rhs_contribution
 
const bool _force_boundary_execution
 
DenseVector< dof_id_type_dof_indices
 
DenseMatrix< Real_matrix_contribution
 
DenseVector< Real_rhs_contribution
 
MooseLinearVariableFV< Real > & _var
 
const unsigned int _var_num
 
const unsigned int _sys_num
 
FEProblemBase_fe_problem
 
SystemBase_sys
 
libMesh::LinearImplicitSystem_linear_system
 
const THREAD_ID _tid
 
MooseMesh_mesh
 
std::vector< NumericVector< Number > *> _vectors
 
std::vector< SparseMatrix< Number > *> _matrices
 
const bool & _enabled
 
MooseApp_app
 
const std::string _type
 
const std::string _name
 
const InputParameters_pars
 
Factory_factory
 
ActionFactory_action_factory
 
const ExecFlagEnum_execute_enum
 
const ExecFlagType_current_execute_flag
 
const InputParameters_ti_params
 
FEProblemBase_ti_feproblem
 
bool _is_implicit
 
Real_t
 
const Real_t_old
 
int_t_step
 
Real_dt
 
Real_dt_old
 
bool _is_transient
 
MooseApp_restartable_app
 
const std::string _restartable_system_name
 
const THREAD_ID _restartable_tid
 
const bool _restartable_read_only
 
FEProblemBase_mci_feproblem
 
SubProblem_subproblem
 
DenseVector< Number_local_re
 
DenseMatrix< Number_local_ke
 
DenseMatrix< Number_nonlocal_ke
 
const MaterialData_blk_material_data
 
bool _nodal
 
MooseVariableFE< Real > * _variable
 
MooseVariableFV< Real > * _fv_variable
 
MooseLinearVariableFV< Real > * _linear_fv_variable
 
MooseVariableField< Real > * _field_variable
 
Assembly_mvi_assembly
 
const Parallel::Communicator & _communicator
 

Detailed Description

Kernel that implements the stress tensor and advection terms for the momentum equation.

Definition at line 22 of file LinearWCNSFVMomentumFlux.h.

Constructor & Destructor Documentation

◆ LinearWCNSFVMomentumFlux()

LinearWCNSFVMomentumFlux::LinearWCNSFVMomentumFlux ( const InputParameters params)

Class constructor.

Parameters
paramsThe InputParameters for the kernel.

Definition at line 49 of file LinearWCNSFVMomentumFlux.C.

50  : LinearFVFluxKernel(params),
52  _mass_flux_provider(getUserObject<RhieChowMassFlux>("rhie_chow_user_object")),
53  _mu(getFunctor<Real>(getParam<MooseFunctorName>(NS::mu))),
54  _use_nonorthogonal_correction(getParam<bool>("use_nonorthogonal_correction")),
55  _use_deviatoric_terms(getParam<bool>("use_deviatoric_terms")),
56  _advected_interp_coeffs(std::make_pair<Real, Real>(0, 0)),
57  _face_mass_flux(0.0),
60  _index(getParam<MooseEnum>("momentum_component")),
61  _u_var(dynamic_cast<const MooseLinearVariableFVReal *>(
62  &_fe_problem.getVariable(_tid, getParam<SolverVariableName>("u")))),
63  _v_var(params.isParamValid("v")
64  ? dynamic_cast<const MooseLinearVariableFVReal *>(
65  &_fe_problem.getVariable(_tid, getParam<SolverVariableName>("v")))
66  : nullptr),
67  _w_var(params.isParamValid("w")
68  ? dynamic_cast<const MooseLinearVariableFVReal *>(
69  &_fe_problem.getVariable(_tid, getParam<SolverVariableName>("w")))
70  : nullptr)
71 {
72  // We only need gradients if the nonorthogonal correction is enabled or when we request the
73  // computation of the deviatoric parts of the stress tensor.
76 
77  Moose::FV::setInterpolationMethod(*this, _advected_interp_method, "advected_interp_method");
78 
79  if (!_u_var)
80  paramError("u", "the u velocity must be a MooseLinearVariableFVReal.");
81 
82  if (_dim >= 2 && !_v_var)
83  paramError("v",
84  "In two or more dimensions, the v velocity must be supplied and it must be a "
85  "MooseLinearVariableFVReal.");
86 
87  if (_dim >= 3 && !_w_var)
88  paramError("w",
89  "In three-dimensions, the w velocity must be supplied and it must be a "
90  "MooseLinearVariableFVReal.");
91 }
virtual MooseMesh & mesh()=0
SubProblem & _subproblem
const unsigned int _index
Index x|y|z, this is mainly to handle the deviatoric parts correctly in in the stress term...
const MooseLinearVariableFVReal *const _w_var
Velocity in direction z.
MooseLinearVariableFV< Real > & _var
const bool _use_nonorthogonal_correction
Switch to enable/disable nonorthogonal correction in the stress term.
const RhieChowMassFlux & _mass_flux_provider
The Rhie-Chow user object that provides us with the face velocity.
virtual const MooseVariableFieldBase & getVariable(const THREAD_ID tid, const std::string &var_name, Moose::VarKindType expected_var_type=Moose::VarKindType::VAR_ANY, Moose::VarFieldType expected_var_field_type=Moose::VarFieldType::VAR_FIELD_ANY) const override
const Moose::Functor< Real > & _mu
The functor for the dynamic viscosity.
const THREAD_ID _tid
virtual unsigned int dimension() const
static const std::string mu
Definition: NS.h:123
std::pair< Real, Real > _advected_interp_coeffs
Container for the current advected interpolation coefficients on the face to make sure we don&#39;t compu...
Real _stress_rhs_contribution
The cached right hand side contribution.
void paramError(const std::string &param, Args... args) const
const unsigned int _dim
The dimension of the mesh.
Real _stress_matrix_contribution
The cached matrix contribution.
LinearFVFluxKernel(const InputParameters &params)
Real _face_mass_flux
Container for the mass flux on the face which will be reused in the advection term&#39;s matrix and right...
const MooseLinearVariableFVReal *const _v_var
Velocity in direction y.
Moose::FV::InterpMethod _advected_interp_method
The interpolation method to use for the advected quantity.
FEProblemBase & _fe_problem
bool setInterpolationMethod(const MooseObject &obj, Moose::FV::InterpMethod &interp_method, const std::string &param_name)
const bool _use_deviatoric_terms
Switch to enable/disable deviatoric parts in the stress term.
const MooseLinearVariableFVReal *const _u_var
Velocity in direction x.
bool isParamValid(const std::string &name) const

Member Function Documentation

◆ computeAdvectionBoundaryMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeAdvectionBoundaryMatrixContribution ( const LinearFVAdvectionDiffusionBC bc)
protected

Computes the matrix contributions of the boundary conditions resulting from the advection term.

Parameters
bcThe boundary condition whose contributions should be used

Definition at line 316 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryMatrixContribution().

318 {
319  const auto boundary_value_matrix_contrib = bc->computeBoundaryValueMatrixContribution();
320 
321  // We support internal boundaries too so we have to make sure the normal points always outward
322  const auto factor = (_current_face_type == FaceInfo::VarFaceNeighbors::ELEM) ? 1.0 : -1.0;
323 
324  return boundary_value_matrix_contrib * factor * _face_mass_flux;
325 }
FaceInfo::VarFaceNeighbors _current_face_type
virtual Real computeBoundaryValueMatrixContribution() const=0
Real _face_mass_flux
Container for the mass flux on the face which will be reused in the advection term&#39;s matrix and right...

◆ computeAdvectionBoundaryRHSContribution()

Real LinearWCNSFVMomentumFlux::computeAdvectionBoundaryRHSContribution ( const LinearFVAdvectionDiffusionBC bc)
protected

Computes the right hand side contributions of the boundary conditions resulting from the advection term.

Parameters
bcThe boundary condition whose contributions should be used

Definition at line 328 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryRHSContribution().

330 {
331  // We support internal boundaries too so we have to make sure the normal points always outward
332  const auto factor = (_current_face_type == FaceInfo::VarFaceNeighbors::ELEM ? 1.0 : -1.0);
333 
334  const auto boundary_value_rhs_contrib = bc->computeBoundaryValueRHSContribution();
335  return -boundary_value_rhs_contrib * factor * _face_mass_flux;
336 }
FaceInfo::VarFaceNeighbors _current_face_type
Real _face_mass_flux
Container for the mass flux on the face which will be reused in the advection term&#39;s matrix and right...
virtual Real computeBoundaryValueRHSContribution() const=0

◆ computeBoundaryMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeBoundaryMatrixContribution ( const LinearFVBoundaryCondition bc)
overridevirtual

Implements LinearFVFluxKernel.

Definition at line 122 of file LinearWCNSFVMomentumFlux.C.

123 {
124  const auto * const adv_diff_bc = static_cast<const LinearFVAdvectionDiffusionBC *>(&bc);
125  mooseAssert(adv_diff_bc, "This should be a valid BC!");
126  return (computeStressBoundaryMatrixContribution(adv_diff_bc) +
129 }
Real computeAdvectionBoundaryMatrixContribution(const LinearFVAdvectionDiffusionBC *bc)
Computes the matrix contributions of the boundary conditions resulting from the advection term...
Real computeStressBoundaryMatrixContribution(const LinearFVAdvectionDiffusionBC *bc)
Computes the matrix contributions of the boundary conditions resulting from the stress tensor...

◆ computeBoundaryRHSContribution()

Real LinearWCNSFVMomentumFlux::computeBoundaryRHSContribution ( const LinearFVBoundaryCondition bc)
overridevirtual

Implements LinearFVFluxKernel.

Definition at line 132 of file LinearWCNSFVMomentumFlux.C.

133 {
134  const auto * const adv_diff_bc = static_cast<const LinearFVAdvectionDiffusionBC *>(&bc);
135  mooseAssert(adv_diff_bc, "This should be a valid BC!");
136  return (computeStressBoundaryRHSContribution(adv_diff_bc) +
139 }
Real computeStressBoundaryRHSContribution(const LinearFVAdvectionDiffusionBC *bc)
Computes the right hand side contributions of the boundary conditions resulting from the stress tenso...
Real computeAdvectionBoundaryRHSContribution(const LinearFVAdvectionDiffusionBC *bc)
Computes the right hand side contributions of the boundary conditions resulting from the advection te...

◆ computeElemMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeElemMatrixContribution ( )
overridevirtual

Implements LinearFVFluxKernel.

Definition at line 94 of file LinearWCNSFVMomentumFlux.C.

95 {
99 }
Real computeInternalAdvectionElemMatrixContribution()
Computes the matrix contribution of the advective flux on the element side of current face when the f...
Real computeInternalStressMatrixContribution()
Computes the matrix contribution of the stress term on the current face when the face is an internal ...

◆ computeElemRightHandSideContribution()

Real LinearWCNSFVMomentumFlux::computeElemRightHandSideContribution ( )
overridevirtual

Implements LinearFVFluxKernel.

Definition at line 110 of file LinearWCNSFVMomentumFlux.C.

111 {
113 }
Real computeInternalStressRHSContribution()
Computes the right hand side contribution of the stress term on the current face when the face is an ...

◆ computeInternalAdvectionElemMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeInternalAdvectionElemMatrixContribution ( )
protected

Computes the matrix contribution of the advective flux on the element side of current face when the face is an internal face (doesn't have associated boundary conditions).

Definition at line 142 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeElemMatrixContribution().

143 {
145 }
std::pair< Real, Real > _advected_interp_coeffs
Container for the current advected interpolation coefficients on the face to make sure we don&#39;t compu...
Real _face_mass_flux
Container for the mass flux on the face which will be reused in the advection term&#39;s matrix and right...

◆ computeInternalAdvectionNeighborMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeInternalAdvectionNeighborMatrixContribution ( )
protected

Computes the matrix contribution of the advective flux on the neighbor side of current face when the face is an internal face (doesn't have associated boundary conditions).

Definition at line 148 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeNeighborMatrixContribution().

149 {
151 }
std::pair< Real, Real > _advected_interp_coeffs
Container for the current advected interpolation coefficients on the face to make sure we don&#39;t compu...
Real _face_mass_flux
Container for the mass flux on the face which will be reused in the advection term&#39;s matrix and right...

◆ computeInternalStressMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeInternalStressMatrixContribution ( )
protected

Computes the matrix contribution of the stress term on the current face when the face is an internal face (doesn't have associated boundary conditions).

Definition at line 154 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeElemMatrixContribution(), and computeNeighborMatrixContribution().

155 {
156  // If we don't have the value yet, we compute it
158  {
159  const auto face_arg = makeCDFace(*_current_face_info);
160 
161  // If we requested nonorthogonal correction, we use the normal component of the
162  // cell to face vector.
163  const auto d = _use_nonorthogonal_correction
164  ? std::abs(_current_face_info->dCN() * _current_face_info->normal())
166 
167  // Cache the matrix contribution
170  }
171 
173 }
Moose::StateArg determineState() const
const bool _use_nonorthogonal_correction
Switch to enable/disable nonorthogonal correction in the stress term.
const Moose::Functor< Real > & _mu
The functor for the dynamic viscosity.
const FaceInfo * _current_face_info
const Point & normal() const
Real dCNMag() const
Real _stress_matrix_contribution
The cached matrix contribution.
bool _cached_matrix_contribution
Moose::FaceArg makeCDFace(const FaceInfo &fi, const bool correct_skewness=false) const
const Point & dCN() const

◆ computeInternalStressRHSContribution()

Real LinearWCNSFVMomentumFlux::computeInternalStressRHSContribution ( )
protected

Computes the right hand side contribution of the stress term on the current face when the face is an internal face (doesn't have associated boundary conditions).

Definition at line 176 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeElemRightHandSideContribution(), and computeNeighborRightHandSideContribution().

177 {
178  // We can have contributions to the right hand side in two occasions:
179  // (1) when we use nonorthogonal correction for the normal gradients
180  // (2) when we request the deviatoric parts of the stress tensor. (needed for space-dependent
181  // viscosities for example)
183  {
184  // scenario (1), we need to add the nonorthogonal correction. In 1D, we don't have
185  // any correction so we just skip this part
187  {
188  const auto face_arg = makeCDFace(*_current_face_info);
189  const auto state_arg = determineState();
190 
191  // Get the gradients from the adjacent cells
192  const auto grad_elem = _var.gradSln(*_current_face_info->elemInfo());
193  const auto & grad_neighbor = _var.gradSln(*_current_face_info->neighborInfo());
194 
195  // Interpolate the two gradients to the face
196  const auto interp_coeffs =
198 
199  const auto correction_vector =
203 
204  // Cache the matrix contribution
206  _mu(face_arg, state_arg) *
207  (interp_coeffs.first * grad_elem + interp_coeffs.second * grad_neighbor) *
208  correction_vector;
209  }
210  // scenario (2), we will have to account for the deviatoric parts of the stress tensor.
211  else if (_use_deviatoric_terms)
212  {
213  // Interpolate the two gradients to the face
214  const auto interp_coeffs =
216 
217  const auto u_grad_elem = _u_var->gradSln(*_current_face_info->elemInfo());
218  const auto u_grad_neighbor = _u_var->gradSln(*_current_face_info->neighborInfo());
219 
220  Real trace_elem = 0;
221  Real trace_neighbor = 0;
222  RealVectorValue deviatoric_vector_elem;
223  RealVectorValue deviatoric_vector_neighbor;
224 
225  deviatoric_vector_elem(0) = u_grad_elem(_index);
226  deviatoric_vector_neighbor(0) = u_grad_neighbor(_index);
227  trace_elem += u_grad_elem(0);
228  trace_neighbor += u_grad_neighbor(0);
229 
230  const auto face_arg = makeCDFace(*_current_face_info);
231  const auto state_arg = determineState();
232 
233  if (_dim > 1)
234  {
235  const auto v_grad_elem = _v_var->gradSln(*_current_face_info->elemInfo());
236  const auto v_grad_neighbor = _v_var->gradSln(*_current_face_info->neighborInfo());
237 
238  deviatoric_vector_elem(1) = v_grad_elem(_index);
239  deviatoric_vector_neighbor(1) = v_grad_neighbor(_index);
240  trace_elem += v_grad_elem(1);
241  trace_neighbor += v_grad_neighbor(1);
242  if (_dim > 2)
243  {
244  const auto w_grad_elem = _w_var->gradSln(*_current_face_info->elemInfo());
245  const auto w_grad_neighbor = _w_var->gradSln(*_current_face_info->neighborInfo());
246 
247  deviatoric_vector_elem(2) = w_grad_elem(_index);
248  deviatoric_vector_neighbor(2) = w_grad_neighbor(_index);
249  trace_elem += w_grad_elem(2);
250  trace_neighbor += w_grad_neighbor(2);
251  }
252  }
253  deviatoric_vector_elem(_index) = trace_elem;
254  deviatoric_vector_neighbor(_index) = trace_neighbor;
255 
256  _stress_rhs_contribution += _mu(face_arg, state_arg) *
257  (interp_coeffs.first * deviatoric_vector_elem +
258  interp_coeffs.second * deviatoric_vector_neighbor) *
260  }
262  }
263 
265 }
const unsigned int _index
Index x|y|z, this is mainly to handle the deviatoric parts correctly in in the stress term...
const MooseLinearVariableFVReal *const _w_var
Velocity in direction z.
std::pair< Real, Real > interpCoeffs(const InterpMethod m, const FaceInfo &fi, const bool one_is_elem, const T &face_flux=0.0)
Moose::StateArg determineState() const
const ElemInfo * neighborInfo() const
MooseLinearVariableFV< Real > & _var
const bool _use_nonorthogonal_correction
Switch to enable/disable nonorthogonal correction in the stress term.
const ElemInfo * elemInfo() const
const Moose::Functor< Real > & _mu
The functor for the dynamic viscosity.
const FaceInfo * _current_face_info
Real _stress_rhs_contribution
The cached right hand side contribution.
const Point & normal() const
const unsigned int _dim
The dimension of the mesh.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Point & eCN() const
const MooseLinearVariableFVReal *const _v_var
Velocity in direction y.
const VectorValue< Real > gradSln(const ElemInfo &elem_info) const
Moose::FaceArg makeCDFace(const FaceInfo &fi, const bool correct_skewness=false) const
const bool _use_deviatoric_terms
Switch to enable/disable deviatoric parts in the stress term.
const MooseLinearVariableFVReal *const _u_var
Velocity in direction x.

◆ computeNeighborMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeNeighborMatrixContribution ( )
overridevirtual

Implements LinearFVFluxKernel.

Definition at line 102 of file LinearWCNSFVMomentumFlux.C.

103 {
107 }
Real computeInternalAdvectionNeighborMatrixContribution()
Computes the matrix contribution of the advective flux on the neighbor side of current face when the ...
Real computeInternalStressMatrixContribution()
Computes the matrix contribution of the stress term on the current face when the face is an internal ...

◆ computeNeighborRightHandSideContribution()

Real LinearWCNSFVMomentumFlux::computeNeighborRightHandSideContribution ( )
overridevirtual

Implements LinearFVFluxKernel.

Definition at line 116 of file LinearWCNSFVMomentumFlux.C.

117 {
119 }
Real computeInternalStressRHSContribution()
Computes the right hand side contribution of the stress term on the current face when the face is an ...

◆ computeStressBoundaryMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeStressBoundaryMatrixContribution ( const LinearFVAdvectionDiffusionBC bc)
protected

Computes the matrix contributions of the boundary conditions resulting from the stress tensor.

Parameters
bcThe boundary condition whose contributions should be used

Definition at line 268 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryMatrixContribution().

270 {
271  auto grad_contrib = bc->computeBoundaryGradientMatrixContribution();
272  // If the boundary condition does not include the diffusivity contribution then
273  // add it here.
275  {
276  const auto face_arg = singleSidedFaceArg(_current_face_info);
277  grad_contrib *= _mu(face_arg, determineState());
278  }
279 
280  return grad_contrib;
281 }
Moose::FaceArg singleSidedFaceArg(const FaceInfo *fi, Moose::FV::LimiterType limiter_type=Moose::FV::LimiterType::CentralDifference, bool correct_skewness=false) const
Moose::StateArg determineState() const
virtual Real computeBoundaryGradientMatrixContribution() const=0
const Moose::Functor< Real > & _mu
The functor for the dynamic viscosity.
const FaceInfo * _current_face_info
virtual bool includesMaterialPropertyMultiplier() const

◆ computeStressBoundaryRHSContribution()

Real LinearWCNSFVMomentumFlux::computeStressBoundaryRHSContribution ( const LinearFVAdvectionDiffusionBC bc)
protected

Computes the right hand side contributions of the boundary conditions resulting from the stress tensor.

Parameters
bcThe boundary condition whose contributions should be used

Definition at line 284 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryRHSContribution().

286 {
287  const auto face_arg = singleSidedFaceArg(_current_face_info);
288  auto grad_contrib = bc->computeBoundaryGradientRHSContribution();
289 
290  // If the boundary condition does not include the diffusivity contribution then
291  // add it here.
293  grad_contrib *= _mu(face_arg, determineState());
294 
295  // We add the nonorthogonal corrector for the face here. Potential idea: we could do
296  // this in the boundary condition too. For now, however, we keep it like this.
298  {
299  const auto correction_vector =
302 
303  // We might be on a face which is an internal boundary so we want to make sure we
304  // get the gradient from the right side.
305  const auto elem_info = (_current_face_type == FaceInfo::VarFaceNeighbors::ELEM)
308 
309  grad_contrib += _mu(face_arg, determineState()) * _var.gradSln(*elem_info) * correction_vector;
310  }
311 
312  return grad_contrib;
313 }
virtual Real computeBoundaryGradientRHSContribution() const=0
Moose::FaceArg singleSidedFaceArg(const FaceInfo *fi, Moose::FV::LimiterType limiter_type=Moose::FV::LimiterType::CentralDifference, bool correct_skewness=false) const
Moose::StateArg determineState() const
const ElemInfo * neighborInfo() const
MooseLinearVariableFV< Real > & _var
const bool _use_nonorthogonal_correction
Switch to enable/disable nonorthogonal correction in the stress term.
const ElemInfo * elemInfo() const
FaceInfo::VarFaceNeighbors _current_face_type
const Moose::Functor< Real > & _mu
The functor for the dynamic viscosity.
const FaceInfo * _current_face_info
const Point & normal() const
virtual bool includesMaterialPropertyMultiplier() const
const Point & eCN() const
const VectorValue< Real > gradSln(const ElemInfo &elem_info) const

◆ setupFaceData()

void LinearWCNSFVMomentumFlux::setupFaceData ( const FaceInfo face_info)
overridevirtual

Set the current FaceInfo object.

We override this here to make sure the face velocity evaluation happens only once and that it can be reused for the matrix and right hand side contributions.

Parameters
face_infoThe face info which will be used as current face info

Reimplemented from LinearFVFluxKernel.

Definition at line 339 of file LinearWCNSFVMomentumFlux.C.

340 {
342 
343  // Caching the mass flux on the face which will be reused in the advection term's matrix and right
344  // hand side contributions
346 
347  // Caching the interpolation coefficients so they will be reused for the matrix and right hand
348  // side terms
351 
352  // We'll have to set this to zero to make sure that we don't accumulate values over multiple
353  // faces. The matrix contribution should be fine.
355 }
std::pair< Real, Real > interpCoeffs(const InterpMethod m, const FaceInfo &fi, const bool one_is_elem, const T &face_flux=0.0)
Real getMassFlux(const FaceInfo &fi) const
Get the face velocity times density (used in advection terms)
virtual void setupFaceData(const FaceInfo *face_info)
const RhieChowMassFlux & _mass_flux_provider
The Rhie-Chow user object that provides us with the face velocity.
const FaceInfo * _current_face_info
std::pair< Real, Real > _advected_interp_coeffs
Container for the current advected interpolation coefficients on the face to make sure we don&#39;t compu...
Real _stress_rhs_contribution
The cached right hand side contribution.
Real _face_mass_flux
Container for the mass flux on the face which will be reused in the advection term&#39;s matrix and right...
Moose::FV::InterpMethod _advected_interp_method
The interpolation method to use for the advected quantity.

◆ validParams()

InputParameters LinearWCNSFVMomentumFlux::validParams ( )
static

Definition at line 21 of file LinearWCNSFVMomentumFlux.C.

22 {
24  params.addClassDescription("Represents the matrix and right hand side contributions of the "
25  "stress and advection terms of the momentum equation.");
26  params.addRequiredParam<SolverVariableName>("u", "The velocity in the x direction.");
27  params.addParam<SolverVariableName>("v", "The velocity in the y direction.");
28  params.addParam<SolverVariableName>("w", "The velocity in the z direction.");
29  params.addRequiredParam<UserObjectName>(
30  "rhie_chow_user_object",
31  "The rhie-chow user-object which is used to determine the face velocity.");
32  params.addRequiredParam<MooseFunctorName>(NS::mu, "The diffusion coefficient.");
33  MooseEnum momentum_component("x=0 y=1 z=2");
35  "momentum_component",
36  momentum_component,
37  "The component of the momentum equation that this kernel applies to.");
38  params.addParam<bool>(
39  "use_nonorthogonal_correction",
40  true,
41  "If the nonorthogonal correction should be used when computing the normal gradient.");
42  params.addParam<bool>(
43  "use_deviatoric_terms", false, "If deviatoric terms in the stress terms need to be used.");
44 
46  return params;
47 }
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
void addRequiredParam(const std::string &name, const std::string &doc_string)
static InputParameters validParams()
InputParameters advectedInterpolationParameter()
static const std::string mu
Definition: NS.h:123
void addClassDescription(const std::string &doc_string)

Member Data Documentation

◆ _advected_interp_coeffs

std::pair<Real, Real> LinearWCNSFVMomentumFlux::_advected_interp_coeffs
protected

Container for the current advected interpolation coefficients on the face to make sure we don't compute it multiple times for different terms.

Definition at line 106 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalAdvectionElemMatrixContribution(), computeInternalAdvectionNeighborMatrixContribution(), and setupFaceData().

◆ _advected_interp_method

Moose::FV::InterpMethod LinearWCNSFVMomentumFlux::_advected_interp_method
protected

The interpolation method to use for the advected quantity.

Definition at line 119 of file LinearWCNSFVMomentumFlux.h.

Referenced by LinearWCNSFVMomentumFlux(), and setupFaceData().

◆ _dim

const unsigned int LinearWCNSFVMomentumFlux::_dim
protected

The dimension of the mesh.

Definition at line 90 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and LinearWCNSFVMomentumFlux().

◆ _face_mass_flux

Real LinearWCNSFVMomentumFlux::_face_mass_flux
protected

Container for the mass flux on the face which will be reused in the advection term's matrix and right hand side contribution.

Definition at line 110 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeAdvectionBoundaryMatrixContribution(), computeAdvectionBoundaryRHSContribution(), computeInternalAdvectionElemMatrixContribution(), computeInternalAdvectionNeighborMatrixContribution(), and setupFaceData().

◆ _index

const unsigned int LinearWCNSFVMomentumFlux::_index
protected

Index x|y|z, this is mainly to handle the deviatoric parts correctly in in the stress term.

Definition at line 123 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution().

◆ _mass_flux_provider

const RhieChowMassFlux& LinearWCNSFVMomentumFlux::_mass_flux_provider
protected

The Rhie-Chow user object that provides us with the face velocity.

Definition at line 93 of file LinearWCNSFVMomentumFlux.h.

Referenced by setupFaceData().

◆ _mu

const Moose::Functor<Real>& LinearWCNSFVMomentumFlux::_mu
protected

◆ _stress_matrix_contribution

Real LinearWCNSFVMomentumFlux::_stress_matrix_contribution
protected

The cached matrix contribution.

Definition at line 113 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressMatrixContribution().

◆ _stress_rhs_contribution

Real LinearWCNSFVMomentumFlux::_stress_rhs_contribution
protected

The cached right hand side contribution.

Definition at line 116 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and setupFaceData().

◆ _u_var

const MooseLinearVariableFVReal* const LinearWCNSFVMomentumFlux::_u_var
protected

Velocity in direction x.

Definition at line 126 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and LinearWCNSFVMomentumFlux().

◆ _use_deviatoric_terms

const bool LinearWCNSFVMomentumFlux::_use_deviatoric_terms
protected

Switch to enable/disable deviatoric parts in the stress term.

Definition at line 102 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and LinearWCNSFVMomentumFlux().

◆ _use_nonorthogonal_correction

const bool LinearWCNSFVMomentumFlux::_use_nonorthogonal_correction
protected

Switch to enable/disable nonorthogonal correction in the stress term.

Definition at line 99 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressMatrixContribution(), computeInternalStressRHSContribution(), computeStressBoundaryRHSContribution(), and LinearWCNSFVMomentumFlux().

◆ _v_var

const MooseLinearVariableFVReal* const LinearWCNSFVMomentumFlux::_v_var
protected

Velocity in direction y.

Definition at line 128 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and LinearWCNSFVMomentumFlux().

◆ _w_var

const MooseLinearVariableFVReal* const LinearWCNSFVMomentumFlux::_w_var
protected

Velocity in direction z.

Definition at line 130 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and LinearWCNSFVMomentumFlux().


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