This class provides the (locked) sliced traversal. More...
#include <VLCSlicedTraversal.h>
Public Member Functions | |
VLCSlicedTraversal (const std::array< unsigned long, 3 > &dims, PairwiseFunctor *pairwiseFunctor, double interactionLength, const std::array< double, 3 > &cellLength, DataLayoutOption dataLayout, bool useNewton3, ContainerOption::Value typeOfList) | |
Constructor of the sliced traversal. | |
void | traverseParticles () override |
Traverse the particles by pairs, triplets etc. | |
TraversalOption | getTraversalType () const override |
Return a enum representing the name of the traversal class. | |
bool | isApplicable () const override |
Checks if the traversal is applicable to the current state of the domain. | |
void | setSortingThreshold (size_t sortingThreshold) override |
Set the sorting-threshold for traversals that use the CellFunctor If the sum of the number of particles in two cells is greater or equal to that value, the CellFunctor creates a sorted view of the particles to avoid unnecessary distance checks. | |
![]() | |
SlicedLockBasedTraversal (const std::array< unsigned long, 3 > &dims, PairwiseFunctor *functor, const double interactionLength, const std::array< double, 3 > &cellLength, DataLayoutOption dataLayout, bool useNewton3, bool spaciallyForward) | |
Constructor of the sliced traversal. | |
![]() | |
SlicedBasedTraversal (const std::array< unsigned long, 3 > &dims, Functor *functor, const double interactionLength, const std::array< double, 3 > &cellLength, DataLayoutOption dataLayout, bool useNewton3, bool spaciallyForward) | |
Constructor of the sliced traversal. | |
bool | isApplicable () const override |
Checks if the traversal is applicable to the current state of the domain. | |
virtual void | initSliceThickness (unsigned long minSliceThickness) |
Sets up the slice thicknesses to create as many slices as possible while respecting minSliceThickness. | |
void | initTraversal () override |
Load Data Layouts and sets up slice thicknesses. | |
void | endTraversal () override |
Write Data to AoS if cells have been set through setCellsToTraverse(). | |
![]() | |
CellTraversal (const std::array< unsigned long, 3 > &dims) | |
Constructor of CellTraversal. | |
virtual | ~CellTraversal ()=default |
Destructor of CellTraversal. | |
virtual void | setCellsToTraverse (std::vector< ParticleCell > &cells) |
Sets the cells to iterate over. | |
virtual void | setSortingThreshold (size_t sortingThreshold)=0 |
Set the sorting-threshold for traversals that use the CellFunctor If the sum of the number of particles in two cells is greater or equal to that value, the CellFunctor creates a sorted view of the particles to avoid unnecessary distance checks. | |
![]() | |
virtual | ~TraversalInterface ()=default |
Destructor of TraversalInterface. | |
TraversalInterface (DataLayoutOption dataLayout, bool useNewton3) | |
Constructor of the TraversalInterface. | |
virtual TraversalOption | getTraversalType () const =0 |
Return a enum representing the name of the traversal class. | |
virtual bool | isApplicable () const =0 |
Checks if the traversal is applicable to the current state of the domain. | |
virtual void | initTraversal ()=0 |
Initializes the traversal. | |
virtual void | traverseParticles ()=0 |
Traverse the particles by pairs, triplets etc. | |
virtual void | endTraversal ()=0 |
Finalizes the traversal. | |
bool | getUseNewton3 () const |
Return whether the traversal uses newton 3. | |
DataLayoutOption | getDataLayout () const |
Return the data layout option. | |
![]() | |
VLCTraversalInterface (ContainerOption typeOfList) | |
Constructor of the VLCTraversalInterface. | |
virtual void | setVerletList (NeighborList &verlet) |
Sets the verlet list for the traversal to iterate over. | |
Additional Inherited Members | |
![]() | |
void | slicedTraversal (LoopBody &&loopBody) |
The main traversal of the sliced traversal. | |
![]() | |
void | init (const std::array< unsigned long, 3 > &dims) |
Resets the cell structure of the traversal. | |
virtual void | loadDataLayout () |
Load Data Layouts required for this Traversal if cells have been set through setCellsToTraverse(). | |
![]() | |
void | processCellLists (NeighborList &neighborLists, unsigned long cellIndex, PairwiseFunctor *pairwiseFunctor, DataLayoutOption dataLayout, bool useNewton3) |
Iterate over all neighbor lists list of a given cell. | |
void | loadSoA (PairwiseFunctor *pairwiseFunctor, NeighborList &neighborLists) |
Load the SoA from the respective neighbor list. | |
void | extractSoA (PairwiseFunctor *pairwiseFunctor, NeighborList &neighborLists) |
Extract the SoA from the respective neighbor list. | |
![]() | |
bool | _dynamic |
whether to use static or dynamic scheduling. | |
![]() | |
std::array< unsigned long, 3 > | _overlap |
Overlap of interacting cells. | |
std::array< int, 3 > | _dimsPerLength |
Store ids of dimensions ordered by number of cells per dimensions. | |
unsigned long | _overlapLongestAxis |
Overlap of interacting cells along the longest axis. | |
std::vector< unsigned long > | _sliceThickness |
The number of cells per slice in the dimension that was sliced. | |
bool | _spaciallyForward |
Whether the base step only covers neigboring cells tha are spacially forward (for example c08). | |
![]() | |
std::array< unsigned long, 3 > | _cellsPerDimension |
The dimensions of the cellblock. | |
std::vector< ParticleCell > * | _cells |
The cells to traverse. | |
![]() | |
DataLayoutOption | _dataLayout |
The datalayout used by this traversal. | |
bool | _useNewton3 |
If this traversal makes use of newton3. | |
![]() | |
NeighborList * | _verletList |
The verlet list to iterate over. | |
SoA< typename Particle_T::SoAArraysType > * | _soa |
Structure of arrays to be used if the data layout is SoA. | |
ContainerOption | _typeOfList |
The type of neighbor list as an enum value. | |
This class provides the (locked) sliced traversal.
The traversal finds the longest dimension of the simulation domain and cuts the domain into multiple slices along this dimension. Slices are assigned to the threads in a round robin fashion. Each thread locks the cells on the boundary wall to the previous slice with one lock. This lock is lifted as soon the boundary wall is fully processed.
For each cell all neighbor lists are processed, so depending on whether lists were built with newton3 the base step is c01 or c18
ParticleCell | the type of cells |
PairwiseFunctor | The functor that defines the interaction of two particles. |
NeighborList | type of the neighbor list |
|
inlineexplicit |
Constructor of the sliced traversal.
dims | The dimensions of the cellblock, i.e. the number of cells in x, y and z direction. |
interactionLength | cutoff + skin |
cellLength | length of the underlying cells |
pairwiseFunctor | The functor that defines the interaction of two particles. |
dataLayout | |
useNewton3 | |
typeOfList | indicates the type of neighbor list as an enum value, currently only used for getTraversalType |
|
inlineoverridevirtual |
Return a enum representing the name of the traversal class.
Implements autopas::TraversalInterface.
|
inlineoverridevirtual |
Checks if the traversal is applicable to the current state of the domain.
Reimplemented from autopas::SlicedBasedTraversal< ParticleCell, Functor >.
|
inlineoverridevirtual |
Set the sorting-threshold for traversals that use the CellFunctor If the sum of the number of particles in two cells is greater or equal to that value, the CellFunctor creates a sorted view of the particles to avoid unnecessary distance checks.
sortingThreshold | Sum of the number of particles in two cells from which sorting should be enabled This traversal does not use the CellFunctor, so the function has no effect here |
Implements autopas::CellTraversal< ParticleCell >.
|
inlineoverridevirtual |
Traverse the particles by pairs, triplets etc.
as determined by the Functor type.
Implements autopas::TraversalInterface.