OpenLB 1.7
Loading...
Searching...
No Matches
Public Types | Public Member Functions | List of all members
olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal > Class Template Reference

Defines incoming directions on corner boundaries. More...

#include <rtlbmBoundaryDynamics.h>

+ Inheritance diagram for olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >:
+ Collaboration diagram for olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >:

Public Types

template<typename M >
using exchange_momenta = RtlbmDiffuseConstCornerBoundaryDynamics<T,DESCRIPTOR,M,xNormal,yNormal,zNormal>
 
- Public Types inherited from olb::dynamics::CustomCollision< T, DESCRIPTOR, MOMENTA >
using value_t = T
 
using descriptor_t = DESCRIPTOR
 
using MomentaF = typename MOMENTA::template type<DESCRIPTOR>
 
- Public Types inherited from olb::Dynamics< T, DESCRIPTOR >
using value_t = T
 
using descriptor_t = DESCRIPTOR
 

Public Member Functions

 RtlbmDiffuseConstCornerBoundaryDynamics (T omega_)
 Constructor.
 
computeEquilibrium (int iPop, T rho, const T u[DESCRIPTOR::d]) const override
 Compute equilibrium distribution function.
 
CellStatistic< T > collide (Cell< T, DESCRIPTOR > &cell) override
 Collision step for corner.
 
getOmega () const
 place holder
 
void setOmega (T omega_)
 place holder
 
- Public Member Functions inherited from olb::legacy::BasicDynamics< T, DESCRIPTOR, MOMENTA >
std::type_index id () override
 Expose unique type-identifier for RTTI.
 
AbstractParameters< T, DESCRIPTOR > & getParameters (BlockLattice< T, DESCRIPTOR > &block) override
 Parameters access for legacy post processors.
 
- Public Member Functions inherited from olb::dynamics::CustomCollision< T, DESCRIPTOR, MOMENTA >
void initialize (Cell< T, DESCRIPTOR > &cell) override
 Initialize dynamics-specific data for cell.
 
computeRho (ConstCell< T, DESCRIPTOR > &cell) const override
 Compute particle density.
 
void computeU (ConstCell< T, DESCRIPTOR > &cell, T u[DESCRIPTOR::d]) const override
 Compute fluid velocity.
 
void computeJ (ConstCell< T, DESCRIPTOR > &cell, T j[DESCRIPTOR::d]) const override
 Compute fluid momentum.
 
void computeStress (ConstCell< T, DESCRIPTOR > &cell, T rho, const T u[DESCRIPTOR::d], T pi[util::TensorVal< DESCRIPTOR >::n]) const override
 Compute stress tensor.
 
void computeRhoU (ConstCell< T, DESCRIPTOR > &cell, T &rho, T u[DESCRIPTOR::d]) const override
 Compute fluid velocity and particle density.
 
void computeAllMomenta (ConstCell< T, DESCRIPTOR > &cell, T &rho, T u[DESCRIPTOR::d], T pi[util::TensorVal< DESCRIPTOR >::n]) const override
 Compute all momenta up to second order.
 
void defineRho (Cell< T, DESCRIPTOR > &cell, T rho) override
 Set particle density.
 
void defineU (Cell< T, DESCRIPTOR > &cell, const T u[DESCRIPTOR::d]) override
 Set fluid velocity.
 
void defineRhoU (Cell< T, DESCRIPTOR > &cell, T rho, const T u[DESCRIPTOR::d]) override
 Define fluid velocity and particle density.
 
void defineAllMomenta (Cell< T, DESCRIPTOR > &cell, T rho, const T u[DESCRIPTOR::d], const T pi[util::TensorVal< DESCRIPTOR >::n]) override
 Define all momenta up to second order.
 
void inverseShiftRhoU (ConstCell< T, DESCRIPTOR > &cell, T &rho, T u[DESCRIPTOR::d]) const override
 Calculate population momenta s.t. the physical momenta are reproduced by the computeRhoU.
 
- Public Member Functions inherited from olb::Dynamics< T, DESCRIPTOR >
virtual ~Dynamics () any_platform
 
virtual std::string getName () const
 Return human-readable name.
 
void iniEquilibrium (Cell< T, DESCRIPTOR > &cell, T rho, const T u[DESCRIPTOR::d])
 Initialize to equilibrium distribution.
 
void iniRegularized (Cell< T, DESCRIPTOR > &cell, T rho, const T u[DESCRIPTOR::d], const T pi[util::TensorVal< DESCRIPTOR >::n])
 Initialize cell to equilibrium and non-equilibrum part.
 

Detailed Description

template<typename T, typename DESCRIPTOR, typename MOMENTA, int xNormal, int yNormal, int zNormal>
class olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >

