The VecGeom geometry library is a relatively recent effort aiming to provide a modern and high performance geometry service for particle detector simulation in hierarchical detector geometries common to HEP experiments. One of its principal targets is the efficient use of vector SIMD hardware instructions to accelerate geometry calculations for single track as well as multi-track queries. Previously, excellent performance improvements compared to Geant4/ROOT could be reported for elementary geometry algorithms at the level of single shape queries. In this contribution, we will focus on the higher level navigation algorithms in VecGeom, which are the most important components as seen from the simulation engines. We will first report on our R&D effort and developments to implement SIMD enhanced data structures to speed up the well-known “voxelised” navigation algorithms, ubiquitously used for particle tracing in complex detector modules consisting of many daughter parts. Second, we will discuss complementary new approaches to improve navigation algorithms in HEP. These ideas are based on a systematic exploitation of static properties of the detector layout as well as automatic code generation and specialisation of the C++ navigator classes. Such specialisations reduce the overhead of genericor virtual function based algorithms and enhance the effectiveness of the SIMD vector units. These novel approaches go well beyond the existing solutions available in Geant4 or TGeo/ROOT, achieve a significantly superior performance, and might be of interest for a wide range of simulation backends (GeantV, Geant4). We exemplify this with concrete benchmarks for the CMS and ALICE detectors.
[1]
Volker Lindenstruth,et al.
Vc: A C++ library for explicit vectorization
,
2012,
Softw. Pract. Exp..
[2]
M. A. Cortés-Giraldo,et al.
Recent developments in GEANT4
,
2016
.
[3]
John Apostolakis,et al.
New software library of geometrical primitives for modeling of solids used in Monte Carlo detector simulations
,
2012
.
[4]
Lorenzo Moneta,et al.
ROOT - A C++ framework for petabyte data storage, statistical analysis and visualization
,
2009,
Comput. Phys. Commun..
[5]
Alexander Keller,et al.
Shallow Bounding Volume Hierarchies for Fast SIMD Ray Tracing of Incoherent Rays
,
2008,
Comput. Graph. Forum.
[6]
Ingo Wald,et al.
Embree: a kernel framework for efficient CPU ray tracing
,
2014,
ACM Trans. Graph..
[7]
A. Dell'Acqua,et al.
Geant4 - A simulation toolkit
,
2003
.
[8]
F. Rademakers,et al.
ROOT — An object oriented data analysis framework
,
1997
.