2018-07-08 21:08:26 +03:00
|
|
|
# ruby/benchmark
|
|
|
|
|
|
|
|
This directory has benchmark definitions to be run with
|
|
|
|
[benchmark\_driver.gem](https://github.com/benchmark-driver/benchmark-driver).
|
|
|
|
|
|
|
|
## Normal usage
|
|
|
|
|
2018-07-10 16:36:44 +03:00
|
|
|
Execute `gem install benchmark_driver` and run a command like:
|
2018-07-08 21:08:26 +03:00
|
|
|
|
2018-07-08 21:10:14 +03:00
|
|
|
```bash
|
2018-07-08 21:08:26 +03:00
|
|
|
# Run a benchmark script with the ruby in the $PATH
|
2018-07-10 19:03:51 +03:00
|
|
|
benchmark-driver benchmark/app_fib.rb
|
2018-07-08 21:08:26 +03:00
|
|
|
|
2018-07-11 02:56:57 +03:00
|
|
|
# Run benchmark scripts with multiple Ruby executables or options
|
|
|
|
benchmark-driver benchmark/*.rb -e /path/to/ruby -e '/path/to/ruby --jit'
|
2018-07-08 21:08:26 +03:00
|
|
|
|
|
|
|
# Or compare Ruby versions managed by rbenv
|
2018-07-11 02:56:57 +03:00
|
|
|
benchmark-driver benchmark/*.rb --rbenv '2.5.1;2.6.0-preview2 --jit'
|
2018-07-10 18:01:27 +03:00
|
|
|
|
|
|
|
# You can collect many metrics in many ways
|
2018-07-11 02:56:57 +03:00
|
|
|
benchmark-driver benchmark/*.rb --runner memory --output markdown
|
|
|
|
|
|
|
|
# Some are defined with YAML for complex setup or accurate measurement
|
|
|
|
benchmark-driver benchmark/*.yml
|
2018-07-08 21:08:26 +03:00
|
|
|
```
|
|
|
|
|
2018-07-10 16:41:13 +03:00
|
|
|
See also:
|
|
|
|
|
|
|
|
```console
|
2018-07-11 03:34:32 +03:00
|
|
|
Usage: benchmark-driver [options] RUBY|YAML...
|
2022-06-08 07:30:22 +03:00
|
|
|
-r, --runner TYPE Specify runner type: ips, time, memory, once, block (default: ips)
|
|
|
|
-o, --output TYPE Specify output type: compare, simple, markdown, record, all (default: compare)
|
2018-07-11 03:34:32 +03:00
|
|
|
-e, --executables EXECS Ruby executables (e1::path1 arg1; e2::path2 arg2;...)
|
|
|
|
--rbenv VERSIONS Ruby executables in rbenv (x.x.x arg1;y.y.y arg2;...)
|
|
|
|
--repeat-count NUM Try benchmark NUM times and use the fastest result or the worst memory usage
|
|
|
|
--repeat-result TYPE Yield "best", "average" or "worst" result with --repeat-count (default: best)
|
2022-06-08 07:30:22 +03:00
|
|
|
--alternate Alternate executables instead of running the same executable in a row with --repeat-count
|
2018-07-10 16:41:13 +03:00
|
|
|
--bundler Install and use gems specified in Gemfile
|
2018-07-11 03:34:32 +03:00
|
|
|
--filter REGEXP Filter out benchmarks with given regexp
|
|
|
|
--run-duration SECONDS Warmup estimates loop_count to run for this duration (default: 3)
|
2022-06-08 07:30:22 +03:00
|
|
|
--timeout SECONDS Timeout ruby command execution with timeout(1)
|
|
|
|
-v, --verbose Verbose mode. Multiple -v options increase visilibity (max: 2)
|
2018-07-10 16:41:13 +03:00
|
|
|
```
|
|
|
|
|
2018-07-08 21:08:26 +03:00
|
|
|
## make benchmark
|
|
|
|
|
|
|
|
Using `make benchmark`, `make update-benchmark-driver` automatically downloads
|
2018-07-10 16:36:44 +03:00
|
|
|
the supported version of benchmark\_driver, and it runs benchmarks with the downloaded
|
2018-07-10 18:49:42 +03:00
|
|
|
benchmark\_driver.
|
2018-07-08 21:08:26 +03:00
|
|
|
|
2018-07-08 21:10:14 +03:00
|
|
|
```bash
|
2018-07-08 21:08:26 +03:00
|
|
|
# Run all benchmarks with the ruby in the $PATH and the built ruby
|
|
|
|
make benchmark
|
|
|
|
|
|
|
|
# Or compare with specific ruby binary
|
|
|
|
make benchmark COMPARE_RUBY="/path/to/ruby --jit"
|
|
|
|
|
2020-04-14 07:37:42 +03:00
|
|
|
# Run vm benchmarks
|
|
|
|
make benchmark ITEM=vm
|
2018-07-08 21:08:26 +03:00
|
|
|
|
2018-07-09 19:31:35 +03:00
|
|
|
# Run some limited benchmarks in ITEM-matched files
|
2020-04-14 07:37:42 +03:00
|
|
|
make benchmark ITEM=vm OPTS=--filter=block
|
2018-07-08 21:08:26 +03:00
|
|
|
|
2018-07-10 16:05:29 +03:00
|
|
|
# You can specify the benchmark by an exact filename instead of using the default argument:
|
|
|
|
# ARGS = $$(find $(srcdir)/benchmark -maxdepth 1 -name '*$(ITEM)*.yml' -o -name '*$(ITEM)*.rb')
|
2020-06-07 01:39:41 +03:00
|
|
|
make benchmark ARGS=benchmark/erb_render.yml
|
2018-07-08 21:08:26 +03:00
|
|
|
|
2018-07-09 19:31:35 +03:00
|
|
|
# You can specify any option via $OPTS
|
|
|
|
make benchmark OPTS="--help"
|
2018-07-10 15:14:04 +03:00
|
|
|
|
|
|
|
# With `make benchmark`, some special runner plugins are available:
|
2018-07-10 18:01:27 +03:00
|
|
|
# -r peak, -r size, -r total, -r utime, -r stime, -r cutime, -r cstime
|
2020-04-14 07:37:42 +03:00
|
|
|
make benchmark ITEM=vm_bigarray OPTS="-r peak"
|
2018-07-08 21:08:26 +03:00
|
|
|
```
|