diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2017-07-08 22:35:29 +0200 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2017-07-08 22:35:29 +0200 |
commit | 5a8207c9d18ff88d6c762b8c57d57d9c4a2ff8db (patch) | |
tree | 4ab98185fd13d4d2f4866057407371b750079205 /ee | |
download | ee-python-5a8207c9d18ff88d6c762b8c57d57d9c4a2ff8db.tar.gz ee-python-5a8207c9d18ff88d6c762b8c57d57d9c4a2ff8db.tar.bz2 ee-python-5a8207c9d18ff88d6c762b8c57d57d9c4a2ff8db.tar.xz ee-python-5a8207c9d18ff88d6c762b8c57d57d9c4a2ff8db.zip |
o Start on some electronics engineering code.
Diffstat (limited to 'ee')
-rw-r--r-- | ee/__init__.py | 109 | ||||
-rw-r--r-- | ee/tools/__init__.py | 0 | ||||
-rw-r--r-- | ee/tools/read_ltspice_raw.py | 27 |
3 files changed, 136 insertions, 0 deletions
diff --git a/ee/__init__.py b/ee/__init__.py new file mode 100644 index 0000000..5c26c0a --- /dev/null +++ b/ee/__init__.py @@ -0,0 +1,109 @@ +import sympy +import numpy as np + +__all__ = [ + 'read_ltspice_raw' +] + +class LtSpiceRaw(object): + def __init__(self, variables, values): + self.variables = variables + self.values = values + + def get_values(self, variable): + v = [v for v in self.variables if v.expression == variable] + if len(v) != 1: + raise Error('Unknown variable: ' + str(variable)) + return self.values[v[0].idx] + +class LtSpiceVariable(object): + def __init__(self, idx, expression, kind): + self.idx = idx + self.expression = expression + self.kind = kind + +class LtSpiceReader(object): + + def __init__(self, f): + self.f = f + self.mode = 'header' + self.headers = {} + + def read_header(self, line): + sep = line.find(':') + key = line[0:sep] + value = line[sep + 1:].strip() + +# print("key='{}', value='{}'".format(key, str(value))) + + if key == 'Binary': + self.set_binary_mode() + elif key == 'Variables': + self.no_variables = int(self.headers['No. Variables']) + self.variables = [] + self.mode = 'variables' + else: + self.headers[key] = value + + def read_variable(self, line): + parts = line.split('\t') + idx = int(parts[1]) + expression = parts[2] + kind = parts[3] + self.variables.append(LtSpiceVariable(idx, expression, kind)) + + if len(self.variables) == self.no_variables: + self.mode = 'header' + + def set_binary_mode(self): + self.mode = 'binary' + + def read_binary(self): + pos = self.f.tell() + # Skip an extra '\0' + self.f.seek(pos + 1) + no_points = int(self.headers['No. Points']) + no_variables = int(self.headers['No. Variables']) +# print("variables={}, no_points={}, pos={}".format(no_variables, no_points, pos)) + self.values = vs = np.zeros((no_variables, no_points)) + for p in range(no_points): + vs[0][p] = np.fromfile(self.f, count=1, dtype='float64') + pointdata = np.fromfile(self.f, count=no_variables - 1, dtype='float32') +# print("value={:0=0.15e}".format(vs[0][p])) + for v in range(1, no_variables): +# print("p={}, v={}".format(p, v)) +# print(" value={:0=0.15e}".format(pointdata[v - 1])) + vs[v][p] = pointdata[v - 1] + + def read(self): + while True: + line = self.f.readline(); + + if len(line) == 0: + break + + if line[0] == 0: + line = line[1:] + if line[-1] == 10: + line = line[:-1] +# print("len(line)={}, line={}".format(len(line), str(line))) + line = str(line, encoding="utf-16") + + if self.mode == 'header': + self.read_header(line) + elif self.mode == 'variables': + self.read_variable(line) + + # The binary data can't be read with readline() + if self.mode == 'binary': +# self.f.read() + self.read_binary() + break + + return LtSpiceRaw(self.variables, self.values) + +def read_ltspice_raw(filename): + + with open(filename, mode="rb") as f: + r = LtSpiceReader(f) + return r.read() diff --git a/ee/tools/__init__.py b/ee/tools/__init__.py new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/ee/tools/__init__.py diff --git a/ee/tools/read_ltspice_raw.py b/ee/tools/read_ltspice_raw.py new file mode 100644 index 0000000..0b3b7e1 --- /dev/null +++ b/ee/tools/read_ltspice_raw.py @@ -0,0 +1,27 @@ +import ee +import sys + +raw = ee.read_ltspice_raw(sys.argv[1]) + +#print("Variables:") +#for i, v in enumerate(raw.variables): +# print("{:2}: kind: {:20} expression: {}".format(i, v.kind, v.expression)) + +#for i, v in enumerate(raw.variables): +# print("{:2}: kind: {:20} expression: {}".format(i, v.kind, v.expression)) +# for p in raw.values[i]: +# print(" {}".format(p)) + +xs = raw.get_values('V(load)') + +import matplotlib +matplotlib.use('Agg') + +import matplotlib.pyplot as plt +from matplotlib.ticker import FuncFormatter, MaxNLocator +fig = plt.figure() +ax = fig.add_subplot(111) +ax.plot(xs) + +with open("ltspice.png", "wb") as f: + plt.savefig(f, format="png") |