Spack package repository for Muon Collider software stack
This repository holds a set of Spack recipes for Muon Collider software (under namespace mucoll
) based on Key4hep stack. It extends the corresponding key4hep-stack repository, which is required for installation, overriding several packages by the ones customised for Muon Collider simulation studies.
After installing Spack and downloading the key4hep-spack and mucoll-spack repositories, the whole software stack can be installed using the following commands:
# Add repositories
spack repo add ./key4hep-spack
spack repo add ./mucoll-spack
# Create a Spack environment
spack env create sim ./mucoll-spack/environments/mucoll-release/spack.yaml
spack env activate sim
# Install the software stack
spack add mucoll-stack
spack concretize --reuse
spack install --fail-fast
# Load the Muon Collider environment
source $MUCOLL_STACK
When signing in to a machine with the installed sofware stack (VM or Docker container), it has to be loaded into the environment:
spack env activate sim
source $MUCOLL_STACK
Preferred convention for version names in Spack is numbers separated by dots, without leading zeros, e.g. 1.2.13
.
Conversion to tag names in mucoll
packages is provided by MCIlcsoftpackage
class defined in packages/mucoll-stack/mucoll_utils.py
, e.g. for lcgeo
package version 0.17
corresponds to tag name v00-17-MC
.
After a new tag for the package is created, e.g. v00-17-MC
in lcgeo
repository, it can be added to this Spack repository in two steps:
- Get the archive checksum for the new tag
spack checksum lcgeo 0.17
# Validates archive URL and returns the checksum
version('0.17', sha256='5ab33aaf5bc37deba82c2dde78cdce6c0041257222ed7ea052ecdd388a41cf9b')
- Add the returned version definition to the corresponding package file:
packages/lcgeo/package.py
NOTE: This repository only contains packages maintained by the Muon Collider collaboration. If the version of interest is missing from Spack for some other package, the line with a new version definition should be added to the package file in the corresponding repository.
To see locations of other repositories:spack repo list
To introduce a new release version for the whole software stack, update the version number in packages/mucoll-stack/package.py
and then update versions of all the relevant packages in [environments/mucoll-release/packages.yaml].
Test this new configuration in a fresh environment:
# Create a development environment
spack env create dev ./mucoll-spack/environments/mucoll-release/spack.yaml
spack env activate dev
# Add stack with updated version to the environment
spack add mucoll-stack
# Check which packages would be installed
spack spec --reuse -NIt
Packages that are already installed in the sim
environment are known to Spack and will be reused, providing a clear indication of which part of the dependency tree will be modified by the new release.
It is possible to modify code of one or more packages using the development workflow, which lets Spack build it from your own source folder and use this custom version instead of the one installed in the release.
NOTE: This should primarily be used for simple code changes in a few packages that do not affect the overall build process and dependency tree of other packages in the release. For more global changes it's better to set up a new release.
Assume that we want to make changes in the LCIO
package, which many other packages depend on.
To leave the original release untouched it is preferable to create a new Spack environment, e.g. called dev_lcio
, using the .lock
file of the original environment as a starting point:
# Create a new environment
spack env create dev_lcio $SPACK_ENV/spack.lock
# Activate the development environment
spack env activate dev_lcio
The general procedure to replace a package with a custom version is the following:
- put your new source code in a development folder of your choice, e.g.
/opt/dev/LCIO
; - find the exact spec of this package in the release and mark it for development in the folder with the new source code;
- reconcretize the environment to replace the default version of the package with the development one;
- rebuild the modified package using
spack install <package>
; - rebuild the rest of the release, which will reinstall all the packages that depend on the one you've modified.
You can repeat the last 2 steps each time you modify the source code again.
# Create the development folder
mkdir -p /opt/dev/LCIO
# Download the original source code (and modify it)
git clone https://github.com/MuonColliderSoft/LCIO.git --branch v02-19-01-MC
# Find the exact spec of this package in the current release
spack find lcio # [email protected]
# Mark the package with this spec for development
spack develop -p /opt/dev/LCIO [email protected]
# Reconcretize the environment
spack concretize -f --reuse
# Build the modified package
spack install lcio
# Build the rest of the release
spack install
NOTE: The package spec you mark for development must match exactly the one in the release, even if the actual code comes from a different version of the package. Otherwise you'll have to modify the packages configuration in the relase to properly include the new spec in the dependency tree.
To return to the original version of the release:
# Deactivate the current environment (if on lxplus)
spack env deactivate
# Activate the default environment (if in a Docker container)
spack env activate sim