2015-01-02 23:18:35 -08:00
|
|
|
open nat
|
|
|
|
|
|
|
|
inductive vector (A : Type) : nat → Type :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| nil {} : vector A zero
|
|
|
|
| cons : Π {n}, A → vector A n → vector A (succ n)
|
2015-01-02 23:18:35 -08:00
|
|
|
|
|
|
|
infixr `::` := vector.cons
|
|
|
|
|
2015-02-25 16:20:44 -08:00
|
|
|
definition swap {A : Type} : Π {n}, vector A (succ (succ n)) → vector A (succ (succ n))
|
|
|
|
| swap (a :: b :: vs) := b :: a :: vs
|
2015-01-02 23:18:35 -08:00
|
|
|
|
|
|
|
-- Remark: in the current approach for HoTT, the equation
|
|
|
|
-- swap (a :: b :: v) = b :: a :: v
|
|
|
|
-- holds definitionally only when the index is a closed term.
|
|
|
|
example (a b : num) (v : vector num 5) : swap (a :: b :: v) = b :: a :: v :=
|
|
|
|
rfl
|