File Exchange

image thumbnail

An automated P-phase Arrival Time Picker with SNR output

version 6.0.2 (1.5 MB) by Dr. Erol Kalkan, P.E.
PPHASEPICKER is a powerful tool for automatically picking P-phase onsets.

15 Downloads

Updated 03 Apr 2019

View License

PPHASEPICKER is a powerful tool for automatically picking P-phase onsets with high precision without requiring detection interval or threshold settings. The algorithm detects P-phase onset in single-component acceleration or broadband velocity records using the histogram method. It also computes signal-to-noise ratio (SNR).

PPHASEPICKER has been integrated into the “Automated Processing and Review Interface for Strong Motion Data (PRISM)” software (https://earthquake.usgs.gov/research/software/prism/) of the U.S. Geological Survey in order to identify pre-event time-window for systematic and automated processing of large numbers of strong-motion data.

An example MatLAB code is provided in zip file to show how to run PPHASEPICKER using three sample waveforms, one from strong earthquake and others from micro seismic events.

For your intended application, please note that filter corner frequencies may need to be updated manually within the code based on the frequency content of the input record.

Reference:

Kalkan, E. (2016). “An Automatic P-phase Arrival Time Picker“, Bull. of Seis. Soc. of Am., 106(3): 971-986, doi: 10.1785/0120150111.

Cite As

Dr. Erol Kalkan, P.E. (2019). An automated P-phase Arrival Time Picker with SNR output (https://www.mathworks.com/matlabcentral/fileexchange/57729-an-automated-p-phase-arrival-time-picker-with-snr-output), MATLAB Central File Exchange. Retrieved .

Comments and Ratings (8)

That's a good comment. Note that background noise always exists in the signal itself too so it is not possible to say P-phase onset is the cutoff between noise and seismic signal. It is a cut-off between noise and noise+seismic signal. Even if you filter out the signal based on FAS of the noise, you still remove part of the seismic signal within the same passband. Nonetheless, I will include your suggestion into the code as short window SNR output. Thanks...

Erol in part where you Compute SNR, you take:
signal=x;
noise=x(1:loc/dt);
but x is all signal (noise first and signal then). I think that is necessary select only seismic wave signal without noise for example using a window centered in ppicking time (that suppose is named Tm) and taking 2 second after this value and 1 second first this value (using a window of width 3s). So the signal window will be [Tm-1s;Tm+2s].

I just completed a new algorithm to pick both P- and S-phases. It is now in MatLAB FEX.
https://www.mathworks.com/matlabcentral/fileexchange/70343-an-automated-s-phase-arrival-time-picker-with-snr-output

This algorithm no find the time value when p-phase end, and the s-phase pick. How find them? Thanks.

Thank you! I have included a link above for download of the paper.

Hello, would it be possible for you to email me your paper - “An Automatic P-phase Arrival Time Picker“, mentioned in the reference section to - "pritesh@ou.edu". I would really like to read it.

Zhichao Yu

Updates

6.0.2

Description updated

6.0.1

Updated notes

6.0.0.0

Updated the reference

6.0.0.0

Updated description

6.0.0.0

Added signal-to-noise ratio computation
Updated demo example file

5.0.0.0

Code is modified to prevent numerical errors due to very low amplitude input signals

4.0.0.0

Added BSSA paper describing the picker

4.0.0.0

Fixed "nbins" for arbitrary sampling rates; tested for inhomogeneous (arbitrarily sampled) weak acceleration records from China.

3.0.0.0

Modified for low sampled input waveforms (lower than 100 samples-per-second, sps) and third example (waveform with 80 sps) is included in demo file.

2.0.0.0

Tested for MatLAB 2013a, 2014a and 2016a.

1.0.0.0

A new micro seismic earthquake example is included.
Histogram computation is added in order to eliminate need for digital signal processing toolbox.
"no bandpass filter" option is added.

1.0.0.0

Typo has been fixed.

1.0.0.0

Text is revised

MATLAB Release Compatibility
Created with R2014a
Compatible with any release
Platform Compatibility
Windows macOS Linux