-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_bench.py
108 lines (93 loc) · 3.88 KB
/
run_bench.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
"""
=========
run bench hots
=========
Run the bench of hots with one dataset, specifying the parameters k and tau you want.
"""
import subprocess
import click
# TODO add 'help' message
datasets = [
'profiles_stab_5n_50i',
'profiles_stab_10n_217i',
'profiles_add_5n_68i',
'profiles_add_10n_477i',
'profiles_change_5n_71i',
'profiles_change_10n_197i',
'profiles_del_5n_57i',
'profiles_del_10n_261i'
]
# methods = ['init', 'spread', 'iter-consol', 'heur', 'loop']
# methods = ['iter-consol', 'heur', 'loop']
# methods = ['init', 'spread']
methods = ['loop']
cluster_methods = ['loop-cluster',
'kmeans-scratch',
'stream-km']
# cluster_methods = ['loop-cluster']
# command = python run_bench.py --path ../data/v17/v1_50n --kmin 2 --kmax 3 --taumin 5 --taumax 25
@click.command()
@click.option('--path', required=True, type=click.Path(exists=True))
@click.option('--kmin', required=False, type=int)
@click.option('--kmax', required=False, type=int)
@click.option('--taumin', required=False, type=int)
@click.option('--taumax', required=False, type=int)
@click.option('--kstep', required=False, type=int)
@click.option('--taustep', required=False, type=int)
def main(path, kmin, kmax, taumin, taumax, kstep, taustep):
"""Perform the bench."""
kstep = kstep or 1
taustep = taustep or 5
output_path = '../bench/global_eval/%s/' % path.split('/')[3]
# output_path = '../bench/global_eval/real/Alter_way_7d/'
# output_path = '../bench/global_eval/AlibabaV1_50n/'
# tol_clust_min = 4
# tol_clust_max = 4
# tol_place_min = 4
# tol_place_max = 4
for k in range(kmin, kmax + 1, kstep):
for tau in range(taumin, taumax + 1, taustep):
for method in methods:
if method == 'loop':
for cluster_method in cluster_methods:
temp_output = '%sk%d_tau%d_%s_%s' % (
output_path, k, tau, method, cluster_method
)
bash_command = 'hots %s -k %d -t %d -m %s -c %s -o %s' % (
path, k, tau, method, cluster_method, temp_output
)
print('\n%s\n' % bash_command)
process = subprocess.Popen(bash_command.split())
output, error = process.communicate()
else:
temp_output = '%sk%d_tau%d_%s' % (
output_path, k, tau, method
)
bash_command = 'hots %s -k %d -t %d -m %s -o %s' % (
path, k, tau, method, temp_output
)
print('\n%s\n' % bash_command)
process = subprocess.Popen(bash_command.split())
output, error = process.communicate()
# bash_command =
# 'hots ' + path + ' -k ' + str(k) + ' -t ' + str(tau) + ' -m loop_v2'
# print('\n%s\n' % bash_command)
# process = subprocess.Popen(bash_command.split())
# output, error = process.communicate()
# bash_command =
# 'hots ' + path + ' -k ' + str(k) + ' -t ' + str(tau) + ' -m loop_kmeans'
# print('\n%s\n' % bash_command)
# process = subprocess.Popen(bash_command.split())
# output, error = process.communicate()
# for tol_c in range(tol_clust_min, tol_clust_max):
# epsilon_c = tol_c / 10
# for tol_a in range(tol_place_min, tol_place_max):
# epsilon_a = tol_a / 10
# temp_output = output_path + str(tol_c) + '_' + str(tol_a) + '/'
# bash_command = 'hots ' + path + ' -o ' + temp_output + \
# ' -ec ' + str(epsilon_c) + ' -ea ' + str(epsilon_a)
# print('\n%s\n' % bash_command)
# process = subprocess.Popen(bash_command.split())
# output, error = process.communicate()
if __name__ == '__main__':
main()