aboutsummaryrefslogtreecommitdiffstats
path: root/benchmarks
diff options
context:
space:
mode:
Diffstat (limited to 'benchmarks')
-rwxr-xr-xbenchmarks/plot.py155
1 files changed, 155 insertions, 0 deletions
diff --git a/benchmarks/plot.py b/benchmarks/plot.py
new file mode 100755
index 0000000..b329ed4
--- /dev/null
+++ b/benchmarks/plot.py
@@ -0,0 +1,155 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+import csv
+import glob
+import itertools
+import math
+import matplotlib.pyplot as plt
+import sys
+
+
+def get_dashes():
+ """Generator for plot line dash patterns."""
+ dash = 2.0
+ space = dot = 0.75
+
+ yield [] # Solid
+ yield [dash, space] # Dashed
+ yield [dot, space] # Dotted
+
+ # Dash-dots, with increasing number of dots for each line
+ for i in itertools.count(2):
+ yield [dash, space] + [dot, space] * (i - 1)
+
+
+def plot(in_file, out_filename, x_label, y_max=None):
+ fig_height = 4.0
+ dashes = get_dashes()
+ markers = itertools.cycle(
+ ['o', 's', 'v', 'D', '*', 'p', 'P', 'h', 'X', '+', 'x'])
+
+ reader = csv.reader(in_file, delimiter='\t')
+ header = next(reader)
+ cols = [x for x in zip(*list(reader))]
+
+ plt.clf()
+ fig = plt.figure(figsize=(fig_height * math.sqrt(2), fig_height))
+ ax = fig.add_subplot(111)
+
+ ax.set_xlabel(x_label)
+
+ ax.set_ylabel(u'Time (μs)')
+ if y_max is not None:
+ ax.set_ylim([0.0, y_max])
+
+ ax.grid(linewidth=0.25, linestyle=':', color='0', dashes=[0.2, 1.6])
+ ax.tick_params(axis='both', width=0.75)
+
+ x = cols[0]
+ for i, y in enumerate(cols[1::]):
+ ax.plot(x,
+ list(map(float, y)),
+ label=header[i + 1],
+ marker=next(markers),
+ dashes=next(dashes),
+ markersize=3.0,
+ linewidth=1.0)
+
+ plt.legend(loc='upper left')
+ plt.savefig(out_filename, bbox_inches='tight', pad_inches=0.025)
+ plt.close()
+ sys.stderr.write('wrote {}\n'.format(out_filename))
+
+
+def plot_section(x_label, plots):
+ # Get maximum value for all Y axes
+ y_max = 0.0
+ for p in plots:
+ name = p[0]
+ filename = name + '.txt'
+
+ with open(filename, 'r') as in_file:
+ reader = csv.reader(in_file, delimiter='\t')
+ next(reader)
+ for row in reader:
+ y_max = max(y_max, *map(float, row[1::]))
+
+ html = ''
+ for p in plots:
+ name = p[0]
+ caption = p[1]
+ filename = name + '.txt'
+ out_filename = filename.replace('.txt', '.svg')
+
+ with open(filename, 'r') as in_file:
+ plot(in_file, filename.replace('.txt', '.svg'), x_label, y_max)
+
+ html += ''.join([' <figure>',
+ '<img src="{}"/>'.format(out_filename),
+ '<figcaption>{}</figcaption>'.format(caption),
+ '</figure>\n'])
+
+ return html
+
+
+if __name__ == '__main__':
+ files = glob.glob('*.txt')
+
+ html = '''<html>
+<head>
+ <title>Hilbert Benchmarks</title>
+ <style type="text/css">
+ figure {
+ display: inline-block;
+ }
+
+ figure img {
+ width: 100%;
+ }
+
+ figcaption {
+ padding-top: 1ex;
+ text-align: center;
+ }
+ </style>
+</head>
+<body>
+ <h1>CHilbert Benchmarks</h1>
+'''
+
+ html += ' <h2>Bit Vector Operations</h2>'
+ html += plot_section(
+ 'Bits',
+ [('bitvec_and', 'Bitwise AND'),
+ ('bitvec_or', 'Bitwise OR'),
+ ('bitvec_xor', 'Bitwise XOR'),
+ ('bitvec_none', 'Zero test'),
+ ('bitvec_set_one', 'Set bit'),
+ ('bitvec_set_all', 'Set all'),
+ ('bitvec_reset_one', 'Reset bit'),
+ ('bitvec_reset_all', 'Reset all'),
+ ('bitvec_flip_one', 'Flip bit'),
+ ('bitvec_flip_all', 'Flip all'),
+ ('bitvec_count', 'Count'),
+ ('bitvec_find_first', 'Find first'),
+ ('bitvec_left_shift', 'Left shift'),
+ ('bitvec_right_shift', 'Right shift'),
+ ('bitvec_left_rotate', 'Left rotate'),
+ ('bitvec_right_rotate', 'Right rotate'),
+ ('bitvec_gray_code', 'Gray code'),
+ ('bitvec_gray_code_inv', 'Gray code inverse'),
+ ('bitvec_comparison', 'Comparison'),
+ ('bitvec_iteration', 'Iteration')])
+
+ html += ' <h2>Hilbert Mapping</h2>\n'
+ html += plot_section(
+ 'Dimensions',
+ [('hilbert_coords_to_index', 'Coordinates to index'),
+ ('hilbert_index_to_coords', 'Index to coordinates')])
+
+ html += '</body>\n</html>\n'
+ with open('benchmarks.html', 'w') as index_file:
+ index_file.write(html)
+
+ sys.stderr.write('wrote benchmarks.html\n')