#!/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>" firsttime = True stageorderdict = {} stageorder = [] stages = {} itemorder = {} for (i, iteration) in iterations: for (_, stage, data) in iteration: if stage not in stages: stageorderdict[stage] = len(stageorderdict) stageorder.append(stage) stages[stage] = {} itemorder[stage] = [] for (item, useconds) in data: if item not in stages[stage]: itemorder[stage].append(item) stages[stage][item] = len(stages[stage]) iterations = itertools.groupby(lines, lambda x: x[0]) for (i, iteration) in iterations: print >>sys.stderr, (i, iteration) print "<table style='border-collapse: collapse;'><tr>" for (_, stage, data) in iteration: data = list(data) for (itemn, (item, useconds)) in enumerate(data): seconds = useconds / 1000000 shades = stages[stage] step = 50 / (len(shades) - 1) shade = shades[item] stagen = stageorderdict[stage] print "<td style='width: %dpx; padding: 0; background-color: hsl(%d, 90%%, %d%%);' title='%s:%s %d'>" % (int(seconds*scale), stagen * 90, shade * step + 40, stage, item, seconds) print " " print "</td>" print "</tr></table>" print "</div>" print "<div style='height: 30px;'>" print "</div>" print "<div>" for stage in stageorder: print "<div><span>%s</span>" % (stage,) shades = stages[stage] for item in itemorder[stage]: shade = shades[item] step = 50 / (len(shades) - 1) stagen = stageorderdict[stage] print "<span style='background-color: hsl(%d, 90%%, %d%%);'>%s</span>" % (stagen * 90, shade * step + 40, item) print "</div>" print "</div>" main()