Next: Solving the eikonal equation
Up: Fomel: Fast marching
Previous: The theoretic grounds of
In this section, I derive a discrete traveltime computation procedure,
based solely on Fermat's principle, and show that on a Cartesian
rectangular grid it is precisely equivalent to the update formula
(1) of the first-order eikonal solver.
triangle
Figure 3 A geometrical scheme for the
traveltime updating procedure in two dimensions.
|
| data:image/s3,"s3://crabby-images/7a3ec/7a3eca19d60b4779b0fa62421b00774af891bdca" alt="triangle" |
For simplicity, let us focus on the two-dimensional case
. Consider a line segment with the end points A and B,
as shown in Figure 3. Let tA and tB denote the
traveltimes from a fixed distant source to points A and B,
respectively. Define a parameter
such that
at A,
at B, and
changes continuously on the line segment
between A and B. Then for each point of the segment, we can
approximate the traveltime by the linear interpolation formula
| data:image/s3,"s3://crabby-images/19524/195240b2939955373f27351654e54282afbd287b" alt="\begin{displaymath}
t (\xi) = (1-\xi) t_A + \xi t_B\;.\end{displaymath}" |
(9) |
Now let us consider an arbitrary point C in the vicinity of AB. If
we know that the ray from the source to C passes through some point
of the segment AB, then the total traveltime at C is
approximately
| data:image/s3,"s3://crabby-images/1ed99/1ed9973f1245dd0db715f4903618af646bd8aeeb" alt="\begin{displaymath}
t_C = t (\xi) + s_C\,\sqrt{\vert AB\vert^2 (\xi-\xi_0)^2 +
\rho_0^2}\;,\end{displaymath}" |
(10) |
where sC is the local slowness,
corresponds to the
projection of C to the line AB (normalized by the length |AB|),
and
is the length of the normal from C to
.
Fermat's principle states that the actual ray to C corresponds to a
local minimum of the traveltime with respect to raypath perturbations.
According to our parameterization, it is sufficient to find a local
extreme of tC with respect to the parameter
. Equating the
derivative to zero, we arrive at the equation
| data:image/s3,"s3://crabby-images/bca26/bca26ecda07714b74a32e5b99966be58ca76a21c" alt="\begin{displaymath}
t_B - t_A + \frac{s_C\,\vert AB\vert^2\,(\xi-\xi_0)}
{\sqrt{\vert AB\vert^2 (\xi-\xi_0)^2 + \rho_0^2}} = 0\;,\end{displaymath}" |
(11) |
which has (as a quadratic equation) the explicit solution for
:
| data:image/s3,"s3://crabby-images/c5baa/c5baa972890625fc4d4725d5453224f0b9634a6c" alt="\begin{displaymath}
\xi = \xi_0 \pm \frac{\rho_0\,(t_A - t_B)}
{\vert AB\vert\,\sqrt{s_C^2\,\vert AB\vert^2 - (t_A - t_B)^2}}\;.\end{displaymath}" |
(12) |
Finally, substituting the value of
from (12) into
equation (10) and selecting the appropriate branch of the
square root, we obtain the formula
| data:image/s3,"s3://crabby-images/c67f7/c67f78fd909744cadf006c765cd04cf27a593bf1" alt="\begin{eqnarray}
c\,t_C & = & \rho_0\,\sqrt{s_C^2 c^2 - (t_A - t_B)^2} +
c\,t_...
... - (t_A - t_B)^2} +
a\,t_A\,\cos{\beta} + b\,t_B\,\cos{\alpha}\;,\end{eqnarray}" |
|
| (13) |
where c = |AB|, a = |BC|, b = |AC|, angle
corresponds to
, and angle
corresponds to
in the triangle ABC (Figure 3).
square
Figure 4 A geometrical scheme for
traveltime updating on a rectangular grid.
|
| data:image/s3,"s3://crabby-images/ea52c/ea52c3094b7c35eba7b4c76eb85ec0e19a7a5c7e" alt="square" |
To see the connection of formula (13) with the eikonal
difference equation (1), we need to consider the case
of a rectangular computation cell with the edge AB being a diagonal
segment, as illustrated in Figure 4. In this case,
,
,
, and formula (13) reduces to
| data:image/s3,"s3://crabby-images/ba85c/ba85cc8e471a0ba4ec4d6066db6f7927ac9f08b5" alt="\begin{displaymath}
t_C = \frac{ab\,\sqrt{s_C^2 (a^2 + b^2) - (t_A - t_B)^2} + a^2\,t_A + b^2\,t_B}
{a^2+b^2}\;.\end{displaymath}" |
(14) |
We can notice that (14) is precisely equivalent to the
solution of the quadratic equation (13), which in our
new notation takes the form
| data:image/s3,"s3://crabby-images/535f8/535f8e78959e41254e2090c585eeb4ea3c3bd761" alt="\begin{displaymath}
\left(\frac{t_C - t_A}{b}\right)^2 +
\left(\frac{t_C - t_B}{a}\right)^2 = s_C^2\;.\end{displaymath}" |
(15) |
What have we accomplished by this analysis? First, we have derived a
local traveltime computation formula for an arbitrary grid. The
derivation is based solely on Fermat's principle and a local linear
interpolation, which provides the first-order accuracy. Combined with
the fast marching evaluation order, which is also based on Fermat's
principle, this procedure defines a complete algorithm of
first-arrival traveltime calculation. On a rectangular grid, this
algorithm is exactly equivalent to the fast marching method of
Sethian (1996a) and Sethian and Popovici (1997). Second, the derivation
provides a general principle, which can be applied to derive analogous
algorithms for other eikonal-type (Hamilton-Jacobi) equations and
their corresponding variational principles.
Next: Solving the eikonal equation
Up: Fomel: Fast marching
Previous: The theoretic grounds of
Stanford Exploration Project
9/12/2000