Skip to content

A General Approach to Seismic Inversion Problems using Automatic Differentiation

License

Notifications You must be signed in to change notification settings

kailaix/ADSeismic.jl

Repository files navigation

ADSeismic: An Open Source High Performance Package for Automatic Differentiation (AD) based General Seismic Inversion

Documentation Build Status
Build Status

ADSeismic is built for general seismic inversion problems, such as estimating velocity model, source location and time function. The package implements the forward FDTD (finite difference time domain) simulation of acoustic and elastic wavefields and enables flexible inversions of parameters in the wave equations using automatic differentiation. Several features of this package includes:

  • Battery included: No adjoint state method codes required for building your own inversion models; Automatic differentiation is the work horse, making it unified approach to various seismic inversion problems such as full waveform inversion (FWI), earthquake location inversion, and source rupture inversion.
  • Neural Networks: Easy to integrate Neural Networks (NN) into seismic inversion.
  • High performance: Computational graph optimization using Tensorflow; Parallel computing using MPI.
  • (Multi-)GPU support: Support for GPU acceleration as well as multi-GPU (in theory TPUs are also supported).

Examples can be found int these papers:

A General Approach to Seismic Inversion with Automatic Differentiation

Integrating Deep Neural Networks with Full-waveform Inversion: Reparametrization, Regularization, and Uncertainty Quantification

Distributed Machine Learning for Computational Engineering using MPI

Learning generative neural networks with physics knowledge

Installation

ADSeismic.jl requires proper installation of ADCME.jl.

using Pkg
Pkg.add("ADCME")

This might take up to 20 minutes for complete installation.

Then install this package (ADSeismic.jl) by

using Pkg
Pkg.add("ADSeismic")

To enable GPU support, make sure nvcc is available on your machine, and then

using ADCME
use_gpu()

Use has_gpu() to check GPUs exist.

Demo

  • Acoustic Wave

Script: AcousticWave.jl

Result: Acoustic Wavefield

  • Elastic Wave

Script: ElasticWave.jl

Result: Elastic Wavefield

About

A General Approach to Seismic Inversion Problems using Automatic Differentiation

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages