hyperfine/README.md

160 lines
5.3 KiB
Markdown
Raw Normal View History

2018-01-13 22:27:24 +03:00
# hyperfine
2018-01-18 21:19:13 +03:00
[![Build Status](https://travis-ci.org/sharkdp/hyperfine.svg?branch=master)](https://travis-ci.org/sharkdp/hyperfine)
2018-02-13 23:16:45 +03:00
[![Build status](https://ci.appveyor.com/api/projects/status/pdqq5frgkcj0smrs?svg=true)](https://ci.appveyor.com/project/sharkdp/hyperfine)
2018-01-18 21:19:13 +03:00
[![Version info](https://img.shields.io/crates/v/hyperfine.svg)](https://crates.io/crates/hyperfine)
2018-10-19 22:35:21 +03:00
[中文](https://github.com/chinanf-boy/hyperfine-zh)
2018-01-13 22:27:24 +03:00
2019-06-08 15:29:07 +03:00
A command-line benchmarking tool.
2018-01-13 22:27:24 +03:00
2018-01-18 20:13:12 +03:00
**Demo**: Benchmarking [`fd`](https://github.com/sharkdp/fd) and
[`find`](https://www.gnu.org/software/findutils/):
2018-01-15 00:19:52 +03:00
2018-01-15 00:12:02 +03:00
![hyperfine](https://i.imgur.com/5OqrGWe.gif)
2018-01-13 23:31:51 +03:00
2018-01-13 22:27:24 +03:00
## Features
2018-01-20 16:22:26 +03:00
* Statistical analysis across multiple runs.
* Support for arbitrary shell commands.
* Constant feedback about the benchmark progress and current estimates.
* Warmup runs can be executed before the actual benchmark.
* Cache-clearing commands can be set up before each timing run.
2019-06-08 15:36:45 +03:00
* Statistical outlier detection to detect interference from other programs and caching effects.
* Export results to various formats: CSV, JSON, Markdown, AsciiDoc.
* Parameterized benchmarks (e.g. vary the number of threads).
2018-02-13 23:17:27 +03:00
* Cross-platform
2018-01-13 23:07:28 +03:00
2018-01-17 00:03:50 +03:00
## Usage
### Basic benchmark
2018-01-18 20:13:12 +03:00
To run a benchmark, you can simply call `hyperfine <command>...`. The argument(s) can be any
shell command. For example:
2018-01-17 00:03:50 +03:00
``` bash
2018-01-24 10:32:11 +03:00
hyperfine 'sleep 0.3'
2018-01-17 00:03:50 +03:00
```
2018-01-18 20:13:12 +03:00
Hyperfine will automatically determine the number of runs to perform for each command. By default,
it will perform *at least* 10 benchmarking runs. To change this, you can use the `-m`/`--min-runs`
option:
2018-01-17 00:03:50 +03:00
``` bash
2018-01-24 10:32:11 +03:00
hyperfine --min-runs 5 'sleep 0.2' 'sleep 3.2'
2018-01-17 00:03:50 +03:00
```
### I/O-heavy programs
2018-01-18 20:13:12 +03:00
If the program execution time is limited by disk I/O, the benchmarking results can be heavily
2018-01-31 00:33:00 +03:00
influenced by disk caches and whether they are cold or warm.
2018-01-17 00:03:50 +03:00
2018-01-18 20:13:12 +03:00
If you want to run the benchmark on a warm cache, you can use the `-w`/`--warmup` option to perform
a certain number of program executions before the actual benchmark:
2018-01-17 00:03:50 +03:00
``` bash
2018-01-24 10:32:11 +03:00
hyperfine --warmup 3 'grep -R TODO *'
2018-01-17 00:03:50 +03:00
```
2018-01-18 20:13:12 +03:00
Conversely, if you want to run the benchmark for a cold cache, you can use the `-p`/`--prepare`
option to run a special command before *each* timing run. For example, to clear harddisk caches
on Linux, you can run
2018-01-17 00:03:50 +03:00
``` bash
sync; echo 3 | sudo tee /proc/sys/vm/drop_caches
```
To use this specific command with Hyperfine, call `sudo -v` to temporarily gain sudo permissions
2018-01-18 20:13:12 +03:00
and then call:
2018-01-17 00:03:50 +03:00
``` bash
2018-01-18 20:13:12 +03:00
hyperfine --prepare 'sync; echo 3 | sudo tee /proc/sys/vm/drop_caches' 'grep -R TODO *'
2018-01-17 00:03:50 +03:00
```
### Parameterized benchmarks
If you want to run a benchmark where only a single parameter is varied (say, the number of
threads), you can use the `-P`/`--parameter-scan` option and call:
``` bash
hyperfine --prepare 'make clean' --parameter-scan num_threads 1 12 'make -j {num_threads}'
```
### Export results
Hyperfine has multiple options for exporting benchmark results: CSV, JSON, Markdown (see `--help`
text for details). To export results to Markdown, for example, you can use the `--export-markdown`
option that will create tables like this:
2019-06-08 15:36:45 +03:00
| Command | Mean [s] | Min [s] | Max [s] | Relative |
|:---|---:|---:|---:|---:|
| `find . -iregex '.*[0-9]\.jpg$'` | 2.395 ± 0.033 | 2.355 | 2.470 | 7.7 |
| `find . -iname '*[0-9].jpg'` | 1.416 ± 0.029 | 1.389 | 1.494 | 4.6 |
| `fd -HI '.*[0-9]\.jpg$'` | 0.309 ± 0.005 | 0.305 | 0.320 | 1.0 |
2018-12-12 22:37:51 +03:00
The JSON output is useful if you want to analyze the benchmark results in more detail. See the
[`scripts/`](https://github.com/sharkdp/hyperfine/tree/master/scripts) folder for some examples.
2018-01-13 23:07:28 +03:00
## Installation
2018-03-25 00:06:03 +03:00
### On Ubuntu
Download the appropriate `.deb` package from the [Release page](https://github.com/sharkdp/hyperfine/releases)
and install it via `dpkg`:
2018-01-13 23:07:28 +03:00
```
2019-06-08 15:38:43 +03:00
wget https://github.com/sharkdp/hyperfine/releases/download/v1.6.0/hyperfine_1.6.0_amd64.deb
sudo dpkg -i hyperfine_1.6.0_amd64.deb
2018-01-13 23:07:28 +03:00
```
2018-01-13 22:27:24 +03:00
### On Alpine Linux
On Alpine Linux, hyperfine can be installed [from the official repositories](https://pkgs.alpinelinux.org/packages?name=hyperfine):
```
apk add hyperfine
```
2018-03-25 00:06:03 +03:00
### On Arch Linux
2018-01-15 20:34:48 +03:00
On Arch Linux, hyperfine can be installed [from the AUR](https://aur.archlinux.org/packages/hyperfine):
```
yaourt -S hyperfine
```
2018-03-25 00:06:03 +03:00
### On Void Linux
Hyperfine can be installed via xbps
2018-01-20 16:22:26 +03:00
```
2018-03-25 00:06:03 +03:00
xbps-install -S hyperfine
2018-01-20 16:22:26 +03:00
```
2019-06-08 15:36:45 +03:00
### On macOS
Hyperfine can be installed via [Homebrew](https://brew.sh):
```
brew install hyperfine
```
### With conda
2019-06-08 17:24:14 +03:00
[![Conda Platforms](https://img.shields.io/conda/pn/conda-forge/hyperfine.svg)](https://anaconda.org/conda-forge/hyperfine)
Hyperfine can be installed via [`conda`](https://conda.io/en/latest/) from the [`conda-forge`](https://anaconda.org/conda-forge/hyperfine) channel:
```
conda install -c conda-forge hyperfine
```
2018-03-25 00:06:03 +03:00
### With cargo (Linux, macOS, Windows)
2018-01-31 02:55:26 +03:00
2018-03-25 00:06:03 +03:00
Hyperfine can be installed via [cargo](https://doc.rust-lang.org/cargo/):
2018-01-31 02:55:26 +03:00
```
2018-03-25 00:06:03 +03:00
cargo install hyperfine
2018-01-31 02:55:26 +03:00
```
2018-01-20 16:22:26 +03:00
2018-12-28 22:33:31 +03:00
Make sure that you use Rust 1.30 or higher.
2018-07-18 19:11:05 +03:00
2018-09-28 23:02:24 +03:00
### From binaries (Linux, macOS, Windows)
2018-03-25 00:06:03 +03:00
Download the corresponding archive from the [Release page](https://github.com/sharkdp/hyperfine/releases).
2019-06-08 15:29:07 +03:00
## Alternative tools
Hyperfine is inspired by [bench](https://github.com/Gabriel439/bench).
2018-01-13 22:27:24 +03:00
## Origin of the name
The name *hyperfine* was chosen in reference to the hyperfine levels of caesium 133 which play a crucial role in the
2018-09-04 12:44:59 +03:00
[definition of our base unit of time](https://en.wikipedia.org/wiki/Second#History_of_definition)
2018-01-13 22:27:24 +03:00
— the second.