Skip to content
master
Go to file
Code

Latest commit

 

Git stats

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
lib
 
 
 
 
 
 
 
 

README.md

Benchmark v1.1 by Solistra

Summary

This script provides a simple benchmarking tool similar to the Benchmark module present in the Ruby standard library. Essentially, this script allows you to run specified code and objectively determine its execution speed. This is primarily a scripter's tool.

Usage

This script is intended to be used entirely through the benchmarking method SES::Benchmark.measure. This method takes the number of iterations to run the passed block as an argument -- if no argument is given, the block is run SES::Benchmark.iterations times (10,000 by default, though this can be redefined in the configuration area or during runtime). For example, we could measure Array#pop 100,000 times like so:

SES::Benchmark.measure(100_000) { [1, 2, 3].pop }

The SES::Benchmark.measure method can also report on any number of ways to potentially run code -- very useful for benchmarking alternative methods of attaining the same result. To do so, simply pass a block that takes a single argument; the argument passed yields a Reporter instance with the report method. For example, this is how we could benchmark Array#sort versus Array#sort!:

SES::Benchmark.measure do |x|
  a = (1..100).to_a.shuffle!
  x.report('Array#sort')  { a.sort  }
  x.report('Array#sort!') { a.sort! }
end

NOTE: Reports are executed in the order that they are given -- running the code above with the report calls switched would produce misleading results. (Labels for reports are also optional, but highly recommended.)

In addition to this, you may run individual reports a different number of times than the other reports in a measure block. For instance, we could default to running iterations 100,000 times while running a single report for 200,000 like so (using the previous example):

SES::Benchmark.iterations = 100_000
SES::Benchmark.measure do |x|
  a = (1..100).to_a.shuffle!
  x.report('Array#sort')           { a.sort  }
  x.report('Array#sort!', 200_000) { a.sort! }
end

License

This script is made available under the terms of the MIT Expat license. View this page for more detailed information.

Installation

Place this script below the SES Core (v2.0) script (if you are using it) or the Materials header, but above all other custom scripts. This script does not require the SES Core (v2.0), but it is recommended.

About

Provides a simple benchmarking tool similar to the Benchmark module present in the Ruby standard library.

Resources

Packages

No packages published

Languages

You can’t perform that action at this time.