/SeisCL

Software for viscoelastic full waveform inversion on large heterogeneous clusters

Primary LanguageJupyter NotebookGNU General Public License v3.0GPL-3.0

SeisCL

SeisCL is a program to perform seismic modeling, full waveform inversion and reverse time migration. Modeling is performed with finite-difference in the time-domain, and can be either 3D or 2D, isotropic acoustic, elastic or viscoelastic. SeisCL can be run either on GPUs with CUDA or OpenCL, or CPUs with OpenCL. Model decomposition and shot parallelization allows using multiple GPUs/nodes. Although written is C/CUDA/OpenCL, a python interface (Python 3) is provided for implementing the inversion/imaging workflows.

Full documentation can be found at readthedocs.

Cite this publication if you use this software:

Fabien-Ouellet, G., Gloaguen, E., & Giroux, B. (2016). Time-domain seismic modeling in viscoelastic media for full waveform inversion on heterogeneous computing platforms with OpenCL. Computers & Geosciences. http://dx.doi.org/10.1016/j.cageo.2016.12.004

1.0 Installation

You should clone this repository

git clone https://github.com/gfabieno/SeisCL.git

Two options are provided to install the software.

1.1 Use Docker (easiest, but limited)

This method only works with Nvidia GPUs, and is restricted to a single node execution. However, multi-GPU domain decomposition is supported.

You first need to install Docker Engine, following the instructions here. Because SeisCL uses GPUs, you also need to install the Nvidia docker. For the later to work, Nvidia drivers should be installed. Then, when in SeisCL repository, build the docker image as follows:

docker build -t seiscl:v0

You can then directly use the python interface to launch SeisCL.

1.2 Compile from source (all features available)

To obtain all features (multi-node, CUDA and OpenCL, GPUs and CPUs), you need to compile from source. There are several prerequisites:

  • HDF5, for input and ouput files. On Unix systems, the easiest way is to install with a package manager (yum, apt-get). On a cluster, it should be already available.
  • Option 1: CUDA. Install CUDA if SeisCL will be mainly used on NVidia GPUs (most likely case). It is faster than OpenCL and supports SeisCL FP16 modes, which are more or less 2x faster than conventional mode.
  • Option 2: OpenCL. This option is slightly slower on Nvidia GPUs for large models, but faster for smaller models (because of faster JIT compilation). It also supports Intel and AMD CPUs and GPUs. To install OpenCL on Linux, see this very good tutorial.
  • (Optional) An MPI Library, either OpenMPI or MPICH. If working on a cluster, this should already be installed!
1.2.1 Compiling with Cmake

You can compile SeisCL with cmake. This option is recommanded over using make because of the better portability. To compile, first create a build directory.

mkdir build;
cd build

Then configure and build SeisCL:

cmake .. -DUSECUDA=1
cmake --build .

Different options are provided to compile with different librairies:

  • USECUDA -- Use this option to use CUDA instead of OpenCL
  • USEMPI -- If true, compile with MPI support. Default to ON.

Finally, add the SeisCL directory to the PATH:

echo "export PATH=$(pwd):\$PATH" >> ~/.bashrc
source ~/.bashrc
1.2.2 Compiling with make

If you want to ues make instead, a Makefile is provided, which may need to be modified to your specific system. To compile, just run:

cd src;
make all
echo "export PATH=$(pwd):\$PATH" >> ~/.bashrc
source ~/.bashrc

Several options can be passed to make to compile different flavors of SeisCL:

  • api -- Use api=cuda to build SeisCL with Cuda instead of OpenCL
  • nompi -- Use nompi=1 to compile without MPI support.
  • H5LIB -- Use option to set the path to hdf5 libraries (libhdf5.so).
  • H5LIB -- Use this option to set the path to hdf5 headers.
  • H5CC -- Define the desired compiler, even if the h5cc wrapper is found.

For example, to compile with Cuda, without MPI support with gcc:

make all api=cuda nompi=1 H5CC=gcc

1.3 Install python wrapper

Once SeisCL is compiled and the directory of the binary is found in PATH, the python wrapper must be added to your python environment You can use pip in the root directory of the repo

pip install -e .

2.0 Testing

Several tests can be found in ./tests`, wihtin two scripts:

  • test_consistency.py, which test that model decomposition, floating point precision options and gradient calculation are accurate and working,
  • test_accuracy.py, which contains comparison with different analytical solutions. For the moment, we have analytical solutions for a 3D and 2D homogenous (visco)elastic unbounded space and 3D and 2D solutions for an elastic half-space (Lamb and Garvins's problem). See those solutions in tests/analytical.

To test for all analytical solutions with plots:

cd tests
python test_analytics.py --plot=1

To perform all consistency tests:

python test_consistency.py

Test scripts are a good start to understand how to use the python interface to SeisCL.