Version: SMASH-3.2
smash::GridBase Class Reference

#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.

Inheritance diagram for smash::GridBase:
smash::Grid< GridOptions::PeriodicBoundaries > smash::Grid< Options >

Public Types

typedef int SizeType
 A type to store the sizes. More...
 

Static Protected Member Functions

static std::pair< std::array< double, 3 >, std::array< double, 3 > > find_min_and_length (const Particles &particles)
 

Member Typedef Documentation

◆ SizeType

A type to store the sizes.

Definition at line 70 of file grid.h.

Member Function Documentation

◆ 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
[in]particlesParticles in the system

Definition at line 88 of file grid.cc.

88  {
89  std::pair<std::array<double, 3>, std::array<double, 3>> r;
90  auto &min_position = r.first;
91  auto &length = r.second;
92 
93  // intialize min and max position arrays with the position of the first
94  // particle in the list
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]);
106  }
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];
110  return r;
111 }
constexpr int p
Proton.

The documentation for this class was generated from the following files: