https://mooseframework.inl.gov
Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Static 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 Real computeBoundaryFlux (const LinearFVBoundaryCondition &bc)
 
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
 
bool isKokkosObject () const
 
MooseAppgetMooseApp () const
 
const std::string & type () const
 
const std::string & name () const
 
std::string typeAndName () const
 
MooseObjectParameterName uniqueParameterName (const std::string &parameter_name) const
 
MooseObjectName uniqueName () const
 
const InputParametersparameters () const
 
const hit::Node * getHitNode () const
 
bool hasBase () const
 
const std::string & getBase () const
 
const TgetParam (const std::string &name) const
 
std::vector< std::pair< T1, T2 > > getParam (const std::string &param1, const std::string &param2) const
 
const TqueryParam (const std::string &name) const
 
const TgetRenamedParam (const std::string &old_name, const std::string &new_name) const
 
T getCheckedPointerParam (const std::string &name, const std::string &error_string="") const
 
bool haveParameter (const std::string &name) const
 
bool isParamValid (const std::string &name) const
 
bool isParamSetByUser (const std::string &name) const
 
void connectControllableParams (const std::string &parameter, const std::string &object_type, const std::string &object_name, const std::string &object_parameter) const
 
void paramError (const std::string &param, Args... args) const
 
void paramWarning (const std::string &param, Args... args) const
 
void paramWarning (const std::string &param, Args... args) const
 
void paramInfo (const std::string &param, Args... args) const
 
std::string messagePrefix (const bool hit_prefix=true) const
 
std::string errorPrefix (const std::string &) const
 
void mooseError (Args &&... args) const
 
void mooseDocumentedError (const std::string &repo_name, const unsigned int issue_num, Args &&... args) const
 
void mooseErrorNonPrefixed (Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseDeprecatedNoTrace (Args &&... args) const
 
void mooseInfo (Args &&... args) const
 
void callMooseError (std::string msg, const bool with_prefix, const hit::Node *node=nullptr, const bool show_trace=true) const
 
std::string getDataFileName (const std::string &param) const
 
std::string getDataFileNameByName (const std::string &relative_path) const
 
std::string getDataFilePath (const std::string &relative_path) const
 
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
 
Moose::Kokkos::Function getKokkosFunction (const std::string &name) const
 
const TgetKokkosFunction (const std::string &name) const
 
Moose::Kokkos::Function getKokkosFunctionByName (const FunctionName &name) const
 
const TgetKokkosFunctionByName (const FunctionName &name) const
 
bool hasKokkosFunction (const std::string &param_name) const
 
bool hasKokkosFunctionByName (const FunctionName &name) const
 
UserObjectName getUserObjectName (const std::string &param_name) const
 
const TgetUserObject (const std::string &param_name, bool is_dependency=true) const
 
const TgetUserObjectByName (const UserObjectName &object_name, bool is_dependency=true) const
 
const UserObjectBasegetUserObjectBase (const std::string &param_name, bool is_dependency=true) const
 
const UserObjectBasegetUserObjectBaseByName (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 void callMooseError (MooseApp *const app, const InputParameters &params, std::string msg, const bool with_prefix, const hit::Node *node, const bool show_trace=true)
 
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

 usingCombinedWarningSolutionWarnings
 
const ConsoleStream _console
 

Static Public Attributes

static const std::string type_param
 
static const std::string name_param
 
static const std::string unique_name_param
 
static const std::string app_param
 
static const std::string moose_base_param
 
static const std::string kokkos_object_param
 

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...
 
const MooseLinearVariableFVRealvelocityVar (unsigned int dir) const
 Helper to access the velocity variable for a given direction. 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
 
void requestVariableCellGradient (const std::string &variable_name)
 
void flagInvalidSolutionInternal (const InvalidSolutionID invalid_solution_id) const
 
InvalidSolutionID registerInvalidSolutionInternal (const std::string &message, const bool warning) const
 
virtual void addUserObjectDependencyHelper (const UserObjectBase &) const
 
virtual void addPostprocessorDependencyHelper (const PostprocessorName &) const
 
virtual void addVectorPostprocessorDependencyHelper (const VectorPostprocessorName &) const
 
TdeclareRestartableData (const std::string &data_name, Args &&... args)
 
ManagedValue< TdeclareManagedRestartableDataWithContext (const std::string &data_name, void *context, Args &&... args)
 
const TgetRestartableData (const std::string &data_name) const
 
TdeclareRestartableDataWithContext (const std::string &data_name, void *context, Args &&... args)
 
TdeclareRecoverableData (const std::string &data_name, Args &&... args)
 
TdeclareRestartableDataWithObjectName (const std::string &data_name, const std::string &object_name, Args &&... args)
 
TdeclareRestartableDataWithObjectNameWithContext (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 Residuals &residuals, const Indices &dof_indices, const std::vector< Real > &scaling_factors)
 
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 Residuals &residuals, const Indices &dof_indices, const std::vector< Real > &scaling_factors)
 
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)
 
