2014-10-27 16:49:29 -07:00
|
|
|
import logic data.nat.basic
|
|
|
|
open nat
|
|
|
|
|
|
|
|
inductive vector (A : Type) : nat → Type :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| vnil : vector A zero
|
|
|
|
| vcons : Π {n : nat}, A → vector A n → vector A (succ n)
|
2014-10-27 16:49:29 -07:00
|
|
|
|
|
|
|
namespace vector
|
|
|
|
theorem vcons.inj₁ {A : Type} {n : nat} (a₁ a₂ : A) (v₁ v₂ : vector A n) : vcons a₁ v₁ = vcons a₂ v₂ → a₁ = a₂ :=
|
2015-02-11 12:49:27 -08:00
|
|
|
assume h, vector.no_confusion h (λ n h t, h)
|
2014-10-27 16:49:29 -07:00
|
|
|
|
2014-11-08 15:20:19 -08:00
|
|
|
theorem vcons.inj₂ {A : Type} {n : nat} (a₁ a₂ : A) (v₁ v₂ : vector A n) : vcons a₁ v₁ = vcons a₂ v₂ → v₁ == v₂ :=
|
2015-02-11 12:49:27 -08:00
|
|
|
assume h, vector.no_confusion h (λ n h t, t)
|
2014-10-27 16:49:29 -07:00
|
|
|
end vector
|