-
Notifications
You must be signed in to change notification settings - Fork 115
/
stats-voc.py
executable file
·102 lines (84 loc) · 2.84 KB
/
stats-voc.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
#!/usr/bin/env python3
# vim: set ts=4 sw=4 tw=0 et fenc=utf8 pm=:
import sys
import matplotlib.pyplot as plt
import os
from util import parse_channel
def filter_voc(t_start = None, t_stop = None, f_min = None, f_max = None):
tsl = []
fl = []
lines = []
quals = []
f = open(sys.argv[1])
for line in f:
line = line.strip()
if 'VOC: ' in line and not "LCW(0,001111,100000000000000000000" in line:
line_split = line.split()
oknok=0
if line_split[1] == 'VOC:':
oknok=int(line_split[0][len(line_split[0])-1])
line_split=line_split[1:]
else:
oknok= "LCW(0,T:maint,C:<silent>," in line
oknok=['red','orange','green'][oknok]
#ts_base = int(line[1].split('-')[1].split('.')[0])
ts_base = 0
ts = ts_base + float(line_split[2])/1000.
f = parse_channel(line_split[3])
if ((not t_start or t_start <= ts) and
(not t_stop or ts <= t_stop) and
(not f_min or f_min <= f) and
(not f_max or f <= f_max)):
tsl.append(ts)
fl.append(f)
quals.append(oknok)
lines.append(line)
return tsl, fl, quals, lines
def cut_convert_play(t_start, t_stop, f_min, f_max):
if t_start and t_stop:
if t_start > t_stop:
tmp = t_stop
t_stop = t_start
t_start = tmp
if f_min > f_max:
tmp = f_max
f_max = f_min
f_min = tmp
_, _, _, lines = filter_voc(t_start, t_stop, f_min, f_max)
if len(lines)==0:
print("No data selected")
return
f_out = open('/tmp/voice.bits', 'w')
for line in lines:
f_out.write(line + "\n")
f_out.close()
os.system("play-iridium-ambe /tmp/voice.bits")
def onclick(event):
global t_start, t_stop, f_min, f_max
print('button=%d, x=%d, y=%d, xdata=%f, ydata=%f'%(
event.button, event.x, event.y, event.xdata, event.ydata))
if event.button == 1:
t_start = event.xdata
f_min = event.ydata
t_stop = None
f_max = None
if event.button == 3:
t_stop = event.xdata
f_max = event.ydata
if t_start and t_stop:
cut_convert_play(t_start, t_stop, f_min, f_max)
def main():
tsl, fl, quals, _ = filter_voc()
print(len(tsl))
fig = plt.figure()
ax = fig.add_subplot(111)
ax.scatter(x = tsl, y = fl, c= quals, s=30)
t_start = None
t_stop = None
f_min = None
f_max = None
cid = fig.canvas.mpl_connect('button_press_event', onclick)
plt.title("Click once left and once rigth to define an area. The script will try to play iridium using the play-iridium-ambe shell script.")
plt.show()
if __name__ == "__main__":
main()