OpenLB 1.7
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Static Public Attributes | List of all members
olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE > Class Template Referencefinal

#include <fdBoundaryPostProcessors3D.h>

+ Inheritance diagram for olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >:
+ Collaboration diagram for olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >:

Public Types

using parameters = PARAMS
 

Public Member Functions

 FdBoundaryPostProcessor3D ()
 
int getPriority () const
 
template<typename CELL , typename PARAMETERS >
void apply (CELL &cell, PARAMETERS &vars) any_platform
 

Static Public Attributes

static constexpr OperatorScope scope = OperatorScope::PerCellWithParameters
 

Additional Inherited Members

- Protected Member Functions inherited from olb::FdBasePostProcessor3D< T, DESCRIPTOR, FIELD, SOURCE >
 FdBasePostProcessor3D ()
 
template<typename CELL >
void applySourceTerm (T *fNew, CELL &cell) any_platform
 

Detailed Description

template<typename T, typename DESCRIPTOR, typename MODEL, typename SCHEME_BOUND, typename PARAMS, typename FIELD = descriptors::AD_FIELD, typename SOURCE = void>
class olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >

Definition at line 37 of file fdBoundaryPostProcessors3D.h.

Member Typedef Documentation

◆ parameters

template<typename T , typename DESCRIPTOR , typename MODEL , typename SCHEME_BOUND , typename PARAMS , typename FIELD = descriptors::AD_FIELD, typename SOURCE = void>
using olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >::parameters = PARAMS

Definition at line 39 of file fdBoundaryPostProcessors3D.h.

Constructor & Destructor Documentation

◆ FdBoundaryPostProcessor3D()

template<typename T , typename DESCRIPTOR , typename MODEL , typename SCHEME_BOUND , typename PARAMS , typename FIELD , typename SOURCE >
olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >::FdBoundaryPostProcessor3D ( )

Definition at line 33 of file fdBoundaryPostProcessors3D.hh.

34 : FdBasePostProcessor3D<T,DESCRIPTOR,FIELD,SOURCE>()
35{
36 OLB_PRECONDITION( DESCRIPTOR::template provides<descriptors::NORMAL_X>() );
37 OLB_PRECONDITION( DESCRIPTOR::template provides<descriptors::NORMAL_Y>() );
38 OLB_PRECONDITION( DESCRIPTOR::template provides<descriptors::NORMAL_Z>() );
39}
#define OLB_PRECONDITION(COND)
Definition olbDebug.h:46

References OLB_PRECONDITION.

Member Function Documentation

◆ apply()

template<typename T , typename DESCRIPTOR , typename MODEL , typename SCHEME_BOUND , typename PARAMS , typename FIELD , typename SOURCE >
template<typename CELL , typename PARAMETERS >
void olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >::apply ( CELL & cell,
PARAMETERS & vars )

Definition at line 49 of file fdBoundaryPostProcessors3D.hh.

