-
-
Notifications
You must be signed in to change notification settings - Fork 65
/
Copy pathbenchmark.py
60 lines (46 loc) · 2.01 KB
/
benchmark.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
#!/usr/bin/env python
import sys
import time
import os
def timeit(cmd):
t = time.time()
os.system(cmd)
return time.time() - t
# test name, input command, test command
tests = [
['a few stdout', 'seq 1 10', 'echo job:{}; seq 1 10'],
['lots of stdout', 'seq 1 10', 'echo job:{}; seq 1 1000000'],
['a few stdout & run long', 'seq 1 10', 'echo job:{}; sleep 2; seq 1 10'],
['lots of stdout & run long', 'seq 1 10', 'echo job:{}; sleep 2; seq 1 1000000'],
]
apps = {'parallel': {'jobs': '-j', 'keep-order': '-k'}, # parallel: GNU parallel (Perl)
# parallel: https://github.com/mmstick/parallel (Rust)
'rust-parallel': {'jobs': '-j', 'keep-order': ''},
'gargs': {'jobs': '-p', 'keep-order': '-o'}, # gargs: https://github.com/brentp/gargs (Go)
'rush': {'jobs': '-j', 'keep-order': '-k'}} # rush: https://github.com/shenwei356/rush (Go)
njobs = 4
for test in tests:
n = int((75 - len(test[0])) / 2)
sys.stderr.write('{}[ {} ]{}\n'.format('=' * n, test[0], '=' * n))
for keep_order in [False, True]:
msg = 'keep order: {}'.format(keep_order)
n = int((70 - len(msg)) / 2)
sys.stderr.write('{}[ {} ]{}\n'.format('-' * n, msg, '-' * n))
sys.stderr.write('\ncommands:\n')
times = dict()
for app, args in apps.items():
cmd = '{} | {} {} {} {} "{}" > t.{}'.format(
test[1], app, args['jobs'], njobs,
args['keep-order'] if keep_order else '',
test[2], os.path.basename(app))
sys.stderr.write('{}\n'.format(cmd))
times[app] = timeit(cmd)
sys.stderr.write('\ntime:\n')
for app in sorted(times.keys()):
sys.stderr.write('{}: {}\n'.format(app, times[app]))
sys.stderr.write('\nmd5sum:\n')
for app in sorted(times.keys()):
os.system('md5sum t.{}'.format(os.path.basename(app)))
os.remove('t.{}'.format(os.path.basename(app)))
sys.stderr.write('\n')
sys.stderr.write('\n')