2015-08-12 15:05:14 -07:00
|
|
|
|
import data.examples.vector data.prod
|
2015-01-05 16:52:30 -08:00
|
|
|
|
open nat vector prod
|
|
|
|
|
|
|
|
|
|
variables {A B : Type}
|
|
|
|
|
|
2015-02-25 16:20:44 -08:00
|
|
|
|
definition unzip : Π {n}, vector (A × B) n → vector A n × vector B n
|
|
|
|
|
| unzip nil := (nil, nil)
|
|
|
|
|
| unzip ((a, b) :: t) := (a :: pr₁ (unzip t), b :: pr₂ (unzip t))
|
2015-01-05 16:52:30 -08:00
|
|
|
|
|
|
|
|
|
theorem unzip_nil : unzip nil = (@nil A, @nil B) :=
|
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
theorem unzip_cons {n : nat} (a : A) (b : B) (t : vector (A × B) n) :
|
|
|
|
|
unzip ((a, b) :: t) = (a :: pr₁ (unzip t), b :: pr₂ (unzip t)) :=
|
|
|
|
|
rfl
|