-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathdisagg_EMU2.py
executable file
·121 lines (98 loc) · 3.79 KB
/
disagg_EMU2.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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/env python3
#
# Disaggregate smart meter reading from the EMU2 (disagg_EMU2.py)
# Copyright (C) 2016 Stephen Makonin. All Right Reserved.
#
import sys, json, serial
from statistics import mean
from time import time, sleep
from datetime import datetime
from libDataLoaders import dataset_loader
from libFolding import Folding
from libSSHMM import SuperStateHMM
from libAccuracy import Accuracy
import xml.etree.ElementTree as et
print()
print('-----------------------------------------------------------------------------------------')
print('Test running NILM and report stats each time -- Copyright (C) 2016, by Stephen Makonin.')
print('-----------------------------------------------------------------------------------------')
print()
print('Start Time = ', datetime.now(), '(local time)')
print()
if len(sys.argv) != 6:
print()
print('USAGE: %s [modeldb] [precision] [measure] [algo name] [device]' % (sys.argv[0]))
print()
print(' [modeldb] - file name of model (omit file ext).')
print(' [precision] - number; e.g. 10 would convert A to dA.')
print(' [measure] - the measurement, e.g. A for current')
print(' [algo name] - specifiy the disaggregation algorithm to use.')
print(' [device] - usually /dev/ttyACM0 in a RPi.')
print()
exit(1)
print()
print('Parameters:', sys.argv[1:])
(modeldb, precision, measure, algo_name, device) = sys.argv[1:]
precision = float(precision)
disagg_algo = getattr(__import__('algo_' + algo_name, fromlist=['disagg_algo']), 'disagg_algo')
print('Using disaggregation algorithm disagg_algo() from %s.' % ('algo_' + algo_name + '.py'))
datasets_dir = './datasets/%s.csv'
logs_dir = './logs/%s.log'
models_dir = './models/%s.json'
print()
print('Loading saved model %s from JSON storage (%s)...' % (modeldb, models_dir % modeldb))
fp = open(models_dir % modeldb, 'r')
jdata = json.load(fp)
fp.close()
folds = len(jdata)
if folds != 1:
print('ERROR: please use only single fold models.')
exit(1)
print('\tLoading JSON data into SSHMM object...')
sshmm = SuperStateHMM()
sshmm._fromdict(data)
del jdata
labels = sshmm.labels
print('\tModel lables are: ', labels)
print()
print('Testing %s algorithm load disagg...' % algo_name)
acc = Accuracy(len(labels), folds)
print()
print('Connecting to EMU2 on %s...' % (device))
emu2 = serial.Serial(dev, 115200, timeout=1)
y0 = y1 = -1
while True:
msg = emu2.readlines()
ts = int(time.time())
dt = datetime.datetime.fromtimestamp(ts)
if msg == [] or msg[0].decode()[0] != '<':
continue
msg = ''.join([line.decode() for line in msg])
try:
tree = et.fromstring(msg)
except:
continue
if tree.tag == 'InstantaneousDemand':
power = int(tree.find('Demand').text, 16)
power = int(power * precision)
y0 = y1
y1 = power
if y0 == -1:
y0 = y1
start = time()
(p, k, Pt, cdone, ctotal) = disagg_algo(sshmm, [y0, y1])
elapsed = (time() - start)
s_est = sshmm.detangle_k(k)
y_est = sshmm.y_estimate(s_est, breakdown=True)
y_true = hidden[i]
s_true = sshmm.obs_to_bins(y_true)
acc.classification_result(fold, s_est, s_true, sshmm.Km)
acc.measurement_result(fold, y_est, y_true)
unseen = 'no'
if p == 0.0:
unseen = 'yes'
y_noise = round(y1 - sum(y_true), 1)
fscore = acc.fs_fscore()
estacc = acc.estacc()
scp = sum([i != j for (i, j) in list(zip(hidden[i - 1], hidden[i]))])
print('Obs %5d%s Δ %4d%s | SCP %2d | FS-fscore %.4f | Est.Acc. %.4f | Time %7.3fms' % (y1, measure, y1 - y0, measure, scp, fscore, estacc, elapsed * 1000))