The goal of bench is to benchmark code, tracking execution time, memory
allocations and garbage collections.
Installation
You can install the release version from
CRAN with:
install.packages("bench")
Or you can install the development version from
GitHub with:
# install.packages("pak")
pak::pak("r-lib/bench")
Features
bench::mark() is used to benchmark one or a series of expressions, we
feel it has a number of advantages over alternatives.
Always uses the highest precision APIs available for each operating
system (often nanoseconds).
Tracks memory allocations for each expression.
Tracks the number and type of R garbage collections per expression
iteration.
Verifies equality of expression results by default, to avoid
accidentally benchmarking inequivalent code.
Has bench::press(), which allows you to easily perform and combine
benchmarks across a large grid of values.
Uses adaptive stopping by default, running each expression for a set
amount of time rather than for a specific number of iterations.
Expressions are run in batches and summary statistics are calculated
after filtering out iterations with garbage collections. This allows
you to isolate the performance and effects of garbage collection on
running time (for more details see Neal
2014).
The times and memory usage are returned as custom objects which have
human readable formatting for display (e.g. 104ns) and comparisons
(e.g. x$mem_alloc > "10MB").
There is also full support for plotting with
ggplot2 including custom scales and
formatting.
Usage
bench::mark()
Benchmarks can be run with bench::mark(), which takes one or more
expressions to benchmark against each other.
library(bench)
set.seed(42)
dat <- data.frame(
x = runif(10000, 1, 1000),
y = runif(10000, 1, 1000)
)
bench::mark() will throw an error if the results are not equivalent,
so you don’t accidentally benchmark inequivalent code.
bench::mark(
dat[dat$x > 500, ],
dat[which(dat$x > 499), ],
subset(dat, x > 500)
)
#> Error: Each result must equal the first result:
#> `dat[dat$x > 500, ]` does not equal `dat[which(dat$x > 499), ]`
Results are easy to interpret, with human readable units.
By default the summary uses absolute measures, however relative results
can be obtained by using relative = TRUE in your call to
bench::mark() or calling summary(relative = TRUE) on the results.
bench::press() is used to run benchmarks against a grid of parameters.
Provide setup and benchmarking code as a single unnamed argument then
define sets of values as named arguments. The full combination of values
will be expanded and the benchmarks are then pressed together in the
result. This allows you to benchmark a set of expressions across a wide
variety of input sizes, perform replications and other useful tasks.
ggplot2::autoplot() can be used to generate an informative default
plot. This plot is colored by gc level (0, 1, or 2) and faceted by
parameters (if any). By default it generates a
beeswarm plot,
however you can also specify other plot types (jitter, ridge,
boxplot, violin). See ?autoplot.bench_mark for full details.
ggplot2::autoplot(results)
You can also produce fully custom plots by un-nesting the results and
working with the data directly.
bench also includes system_time(), a higher precision alternative
to
system.time().
bench::system_time({
i <- 1
while (i < 1e7) {
i <- i + 1
}
})
#> process real
#> 1.73s 1.7s
bench::system_time(Sys.sleep(.5))
#> process real
#> 58µs 497ms
bench
The goal of bench is to benchmark code, tracking execution time, memory allocations and garbage collections.
Installation
You can install the release version from CRAN with:
Or you can install the development version from GitHub with:
Features
bench::mark()is used to benchmark one or a series of expressions, we feel it has a number of advantages over alternatives.bench::press(), which allows you to easily perform and combine benchmarks across a large grid of values.The times and memory usage are returned as custom objects which have human readable formatting for display (e.g.
104ns) and comparisons (e.g.x$mem_alloc > "10MB").There is also full support for plotting with ggplot2 including custom scales and formatting.
Usage
bench::mark()Benchmarks can be run with
bench::mark(), which takes one or more expressions to benchmark against each other.bench::mark()will throw an error if the results are not equivalent, so you don’t accidentally benchmark inequivalent code.Results are easy to interpret, with human readable units.
By default the summary uses absolute measures, however relative results can be obtained by using
relative = TRUEin your call tobench::mark()or callingsummary(relative = TRUE)on the results.bench::press()bench::press()is used to run benchmarks against a grid of parameters. Provide setup and benchmarking code as a single unnamed argument then define sets of values as named arguments. The full combination of values will be expanded and the benchmarks are then pressed together in the result. This allows you to benchmark a set of expressions across a wide variety of input sizes, perform replications and other useful tasks.Plotting
ggplot2::autoplot()can be used to generate an informative default plot. This plot is colored by gc level (0, 1, or 2) and faceted by parameters (if any). By default it generates a beeswarm plot, however you can also specify other plot types (jitter,ridge,boxplot,violin). See?autoplot.bench_markfor full details.You can also produce fully custom plots by un-nesting the results and working with the data directly.
system_time()bench also includes
system_time(), a higher precision alternative to system.time().Alternatives