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

The gradient in a volume using Green Gauss theorem and a cell-centered finite-volume approximation can be computed as follows: More...

#include <ComputeLinearFVGreenGaussGradientFaceThread.h>

Public Types

using FaceInfoRange = StoredRange< MooseMesh::const_face_info_iterator, const FaceInfo * >
 

Public Member Functions

 ComputeLinearFVGreenGaussGradientFaceThread (FEProblemBase &fe_problem, SystemBase &system, std::vector< std::unique_ptr< NumericVector< Number >>> &temporary_gradient)
 Class constructor. More...
 
 ComputeLinearFVGreenGaussGradientFaceThread (ComputeLinearFVGreenGaussGradientFaceThread &x, Threads::split split)
 Splitting constructor. More...
 
void operator() (const FaceInfoRange &range)
 Operator which is used to execute the thread over a certain iterator range. More...
 
void join (const ComputeLinearFVGreenGaussGradientFaceThread &y)
 Join threads at the end of the execution. More...
 

Protected Attributes

FEProblemBase_fe_problem
 Reference to the problem. More...
 
const unsigned int _dim
 The dimension of the domain. More...
 
SystemBase_system
 The system wrapper this thread operates on. More...
 
const libMesh::System_libmesh_system
 Reference to the libMesh system backing the wrapper system. More...
 
const unsigned int _system_number
 Global system number (the number of this system in the libmesh equation system) More...
 
THREAD_ID _tid
 Thread ID. More...
 
MooseLinearVariableFV< Real > * _current_var
 Pointer to the current variable. More...
 
std::vector< std::unique_ptr< NumericVector< Number > > > & _temporary_gradient
 Cache for the temporary gradient being built. More...
 

Detailed Description

The gradient in a volume using Green Gauss theorem and a cell-centered finite-volume approximation can be computed as follows:

u {1}{V_C} u_f{S}_f,

where V_C denotes the volume of the cell, f is a face iterator, while u_f and {S}_f are the face value of the variable and surface area vector (the product of the surface area and normals), respectively. This object carries out the summation part over the faces ( u_f{S}_f).

Definition at line 35 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Member Typedef Documentation

◆ FaceInfoRange

Constructor & Destructor Documentation

◆ ComputeLinearFVGreenGaussGradientFaceThread() [1/2]

ComputeLinearFVGreenGaussGradientFaceThread::ComputeLinearFVGreenGaussGradientFaceThread ( FEProblemBase fe_problem,
SystemBase system,
std::vector< std::unique_ptr< NumericVector< Number >>> &  temporary_gradient 
)

Class constructor.

Parameters
fe_problemReference to the problem
systemThe system which contains variables that need gradients.
temporary_gradientScratch storage for gradients being assembled.

Definition at line 16 of file ComputeLinearFVGreenGaussGradientFaceThread.C.

20  : _fe_problem(fe_problem),
22  _system(system),
23  _libmesh_system(system.system()),
25  _temporary_gradient(temporary_gradient)
26 {
27 }
const libMesh::System & _libmesh_system
Reference to the libMesh system backing the wrapper system.
virtual libMesh::System & system()=0
Get the reference to the libMesh system.
SystemBase & _system
The system wrapper this thread operates on.
unsigned int number() const
virtual unsigned int dimension() const
Returns MeshBase::mesh_dimension(), (not MeshBase::spatial_dimension()!) of the underlying libMesh me...
Definition: MooseMesh.C:3012
const unsigned int _system_number
Global system number (the number of this system in the libmesh equation system)
std::vector< std::unique_ptr< NumericVector< Number > > > & _temporary_gradient
Cache for the temporary gradient being built.
virtual MooseMesh & mesh() override

◆ ComputeLinearFVGreenGaussGradientFaceThread() [2/2]

ComputeLinearFVGreenGaussGradientFaceThread::ComputeLinearFVGreenGaussGradientFaceThread ( ComputeLinearFVGreenGaussGradientFaceThread x,
Threads::split  split 
)

Splitting constructor.

Parameters
xReference to the other bodies
splitThe thread split

Definition at line 29 of file ComputeLinearFVGreenGaussGradientFaceThread.C.

