#!/bin/sh
#
# CDDL HEADER START
#
# The contents of this file are subject to the terms
# of the Common Development and Distribution License
# (the "License"). You may not use this file except
# in compliance with the License.
#
# You can obtain a copy of the license at
# src/OPENSOLARIS.LICENSE
# or http://www.opensolaris.org/os/licensing.
# See the License for the specific language governing
# permissions and limitations under the License.
#
# When distributing Covered Code, include this CDDL
# HEADER in each file and include the License file at
# usr/src/OPENSOLARIS.LICENSE. If applicable,
# add the following below this CDDL HEADER, with the
# fields enclosed by brackets "[]" replaced with your
# own identifying information: Portions Copyright [yyyy]
# [name of copyright owner]
#
# CDDL HEADER END
#
#
# Copyright 2005 Sun Microsystems, Inc. All rights reserved.
# Use is subject to license terms.
#
#
# output html comparison of several libmicro output data files
# usage: multiview file1 file2 file3 file4 ...
#
# relative ranking is calculated using first as reference
# color interpolation is done to indicate relative performance;
# the redder the color, the slower the result, the greener the
# faster
/bin/nawk ' BEGIN {
benchmark_count = 0;
header_count = 0;
}
/^#/ {
continue;
}
/errors/ {
continue;
}
/^\!/ {
split($0, A_header, ":");
name = substr(A_header[1],2);
headers[name]=name;
header_data[name,FILENAME] = substr($0, length(name) + 3);
if (header_names[name] == 0) {
header_names[name] = ++header_count;
headers[header_count] = name;
}
continue;
}
{
if(NF >= 7) {
if (benchmark_names[$1] == 0) {
benchmark_names[$1] = ++benchmark_count;
benchmarks[benchmark_count] = $1;
}
if ($6 == 0)
benchmark_data[$1,FILENAME] = $4;
else
benchmark_data[$1,FILENAME] = -1;
}
}
END {
printf("<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\"\n");
printf("\"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n");
printf("<html xmlns=\"http://www.w3.org/1999/xhtml\">\n");
printf("<head>\n");
printf("<meta http-equiv=\"content-type\" content=\"text/html; charset=ISO-8859-1\" />\n");
printf("<meta name=\"author\" content=\"autogen\" />\n");
printf("<title>multiview comparison</title>\n")
printf("<style type=\"text/css\">\n");
printf("body { font-family: sans-serif; }\n");
printf("table { border-collapse: collapse; }\n");
printf("td { padding: 0.1em; border: 1px solid #ccc; text-align: right; }\n");
printf("td.header { text-align: left; }\n");
printf("pre { margin-top: 0em; margin-bottom: 0em; }\n");
printf("</style>\n");
printf("</head>\n");
printf("<body bgcolor=\"#ffffff\" link=\"#0000ee\" vlink=\"#cc0000\" alink=\"#0000ee\">\n");
printf("<table border=\"1\" cellspacing=\"1\">\n");
printf("<tbody>\n");
for(i = 1; i <= header_count; i++) {
hname = headers[i];
printf("<tr><td class=\"header\">%s</td>\n", hname);
for (j = 1; j < ARGC; j++) {
sub("^[\t ]+", "", header_data[hname, ARGV[j]]);
printf("<td class=\"header\">%s</td>\n", header_data[hname, ARGV[j]]);
}
printf("</tr>\n");
}
printf("<tr>\n");
printf("<th>BENCHMARK</th>\n");
printf("<th align=\"right\">USECS</th>\n");
for (i = 2; i < ARGC; i++)
printf("<th align=\"right\">USECS [percentage]</th>\n");
printf("</tr>\n");
for(i = 1; i < benchmark_count; i++) {
for(j = 1; j < benchmark_count; j++) {
if (benchmarks[j] > benchmarks[j + 1]) {
tmp = benchmarks[j];
benchmarks[j] = benchmarks[j+1];
benchmarks[j+1] = tmp;
}
}
}
for(i = 1; i <= benchmark_count; i++) {
name = benchmarks[i];
a = benchmark_data[name, ARGV[1]];
printf("<tr>\n");
printf("<td>%s</td>\n", name);
if (a > 0)
printf("<td><pre>%f</pre></td>\n", a);
else {
if (a < 0)
printf("<td bgcolor=\"#ff0000\">%s</td>\n", "ERRORS");
else
printf("<td>%s</td>\n", "missing");
for (j = 2; j < ARGC; j++)
printf("<td>%s</td>\n", "not computed");
continue;
}
for (j = 2; j < ARGC; j++) {
b = benchmark_data[name, ARGV[j]];
if (b > 0) {
factor = b/a;
bgcolor = colormap(factor);
if (factor > 1)
percentage = -(factor * 100 - 100);
if (factor <= 1)
percentage = 100/factor - 100;
printf("<td bgcolor=\"%s\"><pre>%11.5f[%#+7.1f%%]</pre></td>\n",
bgcolor, b, percentage);
}
else if (b < 0)
printf("<td bgcolor=\"#ff0000\">%s</td>\n", "ERRORS");
else
printf("<td>%25s</td>\n", "missing");
}
printf("</tr>\n");
}
printf("</tbody></table></body></html>\n");
}
function colormap(value, bgcolor, r, g, b)
{
if (value <= .2)
value = .2;
if (value > 5)
value = 5;
if (value < .9) {
r = colorcalc(.2, value, .9, 0, 255);
g = colorcalc(.2, value, .9, 153, 255);
b = colorcalc(.2, value, .9, 0, 255);
bgcolor=sprintf("#%2.2x%2.2x%2.2x", r, g, b);
}
else if (value < 1.1)
bgcolor="#ffffff";
else {
r = 255;
g = colorcalc(1.1, value, 5, 255, 0);
b = colorcalc(1.1, value, 5, 255, 0);
bgcolor=sprintf("#%2.2x%2.2x%2.2x", r, g, b);
}
return (bgcolor);
}
function colorcalc(min, value, max, mincolor, maxcolor)
{
return((value - min)/(max-min) * (maxcolor-mincolor) + mincolor);
}
' "$@"