Defines incoming directions on corner boundaries.

Emposed dirichlet density is distributed equivalently to all incoming/unkown directions.

Parameters
xNormaltakes value -1 or 1
yNormaltakes value -1 or 1
zNormaltakes value -1 or 1

Definition at line 160 of file rtlbmBoundaryDynamics.h.

Member Typedef Documentation

◆ exchange_momenta

template<typename T , typename DESCRIPTOR , typename MOMENTA , int xNormal, int yNormal, int zNormal>
template<typename M >
using olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >::exchange_momenta = RtlbmDiffuseConstCornerBoundaryDynamics<T,DESCRIPTOR,M,xNormal,yNormal,zNormal>

Definition at line 163 of file rtlbmBoundaryDynamics.h.

Constructor & Destructor Documentation

◆ RtlbmDiffuseConstCornerBoundaryDynamics()

template<typename T , typename DESCRIPTOR , typename MOMENTA , int xNormal, int yNormal, int zNormal>
olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >::RtlbmDiffuseConstCornerBoundaryDynamics ( T omega_)

Constructor.

Definition at line 287 of file rtlbmBoundaryDynamics.hh.

288 : legacy::BasicDynamics<T,DESCRIPTOR,MOMENTA>()
289{
290 this->getName() = "RtlbmDiffuseConstCornerBoundaryDynamics";
291}
virtual std::string getName() const
Return human-readable name.
Definition interface.h:63

References olb::Dynamics< T, DESCRIPTOR >::getName().

+ Here is the call graph for this function:

Member Function Documentation

◆ collide()

template<typename T , typename DESCRIPTOR , typename MOMENTA , int xNormal, int yNormal, int zNormal>
CellStatistic< T > olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >::collide ( Cell< T, DESCRIPTOR > & cell)
overridevirtual

Collision step for corner.

Reimplemented from olb::Dynamics< T, DESCRIPTOR >.

Definition at line 300 of file rtlbmBoundaryDynamics.hh.

301{
302 // For direction i \in I_in define
303 // cell_i = w_i * dirichlet/sumWeights - w_i
304 // For direction i \in I_out defube
305 // cell_i = - w_i
306 // This construction yields
307 // sum_{i=0}^{q-1} cell_i == dirichlet - 1
308
309 typedef DESCRIPTOR L;
310
311 // shift all: cell_i = f_i - weight_i
312 for ( int iPop = 0; iPop < L::q; ++iPop ) {
313 cell[iPop] = - descriptors::t<T,L>(iPop);
314 }
315
316 auto missing_iPop = util::subIndexOutgoing3DonCorners<L,xNormal,yNormal,zNormal>();
317 T sumWeights = 0;
318 for ( int i : missing_iPop ) {
319 sumWeights += descriptors::t<T,L>(i);
320 }
321
322 using MomentaF = typename MOMENTA::template type<DESCRIPTOR>;
323 T dirichletTemperature = MomentaF().computeRho(cell);
324 for ( int i : missing_iPop ) {
325 cell[i] = descriptors::t<T,L>(i)*dirichletTemperature/sumWeights - descriptors::t<T,L>(i);
326 }
327
328 return {-1, -1};
329}
typename MOMENTA::template type< DESCRIPTOR > MomentaF
Definition interface.h:299

◆ computeEquilibrium()

template<typename T , typename DESCRIPTOR , typename MOMENTA , int xNormal, int yNormal, int zNormal>
T olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >::computeEquilibrium ( int iPop,
T rho,
const T u[DESCRIPTOR::d] ) const
overridevirtual

Compute equilibrium distribution function.

Reimplemented from olb::legacy::BasicDynamics< T, DESCRIPTOR, MOMENTA >.

Definition at line 294 of file rtlbmBoundaryDynamics.hh.

295{
296 return descriptors::t<T,DESCRIPTOR>(iPop)*rho - descriptors::t<T,DESCRIPTOR>(iPop);
297}

◆ getOmega()

template<typename T , typename DESCRIPTOR , typename MOMENTA , int xNormal, int yNormal, int zNormal>
T olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >::getOmega ( ) const

place holder

Definition at line 332 of file rtlbmBoundaryDynamics.hh.

333{
334 return T(-1);
335}

◆ setOmega()

template<typename T , typename DESCRIPTOR , typename MOMENTA , int xNormal, int yNormal, int zNormal>
void olb::RtlbmDiffuseConstCornerBoundaryDynamics< T, DESCRIPTOR, MOMENTA, xNormal, yNormal, zNormal >::setOmega ( T omega_)

place holder

Definition at line 338 of file rtlbmBoundaryDynamics.hh.

339{
340}

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