forked from SPECFEM/specfem3d_globe
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path13_post_processing.tex
161 lines (121 loc) · 7.1 KB
/
13_post_processing.tex
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
\chapter{Post-Processing Scripts}
Several post-processing scripts/programs are provided in the \texttt{utils/seis\_process}
directory, most of which need to be adjusted for different
systems, for example, the path of the executable programs. Here we
only list the available scripts and provide a brief description, and
you can either refer to the related sections for detailed usage or,
in many cases, type the script/program name without arguments
to see its usage.
\section{Clean Local Database}
After all the simulations are done, you may need to clean the local
scratch disks for the next simulation. This is especially important
in the case of 1- or 2-chunk kernel simulations, where very large files
are generated for the absorbing boundaries to help with the reconstruction
of the regular forward wavefield. A sample script is provided in \texttt{utils/Cluster/lsf}:
\begin{verbatim}
cleanbase.pl machines
\end{verbatim}
\section{Process Data and Synthetics}\label{sec:Process-data-and-syn}
In many cases, the SEM synthetics are calculated and compared to observed
seismograms recorded at seismic stations. Since the SEM synthetics
are accurate for a certain frequency range, both the original data
and the synthetics need to be processed before a comparison can be
made. For such comparisons, the following steps are recommended:\newline
\begin{enumerate}
\item Make sure that both synthetic and observed seismograms have the correct station/event and timing information.
\item Convolve synthetic seismograms with a source-time function with the half duration specified in the \texttt{CMTSOLUTION} file, provided, as recommended, you used a zero half duration in the SEM simulations.
\item Resample both observed and synthetic seismograms to a common sampling rate.
\item Cut the records using the same window.
\item Remove the trend and mean from the records and taper them.
\item Remove the instrument response from the observed seismograms (recommended) or convolve the synthetic seismograms with the instrument response.
\item Make sure that you apply the same filters to both observed and synthetic seismograms. Preferably, avoid filtering your records more than once.
\item Now, you are ready to compare your synthetic and observed seismograms.
\end{enumerate}
We generally use the following scripts for processing:
\subsection{\texttt{process\_data.pl}}
This script cuts a given portion of the original data, filters it,
transfers the data into a displacement record, and picks the first
P and S arrivals. For more functionality, type `\texttt{process\_data.pl}'
without any argument. An example of the usage of the script:
{\footnotesize
\begin{verbatim}
process_data.pl -m CMTSOLUTION -s 1.0 -l 0/4000 -i -f -t 40/500 -p -x bp DATA/1999.330*.LH?.SAC
\end{verbatim}
}
\noindent
which has resampled the SAC files to a sampling rate of 1 seconds, cut them between 0 and 4000 seconds, transfered them into displacement
records and filtered them between 40 and 500 seconds, picked the first P and S arrivals, and added suffix `\texttt{bp}' to the file names.\newline
Note that all of the scripts in this section actually use SAC,
saclst and/or IASP91 to do the core operations; therefore make sure
that the SAC, saclst and IASP91 packages are installed on your
system, and that all the environment variables are set properly before
running these scripts.
\subsection{\texttt{process\_syn.pl}}\label{sub:process_syn.pl}
This script converts the synthetic output from the SEM code from ASCII
to SAC format, and performs similar operations as `\texttt{process\_data.pl}'.
An example of the usage of the script:
{\footnotesize
\begin{verbatim}
process_syn.pl -m CMTSOLUTION -h -a STATIONS -s 1.0 -l 0/4000 -f -t 40/500 -p -x bp SEM/*.MX?.sem
\end{verbatim}
}
\noindent
which will convolve the synthetics with a triangular source-time function
from the \texttt{CMTSOLUTION} file, convert the synthetics into SAC
format, add event and station information into the SAC headers, resample the SAC files with a sampling rate of 1 seconds, cut them between 0 and 4000 seconds, filter them between 40 and
500 seconds with the same filter used for the observed data, pick the first P and S arrivals, and add the suffix `\texttt{bp}'
to the file names.\newline
More options are available for this script, such as adding a time shift
to the origin time of the synthetics, convolving the synthetics with
a triangular source-time function with a given half duration, etc.
Type \texttt{process\_syn.pl} without any argument for detailed
usage.
\subsection{\texttt{rotate.pl}}
To rotate the horizontal components of both the data and the synthetics
(i.e., \texttt{MXN} and \texttt{MXE}) to the transverse and radial directions (i.e., \texttt{MXT} and \texttt{MXR}),\texttt{\small{}
}use{\small{} }\texttt{\small rotate.pl}:\\
\noindent
data example:
\begin{verbatim}
rotate.pl -l 0 -L 4000 -d DATA/*.LHE.SAC.bp
\end{verbatim}
synthetics example:
\begin{verbatim}
rotate.pl -l 0 -L 4000 SEM/*.MXE.sem.sac.bp
\end{verbatim}
\noindent
where the first command performs rotation on the SAC data obtained
through IRIS (which may have timing information written in the filename),
while the second command rotates the processed synthetics.\newline
For synthetics, another (simpler) option is to set flag \texttt{ROTATE\_SEISMOGRAMS\_RT}
to \texttt{.true.} in the parameter file \texttt{DATA/Par\_file}.
\subsection{\texttt{clean\_sac\_headers\_after\_crash.sh}}
Note: You need to have the \texttt{sismoutil-0.9b} package installed
on your computer if you want to run this script on binary SAC files.
The software is available via the \href{http://www.orfeus-eu.org}{ORFEUS web site}.\newline
In case the simulation crashes during run-time without computing and
writing all time steps, the SAC files (if flags \texttt{OUTPUT\_SEISMOS\_SAC\_ALPHANUM}
or \texttt{OUTPUT\_SEISMOS\_SAC\_BINARY} have been set to \texttt{.true.})
are corrupted and cannot be used in SAC. If the simulation
ran long enough so that the synthetic data may still be of use, you
can run the script called \texttt{clean\_sac\_headers\_after\_crash.sh}
(located in the \texttt{utils/} directory) on the SAC files to correct
the header variable NPTS to the actually written number of time steps.
The script must be called from the \texttt{SPECFEM3D} main directory,
and the input argument to this script is simply a list of SAC seismogram
files.
\section{Map Local Database}
A sample program \texttt{remap\_database} is provided to map the local
database from a set of machines to another set of machines. This is
especially useful when you want to run mesher and solver, or different
types of solvers separately through a scheduler (refer to Chapter~\ref{cha:Running-Scheduler}).
\begin{verbatim}
run_lsf.bash --gm-no-shmem --gm-copy-env remap_database \
old_machines 150 [old_jobid new_jobid]
\end{verbatim}
where \texttt{old\_machines} is the LSF machine file used in the previous
simulation, and \texttt{150} is the number of processors in total.
Note that you need to supply \texttt{old\_jobid} and \texttt{new\_jobid(\%J)}
which are the LSF job-IDs for the old and new run if your databases
are stored in a sub-directory named after the jobid on the scratch
disk.