-
Notifications
You must be signed in to change notification settings - Fork 150
04_running_the_solver
Table of Contents
-
Running the Solver xspecfem2D
- Notes about
DATA/Par_file
parameters - Notes about
DATA/SOURCE
parameters - How to run elastic wave simulations
- How to run axisymmetric wave simulations
- How to run anisotropic wave simulations
- How to run poroelastic wave simulations
- How to run electromagnetic wave simulations
- Coupled simulations
- How to choose the time step
- How to set plane waves as initial conditions
- Note on the viscoelastic model used
- Note on viscoelasticity in the 2D plane strain approximation
- References
- Notes about
To run the solver, type
bin/xspecfem2D
from within the main working directory (use mpirun
or equivalent if you compiled with parallel support). This will output the seismograms and snapshots of the wave fronts at different time steps in directory OUTPUT_FILES/
. To visualize them, type "gs OUTPUT_FILES/vect*.ps
" to see the Postscript files (in which the wave field is represented with small arrows, fluid/solid matching interfaces with a thick pink line, and absorbing edges with a thick green line) and "gimp OUTPUT_FILES/image*.gif
" to see the colour snapshot showing a pixelized image of one of the two components of the wave field (or pressure, depending on what you have selected for the output in DATA/Par_file
).
Please consider these following points, when running the solver:
-
the
DATA/Par_file
given with the code works fine, you can use it without any modification to test the code -
the seismograms
OUTPUT_FILES/*.sem*
are simple ASCII files with two columns: time in the first column and amplitude in the second, therefore they can be visualized with any tool you like, for instance “gnuplot
”; if you prefer to output binary seismograms in Seismic Unix format (which is a simple binary array dump) you can use parameterSU_FORMAT
, in which case all the seismograms will be written to a single file with the extension*.bin
. Depending on your installation of the Seismic Unix package you can use one of these two commands:surange < Uz_file_single.bin suoldtonew < Uz_file_single.bin | surange
to see the header info. Replace
surange
withsuxwigb
to see wiggle plots for the seismograms. -
if flag
MODEL
inDATA/Par_file
is set todefault
, the velocity and density model is determined using thenbmodels
andnbregions
devices. Otherwise,nbmodels
values are ignored and the velocity and density model is determined from a user supplied file or subroutine. -
when compiling with Intel ifort, use “
-assume byterecl
” option to create binary PNM images displaying the wave field -
there are a few useful scripts and Fortran routines in directory
utils/
. -
you can find a Fortran code to compute the analytical solution for simple media that we use as a reference in benchmarks in many of our articles at EX2DDIR. That code is described in: (Berg et al. 1994)
The DATA/Par_file
contains detailed comments and should be almost self-explanatory. Please see also the corresponding explanations in generating the mesh. Some more detailed informations are listed here for a few parameters affecting the solver:
ATTENUATION_VISCOELASTIC
or ATTENUATION_VISCOACOUSTIC
Regarding attenuation (viscoelasticity and viscoacoustic), in the Par_file
you need to select the number of standard linear solids (N_SLS) to mimic a constant
USE_TRICK_FOR_BETTER_PRESSURE
This option can only be used so far if all the receivers record pressure and are in acoustic elements. Use a trick to increase accuracy of pressure seismograms in fluid (acoustic) elements: use the second derivative of the source for the source time function instead of the source itself, and then record potential_acoustic()
as pressure seismograms instead of potential_dot_dot_acoustic()
; this is mathematically equivalent, but numerically significantly more accurate because in the explicit Newmark time scheme acceleration is accurate at zeroth order while displacement is accurate at second order, thus in fluid elements potential_dot_dot_acoustic()
is accurate at zeroth order while potential_acoustic()
is accurate at second order and thus contains significantly less numerical noise.
The SOURCE
file located in the DATA/
directory should be edited in the following way:
source_surf
Set this flag to .true.
to force the source to be located at the surface of the model, otherwise the sol be placed inside the medium
xs
source location
zs
source location
source_type
Set this value equal to 1
for elastic forces or acoustic pressure, set this to 2
for moment tensor sources. For a plane wave including converted and reflected waves at the free surface, P wave = 1, S wave = 2, Rayleigh wave = 3; for a plane wave without converted nor reflected waves at the free surface, i.e. the incident wave only, P wave = 4, S wave = 5. (incident plane waves are turned on by parameter initialfield
in DATA/Par_file
).
time_function_type
Choose a source-time function: set this value to 1
to use a Ricker, i.e. the second derivative of a Gaussian, 2
to use the first derivative of a Gaussian, 3
to use a Gaussian, 4
to use a Dirac or 5
to use a Heaviside source-time function. Note that we use the standard definition of a Ricker, for a dominant frequency
f0
Set this to the dominant frequency of the source. For point-source simulations using a Heaviside source-time function (time_function_type = 5
), we recommend setting the source frequency parameter f0
equal to a high value, which corresponds to simulating a step source-time function, i.e., a moment-rate function that is a delta function.
The half duration
of a source is obtained by time_function_type = 3
) (i.e., a signal with a shape similar to a ‘smoothed triangle’, as explained in Komatitsch and Tromp (2002) and shown in Fig 1.3), the source-time function uses a half-width of half duration
. We prefer to run the solver with half duration
set to zero and convolve the resulting synthetic seismograms in post-processing after the run, because this way it is easy to use a variety of source-time functions. Komatitsch and Tromp (2002) determined that the noise generated in the simulation by using a step source time function may be safely filtered out afterward based upon a convolution with the desired source time function and/or low-pass filtering. Use the serial code convolve_source_timefunction.f90
and the script convolve_source_timefunction.sh
for this purpose (or alternatively use signal-processing software packages such as SAC). Type
make xconvolve_source_timefunction
to compile the code and then set the parameter hdur
in convolve_source_timefunction.sh
to the desired half-duration.
t0
For single sources, we recommend to set the time shift parameter t0
equal to
anglesource
angle of the source (for a force only); for a plane wave, this is the incidence angle. For moment tensor sources this parameter is unused.
Mxx
,Mzz
,Mxz
Moment tensor components (valid only for moment tensor sources, source_type = 2
). Note that the units for the components of a moment tensor source are different in SPECFEM2D and in SPECFEM3D:
SPECFEM3D:
in SPECFEM3D the moment tensor components are in dyne*cm
SPECFEM2D:
in SPECFEM2D the moment tensor components are in N*m
To go from strike / dip / slip to CMTSOLUTION moment-tensor format using the classical formulas (of e.g. (Aki and Richards 1980) you can use these two small C programs from SPECFEM3D_GLOBE
:
./utils/strike_dip_rake_to_CMTSOLUTION.c
./utils/CMTSOLUTION_to_AkiRichards.c
but then it is another story to make a good 2D approximation of that, because in plain-strain P-SV what you get is the equivalent of a line source in the third direction (orthogonal to the plane) rather than a 3D point source For more details on this see e.g. Section 7.3 "Two-dimensional point sources" of the book of (Pilant 1979). That book being hard to find, we scanned the related pages in file discussion_of_2D_sources_and_approximations_from_Pilant_1979.pdf
in the same directory as this users manual. Another very useful reference addressing that is (Helmberger and Vidale 1988) and its recent extension (Li et al. 2014).
factor
amplification factor
Note, the zero time of the simulation corresponds to the center of the triangle/Gaussian, or the centroid time of the earthquake. The start time of the simulation is USER_T0
in the constants.h
file to a positive, non-zero value. The simulation in that case would start at a starting time equal to -USER_T0
.
For isotropic elastic materials, there are two options:
P-SV:
To run a P-SV waves calculation propagating in the p_sv = .true.
in the Par_file
.
SH:
To run a SH (membrane) waves calculation travelling in the p_sv = .false.
This feature is only implemented for elastic materials and sensitivity kernels can be calculated (see (Tape, Liu, and Tromp 2007) for details on membrane surface waves).
An optional useful Python script called SEM_save_dir.py
is provided. It allows one to automatically save all the parameters and results of a given simulation.
Axisymmetric simulations are possible in SPECFEM2D. For these simulations the 2D domain simulated is physically the meridional 2D shape of an axisymmetric 3D domain. We invite you to read our publication (Bottero et al. 2016) as an introduction. To set the geometry as axisymmetric turn the flag AXISYM
to .true.
in the Par_file
:
AXISYM = .true.
The left border of the model becomes then a symmetry axis. The wavefield calculated is then physically a 3D wavefield obtained by revolution of a 2D wavefield around its left border.
Note about the source: In axisymmetric geometry the whole model is symmetric with respect to this axis, including the source. Hence if the source is not on the axis it will physically have a circular shape. This is still possible and relevant for some applications as non destructive testing but is most of the time unwanted. This has to be kept in mind. In acoustic medium, as an explosion in a fluid is naturally axisymmetric, the wavefield generated has the correct 3D shape. However, if the source is put in an elastic solid, its 3D radiation pattern will be axisymmetric.
Getting started: To get started a simple example is available in EXAMPLES/axisymmetric_case_AXISYM_option
, we encourage you to read the README
file you will find there. This example contains an example of the use of AXISYM
option plus a validation using the semi-analytical code OASES ((Schmidt 2004)). In this example the domain studied is a water layer lying above a viscoelastic medium. The source is an explosion in the water and the domain is bounded with PMLs.
Note about external meshers: Using external meshers is possible in axisymmetric geometry. An example is available in EXAMPLES/paper_axisymmetry_example
with the mesher Cubit/Trelis (http://www.csimsoft.com/trelis). We invite you to check this example and read the previous chapter for more details. The only difference with plane-strain geometry is that SPECFEM2D needs an additional file defining axial elements. The path to this file has to be given in the Par_file
:
axial_elements_file = /path/to/the/axial_elements_file
The axial elements file has the following structure:
48
1 2 8456 8457
2 2 8457 8458
3 2 8458 8459
4 2 8459 8460
623 2 171 204
1053 2 172 9512
1054 2 172 173
1055 2 173 174
...
Which is similar to free surface files. Hence the first line contains the number of axial elements, then the other lines contain four columns: element id, number of nodes describing an axial element (always 2), first node id, second node id. Note that the axis elements must include the possible (up and/or down) PMLs elements in contact with the axis. For simplicity we assume that the mesh elements that are in contact with the symmetry axis are in contact with it by a full edge rather than by a single point, i.e. we exclude cases as that of Figure 1.4. This amounts to imposing that the leftmost layer of elements in the mesh be structured rather than non structured; The rest of the mesh can be non structured.
Note about the resolution: In axisymmetry a different quadrature is used in the axial elements making the number of points per wavelength necessary a slightly bigger (
Note about a small remaining bug: It has to be noted that a small bug is still hiding somewhere in the code. Indeed the output signals generated are correct in the whole domain except in the element containing the source. This small bug has not been solved so far but not prevent to use the code.
Note about a demo code to learn: A simplistic demo code is available in utils/small_SEM_solver_in_Fortran_without_MPI_to_learn
. This simple code is useful to learn how the spectral-element method works in both plane-strain and axisymmetric geometries. Have a look to it if interested. Once in its directory, type ./make_Fortran_2D_axisymmetric.csh
and then ./xspecfem2D
to compile and run. The bug discussed above is not present in this small code.
Following (J. M. Carcione, Kosloff, and Kosloff 1988b), we use the classical reduced Voigt notation to represent symmetric tensors (Helbig 1994; José M. Carcione 2007):
The constitutive relation of a heterogeneous anisotropic and elastic solid is expressed by the generalized Hooke’s law, which can be written as
$$\sigma_{ij} = c_{ijkl} \varepsilon_{kl}, \qquad i, j, k = 1, \dots, 3,$$ where$t$ is the time,$\mathbf{x}$ is the position vector,$\sigma_{ij}(\mathbf{x}, t)$ and$\varepsilon_{ij}(\mathbf{x}, t)$ are the Cartesian components of the stress and strain tensors respectively, and$c_{ijkl}(\mathbf{x})$ are the components of a fourth-order tensor called the elasticites of the medium. The Einstein convention for repeated indices is used.To express the stress-strain relation for a transversely isotropic medium we introduce a shortened matrix notation commonly used in the literature. With this convention, pairs of subscripts concerning the elasticities are replaced by a single number according to the following correspondence: $$\begin{aligned} (11) \rightarrow 1, && (22) \rightarrow 2, && (33) \rightarrow 3, \ (23) = (32) \rightarrow 4, && (31) = (13) \rightarrow 5, && (12) = (21) \rightarrow 6. \end{aligned}$$
Thus in the most general 2D case we have the following convention for the stress-strain relationship:
! implement anisotropy in 2D
sigma_xx = c11*dux_dx + c13*duz_dz + c15*(duz_dx + dux_dz)
sigma_zz = c13*dux_dx + c33*duz_dz + c35*(duz_dx + dux_dz)
sigma_xz = c15*dux_dx + c35*duz_dz + c55*(duz_dx + dux_dz)
! sigma_yy is not equal to zero in the plane strain formulation
! but is used only in post-processing if needed,
! to compute pressure for display or seismogram recording purposes
sigma_yy = c12*dux_dx + c23*duz_dz + c25*(duz_dx + dux_dz)
where the notations are for instance duz_dx = d(Uz) / dx
.
Check the following new inputs in Par_file
:
ATTENUATION_PORO_FLUID_PART
, Q0_poroelastic
, and freq0_poroelastic
deal with viscous damping in a poroelastic medium. Q0_poroelastic
is the quality factor set at the central frequency freq0_poroelastic
. For more details see (Morency and Tromp 2008).
SIMULATION_TYPE
defines the type of simulation
-
forward simulation
-
UNUSED (purposely, for compatibility with the numbering convention used in our 3D codes)
-
adjoint method and kernels calculation
The code now support multiple sources. NSOURCE
is the number of sources. Parameters of the sources are displayed in the file SOURCE
, which must be in the directory DATA/
. The components of a moment tensor source must be given in N.m, not in dyne.cm as in the DATA/CMTSOLUTION
source file of the 3D version of the code.
SAVE_FORWARD
determines if the last frame of a forward simulation is saved (.true.
) or not (.false
)
There are three possible types of models for seismic wave propagation:
-
(
model_number 1 rho Vp Vs 0 0 QKappa Qmu 0 0 0 0 0 0
) or -
(
model_number 2 rho c11 c13 c15 c33 c35 c55 c12 c23 c25 0 0 0
) or -
(
model_number 3 rhos rhof phi c kxx kxz kzz Ks Kf Kfr etaf mufr Qmu
).
For isotropic elastic/acoustic material use I
and set Vs
to zero to make a given model acoustic, for anisotropic elastic use II
, and for isotropic poroelastic material use III
. The mesh can contain acoustic, elastic, and poroelastic models simultaneously.
For anisotropic elastic media the last three parameters, c12 c23 c25
, are used only when the user asks the code to compute pressure for display or seismogram recording purposes. Thus, if you do not know these parameters for your anisotropic material and/or if you do not plan to display or record pressure you can ignore them and set them to zero. When pressure is used these three parameters are needed because the code needs to compute
rho_s
= solid density
rho_f
= fluid density
phi
= porosity
tort
= tortuosity
permxx
= xx component of permeability tensor
permxz
= xz,zx components of permeability tensor
permzz
= zz component of permeability tensor
kappa_s
= solid bulk modulus
kappa_f
= fluid bulk modulus
kappa_fr
= frame bulk modulus
eta_f
= fluid viscosity
mu_fr
= frame shear modulus
Qmu
= shear quality factor
Note: for the poroelastic case, mu_s
is irrelevant. For details on the poroelastic theory see (Morency and Tromp 2008).
get_poroelastic_velocities.f90
allows to compute cpI, cpII, and cs function of the source dominant frequency. Notice that for this calculation we use permxx
and the dominant frequency of the first source, f0(1). Caution if you use several sources with different frequencies and if you consider anistropic permeability.
For more details on the electromagetic (EM) wave propagation in SPECFEM, please refer to (Morency 2020). Check the following new inputs in Par_file
:
ATTENUATION_PERMITTIVITY
, ATTENUATION_CONDUCTIVITY
, and f0_electromagnetic
deal with dispersive and attenuating EM media. For more details see section 2.2 in (Morency 2020).
SIMULATION_TYPE
defines the type of simulation
-
forward simulation
-
UNUSED (purposely, for compatibility with the numbering convention used in our 3D codes)
-
adjoint method and kernels calculation – TO DO
There are three possible types of models for seismic wave propagation and one for EM wave propagation:
-
(
model_number 1 rho Vp Vs 0 0 QKappa Qmu 0 0 0 0 0 0
) or -
(
model_number 2 rho c11 c13 c15 c33 c35 c55 c12 c23 c25 0 0 0
) or -
(
model_number 3 rhos rhof phi c kxx kxz kzz Ks Kf Kfr etaf mufr Qmu
) or -
(
model_number 4 mu0 e0 e11 e33 sig11 sig33 Qe11 Qe33 Qs11 Qs33 0 0 0
).
For isotropic EM material use IV
, where
mu_0
= magnetic permeability
e_0
= vacuum dielectric permittivity
e_11
= xx component of relative dielectric permittivity
e_33
= zz component of relative dielectric permittivity
sig_11
= xx component of conductivity
sig_33
= zz component of conductivity
Qe_11
= quality factor of xx component of permittivity
Qe_33
= quality factor of zz component of permittivity
Qs_11
= quality factor of xx component of conductivity
Qs_33
= quality factor of zz component of conductivity
get_electromagnetic_velocities.f90
allows to compute the anisotropic EM wavespeeds as a function of the source dominant frequency. Notice that for this calculation we use the dominant frequency of the first source, f0(1). Caution if you use several sources with different frequencies.
Finally, 2-D transverse electric (TE) mode, more suitable for crosshole and vertical radar profiling applications, and transverse magnetic (TM) mode, suitable for surface based reflection ground penetration radar type of applications, can be handled using the P-SV/SH flag in Par_file
:
P-SV (EM TE):
To run a EM waves calculation propagating in the p_sv = .true.
SH (EM TM):
To run EM waves calculation travelling in the p_sv = .false.
The code supports acoustic/elastic, acoustic/poroelastic, elastic/poroelastic, and acoustic, elastic/poroelastic simulations. Elastic/poroelastic coupling supports anisotropy, but not attenuation for the elastic material.
Three different explicit conditionally-stable time schemes can be used for elastic, acoustic (fluid) or coupled elastic/acoustic media: the Newmark method, the low-dissipation and low-dispersion fourth-order six-stage Runge-Kutta method (LDDRK4-6) presented in (Berland, Bogey, and Bailly 2006), and the classical fourth-order four-stage Runge-Kutta (RK4) method. Currently the last two methods are not implemented for poroelastic media. According to (De Basabe and Sen 2010) and (Berland, Bogey, and Bailly 2006), with different degrees output_solver.txt
to see whether you set the correct Par_file
or not. For elastic simulation, the CFL value given in output_solver.txt
does not consider the
Degree |
Newmark | LDDRK4-6 | RK4 |
---|---|---|---|
1 | 0.709 | 1.349 | 1.003 |
2 | 0.577 | 1.098 | 0.816 |
3 | 0.593 | 1.129 | 0.839 |
4 | 0.604 | 1.150 | 0.854 |
5 | 0.608 | 1.157 | 0.860 |
6 | 0.608 | 1.157 | 0.860 |
7 | 0.608 | 1.157 | 0.860 |
8 | 0.607 | 1.155 | 0.858 |
9 | 0.607 | 1.155 | 0.858 |
10 | 0.607 | 1.155 | 0.858 |
CFL upper bound for an acoustic (fluid) simulation.
Degree |
Newmark | LDDRK4-6 | RK4 |
---|---|---|---|
1 | 0.816 | 1.553 | 1.154 |
2 | 0.666 | 1.268 | 0.942 |
3 | 0.684 | 1.302 | 0.967 |
4 | 0.697 | 1.327 | 0.986 |
5 | 0.700 | 1.332 | 0.990 |
6 | 0.700 | 1.332 | 0.990 |
7 | 0.700 | 1.332 | 0.990 |
8 | 0.699 | 1.330 | 0.989 |
9 | 0.698 | 1.328 | 0.987 |
10 | 0.698 | 1.328 | 0.987 |
CFL upper bound for an elastic simulation with
To simulate propagation of incoming plane waves in the simulation domain, initial conditions based on analytical formulae of plane waves in homogeneous model need to be set. No additional body or boundary forces are required. To set up this scenario:
Par_file
:
-
switch on
initialfield = .true.
-
at this point setting
add_bielak_condition
does not seem to help with absorbing boundaries, therefore, it should be turned off.
SOURCE
:
-
zs
has to be the same as the height of the simulation domain defined ininterfacesfile
. -
xs
is the$x$ -coordinate of the intersection of the initial plane wave front with the free surface. -
source_type
= 1 for a plane P wave, 2 for a plane SV wave, 3 for a Rayleigh wave. -
angleforce
can be negative to indicate a plane wave incident from the right (instead of the left)
The model used is a constant
However in practice for technical reasons it is approximated based on the sum of different Generalized Zener body mechanisms and thus the code outputs the band in which the approximation is very good, outside of that range it can be less accurate. The logarithmic center of that frequency band is the f0
parameter defined (in Hz) in input file DATA/SOURCE
.
In 2D plane strain, one spatial dimension is much greater than the others (see for example: [http://www.engineering.ucsb.edu/ hpscicom/projects/stress/introge.pdf](http://www.engineering.ucsb.edu/ hpscicom/projects/stress/introge.pdf)) and thus
In 2D axisymmetric I think the 2/3 coefficient is OK, but it would be worth doublechecking.
Aki, K., and P. G. Richards. 1980. Quantitative Seismology, Theory and Methods. San Francisco, USA: W. H. Freeman.
Berg, P., F. If, P. Nielsen, and O. Skovegaard. 1994. “Analytic Reference Solutions.” In Modeling the Earth for Oil Exploration, Final Report of the CEC’s GEOSCIENCE i Program 1990-1993, edited by K. Helbig, 421–27. Pergamon Press, Oxford, United Kingdom.
Berland, J., C. Bogey, and C. Bailly. 2006. “Low-Dissipation and Low-Dispersion Fourth-Order Runge-Kutta Algorithm.” Computers and Fluids 35: 1459–63.
Blanc, Émilie, Dimitri Komatitsch, Emmanuel Chaljub, Bruno Lombard, and Zhinan Xie. 2016. “Highly Accurate Stability-Preserving Optimization of the Zener Viscoelastic Model, with Application to Wave Propagation in the Presence of Strong Attenuation.” Geophys. J. Int. 205 (1): 427–39. https://doi.org/10.1093/gji/ggw024.
Bottero, Alexis, Paul Cristini, Dimitri Komatitsch, and Mark Asch. 2016. “An Axisymmetric Time-Domain Spectral-Element Method for Full-Wave Simulations: Application to Ocean Acoustics.” J. Acoust. Soc. Am. 140 (5): 3520–30. https://doi.org/10.1121/1.4965964.
Carcione, J. M., D. Kosloff, and R. Kosloff. 1988a. “Wave Propagation Simulation in a Linear Viscoelastic Medium.” Geophys. J. Int. 95: 597–611.
———. 1988b. “Wave Propagation Simulation in an Elastic Anisotropic (Transversely Isotropic) Solid.” Q. J. Mech. Appl. Math. 41 (3): 319–45.
Carcione, José M. 2007. Wave Fields in Real Media: Theory and Numerical Simulation of Wave Propagation in Anisotropic, Anelastic, Porous and Electromagnetic Media. Second. Amsterdam, The Netherlands: Elsevier Science.
De Basabe, Jonás D., and Mrinal K. Sen. 2010. “Stability of the High-Order Finite Elements for Acoustic or Elastic Wave Propagation with High-Order Time Stepping.” Geophys. J. Int. 181 (1): 577–90. https://doi.org/10.1111/j.1365-246X.2010.04536.x.
Helbig, K. 1994. “Foundations of Anisotropy for Exploration Seismics.” In Handbook of Geophysical Exploration, Section i: Seismic Exploration, edited by K. Helbig and S. Treitel. Vol. 22. Oxford, England: Pergamon.
Helmberger, Donald V., and John E. Vidale. 1988. “Modeling Strong Motions Produced by Earthquakes with Two-Dimensional Numerical Codes.” Bull. Seism. Soc. Am. 78 (1): 109–21.
Komatitsch, D., and J. Tromp. 2002. “Spectral-Element Simulations of Global Seismic Wave Propagation-I. Validation.” Geophys. J. Int. 149 (2): 390–412. https://doi.org/10.1046/j.1365-246X.2002.01653.x.
Kristeková, Miriam, Jozef Kristek, and Peter Moczo. 2009. “Time-Frequency Misfit and Goodness-of-Fit Criteria for Quantitative Comparison of Time Signals.” Geophys. J. Int. 178 (2): 813–25. https://doi.org/10.1111/j.1365-246X.2009.04177.x.
Li, Dunzhu, Don Helmberger, Robert W. Clayton, and Daoyuan Sun. 2014. “Global Synthetic Seismograms Using a 2-D Finite-Difference Method.” Geophys. J. Int. 197 (2): 1166–83. https://doi.org/10.1093/gji/ggu050.
Morency, C. 2020. “Electromagnetic Wave Propagation Based Upon Spectral-Element Methodology in Dispersive and Attenuating Media.” Geophys. J. Int. 220: 951–66.
Morency, C., and J. Tromp. 2008. “Spectral-Element Simulations of Wave Propagation in Poroelastic Media.” Geophys. J. Int. 175: 301–45.
Pilant, Walter L. 1979. Elastic Waves in the Earth. Vol. 11 of "Developments in Solid Earth Geophysics" Series. Amsterdam, The Netherlands: Elsevier Scientific Publishing Company.
Schmidt, H. 2004. OASES Version 3.1 User Guide and Reference Manual. Center for Ocean Engineering, Massachusetts Institute of Technology, USA.
Tape, Carl, Qinya Liu, and Jeroen Tromp. 2007. “Finite-Frequency Tomography Using Adjoint Methods - Methodology and Examples Using Membrane Surface Waves.” Geophys. J. Int. 168 (3): 1105–29. https://doi.org/10.1111/j.1365-246X.2006.03191.x.
This documentation has been automatically generated by pandoc based on the User manual (LaTeX version) in folder doc/USER_MANUAL/ (Aug 26, 2024)
Development wiki
User manual
- 01_introduction
- 02_getting_started
- 03_mesh_generation
- 04_running_the_solver
- 05_adjoint_simulations
- 06_doing_tomography
- 07_oil_and_gas_industry_simulations
- 08_informations_for_developers
- A_reference_frame
- B_channel_codes
- C_troubleshooting
- D_license
- authors
- copyright_and_version
- features
- manual_SPECFEM2D
- notes_and_acknowledgement
- sponsors