Input (or configuration) file is where user stores all the relevant simulation related parameters and constants, be it technical (i.e., number of cores, max number of particles, etc), domain specific (boundary types, number of grid cells, etc) or physical and problem specific (sigma
, c_omp
, etc).
The most complete example of the input file containing all the possible necessary settings can be found in the
inputs/full.cfg
file with all the relevant descriptions. When starting to work on a new simulation it’s a good idea to inherit input file from that particular one. This file also contains the most up to date description of all the relevant input parameters.
The user file is specified as a command line argument using -i
or --input
flag when running the simulation:
mpiexec -np 8 ./tristan-mp2d -i myinput
Following is an example of such an input file:
<node_configuration>
sizex = 2 # number of cpus in x direction
sizey = 2 # number of cpus in y direction
sizez = 1 # number of cpus in z direction
<time>
last = 1000 # last timestep
<grid>
mx0 = 64 # number of actual grid points in the x direction
my0 = 64 # number of actual grid points in the y direction
mz0 = 1 # number of actual grid points in the z direction
boundary_x = 1 # boundary in x: 1 = periodic, 0 = outflow, 2 = radial outflow
boundary_y = 1 # boundary in y: 1 = periodic, 0 = outflow, 2 = radial outflow
boundary_z = 1 # boundary in z: 1 = periodic, 0 = outflow, 2 = radial outflow
# ... if either is "2" all will be assigned to "2"
# ....
<plasma>
ppc0 = 10
sigma = 4
c_omp = 10
<particles>
nspec = 2
maxptl1 = 1e6 # max number of particles per core
m1 = 1
ch1 = -1
deposit1 = 1 # [defaults to TRUE if charge != 0]
move1 = 1 # [defaults to TRUE]
cool1 = 1 # turn ON/OFF cooling for this species
output1 = 0 # save particles to `prtl` output or not [defaults to TRUE]
maxptl2 = 1e6 # max number of particles per core
m2 = 1
ch2 = 1
deposit2 = 1 # [defaults to TRUE if charge != 0]
move2 = 1 # [defaults to TRUE]
cool2 = 0 # turn ON/OFF cooling for this species
<problem>
myvariable = 0.1
Each of those bracketed sections (e.g., <particles>
) are called blocks. When trying to read a variable from the input from anywhere in the code one can simply do:
call getInput('problem', 'myvariable', myvar)
Notice that you first specify the block (in this case the problem
) and then the variable name (myvariable
). The value read from the input will be stored in myvar
variable. Since getInput
subroutine is overloaded myvar
can have any type (integer
, real
, logical
), the routine will do the necessary conversion itself.
You can also specify the default value in case the variable isn't found in the input:
call getInput('problem', 'myvariable', myvar, 0.5)
If
myvar
is boolean (i.e. has type oflogical
in Fortran) it will automatically convert1
and0
from the input file to.true.
and.false.
.