Skip to content

Latest commit

 

History

History
326 lines (272 loc) · 15.7 KB

INSTALL.md

File metadata and controls

326 lines (272 loc) · 15.7 KB

PIConGPU Install Guide

Overview

Overview of PIConGPU Library Dependencies

Figure: Overview of inter-library dependencies for parallel execution of PIConGPU on a typical HPC system. Due to common binary incompatibilities between compilers, MPI and boost versions, we recommend to deploy a hierarchical module system such as lmod. An example setup can be found here.

Requirements

Mandatory

  • gcc 4.9 to 5.X (depends on your current CUDA version)

    • Debian/Ubuntu:
      • sudo apt-get install gcc-4.9 g++-4.9 build-essential
      • sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.9 60 --slave /usr/bin/g++ g++ /usr/bin/g++-4.9
    • Arch Linux:
  • CUDA 7.5+

    • Arch Linux: sudo pacman --sync cuda
  • at least one CUDA capable GPU

    • Compute capability sm_20 or higher
    • full list of CUDA GPUs and their compute capability
    • (More is always better. Especially, if we are talking about GPUs.)
  • cmake 3.3.0 or higher

    • Debian/Ubuntu: sudo apt-get install cmake file cmake-curses-gui
    • Arch Linux: sudo pacman --sync cmake
  • OpenMPI 1.5.1+ / MVAPICH2 1.8+ or similar (GPU aware install recommended)

    • Debian/Ubuntu: sudo apt-get install libopenmpi-dev
    • Arch Linux: sudo pacman --sync openmpi
  • zlib

    • Debian/Ubuntu: sudo apt-get install zlib1g-dev
    • Arch Linux: sudo pacman --sync zlib
  • boost 1.57.0+ ("program options", "regex" , "filesystem", "system", "thread", "math" and nearly all header-only libs)

    • download from http://www.boost.org/, e.g. version 1.57.0
    • Debian/Ubuntu: sudo apt-get install libboost-program-options-dev libboost-regex-dev libboost-filesystem-dev libboost-system-dev libboost-thread-dev libboost-math-dev
    • Arch Linux: sudo pacman --sync boost
    • From source:
      • ./bootstrap.sh --with-libraries=filesystem,program_options,regex,system,thread,math --prefix=$HOME/lib/boost
      • ./b2 -j4 && ./b2 install
  • git 1.7.9.5 or higher

    • Debian/Ubuntu: sudo apt-get install git
    • Arch Linux: sudo pacman --sync git

Optional Libraries

