-
Notifications
You must be signed in to change notification settings - Fork 173
/
exps.py
70 lines (59 loc) · 1.55 KB
/
exps.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
#!/bin/python
import os
import time
import sys
# running experiments
RATES=[8]
THREADS=[32]
EXPS=[(32,8), (16,8), (16,16)]
ENV='env.sh'
NNODES=[4,8,12]
def change_config(run_no):
f = open(ENV,'r')
envs = f.readlines()
f.close()
f = open(ENV,'w')
for l in envs:
if l.startswith('LOG_DIR'):
f.write(l[:l.find('results')]+'results_'+str(run_no)+'\n')
else:
f.write(l)
f.close()
def run_exp(n, is_security=False):
cmd='./run-bench.sh {} {} {} {}'
if is_security:
cmd='./run-bench-security {} {} {} {}'
#for t in THREADS:
# for r in RATES:
for (t,r) in EXPS:
# run the experiments
print cmd.format(n,t,n,r)
os.system(cmd.format(n,t,n,r))
# python exps.py [-security/-donothing]
if __name__=='__main__':
error_msg = 'python exps.py [-security/-donothing] \n'\
+ ' no argument: run saturation benchmark \n'\
+ ' -security: security benchmark \n'\
+ ' -donothing: donothing benchmark\n'
opts = ['-security', '-donothing']
if len(sys.argv)>2:
print error_msg
if len(sys.argv)==2 and (not sys.argv in opts):
print error_msg
cp_cmd='cp env_ycsb.sh env.sh'
os.system(cp_cmd)
change_config(1)
for n in NNODES:
if len(sys.argv)>1 and sys.argv[1]=='-security':
run_exp(n,True)
else:
run_exp(n, False)
# do-nothing option
if len(sys.argv)>1 and sys.argv[1]=='-donothing':
time.sleep(10)
cp_cmd = 'cp env_donothing.sh env.sh'
os.system(cp_cmd)
change_config(1)
for n in NNODES:
run_exp(n, False)
print 'Done!'