title: Write a Namelist
Following here is a brief description of the new input.nml
file required for the simulation parameters definition, through an example.
&GRID
nx = 7168,
ny = 3584,
nz = 1,
ny_targ = 3500,
k0 = 100.0,
yx_rat = 2.0,
zx_rat = 2.0,
/
nx
is the number of grid points in the x direction- for PWFA simulations, it is required that this number contains the number of cpus of the y and z domains defined by
nprocx
,nprocy
andnprocz
in order to be sure that FFTs are working as expected
- for PWFA simulations, it is required that this number contains the number of cpus of the y and z domains defined by
ny
is the number of points in the y direction- in order to be sure that the simulation is working as expected, it is better to always use a number that contains
nprocx
,nprocy
andnprocz
- in order to be sure that the simulation is working as expected, it is better to always use a number that contains
nz
is the number of points in the z direction; for a 2D simulaton, usenz = 1
- in order to be sure that the 3D simulation is working as expected, it is better to always use here a number that contains the number of cpu assigned to split the z domain (
mpi_ntot/pey
)
- in order to be sure that the 3D simulation is working as expected, it is better to always use here a number that contains the number of cpu assigned to split the z domain (
ny_targ
is the transverse size of the target, expressed in number of grid cell filled with particles (if the simulation is a 3D one, the target is a square in the xy plane)k0
defines the resolution, being the number of points per μm along x, so that Δx = 1/k0 [μm]; please remember to set a value small enough to solve the skin depthyx_rat
is the ratio between the resolution along x and y: Δy = yx_rat/k0 [μm].zx_rat
is the ratio between the resolution along x and z: Δz = zx_rat/k0 [μm]; the resolution along z is the same as for y if this parameter is not defined.
With those parameters, the full box size (in μm) is: Lx = nx / k0
, Ly = yx_rat * ny / k0
, Lz = zx_rat * nz / k0
&SIMULATION
LPf_ord = 2,
der_ord = 2,
str_flag = 0,
iform = 0,
model_id = 1,
dmodel_id = 3,
ibx = 0,
iby = 0,
ibz = 0,
ibeam = 1
/
Lpf_ord
is the integration scheme order. Lpf_ord=2 for standard leap-frog, Lpf_ord_ord=4 for RK4 (now disabled)der_ord
is the order of the finite difference scheme. der_ord=2 or 3 for Lpf_ord=2, der_ord=4 for RK4der_ord=2
→ Standard Yee schemeder_ord=3
assures optimized wave (Laser) propagation in under dense plasmas using modified longitudinal derivative.
str_flag
has three possible different values:0
for uniform grid1
to enable stretching along transverse axes. The number of stretched cells isny/6
andnz/6
, starting from both the boundaries.2
to enable stretching along transverse axes. The number of stretched cells isny/4
andnz/4
, starting from both the boundaries. This stretching is stronger.
iform
has two possible different values:0
: Esirkepov's scheme for charge conservation (particle by particle, to be preferred)1
: Esirkepov's scheme for charge conservation (inverted on grid along x, not allowed for MPI decomposition along the x coordinate) (fallback oniform=0
)2
: no charge preserving (better energy conservation assured)
model_id
has five possible different values1
laser is p-polarized2
laser is s-polarized3
laser is circularly polarized4
laser is described by its envelope approximation model
dmodel_id
has five possible different values1
uniform - the simulation is done usingnsp
species (electrons, Z_1,Z_2,Z_3) all distributed along the target x-profile2
empty model3
preplasma - the simulation is tested in this configuration: threensp=3
species (electrons, Z_1, Z_2), with a preplasma made of Z_1 + e, a bulk made of Z_1 + e and a contaminant layer made of Z_2 + e4
foam - the simulation is tested in this configuration: threensp=3
species (electrons, Z_1, Z_2), with a foam made of Z_2 + e, a bulk made of Z_1 + e and a contaminant layer made of Z_2 + e5
nanowires target with size parameters lpy(1),lpy(2) and species (e+Z_1) + a uniform bulk (e+Z_2)6
nanotubes target with size parameters lpy(1),lpy(2) and species (e+Z_1) + a uniform bulk (e+Z_2)
ibx
,iby
,ibz
are the boundary conditions:0
open1
reflective2
periodic
ibeam
:0
1
2
For Envelope-fluid LWFA model (model_id = 4). Code solves Euler equations for plasma density with the laser described as an envelope.
&TARGET_DESCRIPTION
nsp = 3,
nsb = 0,
ion_min(1) = 4,
ion_max(1) = 11,
atomic_number(1) = 13,
mass_number(1) = 26.98,
ion_min(2) = 1,
ion_max(2) = 1,
atomic_number(2) = 1,
mass_number(2) = 1.0,
ion_min(3) = 1,
ion_max(3) = 1,
atomic_number(3) = 1,
mass_number(3) = 1.0,
ionz_model = 0,
ionz_lev = 0,
t0_pl(1) = 0.0003,
t0_pl(2) = 0.0,
t0_pl(3) = 0.0,
t0_pl(4) = 0.0,
np_per_xc(1) = 12,
np_per_xc(2) = 4,
np_per_xc(3) = 4,
np_per_xc(4) = 4,
np_per_xc(5) = 4,
np_per_xc(6) = 4,
np_per_yc(1) = 9,
np_per_yc(2) = 3,
np_per_yc(3) = 4,
np_per_yc(4) = 4,
np_per_yc(5) = 4,
np_per_yc(6) = 4,
np_per_zc(1) = 1,
concentration(1) = 0.5,
concentration(2) = 0.5,
concentration(3) = 0,
concentration(4) = 0,
concentration(5) = 0,
concentration(6) = 0,
lpx(1) = 0.0,
lpx(2) = 0.0,
lpx(3) = 2.0,
lpx(4) = 0.0,
lpx(5) = 0.08,
lpx(6) = 0.0,
lpx(7) = 0.01,
lpy(1) = 0.0,
lpy(2) = 0.0,
n0_ref = 100.0,
np1 = 1.0,
np2 = 10.0,
r_c = 0.0,
/
nsp
is the number of species (be careful and coherent withdmodel_id
)nsb
atomic_number(i)
are the atomic number (Z) that define each element speciesion_min(i)
are the initial ionization status of the element speciesion_max(i)
are the maximum ionization status of the element speciesionz_lev
: if set to 0, we disable ionization; if 1, only one electron can be extracted per ion, if accessible, per timestep; if 2, it ionizes all the accessible levels in a single timestepionz_model
describes the various ionization models:- 1 (pure ADK as in chen et al (2013), the best one for wake sims)
- 2 (ADK averaged over cycles, as in chen et al (2013),
W_AC=<W_DC>
, best for envelope simulations) - 3 (
W_AC+BSI
, added barrier suppression ionization) - 4 (Minimum between ADK and BSI ionization values. Here the ADK value is computed averaging on
m
, the magnetic quantum number of the ionized electrons as in Lawrence-Douglas, 2013)
mass_number(i)
are the mass number (A) that define the exact isotope of a givenatomic_number(i)
. Here following you can find the only elements known by ALaDyn
Hydrogen (atomic_number = 1) - mass_number = 1.0
Helium (atomic_number = 2) - mass_number = 4.0
Lithium (atomic_number = 3) - mass_number = 6.0
Carbon (atomic_number = 6) - mass_number = 12.0
Nitrogen (atomic_number = 7) - mass_number = 14.0
Oxygen (atomic_number = 8) - mass_number = 16.0
Neon (atomic_number = 10) - mass_number = 20.0
Aluminium (atomic_number = 13) - mass_number = 26.98
Silicon (atomic_number = 14) - mass_number = 28.09
Argon (atomic_number = 18) - mass_number = 39.948
Titanium (atomic_number = 22) - mass_number = 47.8
Nickel (atomic_number = 28) - mass_number = 58.7
Copper (atomic_number = 29) - mass_number = 63.54
t0_pl(i)
, withi
from 1 to 4, are the initial temperatures in MeV for the different speciesnp_per_xc(i)
Please note that ifnp_per_xc(1) =0
, it just means to ignore the plasma and simply do a laser propagation simulation.. When in fluid model, particles can be activated anyway to obtain a Hybrid solver (particle + fluid).dmodel_id=1
: i=1 indicates the number of electrons, i=2 the number of macroparticles of Z_1 species, i=3 the number of macroparticles of Z_2 species and i=4 the number of macroparticles of Z_3 species.dmodel_id=3,4
: i=1,2 are the number of electrons and ions per cell along x/y in the bulk, i=3,4 refer to the front layer and i=5,6 to the contaminants.
np_per_yc(i)
: the same asnp_per_xc
, this describes the number of particles per cell along y directions (valid also for z for 3D simulations ifnp_per_zc(i)
is not set)np_per_zc(i)
: the same asnp_per_xc
, this describes the number of particles per cell along z directionsconcentration(i)
: concentration of the i-th ion species. The sum of all the concentrations must be 1 to result in a consistent description.dmodel_id=1
lpx(1)
is the length [μm] of the upstream layer (foam or preplasma), having densityn1/nc
lpx(2)
is the length [μm] of the ramp (linear or exponential depending on themdl
) connecting the upstream layer with the central one (made with bulk particles)lpx(3)
is the length [μm] of the central layer (bulk), having densityn2/nc
lpx(4)
is the length [μm] of the ramp (linear), connecting the bulk with the contaminants (made with bulk particles)lpx(5)
is the length [μm] of the downstream layer (contaminants), having densityn3/nc
lpx(7)
is the offset [μm] between the end of the laser and the beginning of the target (if zero, the target starts right at the end of the laser pulse). In the gaussian case, the end of the pulse is defined as the center position + the FWHM. The offset is calculated before laser rotation, so mind the transverse size ifincid_angle ≠ 0
, in order to avoid laser initialization inside the target.n0_ref
is the density in the central layer (bulk)- LWFA case: density is in units of critical density
- If
nsp=1
,n_over_nc
is the plasma density - If
nsp>1
,n_over_nc
is the density of the neutral gas, e.g. the gas jet density before the plasma formation. If the background atoms are already ionized, the initial plasma density is computed accordingly.
- If
np1
is the density in the upstream layer (foam/preplasma)np2
is the density in the downstream layer (contaminants)
dmodel_id=4
(Ramps are allcos^2
)lpx(1)
is the length [μm] of the upramp to the plateaulpx(2)
is the length [μm] of the first plateau (plasma bulk) with densityn_over_nc
lpx(3)
is the length [μm] of the connecting ramp from the first plateau to the second onelpx(4)
is the length [μm] of the second plateau (plasma bulk) with densitynp1*n_over_nc
lpx(5)
is the length [μm] of the connecting ramp from the second plateau to the third onelpx(6)
is the length [μm] of the third plateau (plasma bulk) with densitynp2*n_over_nc
lpx(7)
is the offset [μm] between the end of the laser and the beginning of the target (if zero, the target starts right at the end of the laser pulse). In the gaussian case, the end of the pulse is defined as the center position + the FWHM. The offset is calculated before laser rotation, so mind the transverse size ifincid_angle ≠ 0
, in order to avoid laser initialization inside the target.n0_ref
is the density of the first plateaunp1
is the density of the second plateaunp2
is the density of the third plateau
lpy(1)
defines the wire size [μm].lpy(2)
defines the distance [μm] between wires (interwire size).n0_ref
is the reference density in units ofn_0=1e18 cm^-3
. Code equations are normalized to that density.r_c
is the plasma channel depth ==>n/n_over_nc = 1 + w0_y^2*lambda_0^2/(r_c^2 *\pi ^2 *n_over_nc)(y^2+z^2)/w0_y^2
, wherew0_y
is the laser waist. Ifr_c
=w0_y
the channel is matched
&LASER
G_prof = .true.,
nb_laser = 1,
t0_lp = 16.5,
xc_lp = 16.5,
tau_fwhm = 33.0,
w0_y = 6.2,
a0 = 3.0,
incid_angle = 0.0,
lam0 = 0.8,
y0_cent = 0.0,
z0_cent = 0.0,
Enable_ionization(0) = .true.
lp_delay = 20.59,
lp_offset = 0,
t1_lp = 200.0,
tau1_fwhm = 24.74,
w1_y = 3.5,
a1 = 0.45,
lam1 = 0.4,
y1_cent = 0.0,
z1_cent = 0.0,
Enable_ionization(1) = .true.,
Symmetrization_pulse=.true.,
a_symm_rat = 1.0,
/
G_prof
logical flag: if true the pulse is temporally gaussian, if false it has acos^2
shapenb_laser
number of (identical) laser pulses injectedxc_lp
is the position (in μm) along x of the central point of the laser envelopet0_lp
is the distance (in μm) after which the laser is focused; so the focus is atxf = xc_lp + t0_lp
tau_fwhm
is the FWHM pulse duration (in fs)w0_y
is the transverse waist FWHM (in μm)a_0
is the laser adimensional parameter: a0=eA/(me c2) of all the pulses injectedincid_angle
Angle of incidence (degrees) of the laser pulse on the target.lam0
is the laser wavelength (in μm) of all the pulses injectedy0_cent(1:nb_laser)
is the array of the pulse center positions on they
axisz0_cent(1:nb_laser)
is the array of the pulse center positions on thez
axislp_delay(1:nb_laser)
is the array distance between the center of every injected laser pulselp_offset
is the distance between the center of the last injected pulse and the center of another different pulse injected (if different from 0)t1_lp
same ast0_lp
, but for the additional pulse injected withlp_offset/=0
tau1_fwhm
same astau_fwhm
, but for the additional pulse injected withlp_offset/=0
w1_y
same asw0_y
, but for the additional pulse injected withlp_offset/=0
a1
same asa0
, but for the additional pulse injected withlp_offset/=0
lam1
same aslam0
, but for the additional pulse injected withlp_offset/=0
y1_cent(1:nb_laser)
is the secondary pulse center positions on they
axisz1_cent(1:nb_laser)
is the secondary pulse center positions on thez
axisEnable_ionization(0)
logical flag: indicates if the main pulse ( i.e.a_0
) ionizes atomsEnable_ionization(1)
logical flag: indicates if the secondary pulse ( i.e.a_1
) ionizes atomsSymmetrization_pulse
logical flag: when ionization is enabled, new electrons possess a nonzero temperature also in the transverse axisa_symm_rat
is the pseudo-temperature that electrons acquire on the transverse axis, ifSymmetrization_pulse=.true.
. Formula issin(2.*pi*u)*a_symm_rat*Delta_a
&BEAM_INJECT
nb_1 = 5,
xc_1 = 30,
gam_1 = 300,
sxb_1 = 3,
syb_1 = 3,
epsy_1 = 0.2,
epsz_1 = 0.2,
dg_1 = 1,
charge_1 = 1,
t_inject = 0,
/
nb_1
is the number of particles in the injected bunch in units of10^5
xc_1
is the longitudinal position of the bunch centergam_1
is the bunch mean gamma factorsxb_1
is the bunch longitudinal r.m.s length in micronssyb_1
is the bunch transverse r.m.s length in microns (valid also for z direction in 3D)epsy_1
is the bunch normalized emittance along yepsz_1
is the bunch normalized emittance along zdg_1
is the bunch energy spreadcharge_1
is the bunch charge in pCt_inject
time at which the bunch is injected in the simulation box
&MOVING_WINDOW
w_sh = 20,
wi_time = 100.0,
wf_time = 150.0,
w_speed = 1.0
/
w_sh
is the number of time steps after which the moving-window is called, repeatedlywi_time
is the absolute time at which the window starts moving. nb: in order to block the MW from a certain simulation, the only tested path is to set awi_time
greater than the ending time of the simulation itself.w_speed=0
should also work, but is not tested for nowwf_time
is the absolute time at which the window stops movingw_speed
is the speed over c of the moving window
&OUTPUT
nouts = 10,
iene = 200,
nvout = 3,
nden = 1,
npout = 0,
nbout = 0,
jump = 1,
pjump = 1,
xp0_out = 0.0,
xp1_out = 100.0,
yp_out = 20.0,
tmax = 100.0,
cfl = 0.8,
new_sim = 0,
id_new = 0,
dump = 0,
L_env_modulus = .true.,
/
nouts
is the number of binary outputs during the relative time of the simulationiene
is the number of text outputs during the relative time of the simulationnvout
is the number of fields written. For a 2D P-polarized case, we have just 3 fields, Ex, Ey and Bz; in all the other cases there are 6 fields with these IDs: 1=Ex, 2=Ey, 3=Ez, 4=Bx, 5=By, 6=Bz. At eachnouts
step, every field withID ≤ nvout
will be dumped.nden
can have three different values; every output is divided by species on different files:1
: writes only the particle density n on the grid2
: writes also the energy density n ・ gamma on the grid3
: writes also the currents J on the grid
npout
1
: writes only the electron phase space2
: writes only the proton phase space- in general it writes only the phase space of the n-th species, with
n=npv
; ifn=npv>nps
, it writes the phase spaces of all the particle species
nbout
(only for PWFA)1
: writes only the electron phase space2
: writes only the proton phase space- in general it writes only the phase space of the n-th species, with
n=npv
; ifn=npv>nps
, it writes the phase spaces of all the particle species
jump
: jump on grid points; ifjump=2
, it means that each processor is going to write only one point every two. Mind that it's extremely important thatjump
is a divisor of the number of grid points per processor, otherwise the grid output will be corruptedpjump
: jump on particles; ifpjump=2
, it means that each processor is going to write the phase space of just one particle every two.xp0_out
,xp1_out
andyp_out
only particles contained inside the box defined byxp0 < x-w_speed t < xp1
,|y| < yp_out
will be printed in the outputtmax
is the relative time (in μm, because it is multiplied by c) that the simulation is going to be evolved. Being relative, it's going to be added to the time eventually already reached before the restart. To obtain the time in fs, you have to divide it by 0.299792458 [speed of light in μm/fs]cfl
is the Courant–Friedrichs–Lewy parameter ( Wikipedia CFL-parameter page )new_sim
: identifies if a simulation is newnew=0
(data is recreated from initial conditions) or if it is a restartnew=1
(dump are going to be read)id_new
identifies the starting number of the output files (ifnew=0
) or the last one written in the previous step (ifnew=1
)dump
1
: each processor will dump a binary file for everynout
in order to enable restart0
: dumps are suppressed
L_env_modulus
logical flag, only ifmodel_id=4
: if true the code generates the absolute value of the laser envelope amplitude, otherwise gives the real and imaginary part in two separate files
&TRACKING
P_tracking = .true.,
nkjump = 1,
tkjump = 4,
txmin = 55.,
txmax = 75.,
tymin = -80.,
tymax = 80.,
tzmin = -20.,
tzmax = 20.,
t_in = 0.,
t_out = 200.,
/
P_tracking
logical flag: if true the particle tracking is enablednkjump
a tracked particle everynkjump
is written in the output filetkjump
a snapshot of the tracked particles phase space is taken everytkjump
timesteptxmin
to select particles with initial longitudinal coordinatex > txmin
to be trackedtxmax
to select particles with initial longitudinal coordinatex < txmax
to be trackedtymin
to select particles with initial transverse coordinatey > tymin
to be trackedtymax
to select particles with initial transverse coordinatey < tymax
to be trackedtzmin
to select particles with initial transverse coordinatez > tzmin
to be trackedtzmax
to select particles with initial transverse coordinatez < tzmax
to be trackedt_in
initial tracking timet_out
final tracking time
&MPIPARAMS
nprocx = 1,
nprocy = 64,
nprocz = 1
/
nprocx
defines the number of processor the simulation will be splitted along thex
coordinatenprocy
defines the number of processor the simulation will be splitted along they
coordinatenprocz
defines the number of processor the simulation will be splitted along thez
coordinate- mind that usually we do not split along
x
and we use the same number of processor alongy
andz
(for 3D simulations) or we definenprocz=1
explicitly for 2D simulations. No guarantees are given if you want to explore other configurations (that should work anyway).
- mind that usually we do not split along