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
|
from qolab.file_utils import save_table_with_header
class Trace:
def __init__(self, label):
self.label = label
self.values = None
self.unit = None
self.tags = {}
def plot(self):
import matplotlib.pyplot as plt
plt.plot(self.values, label=self.descr)
plt.legend()
def header(self):
header = []
if self.label is not None:
header.append(f'label = {self.label}')
if self.unit is not None:
header.append(f'unit = {self.unit}')
for k, v in self.tags.items():
header.append(f'{k} = {v}')
return header
def write(self, fname):
pass
class TraceXY:
def __init__(self, label):
self.label = label
self.x = None
self.y = None
def plot(self):
import matplotlib.pyplot as plt
plt.plot(self.x.values, self.y.values, label=self.label)
plt.legend()
plt.xlabel(self.x.label)
class TraceSetSameX:
def __init__(self, label):
self.label = label
self.x = None
self.traces={}
def addTrace(self, tr):
if len(self.traces) == 0:
self.x = tr.x
trY = tr.y
self.traces[tr.label]=trY
def plot(self):
import matplotlib.pyplot as plt
for k, tr in self.traces.items():
plt.plot(self.x.values, tr.values, label=tr.label)
plt.xlabel(self.x.label)
plt.legend()
def items(self):
return (self.traces.items())
def keys(self):
return (self.traces.keys())
def getTrace(self, label):
tr = TraceXY(label)
tr.x = self.x
tr.y = self.traces[label]
return (tr)
|