-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathobserver_plot.py
executable file
·85 lines (78 loc) · 3.73 KB
/
observer_plot.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
# -*- coding: utf-8 -*-
import os
import json
import time
import pytz
import obspy
import numpy
import requests
import datetime
import matplotlib.pyplot
import matplotlib.animation
station_net = "AS" # Station network code
station_stn = "SHAKE" # Station station code
station_loc = "00" # Station location code
station_address = "127.0.0.1:8073" # Observer address
hours = 6 # Plot X-axes hours
ts_offset = 0 # Data timestamp offset
show_interval = 60 # Plot Y-axes minutes
update_interval = 30 # Plot update interval
scaling_range = 1000000 # Plot scaling range
def make_trace(channel, sps, counts_list, timestamp):
trace = obspy.core.Trace(data=numpy.ma.MaskedArray(counts_list, dtype=numpy.float64))
trace.stats.network = station_net
trace.stats.station = station_stn
trace.stats.location = station_loc
trace.stats.channel = channel
trace.stats.sampling_rate = sps
trace.stats.starttime = obspy.UTCDateTime(timestamp)
return trace
def get_time():
six_hours_ago = datetime.datetime.now() - datetime.timedelta(hours = hours)
six_hours_ago = six_hours_ago.replace(minute = 0, second = 0, microsecond = 0)
timestamp = int(six_hours_ago.timestamp() * 1000)
return timestamp
def get_data(start_time, end_time, max_interval = 3600000):
data = {"BHZ": []}
while start_time < end_time:
current_end_time = min(start_time + max_interval, end_time)
payload = {"channel": "", "start": start_time, "end": current_end_time, "format": "json"}
response = requests.post(f"http://{station_address}/api/v1/history", data = payload, timeout = 15).json()["data"]
sample_rate = response[0]["sample_rate"]
for i in range(len(response)):
if i > 0:
delta = response[i]["timestamp"] - response[i - 1]["timestamp"]
if delta > 1100:
samples_to_fill = int(delta / (1000 / sample_rate))
average_value = sum(response[i - 1]["z_axis"]) / len(response[i - 1]["z_axis"])
data["BHZ"].extend([average_value] * samples_to_fill)
data["BHZ"].extend(response[i]["z_axis"])
start_time = current_end_time
return sample_rate, data
def update(frame):
try:
fig.clf()
ax = fig.add_subplot(111)
ax.set_axis_off()
now_utc = datetime.datetime.utcnow().replace(tzinfo = pytz.utc)
start_time_utc = now_utc - datetime.timedelta(hours = hours)
start_time_utc = start_time_utc.replace(minute = 0, second = 0, microsecond = 0)
end_time_utc = now_utc
data = get_data(int(start_time_utc.timestamp() * 1000) + ts_offset, int(end_time_utc.timestamp() * 1000) + ts_offset)
bhz_data = make_trace("BHZ", data[0], data[1]["BHZ"], start_time_utc.timestamp())
bhz_data.filter("bandpass", freqmin = 0.1, freqmax = 10.0, zerophase = True)
bhz_data.plot(ax = ax, fig = fig, type = "dayplot", title = "", color = ["k", "r", "b", "g"],
tick_format = "%H:%M", interval = show_interval,
vertical_scaling_range = scaling_range,
one_tick_per_line = True,
show_y_UTC_label = False,
starttime = obspy.UTCDateTime(start_time_utc),
endtime = obspy.UTCDateTime(end_time_utc),
subplots_adjust_left = 0.05, subplots_adjust_right = 1, subplots_adjust_top = 1, subplots_adjust_bottom = 0)
except Exception as e:
print(f"Error plotting data: {e}")
if __name__ == "__main__":
fig, ax = matplotlib.pyplot.subplots(num = "Observer Helicorder", figsize = (9.5, 3.8))
ani = matplotlib.animation.FuncAnimation(fig, update, interval = update_interval * 1000, cache_frame_data = False)
matplotlib.pyplot.show()
os._exit(0)