32  _dim(x._dim),
33  _system(x._system),
36  // This will be the vector we work on since the old gradient might still be needed
37  // to compute extrapolated boundary conditions for example.
39 {
40 }
const libMesh::System & _libmesh_system
Reference to the libMesh system backing the wrapper system.
SystemBase & _system
The system wrapper this thread operates on.
const unsigned int _system_number
Global system number (the number of this system in the libmesh equation system)
std::vector< std::unique_ptr< NumericVector< Number > > > & _temporary_gradient
Cache for the temporary gradient being built.

Member Function Documentation

◆ join()

void ComputeLinearFVGreenGaussGradientFaceThread::join ( const ComputeLinearFVGreenGaussGradientFaceThread y)

Join threads at the end of the execution.

Parameters
yReference to the other bodies

Definition at line 157 of file ComputeLinearFVGreenGaussGradientFaceThread.C.

159 {
160 }

◆ operator()()

void ComputeLinearFVGreenGaussGradientFaceThread::operator() ( const FaceInfoRange range)

Operator which is used to execute the thread over a certain iterator range.

Parameters
rangeThe range of FaceInfos which should be computed.

Definition at line 43 of file ComputeLinearFVGreenGaussGradientFaceThread.C.

44 {
45  ParallelUniqueId puid;
46  _tid = puid.id;
47 
48  unsigned int size = 0;
49 
50  for (const auto & variable : _system.getVariables(_tid))
51  {
52  _current_var = dynamic_cast<MooseLinearVariableFV<Real> *>(variable);
53  if (!_current_var)
54  continue;
55 
57  {
58  if (!size)
59  size = range.size();
60 
61  std::vector<std::vector<Real>> temporary_values_elem(_temporary_gradient.size(),
62  std::vector<Real>(size, 0.0));
63  std::vector<std::vector<Real>> temporary_values_neighbor(_temporary_gradient.size(),
64  std::vector<Real>(size, 0.0));
65  std::vector<dof_id_type> dof_indices_elem(size, 0);
66  std::vector<dof_id_type> dof_indices_neighbor(size, 0);
67 
68  {
70 
71  // Iterate over all the face infos in the range
72  auto face_iterator = range.begin();
73  for (const auto & face_i : make_range(size))
74  {
75  const auto & face_info = *face_iterator;
76 
77  const auto current_face_type =
78  face_info->faceType(std::make_pair(_current_var->number(), _system_number));
79 
80  // First we check if this face is internal to the variable, if yes, contribute to both
81  // sides
82  if (current_face_type == FaceInfo::VarFaceNeighbors::BOTH)
83  {
84  dof_indices_elem[face_i] =
85  face_info->elemInfo()->dofIndices()[_system_number][_current_var->number()];
86  dof_indices_neighbor[face_i] =
87  face_info->neighborInfo()->dofIndices()[_system_number][_current_var->number()];
88 
89  const auto face_value =
90  Moose::FV::linearInterpolation(solution_reader(dof_indices_elem[face_i]),
91  solution_reader(dof_indices_neighbor[face_i]),
92  *face_info,
93  true);
94 
95  const auto contribution =
96  face_info->normal() * face_info->faceArea() * face_info->faceCoord() * face_value;
97 
98  for (const auto i : make_range(_dim))
99  {
100  temporary_values_elem[i][face_i] = contribution(i);
101  temporary_values_neighbor[i][face_i] = -contribution(i);
102  }
103  }
104  // If this face is on the boundary of the block where the variable is defined, we
105  // check for boundary conditions. If we don't find any we use an automatic one-term
106  // expansion to compute the face value.
107  else if (current_face_type == FaceInfo::VarFaceNeighbors::ELEM ||
108  current_face_type == FaceInfo::VarFaceNeighbors::NEIGHBOR)
109  {
110  auto * bc_pointer =
111  _current_var->getBoundaryCondition(*face_info->boundaryIDs().begin());
112 
113  if (bc_pointer)
114  bc_pointer->setupFaceData(face_info, current_face_type);
115 
116  const auto * const elem_info = current_face_type == FaceInfo::VarFaceNeighbors::ELEM
117  ? face_info->elemInfo()
118  : face_info->neighborInfo();
119 
120  // We have to account for cases when this face is an internal boundary and the normal
121  // points in the wrong direction
122  const auto multiplier =
123  current_face_type == FaceInfo::VarFaceNeighbors::ELEM ? 1.0 : -1.0;
124  auto & dof_id_container = current_face_type == FaceInfo::VarFaceNeighbors::ELEM
125  ? dof_indices_elem
126  : dof_indices_neighbor;
127  auto & contribution_container = current_face_type == FaceInfo::VarFaceNeighbors::ELEM
128  ? temporary_values_elem
129  : temporary_values_neighbor;
130 
131  dof_id_container[face_i] =
132  elem_info->dofIndices()[_system_number][_current_var->number()];
133 
134  // If we don't have a boundary condition, then it's a natural condition. We'll use a
135  // one-term expansion approximation in that case
136  const auto contribution = multiplier * face_info->normal() * face_info->faceArea() *
137  face_info->faceCoord() *
138  (bc_pointer ? bc_pointer->computeBoundaryValue()
139  : solution_reader(dof_id_container[face_i]));
140  for (const auto i : make_range(_dim))
141  contribution_container[i][face_i] = contribution(i);
142  }
143  face_iterator++;
144  }
145  }
146  for (const auto i : make_range(_dim))
147  {
148  _temporary_gradient[i]->add_vector(temporary_values_elem[i].data(), dof_indices_elem);
149  _temporary_gradient[i]->add_vector(temporary_values_neighbor[i].data(),
150  dof_indices_neighbor);
151  }
152  }
153  }
154 }
const std::vector< MooseVariableFieldBase * > & getVariables(THREAD_ID tid)
Definition: SystemBase.h:752
unsigned int number() const
Get variable number coming from libMesh.
const libMesh::System & _libmesh_system
Reference to the libMesh system backing the wrapper system.
void setupFaceData(const FaceInfo *face_info, const FaceInfo::VarFaceNeighbors face_type)
Set current face info.
MooseLinearVariableFV< Real > * _current_var
Pointer to the current variable.
SystemBase & _system
The system wrapper this thread operates on.
LinearFVBoundaryCondition * getBoundaryCondition(const BoundaryID bd_id) const
Get the boundary condition object which corresponds to the given boundary ID.
libMesh::CompareTypes< T, T2 >::supertype linearInterpolation(const T &value1, const T2 &value2, const FaceInfo &fi, const bool one_is_elem, const InterpMethod interp_method=InterpMethod::Average)
A simple linear interpolation of values between cell centers to a cell face.
Definition: MathFVUtils.h:153
A class which helps with repeated reading from a petsc vector.
const unsigned int _system_number
Global system number (the number of this system in the libmesh equation system)
std::vector< std::unique_ptr< NumericVector< Number > > > & _temporary_gradient
Cache for the temporary gradient being built.
IntRange< T > make_range(T beg, T end)
std::unique_ptr< NumericVector< Number > > current_local_solution
virtual bool needsGradientVectorStorage() const override
Check if cell gradient computations were requested for this variable.

