AutoPas  3.0.0
Loading...
Searching...
No Matches
DirectSum.h
Go to the documentation of this file.
1
8#pragma once
9
24#include "autopas/utils/inBox.h"
25
26namespace autopas {
27
45template <class Particle_T>
46class DirectSum : public CellBasedParticleContainer<FullParticleCell<Particle_T>> {
47 public:
52
56 using ParticleType = Particle_T;
57
66 DirectSum(const std::array<double, 3> &boxMin, const std::array<double, 3> &boxMax, double cutoff, double skin,
67 const size_t sortingThreshold)
68 : CellBasedParticleContainer<ParticleCellType>(boxMin, boxMax, cutoff, skin, sortingThreshold),
69 _cellBorderFlagManager() {
70 using namespace autopas::utils::ArrayMath::literals;
71 // 1 owned and 6 halo cells
72 this->_cells.resize(7);
73 this->_cells[0].setPossibleParticleOwnerships(OwnershipState::owned);
74 std::for_each(++this->_cells.begin(), this->_cells.end(),
75 [&](auto &cell) { cell.setPossibleParticleOwnerships(OwnershipState::halo); });
76 auto boxLength = boxMax - boxMin;
77 this->_cells[0].setCellLength(boxLength);
78 }
79
83 [[nodiscard]] ContainerOption getContainerType() const override { return ContainerOption::directSum; }
84
85 void reserve(size_t numParticles, size_t numParticlesHaloEstimate) override {
86 this->getOwnedCell().reserve(numParticles);
87 for (auto cellIt = ++this->_cells.begin(); cellIt != this->_cells.end(); cellIt++) {
88 cellIt->reserve(numParticlesHaloEstimate);
89 }
90 };
91
95 void addParticleImpl(const Particle_T &p) override { getOwnedCell().addParticle(p); }
96
100 void addHaloParticleImpl(const Particle_T &haloParticle) override {
101 const auto boxMax = this->getBoxMax();
102 const auto boxMin = this->getBoxMin();
103 const auto pos = haloParticle.getR();
104
105 for (size_t dim = 0; dim < 3; ++dim) {
106 if (pos[dim] < boxMin[dim]) {
107 this->_cells[2 * dim + 1].addParticle(haloParticle);
108 return;
109 } else if (pos[dim] >= boxMax[dim]) {
110 this->_cells[2 * dim + 2].addParticle(haloParticle);
111 return;
112 }
113 }
114 }
115
119 bool updateHaloParticle(const Particle_T &haloParticle) override {
120 const auto boxMax = this->getBoxMax();
121 const auto boxMin = this->getBoxMin();
122 const auto pos = haloParticle.getR();
123 const auto skinHalf = 0.5 * this->getVerletSkin();
124
125 // Look for the particle in halo cells that are within half the skin distance of its position
126 for (size_t dim = 0; dim < 3; ++dim) {
127 if (pos[dim] < boxMin[dim] + skinHalf) {
128 if (internal::checkParticleInCellAndUpdateByIDAndPosition(this->_cells[2 * dim + 1], haloParticle, skinHalf)) {
129 return true;
130 }
131 } else if (pos[dim] >= boxMax[dim] - skinHalf) {
132 if (internal::checkParticleInCellAndUpdateByIDAndPosition(this->_cells[2 * dim + 2], haloParticle, skinHalf)) {
133 return true;
134 }
135 }
136 }
137 return false;
138 }
139
140 void deleteHaloParticles() override {
141 for (auto cellIt = ++this->_cells.begin(); cellIt != this->_cells.end(); cellIt++) {
142 cellIt->clear();
143 }
144 }
145
146 void rebuildNeighborLists(TraversalInterface *traversal) override {
147 // nothing to do.
148 }
149
150 void computeInteractions(TraversalInterface *traversal) override {
151 prepareTraversal(traversal);
152
153 traversal->initTraversal();
154 traversal->traverseParticles();
155 traversal->endTraversal();
156 }
157
158 [[nodiscard]] std::vector<Particle_T> updateContainer(bool keepNeighborListsValid) override {
159 if (keepNeighborListsValid) {
161 }
162 // first we delete halo particles, as we don't want them here.
164 getOwnedCell().deleteDummyParticles();
165
166 std::vector<Particle_T> invalidParticles{};
167 auto &particleVec = getOwnedCell()._particles;
168 for (auto iter = particleVec.begin(); iter != particleVec.end();) {
169 if (utils::notInBox(iter->getR(), this->getBoxMin(), this->getBoxMax())) {
170 invalidParticles.push_back(*iter);
171 // swap-delete
172 *iter = particleVec.back();
173 particleVec.pop_back();
174 } else {
175 ++iter;
176 }
177 }
178 return invalidParticles;
179 }
180
184 [[nodiscard]] TraversalSelectorInfo getTraversalSelectorInfo() const override {
185 using namespace autopas::utils::ArrayMath::literals;
186
187 // direct sum consists of seven cells (owned + two halo cells in each dimension)
189 // DS container can be viewed as a 3x3x3 grid with some halo cells being combined.
190 {3, 3, 3},
191 // intentionally use cutoff here, as ds_sequential should be using the cutoff.
192 this->getCutoff(), this->getBoxMax() - this->getBoxMin(), 0);
193 }
194
199 IteratorBehavior behavior = IteratorBehavior::ownedOrHalo,
201 std::nullopt) override {
202 return ContainerIterator<Particle_T, true, false>(*this, behavior, additionalVectors);
203 }
204
209 IteratorBehavior behavior = IteratorBehavior::ownedOrHalo,
211 std::nullopt) const override {
212 return ContainerIterator<Particle_T, false, false>(*this, behavior, additionalVectors);
213 }
214
218 template <typename Lambda>
219 void forEach(Lambda forEachLambda, IteratorBehavior behavior) {
220 if (behavior & IteratorBehavior::owned) {
221 getOwnedCell().forEach(forEachLambda);
222 }
223 if (behavior & IteratorBehavior::halo) {
224 for (auto cellIt = ++this->_cells.begin(); cellIt != this->_cells.end(); cellIt++) {
225 cellIt->forEach(forEachLambda);
226 }
227 }
228 // sanity check
229 if (not(behavior & IteratorBehavior::ownedOrHalo)) {
230 utils::ExceptionHandler::exception("Encountered invalid iterator behavior!");
231 }
232 }
233
237 template <typename Lambda, typename A>
238 void reduce(Lambda reduceLambda, A &result, IteratorBehavior behavior) {
239 if (behavior & IteratorBehavior::owned) {
240 getOwnedCell().reduce(reduceLambda, result);
241 }
242 if (behavior & IteratorBehavior::halo) {
243 for (auto cellIt = ++this->_cells.begin(); cellIt != this->_cells.end(); cellIt++) {
244 cellIt->reduce(reduceLambda, result);
245 }
246 }
247 // sanity check
248 if (not(behavior & IteratorBehavior::ownedOrHalo)) {
249 utils::ExceptionHandler::exception("Encountered invalid iterator behavior!");
250 }
251 }
252
257 const std::array<double, 3> &lowerCorner, const std::array<double, 3> &higherCorner, IteratorBehavior behavior,
259 std::nullopt) override {
260 return ContainerIterator<Particle_T, true, true>(*this, behavior, additionalVectors, lowerCorner, higherCorner);
261 }
262
267 const std::array<double, 3> &lowerCorner, const std::array<double, 3> &higherCorner, IteratorBehavior behavior,
269 std::nullopt) const override {
270 return ContainerIterator<Particle_T, false, true>(*this, behavior, additionalVectors, lowerCorner, higherCorner);
271 }
272
276 template <typename Lambda>
277 void forEachInRegion(Lambda forEachLambda, const std::array<double, 3> &lowerCorner,
278 const std::array<double, 3> &higherCorner, IteratorBehavior behavior) {
279 if (behavior & IteratorBehavior::owned) {
280 getOwnedCell().forEach(forEachLambda, lowerCorner, higherCorner, behavior);
281 }
282 if (behavior & IteratorBehavior::halo) {
283 for (auto cellIt = ++this->_cells.begin(); cellIt != this->_cells.end(); cellIt++) {
284 cellIt->forEach(forEachLambda, lowerCorner, higherCorner, behavior);
285 }
286 }
287 // sanity check
288 if (not(behavior & IteratorBehavior::ownedOrHalo)) {
289 utils::ExceptionHandler::exception("Encountered invalid iterator behavior!");
290 }
291 }
292
296 template <typename Lambda, typename A>
297 void reduceInRegion(Lambda reduceLambda, A &result, const std::array<double, 3> &lowerCorner,
298 const std::array<double, 3> &higherCorner, IteratorBehavior behavior) {
299 if (behavior & IteratorBehavior::owned) {
300 getOwnedCell().reduce(reduceLambda, result, lowerCorner, higherCorner, behavior);
301 }
302 if (behavior & IteratorBehavior::halo) {
303 for (auto cellIt = ++this->_cells.begin(); cellIt != this->_cells.end(); cellIt++) {
304 cellIt->reduce(reduceLambda, result, lowerCorner, higherCorner, behavior);
305 }
306 }
307 // sanity check
308 if (not(behavior & IteratorBehavior::ownedOrHalo)) {
309 utils::ExceptionHandler::exception("Encountered invalid iterator behavior!");
310 }
311 }
312
313 std::tuple<const Particle_T *, size_t, size_t> getParticle(size_t cellIndex, size_t particleIndex,
314 IteratorBehavior iteratorBehavior,
315 const std::array<double, 3> &boxMin,
316 const std::array<double, 3> &boxMax) const override {
317 return getParticleImpl<true>(cellIndex, particleIndex, iteratorBehavior, boxMin, boxMax);
318 }
319 std::tuple<const Particle_T *, size_t, size_t> getParticle(size_t cellIndex, size_t particleIndex,
320 IteratorBehavior iteratorBehavior) const override {
321 // this is not a region iter hence we stretch the bounding box to the numeric max
322 constexpr std::array<double, 3> boxMin{std::numeric_limits<double>::lowest(), std::numeric_limits<double>::lowest(),
323 std::numeric_limits<double>::lowest()};
324
325 constexpr std::array<double, 3> boxMax{std::numeric_limits<double>::max(), std::numeric_limits<double>::max(),
326 std::numeric_limits<double>::max()};
327 return getParticleImpl<false>(cellIndex, particleIndex, iteratorBehavior, boxMin, boxMax);
328 }
329
333 bool deleteParticle(Particle_T &particle) override {
334 // swap-delete helper function
335 auto swapDelFromCell = [&](auto &particleCell) -> bool {
336 auto &particleVec = particleCell._particles;
337 const bool isRearParticle = &particle == &particleVec.back();
338 particle = particleVec.back();
339 particleVec.pop_back();
340 return isRearParticle;
341 };
342
343 // deduce into which vector the reference points
344 if (particle.isOwned()) {
345 return swapDelFromCell(getOwnedCell());
346 } else if (particle.isHalo()) {
347 const auto boxMin = this->getBoxMin();
348 const auto boxMax = this->getBoxMax();
349 const auto skinHalf = 0.5 * this->getVerletSkin();
350 const auto pos = particle.getR();
351
352 // Look for the particle in halo cells that are within half the skinHalf distance of its position
353 for (size_t dim = 0; dim < 3; ++dim) {
354 if (pos[dim] < boxMin[dim] + skinHalf) {
355 if (swapDelFromCell(this->_cells[2 * dim + 1])) {
356 return true;
357 }
358 } else if (pos[dim] >= boxMax[dim] - skinHalf) {
359 if (swapDelFromCell(this->_cells[2 * dim + 2])) {
360 return true;
361 }
362 }
363 }
364 }
365 return false;
366 }
367
368 bool deleteParticle(size_t cellIndex, size_t particleIndex) override {
369 auto &particleVec = this->_cells[cellIndex]._particles;
370 auto &particle = particleVec[particleIndex];
371 // swap-delete
372 particle = particleVec.back();
373 particleVec.pop_back();
374 return particleIndex < particleVec.size();
375 }
376
377 private:
378 class DirectSumCellBorderAndFlagManager : public internal::CellBorderAndFlagManager {
382 using index_t = std::size_t;
383
384 public:
385 [[nodiscard]] bool cellCanContainHaloParticles(index_t index1d) const override {
386 return index1d >= 1 and index1d <= 6;
387 }
388
389 [[nodiscard]] bool cellCanContainOwnedParticles(index_t index1d) const override { return index1d == 0; }
390
391 } _cellBorderFlagManager;
392
404 template <bool regionIter>
405 std::tuple<const Particle_T *, size_t, size_t> getParticleImpl(size_t cellIndex, size_t particleIndex,
406 IteratorBehavior iteratorBehavior,
407 const std::array<double, 3> &boxMin,
408 const std::array<double, 3> &boxMax) const {
409 // first and last relevant cell index
410 const auto [startCellIndex, endCellIndex] = [&]() -> std::tuple<size_t, size_t> {
411 // shortcuts to limit the iterator to only part of the domain.
412 if (not(iteratorBehavior & IteratorBehavior::halo)) {
413 // only owned region
414 return {0, 0};
415 }
416 if (not(iteratorBehavior & IteratorBehavior::owned)) {
417 // only halo region
418 return {1, 6};
419 }
420 if constexpr (regionIter) {
421 // if the region lies fully within the container only look at the owned cell
422 if (utils::ArrayMath::less(this->getBoxMin(), boxMin) and utils::ArrayMath::less(boxMax, this->getBoxMax())) {
423 return {0, 0};
424 }
425 }
426 // all cells
427 return {0, 6};
428 }();
429
430 // if we are at the start of an iteration determine this thread's cell index
431 if (cellIndex == 0 and particleIndex == 0) {
432 cellIndex =
433 startCellIndex + ((iteratorBehavior & IteratorBehavior::forceSequential) ? 0 : autopas_get_thread_num());
434 }
435 // abort if the index is out of bounds
436 if (cellIndex >= this->_cells.size()) {
437 return {nullptr, 0, 0};
438 }
439 // check the data behind the indices
440 if (particleIndex >= this->_cells[cellIndex].size() or
441 not containerIteratorUtils::particleFulfillsIteratorRequirements<regionIter>(
442 this->_cells[cellIndex][particleIndex], iteratorBehavior, boxMin, boxMax)) {
443 // either advance them to something interesting or invalidate them.
444 std::tie(cellIndex, particleIndex) =
445 advanceIteratorIndices<regionIter>(cellIndex, particleIndex, iteratorBehavior, boxMin, boxMax);
446 }
447
448 // shortcut if the given index doesn't exist
449 if (cellIndex >= this->_cells.size()) {
450 return {nullptr, 0, 0};
451 }
452 const Particle_T *retPtr = &this->_cells[cellIndex][particleIndex];
453
454 return {retPtr, cellIndex, particleIndex};
455 }
456
468 template <bool regionIter>
469 std::tuple<size_t, size_t> advanceIteratorIndices(size_t cellIndex, size_t particleIndex,
470 IteratorBehavior iteratorBehavior,
471 const std::array<double, 3> &boxMin,
472 const std::array<double, 3> &boxMax) const {
473 // Find the indices for the next particle
474 const size_t stride = (iteratorBehavior & IteratorBehavior::forceSequential) ? 1 : autopas_get_num_threads();
475
476 do {
477 // advance to the next particle
478 ++particleIndex;
479 // If this breaches the end of a cell, find the next non-empty cell and reset particleIndex.
480 while (particleIndex >= this->_cells[cellIndex].size()) {
481 cellIndex += stride;
482 particleIndex = 0;
483 // If there are no more reasonable cells return invalid indices.
484 if (cellIndex > ((not(iteratorBehavior & IteratorBehavior::halo)) ? 0 : (this->_cells.size() - 1))) {
485 return {std::numeric_limits<decltype(cellIndex)>::max(), std::numeric_limits<decltype(particleIndex)>::max()};
486 }
487 }
488 } while (not containerIteratorUtils::particleFulfillsIteratorRequirements<regionIter>(
489 this->_cells[cellIndex][particleIndex], iteratorBehavior, boxMin, boxMax));
490
491 // the indices returned at this point should always be valid
492 return {cellIndex, particleIndex};
493 }
494
500 template <typename Traversal>
501 void prepareTraversal(Traversal &traversal) {
502 auto *dsTraversal = dynamic_cast<DSTraversalInterface *>(traversal);
503 auto *cellTraversal = dynamic_cast<CellTraversal<ParticleCellType> *>(traversal);
504 if (dsTraversal && cellTraversal) {
505 cellTraversal->setSortingThreshold(this->_sortingThreshold);
506 cellTraversal->setCellsToTraverse(this->_cells);
507 } else {
509 "The selected traversal is not compatible with the DirectSum container. TraversalID: {}",
510 traversal->getTraversalType());
511 }
512 }
513
514 ParticleCellType &getOwnedCell() { return this->_cells[0]; };
515
516 ParticleCellType &getHaloCell() { return this->_cells[1]; };
517};
518
519} // namespace autopas
The CellBasedParticleContainer class stores particles in some object and provides methods to iterate ...
Definition: CellBasedParticleContainer.h:25
const std::array< double, 3 > & getBoxMax() const final
Get the upper corner of the container without halo.
Definition: CellBasedParticleContainer.h:71
size_t _sortingThreshold
If the number of particles in a cell or cell pair exceeds this threshold, the particles will be sorte...
Definition: CellBasedParticleContainer.h:164
size_t size() const override
Get the total number of particles saved in the container (owned + halo + dummy).
Definition: CellBasedParticleContainer.h:133
double getVerletSkin() const final
Returns the verlet Skin length.
Definition: CellBasedParticleContainer.h:96
double getCutoff() const final
Return the cutoff of the container.
Definition: CellBasedParticleContainer.h:81
const std::array< double, 3 > & getBoxMin() const final
Get the lower corner of the container without halo.
Definition: CellBasedParticleContainer.h:76
std::vector< ParticleCellType > _cells
Vector of particle cells.
Definition: CellBasedParticleContainer.h:159
A cell pair traversal.
Definition: CellTraversal.h:23
virtual void setSortingThreshold(size_t sortingThreshold)=0
Set the sorting-threshold for traversals that use the CellFunctor If the sum of the number of particl...
Public iterator class that iterates over a particle container and additional vectors (which are typic...
Definition: ContainerIterator.h:95
std::conditional_t< modifiable, std::vector< std::vector< Particle_T > * >, std::vector< std::vector< Particle_T > const * > > ParticleVecType
Type of the additional vector collection.
Definition: ContainerIterator.h:108
Interface for traversals used by the DirectSum container.
Definition: DSTraversalInterface.h:18
This class stores all owned particles in a single cell.
Definition: DirectSum.h:46
bool deleteParticle(size_t cellIndex, size_t particleIndex) override
Deletes the particle at the given index positions as long as this does not compromise the validity of...
Definition: DirectSum.h:368
std::tuple< const Particle_T *, size_t, size_t > getParticle(size_t cellIndex, size_t particleIndex, IteratorBehavior iteratorBehavior) const override
Fetch the pointer to a particle, identified via a cell and particle index.
Definition: DirectSum.h:319
bool deleteParticle(Particle_T &particle) override
Deletes the given particle as long as this does not compromise the validity of the container.
Definition: DirectSum.h:333
void addParticleImpl(const Particle_T &p) override
Adds a particle to the container.
Definition: DirectSum.h:95
void reduceInRegion(Lambda reduceLambda, A &result, const std::array< double, 3 > &lowerCorner, const std::array< double, 3 > &higherCorner, IteratorBehavior behavior)
Execute code on all particles in this container in a certain region as defined by a lambda function.
Definition: DirectSum.h:297
TraversalSelectorInfo getTraversalSelectorInfo() const override
Generates a traversal selector info for this container.
Definition: DirectSum.h:184
void forEachInRegion(Lambda forEachLambda, const std::array< double, 3 > &lowerCorner, const std::array< double, 3 > &higherCorner, IteratorBehavior behavior)
Execute code on all particles in this container in a certain region as defined by a lambda function.
Definition: DirectSum.h:277
ContainerIterator< Particle_T, false, false > begin(IteratorBehavior behavior=IteratorBehavior::ownedOrHalo, utils::optRef< typename ContainerIterator< Particle_T, false, false >::ParticleVecType > additionalVectors=std::nullopt) const override
Iterate over all particles using for(auto iter = container.begin(); iter.isValid(); ++iter) .
Definition: DirectSum.h:208
void rebuildNeighborLists(TraversalInterface *traversal) override
Rebuilds the neighbor lists for the next traversals.
Definition: DirectSum.h:146
void deleteHaloParticles() override
Deletes all halo particles.
Definition: DirectSum.h:140
FullParticleCell< Particle_T > ParticleCellType
Type of the ParticleCell.
Definition: DirectSum.h:51
void reserve(size_t numParticles, size_t numParticlesHaloEstimate) override
Reserve memory for a given number of particles in the container and logic layers.
Definition: DirectSum.h:85
std::tuple< const Particle_T *, size_t, size_t > getParticle(size_t cellIndex, size_t particleIndex, IteratorBehavior iteratorBehavior, const std::array< double, 3 > &boxMin, const std::array< double, 3 > &boxMax) const override
Fetch the pointer to a particle, identified via a cell and particle index.
Definition: DirectSum.h:313
void computeInteractions(TraversalInterface *traversal) override
Iterates over all particle multiples (e.g.
Definition: DirectSum.h:150
std::vector< Particle_T > updateContainer(bool keepNeighborListsValid) override
Updates the container.
Definition: DirectSum.h:158
ContainerIterator< Particle_T, true, true > getRegionIterator(const std::array< double, 3 > &lowerCorner, const std::array< double, 3 > &higherCorner, IteratorBehavior behavior, utils::optRef< typename ContainerIterator< Particle_T, true, true >::ParticleVecType > additionalVectors=std::nullopt) override
Iterate over all particles in a specified region for(auto iter = container.getRegionIterator(lowCorne...
Definition: DirectSum.h:256
void forEach(Lambda forEachLambda, IteratorBehavior behavior)
Execute code on all particles in this container as defined by a lambda function.
Definition: DirectSum.h:219
bool updateHaloParticle(const Particle_T &haloParticle) override
Update a halo particle of the container with the given haloParticle.
Definition: DirectSum.h:119
void addHaloParticleImpl(const Particle_T &haloParticle) override
Adds a particle to the container that lies in the halo region of the container.
Definition: DirectSum.h:100
DirectSum(const std::array< double, 3 > &boxMin, const std::array< double, 3 > &boxMax, double cutoff, double skin, const size_t sortingThreshold)
Constructor of the DirectSum class.
Definition: DirectSum.h:66
ContainerIterator< Particle_T, false, true > getRegionIterator(const std::array< double, 3 > &lowerCorner, const std::array< double, 3 > &higherCorner, IteratorBehavior behavior, utils::optRef< typename ContainerIterator< Particle_T, false, true >::ParticleVecType > additionalVectors=std::nullopt) const override
Iterate over all particles in a specified region for(auto iter = container.getRegionIterator(lowCorne...
Definition: DirectSum.h:266
ContainerOption getContainerType() const override
Get the ContainerType.
Definition: DirectSum.h:83
Particle_T ParticleType
Type of the Particle.
Definition: DirectSum.h:56
ContainerIterator< Particle_T, true, false > begin(IteratorBehavior behavior=IteratorBehavior::ownedOrHalo, utils::optRef< typename ContainerIterator< Particle_T, true, false >::ParticleVecType > additionalVectors=std::nullopt) override
Iterate over all particles using for(auto iter = container.begin(); iter.isValid(); ++iter) .
Definition: DirectSum.h:198
void reduce(Lambda reduceLambda, A &result, IteratorBehavior behavior)
Reduce properties of particles as defined by a lambda function.
Definition: DirectSum.h:238
This class handles the storage of particles in their full form.
Definition: FullParticleCell.h:26
void deleteDummyParticles() override
Deletes all dummy particles in this cell.
Definition: FullParticleCell.h:227
StorageType _particles
Storage of the molecules of the cell.
Definition: FullParticleCell.h:274
void forEach(Lambda forEachLambda)
Executes code for every particle in this cell as defined by lambda function.
Definition: FullParticleCell.h:105
void reserve(size_t n)
Requests that the vector capacity be at least enough to contain n elements.
Definition: FullParticleCell.h:269
void addParticle(const Particle_T &p) override
Adds a Particle to the cell.
Definition: FullParticleCell.h:51
void reduce(Lambda reduceLambda, A &result)
Reduce properties of particles as defined by a lambda function.
Definition: FullParticleCell.h:144
This interface serves as a common parent class for all traversals.
Definition: TraversalInterface.h:18
virtual void endTraversal()=0
Finalizes the traversal.
virtual void traverseParticles()=0
Traverse the particles by pairs, triplets etc.
virtual void initTraversal()=0
Initializes the traversal.
Info for traversals of a specific container.
Definition: TraversalSelectorInfo.h:14
Interface class to handle cell borders and cell types of cells.
Definition: CellBorderAndFlagManager.h:17
static void exception(const Exception e)
Handle an exception derived by std::exception.
Definition: ExceptionHandler.h:63
std::vector< typename ContainerType::ParticleType > collectParticlesAndMarkNonOwnedAsDummy(ContainerType &container)
Collects leaving particles and marks halo particles as dummy.
Definition: LeavingParticleCollector.h:85
static bool checkParticleInCellAndUpdateByIDAndPosition(CellType &cell, const typename CellType::ParticleType &particle, double absError)
Same as checkParticleInCellAndUpdateByID(CellType, ParticleType), but additionally checks whether the...
Definition: ParticleCellHelpers.h:39
constexpr bool less(const std::array< T, SIZE > &a, const std::array< T, SIZE > &b)
True iff for all d the following holds: a[d] < b[d].
Definition: ArrayMath.h:79
bool notInBox(const std::array< T, 3 > &position, const std::array< T, 3 > &low, const std::array< T, 3 > &high)
Checks if position is not inside of a box defined by low and high.
Definition: inBox.h:50
std::optional< std::reference_wrapper< T > > optRef
Short alias for std::optional<std::reference_wrapper<T>>
Definition: optRef.h:16
This is the main namespace of AutoPas.
Definition: AutoPasDecl.h:32
int autopas_get_num_threads()
Dummy for omp_get_num_threads() when no OpenMP is available.
Definition: WrapOpenMP.h:138
@ owned
Owned state, a particle with this state is an actual particle and owned by the current AutoPas object...
int autopas_get_thread_num()
Dummy for omp_set_lock() when no OpenMP is available.
Definition: WrapOpenMP.h:132