blob: e3164bc989ee7aaefbbd12faf773cd6d8b3f4bdd [file] [log] [blame]
Mike Frysingerc7f15932013-03-20 13:43:35 -04001#!/usr/bin/python
bjanakiramana082e562013-02-15 09:09:57 +00002#
3# Copyright 2010 Google Inc. All Rights Reserved.
4
5"""Script to compare ChromeOS benchmarks
6
7Inputs:
8 <perflab-output directory 1 - baseline>
9 <perflab-output directory 2 - results>
10 --csv - comma separated results
11
12This script doesn't really know much about benchmarks. It simply looks for
13similarly names directories and a results.txt file, and compares
14the results and presents it, along with a geometric mean.
15
16"""
17
18__author__ = "bjanakiraman@google.com (Bhaskar Janakiraman)"
19
kbaclawski20082a02013-02-16 02:12:57 +000020import glob
21import math
bjanakiramana082e562013-02-15 09:09:57 +000022import optparse
23import os
24import re
25import sys
kbaclawski20082a02013-02-16 02:12:57 +000026
bjanakiramana082e562013-02-15 09:09:57 +000027import image_chromeos
kbaclawski20082a02013-02-16 02:12:57 +000028import run_tests
bjanakiramana082e562013-02-15 09:09:57 +000029from utils import command_executer
bjanakiramana082e562013-02-15 09:09:57 +000030from utils import logger
31
32BENCHDIRS = "%s/default/default/*/gcc-4.4.3-glibc-2.11.1-grte-k8-opt/ref/*/results.txt"
33
34
35# Common initializations
36cmd_executer = command_executer.GetCommandExecuter()
37
38
39def Usage(parser, message):
40 print "ERROR: " + message
41 parser.print_help()
42 sys.exit(0)
43
44
45def GetStats(file):
46 """Return stats from file"""
47 f = open(file, 'r')
48 pairs = []
49 for l in f:
50 line = l.strip()
51 # Look for match lines like the following:
52 # METRIC isolated TotalTime_ms (down, scalar) trial_run_0: ['1524.4']
53 # METRIC isolated isolated_walltime (down, scalar) trial_run_0: ['167.407445192']
54 m = re.match(r"METRIC\s+isolated\s+(\S+).*\['(\d+(?:\.\d+)?)'\]", line)
55 if not m:
56 continue
57 metric = m.group(1)
58 if re.match(r"isolated_walltime", metric):
59 continue
60
61 value = float(m.group(2))
62 pairs.append((metric, value))
63
64 return dict(pairs)
65
66def PrintDash(n):
67 tmpstr = ''
68 for i in range(n):
69 tmpstr += '-'
70 print tmpstr
71
72
73def PrintHeaderCSV(hdr):
74 tmpstr = ''
75 for i in range(len(hdr)):
76 if tmpstr != '':
77 tmpstr += ','
78 tmpstr += hdr[i]
79 print tmpstr
80
81
82def PrintHeader(hdr):
83 tot_len = len(hdr)
84 PrintDash(tot_len * 15)
85
86 tmpstr = ''
87 for i in range(len(hdr)):
88 tmpstr += "%15.15s" % hdr[i]
89
90 print tmpstr
91 PrintDash(tot_len * 15)
92
93def Main(argv):
94 """Compare Benchmarks."""
95 # Common initializations
96
97 parser = optparse.OptionParser()
98 parser.add_option("-c", "--csv", dest="csv_output",
99 action="store_true", default=False,
100 help="Output in csv form.")
101
102 (options, args) = parser.parse_args(argv[1:])
103
104 # validate args
105 if len(args) != 2:
106 Usage(parser, "Needs <baseline output dir> <results output dir>")
107
108 base_dir = args[0]
109 res_dir = args[1]
110
111 # find res benchmarks that have results
112 resbenches_glob = BENCHDIRS % res_dir
113 resbenches = glob.glob(resbenches_glob)
114
115 basebenches_glob = BENCHDIRS % base_dir
116 basebenches = glob.glob(basebenches_glob)
117
118 to_compare = []
119 for resbench in resbenches:
120 tmp = resbench.replace(res_dir, base_dir, 1)
121 if tmp in basebenches:
122 to_compare.append((resbench, tmp))
123
124 for (resfile, basefile) in to_compare:
125 stats = GetStats(resfile)
126 basestats = GetStats(basefile)
127 # Print a header
128 # benchname (remove results.txt), basetime, restime, %speed-up
129 hdr = []
130 benchname = re.split('/', resfile)[-2:-1][0]
131 benchname = benchname.replace('chromeos__', '',1)
132 hdr.append(benchname)
133 hdr.append('basetime')
134 hdr.append('restime')
135 hdr.append('%speed up')
136 if options.csv_output:
137 PrintHeaderCSV(hdr)
138 else:
139 PrintHeader(hdr)
140
141 # For geomean computations
142 prod = 1.0
143 count = 0
144 for key in stats.keys():
145 if key in basestats.keys():
146 # ignore very small values.
147 if stats[key] < 0.01:
148 continue
149 count = count + 1
150 prod = prod * (stats[key]/basestats[key])
151 speedup = (basestats[key] - stats[key])/basestats[key]
152 speedup = speedup * 100.0
153 if options.csv_output:
154 print "%s,%f,%f,%f" % (key, basestats[key], stats[key],speedup)
155 else:
156 print "%15.15s%15.2f%15.2f%14.2f%%" % (key, basestats[key], stats[key],speedup)
157
158 prod = math.exp(1.0/count * math.log(prod))
159 prod = (1.0 - prod) * 100
160 if options.csv_output:
161 print "%s,,,%f" % ('Geomean', prod)
162 else:
163 print "%15.15s%15.15s%15.15s%14.2f%%" % ('Geomean', '', '', prod)
164 print
asharif2198c512013-02-15 09:21:35 +0000165 return 0
bjanakiramana082e562013-02-15 09:09:57 +0000166
167
168if __name__ == "__main__":
asharif2198c512013-02-15 09:21:35 +0000169 retval = Main(sys.argv)
170 sys.exit(retval)