Setup Tutorial
Contents
Introduction
Here you will find a step by step guide to downloading, configuring, and running the Einstein Toolkit. You may use this tutorial on a workstation or laptop, or on a supported cluster. Configuring the Einstein Toolkit on an unsupported cluster is beyond the scope of this tutorial. If you find something that does not work, please feel free to edit the wiki or mail users@einsteintoolkit.org.
These instructions were last tested on XX-XXX-XXXX with the ET_XXXX_XX release of the Einstein Toolkit.
Prerequisites
You will need a number of packages installed in order to download the Einstein Toolkit components. On a Debian, Ubuntu, Linux-Mint, Fedora or Mac OSX-based system, install them as follows:
# Debian (stretch, buster) su -c 'apt-get install build-essential libopenmpi-dev openmpi-bin gfortran git subversion curl gnuplot gnuplot-x11' # Ubuntu (16.04.2, 17.04) sudo apt-get install build-essential mpich2? python libmpich2?-dev gfortran git subversion curl gnuplot gnuplot-x11 # Fedora (FC 25) su -c ' yum -y install mpich2 python mpich2-devel gsl gsl-devel libjpeg-devel hdf5 hdf5-mpich-devel gcc gcc-c++ gcc-gfortran patch numactl-devel numactl hwloc subversion git openssl-devel lapack-static' # If you have Mac OSX and use MacPorts, and use the following commands # (last tested for Yosemite): sudo port install subversion git gnuplot szip jpeg gcc46 fftw fftw-3 gsl openssl hdf5 +fortran +gcc46 -universal zlib openmpi +gcc46 # If you have Mac OSX and use Homebrew, and use the # following commands (last tested for Sierra): brew tap homebrew/science brew install subversion gnuplot subversion gcc fftw gsl hdf5 --with-fortran hwloc jpeg openssl pkg-config szip open-mpi # If you have Windows 10 and use the Linux Subsystem you are effectively # running a Ubuntu Linux systems but have to install a separate X11 server # (last tested with Windows 10 2017-07) cd /mnt/c/Users/$USER/Downloads sudo apt-get install build-essential mpich2? python libmpich2?-dev gfortran git subversion curl gnuplot gnuplot-x11 curl -O -L https://downloads.sourceforge.net/project/vcxsrv/vcxsrv/1.19.2.0/vcxsrv-64.1.19.2.0.installer.exe chmod a+x /vcxsrv-64.1.19.2.0.installer.exe # this works in Windows Creators Update (version 1703), older versions you # will have to click in the file in your "Downloads" folder ./vcxsrv-64.1.19.2.0.installer.exe echo "export DISPLAY=:0.0" >>$HOME/.bashrc cd $HOME
Installing in addition packages for (Debian package names so your mileage may vary)
pkg-config libfftw3-dev libgsl0-dev libatlas-base-dev libjpeg-dev libssl-dev libhdf5-serial-dev libhwloc-dev hwloc-nox
can speed up the compilation, since Cactus will try and use the system provided versions rather than compile its own. Once you have downloaded the Einstein Toolkit, you can inspect the option list files in simfactory/mdb/optionlists/ which often contain a list of recommended packages at the top of the files.
Please make sure all required packages are correctly installed before proceeding with the next step.
Download
A script called GetComponents is used to fetch the components of the Einstein Toolkit. GetComponents serves as convenient wrapper around lower level tools like git and svn to download the codes that make up the Einstein toolkit from their individual repositories. You may download and make it executable as follows:
curl -O -L https://raw.githubusercontent.com/gridaphobe/CRL/ET_2017_06/GetComponents chmod a+x GetComponents
GetComponents accepts a thorn list as an argument. To check out the needed components:
./GetComponents --parallel https://bitbucket.org/einsteintoolkit/manifest/raw/ET_2017_06/einsteintoolkit.th
This thornlist checks out the entire Einstein Toolkit, including Cactus, the Simulation Factory, the Einstein Toolkit thorns, and Kranc.
Configure and build
The recommended way to compile the Einstein Toolkit is to use the Simulation Factory ("SimFactory").
Configuring SimFactory for your machine
The ET depends on various libraries, and needs to interact with machine-specific queueing systems and MPI implementations. As such, it needs to be configured for a given machine. For this, it uses SimFactory. Generally, configuring SimFactory means providing an optionlist, for specifying library locations and build options, a submit script for using the batch queueing system, and a runscript, for specifying how Cactus should be run, e.g. which mpirun command to use.
Laptop/workstation operating systems
SimFactory contains general support for specific operating systems commonly used on workstations or laptops. Currently this list includes Linux/Ubuntu, Linux/Debian, Linux/Fedora, MacOS/Homebrew, MacOS/MacPorts, Windows10/BashTerminal.
If your OS is among the ones supported, you may proceed to configure Simfactory like so.
cd Cactus
# for Debian ./simfactory/bin/sim setup-silent --optionlist=debian.cfg --runscript debian.sh # for Ubuntu, Mint ./simfactory/bin/sim setup-silent --optionlist=ubuntu.cfg --runscript debian.sh # for Fedora (you may have to log out and back in if you have just intalled mpich to make the module command work) module load mpi ./simfactory/bin/sim setup-silent --optionlist=fedora.cfg --runscript debian.sh
# OSX+MacPorts ./simfactory/bin/sim setup-silent --optionlist=osx-macports.cfg --runscript osx-macports.run # OSX+Homebrew export CPATH=/usr/local/include LIBRARY_PATH=/usr/local/lib ./simfactory/bin/sim setup-silent --optionlist=osx-homebrew.cfg --runscript generic-mpi.run
# Windows10+BashTerminal ./simfactory/bin/sim setup-silent --optionlist=ubuntu.cfg --runscript debian.sh
After this step is complete you will find your machine's default setup under ./simfactory/mdb/machines/<hostname >.ini
You can edit some of these settings freely, such as "description", "basedir" etc. Some entry edits could result in simulation start-up warnings and/or errors such as "ppn" (processor-per-node meaning number of cores per cpu), "num-threads" (number of threads per core), "nodes" (number of cpus) so such edits must be done with some care.
Supported clusters
TODO (RH): This instructs users to download on a cluster which is not the officially suggested worksload and this thus should be changed.
SimFactory comes with support for many of the large supercomputers, and the ET is tested on these at the time of each release. To find out if the cluster you are running on is supported by SimFactory, run
cd Cactus simfactory/bin/sim whoami
If this returns
Current machine: None
then unfortunately SimFactory does not support your cluster, and you will need to configure it manually (see [Configuring a new machine]).
If you see
Current machine: <name of your cluster>
then SimFactory supports your cluster. Run
simfactory/bin/sim setup
and answer the questions, and SimFactory will automatically detect the correct option list, submit script and run script.
Building the Einstein Toolkit
Assuming that SimFactory has been successfully set up on your machine, you should be able to build the Einstein Toolkit with
simfactory/bin/sim build --mdbkey make 'make -j2' --thornlist manifest/einsteintoolkit.th
Adjust -j2 to match the number of cores your machine possesses if you want to use more or less than 2 parallel build processes. This may take a while, as it compiles all the thorns specified in manifest/einsteintoolkit.th.
Running
You can now run the Einstein Toolkit with a simple test parameter file.
simfactory/bin/sim submit helloworld --parfile arrangements/CactusExamples/HelloWorld/par/HelloWorld.par --walltime 0:5:0
This will submit the simulation to the queue naming it "helloworld" and ask for a 5 minutes long job time, if you are running on a cluster, or run it immediately in the background if you are on a personal laptop or workstation. You can check the status of the simulation with
simfactory/bin/sim list-simulations helloworld
You should see
helloworld [ACTIVE (FINISHED), restart 0000, job id 17456]
once the simulation has finished and
helloworld [ACTIVE (QUEUED), restart 0000, job id 17456]
while it still waits to execute and
helloworld [ACTIVE (RUNNING), restart 0000, job id 17456]
while it is running. Once it finished you can look at the output with
simfactory/bin/sim show-output helloworld
near the end of which you should see the lines
INFO (HelloWorld): Hello World!
If you see these line, then congratulations, you have successfully downloaded, compiled and run the Einstein Toolkit! You may now want to try some of the other tutorials to explore some interesting physics examples.