Next: Computation of amplitudes
Up: ALGORITHM
Previous: Slowness model
A good finite difference scheme should incorporate the relevant physical law
into its representation. Extrapolating traveltimes is like propagating
wavefronts; Huygens' principle and Fermat's principle should be
respected. Extrapolating the gradients of traveltimes is like extending
rays; Snell's law should be respected. Because these two extrapolations
simulate the same physical phenomenon, the algorithm to do one can be
translated and used to do the other. The algorithm described below
does two extrapolations simultaneously.
vfdtime1
Figure 1 The grid and notations.
|
| data:image/s3,"s3://crabby-images/7e7fc/7e7fc87313a51509aa12706d9edf50eea5339f13" alt="vfdtime1" |
The eikonal equation in polar coordinates is as follows:
| data:image/s3,"s3://crabby-images/710c4/710c48faaa451cacfddfaa942a251e8123686f6d" alt="\begin{displaymath}
\tau^2_r+{1 \over r^2}\tau^2_\theta=m^2(\theta,r),\end{displaymath}" |
(17) |
where subscripts r and
denote the partial derivatives with respect
to r and
, respectively. The initial condition is
data:image/s3,"s3://crabby-images/d20b9/d20b9e781d55c7ee74cc38a8e1b5006cba237eeb" alt="\begin{displaymath}
\tau(\theta,r)=m(\theta,r)r \ \ \ \ \ \ \hbox{for}\ r \le r_0,\end{displaymath}"
where r0 defines a circle centered at the source point, within which
the slowness is constant. Starting from this circle, we extrapolate
the traveltime field in the radial directions. As indicated in
Figure
, I use
to denote the traveltime at
grid point
. Then, in the jth step of the
traveltime extrapolation, we know the traveltime
for all i and we want to find the traveltime
for all i.
According to Snell's law, the tangential component of the traveltime gradient
to a boundary is continuous across the boundary.
I define ui,j to be the tangential component
of the traveltime gradient to the constant radius boundary.
If we approximate the wavefront within a cell with a local plane wave,
then we have
| data:image/s3,"s3://crabby-images/90636/9063689a1d28bebe79bab88c122a270c5082e3d2" alt="\begin{displaymath}
u_{i,j}={1 \over r_j}{\partial \tau \over \partial \theta}
={\tau_{i+1,j}-\tau_{i,j} \over r_j\Delta \theta}.\end{displaymath}" |
(18) |
The orthogonal component of the traveltime gradient can be computed
from the eikonal equation as follows:
| data:image/s3,"s3://crabby-images/d396d/d396db42d118da4d8442e3fc9b042c499f290b22" alt="\begin{displaymath}
w_{i,j}=\sqrt{s^2_{i,j}-u^2_{i,j}}.\end{displaymath}" |
(19) |
These two components determine the propagation direction of the local
plane wave. If we define
| data:image/s3,"s3://crabby-images/0e45b/0e45bc8c55d3da70fb26d33a9f569dd2bdfed43b" alt="\begin{displaymath}
\hat{w}_{i,j}={\tau_{i,j+1}-\tau_{i,j} \over \Delta r}\end{displaymath}" |
(20) |
then we can use the principles of Podvin and Lecomte's scheme (1991) to
calculate
in the following four cases:
- 1.
and
data:image/s3,"s3://crabby-images/d3ac7/d3ac77af1d194c526fe8c4352884d05928f1976e" alt="\begin{displaymath}
\hat{w}_{i,j}=\min(w_{i-1,j},w_{i,j},s_{i-1,j},s_{i,j})\end{displaymath}"
- 2.
and ui,j > 0
data:image/s3,"s3://crabby-images/56cd8/56cd8caf593b0d45bd96bc487e018e6e481ed5da" alt="\begin{displaymath}
\hat{w}_{i,j}=\min(w_{i-1,j},s_{i,j})\end{displaymath}"
- 3.
- ui-1,j < 0 and
data:image/s3,"s3://crabby-images/6a7fd/6a7fd098816ed5f8405208663d73334d6f05fbb7" alt="\begin{displaymath}
\hat{w}_{i,j}=\min(w_{i,j},s_{i-1,j})\end{displaymath}"
- 4.
- ui-1,j < 0 and ui,j > 0
data:image/s3,"s3://crabby-images/8d235/8d235fa3da101f3f1fd78269c1a735a400175ef6" alt="\begin{displaymath}
\hat{w}_{i,j}=\min(s_{i-1,j},s_{i,j}).\end{displaymath}"
The appearance of slowness in these formulas indicates that
the possible refractions along the constant
boundary are
taken into account. The ``min'' function ensures that case gives
the minimum traveltime.
The causality of the extrapolation requires that
| data:image/s3,"s3://crabby-images/59aa9/59aa9b2d7bdd5ba137205ed4a75e9564478792db" alt="\begin{displaymath}
w_{i-1,j} \gt s_{i-1,j}{\Delta r \over \sqrt{\Delta r^2+(r_j...
...j} \gt s_{i,j}{\Delta r \over \sqrt{\Delta r^2+(r_j\theta)^2}}.\end{displaymath}" |
(21) |
If we adapt the step size
of the extrapolation to the
propagation direction of the local plane wave and choose
| ![\begin{displaymath}
\Delta r = \min_{\hbox{all}\ i}[
r_j\Delta \theta \left\vert{w_{i,j} \over u_{i,j}}\right\vert],\end{displaymath}](img49.gif) |
(22) |
then the inequalities in equation (21) are guaranteed.
Solving equation (20) for ti,j+1 gives
| data:image/s3,"s3://crabby-images/0f30c/0f30cac8de72ba46074d1b44425780d2246cceed" alt="\begin{displaymath}
t_{i,j+1}=t_{i,j}+\hat{w}_{i,j}\Delta r \ \ \ \ \ \ \ \ \hbox{for all}\ i,\end{displaymath}" |
(23) |
which completes one step of the extrapolation.
The implementation of this algorithm is quite simple and the program is fully
vectorizable. For example, the computation of
for all i
can be coded as follows:
do i = 1,n
sign1 = 0.5*(1.+sign(1.,u(i-1)))
sign2 = 0.5*(1.+sign(1.,-u(i)))
hatw1 = sign1*min(w(i-1),s(i))+(1.-sign1)*s(i-1)
hatw2 = sign2*min(w(i),s(i-1))+(1.-sign2)*s(i)
hatw(i) = min(hatw1,hatw2)
enddo
One problem that has not been addressed yet is the possibility of
refractions along the constant radius boundaries, which may initiate
wave propagations toward the source. In practice, such situation
seldom happen. To make the algorithm more complete, I handle such situation
by adopting Podvin and Lecomte's method in polar coordinates and
performing backward extrapolation as necessary. After obtaining
the traveltimes in polar coordinates, I map them to Cartesian
coordinates through interpolation.
Next: Computation of amplitudes
Up: ALGORITHM
Previous: Slowness model
Stanford Exploration Project
12/18/1997