If you do not install the optional libraries, you will not have the full amount of PIConGPU plugins. We recommend to install at least pngwriter. Some of our examples will also need libSplash.

  • pngwriter >= 0.5.6

    • download our modified version from github.com/pngwriter/pngwriter
    • Requires libpng,
      • Debian/Ubuntu: sudo apt-get install libpng-dev
      • Arch Linux: sudo pacman --sync libpng
    • example:
      • mkdir -p ~/src ~/build ~/lib
      • git clone https://github.com/pngwriter/pngwriter.git ~/src/pngwriter/
      • cd ~/build
      • cmake -DCMAKE_INSTALL_PREFIX=$HOME/lib/pngwriter ~/src/pngwriter
      • make install
    • set the environment variable PNGWRITER_ROOT to $HOME/lib/pngwriter
  • libSplash >= 1.6.0 (requires HDF5, boost program-options)

    • Debian/Ubuntu dependencies: sudo apt-get install libhdf5-openmpi-dev libboost-program-options-dev
    • Arch Linux dependencies: sudo pacman --sync hdf5-openmpi boost
    • or compile hdf5 yourself: follow instructions one paragraph below
    • example:
      • mkdir -p ~/src ~/build ~/lib
      • git clone https://github.com/ComputationalRadiationPhysics/libSplash.git ~/src/splash/
      • cd ~/build
      • cmake -DCMAKE_INSTALL_PREFIX=$HOME/lib/splash ~/src/splash
      • make install
    • set the environment variable SPLASH_ROOT to $HOME/lib/splash
  • HDF5 >= 1.8.6, standard shared version (no c++, enable parallel), e.g. hdf5/1.8.5-threadsafe

    • Debian/Ubuntu: sudo apt-get install libhdf5-openmpi-dev
    • Arch Linux: sudo pacman --sync hdf5-openmpi
    • example:
      • mkdir -p ~/src ~/build ~/lib
      • cd ~/src
      • download hdf5 source code from [release list of the HDF5 group] (https://www.hdfgroup.org/ftp/HDF5/releases/) for example wget https://www.hdfgroup.org/ftp/HDF5/releases/hdf5-1.8.14/src/hdf5-1.8.14.tar.gz
      • tar -xvzf hdf5-1.8.14.tar.gz
      • cd hdf5-1.8.14
      • ./configure --enable-parallel --enable-shared --prefix $HOME/lib/hdf5/
      • make
      • optional: make test
      • make install
    • set the environment variable HDF5_ROOT to $HOME/lib/hdf5 and the LD_LIBRARY_PATH to export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$HOME/lib/hdf5/lib
  • splash2txt (requires libSplash and boost "program_options", "regex")

    • converts slices in dumped hdf5 files to plain txt matrices
    • assume you downloaded PIConGPU to PICSRC=$HOME/src/picongpu
    • mkdir -p ~/build && cd ~/build
    • cmake -DCMAKE_INSTALL_PREFIX=$PICSRC/src/tools/bin $PICSRC/src/tools/splash2txt
    • make
    • make install
    • add the directory of the binary splash2txt, $PICSRC/src/tools/bin, to a place in your $PATH
    • options:
      • splash2txt --help
      • list all available datasets: splash2txt --list <FILE_PREFIX>
  • png2gas (requires libSplash, pngwriter and boost "program_options")

    • converts png files to hdf5 files that can be used as an input for a species initial density profiles
    • compile and install exactly as splash2txt above
  • ADIOS >= 1.10.0 (requires MPI, zlib and mxml http://www.msweet.org/projects.php?Z3)

    • Debian/Ubuntu: sudo apt-get install libadios-dev libadios-bin
    • Arch Linux using an AUR helper: pacaur --sync libadios
    • Arch Linux using the AUR manually:
      • sudo pacman --sync --needed base-devel
      • git clone https://aur.archlinux.org/libadios.git
      • cd libadios
      • makepkg -sri
    • example:
      • mkdir -p ~/src ~/build ~/lib
      • cd ~/src
      • wget http://users.nccs.gov/~pnorbert/adios-1.10.0.tar.gz
      • tar -xvzf adios-1.10.0.tar.gz
      • cd adios-1.10.0
      • CFLAGS="-fPIC" ./configure --enable-static --enable-shared --prefix=$HOME/lib/adios-1.10.0 --with-mpi=$MPI_ROOT --with-zlib=/usr
      • make
      • make install
    • set the environment variable ADIOS_ROOT to export ADIOS_ROOT=$HOME/lib/adios-1.10.0, the PATH to export PATH=$PATH:$ADIOS_ROOT/bin and the LD_LIBRARY_PATH to export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ADIOS_ROOT/lib
  • ISAAC (requires boost (header only), IceT, Jansson, libjpeg (preferably libjpeg-turbo), libwebsockets (only for the ISAAC server, but not the plugin itself) )

    • Enables live in situ visualization, see more here Plugin description
    • To enable ISAAC you need ISAAC itself:
      • git clone https://github.com/ComputationalRadiationPhysics/isaac.git
      • While configuring a simulation add the path of ISAAC to CMake, e.g. with $PICSRC/configure ~/paramSets/kh -c "-DISAAC_DIR=~/isaac/lib/" or with CMAKE_PREFIX_PATH. Of course may the path vary. ISAAC needs C++11, which is enabled for PIConGPU if CUDA 7.5 or newer is available, thus these versions are needed. For more requirements have a look at ISAAC's installation requirements.
      • It may be, that even more installation paths for libraries need to be added. Just add them in the same matter as ISAAC itself. The CMake variables names are described in ISAAC's installation requirements, too. E.g. for the laser wake field experiment configuration you may need: $PICSRC/configure ~/paramSets/lw -c "-DISAAC_DIR=~/isaac/lib -DJansson_DIR=~/jansson/install/lib/cmake/jansson -DIceT_DIR=~/IceT/install/lib". Of course the paths may and will vary for your setup.
  • for VampirTrace support

    • download 5.14.4 or higher, e.g. from http://www.tu-dresden.de
    • example:
      • mkdir -p ~/src ~/build ~/lib
      • cd ~/src
      • wget -O VampirTrace-5.14.4.tar.gz "http://wwwpub.zih.tu-dresden.de/~mlieber/dcount/dcount.php?package=vampirtrace&get=VampirTrace-5.14.4.tar.gz"
      • tar -xvzf VampirTrace-5.14.4.tar.gz
      • cd VampirTrace-5.14.4
      • ./configure --prefix=$HOME/lib/vampirtrace --with-cuda-dir=<CUDA_ROOT>
      • make all -j
      • make install
    • add environment variable: export PATH=$PATH:$HOME/lib/vampirtrace/bin

Install

Mandatory environment variables

  • CUDA_ROOT: cuda installation directory, e.g. export CUDA_ROOT=<CUDA_INSTALL>
  • MPI_ROOT: mpi installation directory, e.g. export MPI_ROOT=<MPI_INSTALL>
  • extend your $PATH with helper tools for PIConGPU, see point, Checkout and Build PIConGPU step 2.2

Additional required environment variables (for optional libraries)

for splash and HDF5

  • SPLASH_ROOT: libsplash installation directory, e.g. export SPLASH_ROOT=$HOME/lib/splash
  • HDF5_ROOT: hdf5 installation directory, e.g. export HDF5_ROOT=$HOME/lib/hdf5
  • LD_LIBRARY_PATH: add path to $HOME/lib/hdf5/lib, e.g. export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$HOME/lib/hdf5/lib

for png support

  • PNGWRITER_ROOT: pngwriter installation directory, e.g. export PNGWRITER_ROOT=<PNGWRITER_INSTALL>

environment variables for tracing

  • VT_ROOT: VampirTrace installation directory, e.g. export PATH=$PATH:$HOME/lib/vampirtrace/bin

Installation notes

  • Be sure to build all libraries/dependencies with the same gcc version.
  • Never set a environment variable to the source folder, always set them to the installation directory.

Checkout and Build PIConGPU

This is an example how to use the modular building environment of PIConGPU.

  1. Setup PIConGPU home export PICHOME=$HOME

    • Note that the PICHOME path can be set to any other location.
  2. Setup directories: mkdir -p $PICHOME/src $PICHOME/build $PICHOME/paramSets $PICHOME/runs

    • $PICHOME/runs is the directory for PIConGPU simulation output
    • NOTE for HPC-Systems: Never write your simulation output to your home (~/ or $HOME) directory, but ask your admin about the mount point of your dedicated high-bandwidth file-system.
    • In most cases $WORK/runs, $WORKDIR/runs or /scratch/runs are the right places!
  3. Download the source code:

    1. git clone https://github.com/ComputationalRadiationPhysics/picongpu.git $PICHOME/src/picongpu
      • optional: update the source code with cd $PICHOME/src/picongpu && git pull
      • optional: change to a different branch with git branch (show) and git checkout <BranchName> (switch)
    2. export PATH=$PATH:$PICHOME/src/picongpu/src/tools/bin
    3. export PICSRC=$PICHOME/src/picongpu
  4. Create parameterset: $PICSRC/createParameterSet $PICSRC/examples/LaserWakefield/ $PICHOME/paramSets/case001

    • Clone the LWFA example to PICHOME/paramSets/case001
    • Edit $PICHOME/paramSets/case001/include/simulation_defines/param/* to change the physical configuration of this parameter set.
    • See $PICSRC/createParameterSet --help for more options.
    • optional: $PICSRC/createParameterSet $PICHOME/paramSets/case001/ $PICHOME/paramSets/case002
      • Clone the individual parameterSet case001 to case002.
  5. cd $PICHOME/build: go to the build directory to compile your first test

  6. Configure: $PICSRC/configure $PICHOME/paramSets/case001

    • optional: $PICSRC/configure --help
    • NOTE: makefiles are always created in the current directory
    • Configure one parameter set for one compilation
    • The script configure is only a wrapper for cmake. The real cmake command will be shown in the first line of the output.
    • case001 is the directory were the full compiled binary with all parameter files will be installed to
  7. Compile: make [-j]: compile PIConGPU with the current parameter set: case001

  8. Install: make install: copy binaries and params to a fixed data structure: case001

  9. cd $PICHOME/paramSets/case001: goto installed programm

  10. Run: Example run for the HPC System "hypnos" using a PBS batch system

    • optional: tbg --help
    • tbg -s qsub -c submit/0016gpus.cfg -t submit/hypnos/k20_profile.tpl $PICHOME/runs/testBatch01
    • This will create the directory $PICHOME/runs/testBatch01 were all simulation output will be written to. ( Again, do NOT use your home $HOME/runs - change this path!)
    • tbg will create a subfolder picongpu in the directory of the run with the same structure as case001. It can be reused to:
      • clone parameters as shown in step 3, by using this run as origin
      • create a new binary with configure (step 5): e.g. $PICSRC/configure -i $PICHOME/paramSets/case002 $PICHOME/runs/testBatch01

To build PIConGPU with tracing support, change the steps in the example to:

(5.) $PICSRC/configure ../projects/case001 -c "-DVAMPIR_ENABLE=ON"

(8.) cd $PICHOME/paramSets/case001: goto installed programm

(9.) tbg -s qsub -c submit/0016gpus.cfg -t submit/hypnos/k20_vampir_profile.tpl $PICHOME/runs/testBatchVampir


Notes:

This document uses markdown syntax: http://daringfireball.net/projects/markdown/

To create and up-to-date pdf out of this Markdown (.md) file use gimli. Anyway, please do not check in the binary pdf in our version control system!

  • sudo apt-get install rubygems wkhtmltopdf libxslt-dev libxml2-dev
  • sudo gem install gimli
  • gimli -f INSTALL.md

On OS X (Apple Macintosh) you can get gimli using the already installed ruby-gems (gem) or install a newer version using macports:

  1. install macports: http://www.macports.org/
  2. install rubygems
    sudo port install rb-rubygems
    rubygems is called gem by default
  3. install gimli
    sudo gem install gimli
    (installs all libraries automatically)
  4. convert documentation to pdf
    gimli -f INSTALL.md