void initializeKokkosBlockRestrictable ()
 
Moose::CoordinateSystemType getBlockCoordSystem ()
 
KOKKOS_FUNCTION dof_id_type numKokkosBlockElements () const
 
KOKKOS_FUNCTION dof_id_type numKokkosBlockNodes () const
 
KOKKOS_FUNCTION dof_id_type numKokkosBlockSides () const
 
KOKKOS_FUNCTION ContiguousElementID kokkosBlockElementID (Moose::Kokkos::ThreadID tid) const
 
KOKKOS_FUNCTION ContiguousElementID kokkosBlockNodeID (Moose::Kokkos::ThreadID tid) const
 
KOKKOS_FUNCTION auto kokkosBlockElementSideID (Moose::Kokkos::ThreadID tid) const
 
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)
 
const Moose::Functor< T > & getFunctorByName (const std::string &name)
 
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 _boundary_normal_factor
 Multiplier that ensures the normal of the boundary always points outwards, even in cases when the boundary is within the mesh. 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...
 
std::array< const MooseLinearVariableFVReal *, 3 > _velocity_vars
 Velocity variables for each coordinate direction. More...
 
const Moose::CoordinateSystemType _coord_type
 Coordinate system of the blocks this kernel operates on. More...
 
const unsigned int _rz_radial_coord
 Axisymmetric radial coordinate index (only used when in RZ) 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
 
Factory_factory
 
ActionFactory_action_factory
 
const std::string & _type
 
const std::string & _name
 
const InputParameters_pars
 
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 24 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),
61  _index(getParam<MooseEnum>("momentum_component")),
62  _velocity_vars{nullptr, nullptr, nullptr},
65 {
66  // We only need gradients if the nonorthogonal correction is enabled or when we request the
67  // computation of the deviatoric parts of the stress tensor.
70 
71  Moose::FV::setInterpolationMethod(*this, _advected_interp_method, "advected_interp_method");
72 
73  auto get_velocity_var = [&](const std::string & param_name)
74  {
75  return dynamic_cast<const MooseLinearVariableFVReal *>(
76  &_fe_problem.getVariable(_tid, getParam<SolverVariableName>(param_name)));
77  };
78 
79  _velocity_vars[0] = get_velocity_var("u");
80  if (!_velocity_vars[0])
81  paramError("u", "the u velocity must be a MooseLinearVariableFVReal.");
82 
83  if (_dim >= 2)
84  {
85  if (!params.isParamValid("v"))
86  paramError("v", "In two or more dimensions, the v velocity must be supplied.");
87  _velocity_vars[1] = get_velocity_var("v");
88  if (!_velocity_vars[1])
89  paramError("v",
90  "In two or more dimensions, the v velocity must be supplied and it must be a "
91  "MooseLinearVariableFVReal.");
92  }
93 
94  if (_dim >= 3)
95  {
96  if (!params.isParamValid("w"))
97  paramError("w", "In three-dimensions, the w velocity must be supplied.");
98  _velocity_vars[2] = get_velocity_var("w");
99  if (!_velocity_vars[2])
100  paramError("w",
101  "In three-dimensions, the w velocity must be supplied and it must be a "
102  "MooseLinearVariableFVReal.");
103  }
104 }
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...
void paramError(const std::string &param, Args... args) const
Moose::CoordinateSystemType getBlockCoordSystem()
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.
std::array< const MooseLinearVariableFVReal *, 3 > _velocity_vars
Velocity variables for each coordinate direction.
const unsigned int _rz_radial_coord
Axisymmetric radial coordinate index (only used when in RZ)
const Moose::CoordinateSystemType _coord_type
Coordinate system of the blocks this kernel operates on.
Real _boundary_normal_factor
Multiplier that ensures the normal of the boundary always points outwards, even in cases when the bou...
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
unsigned int getAxisymmetricRadialCoord() const
static const std::string mu
Definition: NS.h:127
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.
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...
virtual MooseMesh & mesh() override
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.
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 378 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryMatrixContribution().

