Test "level-imax-normalization"
Expected: ✋ reject · Size: 5.8 KB · Lines: 96 · lean4export: 3.1.0 · Lean: 4.26.0 · 📄 Declaration
Proof of False via incorrect universe level normalization for imax.
A correct kernel must distinguish imax 0 v from succ(imax 0 v), since at v=0 these
evaluate to 0 and 1 respectively. However, a level normalization algorithm that drops an
accumulated successor offset when decomposing imax u (param v) will produce identical normal
forms for both, causing the equivalence check to incorrectly return true.
This allows defining a universe-collapsing identity function
down.{v} : Sort (succ (imax 0 v)) → Sort (imax 0 v), and then
myProp : Prop := down.{0} Bool (a Prop that is computationally Bool). Proof irrelevance on
myProp equates Bool.true and Bool.false, and Bool.rec maps this into False.
| Checker | Result | ⏱️ | 🧠 | |||
|---|---|---|---|---|---|---|
| still-nanoda | ✋ | 2 ms | 2.9 MB | |||
| sonanoda | ✋ | 2 ms | 2.9 MB | |||
| nanoda | ✋ | 2 ms | 2.9 MB | |||
| nanobruijn | ✋ | 3 ms | 5.1 MB | |||
| official-nightly | ✋ | 31 ms | 57.1 MB | |||
| official | ✋ | 32 ms | 66.1 MB | |||
| official-v4.28.0 | ✋ | 38 ms | 70.6 MB | |||
| lean4lean | ✋ | 112 ms | 94.4 MB | |||
| rpylean | ✋ | 2 ms | 7.4 MB | |||
| mini | ✋ | 38 ms | 70.3 MB | |||
| always-decline | 🚫 | 1 ms | 2.8 MB | |||
| always-reject | ✋ | 1 ms | 2.8 MB | |||
| parse-only | 👍 | 37 ms | 70.0 MB | |||
| always-accept | 👍 | 1 ms | 2.8 MB |