2015-05-26 17:19:27 -07:00
|
|
|
set_option pp.universes true
|
|
|
|
check @not
|
|
|
|
|
2014-12-08 22:11:48 -08:00
|
|
|
inductive list (A : Type) : Type :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| nil {} : list A
|
|
|
|
| cons : A → list A → list A
|
2014-12-08 22:11:48 -08:00
|
|
|
|
|
|
|
namespace list
|
|
|
|
open lift
|
|
|
|
|
|
|
|
theorem nil_ne_cons {A : Type} (a : A) (v : list A) : nil ≠ cons a v :=
|
2015-02-11 12:49:27 -08:00
|
|
|
λ H, down (list.no_confusion H)
|
2014-12-08 22:11:48 -08:00
|
|
|
|
|
|
|
theorem cons.inj₁ {A : Type} (a₁ a₂ : A) (v₁ v₂ : list A) : cons a₁ v₁ = cons a₂ v₂ → a₁ = a₂ :=
|
2015-02-11 12:49:27 -08:00
|
|
|
λ H, down (list.no_confusion H (λ (h₁ : a₁ = a₂) (h₂ : v₁ = v₂), h₁))
|
2014-12-08 22:11:48 -08:00
|
|
|
|
|
|
|
theorem cons.inj₂ {A : Type} (a₁ a₂ : A) (v₁ v₂ : list A) : cons a₁ v₁ = cons a₂ v₂ → v₁ = v₂ :=
|
2015-02-11 12:49:27 -08:00
|
|
|
λ H, down (list.no_confusion H (λ (h₁ : a₁ = a₂) (h₂ : v₁ = v₂), h₂))
|
2014-12-08 22:11:48 -08:00
|
|
|
|
|
|
|
end list
|