forked from pyrocko/contrib-snufflings
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdrumplot.py
126 lines (108 loc) · 4.18 KB
/
drumplot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
import logging
import numpy as num
import matplotlib.pyplot as plt
import copy
from pyrocko import util, trace
from pyrocko.gui.snuffling import Snuffling, Choice, Switch, Param
logger = logging.getLogger('pyrocko.gui.snuffling.drumplot')
class DrumPlot(Snuffling):
'''
Drum Plot
'''
def setup(self):
'''Customization of the snuffling.'''
self.set_name('Drum Plot')
self.add_parameter(
Param(
'Gain', 'yscale', 2., 0.1, 100.)
)
self.add_parameter(
Choice(
'Pre-scale', 'prescale', 'max', ['max', 'std'])
)
self.add_parameter(
Choice(
'N minutes', 'xminutes', '15', ['1', '15', '30', '60'])
)
# self.add_parameter(
# Choice(
# 'N hours', 'nhours', '24', ['24', '1'])
# )
self.add_parameter(Switch('Global common scale', 'scale_global', True))
self.set_live_update(False)
def call(self):
'''Main work routine of the snuffling.'''
self.cleanup()
viewer = self.get_viewer()
figs = {}
fig_width_inch = viewer.width()
npixel_hori = float(fig_width_inch*50)
xminutes = int(self.xminutes)
xseconds = xminutes * 60
self.nhours = 24
nrows = int(self.nhours) * 60 / xminutes
ynormalizations = {}
lines_data = {}
for traces in self.chopper_selected_traces(tinc=60*60, fallback=True):
for tr in traces:
t0 = util.day_start(tr.tmin)
key = (tr.nslc_id, t0)
if key not in figs:
fig = self.pylab(get='figure')
ax = fig.add_subplot(111)
figs[key] = (fig, ax)
ynormalizations[key] = 0
lines_data[key] = []
tr = tr.copy(data=True)
ndecimate = int((xseconds/tr.deltat) / npixel_hori)
tr.downsample(ndecimate)
if self.prescale == 'max':
ynormalizations[key] = max(num.max(tr.ydata), ynormalizations[key])
else:
ynormalizations[key] = max(num.std(tr.ydata), ynormalizations[key])
if viewer.highpass:
tr.highpass(4, viewer.highpass)
if viewer.lowpass and 1./tr.deltat>2.*viewer.lowpass:
tr.lowpass(4, viewer.lowpass)
t = tr.get_xdata() - t0
y = num.asarray(tr.get_ydata(), dtype=num.float)
nskip = t / 3600.
x = t % xseconds
xdiff = num.diff(x)
itmp = num.where(num.logical_or(xdiff < 0, num.abs(xdiff-tr.deltat) > 1E-4))[0]
indices = num.zeros(len(itmp)+2, dtype=num.int)
indices[1:-1] = itmp
indices[-1] = len(y)-1
for i in range(len(indices)-1):
istart = indices[i] + 1
istop = indices[i+1]
lines_data[key].append(
(t0, x[istart: istop], y[istart: istop],
nskip[istart: istop])
)
ynorm = None
if self.scale_global:
ynorm = max(ynormalizations.values())
for key, lines in lines_data.items():
if not self.scale_global:
ynorm = float(ynormalizations.get(key, 1.))
for (t0, x, y, shifts) in lines:
fig, ax = figs[key]
ax.plot(
x/60.,
y/(ynorm/self.yscale) + shifts,
color='black')
ax.set_title(util.tts(t0, format='%Y-%m-%d'))
yticks = range(0, self.nhours+2, 2)
xticks = range(0, xminutes+1, 1)
for key, (fig, ax) in figs.items():
ax.set_xlim(0, xminutes)
ax.set_ylabel('Hour')
ax.set_xlabel('Minute')
ax.yaxis.set_ticks(yticks)
ax.xaxis.set_ticks(xticks)
ax.set_ylim(-0.1, 24.1)
fig.canvas.draw()
def __snufflings__():
'''Returns a list of snufflings to be exported by this module.'''
return [DrumPlot()]