Skip to content

Latest commit

 

History

History
204 lines (172 loc) · 7.09 KB

README.md

File metadata and controls

204 lines (172 loc) · 7.09 KB

quickbench 1.0

Quick & easy benchmarking of command-line programs.

About | Install | Examples | Options | Related tools

About

quickbench is an update and repackaging of a little benchmarking tool I've been using in the hledger project since 2008. Use it like a more powerful "time" command for measuring the time taken by command-line programs, or for creating repeatable benchmark scripts for your projects.

quickbench produces very simple output (elapsed seconds), as quickly as possible (running commands just once by default), and tabulates results from multiple executables. I find it very useful for quick and dirty, exploratory, and comparative measurements that you can understand at a glance.

Install

You can build it from source on most platforms supporting GHC. A patch is required for one of the dependencies, so for now you must build quickbench from inside its source tree, with stack (or if you build with cabal, ensure it uses the docopt version mentioned in stack.yaml):

$ git clone https://github.com/simonmichael/quickbench
$ cd quickbench
$ stack install

stack will advise you to add ~/.local/bin to $PATH if needed.

Examples

You can specify test commands as arguments:

$ quickbench 'sleep 1'
Running 1 tests 1 times at 2016-10-16 23:06:48.058578 UTC:

Best times:
+---------++------+
|         ||      |
+=========++======+
| sleep 1 || 1.01 |
+---------++------+

or put them in a file and use -f FILE. A file named bench.sh in the current directory will be used automatically:

$ echo 'echo 3 * 1000000' > bench.sh
$ quickbench
Running 1 tests 1 times at 2016-10-16 23:53:04.743899 UTC:

Best times:
+------------------++------+
|                  ||      |
+==================++======+
| echo 3 * 1000000 || 0.00 |
+------------------++------+

You can compare results with different executables:

$ quickbench -w echo,expr -p5
Running 1 tests 1 times with 2 executables at 2016-10-16 23:56:40.808703 UTC:

Best times:
+-------------++---------+---------+
|             ||    echo |    expr |
+=============++=========+=========+
| 3 * 1000000 || 0.00229 | 0.00195 |
+-------------++---------+---------+

and run tests repeatedly to reduce or observe jitter. quickbench assumes the quickest measurement is the truest one:

$ quickbench -w echo,expr -p5 -n100 -N2
Running 1 tests 100 times with 2 executables at 2016-10-16 23:57:34.387764 UTC:

Best times 1:
+-------------++---------+---------+
|             ||    echo |    expr |
+=============++=========+=========+
| 3 * 1000000 || 0.00112 | 0.00135 |
+-------------++---------+---------+

Best times 2:
+-------------++---------+---------+
|             ||    echo |    expr |
+=============++=========+=========+
| 3 * 1000000 || 0.00111 | 0.00136 |
+-------------++---------+---------+

You can turn a shell script into a benchmark suite by adding a shebang line:

$ cat 410-run-time.sh
#!/usr/bin/env quickbench -v -p2 -n2 -w hledger-410-before,hledger-410-8bde75c -f
hledger -f 10000x1000x10.journal print
hledger -f 10000x1000x10.journal register
hledger -f 10000x1000x10.journal balance

$ ./410-run-time.sh
Running 3 tests 2 times with 2 executables at 2016-10-16 23:42:57.349721 UTC:
1: hledger-410-before -f 10000x1000x10.journal print
        [3.14s]
2: hledger-410-before -f 10000x1000x10.journal print
        [2.90s]
1: hledger-410-8bde75c -f 10000x1000x10.journal print
        [3.13s]
2: hledger-410-8bde75c -f 10000x1000x10.journal print
        [2.92s]
1: hledger-410-before -f 10000x1000x10.journal register
        [3.52s]
2: hledger-410-before -f 10000x1000x10.journal register
        [3.52s]
1: hledger-410-8bde75c -f 10000x1000x10.journal register
        [3.51s]
2: hledger-410-8bde75c -f 10000x1000x10.journal register
        [3.66s]
1: hledger-410-before -f 10000x1000x10.journal balance
        [3.38s]
2: hledger-410-before -f 10000x1000x10.journal balance
        [1.93s]
1: hledger-410-8bde75c -f 10000x1000x10.journal balance
        [1.93s]
2: hledger-410-8bde75c -f 10000x1000x10.journal balance
        [1.80s]

Best times:
+-----------------------------------++--------------------+---------------------+
|                                   || hledger-410-before | hledger-410-8bde75c |
+===================================++====================+=====================+
| -f 10000x1000x10.journal print    ||               2.90 |                2.92 |
| -f 10000x1000x10.journal register ||               3.52 |                3.51 |
| -f 10000x1000x10.journal balance  ||               1.93 |                1.80 |
+-----------------------------------++--------------------+---------------------+

Options

$ quickbench -h
quickbench 1.0
Run some test commands, possibly with different executables, once or more
and show their best execution times.
Commands are specified as one or more quote-enclosed arguments,
and/or one per line in CMDSFILE; or read from a default file [./bench.sh].
With -w, commands' first words are replaced with a new executable
(or multiple comma-separated executables, showing times for all).
Note: tests executable files only, not shell builtins; options must precede args.

Usage:
  quickbench [options] [<cmd>...]

Options:
  -f, --file CMDSFILE   file containing commands, one per line (- for stdin)
  -w, --with EXE[,...]  replace first word of commands with these executables
  -n, --iterations=N    run each test this many times [default: 1]
  -N, --cycles=N        run the whole suite this many times [default: 1]
  -p, --precision=N     show times with this many decimal places [default: 2]
  -v, --verbose         show commands being run
  -V, --more-verbose    show command output
      --debug           show debug output for this program
  -h, --help            show this help

Related tools

bench (Gabriel Gonzalez 2016) is another command line benchmarking tool written in Haskell. Use that one if you need detailed statistical analysis and output, or HTML reports. Here is bench's output for the echo/expr example above:

$ bench 'echo 3 * 1000000'; bench 'expr 3 \* 1000000'
benchmarking echo 3 * 1000000
time                 2.215 ms   (2.173 ms .. 2.250 ms)
                     0.995 R²   (0.989 R² .. 0.998 R²)
mean                 2.238 ms   (2.203 ms .. 2.296 ms)
std dev              147.6 μs   (92.84 μs .. 265.3 μs)
variance introduced by outliers: 48% (moderately inflated)

benchmarking expr 3 \* 1000000
time                 3.484 ms   (3.405 ms .. 3.556 ms)
                     0.994 R²   (0.987 R² .. 0.998 R²)
mean                 3.564 ms   (3.497 ms .. 3.684 ms)
std dev              280.3 μs   (178.0 μs .. 494.9 μs)
variance introduced by outliers: 52% (severely inflated)

hyperfine also does statistical analysis and has good usability.

The tasty-bench library looks like a good criterion/gauge alternative.