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
The quick way:
- 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
The correct way:
- Install the gtp-measurepackage (raco pkg install gtp-measure)
- Run raco gtp-measure <PATH-TO-BENCHMARK>(or runraco gtp-measure --help)
- Follow its instructions to get the output
The semi-automatic way:
- Run racket make-lattice.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.
- require-typed-check
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.