24 "Represents the matrix and right hand side contributions of a " 25 "diffusion term for a turbulent variable in a partial differential equation.");
28 "scaling_coeff", 1.0,
"The scaling coefficient for the diffusion term.");
30 params.
addParam<std::vector<BoundaryName>>(
31 "walls", {},
"Boundaries that correspond to solid walls.");
37 _scaling_coeff(getFunctor<
Real>(
"scaling_coeff")),
38 _wall_boundary_names(getParam<
std::vector<BoundaryName>>(
"walls"))
84 mooseAssert(diff_bc,
"This should be a valid BC!");
86 auto grad_contrib = diff_bc->computeBoundaryGradientMatrixContribution() *
_current_face_area;
89 if (!diff_bc->includesMaterialPropertyMultiplier())
102 mooseAssert(diff_bc,
"This should be a valid BC!");
105 auto grad_contrib = diff_bc->computeBoundaryGradientRHSContribution() *
_current_face_area;
109 if (!diff_bc->includesMaterialPropertyMultiplier())
116 const auto correction_vector =
170 "We should only have one boundary on every face.");
190 const auto dof_id_neighbor =
234 "We should only have one boundary on every face.");
254 const auto dof_id_neighbor =
const unsigned int _var_num
const std::vector< BoundaryName > & _wall_boundary_names
Wall boundaries.
virtual Real computeBoundaryMatrixContribution(const LinearFVBoundaryCondition &bc) override
const std::set< BoundaryID > & boundaryIDs() const
const Moose::Functor< Real > & _diffusion_coeff
LinearFVTurbulentDiffusion(const InputParameters ¶ms)
Class constructor.
libMesh::LinearImplicitSystem & _linear_system
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
void setupFaceData(const FaceInfo *face_info, const FaceInfo::VarFaceNeighbors face_type)
MooseLinearVariableFV< Real > & _var
NumericVector< Number > * rhs
const ElemInfo * elemInfo() const
LinearFVBoundaryCondition * getBoundaryCondition(const BoundaryID bd_id) const
void getWallBoundedElements(const std::vector< BoundaryName > &wall_boundary_name, const FEProblemBase &fe_problem, const SubProblem &subproblem, const std::set< SubdomainID > &block_ids, std::unordered_set< const Elem *> &wall_bounded)
Map marking wall bounded elements The map passed in wall_bounded_map gets cleared and re-populated...
virtual const std::set< SubdomainID > & blockIDs() const
Real computeFluxMatrixContribution()
virtual Real computeBoundaryRHSContribution(const LinearFVBoundaryCondition &bc) override
virtual Real computeNeighborMatrixContribution() override
std::unordered_set< const Elem * > _wall_bounded
List for wall bounded elements.
FaceInfo::VarFaceNeighbors _current_face_type
const bool _force_boundary_execution
DenseVector< Real > _rhs_contribution
const Moose::Functor< Real > & _scaling_coeff
The functor for the scaling coefficient for the diffusion term.
static InputParameters validParams()
const FaceInfo * _current_face_info
const Elem * neighborPtr() const
registerMooseObject("NavierStokesApp", LinearFVTurbulentDiffusion)
virtual Real computeElemMatrixContribution() override
virtual void addMatrixContribution() override
virtual Real computeElemRightHandSideContribution() override
const Point & normal() const
virtual void initialSetup() override
static InputParameters validParams()
const Elem * elemPtr() const
DenseVector< dof_id_type > _dof_indices
const std::vector< std::vector< dof_id_type > > & dofIndices() const
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Point & eCN() const
SparseMatrix< Number > * matrix
Kernel that adds contributions from a diffusion term of the turbulent variables, limited in the near-...
const VectorValue< Real > gradSln(const ElemInfo &elem_info) const
virtual Real computeNeighborRightHandSideContribution() override
Real computeFluxRHSContribution()
virtual void initialSetup() override
virtual void addRightHandSideContribution() override
FEProblemBase & _fe_problem
bool hasBlocks(const SubdomainName &name) const
Moose::FaceArg makeCDFace(const FaceInfo &fi, const bool correct_skewness=false) const
void computeCellGradients()
const unsigned int _sys_num
SubdomainID subdomain_id() const
DenseMatrix< Real > _matrix_contribution
const bool _use_nonorthogonal_correction