1#ifndef MILUPHPC_PARAMETER_H
2#define MILUPHPC_PARAMETER_H
12#ifdef SINGLE_PRECISION
39#define power_two(x) (1 << (x))
40#define POW_DIM power_two(DIM)
46#define CUBIC_DOMAINS 1
55#define INTEGRATE_ENERGY 0
58#define INTEGRATE_DENSITY 0
61#define INTEGRATE_SML 0
70#define SML_CORRECTION 0
81#define SPH_EQU_VERSION 1
84#define ARTIFICIAL_VISCOSITY 1
85#define BALSARA_SWITCH 0
88#define AVERAGE_KERNELS 0
89#define DEAL_WITH_TOO_MANY_INTERACTIONS 0
90#define SHEPARD_CORRECTION 0
92#define NAVIER_STOKES 0
93#define ARTIFICIAL_STRESS 0
95#define ZERO_CONSISTENCY 0
96#define LINEAR_CONSISTENCY 0
97#define FRAGMENTATION 0
98#define PALPHA_POROSITY 0
100#define KLEY_VISCOSITY 0
102#define KEY_MAX ULONG_MAX
104#define DOMAIN_LIST_SIZE 512
106#define MAX_NUM_INTERACTIONS 180
107#define NUM_THREADS_LIMIT_TIME_STEP 256
108#define NUM_THREADS_CALC_CENTER_OF_MASS 256
111#define COURANT_FACT 0.4
113#define FORCES_FACT 0.2
116#define DBL_MAX dbl_max;
constexpr real G
Gravitational constant.
__device__ real max(real a, real b)
Maximum value out of two floating point values.
struct SimulationParameters SimulationParameters
EquationOfStates
implemented equation of states
@ EOS_TYPE_LOCALLY_ISOTHERMAL_GAS
ideal gas equation, set polytropic_gamma in material.cfg
@ EOS_TYPE_IDEAL_GAS
this is pure molecular hydrogen at 10 K
@ EOS_TYPE_ISOTHERMAL_GAS
polytropic EOS for gas, needs polytropic_K and polytropic_gamma in material.cfg file
@ EOS_TYPE_POLYTROPIC_GAS
Available space-filling curves.
Execution location (host/device).
@ predictor_corrector_euler
IntegratorSelection(Type t)
bool calculateAngularMomentum
bool loadBalancing
apply load balancing
std::string logDirectory
log file(s) directory
real theta
clumping parameter/
real maxTimeStep
max (allowed) time step
real removeParticlesDimension
int smoothingKernelSelection
int loadBalancingInterval
apply load balancing each x interval/simulation step
real timeEnd
end time of simulation
std::string materialConfigFile
input file containing material configurations/parameters
std::string directory
output file(s) directory
int outputRank
specify a (MPI) rank for console logging (default: -1 logging all ranks)
bool particlesSent2H5
log particles sent to HDF5 file
bool calculateCenterOfMass
bool timeKernels
time the CUDA kernels
bool performanceLog
log performance to HDF5 file
std::string inputFile
input file containing initial particle distribution
int numOutputFiles
number of output files
int verbosity
verbosity level
int sphFixedRadiusNNVersion
int integratorSelection
integrator selection
int sfcSelection
space-filling curve selection
int removeParticlesCriterion
real particleMemoryContingent
(SPH) available smoothing kernels.
Specify target: device or host.