1#include "../include/particle_handler.h"
64#if VARIABLE_SML || INTEGRATE_SML
80#if SOLID || NAVIER_STOKES
106#if LINEAR_CONSISTENCY
190#if VARIABLE_SML || INTEGRATE_SML
192 d_dsmldt = _d_dsmldt;
206#if SOLID || NAVIER_STOKES
232#if LINEAR_CONSISTENCY
262 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_vx,
h_ax,
h_level,
h_uid,
h_materialId,
h_sml,
h_nnl,
267 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_y,
h_vx,
h_vy,
h_ax,
h_ay,
h_level,
h_uid,
h_materialId,
269 ParticlesNS::Kernel::Launch::set(
d_particles,
d_numParticles,
d_numNodes,
d_mass,
d_x,
d_y,
d_vx,
d_vy,
d_ax,
d_ay,
270 d_level,
d_uid,
d_materialId,
d_sml,
d_nnl,
d_noi,
d_e,
d_dedt,
d_cs,
d_rho,
d_p);
272 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_y,
h_z,
h_vx,
h_vy,
h_vz,
h_ax,
h_ay,
h_az,
273 h_level,
h_uid,
h_materialId,
h_sml,
h_nnl,
h_noi,
h_e,
h_dedt,
h_cs,
h_rho,
h_p);
274 ParticlesNS::Kernel::Launch::set(
d_particles,
d_numParticles,
d_numNodes,
d_mass,
d_x,
d_y,
d_z,
d_vx,
d_vy,
d_vz,
303#if VARIABLE_SML || INTEGRATE_SML
305 ParticlesNS::Kernel::Launch::setVariableSML(
d_particles, d_dsmldt);
309 ParticlesNS::Kernel::Launch::setSMLCorrection(
d_particles, d_sml_omega);
313 ParticlesNS::Kernel::Launch::setNavierStokes(
d_particles, d_Tshear, d_eta);
317 ParticlesNS::Kernel::Launch::setSolid(
d_particles, d_S, d_dSdt, d_localStrain);
319#if SOLID || NAVIER_STOKES
321 ParticlesNS::Kernel::Launch::setSolidNavierStokes(
d_particles, d_sigma);
325 ParticlesNS::Kernel::Launch::setArtificialStress(
d_particles, d_R);
328 h_particles->setPorosity(h_pold, h_alpha_jutzi, h_alpha_jutzi_old, h_dalphadt, h_dalphadp, h_dp, h_dalphadrho, h_f,
329 h_delpdelrho, h_delpdele, h_cs_old, h_alpha_epspor, h_dalpha_epspordt, h_epsilon_v,
331 ParticlesNS::Kernel::Launch::setPorosity(
d_particles, d_pold, d_alpha_jutzi, d_alpha_jutzi_old, d_dalphadt,
332 d_dalphadp, d_dp, d_dalphadrho, d_f, d_delpdelrho, d_delpdele, d_cs_old,
333 d_alpha_epspor, d_dalpha_epspordt, d_epsilon_v, d_depsilon_vdt);
336 h_particles->setZeroConsistency(h_shepardCorrection);
337 ParticlesNS::Kernel::Launch::setZeroConsistency(
d_particles, d_shepardCorrection);
339#if LINEAR_CONSISTENCY
340 h_particles->setLinearConsistency(h_tensorialCorrectionMatrix);
341 ParticlesNS::Kernel::Launch::setLinearConsistency(
d_particles, d_tensorialCorrectionMatrix);
344 h_particles->setFragmentation(h_d, h_damage_total, h_dddt, h_numFlaws, h_maxNumFlaws,
345 h_numActiveFlaws, h_flaws);
346 ParticlesNS::Kernel::Launch::setFragmentation(
d_particles, d_d, d_damage_total, d_dddt, d_numFlaws, d_maxNumFlaws,
347 d_numActiveFlaws, d_flaws);
349 h_particles->setPalphaPorosity(h_damage_porjutzi, h_ddamage_porjutzidt);
350 ParticlesNS::Kernel::Launch::setPalphaPorosity(
d_particles, d_damage_porjutzi, d_ddamage_porjutzidt);
357 ParticlesNS::Kernel::Launch::setDivCurl(
d_particles, d_divv, d_curlv);
443#if VARIABLE_SML || INTEGRATE_SML
448 delete [] h_sml_omega;
462 delete [] h_localStrain;
465#if SOLID || NAVIER_STOKES
476 delete [] h_alpha_jutzi;
478 delete [] h_alpha_jutzi_old;
480 delete [] h_dalphadt;
482 delete [] h_dalphadp;
486 delete [] h_dalphadrho;
490 delete [] h_delpdelrho;
492 delete [] h_delpdele;
496 delete [] h_alpha_epspor;
498 delete [] h_dalpha_epspordt;
500 delete [] h_epsilon_v;
502 delete [] h_depsilon_vdt;
506 delete [] h_shepardCorrection;
509#if LINEAR_CONSISTENCY
510 delete [] h_tensorialCorrectionMatrix;
516 delete [] h_damage_total;
520 delete [] h_numFlaws;
522 delete [] h_maxNumFlaws;
524 delete [] h_numActiveFlaws;
529 delete [] h_damage_porjutzi;
531 delete [] h_ddamage_porjutzidt;
625 printf(
"Entry is not available!\n");
649 printf(
"Entry is not available!\n");
655 printf(
"Location is not available!\n");
663 d_x = integratedParticleHandler->
d_x;
664 d_vx = integratedParticleHandler->
d_vx;
665 d_ax = integratedParticleHandler->
d_ax;
667 d_y = integratedParticleHandler->
d_y;
668 d_vy = integratedParticleHandler->
d_vy;
669 d_ay = integratedParticleHandler->
d_ay;
671 d_z = integratedParticleHandler->
d_z;
672 d_vz = integratedParticleHandler->
d_vz;
673 d_az = integratedParticleHandler->
d_az;
680 d_e = integratedParticleHandler->
d_e;
682 d_p = integratedParticleHandler->
d_p;
683 d_cs = integratedParticleHandler->
d_cs;
690#if VARIABLE_SML || INTEGRATE_SML
691 d_dsmldt = integratedParticleHandler->d_dsmldt;
697 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_vx,
h_ax,
h_level,
h_uid,
h_materialId,
h_sml,
h_nnl,
702 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_y,
h_vx,
h_vy,
h_ax,
h_ay,
h_level,
h_uid,
h_materialId,
704 ParticlesNS::Kernel::Launch::set(
d_particles,
d_numParticles,
d_numNodes,
d_mass,
d_x,
d_y,
d_vx,
d_vy,
d_ax,
d_ay,
705 d_level,
d_uid,
d_materialId,
d_sml,
d_nnl,
d_noi,
d_e,
d_dedt,
d_cs,
d_rho,
d_p);
707 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_y,
h_z,
h_vx,
h_vy,
h_vz,
h_ax,
h_ay,
h_az,
708 h_level,
h_uid,
h_materialId,
h_sml,
h_nnl,
h_noi,
h_e,
h_dedt,
h_cs,
h_rho,
h_p);
712#if VARIABLE_SML || INTEGRATE_SML
716 ParticlesNS::Kernel::Launch::set(
d_particles,
d_numParticles,
d_numNodes,
d_mass,
d_x,
d_y,
d_z,
d_vx,
d_vy,
d_vz,
720#if VARIABLE_SML || INTEGRATE_SML
721 ParticlesNS::Kernel::Launch::setVariableSML(
d_particles, d_dsmldt);
758#if VARIABLE_SML || INTEGRATE_SML
759 d_dsmldt = _d_dsmldt;
764 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_vx,
h_ax,
h_level,
h_uid,
h_materialId,
h_sml,
h_nnl,
769 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_y,
h_vx,
h_vy,
h_ax,
h_ay,
h_level,
h_uid,
h_materialId,
771 ParticlesNS::Kernel::Launch::set(
d_particles,
d_numParticles,
d_numNodes,
d_mass,
d_x,
d_y,
d_vx,
d_vy,
d_ax,
d_ay,
772 d_level,
d_uid,
d_materialId,
d_sml,
d_nnl,
d_noi,
d_e,
d_dedt,
d_cs,
d_rho,
d_p);
774 h_particles->
set(&
numParticles, &
numNodes,
h_mass,
h_x,
h_y,
h_z,
h_vx,
h_vy,
h_vz,
h_ax,
h_ay,
h_az,
775 h_level,
h_uid,
h_materialId,
h_sml,
h_nnl,
h_noi,
h_e,
h_dedt,
h_cs,
h_rho,
h_p);
779#if VARIABLE_SML || INTEGRATE_SML
783 ParticlesNS::Kernel::Launch::set(
d_particles,
d_numParticles,
d_numNodes,
d_mass,
d_x,
d_y,
d_z,
d_vx,
d_vy,
d_vz,
787#if VARIABLE_SML || INTEGRATE_SML
788 ParticlesNS::Kernel::Launch::setVariableSML(
d_particles, d_dsmldt);
798 if (includePseudoParticles) {
824 if (includePseudoParticles) {
875 copyMass(target, includePseudoParticles);
930#if VARIABLE_SML || INTEGRATE_SML
953#if VARIABLE_SML || INTEGRATE_SML
989#if VARIABLE_SML || INTEGRATE_SML
~IntegratedParticleHandler()
IntegratedParticles * d_integratedParticles
device instance of IntegratedParticles class
real * d_vz
device time derivative of particle's z position
real * d_vy
device time derivative of particle's y position
idInteger * d_uid
device unique identifier
real * d_vx
device time derivative of particle's x position
real * d_az
device time derivative of particle's z velocity
real * d_ay
device time derivative of particle's y velocity
integer numParticles
(host) number of particles
real * d_ax
device time derivative of particle's x velocity
IntegratedParticleHandler(integer numParticles, integer numNodes)
integer numNodes
(host) number of nodes
integer * d_materialId
device material identifier
real * d_muijmax
device max(mu_ij)
integer * h_noi
host number of interactions
integer * d_numNodes
device number of nodes
real * h_az
host z acceleration
real * h_ax
host x acceleration
real * d_dedt
device time derivative of internal energy
real * h_e
host internal energy
real * d_z
device z position
integer * d_nnl
device near(est) neighbor list
real * d_ay
device y acceleration
real * d_mass
device mass array
real * h_drhodt
host time derivative of density
void copyMass(To::Target target=To::device, bool includePseudoParticles=false)
real * h_vx
host x velocity
real * h_y
host y position
T *& getEntry(Entry::Name entry, Execution::Location location=Execution::device)
integer * d_numParticles
device number of particles
real * d_az
device z acceleration
void copyDistribution(To::Target target=To::device, bool velocity=true, bool acceleration=true, bool includePseudoParticles=false)
real * h_dedt
host time derivative of internal energy
real * d_e
device internal energy
integer numNodes
(host) number of nodes
real * d_vx
device x velocity
Particles * d_particles
device instance of particles class
Particles * h_particles
host instance of particles class
void copyMatId(To::Target target=To::device)
real * h_vz
host z velocity
void copySML(To::Target target=To::device)
void copyUid(To::Target target=To::device)
integer * h_nnl
host near(est) neighbor list
void copyPosition(To::Target target=To::device, bool includePseudoParticles=false)
idInteger * d_uid
device unique identifier
integer * h_materialId
host material identifier
real * h_x
host x position
real * d_ax
device x acceleration
integer numParticles
(host) number of particles
real * d_y
device y position
real * d_sml
device smoothing length
void setPointer(IntegratedParticleHandler *integratedParticleHandler)
real * d_vy
device y velocity
real * h_sml
host smoothing length
real * h_cs
host speed of sound
real * h_z
host z position
real * d_cs
device speed of sound
real * h_ay
host y acceleration
real * d_x
device x position
void copyVelocity(To::Target target=To::device, bool includePseudoParticles=false)
real * d_drhodt
device time derivative of density
void copyAcceleration(To::Target target=To::device, bool includePseudoParticles=false)
void copySPH(To::Target target)
ParticleHandler(integer numParticles, integer numNodes)
real * h_muijmax
host max(mu_ij)
integer * d_noi
device number of interaction
real * d_p
device pressure
real * h_vy
host y velocity
idInteger * h_uid
host unique identifier
real * d_vz
device z velocity
real * d_rho
device density
Particle(s) class based on SoA (Structur of Arrays).
CUDA_CALLABLE_MEMBER void set(integer *numParticles, integer *numNodes, real *mass, real *x, real *y, real *z, real *vx, real *vy, real *vz, real *ax, real *ay, real *az, integer *level, idInteger *uid, integer *materialId, real *sml, integer *nnl, integer *noi, real *e, real *dedt, real *cs, real *rho, real *p)
Setter (DIM = 3) assigning variables to pointer members.
CUDA_CALLABLE_MEMBER void setLeapfrog(real *ax_old, real *ay_old, real *az_old, real *g_ax_old, real *g_ay_old, real *g_az_old)
CUDA_CALLABLE_MEMBER void setGravity(real *g_ax, real *g_ay, real *g_az)
Constructor (DIM = 3) assigning gravitational acceleration to member variables.
CUDA_CALLABLE_MEMBER void setNodeType(integer *nodeType)
Setter for node type.
CUDA_CALLABLE_MEMBER void setArtificialViscosity(real *muijmax)
Setter for artificial viscosity (entry).
CUDA_CALLABLE_MEMBER void setIntegrateDensity(real *drhodt)
Setter in dependence of INTEGRATE_DENSITY.
CUDA_CALLABLE_MEMBER void setU(real *u)
Setter for energy.
void setSML(IntegratedParticles *integratedParticles, real *sml)
void setIntegrateDensity(IntegratedParticles *integratedParticles, real *drhodt)
void set(IntegratedParticles *integratedParticles, idInteger *uid, real *rho, real *e, real *dedt, real *p, real *cs, real *x, real *y, real *z, real *vx, real *vy, real *vz, real *ax, real *ay, real *az)
void setU(Particles *particles, real *u)
void setIntegrateDensity(Particles *particles, real *drhodt)
void setGravity(Particles *particles, real *g_ax, real *g_ay, real *g_az)
void setLeapfrog(Particles *particles, real *ax_old, real *ay_old, real *az_old, real *g_ax_old, real *g_ay_old, real *g_az_old)
void set(Particles *particles, integer *numParticles, integer *numNodes, real *mass, real *x, real *y, real *z, real *vx, real *vy, real *vz, real *ax, real *ay, real *az, integer *level, idInteger *uid, integer *materialId, real *sml, integer *nnl, integer *noi, real *e, real *dedt, real *cs, real *rho, real *p)
void setNodeType(Particles *particles, integer *nodeType)
void setArtificialViscosity(Particles *particles, real *muijmax)
const char *const numParticles
void copy(T *h_var, T *d_var, std::size_t count=1, To::Target copyTo=To::device)
Copy between host and device and vice-versa.
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.
#define MAX_NUM_INTERACTIONS
#define DIM
Dimension of the problem.