Environment variables¶
Some pieces of core Celeritas code interrogate the environment for variables to change system- or output-level behavior. These variables are checked once per execution, and checking them inserts the key and user-defined value (or empty) into a diagnostic database saved to Celeritas’ JSON output, so the user can tell what variables are in use or may be useful.
Variable |
Component |
Brief description |
---|---|---|
CELER_COLOR |
corecel |
Enable/disable ANSI color logging |
CELER_DEBUG_DEVICE |
corecel |
Increase device error checking and output |
CELER_DISABLE_DEVICE |
corecel |
Disable CUDA/HIP support |
CELER_DISABLE_PARALLEL |
corecel |
Disable MPI support |
CELER_DISABLE_ROOT |
corecel |
Disable ROOT I/O calls |
CELER_DEVICE_ASYNC |
corecel |
Flag for asynchronous memory allocation |
CELER_ENABLE_PROFILING |
corecel |
Set up NVTX/ROCTX profiling ranges [3] |
CELER_LOG |
corecel |
Set the “global” logger verbosity |
CELER_LOG_LOCAL |
corecel |
Set the “local” logger verbosity |
CELER_MEMPOOL… [2] |
corecel |
Change |
CELER_PERFETT… [1] |
corecel |
Set the in-process tracing buffer size |
CELER_PROFILE_DEVICE |
corecel |
Record extra kernel launch information |
CUDA_HEAP_SIZE |
geocel |
Change |
CUDA_STACK_SIZE |
geocel |
Change |
G4VG_COMPARE_VOLUMES |
geocel |
Check G4VG volume capacity when converting |
HEPMC3_VERBOSE |
celeritas |
HepMC3 debug verbosity |
VECGEOM_VERBOSE |
celeritas |
VecGeom CUDA verbosity |
CELER_DISABLE |
accel |
Disable Celeritas offloading entirely |
CELER_KILL_OFFLOAD |
accel |
Kill Celeritas-supported tracks in Geant4 |
CELER_NONFATAL_FLUSH |
accel |
Instead of crashing, kill tracks [4] |
CELER_STRIP_SOURCEDIR |
accel |
Strip directories from exception output |
Some of the Celeritas-defined environment variables have prefixes from other
libraries because they directly control the behavior of that library and
nothing else. The CELER_DEVICE_ASYNC
may be needed when running HIP 5.7
or later due to the “beta” nature of hipMallocAsync: it defaults to “true”
except for HIP less than 5.2 (where it is not implemented) or greater than 5.6.
Environment variables from external libraries can also be referenced by Celeritas or its apps:
Variable |
Library |
Brief description |
---|---|---|
CUDA_VISIBLE_DEVICES |
CUDA |
Set the active CUDA device |
HIP_VISIBLE_DEVICES |
HIP |
Set the active HIP device |
G4LEDATA |
Geant4 |
Path to low-energy EM data |
G4FORCE_RUN_MANAGER_TYPE |
Geant4 |
Use MT or Serial thread layout |
G4FORCENUMBEROFTHREADS |
Geant4 |
Set CPU worker thread count |
OMP_NUM_THREADS |
OpenMP |
Number of threads per process |
Note
For frameworks integrating Celeritas, these options are configurable via the
Celeritas API. Before Celeritas is set up for the first time, on a single
thread access the celeritas::environment()
struct (see
System), and call insert
for the desired key/value pairs.
Logging¶
The Celeritas library writes informational messages to stderr
. The given
levels can be used with the CELER_LOG
and CELER_LOG_LOCAL
environment
variables to suppress or increase the output. The default is to print
diagnostic messages and higher.
Level |
Description |
---|---|
debug |
Low-level debugging messages |
diagnostic |
Diagnostics about current program execution |
status |
Program execution status (what stage is beginning) |
info |
Important informational messages |
warning |
Warnings about unusual events |
error |
Something went wrong, but execution can continue |
critical |
Something went terribly wrong: program termination imminent |