ASCOT5
|
Functions to execute main program externally. More...
Go to the source code of this file.
Functions | |
int | prepare_markers (sim_data *sim, int n_tot, input_particle *pin, particle_state **pout, int *nprts) |
Prepare markers for offload. | |
int | write_rungroup (sim_data *sim, particle_state *ps, int n_tot, char *qid) |
Create and store run group and marker inistate. | |
int | offload_and_simulate (sim_data *sim, int n_tot, int n_proc, particle_state *pin, int *n_gather, particle_state **pout) |
Offload data to target, carry out the simulation, and return to host. | |
int | write_output (sim_data *sim, particle_state *ps_gathered, int n_tot) |
Store simulation output data. | |
void | print_marker_summary (particle_state *ps, int n_tot) |
Writes a summary of what happened to the markers during simulation. | |
Functions to execute main program externally.
The main progam for ascot5 is in ascot5_main.c. This header file declares the functions needed to carry out the simulation, so that hey can be used by an external program (i.e. via the python interface).
Definition in file ascot5_main.h.
int prepare_markers | ( | sim_data * | sim, |
int | n_tot, | ||
input_particle * | pin, | ||
particle_state ** | pout, | ||
int * | n_proc ) |
Prepare markers for offload.
This function initializes the marker states and allocates memory for the particle states. The input markers are read from the HDF5 file and stored in the input_particle_states array. The initial marker states are then calculated and stored in the particle_states array.
When MPI is used, the marker states are initialized only for those markers that are used in this MPI process.
sim | simulation data struct |
n_tot | total number of markers |
pin | pointer to marker input array which is deallocated here |
pout | pointer to marker state array created here |
n_proc | pointer to variable for number of markers for this process |
Definition at line 246 of file ascot5_main.c.
int write_rungroup | ( | sim_data * | sim, |
particle_state * | ps, | ||
int | n_tot, | ||
char * | qid ) |
Create and store run group and marker inistate.
sim | simulation data struct |
ps | marker state array for this process |
n_tot | total number of markers in this simulation |
qid | unique identifier for this run group |
Definition at line 289 of file ascot5_main.c.
int offload_and_simulate | ( | sim_data * | sim, |
int | n_tot, | ||
int | n_proc, | ||
particle_state * | pin, | ||
int * | n_gather, | ||
particle_state ** | pout ) |
Offload data to target, carry out the simulation, and return to host.
sim | simulation offload data struct |
n_tot | total number of markers |
n_proc | number of markers in this process |
pin | marker state array for this process (deallocated here) |
offload_data | packed offload data struct |
offload_array | packed offload array containing the input data |
int_offload_array | packed offload integer array containg the input data |
n_gather | pointer for storing the number of markers in pout (either n_tot or n_proc) |
pout | pointer to array containing all endstates in the simulation |
diag_offload_array | array to store output data |
Definition at line 349 of file ascot5_main.c.
int write_output | ( | sim_data * | sim, |
particle_state * | ps, | ||
int | n_tot ) |
Store simulation output data.
sim | simulation data |
ps | marker endstate array to be written |
n_tot | number of markers |
diag_offload_array | diagnostics offload data array |
Definition at line 383 of file ascot5_main.c.
void print_marker_summary | ( | particle_state * | ps, |
int | n_tot ) |
Writes a summary of what happened to the markers during simulation.
This function writes a summary of marker end conditions and possible simulation-time errors. Since simulation can have billions and billions of markers, we only show how many markers had specific error or end condition.
End conditions and errors are printed in human-readable format.
This function is called by the root MPI process only.
ps | array of marker states after simulation has finished |
n_tot | number of markers in the array |
Definition at line 609 of file ascot5_main.c.