Build Allen

There are two options for building Allen: Either as standalone project or as part of the LHCb software stack. The first option is recommended for algorithm developments within Allen, whereas the second is more suitable for integration developments and HLT1 line development and studies.

As standalone project

Requisites

The following packages are required in order to be able to compile Allen. Package names listed here are CentOS 7 names, package names for other distributions may slightly change:

The following python3 packages are also needed, which can be installed with pip, conda, or the package manager:

  • wrapt

  • cachetools

  • pydot

  • sympy

Further requirements depend on the device chosen as target. Allen supports targets CPU (default), CUDA and HIP. The CUDA target requires a CUDA installation, whereas the HIP target requires a ROCm installation.

Building with CVMFS

We show a proposed development setup with the CVMFS filesystem and RHEL 9 that automatically provides all the aforementioned requisites:

First source the LHCb environment:

source /cvmfs/lhcb.cern.ch/lib/LbEnv

The build process is the standard cmake procedure. You should specify a CMAKE_TOOLCHAIN_FILE according to the architecture you want to compile.

  • CPU target:

    mkdir build
    cd build
    cmake -DSTANDALONE=ON -DCMAKE_TOOLCHAIN_FILE=/cvmfs/lhcb.cern.ch/lib/lhcb/lcg-toolchains/LCG_105a/x86_64_v3-el9-gcc12-opt+g.cmake ..
    make
    
  • CUDA target:

    mkdir build
    cd build
    cmake -DSTANDALONE=ON -DCMAKE_TOOLCHAIN_FILE=/cvmfs/lhcb.cern.ch/lib/lhcb/lcg-toolchains/LCG_105a/x86_64_v3-el9-gcc12+cuda12_1-opt+g.cmake ..
    make
    
  • HIP target (the following is a CentOS 7 configuration, a RHEL 9 one will soon be provided):

    mkdir build
    cd build
    cmake -DSTANDALONE=ON -DCMAKE_TOOLCHAIN_FILE=/cvmfs/lhcb.cern.ch/lib/lhcb/lcg-toolchains/LCG_101/x86_64-centos7-clang12+hip5-opt.cmake ..
    make
    

Note: CUDA builds with CVMFS outside CERN network still require a local CUDA installation. If cmake reports that “No CMAKE_CUDA_COMPILER could be found”, it is unable to find the local installation of nvcc CUDA compiler. You can do either one of the following three:

  • Specify CMAKE_CUDA_COMPILER when invoking cmake:

    cmake -DSTANDALONE=ON -DCMAKE_CUDA_COMPILER=</path/to/nvcc> -DCMAKE_TOOLCHAIN_FILE=/cvmfs/lhcb.cern.ch/lib/lhcb/lcg-toolchains/LCG_105a/x86_64_v3-el9-gcc12+cuda12_1-opt+g.cmake ..
    
  • Add nvcc directory to PATH (typically /usr/local/cuda-X.Y/bin):

    export PATH=$PATH:</directory/containing/nvcc>
    
  • Set the environment variable CUDACXX:

    export CUDACXX=</path/to/nvcc>
    

In order to run, use the generated wrapper:

./toolchain/wrapper ./Allen --sequence hlt1_pp_validation

Building without CVMFS

While most requisites can be found as packages on the various OSs, you will need to manually provide the umesimd library:

git clone https://github.com/edanor/umesimd.git <some_dir>/umesimd
export UMESIMD_ROOT_DIR=<some_dir>

The build process doesn’t differ from standard cmake projects:

mkdir build
cd build
cmake -DSTANDALONE=ON ..
make

To run Allen, simply invoke the generated binary:

./Allen --sequence hlt1_pp_validation

Building on macOS

Allen supports macOS, including Apple Silicon, on a best-effort basis. The installation requires the following packages, which can be installed through brew:

brew install llvm cpp-gsl catch2 zeromq nlohmann-json python3 boost
pip3 install --user wrapt cachetools pydot sympy

It also requires the aforementioned umesimd package:

git clone https://github.com/edanor/umesimd.git <some_dir>/umesimd
export UMESIMD_ROOT_DIR=<some_dir>

