-
Notifications
You must be signed in to change notification settings - Fork 2
/
report_geomean_auc.py
132 lines (116 loc) · 4.13 KB
/
report_geomean_auc.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
122
123
124
125
126
127
128
129
130
131
132
# written by Elias Vansteenkiste, May 22, 2016
import sys
import subprocess
import os
from random import randint
import operator
import argparse
parser = argparse.ArgumentParser(description='Process log file.')
parser.add_argument('--filename', dest='filename', action='store',
default="test.log",
help='read and process the log from the filename given (default: test.log)')
parser.add_argument('--detail', dest='details', action='store_true',
default=False,
help='give more details such as csv filenames (default: False)')
parser.add_argument('--show-cm', dest='show_cm', action='store_true',
default=False,
help='print the confusion matrix (default: False)')
parser.add_argument('--show-csv', dest='show_csv', action='store_true',
default=False,
help='print the name of the csv files for the prediction of the test set. (default: False)')
parser.add_argument('--show-fprdtpr', dest='show_fprdtpr', action='store_true',
default=False,
help='print the fpr/tpr of the results. (default: False)')
args = parser.parse_args()
def geometric_mean(iterable):
return (reduce(operator.mul, iterable)) ** (1.0/len(iterable))
def median(lst):
quotient, remainder = divmod(len(lst), 2)
if remainder:
return sorted(lst)[quotient]
return sum(sorted(lst)[quotient - 1:quotient + 1]) / 2.
rpt = open(args.filename,'r')
lines = rpt.readlines()
config_start_pattern = "Configuration "
config_end_pattern = "end Configuration"
inside_config = False
config_printed = False
for line in lines:
if not config_printed and config_start_pattern in line:
inside_config = True
print "Configuration:"
elif not config_printed and config_end_pattern in line:
inside_config = False
config_printed = True
elif not config_printed and inside_config:
print line,
found_parameters = False
no_parameters_pattern = "# Neural Network with "
for line in lines:
if not found_parameters and no_parameters_pattern in line:
words = line.split()
print "No. learnable parameters:", words[4]
found_parameters = True
patterns = ["Error rate (%):"]
csv = ['.csv']
auc_patterns = ['geomean_roc_auc', 'geomean_roc_auc_hours']
tpr2dfpr = []
tprdfpr = []
aucs = []
haucs = []
pattern_found = 0
tp = -1
fn = -1
fp = -1
tpr = -1
fpr = -1
print 'tpr/(fpr+1e-6)\ttp \ttp*tpr/(fpr+1e-6)'
for line in lines:
if args.show_fprdtpr:
if pattern_found == 1:
if args.show_cm:
print line,
mu_line = filter(lambda ch: ch not in "[]", line)
negatives = mu_line.split()
tn = int(negatives[0])
fp = int(negatives[1])
fpr = 1.0*fp/(tn+fp)
pattern_found = 2
elif pattern_found == 2:
if args.show_cm:
print line,
mu_line = filter(lambda ch: ch not in "[]", line)
positives = mu_line.split()
fn = int(positives[0])
tp = int(positives[1])
tpr = 1.0*tp/(fn+tp)
print tpr/(fpr+1e-6), '\t', tp, '\t', tp*tpr/(fpr+1e-6)
tpr2dfpr.append(tp*tpr/(fpr+1e-6))
tprdfpr.append(tpr/(fpr+1e-6))
pattern_found = 0
tp = -1
fn = -1
fp = -1
tpr = -1
fpr = -1
else:
for p in patterns:
if p in line:
pattern_found = 1
break
if args.show_csv:
for p in csv:
if p in line and 'Namespace' not in line:
print line,
break
if 'geomean_roc_auc:' in line:
aucs.append(float(line.split(':')[1].rsplit()[0]))
print line,
if 'geomean_roc_auc_hours:' in line:
haucs.append(float(line.split(':')[1].rsplit()[0]))
print line,
print 'geomean auc:', geometric_mean(aucs)
print 'geomean hour auc:', geometric_mean(haucs)
if args.show_fprdtpr:
print 'median tpr/fpr', median(tprdfpr)
print 'geomean tpr^2/fpr', geometric_mean(tpr2dfpr)