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 " "
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()
|