Skip to main content

Python library for running the CLEVER Benchmark

Project description

CLEVER: Curated Lean Verified Code Generation Benchmark

CI PyPI version PyPI - Downloads arXiv 🏆 leaderboard

Overview

CLEVER is a benchmark suite for end-to-end code generation and formal verification in Lean 4, adapted from the HumanEval dataset. The goal is to move beyond test-case-driven evaluation by requiring models to generate not only implementations but also formal specifications and proofs — all verifiable by Lean’s type checker.

CLEVER Framework

Benchmark Focus

CLEVER evaluates models across a staged verification pipeline:

  • Task 1: Generate a formal specification from a natural language description.
  • Task 2: Prove semantic equivalence to a hidden ground-truth specification.
  • Task 3: Synthesize a Lean implementation that satisfies the specification.
  • Task 4: Prove the implementation's correctness against the reference specification.

Each step is independently verified, allowing fine-grained diagnosis of model performance.

Key Features

  • Non-computable specifications that prevent implementation leakage and enforce semantic reasoning.
  • Staged certification design to isolate failures across spec generation, implementation, and proof.
  • Supports symbolic proof search with agents like COPRA, enabling deeper proof automation analysis.

🚀 Submitting Your Solutions to CLEVER

To evaluate your LLM-generated solutions against the CLEVER benchmark, use the Python API to package and submit them as LeanProblemView objects. Each submission is compiled and verified using Lean 4, and results are returned as structured ValidationResult objects.

🔧 Steps

  1. Installing the python package: You can simply use pip install clever-bench to install the package from PyPi. Alternatively, you can install from source by cloning the repository and then use pip install -e .

    After installing the package, run the command clever-bench-install (this will work on Linux, no prerequisite of installing Lean 4).

    If you are not on Linux, then you will have install the Lean 4 dependency by yourself. After Lean 4 installation, you can run cd <path-to-clever-package-installation/lean4-dir> && lake exe cache get && lake build (or equivalent command) to build the Lean 4 environment (This is a one time step only).

  2. Load the benchmark:

    from clever_bench.benchmark import Benchmark
    benchmark = Benchmark(is_sample=True)  # or is_sample=False for actual HumanEval problems in `src/lean4/human_eval`
    benchmark.load_all()
    
  3. Select a task (e.g., proof generation):

    from clever_bench.task import ProblemViewTask, TaskComponent
    task = ProblemViewTask(benchmark, TaskComponent.PROOF_GENERATION)
    
  4. Get a problem and fill in your solution:

    problem = task.get_view(3) # Abstraction to hide the staged problem details and only show relevant fields for the selected task for problem with id 3
    problem.implementation = "<your Lean implementation>"
    problem.correctness_proof = "<your proof>"
    
  5. Submit the solution:

    import asyncio
    result = asyncio.run(task.submit_async(problem, timeout_in_ms=30000))
    print(result.correctness_ok, result.error_message)
    

✅ Result

The returned ValidationResult will tell you whether your implementation compiled, and whether the proofs were accepted by Lean (i.e., no sorry).

CLEVER also supports multi-stage verification: the Python API automatically hides irrelevant fields during each task (e.g., only showing the natural language description field for spec generation), enabling clean task-specific prompting and evaluation.

This process allows you to validate your solutions programmatically—whether you're using LLMs, proof agents, or writing Lean by hand.

You can try our baselines here: Baseline Provers

🏆 Leaderboard

View the latest results and submit your own: CLEVER Leaderboard

We welcome submissions from the community! To add your results to the leaderboard:

  1. Evaluate your approach using the Python API described above
  2. Document your methodology with a preprint or publication
  3. Submit your results by contacting us with your evaluation metrics and methodology details

For submissions, please contact: amitayush@utexas.edu

Build Instructions

  • Install Lean 4: https://leanprover.github.io/lean4/doc/quickstart.html
  • Run lake build clever to build the project after changing the directory to src/lean4. OR use VS Code with Lean 4 extension to build the project.
  • All the formalizations are in the src/lean4/human_eval directory.
  • Some extra formalizations are provided in src/lean4/sample_examples/ directory, some of which were used in prompts created for evaluating the benchmark.

Paper

You can find the paper describing CLEVER at https://arxiv.org/abs/2505.13938.

@inproceedings{thakur2025clever,
  title={CLEVER: A Curated Benchmark for Formally Verified Code Generation},
  author={Amitayush Thakur and Jasper Lee and George Tsoukalas and Meghana Sistla and Matthew Zhao and Stefan Zetzsche and Greg Durrett and Yisong Yue and Swarat Chaudhuri},  
  booktitle={39th Conference on Neural Information Processing Systems (NeurIPS 2025)},
  year={2025}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

clever_bench-1.4.0.tar.gz (564.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

clever_bench-1.4.0-py3-none-any.whl (198.0 kB view details)

Uploaded Python 3

File details

Details for the file clever_bench-1.4.0.tar.gz.

File metadata

  • Download URL: clever_bench-1.4.0.tar.gz
  • Upload date:
  • Size: 564.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for clever_bench-1.4.0.tar.gz
Algorithm Hash digest
SHA256 8b9bed581efa43f21a13a6fa2859146b6029cd1e1103eb286b41e985ff924560
MD5 d48cb14672f00426306a5bdec9a63259
BLAKE2b-256 e92e692e8678a946731f0a6927390ca17f60e201c6b79a1f4b9bec81e03ad2b6

See more details on using hashes here.

File details

Details for the file clever_bench-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: clever_bench-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 198.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for clever_bench-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3cd8fe0508d002410349607899c57ff8260c0313e0d61593142e23af65c73ea6
MD5 dbc0395e18dd6a2d371d354aeb9607a1
BLAKE2b-256 6666c90aefc08e2755c15beb43b3e855124d6ee26a631ba1703b3dcfd91b50bd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page