32template <
class ParticleCell,
class PairwiseFunctor,
class NeighborList>
48 double interactionLength,
const std::array<double, 3> &cellLength,
49 DataLayoutOption dataLayout,
bool useNewton3, ContainerOption::Value typeOfList)
51 cellLength, dataLayout, useNewton3, false),
53 _functor(pairwiseFunctor) {}
59 case (ContainerOption::verletListsCells):
60 return TraversalOption::vlc_sliced_balanced;
61 case (ContainerOption::pairwiseVerletLists):
62 return TraversalOption::vlp_sliced_balanced;
68 return TraversalOption();
85template <
class ParticleCell,
class PairwiseFunctor,
class NeighborList>
87 if (this->_dataLayout == DataLayoutOption::soa) {
88 this->loadSoA(_functor, *(this->_verletList));
91 this->slicedTraversal([&](
unsigned long x,
unsigned long y,
unsigned long z) {
93 this->
template processCellLists<PairwiseFunctor>(*(this->_verletList), baseIndex, _functor, this->_dataLayout,
97 if (this->_dataLayout == DataLayoutOption::soa) {
98 this->extractSoA(_functor, *(this->_verletList));
PairwiseFunctor class.
Definition: PairwiseFunctor.h:31
Class for Cells of Particles.
Definition: ParticleCell.h:49
This class provides a load balanced version of the base sliced traversal.
Definition: SlicedBalancedBasedTraversal.h:30
DataLayoutOption _dataLayout
The datalayout used by this traversal.
Definition: TraversalInterface.h:75
This class provides the balanced sliced traversal.
Definition: VLCSlicedBalancedTraversal.h:34
bool isApplicable() const override
Checks if the traversal is applicable to the current state of the domain.
Definition: VLCSlicedBalancedTraversal.h:71
TraversalOption getTraversalType() const override
Return a enum representing the name of the traversal class.
Definition: VLCSlicedBalancedTraversal.h:57
void setSortingThreshold(size_t sortingThreshold) override
Set the sorting-threshold for traversals that use the CellFunctor If the sum of the number of particl...
Definition: VLCSlicedBalancedTraversal.h:79
void traverseParticles() override
Traverse the particles by pairs, triplets etc.
Definition: VLCSlicedBalancedTraversal.h:86
VLCSlicedBalancedTraversal(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 balanced sliced traversal.
Definition: VLCSlicedBalancedTraversal.h:47
This class provides the Traversal Interface for the verlet lists cells container.
Definition: VLCTraversalInterface.h:38
ContainerOption _typeOfList
The type of neighbor list as an enum value.
Definition: VLCTraversalInterface.h:108
static void exception(const Exception e)
Handle an exception derived by std::exception.
Definition: ExceptionHandler.h:63
constexpr T threeToOneD(T x, T y, T z, const std::array< T, 3 > &dims)
Convert a 3d index to a 1d index.
Definition: ThreeDimensionalMapping.h:29
This is the main namespace of AutoPas.
Definition: AutoPasDecl.h:32