2015-03-10 14:25:41 +01:00
|
|
|
#! /usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
2015-04-10 10:51:58 +02:00
|
|
|
Produce a dayplot from seismogram recordings
|
2015-03-10 14:25:41 +01:00
|
|
|
|
2022-02-23 14:21:23 +01:00
|
|
|
version: v1.2 (2022-02-23)
|
2015-04-10 10:51:58 +02:00
|
|
|
|
|
|
|
license: gpl3
|
2020-07-14 21:13:15 +02:00
|
|
|
Copyright 2012-2020 Seismological Observatory, Ruhr-University Bochum
|
2015-03-10 14:25:41 +01:00
|
|
|
http://www.gmg.ruhr-uni-bochum.de/geophysik/seisobs
|
|
|
|
Contributors:
|
|
|
|
Martina Rische <martina.rische@rub.de>
|
|
|
|
Kasper D. Fischer <kasper.fischer@rub.de>
|
|
|
|
Sebastian Wehling-Benatelli <sebastian.wehling@rub.de>
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify it
|
|
|
|
under the terms of the GNU General Public License as published by the Free
|
|
|
|
Software Foundation, either version 3 of the License, or (at your option)
|
|
|
|
any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful, but
|
|
|
|
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along
|
|
|
|
with this program. If not, see http://www.gnu.org/licenses/.
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
2015-04-10 10:51:58 +02:00
|
|
|
def trace_dayplot(st, ftype='bandpass', fmin=1.0, fmax=7.0,
|
|
|
|
col=('b', 'r', 'g'), interval=20.0, outpattern=''):
|
|
|
|
"""
|
2015-03-10 14:25:41 +01:00
|
|
|
|
2015-04-10 10:51:58 +02:00
|
|
|
:type st: object
|
|
|
|
:type ftype: str
|
|
|
|
:type fmin: float
|
|
|
|
:type fmax: float
|
|
|
|
:type col: tuple
|
|
|
|
:type interval: float
|
|
|
|
:type outpattern: str
|
|
|
|
"""
|
2015-03-10 14:25:41 +01:00
|
|
|
|
2015-04-10 10:51:58 +02:00
|
|
|
# filter
|
2015-03-10 14:25:41 +01:00
|
|
|
if (ftype == 'bandpass') or (ftype == 'bandstop'):
|
|
|
|
st.filter(ftype, freqmin=fmin, freqmax=fmax)
|
|
|
|
elif (ftype == 'lowpass') or (ftype == 'highpass'):
|
|
|
|
st.filter(ftype, freq=fmin)
|
|
|
|
st.merge()
|
|
|
|
|
2015-04-10 10:51:58 +02:00
|
|
|
# plot
|
|
|
|
for i in range(0, len(st)):
|
|
|
|
if outpattern != '':
|
2015-03-10 14:25:41 +01:00
|
|
|
imagefile = outpattern.format(st[i].stats.network,
|
|
|
|
st[i].stats.station,
|
|
|
|
st[i].stats.channel,
|
|
|
|
st[i].stats.starttime.year,
|
|
|
|
st[i].stats.starttime.julday)
|
|
|
|
st[i].plot(type='dayplot', color=col, interval=interval,
|
|
|
|
outfile=imagefile)
|
|
|
|
else:
|
|
|
|
st[i].plot(type='dayplot', color=col, interval=interval)
|
|
|
|
|
|
|
|
|
|
|
|
# __main__
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
|
|
|
# parse arguments
|
|
|
|
import argparse
|
2015-04-10 10:51:58 +02:00
|
|
|
from obspy.core import read
|
|
|
|
|
2015-03-10 14:25:41 +01:00
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description='Produce filtered 24h-plot (dayplot).',
|
|
|
|
epilog='$Rev: 403 $ ($Date: 2012-04-13 12:16:22 +0200 (Fri, 13 Apr 2012) $, $Author: kasper $)')
|
2015-04-10 10:51:58 +02:00
|
|
|
parser.add_argument('-v', '-V', '--version', action='version',
|
|
|
|
version='$Rev: 403 $ ($Date: 2012-04-13 12:16:22 +0200 (Fri, 13 Apr 2012) $, $Author: kasper $)')
|
2015-03-10 14:25:41 +01:00
|
|
|
parser.add_argument('file', action='store', metavar='FILE', nargs='+',
|
2015-04-10 10:51:58 +02:00
|
|
|
help='File(s) to use for the dayplot. One dayplot will be used for every file. \
|
2015-03-10 14:25:41 +01:00
|
|
|
Use wildcards to use multiple file for one plot')
|
|
|
|
parser.add_argument('-f', '--filter', action='store', dest='ftype',
|
2015-04-10 10:51:58 +02:00
|
|
|
default='bandpass',
|
|
|
|
choices=['none', 'bandpass', 'bandstop', 'lowpass', 'highpass'],
|
|
|
|
help='Select filtertype to filter the data (default: bandpass)\
|
2015-03-10 14:25:41 +01:00
|
|
|
Note: For low- and highpass only fmin is used.')
|
|
|
|
parser.add_argument('--fmin', action='store', type=float, dest='fmin',
|
2015-04-10 10:51:58 +02:00
|
|
|
default=1.0,
|
|
|
|
help='Lower frequency of the filter in Hz (default: 1.0)')
|
2015-03-10 14:25:41 +01:00
|
|
|
parser.add_argument('--fmax', action='store', type=float, dest='fmax',
|
2015-04-10 10:51:58 +02:00
|
|
|
default=7.0,
|
|
|
|
help='Upper frequency of the filter in Hz (default: 7.0)')
|
2015-03-10 14:25:41 +01:00
|
|
|
parser.add_argument('-c', '--color', '--colour', action='store', dest='color',
|
2015-04-10 10:51:58 +02:00
|
|
|
default=('b', 'r', 'g'),
|
|
|
|
help='Color selection to use in the dayplot (default: brg)')
|
2015-03-10 14:25:41 +01:00
|
|
|
parser.add_argument('-i', '--interval', action='store', type=int, dest='interval',
|
2015-04-10 10:51:58 +02:00
|
|
|
default=20,
|
|
|
|
help='Interval length to show in each line of the dayplot in minutes (default: 20)')
|
|
|
|
parser.add_argument('-o', '--output', action='store', dest='outpattern',
|
|
|
|
default='',
|
|
|
|
help="Output filename pattern for the plot. (default: unset, show plot on screen only), \
|
2015-03-10 14:25:41 +01:00
|
|
|
Use {0} to substitute network code, \
|
|
|
|
{1} to substitute station code, \
|
2015-04-10 10:51:58 +02:00
|
|
|
{2} to substitute station channel, \
|
2015-03-10 14:25:41 +01:00
|
|
|
{3} to substitute year, \
|
|
|
|
{4} to substitute doy number \
|
|
|
|
.format (supported formats: emf, eps, pdf, png, ps, raw, rgba, svg, svgz)")
|
|
|
|
|
|
|
|
cla = parser.parse_args()
|
|
|
|
if cla.fmin < 0:
|
|
|
|
cla.fmin = -cla.fmin
|
|
|
|
if cla.fmax < 0:
|
|
|
|
cla.fmax = -cla.fmax
|
|
|
|
|
2015-04-10 10:51:58 +02:00
|
|
|
# call trace_dayplot(...) for each file
|
2015-03-10 14:25:41 +01:00
|
|
|
for datafile in cla.file:
|
2015-04-10 10:51:58 +02:00
|
|
|
trace_dayplot(read(datafile), cla.ftype, cla.fmin, cla.fmax, cla.color,
|
|
|
|
cla.interval, cla.outpattern)
|