TCode is a C++14 compliant application to simulate the response of solid state sensors in massively parallel platforms on Linux systems. TCode is implemented on top of Hydra and as such, it can run on OpenMP, CUDA and TBB compatible devices. TCode is still in its alpha version and the repository it is taking shape, for the moment we focused on getting raw performance and will make more stable and user friendly release in the near future.
TCode uses external 3D maps of electric fields, carrier mobilities and weighting field and energy deposit to simulate the response in current of solid state sensors. The motion of the individual carriers produced in the initial deposit is determined using a 4th other Runge-Kutta using the electric field and the mobilities and assuming that the carriers always move at drift velocity. At each time interval the current induced in the electrod is calculated from the carriers velocity using the corresponding weighting field, according to the Shockley-Ramo theorem. The output is stored to ROOT files, several level of output detail are available, from the simple current vs time plot to the complete information about the position of the carriers at each time step.
TCode depends on ROOT >= v.6.14, libconfig >= v1.5, TCLAP >= v1.2.1 and optionally CUDA >= 10.0 (needed for nVidia GPUs).
To generate executables to run on nVidia GPUs you also need an installation of CUDA >= 10.0 and to use a compatible GCC version.
Build TCode following the instructions below:
- clone the git repository:
git clone https://github.com/MultithreadCorner/TCode.git
- go to TCode directory:
cd TCode
- create a build directory:
mkdir build
- go to build directory cd
build
- run cmake specifying the path to Hydra:
cmake -DHYDRA_INCLUDE_DIR='path-to-hydra'../
- compile (all backends):
make -j8
Several executables, separate for each available backend (CPP, TBB, OMP and CUDA) will be generated in the build directory.
Every simulation is set by defining its parameters on the configuration file. Each configuration file has 3 main sections:
- OutputDirectory: This output sets the folder where all the results of the simulations will be stored
OutputDirectory = "/path/to/output"
- PhysicsMaps: This section contains the paths where the physics maps are stored. It is possibile to call a single physics file which contains all needed physics or 4 different files which contains the electric field (efield), wheighting field (wfield), electron mobility (emob) and hole mobility (hmob).
The alternative with the all-physics maps is called with the keyword
PhysicsMaps:{ efield = "path/to/efield_map" wfield = "path/to/wfield_map" emob = "path/to/emob_map" hmob = "path/to/hmob_map" }
map
:PhysicsMaps:{ map = "path/to/physics_map" }
- InputData: This section sets the name of every single simulation, its parameters like the timestep and the number of time steps. Furthermore InputData defines the energy deposit and how it is build.
InputData: { SimulationName: { name = "SimulationName"; steps = 100; timestep = 1e-12; plot = false; process = true; extrainfo = false; T = 300.; group = 1; path = "path/to/energyDeposit.dat" customdeposit = "NO"; particles = 0; Xshift = 2.; Yshift = 2.; Zshift = 0.; Length = 100.; BunchSize = 600; } }
name
(string): is the nickname for the simulationpath
(string): indicates the path where the specifications of the energy deposit are locatedplot
(bool): iftrue
generates a gif containing charge drift and signal plotting (timeconsuming!)extrainfo
(bool): generates snapshots for all simulation steps (timeconsuming!)steps
: Indicates the number of timesteps required to run the transient simulationtimestep
: Is the minimum advancement in time requested for the transient simulationparticles
: Is the number of particles requested for the dummy deposit (if path is activated, particles does not work).X/Y/Zshift
: Allows to shift (in micrometres) the energy deposit (imported or dummy).Length
: Lenght of the dummy deposit (does not work if path activated).group
: Allows group a large number of electron hole pairs.
TCode was created by Andrea Contu and Angelo Loi.
TCode was developed within the TIMESPOT collaboration, supported by the Instituto Nazionale di Fisica Nucleare (INFN) and by the Università degli Studi di Cagliari.