lean4-htt/tests/bench
2025-03-21 15:59:14 +01:00
..
inundation
mergeSort chore: deprecate List.iota (#6708) 2025-01-21 02:32:35 +00:00
qsort
.gitignore
accumulate_profile.py
arith_eval.ml
big_do.lean
big_omega.lean
binarytrees.ghc-6.hs
binarytrees.lean
binarytrees.lean.args
binarytrees.lean.expected.out
binarytrees.ocaml-2.ml
binarytrees.st.hs
binarytrees.st.lean
binarytrees.st.mlton-2.sml
binarytrees.st.sml
binarytrees.st.swift
binarytrees.swift
binarytrees5.ml
binarytrees5_multicore.ml
bv_decide_inequality.lean
bv_decide_mod.lean
bv_decide_mul.lean
bv_decide_realworld.lean
compile.sh
const_fold.hs
const_fold.lean
const_fold.lean.args
const_fold.lean.expected.out
const_fold.ml
const_fold.sml
const_fold.swift
cross.yaml
dag_hassorry_issue.lean
dag_hassorry_issue.lean.args
dag_hassorry_issue.lean.expected.out
deriv.hs
deriv.lean
deriv.lean.args
deriv.lean.expected.out
deriv.ml
deriv.sml
deriv.swift
ex-50-50-1.leq
flake.lock
flake.nix
full-stdlib.exec.yaml
ghc-gc.py
identifier_completion.lean feat: language reference links and examples in docstrings (#7240) 2025-03-12 09:17:27 +00:00
identifier_completion_didOpen.log feat: language reference links and examples in docstrings (#7240) 2025-03-12 09:17:27 +00:00
identifier_completion_initialization.log test: identifier completion benchmark (#6796) 2025-01-27 19:31:32 +00:00
identifier_completion_runner.lean test: identifier completion benchmark (#6796) 2025-01-27 19:31:32 +00:00
ilean_roundtrip.lean feat: language reference links and examples in docstrings (#7240) 2025-03-12 09:17:27 +00:00
lean-gc.py
liasolver.lean chore: remove the old Lean.Data.HashMap implementation (#7519) 2025-03-20 23:49:55 +00:00
liasolver.lean.args
liasolver.lean.expected.out
Makefile
mlkit-gc.py
nat_repr.lean
nat_repr.lean.args
nat_repr.lean.expected.out
ocaml-gc.py
omega_stress.lean perf: optimize sorry detection in unused variables linter (#7129) 2025-02-22 16:43:39 +00:00
parser.lean
perf.py
qsort.hs
qsort.lean
qsort.lean.args
qsort.lean.expected.out
qsort.ml
qsort.sml
qsort.swift
rbmap.hs
rbmap.lean
rbmap.lean.args
rbmap.lean.expected.out
rbmap.ml
rbmap.sml
rbmap.swift
rbmap2.lean
rbmap3.lean
rbmap500k.lean
rbmap_checkpoint.hs
rbmap_checkpoint.lean
rbmap_checkpoint.lean.args
rbmap_checkpoint.lean.expected.out
rbmap_checkpoint.ml
rbmap_checkpoint.sml
rbmap_checkpoint.swift
rbmap_checkpoint2.lean
rbmap_checkpoint2.sml
rbmap_checkpoint_cpp_lean3.cpp
rbmap_checkpoint_cpp_std.cpp
rbmap_cpp_lean3.cpp
rbmap_cpp_std.cpp
rbmap_fbip.lean
rbmap_library.lean
README.md
reduceMatch.lean
report.py
run.sh
server_startup.lean
server_startup.log
simp_arith1.lean test: fix simp_arith1 benchmark (#7049) 2025-02-12 10:22:32 +00:00
speedcenter.exec.velcom.yaml chore: more core proof benchmarks 2025-03-21 15:59:14 +01:00
speedcenter.yaml
states35.lean
test_single.sh
unionfind.lean
unionfind.lean.args
unionfind.lean.expected.out
unionfind_clean.lean
workspaceSymbols.lean

Lean Benchmark Suites

This folder contains multiple small Lean programs for benchmarking used by two separate benchmark suites based on the temci benchmarking tool:

  • The light-weight "Speedcenter" suite benchmarks the current build of Lean. It can be used for quick comparisons on the cmdline and powers the Lean Speedcenter website.
  • The heavy-weight "Cross" suite benchmarks multiple Lean configurations and other functional compilers against each other and generates CSV and HTML reports from that. It was created for the paper "Counting Immutable Beans - Reference Counting Optimized for Purely Functional Programming" (IFL19).

Speedcenter Suite

Requirements:

  • A local Lean build in ../../build/release. Build at least the bin target.
  • temci. Using Nix, open a nix-shell in the project root directory to add a compatible version to your PATH. Alternatively, try pip3 install git+https://github.com/parttimenerd/temci.git.

To execute the suite and save the results in base.yaml, run (in this folder)

temci exec --config speedcenter.yaml --out base.yaml

Other interesting exec flags:

  • use --runs N to modify the default number of 10 runs per benchmark
  • use --included_blocks fast to excluded slow benchmarks like the stdlib benchmark. You can replace fast with any benchmark name or label in speedcenter.exec.yaml.

If you have multiple saved result files, you can compare them with

temci report --config speedcenter.yaml report1.yaml report2.yaml ...

Cross Suite

We recommend using Nix for building/obtaining all Lean variants and used compilers in a reproducible way. After installing Nix, running the benchmarks is as easy as

nix develop
make

This will record 50 runs for each benchmark configuration (this can be changed with runs in cross.yaml), generate results in report_lean.csv and report_cross.csv, and print them to stdout in a tabulated format. It will also generate HTML reports in report/ comparing the time-based benchmarks.

In order to reduce noise in the benchmarking data, you may instead want to try calling make inside a temci shell:

temci short shell --sudo --preset usable --cpuset_active make

Using root powers, this will temporarily configure your machine similarly to the LLVM benchmarking recommendations and move all your other processes to a single CPU core.