-
Notifications
You must be signed in to change notification settings - Fork 55
Installation notes
These are notes for installing Dales on different systems. (Work in progress, may not be completely accurate/sufficient/up to date. Please comment or fix if you find mistakes).
General requirements for installing Dales:
- NetCDF
- MPI
- a Fortran compiler, e.g. gfortran
- cmake
- make
- doxygen, dot, latex (optional, for building the documentation)
- HYPRE library (optional, for iterative Poisson solver)
- FFTW3 library (optional, for higher performance)
The following optional options can be provided on the CMake command line to control optional features, e.g. the FFTW library, the HYPRE library and select between single and double precision.
Produce a debug build. A debug build is much slower than a Release build, but contains more error checking.
-DCMAKE_BUILD_TYPE=Debug (default Release)
Optional alternative Poisson solvers (since v4.3)
-DUSE_FFTW=True (default False)
-DUSE_HYPRE=True (default False)
Choose between single and double precision for the main prognostic fields and for the Poisson solver (from v4.4)
-DPOIS_PRECISION=32 (default 64)
-DFIELD_PRECISION=32 (default 64)
Note that to use HYPRE or FFTW, the library needs to be enabled at compile time and selected at runtime with settings in the &SOLVER section of the namoptions input file. See Alternative Poisson solvers.
-DPOIS_PRECISION=32
and -DUSE_HYPRE=True
can be used together, but HYPRE is 64-bit only, so only use this if it is really what you want.
sudo dnf install gcc-gfortran cmake netcdf-fortran-devel openmpi-devel
module load mpi/openmpi
git clone https://github.com/dalesteam/dales.git
cd dales
mkdir build
cd build
cmake ..
make
The command module load mpi/openmpi
is needed also before launching Dales - it has to be
run once in every new terminal (unless added to the shell initialization files).
Use brew to install the dependencies.
# first install homebrew
brew install gcc make cmake open-mpi netcdf-fortran git fftw
git clone https://github.com/dalesteam/dales.git
cd dales
mkdir build
export SYST=gnu-fast
cd build
cmake .. -DUSE_FFTW=True
make -j 4
The DALES executable is now at dales/build/src/dales4.4
Note that brew by default installs gfortran10, which does not work directly with DALES versions older than 4.3 (one needs to add -std=legacy to the compiler options).
Other useful programs:
# ncview for viewing netCDF files
# cdo for processing netCDF data e.g. merging the 2D and 3D output files
# wget for downloading files from the command line
brew install cdo ncview wget
sudo apt install git cmake gfortran netcdf-bin libnetcdf-dev libnetcdff-dev libopenmpi-dev libhypre-dev libfftw3-dev
# netcdf-bin is included for the ncdump tool, not directly needed
sudo apt install cdo ncview
# extra: tools for working with netCDF data
git clone https://github.com/dalesteam/dales.git
cd dales
mkdir build
export SYST=gnu-fast
cd build
cmake .. -DUSE_FFTW=True
make -j 4
DALES can be run in Ubuntu using WSL. Install Ubuntu tutorial, then follow the steps for Ubuntu above. Another route is to run DALES in Linux in a virtual machine. A VirtualBox image with DALES pre-installed is available here
Install dependencies with the following command, then compile as usual.
sudo aptitude install libnetcdf-dev mpich gfortran make cmake
Note: -march=native does not work on ARM with gfortran 4.9, which comes with the old Debian Jessie. In the new release it is supposed to work.
Performance: 32 us / (grid point * time step) single core, 46 us / (grid point * time step) with 4 cores on a Raspberry Pi 3B. 60 s Bomex. Compiled with -O3, gfortran 4.9.
With -Ofast: 25 us / (grid point * step)
sudo apt install libnetcdf-dev libnetcdff-dev openmpi-bin gfortran make cmake
git clone https://github.com/dalesteam/dales.git
cd dales
mkdir build
export SYST=gnu-fast
cd build
cmake ..
make
Notes:
- with mpich instead of OpenMPI, DALES crashes in INIT_MPI.
- gcc and gfortran shipped is version 8.3.0.
-march=native
and thusSYST=gnu-fast
now works.
Installation notes for old systems
Tested 6.2.2020. On Eagle, compilation must be done in an interactive job, since the module system does not work on the login node. The module netcdf/4.4.1.1_impi-5.0.3_icc-15.0.3 provides a consistent set of netCDF with Fortran bindings. A more recent cmake than the default is also required.
# start interactive job
srun --pty -N1 --ntasks-per-node=1 -p fast -t 60 /bin/bash
git clone https://github.com/dalesteam/dales
cd dales
# git checkout to4.3_Fredrik # optionally check out another branch
mkdir build
cd build
export SYST=lisa-intel
export MODULEPATH=/home/plgrid-groups/plggvecma/.qcg-modules:$MODULEPATH
module load vecma/common/cmake
module load netcdf/4.4.1.1_impi-5.0.3_icc-15.0.3
cmake ..
make -j 4
Tested in May 2020.
git clone https://github.com/dalesteam/dales
module load hdf5/gcc5/1.10.1
module load netcdf/gcc5
module load netcdf-fortran/gcc5/4.4.4
module load openmpi/gcc5/3.0.0
export SYST=gnu-fast
cd dales
# git checkout to4.3 # optionally check out a branch
mkdir build
cd build
cmake ..
make
# load the same modules
# cd to the case directory
~/dales/build/src/dales4 namoptions.001