GEOS
AccumulationKernels.hpp
Go to the documentation of this file.
1 /*
2  * ------------------------------------------------------------------------------------------------------------
3  * SPDX-License-Identifier: LGPL-2.1-only
4  *
5  * Copyright (c) 2016-2024 Lawrence Livermore National Security LLC
6  * Copyright (c) 2018-2024 TotalEnergies
7  * Copyright (c) 2018-2024 The Board of Trustees of the Leland Stanford Junior University
8  * Copyright (c) 2023-2024 Chevron
9  * Copyright (c) 2019- GEOS/GEOSX Contributors
10  * All rights reserved
11  *
12  * See top level LICENSE, COPYRIGHT, CONTRIBUTORS, NOTICE, and ACKNOWLEDGEMENTS files for details.
13  * ------------------------------------------------------------------------------------------------------------
14  */
15 
20 #ifndef GEOS_PHYSICSSOLVERS_FLUIDFLOW_SINGLEPHASE_ACCUMULATIONKERNELS_HPP
21 #define GEOS_PHYSICSSOLVERS_FLUIDFLOW_SINGLEPHASE_ACCUMULATIONKERNELS_HPP
22 
23 #include "common/DataTypes.hpp"
24 #include "common/GEOS_RAJA_Interface.hpp"
25 #include "constitutive/fluid/singlefluid/SingleFluidBase.hpp"
26 #include "constitutive/fluid/singlefluid/SingleFluidUtils.hpp"
27 #include "constitutive/solid/CoupledSolidBase.hpp"
30 #include "codingUtilities/Utilities.hpp"
31 
32 namespace geos
33 {
34 
35 namespace singlePhaseBaseKernels
36 {
37 
38 /******************************** AccumulationKernel ********************************/
39 
44 template< typename SUBREGION_TYPE, integer NUM_DOF >
46 {
47 
48 public:
49  using SingleFluidProp = constitutive::SingleFluidVar< real64, 2, constitutive::singlefluid::LAYOUT_FLUID, constitutive::singlefluid::LAYOUT_FLUID_DER >;
50 
52  static constexpr integer numDof = NUM_DOF;
53 
55  static constexpr integer numEqn = NUM_DOF;
56 
57 
59  static constexpr integer isThermal = NUM_DOF-1;
60  using DerivOffset = constitutive::singlefluid::DerivativeOffsetC< isThermal >;
61 
70  AccumulationKernel( globalIndex const rankOffset,
71  string const dofKey,
72  SUBREGION_TYPE const & subRegion,
74  arrayView1d< real64 > const & localRhs )
75  :
76  m_rankOffset( rankOffset ),
77  m_dofNumber( subRegion.template getReference< array1d< globalIndex > >( dofKey ) ),
78  m_elemGhostRank( subRegion.ghostRank() ),
79  m_mass( subRegion.template getField< fields::flow::mass >() ),
80  m_mass_n( subRegion.template getField< fields::flow::mass_n >() ),
81  m_dMass( subRegion.template getField< fields::flow::dMass >() ),
82  m_localMatrix( localMatrix ),
83  m_localRhs( localRhs )
84  {}
85 
91  {
92 public:
93 
94  // Residual information
95 
98 
101 
104 
107 
108  };
109 
116  integer elemGhostRank( localIndex const ei ) const
117  { return m_elemGhostRank( ei ); }
118 
119 
126  void setup( localIndex const ei,
127  StackVariables & stack ) const
128  {
129  // set row index and degrees of freedom indices for this element
130  stack.localRow = m_dofNumber[ei] - m_rankOffset;
131  for( integer idof = 0; idof < numDof; ++idof )
132  {
133  stack.dofIndices[idof] = m_dofNumber[ei] + idof;
134  }
135  }
136 
144  template< typename FUNC = NoOpFunc >
147  StackVariables & stack,
148  FUNC && kernelOp = NoOpFunc{} ) const
149  {
150  // Residual contribution is mass conservation in the cell
151  stack.localResidual[0] = m_mass[ei] - m_mass_n[ei];
152 
153  // Derivative of residual wrt to pressure in the cell
154  stack.localJacobian[0][0] = m_dMass[ei][DerivOffset::dP];
155 
156  // Customize the kernel with this lambda
157  kernelOp();
158  }
159 
167  StackVariables & stack ) const
168  {
169  // add contribution to global residual and jacobian (no need for atomics here)
170  m_localMatrix.template addToRow< serialAtomic >( stack.localRow,
171  stack.dofIndices,
172  stack.localJacobian[0],
173  numDof );
174  m_localRhs[stack.localRow] += stack.localResidual[0];
175 
176  }
177 
185  template< typename POLICY, typename KERNEL_TYPE >
186  static void
187  launch( localIndex const numElems,
188  KERNEL_TYPE const & kernelComponent )
189  {
191 
192  forAll< POLICY >( numElems, [=] GEOS_HOST_DEVICE ( localIndex const ei )
193  {
194  if( kernelComponent.elemGhostRank( ei ) >= 0 )
195  {
196  return;
197  }
198 
199  typename KERNEL_TYPE::StackVariables stack;
200 
201  kernelComponent.setup( ei, stack );
202  kernelComponent.computeAccumulation( ei, stack );
203  kernelComponent.complete( ei, stack );
204  } );
205  }
206 
207 protected:
208 
211 
214 
217 
220  arrayView1d< real64 const > const m_mass_n;
222 
227 
228 };
229 
234 class SurfaceElementAccumulationKernel : public AccumulationKernel< SurfaceElementSubRegion, 1 >
235 {
236 
237 public:
238 
240 
252  string const dofKey,
253  SurfaceElementSubRegion const & subRegion,
254  CRSMatrixView< real64, globalIndex const > const & localMatrix,
255  arrayView1d< real64 > const & localRhs )
256  : Base( rankOffset, dofKey, subRegion, localMatrix, localRhs )
257  , m_creationMass( subRegion.getField< fields::flow::massCreated >() )
258  {}
259 
268  Base::StackVariables & stack ) const
269  {
270  Base::computeAccumulation( ei, stack );
271  if( Base::m_mass_n[ei] > 1.1 * m_creationMass[ei] )
272  {
273  stack.localResidual[0] += m_creationMass[ei] * 0.25;
274  }
275  }
276 
277 protected:
278 
279  arrayView1d< real64 const > const m_creationMass;
280 
281 };
282 
287 {
288 public:
289 
301  template< typename POLICY, typename SUBREGION_TYPE >
302  static void
303  createAndLaunch( globalIndex const rankOffset,
304  string const dofKey,
305  SUBREGION_TYPE const & subRegion,
306  CRSMatrixView< real64, globalIndex const > const & localMatrix,
307  arrayView1d< real64 > const & localRhs )
308  {
309  if constexpr ( std::is_base_of_v< CellElementSubRegion, SUBREGION_TYPE > )
310  {
311  integer constexpr NUM_DOF = 1;
312  AccumulationKernel< CellElementSubRegion, NUM_DOF > kernel( rankOffset, dofKey, subRegion, localMatrix, localRhs );
313  AccumulationKernel< CellElementSubRegion, NUM_DOF >::template launch< POLICY >( subRegion.size(), kernel );
314  }
315  else if constexpr ( std::is_base_of_v< SurfaceElementSubRegion, SUBREGION_TYPE > )
316  {
317  SurfaceElementAccumulationKernel kernel( rankOffset, dofKey, subRegion, localMatrix, localRhs );
318  SurfaceElementAccumulationKernel::launch< POLICY >( subRegion.size(), kernel );
319  }
320  else
321  {
322  GEOS_UNUSED_VAR( rankOffset, dofKey, subRegion, localMatrix, localRhs );
323  GEOS_ERROR( "Unsupported subregion type: " << typeid(SUBREGION_TYPE).name() );
324  }
325  }
326 
327 };
328 
329 } // namespace singlePhaseBaseKernels
330 
331 } // namespace geos
332 
333 #endif //GEOS_PHYSICSSOLVERS_FLUIDFLOW_SINGLEPHASE_ACCUMULATIONKERNELS_HPP
#define GEOS_HOST_DEVICE
Marks a host-device function.
Definition: GeosxMacros.hpp:49
#define GEOS_UNUSED_VAR(...)
Mark an unused variable and silence compiler warnings.
Definition: GeosxMacros.hpp:84
#define GEOS_UNUSED_PARAM(X)
Mark an unused argument and silence compiler warnings.
Definition: GeosxMacros.hpp:72
#define GEOS_ERROR(msg)
Raise a hard error and terminate the program.
Definition: Logger.hpp:157
#define GEOS_MARK_FUNCTION
Mark function with both Caliper and NVTX if enabled.
static void createAndLaunch(globalIndex const rankOffset, string const dofKey, SUBREGION_TYPE const &subRegion, CRSMatrixView< real64, globalIndex const > const &localMatrix, arrayView1d< real64 > const &localRhs)
Create a new kernel and launch.
Define the interface for the assembly kernel in charge of accumulation.
static constexpr integer isThermal
Note: Derivative lineup only supports dP & dT, not component terms.
AccumulationKernel(globalIndex const rankOffset, string const dofKey, SUBREGION_TYPE const &subRegion, CRSMatrixView< real64, globalIndex const > const &localMatrix, arrayView1d< real64 > const &localRhs)
Constructor.
static void launch(localIndex const numElems, KERNEL_TYPE const &kernelComponent)
Performs the kernel launch.
GEOS_HOST_DEVICE void computeAccumulation(localIndex const ei, StackVariables &stack, FUNC &&kernelOp=NoOpFunc{}) const
Compute the local accumulation contributions to the residual and Jacobian.
arrayView1d< globalIndex const > const m_dofNumber
View on the dof numbers.
static constexpr integer numDof
Compute time value for the number of degrees of freedom.
GEOS_HOST_DEVICE void complete(localIndex const GEOS_UNUSED_PARAM(ei), StackVariables &stack) const
Performs the complete phase for the kernel.
arrayView1d< real64 const > const m_mass
View on mass.
arrayView1d< real64 > const m_localRhs
View on the local RHS.
GEOS_HOST_DEVICE integer elemGhostRank(localIndex const ei) const
Getter for the ghost rank of an element.
CRSMatrixView< real64, globalIndex const > const m_localMatrix
View on the local CRS matrix.
GEOS_HOST_DEVICE void setup(localIndex const ei, StackVariables &stack) const
Performs the setup phase for the kernel.
arrayView1d< integer const > const m_elemGhostRank
View on the ghost ranks.
static constexpr integer numEqn
Compute time value for the number of equations.
globalIndex const m_rankOffset
Offset for my MPI rank.
Define the interface for the assembly kernel in charge of accumulation in SurfaceElementSubRegion.
SurfaceElementAccumulationKernel(globalIndex const rankOffset, string const dofKey, SurfaceElementSubRegion const &subRegion, CRSMatrixView< real64, globalIndex const > const &localMatrix, arrayView1d< real64 > const &localRhs)
Constructor.
GEOS_HOST_DEVICE void computeAccumulation(localIndex const ei, Base::StackVariables &stack) const
Compute the local accumulation contributions to the residual and Jacobian.
ArrayView< T, 1 > arrayView1d
Alias for 1D array view.
Definition: DataTypes.hpp:180
LvArray::CRSMatrixView< T, COL_INDEX, localIndex const, LvArray::ChaiBuffer > CRSMatrixView
Alias for CRS Matrix View.
Definition: DataTypes.hpp:310
GEOS_GLOBALINDEX_TYPE globalIndex
Global index type (for indexing objects across MPI partitions).
Definition: DataTypes.hpp:88
double real64
64-bit floating point type.
Definition: DataTypes.hpp:99
GEOS_LOCALINDEX_TYPE localIndex
Local index type (for indexing objects within an MPI partition).
Definition: DataTypes.hpp:85
std::int32_t integer
Signed integer type.
Definition: DataTypes.hpp:82
ArrayView< T, 2, USD > arrayView2d
Alias for 2D array view.
Definition: DataTypes.hpp:196
Array< T, 1 > array1d
Alias for 1D array.
Definition: DataTypes.hpp:176
Kernel variables (dof numbers, jacobian and residual) located on the stack.
real64 localJacobian[numEqn][numDof]
Storage for the element local Jacobian matrix.
localIndex localRow
Index of the local row corresponding to this element.
globalIndex dofIndices[numDof]
Index of the matrix row/column corresponding to the dof in this element.
real64 localResidual[numEqn]
Storage for the element local residual vector.