Next: EXAMPLES
Up: ALGORITHM
Previous: Computation of traveltimes
To compute the amplitudes, we need to solve equations (14)
and (16). In polar coordinates, these two equations become:
| data:image/s3,"s3://crabby-images/76159/76159f7f5b6977eb92ec18cbcbeee3c4d2b4923a" alt="\begin{displaymath}
\tau_r\gamma_r+{1 \over r^2}\tau_\theta\gamma_\theta=0\end{displaymath}" |
(24) |
and
| data:image/s3,"s3://crabby-images/a153e/a153e8f2f13691ee803673d3dbbaf2e4d9772128" alt="\begin{displaymath}
\tau_r\eta_r+{1 \over r^2}\tau_\theta\eta_\theta=m(x_0,z_0),\end{displaymath}" |
(25) |
respectively. Because the traveltimes are known now, these
two equations are first-order linear partial differential equations
in
and
. The
algorithms for solving these two equations are very similar to the one for
traveltime calculation. To solve equation (24), we
replace equations (18) to (20) by
| data:image/s3,"s3://crabby-images/1ec8c/1ec8cd8ea9dfcf74a75baa8b6e97300b58fcda94" alt="\begin{displaymath}
f_{i,j} = {\gamma_{i+1,j}-\gamma_{i,j} \over r_j\Delta\theta},\end{displaymath}" |
(26) |
| data:image/s3,"s3://crabby-images/244c1/244c128ef445d53453e90f627f22178a3281264d" alt="\begin{displaymath}
g_{i,j} = -{u_{i,j} \over w_{i,j}}f_{i,j}\end{displaymath}" |
(27) |
and
| data:image/s3,"s3://crabby-images/be452/be452c4ef3aeeb441a321932ccefe52856b61e80" alt="\begin{displaymath}
\hat{g}_{i,j} = {\gamma_{i,j+1}-\gamma_{i,j} \over \Delta r},\end{displaymath}" |
(28) |
respectively. As in the calculation of
,
the calculation of
also involves four different cases:
- 1.
and
data:image/s3,"s3://crabby-images/9e421/9e42138c8443cf20c8a6dd616e3eda7960b4142b" alt="\begin{displaymath}
\hat{g}_{i,j}=\left\{
\begin{array}
{ll}
g_{i-1,j} & \hbox{i...
...\ \hat{w}_{i,j}=s_{i-1,j}\ \hbox{or}\ s_{i,j}\end{array}\right.\end{displaymath}"
- 2.
and ui,j > 0
data:image/s3,"s3://crabby-images/2d7e1/2d7e11ef8e8b999ba99bc137526b3a2291848751" alt="\begin{displaymath}
\hat{g}_{i,j}=\left\{
\begin{array}
{ll}
g_{i-1,j} & \hbox{i...
...-1,j} \\ 0 & \hbox{if}\ \hat{w}_{i,j}=s_{i,j}\end{array}\right.\end{displaymath}"
- 3.
- ui-1,j < 0 and
data:image/s3,"s3://crabby-images/2cc19/2cc194447952e164127adb187e8ee85b7971c66b" alt="\begin{displaymath}
\hat{g}_{i,j}=\left\{
\begin{array}
{ll}
g_{i,j} & \hbox{if}...
...,j} \\ 0 & \hbox{if}\ \hat{w}_{i,j}=s_{i-1,j}\end{array}\right.\end{displaymath}"
- 4.
- ui-1,j < 0 and ui,j > 0
data:image/s3,"s3://crabby-images/b6baf/b6bafe5787fa8518b02be8fdb760d92633c30702" alt="\begin{displaymath}
\hat{g}_{i,j}=0\end{displaymath}"
If
and
are calculated in one subroutine,
then the implementation is simple and the program is fully vectorizable,
which is shown as follows:
do i = 1,n+1
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)
sign3 = 0.5*(1.+sign(1.,w(i-1)-s(i)))
sign4 = 0.5*(1.+sign(1.,w(i)-s(i-1)))
sign5 = 0.5*(1.+sign(1.,hatw2-hatw1))
hatg1 = sign1*(1.-sign3)*g(i-1)
hatg2 = sign2*(1.-sign4)*g(i)
hatg(i) = sign5*hatg1+(1.-sign5)*hatg2
enddo
From equation (28), we have
| data:image/s3,"s3://crabby-images/43a55/43a5508a9f31768ee21e0942895e54544fa38b68" alt="\begin{displaymath}
\gamma_{i,j+1}=\gamma_{i,j}+\hat{g}_{i,j}\Delta r.\end{displaymath}" |
(29) |
I can apply Podvin and Lecomte's method to the computation of function
so that backward extrapolation can be handled.
To solve equation (25), I use
![\begin{displaymath}
\eta_r = {1 \over \tau_r}[m(x_0,z_0)-{1 \over r^2}\tau_\theta\eta_\theta]\end{displaymath}](img63.gif)
to extrapolate the function
. Referring to the algorithm for
calculating
and
, one can
easily construct the algorithm for calculating function
.
The Jacobian function in polar coordinates can be determined
from (13) as follows:
| data:image/s3,"s3://crabby-images/557ce/557ce1ff86edd931fa78a7b4d169ad35f9d841f6" alt="\begin{displaymath}
\vert J(r,\theta)\vert = {1 \over \sqrt{\left({\partial \gam...
...t)^2+\left({\partial \gamma \over r\partial \theta}\right)^2}}.\end{displaymath}" |
(30) |
We can either map this Jacobian function to Cartesian coordinates and
use equation (11) to calculate the amplitudes, or calculate the
amplitudes in polar coordinates and then map them to Cartesian
coordinates.
Next: EXAMPLES
Up: ALGORITHM
Previous: Computation of traveltimes
Stanford Exploration Project
12/18/1997