Due to the recent security features of macOS ignoring DYLD_LIBRARY_PATH settings not playing nicely with cindex.py’s requirement of libclang, it is necessary to provide a symlink in /usr/local/lib as follows:

ln -s /Library/Developer/CommandLineTools/usr/lib/libclang.dylib /usr/local/lib/libclang.dylib

Finally, Allen can be built and run as on any other platform:

mkdir build
cd build
cmake -DSTANDALONE=ON ..
make
./Allen --sequence hlt1_pp_validation

Purging / rebuilding

In few cases a purge command followed by a rebuild may be required. The cases where this is necessary are described here Building with a newly defined algorithm.

Compilation options

The build process can be configured with cmake options. For a complete list of options and for editing them we suggest using the ccmake tool:

ccmake .

Alternatively, cmake options can be passed with -D when invoking the cmake command (eg. cmake -D<option>=<value> ..). Here is a brief explanation of some options:

  • STANDALONE - Selects whether to build Allen standalone or as part of the Gaudi stack. Defaults to OFF.

  • TARGET_DEVICE - Selects the target device architecture. Options are CPU, CUDA and HIP.

  • SEQUENCES - Either a regex or all, if a regex is passed and the pattern is found in a sequence name, it will be built. For a complete list of sequences available, check configuration/sequences/. The name of a sequence is given by its filename without the py extension. Note that sequences are by default generated during runtime, when specified through –sequence. Requesting sequences here causes them to be pregenerated into a json file (in the build directory).

  • CMAKE_BUILD_TYPE - Build type, which is either of RelWithDebInfo, Release or Debug.

  • CUDA_ARCH - Selects the architecture to target for CUDA compilation.

  • HIP_ARCH - Selects the architecture to target with HIP compilation.

Docker

The following lines will build the code base from any computer with NVidia-Docker, assuming you are in the directory with the code checkout and want to build in build:

To run allen builder container from a repo container:

docker-compose up -d

This container would stay attached to this folder as a volume. You will be able to connect and execute commands inside:

docker-compose exec allen bash
cmake -GNinja -DCMAKE_CXX_COMPILER=clang++ -DCMAKE_C_COMPILER=clang -DCMAKE_CUDA_HOST_COMPILER=clang++ -DCMAKE_CUDA_FLAGS="-allow-unsupported-compiler" -DSTANDALONE=ON -DTARGET_DEVICE=${TARGET} -DCMAKE_BUILD_TYPE=${BUILD_TYPE} -DSEQUENCE=${SEQUENCE} -DCPU_ARCH=haswell ..
ninja
./Allen

By default, this docker image would compile the code and run it with the input from the “/input” folder. In the command below we mount input inside this repository and mount the build folder, so that it caches built files.

Note: Files inside the build folder would belong to the root user.

As a Gaudi/LHCb project

Using the stack setup

Follow the instructions in the stack setup to set up the software stack.

To compile Allen and its depending projects call

make Allen

By default, all configured sequences available in configuration/python/AllenSequences <https://gitlab.cern.ch/lhcb/Allen/-/tree/master/configuration/python/AllenSequences are built and the json configuration files are stored inside the Allen/InstallArea/${ARCHITECTURE}/constants/ directory.

As a Gaudi/LHCb cmake project

To build Allen like this, is the same as building any other Gaudi/LHCb project. Allen depends on Rec and all projects that Rec depends on. So either clone them locally or add the path to a valid nightly build to CMAKE_PREFIX_PATH (check the here). Then do:

LbLogin -c x86_64_v3-el9-gcc13-opt+g
cd Allen
lb-project-init
make configure
make install

By default all sequences are built, Allen is built with CUDA, and the CUDA stack is searched for in /usr/local/cuda. These defaults (and other cmake variables) can be changed by adding the same flags that you would pass to a standalone build to the CMAKEFLAGS environment variable before calling make configure.

For example, to specify another CUDA stack to be used set:

export CMAKEFLAGS="-DCMAKE_CUDA_COMPILER=/path/to/alternative/nvcc"

Runtime environment:

To setup the runtime environment for Allen, the same tools as for other Gaudi/LHCb projects can be used:

cd Allen
./build.${BINARY_TAG}/run Allen ...