-
Notifications
You must be signed in to change notification settings - Fork 114
/
Copy pathkiln-logger.py
executable file
·102 lines (82 loc) · 2.57 KB
/
kiln-logger.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 python
import websocket
import json
import time
import csv
import argparse
import sys
STD_HEADER = [
'stamp',
'runtime',
'temperature',
'target',
'state',
'heat',
'totaltime',
'profile',
]
PID_HEADER = [
'pid_time',
'pid_timeDelta',
'pid_setpoint',
'pid_ispoint',
'pid_err',
'pid_errDelta',
'pid_p',
'pid_i',
'pid_d',
'pid_kp',
'pid_ki',
'pid_kd',
'pid_pid',
'pid_out',
]
def logger(hostname, csvfile, noprofilestats, pidstats, stdout):
status_ws = websocket.WebSocket()
csv_fields = []
if not noprofilestats:
csv_fields += STD_HEADER
if pidstats:
csv_fields += PID_HEADER
out = open(csvfile, 'w')
csv_out = csv.DictWriter(out, csv_fields, extrasaction='ignore')
csv_out.writeheader()
if stdout:
csv_stdout = csv.DictWriter(sys.stdout, csv_fields, extrasaction='ignore', delimiter='\t')
csv_stdout.writeheader()
else:
csv_stdout = None
while True:
try:
msg = json.loads(status_ws.recv())
except websocket.WebSocketException:
try:
status_ws.connect(f'ws://{hostname}/status')
except Exception:
time.sleep(5)
continue
if msg.get('type') == 'backlog':
continue
if not noprofilestats:
msg['stamp'] = time.time()
if pidstats and 'pidstats' in msg:
for k, v in msg.get('pidstats', {}).items():
msg[f"pid_{k}"] = v
csv_out.writerow(msg)
out.flush()
if stdout:
for k in list(msg.keys()):
v = msg[k]
if isinstance(v, float):
msg[k] = '{:5.3f}'.format(v)
csv_stdout.writerow(msg)
sys.stdout.flush()
if __name__ == "__main__":
parser = argparse.ArgumentParser(description='Log kiln data for analysis.')
parser.add_argument('--hostname', type=str, default="localhost:8081", help="The kiln-controller hostname:port")
parser.add_argument('--csvfile', type=str, default="/tmp/kilnstats.csv", help="Where to write the kiln stats to")
parser.add_argument('--pidstats', action='store_true', help="Include PID stats")
parser.add_argument('--noprofilestats', action='store_true', help="Do not store profile stats (default is to store them)")
parser.add_argument('--stdout', action='store_true', help="Also print to stdout")
args = parser.parse_args()
logger(args.hostname, args.csvfile, args.noprofilestats, args.pidstats, args.stdout)