|
| SlicedC02BasedTraversal (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 colored sliced traversal.
|
|
template<typename LoopBody > |
void | cSlicedTraversal (LoopBody &&loopBody) |
| The main traversal of the colored sliced traversal.
|
|
bool | isApplicable () const override |
| Checks if the traversal is applicable to the current state of the domain.
|
|
void | initTraversal () override |
| Load Data Layouts and sets up slice thicknesses.
|
|
| 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.
|
|
|
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().
|
|
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.
|
|
template<class
ParticleCell, class
Functor>
class autopas::SlicedC02BasedTraversal< ParticleCell, Functor >
This class provides the colored sliced traversal.
The traversal finds the longest dimension of the simulation domain and cuts the domain into as many slices as possible along this dimension. Unlike the regular sliced traversal, this version uses a 2-coloring to prevent race conditions, instead of locking the starting layers. This could also be describes as a c02-traversal. This class is however not derived from ColorBasedTraversal, as that would not allow varying slice thicknesses, and would prevent us from selecting the dimension in which we cut the slices.
- Template Parameters
-
ParticleCell | The type of cells. |
Functor | The functor that defines the interaction between particles. |