Seismic phase picker.
Project description
PickAx
PickAx: a simple seismic picker, when you just need to dig out a few arrivals.
Start
pickax -h
Hi PickAx!
usage: pickax [-h] [-v] [-l LOADER] [-s SEIS]
Pickax, really simple seismic phase picker.
options:
-h, --help show this help message and exit
-v, --verbose increase output verbosity
-l LOADER, --loader LOADER
Initialization loader script, run at startup
-s SEIS, --seis SEIS Seismogram file, loaded at startup
For example, using simple.py to initialize pickax, load some data from files and open the picker window:
pickax -l simple.py
Or to view just a single miniseed file, ie quick look:
pickax -s JKYD.mseed
Keys
- c: Create a generic pick at the current mouse location
- a: Create a P pick at the current mouse location
- s: Create a S pick at the current mouse location
- backspace: Delete pick at the current mouse location
- d: Display your picks
- D: Display all picks
- f: Apply next filter
- F: Apply previous filter
- x: Zoom in, first use marks one edge, second zooms in
- X: Zoom back out, double time displayed
- z: Return to original autozoom
- w: Shift seismogram to left (west)
- e: Shift seismogram to right (east)
- t: Print current time, amplitude at mouse position
- v: Go to next data
- r: Go to previous data
- V: Skip forward to next quake
- R: Skip backward to previous quake
- q: Quit
- h: Display this help, but you knew that, right?
Picks are draggable with the mouse.
Configuration
PickAx tries to be very simple and do just one thing, just like
a pickax is good for digging a hole in
red clay, but is just one of the tools in your toolshed. So don't forget
to use your shovels, screwdrivers and lawnmowers for the things they do better.
Basically all data management is handed off to the startup
script. By setting the finishFn, you can save picks however you want (or not
at all), and load in the next seismogram for display. Setting the filters
allows toggling between different ways of processing the seismogram.
The creation_info provides default creation info for the pick,
primarily for author or agency_id, defaulting to author=os.getlogin()
.
See simple.py for an example of setting up pickax and loading data.
The fdsnws_query.py is another example that uses FDSN web services to load data on the fly.
Filter functions
Filters are often a way of applying actual time series filters, but can
be anything that modifies the waveform.
They are each a simple dictionary with a name
and fn
.
The function will be called
with four arguments. First is a copy of the original stream, so modification in
place is safe. The second is the current filtered stream, so filters can build
on the previous if that is what you want. Third is the name for the current
filter function, and last is the filter index, just for reference.
If a stream is returned, that becomes
the current displayed stream, but if None is returned, then it assumes
the original was modified in place.
Finish function
The finish function is called whenever the user quits, goes to next or previous,
ie q
, V
, v
, R
or r
. It is called with four arguments, first is the QuakeML
Event, which contains picks, including both new picks and any existing picks.
Second is the current stream, useful to get the channel. Third is the command,
one of "quit", "next", "next_quake", "prev" or "prev_quake" and the last is pickax itself.
For next and prev, you generally will call
pickax.update_data()
passing in a new stream and optionally
quake and inventory if they have changed.
Title
The main window can fave an additional title string, generated by titleFn. The default is origin time, lat/lon depth and magnitude of the event. The titleFn takes 3 arguments, quake, inventory and stream, similar to the update_data function.
utilities
-
usgspicks: reload event from USGS by id to load picks as default query does not include picks. Likely only works if host is USGS server.
-
mergepicks: merge picks from one or more QuakeML files into another, optionally limiting to author
-
dumppicks: print picks from one or more QuakeML files
build hints
conda create -n pickax python=3.10
conda activate pickax
python3 -m pip install --upgrade build
/bin/rm -f dist/* && python3 -m build
pip3 install dist/seismic_pickax-*-py3-none-any.whl --force-reinstall
or if all deps are already installed, much faster:
pip3 install dist/seismic_pickax-*-py3-none-any.whl --force-reinstall --no-deps
to publish:
python3 -m twine upload dist/*
for testing, use code in current directory so updates on edit:
pip install -v -e .
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file seismic-pickax-0.6.0.tar.gz
.
File metadata
- Download URL: seismic-pickax-0.6.0.tar.gz
- Upload date:
- Size: 42.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d3237ba0816837ee58a91cc348e3eb794be0e064459e1956b0a3fbc03e181ab5 |
|
MD5 | 3eb2836c784d9a6ed6053269f36a3d3a |
|
BLAKE2b-256 | 41a0e689c5c2656a1c4cf133949651609f52436625b73305754bb8373aaeaeb6 |
File details
Details for the file seismic_pickax-0.6.0-py3-none-any.whl
.
File metadata
- Download URL: seismic_pickax-0.6.0-py3-none-any.whl
- Upload date:
- Size: 51.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 11f4e692ba32752c8c559f51336f495a670e272ee1858b9f1a7c948df5c3e77e |
|
MD5 | bb38ce1ce570f094c3dae07b4c2e2d93 |
|
BLAKE2b-256 | 95120df382fd46d71ae9f5c3137378df5d936ab962df1855b051e10d68589b2a |