detect_eruption_airWave_independentコマンド マニュアル

(The documentation of detect_eruption_airWave_independent command)

Last Update: 2025/3/13


◆機能・用途(Purpose)

個々の観測点の空振波形を独立に用いて火山噴火を検出する。 検知基準として空振波形の振幅およびテンプレート波形との相関係数を用いる。 各観測点の連続波形は日時によって複数ファイルに分かれていても良い。
Detect volcanic eruptions from pressure waveforms independently at each station. The detection is based on the amplitude of a pressure wave and the correlation coefficient between continuous and template waveforms. The continuous waveform at each station can be separated as multiple files based on dates and times.


◆アルゴリズム(Algorithm)

空振波形の振幅とテンプレート波形との相関係数に基づいて噴火を検知する。 複数の観測点やテンプレートイベントの空振波形を同時に用いることができる。 検知方法は以下の通りである。
The eruptions are detected based on the amplitude of a pressure wave and the correlation coefficient between continuous and template waveforms. Data at multiple stations and multiple template events can be used simultaneously. The detection algorithm is as follows.

\(N_{station}\)個の観測点における空振の連続波形 \(\{s_n^{continuous}(t); n=0,1,\cdots,N_{station}-1\}\) および\(N_{template}\)個のテンプレート波形 \(\{s_i^{template}(\tau_i); i=0,1,\cdots,N_{template}-1\}\) が利用できるものとする。 ここで\(t\)は日付・時刻を表す絶対日時、 \(\tau_i\)はテンプレート波形毎に定義される相対時刻であり、 テンプレート波形が最大値を取る時刻が\(\tau_i=0\)となるように定義する。 テンプレート波形は複数の観測点や複数の噴火に対応するものが混在していても良く、 \(i\)はそれら全てのテンプレート波形に対して割り当てた連続番号である。 \(i\)番目のテンプレート波形は観測点\(n(i)\)における空振波形であるものとし、 その定義域を\([\tau_i^{st},\tau_i^{en}]\)とする。 なお\(\tau_i^{st}<0<\tau_i^{en}\)である。
Suppose that continuous waveforms at \(N_{station}\) stations \(\{s_n^{continuous}(t); n=0,1,\cdots,N_{station}-1\}\) and \(N_{template}\) template waveforms \(\{s_i^{template}(\tau_i); i=0,1,\cdots,N_{template}-1\}\) are available. Here, \(t\) is an absolute time corresponding to a date and time, whereas \(\tau_i\) is a relative time defined for each template waveform as its maximum value is located at \(\tau_i=0\). The template waveforms for different eruptions and/or different stations can be mixed; \(i\) is a consecutive number assigned for all available template waveforms. Suppose that \(i\)th template waveform is from a pressure record at \(n(i)\)th station and its definition range is \([\tau_i^{st},\tau_i^{en}]\), where \(\tau_i^{st}<0<\tau_i^{en}\).

\(i\)番目のテンプレート波形における シグナル開始から最大振幅に達するまでの経過時間を\(T_i^{rise}\)とする。 また想定する噴火口から\(n\)番目の観測点までの空振の理論走時を\(T_n^{travel}\)とする。 これらの値は解析者が与えるものとする。 \(T_i^{rise}+T_n^{travel}\)が 噴火発生から観測点\(n\)において振幅が最大となる時刻までの期待される所要時間である。
Let \(T_i^{rise}\) be an elapsed time from the beginning of a signal to the maximum amplitude in \(i\)th template waveform, and \(T_n^{travel}\) be a theoretical travel time of a pressure wave from an assumed crater location to \(n\)th station. The values of them need to be given by the analyzer. \(T_i^{rise}+T_n^{travel}\) is an expected elapsed time from the beginning of an eruption to the maximum amplitude at \(n\)th station.

以上の準備のもとで、各時刻\(t\)がいずれかのテンプレート波形\(i\)について 以下の3条件が全て成り立つ場合に噴火開始時刻であると判断する。
Each time \(t\) is identified as an eruption onset time if all three requirements listed below are satisfied for either template waveform \(i\):

