-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_ascm_theta_max_exp2_02.py
70 lines (56 loc) · 2.42 KB
/
test_ascm_theta_max_exp2_02.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
import time
import matplotlib.pyplot as plt
import accelerated_sequence_clustering as ascm
import pandas as pd
import numpy as np
import time
import matplotlib.pyplot as plt
import glob
import os
import sys
def __main__(argv):
input_path=os.getcwd()
folder='50k'
files_path = glob.glob(input_path+'/data/'+folder+'/*.csv')
files_path.sort()
THETA=[1.01, 1.05, 1.1, 1.2, 1.5, 2, 5, 10, 20, 50]
MAX=[20]#[5, 10, 20, 50]
k=20
columns=['dataset_name', 'k','theta','max', 'SSE_b', 'SSE_a',
'Total_time_b', 'Total_time_a', 'speed_up', 'Gap']
all_results=pd.DataFrame()
for file_path in files_path:
results=pd.DataFrame(columns=columns)
names= file_path.split('/')
dataset_name=os.path.basename(names[-1])
if dataset_name.endswith('.csv'):
dataset_name = dataset_name[:-4]
data=pd.read_csv(file_path)
a_2d=data.to_numpy()
if len(data>50000):
a_2d=a_2d[:50000]
print(f'ASC method outputs for {dataset_name}....')
for theta in THETA:
print(f'Theta={theta}')
for max in MAX:
start_b = time.time()
_, SSE_b, _, _ = ascm.basic_sequence_clustering_2d(a_2d, k, False)
end_b = time.time()
total_time_b= end_b-start_b
start_a = time.time()
_, SSE_a, _, _ = ascm.accelerated_sequence_clustering_approximated3_2d(a_2d, k, max, theta, False)
end_a = time.time()
total_time_a= end_a-start_a
speed_up=total_time_b/total_time_a
Gap=(SSE_a-SSE_b)/SSE_b*100
asc_current= {'dataset_name':dataset_name, 'k':k,
'theta':theta,'max':max, 'SSE_b':SSE_b, 'SSE_a':SSE_a,
'Total_time_b':total_time_b, 'Total_time_a':total_time_a,
'speed_up':speed_up, 'Gap':Gap}
results= results.append(asc_current, ignore_index=True)
all_results= all_results.append(asc_current, ignore_index=True)
results[columns].to_csv(input_path+f'/outs2/exp2-revise02/{dataset_name}_exp2_max5.csv')
all_results[columns].to_csv(input_path+f'/outs2/exp2-revise02/{folder}_exp2_max5.csv')
print('Finished.')
if __name__ == "__main__":
__main__(sys.argv)