forked from Junior-House/authio
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstart.py
59 lines (51 loc) · 1.78 KB
/
start.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
from data.data import buildData
from model.model import runModel
import numpy as np
import time
from contextlib import contextmanager
import sys, os
@contextmanager
def suppress_stdout():
with open(os.devnull, "w") as devnull:
old_stdout = sys.stdout
old_stderr = sys.stderr
sys.stdout = devnull
sys.stderr = devnull
try: yield
finally:
sys.stdout = old_stdout
sys.stderr = old_stderr
if __name__ == "__main__":
verbose = False
# take start time
start = int(round(time.time() * 1000))
# test each user as valid
results = []
for user in range(51):
print('Testing for user: {}'.format(user))
with suppress_stdout():
buildData(user)
result = list(runModel())
results.append(result)
# print interim results
if verbose:
print("Accuracy: {}".format(result[0]))
print("Recall: {}".format(result[1]))
print("Precision: {}".format(result[2]))
print("F1: {}".format(result[3]))
# calculate final results
results = np.array(results, dtype=np.float64)
means = np.mean(results, axis=0)
stds = np.std(results, axis=0)
# print final results
print('\nFinal accuracy mean: {}'.format(means[0]))
print('Final accuracy std: {}'.format(stds[0]))
print('\nFinal recall mean: {}'.format(means[1]))
print('Final recall std: {}'.format(stds[1]))
print('\nFinal precision mean: {}'.format(means[2]))
print('Final precision std: {}'.format(stds[2]))
print('\nFinal F1 mean: {}'.format(means[3]))
print('Final F1 std: {}'.format(stds[3]))
# calculate total time
end = int(round(time.time() * 1000))
print('\nTotal time expended: {}'.format(end - start))