-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathevaluationi_merge.py
57 lines (45 loc) · 1.62 KB
/
evaluationi_merge.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
import pandas as pd
import statistics
from statistics import mode
folder = './1d_split_filtered/1d_split'
output = 'E:/논문데이터/simulation/' + folder + '/eval_result.csv'
eOut = open(output, 'w')
for num in range(2, 101):
for s in range(1, 11):
fName = 'E:/논문데이터/simulation/' + folder + '/merging_' + str(s) + '_em' + str(num) + '.csv'
oName = 'E:/논문데이터/simulation/' + folder + '/out/merging_' + str(s) + '_em' + str(num) + '_out.csv'
file = open(fName, 'r')
out = open(oName, 'w')
title = file.readline()
tp = 0
tn = 0
fp = 0
fn = 0
print('E:/논문데이터/simulation/' + folder + '/merging_' + str(s) + '_em' + str(num) + '.csv')
for line in file:
tmp = line.strip().split(',')
pos = int(tmp[0])
voters = tmp[1:]
voters = list(map(int, voters))
voting = 0
#voting = min(voters)
try:
voting = int(mode(voters))
except statistics.StatisticsError:
voting = 3
if( pos < 41000):
if(voting == 1):
tp += 1
else:
fn += 1
else:
if(voting == 1):
fp += 1
else:
tn += 1
res = str(pos) + ',' + str(voting) + '\n'
out.write(res)
# tp tn fp fn
eOut.write('split,' + str(s) + ',cluster,' + str(num) + ',' + str(tp) + ',' + str(fn) + ',' + str(fp) + ',' + str(tn) + '\n')
out.close()
eOut.close()