lean4-htt/tests/lean/run/structInst3.lean
Kyle Miller 68c006a95b
feat: transform nondependent lets into haves in declarations and equation lemmas (#8373)
This PR enables transforming nondependent `let`s into `have`s in a
number of contexts: the bodies of nonrecursive definitions, equation
lemmas, smart unfolding definitions, and types of theorems. A motivation
for this change is that when zeta reduction is disabled, `simp` can only
effectively rewrite `have` expressions (e.g. `split` uses `simp` with
zeta reduction disabled), and so we cache the nondependence calculations
by transforming `let`s to `have`s. The transformation can be disabled
using `set_option cleanup.letToHave false`.

Uses `Meta.letToHave`, introduced in #8954.
2025-06-29 19:45:45 +00:00

79 lines
1.5 KiB
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

universe u
set_option pp.structureInstanceTypes true
namespace Ex1
structure A (α : Type u) where
(x : α) (f : αα := λ x => x)
structure B (α : Type u) extends A α where
(y : α := f (f x)) (g : ααα := λ x y => f x)
structure C (α : Type u) extends B α where
(z : α := g x y) (x := f z)
end Ex1
open Ex1
def c1 : C Nat := { x := 1 }
/--
info: let __src := c1;
{ toB := __src.toB, z := 2 : C Nat } : C Nat
-/
#guard_msgs in #check { c1 with z := 2 }
theorem ex1 : { c1 with z := 2 }.z = 2 :=
rfl
/--
info: ex1 :
(have __src := c1;
{ toB := __src.toB, z := 2 : C Nat }).z =
2
-/
#guard_msgs in #check ex1
theorem ex2 : { c1 with z := 2 }.x = c1.x :=
rfl
/--
info: ex2 :
(have __src := c1;
{ toB := __src.toB, z := 2 : C Nat }).x =
c1.x
-/
#guard_msgs in #check ex2
def c2 : C (Nat × Nat) := { z := (1, 1) }
/--
info: let __src := c2;
{
x :=
let __src := __src.x;
(2, __src.snd),
f := __src.f, y := __src.y, g := __src.g, z := __src.z : C (Nat × Nat) } : C (Nat × Nat)
-/
#guard_msgs in #check { c2 with x.fst := 2 }
/--
info: let __src := c2;
{
x :=
let __src := __src.x;
(3, __src.snd),
f := __src.f, y := __src.y, g := __src.g, z := __src.z : C (Nat × Nat) } : C (Nat × Nat)
-/
#guard_msgs in #check { c2 with x.1 := 3 }
/--
info: have this :=
let __src := c2.toB;
{ toB := __src, z := __src.g __src.x __src.y : C (Nat × Nat) };
this : C (Nat × Nat)
-/
#guard_msgs in #check show C _ from { c2.toB with .. }