-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogger.py
47 lines (37 loc) · 1.21 KB
/
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
import numpy as np
import matplotlib as mpl
mpl.use('Agg')
import matplotlib.pyplot as plt
class Logger():
def __init__(self):
self.data = dict()
self.x_vals = []
def append(self, new_data, x_val=None):
"""
Appends data to the data dict.
new_data - dictionary with data pts
x_val - value of x axis to associate with the data contained in
new_data
"""
for key in new_data.keys():
if key in self.data:
self.data[key].append(new_data[key])
else:
self.data[key] = [new_data[key]]
if x_val is not None:
self.x_vals.append(x_val)
def log_data(self):
pass
def make_plots(self, save_name='', xlabel='Frames'):
l = len(self.data[list(self.data)[0]])
if len(self.x_vals) != l:
self.x_vals = np.arange(l)
if save_name != "":
save_name = save_name+"_"
for key in self.data.keys():
plt.plot(self.x_vals, self.data[key])
plt.xlabel(xlabel)
plt.ylabel(key)
plt.title(key)
plt.savefig(save_name+key+".png")
plt.clf()