# ICML Artifact (Lean + datasets)

This repository contains two top-level folders:

- `datasets/`: scripts to generate the benchmark datasets, plus example JSON files (including instances up to `n = 14`).
- `Lean/`: the Lean 4 formalization.

## Datasets

The `datasets/` folder contains Python scripts that generate the benchmark data, and a few pre-generated JSON files as examples (up to `n = 14`).

## Lean formalization

1. Install Lean 4 by following the official instructions:
    https://lean-lang.org/install/
    (This includes installing the VS Code extension and finishing the setup.)
2. Open the `Lean/` folder as a standalone project/workspace (e.g. in VS Code).
3. Once Lean is installed correctly, build the whole project from the `Lean/` folder:

```bash
lake build
```

### Auditing individual declarations

Lean allows temporary placeholders via `sorry` during development. To check whether a theorem depends (directly or indirectly) on any admitted proof, use an “axioms report”:

```lean
#print axioms <NameOfTheorem>
```

If the output mentions `sorryAx`, then the theorem depends on a `sorry`.
If the output only mentions a subset of these axioms:

```lean
propext
Classical.choice
Quot.sound
```

then the theorem is fully proven.
