Isambard - firedrakeproject/firedrake GitHub Wiki
The Isambard 2 service was retired on 30th September 2024. These notes are only for reference.
We have only tried installing on the XCI (ARM/ThunderX2/TX2) system, not the MACS, A64FX or Phase3 portions of the machine.
You should familiarise yourself with as much of Spack's functionality as possible. To achieve the same flexibility as we have on desktop installs the Firedrake Spack install leverages a lot of Spack's features. More information about Spack can be found on their website.
- The following clones the Spack repo, loads modules to setup the environment and activates Spack.
git clone -c feature.manyFiles=true [email protected]:spack/spack.git
module purge
module load Base-opts
module load PrgEnv-gnu
module load pmi-lib
module load cray-python/3.8.5.1
module load cray-mpich
. spack/share/spack/setup-env.sh
- Populate
$SPACK_USER_CONFIG_PATH/cray/compilers.yaml
with
$SPACK_USER_CONFIG_PATH/cray/compilers.yaml
compilers:
- compiler:
spec: [email protected]
paths:
cc: cc
cxx: CC
f77: ftn
fc: ftn
flags: {}
operating_system: cnl7
target: any
modules:
- PrgEnv-cray
- cce/11.0.4
environment: {}
extra_rpaths: []
- compiler:
spec: [email protected]
paths:
cc: cc
cxx: CC
f77: ftn
fc: ftn
flags: {}
operating_system: cnl7
target: any
modules:
- PrgEnv-gnu
- gcc/9.3.0
environment: {}
extra_rpaths: []
- Populate
$SPACK_USER_CONFIG_PATH/packages.yaml
with
$SPACK_USER_CONFIG_PATH/packages.yaml
packages:
all:
providers:
mpi: [cray-mpich]
pkg-config:
externals:
- spec: [email protected]
prefix: /usr
buildable: False
pkgconf:
externals:
- spec: [email protected]
prefix: /usr
buildable: False
cray-mpich:
externals:
- spec: [email protected]%[email protected]
modules:
- PrgEnv-gnu
- gcc/9.3.0
- cray-mpich/7.7.17
- spec: [email protected]%[email protected]
modules:
- PrgEnv-cray
- cce/11.0.4
- cray-mpich/7.7.17
buildable: False
cray-libsci:
externals:
- spec: [email protected]
modules:
- cray-libsci/20.09.1
- spec: [email protected]
modules:
- cray-libsci/19.06.1
buildable: False
python:
externals:
- spec: [email protected]
modules:
- cray-python/3.8.5.1
- spec: [email protected]
modules:
- cray-python/3.7.3.2
buildable: False
- Esure
$SPACK_USER_CONFIG_PATH/upstreams.yaml
does not exist. Upstream (system level installed Spack packages) for Isambard cause the Cray tools (compiler wrappers) to break.
-
Clone the repo:
git clone https://github.com/firedrakeproject/firedrake-spack.git # or git clone [email protected]:firedrakeproject/firedrake-spack.git
-
Add the repository to spack
spack repo add <repo directory>
-
Create an spack environment
spack env create -d ./firedrake
-
Activate that environment
spack env activate -p ./firedrake
-
To avoid a bunch of errors add a whole bunch of packages to the development package list:
spack develop py-firedrake@develop spack develop libsupermesh@develop spack develop petsc@develop spack develop chaco@petsc spack develop py-fiat@develop spack develop py-finat@develop spack develop py-islpy@develop spack develop py-petsc4py@develop spack develop py-pyadjoint@develop spack develop py-pyop2@develop spack develop py-coffee@develop spack develop py-loopy@develop spack develop py-cgen@develop spack develop py-codepy@develop spack develop py-genpy@develop spack develop py-tsfc@develop spack develop py-ufl@develop
-
Add Firedrake:
spack add py-firedrake@develop \ %[email protected] \ ^[email protected] \ ^[email protected]%[email protected] \ ^[email protected] \ ^firedrake.petsc@develop+fftw cflags=\"-O3 -march=native -mtune=native\" cxxflags=\"-O3 -march=native -mtune=native\" fflags=\"-O3 -march=native -mtune=native -ffree-line-length-512\"
-
Add to
$SPACK_ENV/spack.yaml
:spack: packages: all: compiler: [[email protected]] providers: mpi: [cray-mpich] blas: [cray-libsci] lapack: [cray-libsci] scalapack: [cray-libsci] netlib-scalapack: externals: # Pretend cray-libsci is netlib-scalapack - spec: [email protected] modules: - cray-libsci/20.09.1 buildable: False
-
Concretize (and log)
spack concretize -f 2>&1 | tee $SPACK_ENV/conc.log
- Splitting the concretize and install steps into 2 distinct parts allows you to review what is being installed before the lengthy installation process begins.
-
Install (and log)
spack install --fail-fast 2>&1 | tee $SPACK_ENV/spack-firedrake-install.log
Testing must be run on a compute node. An interactive session can be started using
qsub -I -q arm-dev -l walltime=00:10:00
Alternatively submit a jobscript, see additional notes.
- Test you can import Firedrake by running
aprun -n 1 python -c "from firedrake import *"
. You must run viaaprun
to make sure the MPI modules are found.- If this fails, before trying anything else, deactivate the environment with
spack env deactivate
and reactivate withspack env activate -p ./firedrake
(as above) and try runningpython -c "from firedrake import *"
again. This appears to be a shortcoming of spack.
- If this fails, before trying anything else, deactivate the environment with
- Run the basic functionality tests. Before running you will need to set a few pyop2 variables:
Run the tests with:
unset PYOP2_LD export PYOP2_CC=`which cc` export PYOP2_CXX=`which CC` export PYOP2_CFLAGS="-I${CRAY_MPICH_DIR}/include/" export PYOP2_LDFLAGS='-shared'
cd $SPACK_ENV/py-firedrake pytest tests/regression/ -m "not parallel" -k "poisson_strong or stokes_mini or dg_advection"
- When running the environment on the compute nodes the variable
$HOME
needs to be set to something like/work/_projectcode_/_projectcode_/_username_
or/tmp
as many dependencies expect to find configuration in$HOME
. - We don't run parallel tests due to an issue with the current parallel pytest hook, this is in the process of being fixed.
- When running the environment on the compute nodes the variable
- Run the full test suite:
cd $SPACK_ENV/src/firedrake pytest tests -m "not parallel"
This page is based off installation notes available here.
Other potential problems you may run into:
- At the
spack install
step, Spack may complain about a missing dependencygnuconfig
for thelibffi
package. It will tell you to adddepends_on('gnuconfig', type='build', when='@3.4.2')
to the package definition (exact version may not be3.4.2
). You can edit the package file withspack edit libffi
. This opens the package file located inspack/var/spack/repos/builtin/packages/libffi/package.py
with $EDITOR. You can see how to add dependencies from the example in the Spack documentation. - This guide assumes you are using your own Spack installation. After running
. spack/share/spack/setup-env.sh
you can check you are using the correct Spack installation withwhich spack
.
Isambard maintains an installation of Spack, but it is not up to date and does not contain many of the fixes required to install Firedrake. Documentation is available on the Isambard spack docs page.