FM Wavefront Tracer#

The wave front tracker routines solves boundary value ray tracing problems into 2D heterogeneous wavespeed media, defined by continuously varying velocity model calculated by 2D cubic B-splines.

Fast Marching wavefront tracking#

The method used here is Fast Marching wavefront tracking. In this algorithm the entire first arriving wavefronts from each source are calculated across the entire model in the form of a travel time field one per source. Travel times and ray paths are then calculated by tracing rays back from a desired receiver position to the source along the perpendicular to the wavefronts. This uses the Fast Marching method which is stable in highly heterogeneous velocity models. Here we implement a version of Fast Marching with source grid refinement for improved accuracy, as described in the papers below.

Rawlinson, N., de Kool, M. and Sambridge, M., 2006. “Seismic wavefront tracking in 3-D heterogeneous media: applications with multiple data classes”, Explor. Geophys., 37, 322-330.

de Kool, M., Rawlinson, N. and Sambridge, M. 2006. “A practical grid based method for tracking multiple refraction and reflection phases in 3D heterogeneous media”, Geophys. J. Int., 167, 253-270.

The python implementation here is a wrapper around the FMM code fm2dss.f90 of Nick Rawlinson.

Theoretical background#

The goal in travel-time tomography is to infer details about the velocity structure of a medium, given measurements of the minimum time taken for a wave to propagate from source to receiver. For seismic travel times, as we change our model, the route of the fastest path from source to receiver also changes. This makes the problem nonlinear, as raypaths also depend on the sought after velocity or slowness model.

Provided the ‘true’ velocity structure is not too dissimilar from our initial guess, travel-time tomography can be treated as a weakly non-linear problem. In this notebook we optionally treat the ray paths as fixed, and so it becomes a linear problem, or calculate rays in the velociuty model.

The travel-time of an individual ray can be computed as

\[t = \int_\mathrm{path} \frac{1}{v(\mathbf{x})}\,\mathrm{d}\mathbf{x}\]

This points to an additional complication: even for a fixed path, the relationship between velocities and observations is not linear. However, if we define the ‘slowness’ to be the inverse of velocity, \(s(\mathbf{x}) = v^{-1}(\mathbf{x})\), we can write $\(t = \int_\mathrm{path} {s(\mathbf{x})}\,\mathrm{d}\mathbf{x}\)$ which is linear.

We will assume that the object we are interested in is 2-dimensional slowness field. If we discretize this model, with \(N_x\) cells in the \(x\)-direction and \(N_y\) cells in the \(y\)-direction, we can express \(s(\mathbf{x})\) as an \(N_x \times N_y\) vector \(\boldsymbol{s}\).

For the linear case, this is related to the data by

\[d_i = A_{ij}s_j \]

where \(d_i\) is the travel time of the ith path, and where \(A_{ij}\) represents the path length in cell \(j\) of the discretized model.

For the nonlinear case, this is related to the data by

\[\delta d_i = A_{ij}\delta s_j \]

where \(\delta d_i\) is the difference in travel time, of the ith path, between the observed time and the travel time in the reference model. Here \(A_{ij}\) represents the path length in cell \(j\) of the discretized model. The parameters \(\delta s_j\) are slowness perturbations to the reference model.

Library usage#

All the methods comply to geo-espresso standards. Additionally, you can display paths together with the model when running fmm_instance.plot_model(model, paths=True), where fmm_instance is an instance of class FmmTomography.

Contribution Metadata for Fast Marching Wave Front Tracking

The wave front tracker routines solves boundary value ray tracing problems into 2D heterogeneous wavespeed media, defined by continuously varying velocity model calculated by 2D cubic B-splines.

Author:

Nick Rawlinson, Malcolm Sambridge

Contact:

Malcolm Sambridge (Malcolm.Sambridge@anu.edu.au)

Citation:
  • Rawlinson, N., de Kool, M. and Sambridge, M., 2006. Seismic wavefront tracking in 3-D heterogeneous media: applications with multiple data classes, Explor. Geophys., 37, 322-330.

  • Rawlinson, N. and Urvoy, M., 2006. Simultaneous inversion of active and passive source datasets for 3-D seismic structure with application to Tasmania, Geophys. Res. Lett., 33 L24313, 10.1029/2006GL028105

  • de Kool, M., Rawlinson, N. and Sambridge, M. 2006. A practical grid based method for tracking multiple refraction and reflection phases in 3D heterogeneous media, Geophys. J. Int., 167, 253-270

  • Saygin, E. 2007. Seismic receiver and noise correlation based studies in Australia, PhD thesis, Australian National University., 10.25911/5d7a2d1296f96

Extra website:

Software published on iEarth

Example usage for FmmTomography#

Code block below is generated automatically based on our tests and inspection of the example objects. We’d like to also refer you to the API Reference for more about the Espresso API.

 1import espresso
 2
 3# Create a FmmTomography object
 4my_fmm_tomography = espresso.FmmTomography(example_number=1)
 5
 6# Guaranteed API
 7model_size     = my_fmm_tomography.model_size
 8data_size      = my_fmm_tomography.data_size
 9null_model     = my_fmm_tomography.starting_model
10good_model     = my_fmm_tomography.good_model
11given_data     = my_fmm_tomography.data
12synthetic_data = my_fmm_tomography.forward(good_model)
13
14# Optional API
15example_desc       = my_fmm_tomography.description
16cov_matrix         = my_fmm_tomography.covariance_matrix
17inv_cov_matrix     = my_fmm_tomography.inverse_covariance_matrix
18jacobian           = my_fmm_tomography.jacobian(good_model)
19model_fig          = my_fmm_tomography.plot_model(good_model)

Additional attributes to explore: [call_wavefront_tracker, tmp_files, list_capabilities].

LICENCE#

Copyright 2021-2022 The Contributors All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS “AS IS” AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.