個々のテンプレート波形について上記の基準を適用すると、 使用するテンプレート波形に応じて僅かにずれた時刻において 同一の噴火が重複して検知されると予想される。 そこで、解析者が与える時間差の閾値\(\Delta t_{min}\)を用いて、 区間\((t-\Delta t_{min},t)\)において上記の基準を満たす時刻が1つも無い場合にのみ 時刻\(t\)を噴火と判断する。 これにより、\(\Delta t_{min}\)未満の時間差で検知された噴火候補の中で 一番最初のもののみが最終的に噴火と扱われることになる。
Applying these criteria to each template waveform results in duplicated detections of the same eruption at slightly different times from different templates. To avoid it, time \(t\) is identified as being an eruption only of the above criteria are satisfied at none of the times in a section \((t-\Delta t_{min},t)\), where \(\Delta t_{min}\) is a threshold time difference defined by the analyzer. This treatment results in the detection of only the first eruption among the eruption candidates with time differences less than \(\Delta t_{min}\).

候補の中から最初のものを選択する理由はこのプログラムを開発した目的が 噴火直前の傾斜変動の研究のための基礎データとしての噴火日時カタログの作成であった という事情による。 実際の噴火開始よりも遅い時間を噴火開始と同定してしまった場合、 噴火時に発生した傾斜変動を噴火前の傾斜変動と誤認することになる。 実際の噴火開始よりも早い時間を噴火開始と同定する分にはこの問題は起こらない。 それゆえ噴火開始時刻を真の値から早い側に誤る方が遅い側に誤るよりも悪影響が少なく、 そのためには同一の噴火について開始時刻の候補が複数あるならば その中の最初のものを選ぶのが良いという判断になる。
The first one is chosen from the candidates because the purpose of this program (at the time of development) is to create an eruption catalog as the basic data for a research of pre-eruptive tilt changes. If an eruption is detected at a time later than the true value, a syn-eruptive tilt change may be misinterpreted as pre-eruptive. If an eruption is detected at a time earlier than the true value, this problem does not occur. Therefore, errors in the detected eruption time to an earlier side have less effects than the errors to a later side on the study of pre-eruptive tilt changes. For this reason, the earliest candidate is chosen from multiple candidates for the same eruption.

以上のアルゴリズムでは時刻\(t\)が噴火であるか否かを判断するために区間 \([t+T_i^{rise}+T_n^{travel}+\tau_i^{st}, t+T_i^{rise}+T_n^{travel}+\tau_i^{en}]\) の連続波形データが必要になる。 \(T_i^{rise}\), \(T_n^{travel}\), \(\tau_i^{en}\)は全て正であるので \(t<t+T_i^{rise}+T_n^{travel}+\tau_i^{en}\)である。 一方、\(\tau_i^{st}<0\)であるので \(t+T_i^{rise}+T_n^{travel}+\tau_i^{st}\)は \(t\)よりも大きい(遅い)場合も小さい(早い)場合もありうる。
This algorithm requires continuous waveform data in a section \([t+T_i^{rise}+T_n^{travel}+\tau_i^{st}, t+T_i^{rise}+T_n^{travel}+\tau_i^{en}]\) to identify whether \(t\) is an eruption time. The end of this time window is necessarily later than \(t\) (i.e., \(t<t+T_i^{rise}+T_n^{travel}+\tau_i^{en}\)) because \(T_i^{rise}\), \(T_n^{travel}\), and \(\tau_i^{en}\) are all positive. The start of the time window (\(t+T_i^{rise}+T_n^{travel}+\tau_i^{st}\)) may be earlier or later than \(t\) because \(\tau_i^{st}<0\).