380 {
381  const auto boundary_value_matrix_contrib = bc->computeBoundaryValueMatrixContribution();
382  return boundary_value_matrix_contrib * _face_mass_flux;
383 }
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 386 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryRHSContribution().

388 {
389  const auto boundary_value_rhs_contrib = bc->computeBoundaryValueRHSContribution();
390  return -boundary_value_rhs_contrib * _face_mass_flux;
391 }
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 135 of file LinearWCNSFVMomentumFlux.C.

136 {
137  const auto * const adv_diff_bc = static_cast<const LinearFVAdvectionDiffusionBC *>(&bc);
138 
139  mooseAssert(adv_diff_bc, "This should be a valid BC!");
140  return (computeStressBoundaryMatrixContribution(adv_diff_bc) +
143 }
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 146 of file LinearWCNSFVMomentumFlux.C.

147 {
148  const auto * const adv_diff_bc = static_cast<const LinearFVAdvectionDiffusionBC *>(&bc);
149  mooseAssert(adv_diff_bc, "This should be a valid BC!");
150  return (computeStressBoundaryRHSContribution(adv_diff_bc) +
153 }
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 107 of file LinearWCNSFVMomentumFlux.C.

108 {
112 }
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 123 of file LinearWCNSFVMomentumFlux.C.

124 {
126 }
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 156 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeElemMatrixContribution().

157 {
159 }
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 162 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeNeighborMatrixContribution().

163 {
165 }
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 168 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeElemMatrixContribution(), and computeNeighborMatrixContribution().

169 {
170  // If we don't have the value yet, we compute it
172  {
173  const auto face_arg = makeCDFace(*_current_face_info);
174 
175  // If we requested nonorthogonal correction, we use the normal component of the
176  // cell to face vector.
177  const auto d = _use_nonorthogonal_correction
178  ? std::abs(_current_face_info->dCN() * _current_face_info->normal())
180 
181  // Cache the matrix contribution
184  }
185 
187 }
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 190 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeElemRightHandSideContribution(), and computeNeighborRightHandSideContribution().

191 {
192  // We can have contributions to the right hand side in two occasions:
193  // (1) when we use nonorthogonal correction for the normal gradients
194  // (2) when we request the deviatoric parts of the stress tensor. (needed for space-dependent
195  // viscosities for example)
197  {
198  // scenario (1), we need to add the nonorthogonal correction. In 1D, we don't have
199  // any correction so we just skip this part
201  {
202  const auto face_arg = makeCDFace(*_current_face_info);
203  const auto state_arg = determineState();
204 
205  // Get the gradients from the adjacent cells
206  const auto grad_elem = _var.gradSln(*_current_face_info->elemInfo(), state_arg);
207  const auto & grad_neighbor = _var.gradSln(*_current_face_info->neighborInfo(), state_arg);
208 
209  // Interpolate the two gradients to the face
210  const auto interp_coeffs =
212 
213  const auto correction_vector =
217 
218  // Cache the matrix contribution
220  _mu(face_arg, state_arg) *
221  (interp_coeffs.first * grad_elem + interp_coeffs.second * grad_neighbor) *
222  correction_vector;
223  }
224  // scenario (2), we will have to account for the deviatoric parts of the stress tensor.
226  {
227  const auto state_arg = determineState();
228 
229  // Interpolate the two gradients to the face
230  const auto interp_coeffs =
232 
233  RealGradient grad_elem[3];
234  RealGradient grad_neighbor[3];
235  Real trace_elem = 0;
236  Real trace_neighbor = 0;
237  RealVectorValue deviatoric_vector_elem;
238  RealVectorValue deviatoric_vector_neighbor;
239 
240  // Loop over every velocity component so we can form the symmetric gradient pieces
241  for (const auto dir : make_range(_dim))
242  {
243  grad_elem[dir] = velocityVar(dir).gradSln(*_current_face_info->elemInfo(), state_arg);
244  grad_neighbor[dir] =
245  velocityVar(dir).gradSln(*_current_face_info->neighborInfo(), state_arg);
246  trace_elem += grad_elem[dir](dir);
247  trace_neighbor += grad_neighbor[dir](dir);
248  }
249 
250  const auto face_arg = makeCDFace(*_current_face_info);
251 
252  if (_coord_type == Moose::CoordinateSystemType::COORD_RZ)
253  {
254  Real elem_value = 0.0;
255  Real neighbor_value = 0.0;
256  const auto & radial_var = velocityVar(_rz_radial_coord);
257  elem_value = radial_var.getElemValue(*_current_face_info->elemInfo(), state_arg) /
259  neighbor_value = radial_var.getElemValue(*_current_face_info->neighborInfo(), state_arg) /
261 
262  trace_elem += elem_value;
263  trace_neighbor += neighbor_value;
264  }
265 
266  // Assemble the explicit transpose/trace contribution component by component
267  for (const auto dir : make_range(_dim))
268  {
269  grad_elem[dir](dir) -= 2. / 3 * trace_elem;
270  grad_neighbor[dir](dir) -= 2. / 3 * trace_neighbor;
271 
272  deviatoric_vector_elem(dir) = grad_elem[dir](_index);
273  deviatoric_vector_neighbor(dir) = grad_neighbor[dir](_index);
274  }
275 
276  _stress_rhs_contribution += _mu(face_arg, state_arg) *
277  (interp_coeffs.first * deviatoric_vector_elem +
278  interp_coeffs.second * deviatoric_vector_neighbor) *
280  }
282  }
283 
285 }
const unsigned int _index
Index x|y|z, this is mainly to handle the deviatoric parts correctly in in the stress term...
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 unsigned int _rz_radial_coord
Axisymmetric radial coordinate index (only used when in RZ)
const Moose::CoordinateSystemType _coord_type
Coordinate system of the blocks this kernel operates on.
const Moose::Functor< Real > & _mu
The functor for the dynamic viscosity.
VectorValue< Real > gradSln(const ElemInfo &elem_info, const StateArg &state) const
const MooseLinearVariableFVReal & velocityVar(unsigned int dir) const
Helper to access the velocity variable for a given direction.
const Point & centroid() const
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
IntRange< T > make_range(T beg, T end)
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.

◆ computeNeighborMatrixContribution()

Real LinearWCNSFVMomentumFlux::computeNeighborMatrixContribution ( )
overridevirtual

Implements LinearFVFluxKernel.

Definition at line 115 of file LinearWCNSFVMomentumFlux.C.

116 {
120 }
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 129 of file LinearWCNSFVMomentumFlux.C.

130 {
132 }
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 288 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryMatrixContribution().

290 {
291  auto grad_contrib = bc->computeBoundaryGradientMatrixContribution();
292  // If the boundary condition does not include the diffusivity contribution then
293  // add it here.
295  {
296  const auto face_arg = singleSidedFaceArg(_current_face_info);
297  grad_contrib *= _mu(face_arg, determineState());
298  }
299 
300  return grad_contrib;
301 }
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 304 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeBoundaryRHSContribution().

306 {
307  const auto face_arg = singleSidedFaceArg(_current_face_info);
308  auto grad_contrib = bc->computeBoundaryGradientRHSContribution();
309  // If the boundary condition does not include the diffusivity contribution then
310  // add it here.
312  grad_contrib *= _mu(face_arg, determineState());
313 
314  // We add the nonorthogonal corrector for the face here. Potential idea: we could do
315  // this in the boundary condition too. For now, however, we keep it like this.
317  {
318  // We support internal boundaries as well. In that case we have to decide on which side
319  // of the boundary we are on.
320  const auto elem_info = (_current_face_type == FaceInfo::VarFaceNeighbors::ELEM)
323 
324  // Unit vector to the boundary. Unfortunately, we have to recompute it because the value
325  // stored in the face info is only correct for external boundaries
326  const auto e_Cf = _current_face_info->faceCentroid() - elem_info->centroid();
327  const auto correction_vector =
328  _current_face_info->normal() - 1 / (_current_face_info->normal() * e_Cf) * e_Cf;
329 
330  const auto state_arg = determineState();
331  grad_contrib += _mu(face_arg, state_arg) * _var.gradSln(*elem_info, state_arg) *
332  _boundary_normal_factor * correction_vector;
333  }
334 
336  {
337  // We might be on a face which is an internal boundary so we want to make sure we
338  // get the gradient from the right side.
339  const auto elem_info = (_current_face_type == FaceInfo::VarFaceNeighbors::ELEM)
342 
343  const auto state_arg = determineState();
344 
345  RealGradient grad_elem[3];
346  Real trace_elem = 0;
347  RealVectorValue deviatoric_vector_elem;
348 
349  for (const auto dir : make_range(_dim))
350  {
351  grad_elem[dir] = velocityVar(dir).gradSln(*elem_info, state_arg);
352  trace_elem += grad_elem[dir](dir);
353  }
354 
355  if (_coord_type == Moose::CoordinateSystemType::COORD_RZ)
356  {
357  const auto & radial_var = velocityVar(_rz_radial_coord);
358  const Real elem_value =
359  radial_var.getElemValue(*elem_info, state_arg) / elem_info->centroid()(_rz_radial_coord);
360  trace_elem += elem_value;
361  }
362 
363  for (const auto dir : make_range(_dim))
364  {
365  grad_elem[dir](dir) -= 2. / 3 * trace_elem;
366  deviatoric_vector_elem(dir) = grad_elem[dir](_index);
367  }
368 
369  // We support internal boundaries too so we have to make sure the normal points always outward
370  grad_contrib += _mu(face_arg, state_arg) * deviatoric_vector_elem * _boundary_normal_factor *
372  }
373 
374  return grad_contrib;
375 }
const unsigned int _index
Index x|y|z, this is mainly to handle the deviatoric parts correctly in in the stress term...
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
const Point & faceCentroid() const
MooseLinearVariableFV< Real > & _var
const bool _use_nonorthogonal_correction
Switch to enable/disable nonorthogonal correction in the stress term.
const ElemInfo * elemInfo() const
const unsigned int _rz_radial_coord
Axisymmetric radial coordinate index (only used when in RZ)
const Moose::CoordinateSystemType _coord_type
Coordinate system of the blocks this kernel operates on.
FaceInfo::VarFaceNeighbors _current_face_type
Real _boundary_normal_factor
Multiplier that ensures the normal of the boundary always points outwards, even in cases when the bou...
const Moose::Functor< Real > & _mu
The functor for the dynamic viscosity.
VectorValue< Real > gradSln(const ElemInfo &elem_info, const StateArg &state) const
virtual bool useBoundaryGradientExtrapolation() const
const MooseLinearVariableFVReal & velocityVar(unsigned int dir) const
Helper to access the velocity variable for a given direction.
const FaceInfo * _current_face_info
const Point & normal() const
virtual bool includesMaterialPropertyMultiplier() const
const unsigned int _dim
The dimension of the mesh.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
IntRange< T > make_range(T beg, T end)
const bool _use_deviatoric_terms
Switch to enable/disable deviatoric parts in the stress term.

◆ 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 394 of file LinearWCNSFVMomentumFlux.C.

395 {
397 
398  // Multiplier that ensures the normal of the boundary always points outwards, even in cases
399  // when the boundary is within the mesh.
401 
402  // Caching the mass flux on the face which will be reused in the advection term's matrix and
403  // right hand side contributions
405 
406  // Caching the interpolation coefficients so they will be reused for the matrix and right hand
407  // side terms
410 
411  // We'll have to set this to zero to make sure that we don't accumulate values over multiple
412  // faces. The matrix contribution should be fine.
414 }
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.
FaceInfo::VarFaceNeighbors _current_face_type
Real _boundary_normal_factor
Multiplier that ensures the normal of the boundary always points outwards, even in cases when the bou...
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:127
void addClassDescription(const std::string &doc_string)

◆ velocityVar()

const MooseLinearVariableFVReal & LinearWCNSFVMomentumFlux::velocityVar ( unsigned int  dir) const
protected

Helper to access the velocity variable for a given direction.

Definition at line 417 of file LinearWCNSFVMomentumFlux.C.

Referenced by computeInternalStressRHSContribution(), and computeStressBoundaryRHSContribution().

418 {
419  mooseAssert(dir < _velocity_vars.size() && _velocity_vars[dir],
420  "Velocity variable for requested direction is not available.");
421  return *_velocity_vars[dir];
422 }
std::array< const MooseLinearVariableFVReal *, 3 > _velocity_vars
Velocity variables for each coordinate direction.

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 108 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 125 of file LinearWCNSFVMomentumFlux.h.

Referenced by setupFaceData().

◆ _boundary_normal_factor

Real LinearWCNSFVMomentumFlux::_boundary_normal_factor
protected

Multiplier that ensures the normal of the boundary always points outwards, even in cases when the boundary is within the mesh.

Definition at line 116 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeStressBoundaryRHSContribution(), and setupFaceData().

◆ _coord_type

const Moose::CoordinateSystemType LinearWCNSFVMomentumFlux::_coord_type
protected

Coordinate system of the blocks this kernel operates on.

Definition at line 135 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and computeStressBoundaryRHSContribution().

◆ _dim

const unsigned int LinearWCNSFVMomentumFlux::_dim
protected

The dimension of the mesh.

Definition at line 92 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and computeStressBoundaryRHSContribution().

◆ _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 112 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 129 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and computeStressBoundaryRHSContribution().

◆ _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 95 of file LinearWCNSFVMomentumFlux.h.

Referenced by setupFaceData().

◆ _mu

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

◆ _rz_radial_coord

const unsigned int LinearWCNSFVMomentumFlux::_rz_radial_coord
protected

Axisymmetric radial coordinate index (only used when in RZ)

Definition at line 138 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and computeStressBoundaryRHSContribution().

◆ _stress_matrix_contribution

Real LinearWCNSFVMomentumFlux::_stress_matrix_contribution
protected

The cached matrix contribution.

Definition at line 119 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 122 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and setupFaceData().

◆ _use_deviatoric_terms

const bool LinearWCNSFVMomentumFlux::_use_deviatoric_terms
protected

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

Definition at line 104 of file LinearWCNSFVMomentumFlux.h.

Referenced by computeInternalStressRHSContribution(), and computeStressBoundaryRHSContribution().

◆ _use_nonorthogonal_correction

const bool LinearWCNSFVMomentumFlux::_use_nonorthogonal_correction
protected

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

Definition at line 101 of file LinearWCNSFVMomentumFlux.h.

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

◆ _velocity_vars

std::array<const MooseLinearVariableFVReal *, 3> LinearWCNSFVMomentumFlux::_velocity_vars
protected

Velocity variables for each coordinate direction.

Definition at line 132 of file LinearWCNSFVMomentumFlux.h.

Referenced by velocityVar().


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