This guide provides step-by-step instructions for compiling and running GROOPS from scratch.
While GROOPS is intended to be a standalone software package, some functionality depends on external libraries. Hard dependencies are:
- the Expat XML parser
- an implementation of the Linear Algebra Package (LAPACK), for example:
Additional libraries extend the feature set of GROOPS and can be optionally enabled at compile time. At the moment, these include:
- NetCDF for reading and writing NetCDF files
- zlib for reading and writing compressed files
- the Essential Routines for Fundamental Astronomy (liberfa) for high-precision Earth rotation
Another optional dependency is an implementation of the Message Passing Interface standard (MPI, for example MPICH or Microsoft MPI). Resource intensive tasks and algorithms are designed and implemented to be optionally run in parallel on distributed systems.
To visualize data sets, GROOPS requires an installation of the Generic Mapping Tools (GMT).
You can download the source code of a specific version on the Releases page, or clone the repository to always get the latest updates:
git clone https://github.com/groops-devs/groops.git
GROOPS under Windows requires CMake, and 64bit C++14 and Fortan compilers.
A convenient way to install all required tools is through MSYS2.
This installation guide assumes that the GROOPS source code is located in C:\groops
.
-
Download the MSYS2 installer and follow the installation guide.
-
Important: After successful installation, close the MSYS2 terminal from step 1 and open the MSYS2 MinGW 64-bit terminal through
Start Menu > MSYS2 64-bit > MSYS2 MinGW 64-bit
.The command prompt in the terminal window should now read
username@hostname MINGW64
. -
Install compilers, cmake, expat, OpenBLAS, and LAPACK:
pacman -S mingw-w64-x86_64-toolchain mingw-w64-x86_64-cmake expat mingw64/mingw-w64-x86_64-openblas
-
(Optional) Install the NetCDF library:
pacman -S mingw-w64-x86_64-netcdf
-
(Optional) Download and install liberfa:
5.1. Install the
tar
utility and required build tool:pacman -S tar make
5.2. Download and build the ERFA library:
mkdir -p /c/groops/lib && cd /c/groops/lib wget https://github.com/liberfa/erfa/releases/download/v1.7.0/erfa-1.7.0.tar.gz tar -xvf erfa-1.7.0.tar.gz cd erfa-1.7.0 ./configure make make install
-
(Optional) Install Microsoft MPI:
6.1 Download and install the Microsoft MPI.
6.2 Install the MSYS2
msmpi
package:pacman -S mingw-w64-x86_64-msmpi
-
Create the build directory and compile GROOPS:
mkdir /c/groops/source/build && cd /c/groops/source/build cmake.exe .. -G "MinGW Makefiles" -DCMAKE_BUILD_TYPE=Release mingw32-make.exe
-
Make sure to also read the post-installation steps.
The GROOPS GUI is based on Qt and is tested with Qt version 5.15.1. Precompiled Windows binaries of the GROOPS GUI are provided with each release. To compile the GUI yourself, you need to:
-
Download and install Qt (registration required).
-
When prompted to choose which Qt components to install, select
Select Package Categories > LTS
and then selectQt > Qt 5.15.1
or a newer version. UnderDeveloper and Designer Tools
,Qt Creator Debugger Support
,Debugging Tools for Windows
,cmake
, andNinja
should be selected automatically. -
Open the project file
C:\groops\gui\groopsGui.pro
in Qt Creator and build the project.
The Generic Mapping Tools (GMT) are an optional dependency of GROOPS and enable the generation of high-quality figures. GMT provides Windows binaries which can be easily installed. The current GROOPS release is tested against GMT version 6.0.0.
After the installation of GROOPS and GROOPS GUI, we recommend some post-installation configuration steps to make working with GROOPS easier.
-
To use the GROOPS and GROOPS GUI binaries without directory prefix, you have to add the required directories to the system path.
1.1. Open the Control Panel through the Windows Start Menu:
Windows System > Control Panel
.1.2. In the Control Panel window, go to
User Accounts > User Accounts
.1.3. There you should click on
Change my environment variables
, which will open a new window.1.4. In the environment variable window, select
Path
and clickEdit...
. A pop-up window will appear where you can add the following directories to your system path:"C:\groops\bin" "C:\msys64\mingw64\bin" "C:\Program Files\Microsoft MPI\Bin"
In case you manually compiled the GUI, additionally add the directory:
"C:\Qt\5.15.1\mingw81_64\bin"
-
(Optional) Set the environment variable
OPENBLAS_NUM_THREADS
to the number of threads to use for matrix operations.
Most Linux distributions provide all GROOPS dependencies through their package managers. We provide a detailed installation guide for Ubuntu and OpenSUSE, the installation steps are however very similar for other distributions.
The installation procedure for Ubuntu is representative for all Debian based distributions,
however the individual package names may differ.
Check your distribution's documentation to find the correct packages.
This installation guide assumes that the GROOPS source code is located in $HOME/groops
.
-
First, make sure your system is up to date:
sudo apt update && sudo apt upgrade
-
Install dependencies and build tools:
sudo apt-get install g++ gfortran cmake libexpat1-dev libopenblas-dev
-
(Optional) Install the NetCDF development package:
sudo apt-get install libnetcdf-dev
-
(Optional) Install liberfa development packages:
sudo apt-get install liberfa-dev
-
(Optional) Install MPI development packages:
sudo apt-get install mpi-default-dev
-
Create the build directory and compile GROOPS:
mkdir $HOME/groops/source/build && cd $HOME/groops/source/build cmake .. -DCMAKE_BUILD_TYPE=Release make
-
Make sure to also read the post-installation steps.
The GROOPS GUI depends on Qt packages. To install the required packages, run:
sudo apt-get install qtbase5-dev
Then, change into the gui
directory and compile the source code:
cd $HOME/groops/gui
qmake
make
Ubuntu provides packages for the Generic Mapping Tools:
sudo apt-get install gmt gmt-gshhg
-
First, make sure your system is up to date:
sudo zypper up
-
Install dependencies and build tools:
sudo zypper install gcc-c++ gcc-fortran cmake libexpat-devel openblas-devel
-
(Optional) Install the NetCDF development package:
sudo zypper install netcdf-devel
-
(Optional) Install liberfa development packages:
4.1 Add the OpenSUSE Science Repository (change OpenSUSE release version if necessary):
sudo zypper addrepo http://download.opensuse.org/repositories/science/openSUSE_Leap_15.2/ science
4.2 Install the required package:
sudo zypper install erfa-devel
-
(Optional) Install MPI development packages:
sudo zypper install mpich-devel
-
Create the build directory and compile GROOPS:
mkdir $HOME/groops/source/build && cd $HOME/groops/source/build cmake .. make
-
Make sure to also read the post-installation steps.
The GROOPS GUI depends on Qt packages. To install the required packages, run:
sudo zypper install libqt5-qtbase-devel
Then, change into the gui
directory and compile the source code:
cd $HOME/groops/gui
qmake-qt5
make
The OpenSUSE packages for the Generic Mapping Tools are available in the GEO
repository
(change OpenSUSE release version if necessary):
sudo zypper addrepo http://download.opensuse.org/repositories/Application:/Geo/openSUSE_Leap_15.2/ GEO
Then install the packages:
sudo zypper install GMT GMT-doc GMT-coastlines
After the installation of GROOPS and GROOPS GUI, we recommend some post-installation configuration steps to make working with GROOPS easier.
-
To use the GROOPS and GROOPS GUI binaries without directory prefix, you have to add the required directories to the system path:
echo "export PATH=$PATH:$HOME/groops/bin" >> $HOME/.bashrc source $HOME/.bashrc
-
(Optional) Set the environment variable
OPENBLAS_NUM_THREADS
to the number of threads to use for matrix operations.