from devito import *
from examples.seismic.source import DGaussSource, TimeAxis
from examples.seismic import plot_image
import numpy as np
from sympy import init_printing, latex
='mathjax') init_printing(use_latex
05 - First order acoustic modeling on a staggered grid
# Initial grid: 1km x 1km, with spacing 100m
= (2000., 2000.)
extent = (81, 81)
shape = SpaceDimension(name='x', spacing=Constant(name='h_x', value=extent[0]/(shape[0]-1)))
x = SpaceDimension(name='z', spacing=Constant(name='h_z', value=extent[1]/(shape[1]-1)))
z = Grid(extent=extent, shape=shape, dimensions=(x, z)) grid
# Timestep size from Eq. 7 with V_p=6000. and dx=100
= 0., 200.
t0, tn = 1e2*(1. / np.sqrt(2.)) / 60.
dt = TimeAxis(start=t0, stop=tn, step=dt)
time_range
= DGaussSource(name='src', grid=grid, f0=0.01, time_range=time_range, a=0.004)
src = [1000., 1000.] src.coordinates.data[:]
#NBVAL_SKIP
src.show()
# Now we create the velocity and pressure fields
= TimeFunction(name='p', grid=grid, staggered=NODE, space_order=2, time_order=1)
p = VectorTimeFunction(name='v', grid=grid, space_order=2, time_order=1) v
from devito.finite_differences.operators import div, grad
= grid.stepping_dim
t = grid.time_dim
time
# We need some initial conditions
= 4.0
V_p = 1.
density
= 1/density
ro = V_p*V_p*density
l2m
# The source injection term
= src.inject(field=p.forward, expr=src)
src_p
# 2nd order acoustic according to fdelmoc
= Eq(v.forward, solve(v.dt - ro * grad(p), v.forward))
u_v_2 = Eq(p.forward, solve(p.dt - l2m * div(v.forward), p.forward)) u_p_2
u_v_2
\(\displaystyle \left[\begin{matrix}v_x(t + dt, x + h_x/2, z)\\v_z(t + dt, x, z + h_z/2)\end{matrix}\right] = \left[\begin{matrix}dt \left(1.0 \frac{\partial}{\partial x} p(t, x, z) + \frac{v_x(t, x + h_x/2, z)}{dt}\right)\\dt \left(1.0 \frac{\partial}{\partial z} p(t, x, z) + \frac{v_z(t, x, z + h_z/2)}{dt}\right)\end{matrix}\right]\)
u_p_2
\(\displaystyle p(t + dt, x, z) = dt \left(16.0 \frac{\partial}{\partial x} v_x(t + dt, x + h_x/2, z) + 16.0 \frac{\partial}{\partial z} v_z(t + dt, x, z + h_z/2) + \frac{p(t, x, z)}{dt}\right)\)
= Operator([u_v_2, u_p_2] + src_p) op_2
#NBVAL_IGNORE_OUTPUT
# Propagate the source
=src.time_range.num-1, dt=dt) op_2(time
Operator `Kernel` ran in 0.01 s
PerformanceSummary([(PerfKey(name='section0', rank=None),
PerfEntry(time=0.005126, gflopss=0.0, gpointss=0.0, oi=0.0, ops=0, itershapes=[])),
(PerfKey(name='section1', rank=None),
PerfEntry(time=0.0023490000000000017, gflopss=0.0, gpointss=0.0, oi=0.0, ops=0, itershapes=[]))])
#NBVAL_SKIP
# Let's see what we got....
0].data[0])
plot_image(v[1].data[0])
plot_image(v[0]) plot_image(p.data[
= norm(p)
norm_p assert np.isclose(norm_p, .35098, atol=1e-4, rtol=0)
# # 4th order acoustic according to fdelmoc
= TimeFunction(name='p', grid=grid, staggered=NODE, space_order=4, time_order=1)
p4 = VectorTimeFunction(name='v', grid=grid, space_order=4, time_order=1)
v4 = src.inject(field=p4.forward, expr=src)
src_p = Eq(v4.forward, solve(v4.dt - ro * grad(p4), v4.forward))
u_v_4 = Eq(p4.forward, solve(p4.dt - l2m * div(v4.forward), p4.forward)) u_p_4
#NBVAL_IGNORE_OUTPUT
= Operator([u_v_4, u_p_4] + src_p)
op_4 # Propagate the source
=src.time_range.num-1, dt=dt) op_4(time
Operator `Kernel` ran in 0.01 s
PerformanceSummary([(PerfKey(name='section0', rank=None),
PerfEntry(time=0.005326999999999997, gflopss=0.0, gpointss=0.0, oi=0.0, ops=0, itershapes=[])),
(PerfKey(name='section1', rank=None),
PerfEntry(time=0.0017349999999999978, gflopss=0.0, gpointss=0.0, oi=0.0, ops=0, itershapes=[]))])
#NBVAL_SKIP
# Let's see what we got....
0].data[-1])
plot_image(v4[1].data[-1])
plot_image(v4[-1]) plot_image(p4.data[
= norm(p)
norm_p assert np.isclose(norm_p, .35098, atol=1e-4, rtol=0)