1#include "../../include/integrator/leapfrog.h"
36 if (step == 0 &&
subStep == 0) {
38 rhs(step,
true,
true);
43 Logger(
INFO) <<
"Leapfrog::integrate while...";
51 Logger(
TIME) <<
"removing particles: " << timeElapsed <<
" ms";
60 Logger(
TIME) <<
"rhs::loadBalancing(): " << elapsed <<
" ms";
72 time =
rhs(step,
true,
true);
76 Logger(
TIME) <<
"rhsElapsed: " << timeElapsed <<
" ms";
95 <<
" (STEP: " << step <<
" | subStep: " <<
subStep
103 boost::mpi::communicator comm;
105 all_reduce(comm, boost::mpi::inplace_t<integer*>(&
sumParticles), 1, std::plus<integer>());
void vector2file(const std::string &path, std::vector< T > data)
void value2file(const std::string &path, T value)
Write value to single value data set.
void integrate(int step)
Implementation of the abstract integration method.
Leapfrog(SimulationParameters simulationParameters)
Constructor.
ParticleHandler * particleHandler
Instance to handle the Particles instance on device and host.
real rhs(int step, bool selfGravity=true, bool assignParticlesToProcess=true)
H5Profiler & profiler
H5 profiler instance.
void dynamicLoadBalancing(int bins=5000)
Pre-calculations for updateRangeApproximately.
SubDomainKeyTreeHandler * subDomainKeyTreeHandler
Instance to handle the SubDomainKeyTree instance on device and host.
integer numParticles
number of particles (to be allocated)
int subStep
current sub-step (there are possibly more sub-steps within a step!)
real removeParticles()
Remove particles in dependence of some criterion.
SimulationParameters simulationParameters
buffer (need for revising)
integer numParticlesLocal
integer sumParticles
(real) number of particles on all processes
SimulationTimeHandler * simulationTimeHandler
Instance to handle the SimulationTime instances on device and host.
Particles * d_particles
device instance of particles class
void copy(To::Target target)
keyType * h_range
host range(s)
void copy(To::Target target=To::device, bool range=true, bool counter=true)
Copy (parts of the) SubDomainKeyTree instance(s) between host and device.
double elapsed() const
Get elapsed time since instantiation/latest reset.
void reset()
Reset timer instance.
real updateX(Particles *particles, integer n, real dt)
Wrapper for LeapfrogNS::Kernel::update().
real updateV(Particles *particles, integer n, real dt)
const char *const removeParticles
const char *const loadBalancing
const char *const integrate
const char *const rhsElapsed
const char *const numParticlesLocal
const char *const numParticles
void set(T *d_var, T val, std::size_t count=1)
Set device memory to a specific value.
bool loadBalancing
apply load balancing
int loadBalancingInterval
apply load balancing each x interval/simulation step