Skip to content

Application for simulation of solid state sensor response

License

GPL-3.0, GPL-3.0 licenses found

Licenses found

GPL-3.0
LICENSE
GPL-3.0
COPYING
Notifications You must be signed in to change notification settings

MultithreadCorner/TCode

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

44 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DOI

What is it?

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.

How it works

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.

Dependencies

TCode depends on ROOT >= v.6.14, libconfig >= v1.5, TCLAP >= v1.2.1 and optionally CUDA >= 10.0 (needed for nVidia GPUs).

Build application

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:

  1. clone the git repository: git clone https://github.com/MultithreadCorner/TCode.git
  2. go to TCode directory: cd TCode
  3. create a build directory: mkdir build
  4. go to build directory cd build
  5. run cmake specifying the path to Hydra: cmake -DHYDRA_INCLUDE_DIR='path-to-hydra'../
  6. compile (all backends): make -j8

Several executables, separate for each available backend (CPP, TBB, OMP and CUDA) will be generated in the build directory.

Manual

Parameter file

Every simulation is set by defining its parameters on the configuration file. Each configuration file has 3 main sections:

  1. OutputDirectory: This output sets the folder where all the results of the simulations will be stored OutputDirectory = "/path/to/output"
  2. 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).
    PhysicsMaps:{
      efield  =  "path/to/efield_map"
      wfield  =  "path/to/wfield_map"
      emob    =  "path/to/emob_map"
      hmob    =  "path/to/hmob_map"
    }
    
    The alternative with the all-physics maps is called with the keyword map:
    PhysicsMaps:{
      map  =  "path/to/physics_map"
    }
    
  3. 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; 
       }
    }
    

The parameters

  1. name(string): is the nickname for the simulation
  2. path(string): indicates the path where the specifications of the energy deposit are located
  3. plot(bool): if true generates a gif containing charge drift and signal plotting (timeconsuming!)
  4. extrainfo(bool): generates snapshots for all simulation steps (timeconsuming!)
  5. steps: Indicates the number of timesteps required to run the transient simulation
  6. timestep: Is the minimum advancement in time requested for the transient simulation
  7. particles: Is the number of particles requested for the dummy deposit (if path is activated, particles does not work).
  8. X/Y/Zshift: Allows to shift (in micrometres) the energy deposit (imported or dummy).
  9. Length: Lenght of the dummy deposit (does not work if path activated).
  10. group: Allows group a large number of electron hole pairs.

Authors

TCode was created by Andrea Contu and Angelo Loi.

Acknowledgement

TCode was developed within the TIMESPOT collaboration, supported by the Instituto Nazionale di Fisica Nucleare (INFN) and by the Università degli Studi di Cagliari.