summaryrefslogtreecommitdiff
path: root/tools/parsebench.py
blob: 671e482fb26480a8484bd853ab7b561c58e70ca3 (plain)
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
#!/usr/bin/env python

# Copyright (c) 2015, NORDUnet A/S.
# See LICENSE for licensing information.

import argparse
import sys
import ast
import itertools

def parse_one_line(line):
    row = line.rstrip().split(":")
    assert row[0].startswith("bench-")
    iteration = int(row[0][6:])
    stage = row[2].strip()
    data = ast.literal_eval(row[3].strip())
    return (iteration, stage, data)

def main():
    parser = argparse.ArgumentParser(description="")
    parser.add_argument('inputfile', help="Input file", nargs='*')
    args = parser.parse_args()
    print "<!DOCTYPE html>"
    print "<html>"
    print "<head>"
    print "</head>"
    print "<body>"
    for filename in args.inputfile:
        parse_one_file(filename)
    print "</body>"
    print "</html>"

scale = 0.25

def parse_one_file(filename):
    lines = [parse_one_line(line) for line in open(filename)]
    iterations = itertools.groupby(lines, lambda x: x[0])
    print "<h1>%s</h1>" % (filename,)
    print "<div>"
    legend = []
    firsttime = True
    for (i, iteration) in iterations:
        print >>sys.stderr,  (i, iteration)
        print "<table style='border-collapse: collapse;'><tr>"
        for (stagen, (_, stage, data)) in enumerate(iteration):
            if firsttime:
                legend.append("<div><span>%s</span>" % (stage,))
            data = list(data)
            for (itemn, (item, useconds)) in enumerate(data):
                seconds = useconds / 1000000
                step = 50 / (len(data) - 1)
                print "<td style='width: %dpx; padding: 0; background-color: hsl(%d, 90%%, %d%%);' title='%s:%s %d'>" % (int(seconds*scale), stagen * 90, itemn * step + 40, stage, item, seconds)
                if firsttime:
                    legend.append("<span style='background-color: hsl(%d, 90%%, %d%%);'>%s</span>" % (stagen * 90, itemn * step + 40, item))
                print "&nbsp;"
                print "</td>"
            if firsttime:
                legend.append("</div>")
        print "</tr></table>"
        firsttime = False
    print "</div>"
    print "<div style='height: 30px;'>"
    print "</div>"
    print "<div>"
    for row in legend:
        print row
    print "</div>"

main()