aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools/profiling/microbenchmarks
diff options
context:
space:
mode:
authorGravatar Craig Tiller <ctiller@google.com>2017-03-08 13:45:53 -0800
committerGravatar Craig Tiller <ctiller@google.com>2017-03-08 13:45:53 -0800
commit47c56a677ee2abe3089fe53a7f81cd0e772491d7 (patch)
treed59ad7732d3b6f0bdceb97c03ef8a02545e214a0 /tools/profiling/microbenchmarks
parent5adc93e0ba993b3f43d7982aa738e98f1f777abb (diff)
A better benchmark diff script
Diffstat (limited to 'tools/profiling/microbenchmarks')
-rwxr-xr-xtools/profiling/microbenchmarks/bm_diff.py40
1 files changed, 31 insertions, 9 deletions
diff --git a/tools/profiling/microbenchmarks/bm_diff.py b/tools/profiling/microbenchmarks/bm_diff.py
index c9e721369a..5e1f68bc37 100755
--- a/tools/profiling/microbenchmarks/bm_diff.py
+++ b/tools/profiling/microbenchmarks/bm_diff.py
@@ -3,6 +3,7 @@
import sys
import json
import bm_json
+import tabulate
with open(sys.argv[1]) as f:
js_new_ctr = json.loads(f.read())
@@ -21,8 +22,11 @@ for row in bm_json.expand_json(js_new_ctr, js_new_opt):
for row in bm_json.expand_json(js_old_ctr, js_old_opt):
old[row['cpp_name']] = row
+def changed_ratio(n, o):
+ return float(n-o)/float(o)
+
def min_change(pct):
- return lambda n, o: abs((n-o)/o - 1) > pct/100
+ return lambda n, o: abs(changed_ratio(n,o)) > pct/100.0
_INTERESTING = (
('cpu_time', min_change(10)),
@@ -34,18 +38,36 @@ _INTERESTING = (
('atm_add_per_iteration', min_change(5)),
)
+changed = []
+for fld, chk in _INTERESTING:
+ for bm in new.keys():
+ if bm not in old: continue
+ n = new[bm]
+ o = old[bm]
+ if fld not in n or fld not in o: continue
+ if chk(n[fld], o[fld]):
+ changed.append((fld, chk))
+ break
+
+headers = ['Benchmark'] + [c[0] for c in changed] + ['Details']
+rows = []
for bm in sorted(new.keys()):
if bm not in old: continue
- hdr = False
+ row = [bm]
+ any_changed = False
n = new[bm]
o = old[bm]
- print n
- print o
+ details = ''
for fld, chk in _INTERESTING:
if fld not in n or fld not in o: continue
if chk(n[fld], o[fld]):
- if not hdr:
- print '%s shows changes:' % bm
- hdr = True
- print ' %s changed %r --> %r' % (fld, o[fld], n[fld])
- sys.exit(0)
+ row.append(changed_ratio(n[fld], o[fld]))
+ if details: details += ', '
+ details += '%s:%r-->%r' % (fld, o[fld], n[fld])
+ any_changed = True
+ else:
+ row.append('')
+ if any_changed:
+ row.append(details)
+ rows.append(row)
+print tabulate.tabulate(rows, headers=headers, floatfmt='+.2f')