このプログラムでは一定の時間間隔(例えば1時間毎や1日毎など)で複数ファイルに分割された 連続波形データを読み込んで処理を行う。 連続する2つの時間帯のファイルのデータ (例えば1時間毎に分割されたデータファイルを使用する場合であれば2時間分の波形) を同時にコンピュータメモリに読み込んで処理する。 1ファイルあたりの波形の長さを\(T^{file}\)、 ファイルの区切りの時刻のうちの1つを\(t^o\)として、 \(t^o-T^{file}/2\leq t<t^o+T^{file}/2\) の範囲の噴火の検知には \([t^o-T^{file},t^o)\)および\([t^o,t^o+T^{file})\) の連続波形データを使用する。この連続波形データが 時刻\(t\)が噴火であるか否かを判断するために必要な \([t+T_i^{rise}+T_n^{travel}+\tau_i^{st}, t+T_i^{rise}+T_n^{travel}+\tau_i^{en}]\) の区間を包含するための条件は \[\begin{equation} t^o-T^{file} \leq t^o-\frac{T^{file}}{2}+T_i^{rise}+T_n^{travel}+\tau_i^{st} \label{eq.window.start} \end{equation}\] \[\begin{equation} t^o+\frac{T^{file}}{2}+T_i^{rise}+T_n^{travel}+\tau_i^{en} < t^o+T^{file} \label{eq.window.end} \end{equation}\] と表され、整理すると \[\begin{equation} -\frac{T^{file}}{2} \leq T_i^{rise}+T_n^{travel}+\tau_i^{st} \label{eq.window.start.arranged} \end{equation}\] \[\begin{equation} T_i^{rise}+T_n^{travel}+\tau_i^{en} < \frac{T^{file}}{2} \label{eq.window.end.arranged} \end{equation}\] となる。全てのテンプレート波形について (\ref{eq.window.start.arranged})(\ref{eq.window.end.arranged}) 式の条件が満たされるようにテンプレート波形の長さや 連続波形データの1ファイルあたりの長さ\(T^{file}\)、 \(T_i^{rise}\)や\(T_n^{travel}\)の値を決める必要がある。
This program reads continuous waveform data separated as multiple files of a fixed length (e.g., hourly or daily data). The data from two consecutive time sections (i.e., 2-h data if hourly data files are used) are read into a computer memory simultaneously. Eruptions in \(t^o-T^{file}/2\leq t<t^o+T^{file}/2\) are detected using continuous waveform records in sections \([t^o-T^{file},t^o)\) and \([t^o,t^o+T^{file})\), where \(T^{file}\) is the length of the continuous waveform in each file and \(t^o\) is one of the times at which the files are divided. Conditions that these sections include the data necessary to identify whether \(t\) is an eruption (\([t+T_i^{rise}+T_n^{travel}+\tau_i^{st}, t+T_i^{rise}+T_n^{travel}+\tau_i^{en}]\), as mentioned earlier) are given as Eqs. (\ref{eq.window.start}) and (\ref{eq.window.end}), which can be arranged as (\ref{eq.window.start.arranged}) and (\ref{eq.window.end.arranged}), respectively. The lengths of all template waveforms, the length \(T^{file}\) of the continuous waveform in each file, and the values of \(T_i^{rise}\) and \(T_n^{travel}\) must be chosen to satisfy Eqs. (\ref{eq.window.start.arranged}) and (\ref{eq.window.end.arranged}).


◆ソースコード(Source code)

$YMAEDA_OPENTOOL_DIR/sac_data/src/detect_eruption_airWave_independent.c


◆使用方法(Usage)

コマンドライン引数でパラメータを指定する。 パラメータの一覧を下表に示す。
Specify parameters by command-line arguments. The table below shows a list of parameters.


●「-」から始まらない引数 (Arguments not beginning with “-”)

このコマンドでは「-」から始まらない引数は存在しない。
This command does not have arguments not beginning with “-”.


●1つの「-」から始まる引数 (Arguments beginning with a single “-”)

このコマンドでは1つの「-」から始まる引数は存在しない。
This command does not have arguments beginning with a single “-”.


●「--パラメータ名=パラメータ値」の形式の引数 (Arguments of a form “--Parameter name=Parameter Value”)

「--パラメータ名=パラメータ値」の形式の引数は自由な順番で指定できる。 「-」から始まらない引数の間に挿入しても良い。 相反する指定がなされた場合には後の指定が優先される。 デフォルト値を持つパラメータは省略できる。
Arguments of a form “--Parameter name=Parameter Value” can be placed in an arbitrary order. They can even be inserted between arguments not beginning with “-”. In case of conflicting options being specified, the latter option has a higher priority. Parameters that have default values can be omitted.

パラメータ名
Parameter name
意味
Meaning
可能なパラメータ値
Allowed parameter values
デフォルト値
Default value
inputfiles 入力として用いる連続波形データファイル名。 ファイルはSAC形式の時系列データファイルとする。 通常、複数のファイルであるが、 それらを列挙するのではなく、 日時や観測点・成分コードをパターンとして含む形で命名規則で与える。 サンプリング間隔は全てのファイルで共通かつ テンプレート波形のサンプリング間隔とも等しくなければならない。
The name of the continuous waveform data files used as the inputs. Each file must be a time series data file of SAC format. Although multiple files are usually used, do not list them but instead give the naming rule of the file names that includes the patterns corresponding to the date, time, and station and component codes. The sampling intervals for all files must be same and must be equal to the sampling intervals of template waveforms.
ファイル名を表す文字列。ディレクトリパスを含んでいても良い。 以下のパターン文字列を含めることができる。
A string that represents a file name, possibly including the directory path. The patterns listed below can be used.

  • %YYYY
    年(西暦、4桁)
    Year (A.D., 4-digits)

  • %YY
    年(西暦、下2桁)
    Year (A.D., lowest 2-digits)

  • %MM
    月(2桁)
    Month (2-digits)

  • %DD
    日(2桁)
    Day (2-digits)

  • %JJJ
    その年の先頭からの日数(3桁、1月1日が001)
    The number of days from the beginning of the year (3-digits; Jan. 1 corresponds to 001)

  • %hh
    時(2桁)
    Hour (2-digits)

  • %mm
    分(2桁)
    Minute (2-digits)

  • %ss
    秒(2桁)
    Second (2-digits)

  • %STATION
    観測点コード
    Station code

  • %COMPONENT
    成分コード
    Component code

省略不可
Cannot be omitted
start 解析期間の先頭日時。この日付以降に発生した噴火が探索対象となる。
The beginning date and time of the analysis period. Eruptions that occurred after this date and time are searched.
「YYYY-MM-DD.hh-mm-ss」の形式の文字列。ここで
  • YYYY: 年(西暦4桁)
  • MM: 月(2桁)
  • DD: 日(2桁)
  • hh: 時(2桁)
  • mm: 分(2桁)
  • ss: 秒(2桁)
である。
A string of “YYYY-MM-DD.hh-mm-ss” format, where
  • YYYY is the year (A.D., 4-digits),
  • MM is the month (2-digits),
  • DD is the day (2-digits),
  • hh is the hour (2-digits),
  • mm is the minute (2-digits), and
  • ss is the second (2-digits).
省略不可
Cannot be omitted
end 解析期間の末尾日時。この日付以降に発生した噴火が探索対象となる (この日時よりも少し後の波形データまで使用する)。
The end date and time of the analysis period. Eruptions that occurred before this date and time are searched (using waveforms until time periods slightly after this date and time).
「YYYY-MM-DD.hh-mm-ss」の形式の文字列。ここで
  • YYYY: 年(西暦4桁)
  • MM: 月(2桁)
  • DD: 日(2桁)
  • hh: 時(2桁)
  • mm: 分(2桁)
  • ss: 秒(2桁)
である。
A string of “YYYY-MM-DD.hh-mm-ss” format, where
  • YYYY is the year (A.D., 4-digits),
  • MM is the month (2-digits),
  • DD is the day (2-digits),
  • hh is the hour (2-digits),
  • mm is the minute (2-digits), and
  • ss is the second (2-digits).
省略不可
Cannot be omitted
file_interval 入力ファイルの時間区切りの長さ(s)。 例えば1時間毎に分割されたファイルを用いる場合は3600となる。
The time length (s) of individual input files. For example, the value is 3600 if the files are divided every 1 hour.
正の整数。
A positive integer.
パラメータinputfileに登場するパターン文字列の最小時間単位。 例えばパラメータinputfileに%hhまで登場するなら1時間刻み(3600)、 %mmまで登場するなら1分刻み(60)となる。
The minimum time unit of the pattern strings that appear in parameter inputfile. For example, if the parameter inputfile includes down to %hh then the interval is 1 hour (3600); if %mm is included then 1 min (60).
station_config_file 観測点毎の設定の詳細が記載されたファイル名。 テキストファイルであり拡張子は何でも良い。 ファイルの書式はこちら
The name of a file that gives detailed settings for each station. This is a text file with an arbitrary extension. Click here for the file format.
ファイル名を表す文字列。ディレクトリパスを含んでいても良い。
A string that represents a file name, possibly including the directory path.
省略不可
Cannot be omitted
template_list_file テンプレートとして用いる短時間の波形データファイル名を列挙したテキストファイル名。 テキストファイルであり拡張子は何でも良い。 ファイルの書式はこちら
The name of a text file that lists the names of short waveform data files used as the templates. This is a text file with an arbitrary extension. Click here for the file format.
ファイル名を表す文字列。ディレクトリパスを含んでいても良い。
A string that represents a file name, possibly including the directory path.
省略不可
Cannot be omitted
eruption_interval_min 使用する\(\Delta t_{min}\)の値(s)。
The value of \(\Delta t_{min}\) (s) used.
正の実数。
A positive real number.
省略不可
Cannot be omitted
outputfile 出力ファイル名。 テキストファイルであり拡張子は何でも良い。
The name of the output file. This is a text file with an arbitrary extension.
ファイル名を表す文字列。ディレクトリパスを含んでいても良い。
A string that represents a file name, possibly including the directory path.
省略不可
Cannot be omitted

  1. パラメータstation_config_fileで指定するファイルの書式は以下の通り。
    The format of the file specified by parameter station_config_file is as follows.

  2. パラメータtemplate_list_fileで指定するファイルの書式は以下の通り。
    The format of the file specified by parameter template_list_file is as follows.



◆動作(Behaviour)

パラメータstartで指定した日時からendで指定した日時までの期間における噴火を検知し、 結果をパラメータoutputfileで指定したファイルに出力する。
Detect eruptions from the date and time specified by parameter start to those specified by parameter end and record the result into the file specified by parameter outputfile.

出力ファイルには1行につき1つの噴火の情報が以下の書式で出力される。 列の区切りにはタブが用いられる。
The output file consists of the information of an eruption in each line with the format as below. Tabs are used to separate the columns.


Column

Value
1 検出した噴火の日時(YYYY/MM/DD hh:mm:ss.sss形式)。
The date and time of a detected eruption (in YYYY/MM/DD hh:mm:ss format).
2 その噴火の検出に用いられた観測点コード。
The code of a station used to detect this eruption.
3 \(t_i^p\)の値(s)。 \(T^{file}\)の間隔で別々のファイルに分割された連続波形データにおける、 噴火日時を含む時間区切りの先頭(例えば1時間や1日の先頭)を0とする相対時間で表す。 多くの場合、この値は連続波形データの中での時間(s)と一致するので、 この値を用いることで連続波形中の検出された噴火のシグナルを 容易に見つけることができる。
The value of \(t_i^p\) (s), expressed as a relative time from the beginning of a time section of file units that includes the eruption time (e.g., the beginning of the hour or the day of the eruption). This value is useful to identify the eruption signal in the continuous waveform because the definition of the relative time (s) is identical to that of continuous waveform in most cases.
4 時刻\(t_i^p\)における連続波形の振幅。
The amplitude of the continuous waveform at time \(t_i^p\).
5 相関係数(\ref{eq.correlation}式)。
The correlation coefficient (Eq. \ref{eq.correlation}).
6 この噴火の検知に用いられたテンプレート波形のファイル名。
The file name of the template waveform used to detect this eruption.

直前に検知された噴火との時間差が\(\Delta t_{min}\)未満であったために 検知済みの噴火と同一の噴火であると判断されたものについては 参考値として行頭に「#」を付けて出力される。 これにより、「#」から始まる行を無視すれば最終的な噴火日時のリストになり、 「#」から始まる行を含めて調査すれば 個々のテンプレート波形や観測点による検知結果の詳細を知ることができる。
Eruptions that occurred after \(< \Delta t_{min}\) from the previously detected eruption, which are regarded as duplicated detections of the same eruption, are written into this file with # at the head. Therefore, ignoring lines beginning with # gives the final list of eruptions, whereas the analyzer can survey the details of the detection results from individual templates and stations by looking at these comment lines of the output file.


◆使用例(Example)

detect_eruption_airWave_independent --inputfiles=data_continuous/%STATION/%YYYY-%MM-%DD.sac --start=2025-01-01.00-00-00 --end=2025-01-31.23-59-59 --station_config_file=stations.ini --template_list_file=templates.ini --eruption_interval_min=1.0 --outputfile=eruptions_detected.dat

(stations.ini)
NU.STN1[TAB]Ac[TAB]5.6[TAB]10.0
NU.STN2[TAB]Ac[TAB]7.8[TAB]10.0
NU.STN3[TAB]Ac[TAB]12.3[TAB]10.0

(templates.ini)
NU.STN1[TAB]data_templates/2025-01-02.03-04-05/NU.STN1.Ac.sac[TAB]0.5[TAB]0.7
NU.STN2[TAB]data_templates/2025-01-02.03-04-05/NU.STN2.Ac.sac[TAB]0.5[TAB]0.7
NU.STN1[TAB]data_templates/2025-01-05.06-54-32/NU.STN1.Ac.sac[TAB]0.5[TAB]0.7
NU.STN2[TAB]data_templates/2025-01-05.06-54-32/NU.STN2.Ac.sac[TAB]0.5[TAB]0.7
NU.STN3[TAB]data_templates/2025-01-05.06-54-32/NU.STN3.Ac.sac[TAB]0.5[TAB]0.7
NU.STN2[TAB]data_templates/2025-01-12.03-45-01/NU.STN2.Ac.sac[TAB]1.0[TAB]0.7
NU.STN3[TAB]data_templates/2025-01-12.03-45-01/NU.STN3.Ac.sac[TAB]1.0[TAB]0.7

ここでNU.STN1, NU.STN2, NU.STN3は観測点コード、Acは成分コードであり、 [TAB]はタブを表す。
Here, NU.STN1, NU.STN2, and NU.STN3 are station codes, Ac is a component code, and [TAB] represents a tab.