Gradual Typing Performance benchmark programs.
This is a collection of Racket programs. Each program can run in exponentially-many configurations that differ in terms of their type annotations.
The benchmarks are in the benchmarks/
folder.
Each benchmark is made of 2-4 folders:
untyped/
a Racket version of the benchmark (the untyped configuration)typed/
a Typed Racket version of the benchmark (the typed configuration)- (optional)
both/
extra Racket / Typed Racket files - (optional)
base/
extra libraries or data files
- Go to the benchmark's directory
- Create a new directory
- Copy in all the
both/
files, if any - Copy in your choice of
typed/
anduntyped/
files - Run
main.rkt
- Install the
gtp-measure
package (raco pkg install gtp-measure
) - Run
raco gtp-measure <PATH-TO-BENCHMARK>
(or runraco gtp-measure --help
) - Follow its instructions to get the output
To run all benchmarks, copy and modify the sample manifest here and run via:
PLTSTDERR="error info@gtp-measure" raco gtp-measure --output sample-data/ sample-gtp-measure-manifest.rkt
Results appear in a new directory ./sample-data/1/
and if you re-run the command
new directories appear under ./sample-data/
.
- Run
racket utilities/make-configurations.rkt <PATH-TO-BENCHMARK>
, this creates a directory with all typed/untyped configurations of the benchmark. - Go to one of the new directories, run
main.rkt
The benchmarks try to meet the following "rock bottom" guidelines for giving reproducible performance data in reasonable time:
- No I/O actions during timed computation
- Able to run all typed/untyped configurations
- Run for 1-5 seconds when untyped or fully-typed
- Run for < 300 seconds in the worst case
Points 3 and 4 are in conflict.
For forth
in particular, the untyped configuration runs extremely quickly
but some partially-typed configurations take close to 5 minutes.
Original development: https://github.com/nuprl/gradual-typing-performance
Subsets / earlier-versions of these benchmarks have appeared in:
- Is Sound Gradual Typing Dead?. Asumu Takikawa, Daniel Feltey, Ben Greenman, Max S. New, Jan Vitek, and Matthias Felleisen. POPL 2016.
- How to Evaluate the Performance of Gradual Type Systems. Ben Greenman, Asumu Takikawa, Max S. New, Daniel Feltey, Robert Bruce Findler, Jan Vitek, and Matthias Felleisen. Submitted for publication.
- Sound Gradual Typing: Only Mostly Dead. Spenser Bauman, Carl Friedrich Bolz-Tereick, Jeremy Siek, and Sam Tobin-Hochstadt. OOPSLA 2017.