lean2/tests/lean/acc_rec_bug.lean
Leonardo de Moura 781f709bb4 feat(library/logic): import wf.lean in logic/default.lean
We will use well-founded recursion in the definitional package
2014-11-06 15:03:13 -08:00

22 lines
845 B
Text

import logic.prop
inductive acc {A : Type} (R : A → A → Prop) : A → Prop :=
intro : ∀x, (∀ y, R y x → acc R y) → acc R x
variables {A : Type} (R : A → A → Prop) (C : A → Type) (x₁ : A) (ac : ∀y, R y x₁ → acc R y)
variable F : Πx, (Πy, R y x → C y) → C x
eval @acc.rec A R C (λ (x₂ : A)
(ac : ∀y, R y x₂ → acc R y)
(iH : Πy, R y x₂ → C y),
F x₂ iH) x₁ (acc.intro x₁ ac)
check @acc.rec A R C (λ (x₂ : A)
(ac : ∀y, R y x₂ → acc R y)
(iH : Πy, R y x₂ → C y),
F x₂ iH) x₁ (acc.intro x₁ ac)
check F x₁
(λ (y : A) (a : R y x₁),
acc.rec (λ (x₂ : A) (ac : ∀ (y : A), R y x₂ → acc R y) (iH : Π (y : A), R y x₂ → C y), F x₂ iH)
(ac y a))