GADGET-4
|
#include <simulation.h>
Inherits pinning, and test_io_bandwidth.
Public Member Functions | |
sim (MPI_Comm comm) | |
void | rearrange_lightcone (int argc, char **argv) |
void | rearrange_snapshot (int argc, char **argv) |
template<typename partset > | |
void | rearrange_generic (partset &Tp, int conenr, int firstnr, int lastnr) |
template<typename partset > | |
void | rearrange_fill_treetable (partset &Tp) |
template<typename partset > | |
void | rearrange_read (partset &Tp, int num, int conenr) |
template<typename partset > | |
void | rearrange_write (partset &Tp, int num, int conenr) |
void | hello (void) |
void | endrun (void) |
This function aborts the simulations. More... | |
void | begrun1 (const char *parameterFile) |
This function performs the initial set-up of the simulation. More... | |
void | begrun2 (void) |
This function does late setup, after the IC file has been loaded but before run() is called. More... | |
void | init (int RestartSnapNum) |
Prepares the loaded initial conditions for the run. More... | |
void | run (void) |
void | set_units (void) |
Computes conversion factors between internal code units and the cgs-system. More... | |
void | create_snapshot_if_desired (void) |
Check if a snapshot should be saved. More... | |
void | healthtest (void) |
void | mpi_report_comittable_memory (void) |
long long | report_comittable_memory (long long *MemTotal, long long *Committed_AS, long long *SwapTotal, long long *SwapFree) |
long long | report_free_size_in_tmpfs (void) |
void | do_gravity_step_second_half (void) |
performs the second gravity half step kick operator More... | |
void | find_timesteps_and_do_gravity_step_first_half (void) |
performs the first half step kick operator for the gravity More... | |
void | do_hydro_step_first_half (void) |
void | do_hydro_step_second_half (void) |
void | find_global_timesteps (void) |
void | find_hydro_timesteps (void) |
void | gravity (int timebin) |
main driver routine of gravity tree/fmm force calculation More... | |
void | gravity_long_range_force (void) |
void | gravity_comoving_factors (int timebin) |
void | gravity_pm (int timebin) |
void | gravity_set_oldacc (int timebin) |
void | hydro_force (int step_indicator) |
void | compute_grav_accelerations (int timebin) |
This routine computes the gravitational accelerations for all active particles. More... | |
![]() | |
void | get_core_set (void) |
void | detect_topology (void) |
void | pin_to_core_set (setcomm *sc) |
void | report_pinning (setcomm *sc) |
![]() | |
test_io_bandwidth (MPI_Comm comm) | |
void | measure_io_bandwidth (void) |
![]() | |
size_t | my_fwrite (const void *ptr, size_t size, size_t nmemb, FILE *stream) |
A wrapper for the fwrite() function. More... | |
size_t | my_fread (void *ptr, size_t size, size_t nmemb, FILE *stream) |
A wrapper for the fread() function. More... | |
void | reset_io_byte_count (void) |
long long | get_io_byte_count (void) |
![]() | |
setcomm (MPI_Comm Comm) | |
setcomm (const char *str) | |
void | initcomm (MPI_Comm Comm) |
void | mpi_printf (const char *fmt,...) |
void | determine_compute_nodes (void) |
Public Attributes | |
simparticles | Sp {Communicator} |
domain< simparticles > | Domain {Communicator, &Sp} |
gwalk | GravTree |
sph | NgbTree |
![]() | |
long long | byte_count = 0 |
![]() | |
MPI_Comm | Communicator |
int | NTask |
int | ThisTask |
int | PTask |
int | ThisNode |
int | NumNodes = 0 |
int | TasksInThisNode |
int | RankInThisNode |
int | MinTasksPerNode |
int | MaxTasksPerNode |
long long | MemoryOnNode |
long long | SharedMemoryOnNode |
Definition at line 49 of file simulation.h.
|
inline |
Definition at line 52 of file simulation.h.
void begrun1 | ( | const char * | parameterFile | ) |
This function performs the initial set-up of the simulation.
First, the parameter file is read by read_parameter_file(), then routines for setting units, etc are called. This function only does the setup necessary to load the IC file. After the IC file has been loaded and prepared by init(), setup continues with begrun2(). This splitting is done so that we can return cleanly from operations that don't actually start the simulation (converting snapshots, making projected images, etc.)
void begrun2 | ( | void | ) |
void compute_grav_accelerations | ( | int | timebin | ) |
This routine computes the gravitational accelerations for all active particles.
If the particle mesh is used and the current time step requires a PM force computation, new long range forces are computed by long_range_force(). Then the shortrange tree forces are computed by gravity(). The force tree is rebuild every time step.
Definition at line 41 of file gravity.cc.
void create_snapshot_if_desired | ( | void | ) |
Check if a snapshot should be saved.
This function checks whether a snapshot file or other kinds of output files, such as a projection, should be saved at the current time-step. If that is the case, the appropriate functions to produce the desired file are called and the parameter controlling the output are updated accordingly.
void do_gravity_step_second_half | ( | void | ) |
performs the second gravity half step kick operator
This function applies a half step kick similar to do_gravity_step_first_half(). First the short range kick due to the tree force is added. If we are on a PM step the kick due to the particle mesh's long range gravity is applied too. In both cases the momentum and energy for Sph particles is updated.
void endrun | ( | void | ) |
This function aborts the simulations.
This method has to be called by all processes. It should be used only if the simulation ends without a errors or a an error message is already printed. Otherwise Terminate() should be used instead.
void find_global_timesteps | ( | void | ) |
void find_hydro_timesteps | ( | void | ) |
This function advances the system in momentum space, i.e. it does apply the 'kick' operation after the forces have been computed. Additionally, it assigns new timesteps to particles. At start-up, a half-timestep is carried out, as well as at the end of the simulation. In between, the half-step kick that ends the previous timestep and the half-step kick for the new timestep are combined into one operation.
Definition at line 39 of file timestep.cc.
void find_timesteps_and_do_gravity_step_first_half | ( | void | ) |
performs the first half step kick operator for the gravity
This function applies a half step kick similar to do_gravity_step_second_half(). If we are on a PM step the kick due to the particle mesh's long range gravity is applied first. Afterwards the short range kick due to the tree force is added.
void gravity | ( | int | timebin | ) |
main driver routine of gravity tree/fmm force calculation
This routine handles the whole tree force calculation. First it builds a new force tree force_treebuild() every timestep. This tree is then used to calculate a new tree force for every active particle ( gravity_tree() ). The passed variable 'timebin' is only used to inform about the largest timebin of the particles in the list of active particles.
The tree will be constructed for the NActiveGravity particles listed in the array ActiveActiveGravityParticles[]
Definition at line 171 of file gravity.cc.
void gravity_comoving_factors | ( | int | timebin | ) |
Definition at line 277 of file gravity.cc.
void gravity_long_range_force | ( | void | ) |
void gravity_pm | ( | int | timebin | ) |
void gravity_set_oldacc | ( | int | timebin | ) |
Definition at line 248 of file gravity.cc.
void healthtest | ( | void | ) |
Definition at line 36 of file healthtest.cc.
void hello | ( | void | ) |
void hydro_force | ( | int | step_indicator | ) |
void init | ( | int | RestartSnapNum | ) |
Prepares the loaded initial conditions for the run.
It is only called if RestartFlag != RST_RESUME. Various counters and variables are initialized. Entries of the particle data structures not read from initial conditions are initialized or converted and a initial domain decomposition is performed. If SPH particles are present, the initial SPH smoothing lengths are determined.
void rearrange_fill_treetable | ( | partset & | Tp | ) |
void rearrange_generic | ( | partset & | Tp, |
int | conenr, | ||
int | firstnr, | ||
int | lastnr | ||
) |
void rearrange_lightcone | ( | int | argc, |
char ** | argv | ||
) |
void rearrange_read | ( | partset & | Tp, |
int | num, | ||
int | conenr | ||
) |
void rearrange_snapshot | ( | int | argc, |
char ** | argv | ||
) |
void rearrange_write | ( | partset & | Tp, |
int | num, | ||
int | conenr | ||
) |
long long report_comittable_memory | ( | long long * | MemTotal, |
long long * | Committed_AS, | ||
long long * | SwapTotal, | ||
long long * | SwapFree | ||
) |
void run | ( | void | ) |
Main driver routine for advancing the simulation forward in time. The loop terminates when the cpu-time limit is reached, when a ‘stop’ file is found in the output directory, or when the simulation ends because we arrived at TimeMax.
If the simulation is started from initial conditions, an initial domain decomposition is performed, the gravitational forces are computed and initial hydro forces are calculated.
void set_units | ( | void | ) |
domain<simparticles> Domain {Communicator, &Sp} |
Definition at line 58 of file simulation.h.
gwalk GravTree |
Definition at line 65 of file simulation.h.
sph NgbTree |
Definition at line 68 of file simulation.h.
simparticles Sp {Communicator} |
Definition at line 56 of file simulation.h.