Skip to content

rho-devel/benchmarks

 
 

Repository files navigation

#R Benchmark Suite

R Benchmark Suite is a collection of benchmarks for R programming language as well as a benchmarking environment for measuring the performance of different R VM implementations.

Available benchmark suites

Name Description Type
Shooutout R version of Computer Language Benchmarks Game Type I
R-benchmark-25 Also called ATT benchmark Type I and III
scalar Micro benchmarks, such as GCD, fib, primes, etc. Type I
mathkernel Math kernels, such as Matrix-matrix multiply, vector add, etc. Type I, II and III
riposte Vector dominated benchmark used in Riposte project Type II
misc Some random collections Type I, II, and III

The benchmark type is defined as

Type I: Looping Over Data

Example

#R-benchmark-25: creation of Toeplitz matrix
for (j in 1:500) {
    for (k in 1:500) {
        jk<-j - k;
        b[k,j] <- abs(jk) + 1
    }
}

Type II: Vector Programming

Example

#Riposte benchmark: age and gender are large vectors
males_over_40 <- function(age, gender) {
    age >= 40 & gender == 1
}

Type III: Native library Glue

Example

#R-benchmark-25:  FFT over 2.4Mill random values
a <- rnorm(2400000);
b <- fft(a)

Running a benchmark

The driver is rbench.py under utility directory. You can use "-h" to get the help.

$ rbench.py -h
usage: rbench.py [-h] [--meter {time,perf,system.time}]
                 [--rvm {R,R-bytecode,rbase2.4,...}]
                 [--warmup_rep WARMUP_REP] [--bench_rep BENCH_REP]
                 source [args [args ...]]
...

Note: on Windows platform, you may use "python rbench.py -h"

Do a simple benchmark

$ cd examples
$ ../utility/rbench.py hello_rbenchmark.R

It will use the default R VM (R-bytecode) and the default meter to benchmark the application. The output of benchmark application will be thrown away (redirect to "/dev/null"), and the timing result will be recorded in "rbench.csv" file.

The default benchmark method has two phases

  • pure warmup: run run() 2 times
  • warmup + benchmark: run run() 2 + 5 times

Then the post processing will diff the two phases, and reports the average value for the 5 benchmark iterations.

You can use command line to do more controls

$ cd examples
$ ../utility/rbench.py --meter perf --rvm R --bench_log stdout hello_rbenchmark.R 1000

Then it will use Linux perf (only on Linux Platform) for the data measuring, choose the R (without byte-code compiler) as the VM for benchmarking, and dump the benchmark's output to the standard output.

You can run benchmark for all .R files in a directory, or run benchmarks defined in a .list file.

Please refer Running Benchmark for additional controls of running a benchmark. And the driver supports many RVMs for benchmarking. Here is the list.

Writing your own benchmark R program

A benchmark R program should have a mandatory run() function. The driver will call run() function in the benchmarking.

#hello_rbenchmark.R
run <- function () {
    print("Executing hello_rbenchmark run()")
}

The benchmark R program could have an optional setup() function. The driver will call setup() first, then use the return value of the setup() to call the run().

#hello_rbenchmark.R

setup <- function(cmdline_args=character(0)) {
   return(cmdline_args)
}

run <- function (input) { # input = setup(cmdline_args)
    print("Executing hello_rbenchmark run() with input")
    print(input)
}

Please refer Writing Benchmark for additional controls of the benchmark program

FAQ

FAQ

Credit

The R-benchmark-25 benchmark is ported from http://r.research.att.com/benchmarks/.

The R version shootout benchmark is ported from UIUC ORBIT project and Purdue FastR project (https://github.com/allr/fastr).

The Riposte benchmark is ported from Riposte project (https://github.com/jtalbot/riposte/)

Contact

Please contact Haichuan Wang (hwang154@illinois.edu) and Arun Chauhan(arunchauhan@google.com) for any questions and suggestions.

About

Collections of Benchmarks of R

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • R 70.0%
  • C 13.1%
  • Python 6.8%
  • Java 5.0%
  • Fortran 4.0%
  • Makefile 1.1%