50{
51 int normalX = (int)( cell.template getField<descriptors::NORMAL_X>() );
52 int normalY = (int)( cell.template getField<descriptors::NORMAL_Y>() );
53 int normalZ = (int)( cell.template getField<descriptors::NORMAL_Z>() );
54 if (normalX!=0 || normalY!=0 || normalZ!=0) { // does absolutely nothing if the cell does not belong to a border
55 constexpr int extraExtent = MODEL::extent() + SCHEME_BOUND::getExtraExtent();
56 std::size_t iT = vars.template get<fd::fdParams::Timestep>();
57 T f[MODEL::extent()*DESCRIPTOR::d], F[MODEL::extent()*DESCRIPTOR::d];
58 T fGhost[MODEL::extent()*DESCRIPTOR::d], fNormal[extraExtent*DESCRIPTOR::d];
59 T u[DESCRIPTOR::d];
60 int normal[] {normalX, normalY, normalZ};
61 std::fill(std::begin(fGhost), std::end(fGhost), 0);
62 T* fNew = fd::accessNew<T,FIELD>(cell, iT);
63 T* f0 = fd::accessOld<T,FIELD>(cell, iT);
64 for (int iN=1; iN<=extraExtent; ++iN) {
65 fNormal[fd::getArrayPos<extraExtent>(iN-1,0)] = *fd::accessOld<T,FIELD>( cell.neighbor({normalX*iN, 0, 0}), iT );
66 fNormal[fd::getArrayPos<extraExtent>(iN-1,1)] = *fd::accessOld<T,FIELD>( cell.neighbor({ 0, normalY*iN, 0}), iT );
67 fNormal[fd::getArrayPos<extraExtent>(iN-1,2)] = *fd::accessOld<T,FIELD>( cell.neighbor({ 0, 0, normalZ*iN}), iT );
68 }
69 cell.computeU(u);
70 SCHEME_BOUND::apply(fGhost, *f0, fNormal, normal, u, vars);
71 for (int iN=1; iN<=MODEL::extent(); ++iN) {
72 f[fd::getArrayPos<MODEL::extent()>(iN-1,0)] = normalX<=0 ? *fd::accessOld<T,FIELD>( cell.neighbor({-iN, 0, 0}), iT )
73 : fGhost[fd::getArrayPos<MODEL::extent()+SCHEME_BOUND::getExtraExtent()>(iN-1,0)];
74 F[fd::getArrayPos<MODEL::extent()>(iN-1,0)] = normalX>=0 ? *fd::accessOld<T,FIELD>( cell.neighbor({+iN, 0, 0}), iT )
75 : fGhost[fd::getArrayPos<MODEL::extent()+SCHEME_BOUND::getExtraExtent()>(iN-1,0)];
76 f[fd::getArrayPos<MODEL::extent()>(iN-1,1)] = normalY<=0 ? *fd::accessOld<T,FIELD>( cell.neighbor({ 0, -iN, 0}), iT )
77 : fGhost[fd::getArrayPos<MODEL::extent()+SCHEME_BOUND::getExtraExtent()>(iN-1,1)];
78 F[fd::getArrayPos<MODEL::extent()>(iN-1,1)] = normalY>=0 ? *fd::accessOld<T,FIELD>( cell.neighbor({ 0, +iN, 0}), iT )
79 : fGhost[fd::getArrayPos<MODEL::extent()+SCHEME_BOUND::getExtraExtent()>(iN-1,1)];
80 f[fd::getArrayPos<MODEL::extent()>(iN-1,2)] = normalZ<=0 ? *fd::accessOld<T,FIELD>( cell.neighbor({ 0, 0, -iN}), iT )
81 : fGhost[fd::getArrayPos<MODEL::extent()+SCHEME_BOUND::getExtraExtent()>(iN-1,2)];
82 F[fd::getArrayPos<MODEL::extent()>(iN-1,2)] = normalZ>=0 ? *fd::accessOld<T,FIELD>( cell.neighbor({ 0, 0, +iN}), iT )
83 : fGhost[fd::getArrayPos<MODEL::extent()+SCHEME_BOUND::getExtraExtent()>(iN-1,2)];
84 }
85 MODEL::apply(fNew, f0, f, F, u, vars);
86 this->applySourceTerm(fNew, cell);
87 }
88}
void applySourceTerm(T *fNew, CELL &cell) any_platform
constexpr unsigned getArrayPos(const unsigned iExt, const unsigned iD) any_platform

◆ getPriority()

template<typename T , typename DESCRIPTOR , typename MODEL , typename SCHEME_BOUND , typename PARAMS , typename FIELD , typename SOURCE >
int olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >::getPriority ( ) const

Definition at line 42 of file fdBoundaryPostProcessors3D.hh.

43{
44 return 1;
45}

Member Data Documentation

◆ scope

template<typename T , typename DESCRIPTOR , typename MODEL , typename SCHEME_BOUND , typename PARAMS , typename FIELD = descriptors::AD_FIELD, typename SOURCE = void>
constexpr OperatorScope olb::FdBoundaryPostProcessor3D< T, DESCRIPTOR, MODEL, SCHEME_BOUND, PARAMS, FIELD, SOURCE >::scope = OperatorScope::PerCellWithParameters
staticconstexpr

Definition at line 40 of file fdBoundaryPostProcessors3D.h.


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