1#include "../../include/integrator/predictor_corrector_euler.h"
4 printf(
"PredictorCorrectorEuler()\n");
9 printf(
"Device: %i\n",
device);
33 printf(
"~PredictorCorrectorEuler()\n");
49 printf(
"PredictorCorrector::integrate()\n");
69 Logger(
TIME) <<
"removing particles: " << timeElapsed <<
" ms";
78 time +=
rhs(step,
true,
true);
80 timeElapsed = timerRhs.
elapsed();
124 time +=
rhs(step,
false,
false);
126 timeElapsed = timerRhs.
elapsed();
127 Logger(
TIME) <<
"rhsElapsed: " << timeElapsed;
146 <<
" (STEP: " << step <<
" | subStep: " <<
subStep
157 boost::mpi::communicator comm;
159 all_reduce(comm, boost::mpi::inplace_t<integer*>(&
sumParticles), 1, std::plus<integer>());
167 Logger(
TIME) <<
"integration step elapsed: " << timeElapsed <<
" ms";
void vector2file(const std::string &path, std::vector< T > data)
void const setStep(const int &_step)
Set current step of profiler.
void value2file(const std::string &path, T value)
Write value to single value data set.
IntegratedParticles * d_integratedParticles
device instance of IntegratedParticles class
Material * d_materials
device instance of material class
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.
integer numNodes
number of nodes (to be allocated)
void dynamicLoadBalancing(int bins=5000)
Pre-calculations for updateRangeApproximately.
MaterialHandler * materialHandler
Instance to handle Materials instances on device and host.
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!)
IntegratedParticleHandler * integratedParticles
real removeParticles()
Remove particles in dependence of some criterion.
SimulationParameters simulationParameters
buffer (need for revising)
integer numParticlesLocal
real h_searchRadius
search radius for SPH (MPI-process overarching) neighbor search
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 setPointer(IntegratedParticleHandler *integratedParticleHandler)
PredictorCorrectorEulerNS::BlockShared * d_blockShared
~PredictorCorrectorEuler()
Destructor.
PredictorCorrectorEuler(SimulationParameters simulationParameters)
Constructor.
void integrate(int step)
Implementation of the abstract integration method.
struct cudaDeviceProp prop
void globalizeTimeStep(Execution::Location exLoc)
void copy(To::Target target)
SimulationTime * d_simulationTime
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.
void setE(BlockShared *blockShared, real *e)
void setVmax(BlockShared *blockShared, real *vmax)
void setRho(BlockShared *blockShared, real *e)
void set(BlockShared *blockShared, real *forces, real *courant, real *artVisc)
real setTimeStep(int multiProcessorCount, SimulationTime *simulationTime, Material *materials, Particles *particles, BlockShared *blockShared, int *blockCount, real searchRadius, int numParticles)
Wrapper for PredictorCorrectorEulerNS::Kernel::setTimeStep().
real predictor(Particles *particles, IntegratedParticles *predictor, real dt, int numParticles)
Wrapper for PredictorCorrectorEulerNS::Kernel::predictor().
real corrector(Particles *particles, IntegratedParticles *predictor, real dt, int numParticles)
Wrapper for PredictorCorrectorEulerNS::Kernel::corrector().
const char *const removeParticles
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.
void free(T *d_var)
Free device memory.
void malloc(T *&d_var, std::size_t count)
Allocate device memory.
bool loadBalancing
apply load balancing
int loadBalancingInterval
apply load balancing each x interval/simulation step