lean2/tests/lean/slow/path_ind.lean

31 lines
1.3 KiB
Text

import hott
open path
set_option pp.beta true
variables {A : Type} {B : A → Type} {C : Π a : A, B a → Type} {D : Π (a : A) (b : B a), C a b → Type}
structure foo :=
mk :: (a : A) (b : B a) (c : C a b)
set_option unifier.max_steps 50000
definition foo.eq {a₁ a₂ : A} {b₁ : B a₁} {b₂ : B a₂} {c₁ : C a₁ b₁} {c₂ : C a₂ b₂}
(H₁ : a₁ ≈ a₂)
(H₂ : path.rec_on H₁ b₁ ≈ b₂)
(H₃ : path.rec_on H₂ (path.rec_on H₁ c₁) ≈ c₂)
: foo.mk a₁ b₁ c₁ ≈ foo.mk a₂ b₂ c₂ :=
have aux₁: Π (b₂ : B a₁) (c₂ : C a₁ b₂)
(H₂ : path.rec_on idp b₁ ≈ b₂)
(H₃ : path.rec_on H₂ (path.rec_on idp c₁) ≈ c₂),
foo.mk a₁ b₁ c₁ ≈ foo.mk a₁ b₂ c₂, from
λ (b₂ : B a₁) (c₂ : C a₁ b₂)
(H₂ : b₁ ≈ b₂) (H₃ : path.rec_on H₂ c₁ ≈ c₂),
have aux₂ : Π (c₂ : C a₁ b₁) (H₃ : path.rec_on idp c₁ ≈ c₂),
foo.mk a₁ b₁ c₁ ≈ foo.mk a₁ b₁ c₂, from
λ (c₂ : C a₁ b₁) (H₃ : c₁ ≈ c₂),
have aux₃ : foo.mk a₁ b₁ c₁ ≈ foo.mk a₁ b₁ c₁, from
idp,
path.rec_on H₃ aux₃,
path.rec_on H₂ aux₂ c₂ H₃,
path.rec_on H₁ aux₁ b₂ c₂ H₂ H₃