Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
Last revision Both sides next revision
hepsim:files [2018/08/01 10:56]
hepsim17
hepsim:files [2018/08/01 11:16]
hepsim17 [ProIO file format]
Line 3: Line 3:
 ====== Supported file formats ====== ====== Supported file formats ======
  
 +
 +===== ProMC file format =====
 +
 +[[https://atlaswww.hep.anl.gov/asc/promc/ | PROMC]] file format is used since 2014. It is primary used to to keep
 +EVGEN records (truth level). The format uses Google protocol buffers. 
 +It uses varints for integer values (and, by design, for 4-momenta and vertex). 
 +It's efficient format for events with large number of particles.
 +The file sizes for EVGEN files are typically 30% smaller than for traditional ROOT files (with fixed bytes for floats and integers).
 +The file format is self-describing. Suported by C++, Java/Jython (read/write), CPython.
 +
 +<fc #000080>
 +Supported by: </fc>  hs-toolkit and Jas4PP
 +===== ProIO file format =====
 +
 +[[https://github.com/decibelcooper/proio | PROIO]] file format is used since 2018. 
 +It is more efficient file format than ProMC when the number of events in the files larger than 64k,
 +and when number of particles in files is not large. For Monte Carlo records, the files created by ProIO are about 10-20% smaller in size than those from ProMC. ProIO files can be used with C++, Python, Java/Jython (only read), Go.
 +
 +<fc #000080>
 +Supported by: </fc>  hs-toolkit and Jas4PP
 +
 +
 +===== LCIO file format =====
 +
 +[[https://github.com/iLCSoft/LCIO | LCIO]] files are used to keep simulated and reconstructed events for
 +Geant4 simulation (and reconstruction) using "all-silicon" detector deigns.
 +
 +<fc #000080>
 +Supported by Jas4PP</fc>
 +
 +
 +
 +===== ROOT file format =====
 +
 +ROOT files are used to keep fast detector simulations from Delphes
 +
 +
 +
 +===== LHE file format =====
 +
 +LHE file formats are typically used for parton-level events from Madgraph.