#include <grid.h>
Base class for Grid to host common functions that do not depend on the GridOptions parameter.
Definition at line 67 of file grid.h.
◆ SizeType
A type to store the sizes.
Definition at line 70 of file grid.h.
◆ find_min_and_length()
std::pair< std::array< double, 3 >, std::array< double, 3 > > smash::GridBase::find_min_and_length |
( |
const Particles & |
particles | ) |
|
|
staticprotected |
- Returns
- the minimum x,y,z coordinates and the largest dx,dy,dz distances of the particles in
particles
.
- Parameters
-
Definition at line 88 of file grid.cc.
89 std::pair<std::array<double, 3>, std::array<double, 3>> r;
90 auto &min_position = r.first;
91 auto &length = r.second;
95 const auto &first_position = particles.front().position();
96 min_position = {{first_position[1], first_position[2], first_position[3]}};
97 auto max_position = min_position;
98 for (
const auto &
p : particles) {
99 const auto &pos =
p.position();
100 min_position[0] = std::min(min_position[0], pos[1]);
101 min_position[1] = std::min(min_position[1], pos[2]);
102 min_position[2] = std::min(min_position[2], pos[3]);
103 max_position[0] = std::max(max_position[0], pos[1]);
104 max_position[1] = std::max(max_position[1], pos[2]);
105 max_position[2] = std::max(max_position[2], pos[3]);
107 length[0] = max_position[0] - min_position[0];
108 length[1] = max_position[1] - min_position[1];
109 length[2] = max_position[2] - min_position[2];
The documentation for this class was generated from the following files: