Skip to content

Latest commit

 

History

History
50 lines (34 loc) · 3.35 KB

README.md

File metadata and controls

50 lines (34 loc) · 3.35 KB

STA-LTA-OS: Adaptive STA-LTA with outlier statistics

Introduction

This is the online repository for code from [1]. Code is stable, semi-flexible, and has been cleaned and optimized from the original scripts.

Aim

STA-LTA with outlier statistics improves detection and picking accuracy, particularly in environments with many closely spaced events (e.g. earthquake swarms, hydraulic fractures).

Approach

In these programs, STA-LTA is recast as an outlier statistics problem using a two-state hidden Markov model (HMM), which I resolve with an expectation-maximization (EM) algorithm to determine the state membership probabilities of transformed data points.

Use

This program can be used without modification by creating a matrix X of column vector data and typing the command Ev = hmmscan(X);. The resultant structure Ev contains event start times (Ev.s), end times (Ev.e), P-picks (Ev.p), etc. Type help hmmscan for more details.

Descriptions of Individual Programs

  • hmmscan: Scan a record of data by applying EM to successive long data windows.
  • exmax: Two-state classification of column vector data using an expectation-maximization algorithm.
  • genprep: Generic data preprocessing.
  • es94ap: An automatic P-picker based on [2].
  • hmminit: Set initial HMM parameters.
  • sop: Event detection and picking from short-term averages of outlier probabilities.

Visualizing Results

One easy way to determine whether this program is working as expected is to compare the results of exmax using histograms. For example, the code below is a complete command sequence for one run of exmax using an exponential solver, with corresponding histogram plots. It bypasses hmmscan completely.

Y = genprep(X,{'demean'; 'abs'});

[h0,y0] = hist(Y,100); dy = y0(2)-y0(1); h0 = h0./max(h0); t1 = 0:dy:max(Y);

[P,f,Q] = exmax(Y,'cf','abs','slv','exp'); m1 = Q{1}(1,1); m0 = Q{1}(2,1);

y1 = (1/m1)*exp(-t1./m1); y1 = y1./max(y1);

y0 = (1/m0)*exp(-t1./m0); y0 = y1./max(y0);

figure; hold on; bar(y0,h0,1); xlim([0 max(y0)]);

plot(t1,y1,'k-','linewidth',2); plot(t1,y0,'k--','linewidth',2);

Limitations

  1. Because hmmscan expects a matrix of data in column vectors, it's implicitly assumed that data are sampled at a uniform rate and time-synched.
  2. The default program options are intended for borehole data sampled at 4 kHz. You'll need to modify many of them to use these routines on seismic network data.

Supplemental Notes

  1. Program exmax contains two solvers that weren't used in the paper: An ordinary Gaussian solver (opts.slv = 'gauss') and a questionable (i.e. possibly wrong) solver for beta distributions (opts.slv = 'beta'). I only tested the beta solver to the extent that I can confidently say it usually converges when fed a time series of beta-distributed coefficients. Use at your peril.
  2. I do not have data distribution rights. Data from the paper can be obtained from professor Mirko van der Baan (University of Alberta) or professor David Eaton (University of Calgary).

References

  1. Jones, J.P., and van der Baan, M. (2015). Adaptive STA-LTA with outlier statistics, Bull. Seismol. Soc. Am. 105 (3), 1606--1618. doi: 10.1785/0120140203.
  2. Earle, P., and P. Shearer (1994). Characterization of global seismograms using an automatic picking algorithm, Bull. Seismol. Soc. Am. 84 (2), 366--376.