forked from navjotk/error_propagation
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsimple.py
More file actions
117 lines (97 loc) · 4.9 KB
/
simple.py
File metadata and controls
117 lines (97 loc) · 4.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
from argparse import ArgumentParser
from examples.seismic import (Receiver, TimeAxis, RickerSource,
AcquisitionGeometry)
from examples.seismic.acoustic import AcousticWaveSolver
from examples.seismic.tti import AnisotropicWaveSolver
import numpy as np
from util import to_hdf5, from_hdf5
def overthrust_setup(filename, kernel='OT2', tn=4000, src_coordinates=None,
space_order=2, datakey='m0', nbpml=40, dtype=np.float32,
**kwargs):
model = from_hdf5(filename, space_order=space_order, nbpml=nbpml,
datakey=datakey, dtype=dtype)
shape = model.shape
spacing = model.spacing
nrec = shape[0]
if src_coordinates is None:
src_coordinates = np.empty((1, len(spacing)))
src_coordinates[0, :] = np.array(model.domain_size) * .5
if len(shape) > 1:
src_coordinates[0, -1] = model.origin[-1] + 2 * spacing[-1]
rec_coordinates = np.empty((nrec, len(spacing)))
rec_coordinates[:, 0] = np.linspace(0., model.domain_size[0], num=nrec)
if len(shape) > 1:
rec_coordinates[:, 1] = np.array(model.domain_size)[1] * .5
rec_coordinates[:, -1] = model.origin[-1] + 2 * spacing[-1]
# Create solver object to provide relevant operator
geometry = AcquisitionGeometry(model, rec_coordinates, src_coordinates,
t0=0.0, tn=tn, src_type='Ricker', f0=0.008)
solver = AcousticWaveSolver(model, geometry, kernel=kernel,
space_order=space_order, **kwargs)
return solver
def overthrust_setup_tti(filename, tn=4000, space_order=2, nbpml=40,
**kwargs):
model = from_hdf5(filename, space_order=space_order, nbpml=nbpml,
datakey='m0', dtype=np.float32)
shape = model.vp.shape
spacing = model.shape
nrec = shape[0]
# Derive timestepping from model spacing
dt = model.critical_dt
t0 = 0.0
time_range = TimeAxis(start=t0, stop=tn, step=dt)
# Define source geometry (center of domain, just below surface)
src = RickerSource(name='src', grid=model.grid, f0=0.015,
time_range=time_range)
src.coordinates.data[0, :] = np.array(model.domain_size) * .5
if len(shape) > 1:
src.coordinates.data[0, -1] = model.origin[-1] + 2 * spacing[-1]
# Define receiver geometry (spread across x, just below surface)
rec = Receiver(name='rec', grid=model.grid, time_range=time_range,
npoint=nrec)
rec.coordinates.data[:, 0] = np.linspace(0., model.domain_size[0],
num=nrec)
if len(shape) > 1:
rec.coordinates.data[:, 1:] = src.coordinates.data[0, 1:]
# Create solver object to provide relevant operators
return AnisotropicWaveSolver(model, source=src, receiver=rec,
space_order=space_order, **kwargs)
def run(space_order=4, kernel='OT4', nbpml=40, filename='', **kwargs):
if kernel in ['OT2', 'OT4']:
solver = overthrust_setup(filename=filename, nbpml=nbpml,
space_order=space_order, kernel=kernel,
**kwargs)
elif kernel == 'TTI':
solver = overthrust_setup_tti(filename=filename, nbpml=nbpml,
space_order=space_order, kernel=kernel,
**kwargs)
else:
raise ValueError()
return_values = solver.forward(save=False)
u = return_values[1]
uncompressed = u.data[0]
to_hdf5(uncompressed, "uncompressed.h5")
# rec = return_values[0]
# last_time_step = rec.shape[0] - 1
# to_hdf5(uncompressed[last_time_step-1, :], "uncompressed.h5.1")
if __name__ == "__main__":
description = ("Example script for a set of acoustic operators.")
parser = ArgumentParser(description=description)
parser.add_argument("-so", "--space_order", default=6,
type=int, help="Space order of the simulation")
parser.add_argument("--nbpml", default=40,
type=int, help="Number of PML layers around the domain")
parser.add_argument("-k", dest="kernel", default='OT2',
choices=['OT2', 'OT4', 'TTI'],
help="Choice of finite-difference kernel")
parser.add_argument("-dse", default="advanced",
choices=["noop", "basic", "advanced",
"speculative", "aggressive"],
help="Devito symbolic engine (DSE) mode")
parser.add_argument("-dle", default="advanced",
choices=["noop", "advanced", "speculative"],
help="Devito loop engine (DLE) mode")
args = parser.parse_args()
run(nbpml=args.nbpml,
space_order=args.space_order, kernel=args.kernel,
dse=args.dse, dle=args.dle, filename='overthrust_3D_initial_model.h5')