hyperfine/scripts/plot_histogram.py

51 lines
1.4 KiB
Python
Raw Normal View History

#!/usr/bin/env python
2019-10-14 23:45:52 +03:00
"""This program shows `hyperfine` benchmark results as a histogram."""
import argparse
import json
import numpy as np
2019-10-14 23:45:52 +03:00
import matplotlib.pyplot as plt
parser = argparse.ArgumentParser(description=__doc__)
parser.add_argument("file", help="JSON file with benchmark results")
parser.add_argument("--title", help="Plot title")
parser.add_argument(
"--labels", help="Comma-separated list of entries for the plot legend"
)
parser.add_argument("--bins", help="Number of bins (default: auto)")
parser.add_argument(
"--type", help="Type of histogram (*bar*, barstacked, step, stepfilled)"
)
parser.add_argument("--imgname", help="Save image to the given filename.")
2019-10-14 23:45:52 +03:00
args = parser.parse_args()
with open(args.file) as f:
results = json.load(f)["results"]
if args.labels:
labels = args.labels.split(",")
else:
labels = [b["command"] for b in results]
2019-10-14 23:45:52 +03:00
all_times = [b["times"] for b in results]
2020-04-02 19:32:42 +03:00
t_min = np.min(list(map(np.min, all_times)))
t_max = np.max(list(map(np.max, all_times)))
bins = int(args.bins) if args.bins else "auto"
histtype = args.type if args.type else "bar"
2020-04-01 10:35:06 +03:00
plt.hist(
all_times, label=labels, bins=bins, histtype=histtype, range=(t_min, t_max),
2020-04-01 10:35:06 +03:00
)
plt.legend(prop={"family": ["Source Code Pro", "Fira Mono", "Courier New"]})
2019-10-14 23:45:52 +03:00
plt.xlabel("Time [s]")
if args.title:
plt.title(args.title)
if args.imgname:
plt.savefig(args.imgname)
else:
plt.show()