.. only:: noconfig .. warning:: This autogenerated documentation is incomplete because it was not built with all optional dependencies (breathe, sphinxbib, cmake). Please visit the `Celeritas documentation`_ hosted on GitHub pages for the full documentation. .. _Celeritas documentation: https://celeritas-project.github.io/celeritas/user/index.html
Celeritas is a Monte Carlo particle transport code for simulating High Energy Physics detectors on general purpose GPUs. Motivated by the massive computational requirements of the High Luminosity upgrade to the Large Hadron Collider, the code's initial goal is to accelerate electromagnetic physics simulations of the CMS and ATLAS detectors.
.. only:: html :Release: |release| :Date: |today|
New projects in High Energy Physics (HEP) and upgrades to existing ones promise new discoveries but at the cost of increased hardware complexity and data readout rates. Deducing new physics from detector readouts requires a proportional increase in computational resources. The High Luminosity Large Hadron Collider (HL-LHC) detectors will require more computational resources than are available with traditional CPU-based computing grids. For example, the CMS collaboration forecasts :cite:`2021-CMS-Offline` that when the upgrade is brought online, computational resource requirements will exceed availability by more than a factor of two, about 40% of which is Monte Carlo (MC) detector simulation, without substantial research and development improvements.
Celeritas [1] is a new MC particle transport code designed for high performance simulation of complex HEP detectors on GPU-accelerated hardware. Its immediate goal is to simulate electromagnetic (EM) physics for HL-LHC detectors with no loss in fidelity, acting as a plugin to accelerate existing Geant4 :cite:`Geant4` workflows by "offloading" selected particles to Celeritas to transport on GPU.
[1] | This documentation is generated from Celeritas |release|. |
.. toctree:: :maxdepth: 2 :caption: Getting started introduction/overview.rst introduction/installation.rst introduction/usage.rst
.. only:: nobreathe .. note:: The breathe_ extension was not used when building this version of the documentation. The API documentation will not be rendered below. .. _breathe: https://github.com/michaeljones/breathe#readme
The bulk of Celeritas' code is in several code libraries to be used by external users and application developers. Currently, the most stable and user-ready component of Celeritas is its :ref:`api_g4_interface` for offloading. This section has two audiences:
- high-level developers, particularly those who might want to write a new physics code; and
- external users of Celeritas as a library for integration into a Geant4 application.
Cursory documentation for many of the classes and other data constructs are described in this user manual, but further details for developers can be found in the full Doxygen-generated developer documentation.
The Celeritas codebase lives under the src/
directory and is partitioned
into several libraries of increasing complexity:
corecel
for GPU/CPU abstractions,
geocel
for geometry interfaces and wrappers to external libraries,
orange
for the ORANGE platform-portable geometry implementation,
celeritas
for the GPU implementation of physics and MC particle tracking,
and
accel
for the Geant4 integration library.
Additional top-level files provide access to version and configuration attributes.
Note
When building Celeritas, regardless of the configured :ref:`dependencies
<Dependencies>`, all of the documented API code in corecel
, orange
,
and celeritas
(except possibly headers ending in .json.hh
,
.device.hh
, etc.) will compile and can link to downstream code. However,
some classes will throw celeritas::RuntimeError
if they lack the required
functionality.
If Geant4 is disabled, the accel
library will not be built or installed,
because every component of that library requires Geant4.
.. toctree:: :maxdepth: 2 :caption: Implementation details implementation/corecel.rst implementation/data-model.rst implementation/orange.rst implementation/units-constants.rst implementation/core-physics.rst implementation/em-physics.rst implementation/optical-physics.rst implementation/decay-physics.rst implementation/geant4-interface.rst
The agility, extensibility, and performance of Celeritas depend strongly on software infrastructure and best practices. This section describes how to modify and extend the codebase.
.. toctree:: :maxdepth: 2 :caption: Development development/contributing.rst development/coding.rst development/style.rst development/testing.rst
A few standalone codes demonstrate how to use Celeritas as an app and as a library, in independent and Geant4-integrated contexts.
.. todo:: This section is not yet complete.
.. toctree:: :maxdepth: 2 :caption: Examples example/minimal.rst example/geant4.rst example/celer-sim.rst example/celer-g4.rst example/celer-geo.rst
.. toctree:: :maxdepth: 2 :caption: Appendices backmatter/acknowledgments.rst backmatter/references.rst appendix/release-history.rst appendix/administration.rst appendix/license.rst