Member Data Documentation

◆ _current_var

MooseLinearVariableFV<Real>* ComputeLinearFVGreenGaussGradientFaceThread::_current_var
protected

Pointer to the current variable.

Definition at line 86 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Referenced by operator()().

◆ _dim

const unsigned int ComputeLinearFVGreenGaussGradientFaceThread::_dim
protected

The dimension of the domain.

Definition at line 71 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Referenced by operator()().

◆ _fe_problem

FEProblemBase& ComputeLinearFVGreenGaussGradientFaceThread::_fe_problem
protected

Reference to the problem.

Definition at line 68 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

◆ _libmesh_system

const libMesh::System& ComputeLinearFVGreenGaussGradientFaceThread::_libmesh_system
protected

Reference to the libMesh system backing the wrapper system.

Definition at line 77 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Referenced by operator()().

◆ _system

SystemBase& ComputeLinearFVGreenGaussGradientFaceThread::_system
protected

The system wrapper this thread operates on.

Definition at line 74 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Referenced by operator()().

◆ _system_number

const unsigned int ComputeLinearFVGreenGaussGradientFaceThread::_system_number
protected

Global system number (the number of this system in the libmesh equation system)

Definition at line 80 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Referenced by operator()().

◆ _temporary_gradient

std::vector<std::unique_ptr<NumericVector<Number> > >& ComputeLinearFVGreenGaussGradientFaceThread::_temporary_gradient
protected

Cache for the temporary gradient being built.

It is needed because in certain scenarios the old gradient is used while assembling the replacement gradient.

Definition at line 90 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Referenced by operator()().

◆ _tid

THREAD_ID ComputeLinearFVGreenGaussGradientFaceThread::_tid
protected

Thread ID.

Definition at line 83 of file ComputeLinearFVGreenGaussGradientFaceThread.h.

Referenced by operator()().


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