AutoPas  3.0.0
Loading...
Searching...
No Matches
VLCC08Traversal.h
Go to the documentation of this file.
1
7#pragma once
8
11
12namespace autopas {
13
27template <class ParticleCell, class PairwiseFunctor, class NeighborList>
28class VLCC08Traversal : public C08BasedTraversal<ParticleCell, PairwiseFunctor>,
29 public VLCTraversalInterface<typename ParticleCell::ParticleType, NeighborList> {
30 public:
41 explicit VLCC08Traversal(const std::array<unsigned long, 3> &dims, PairwiseFunctor *pairwiseFunctor,
42 double interactionLength, const std::array<double, 3> &cellLength,
43 DataLayoutOption dataLayout, bool useNewton3)
44 : C08BasedTraversal<ParticleCell, PairwiseFunctor>(dims, pairwiseFunctor, interactionLength, cellLength,
45 dataLayout, useNewton3),
46 VLCTraversalInterface<typename ParticleCell::ParticleType, NeighborList>(ContainerOption::verletListsCells),
47 _functor(pairwiseFunctor) {}
48
49 void traverseParticles() override;
50
51 [[nodiscard]] TraversalOption getTraversalType() const override { return TraversalOption::vlc_c08; }
52
53 [[nodiscard]] bool isApplicable() const override {
54 // This traversal is only safe to use for CSF>=1
55 const double minCellLength = *std::min_element(this->_cellLength.cbegin(), this->_cellLength.cend());
56 const bool maxOneCellInCutoff = minCellLength >= this->_interactionLength;
57
58 return maxOneCellInCutoff;
59 }
60
65 void setSortingThreshold(size_t sortingThreshold) override {}
66
67 private:
68 PairwiseFunctor *_functor;
69};
70
71template <class ParticleCell, class PairwiseFunctor, class NeighborList>
73 if (this->_dataLayout == DataLayoutOption::soa) {
74 this->loadSoA(_functor, *(this->_verletList));
75 }
76
77 this->c08Traversal([&](unsigned long x, unsigned long y, unsigned long z) {
78 const auto baseIndex = utils::ThreeDimensionalMapping::threeToOneD(x, y, z, this->_cellsPerDimension);
79 this->template processCellLists<PairwiseFunctor>(*(this->_verletList), baseIndex, _functor, this->_dataLayout,
80 this->_useNewton3);
81 });
82
83 if (this->_dataLayout == DataLayoutOption::soa) {
84 this->extractSoA(_functor, *(this->_verletList));
85 }
86}
87
88} // namespace autopas
This class provides the base for traversals using the c08 base step.
Definition: C08BasedTraversal.h:24
const double _interactionLength
Interaction length (cutoff + skin).
Definition: ColorBasedTraversal.h:111
const std::array< double, 3 > _cellLength
cell length in CellBlock3D.
Definition: ColorBasedTraversal.h:116
PairwiseFunctor class.
Definition: PairwiseFunctor.h:31
Class for Cells of Particles.
Definition: ParticleCell.h:49
This class provides the vlc_c08 traversal.
Definition: VLCC08Traversal.h:29
VLCC08Traversal(const std::array< unsigned long, 3 > &dims, PairwiseFunctor *pairwiseFunctor, double interactionLength, const std::array< double, 3 > &cellLength, DataLayoutOption dataLayout, bool useNewton3)
Constructor of the vlc_c08 traversal.
Definition: VLCC08Traversal.h:41
void traverseParticles() override
Traverse the particles by pairs, triplets etc.
Definition: VLCC08Traversal.h:72
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: VLCC08Traversal.h:65
TraversalOption getTraversalType() const override
Return a enum representing the name of the traversal class.
Definition: VLCC08Traversal.h:51
bool isApplicable() const override
Checks if the traversal is applicable to the current state of the domain.
Definition: VLCC08Traversal.h:53
This class provides the Traversal Interface for the verlet lists cells container.
Definition: VLCTraversalInterface.h:38
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