OpenLB 1.8.1
Loading...
Searching...
No Matches
olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR > Class Template Referencefinal

#include <reductionF3D.h>

+ Inheritance diagram for olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR >:
+ Collaboration diagram for olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR >:

Public Member Functions

 SuperLatticeInterpDensity3Degree3D (SuperLattice< T, DESCRIPTOR > &sLattice, SuperGeometry< T, 3 > &sGeometry, UnitConverter< T, DESCRIPTOR > &conv, int range=1)
 
 ~SuperLatticeInterpDensity3Degree3D () override
 
bool operator() (T output[], const int input[]) override
 
void operator() (T output[], const T input[], const int iC)
 
- Public Member Functions inherited from olb::SuperLatticeF3D< T, DESCRIPTOR >
SuperLattice< T, DESCRIPTOR > & getSuperLattice ()
 
bool operator() (T output[], const int input[])
 
- Public Member Functions inherited from olb::SuperF3D< T, T >
SuperF3D< T, W > & operator- (SuperF3D< T, W > &rhs)
 
SuperF3D< T, W > & operator+ (SuperF3D< T, W > &rhs)
 
SuperF3D< T, W > & operator* (SuperF3D< T, W > &rhs)
 
SuperF3D< T, W > & operator/ (SuperF3D< T, W > &rhs)
 
SuperStructure< T, 3 > & getSuperStructure ()
 
int getBlockFSize () const
 
BlockF3D< W > & getBlockF (int iCloc)
 
bool operator() (W output[], const int input[])
 has to be implemented for 'every' derived class
 
- Public Member Functions inherited from olb::GenericF< W, int >
virtual ~GenericF ()=default
 
int getSourceDim () const
 read only access to member variable _m
 
int getTargetDim () const
 read only access to member variable _n
 
std::string & getName ()
 read and write access to name
 
std::string const & getName () const
 read only access to name
 
bool operator() (W output[])
 wrapper that call the pure virtual operator() (T output[], const S input[]) from above
 
bool operator() (W output[], int input0)
 
bool operator() (W output[], int input0, int input1)
 
bool operator() (W output[], int input0, int input1, int input2)
 
bool operator() (W output[], int input0, int input1, int input2, int input3)
 

Additional Inherited Members

- Public Types inherited from olb::SuperLatticeF3D< T, DESCRIPTOR >
using identity_functor_type = SuperLatticeIdentity3D<T,DESCRIPTOR>
 
- Public Types inherited from olb::SuperF3D< T, T >
using identity_functor_type
 
- Public Types inherited from olb::GenericF< W, int >
using targetType
 
using sourceType
 
- Public Attributes inherited from olb::GenericF< W, int >
std::shared_ptr< GenericF< W, int > > _ptrCalcC
 memory management, frees resouces (calcClass)
 
- Static Public Attributes inherited from olb::SuperF3D< T, T >
static constexpr bool isSuper
 
static constexpr unsigned d
 
- Protected Member Functions inherited from olb::SuperLatticeF3D< T, DESCRIPTOR >
 SuperLatticeF3D (SuperLattice< T, DESCRIPTOR > &superLattice, int targetDim)
 
- Protected Member Functions inherited from olb::SuperF3D< T, T >
 SuperF3D (SuperStructure< T, 3 > &superStructure, int targetDim)
 
- Protected Member Functions inherited from olb::GenericF< W, int >
 GenericF (int targetDim, int sourceDim)
 
- Protected Attributes inherited from olb::SuperLatticeF3D< T, DESCRIPTOR >
SuperLattice< T, DESCRIPTOR > & _sLattice
 
- Protected Attributes inherited from olb::SuperF3D< T, T >
SuperStructure< T, 3 > & _superStructure
 
std::vector< std::unique_ptr< BlockF3D< W > > > _blockF
 Super functors may consist of several BlockF3D<W> derived functors.
 

Detailed Description

template<typename T, typename DESCRIPTOR>
class olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR >

Definition at line 170 of file reductionF3D.h.

Constructor & Destructor Documentation

◆ SuperLatticeInterpDensity3Degree3D()

template<typename T , typename DESCRIPTOR >
olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR >::SuperLatticeInterpDensity3Degree3D ( SuperLattice< T, DESCRIPTOR > & sLattice,
SuperGeometry< T, 3 > & sGeometry,
UnitConverter< T, DESCRIPTOR > & conv,
int range = 1 )

Definition at line 283 of file reductionF3D.hh.

285 :
287{
288 this->getName() = "Interp3DegreeDensity";
289 int maxC = this->_sLattice.getLoadBalancer().size();
290 this->_blockF.reserve(maxC);
291 for (int lociC = 0; lociC < maxC; lociC++) {
292 int globiC = this->_sLattice.getLoadBalancer().glob(lociC);
293
294 BlockLatticeInterpDensity3Degree3D<T, DESCRIPTOR>* foo =
295 new BlockLatticeInterpDensity3Degree3D<T, DESCRIPTOR>(
296 sLattice.getBlock(lociC),
297 sGeometry.getBlockGeometry(lociC),
298 conv,
299 &sLattice.getCuboidDecomposition().get(globiC),
300 range);
301 _bLattices.push_back(foo);
302
303 if (sLattice.getOverlap() <= range + 1)
304 std::cout << "lattice overlap has to be larger than (range + 1)"
305 << std::endl;
306 }
307}
std::string & getName()
Definition genericF.hh:51
std::vector< std::unique_ptr< BlockF3D< W > > > _blockF
SuperLattice< T, DESCRIPTOR > & _sLattice
SuperLatticeF3D(SuperLattice< T, DESCRIPTOR > &superLattice, int targetDim)

References olb::SuperF3D< T, T >::_blockF, olb::SuperLatticeF3D< T, DESCRIPTOR >::_sLattice, olb::SuperLattice< T, DESCRIPTOR >::getBlock(), olb::SuperGeometry< T, D >::getBlockGeometry(), olb::SuperStructure< T, D >::getCuboidDecomposition(), olb::GenericF< W, int >::getName(), and olb::SuperStructure< T, D >::getOverlap().

+ Here is the call graph for this function:

◆ ~SuperLatticeInterpDensity3Degree3D()

template<typename T , typename DESCRIPTOR >
olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR >::~SuperLatticeInterpDensity3Degree3D ( )
override

Definition at line 310 of file reductionF3D.hh.

311{
312 // first deconstruct vector elements
313 for ( auto it : _bLattices) {
314 delete it;
315 }
316 // then delete std::vector
317 _bLattices.clear();
318}

Member Function Documentation

◆ operator()() [1/2]

template<typename T , typename DESCRIPTOR >
bool olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR >::operator() ( T output[],
const int input[] )
inlineoverride

Definition at line 180 of file reductionF3D.h.

181 {
182 return 0;
183 }

◆ operator()() [2/2]

template<typename T , typename DESCRIPTOR >
void olb::SuperLatticeInterpDensity3Degree3D< T, DESCRIPTOR >::operator() ( T output[],
const T input[],
const int iC )

Definition at line 321 of file reductionF3D.hh.

323{
324 if (this->_sLattice.getLoadBalancer().rank(globiC) == singleton::mpi().getRank()) {
325 _bLattices[this->_sLattice.getLoadBalancer().loc(globiC)]->operator()(output,
326 input);
327 }
328}
int getRank() const
Returns the process ID.
MpiManager & mpi()

References olb::singleton::MpiManager::getRank(), and olb::singleton::mpi().

+ Here is the call graph for this function:

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