summaryrefslogtreecommitdiff
path: root/transfer/lib/vector.tra
blob: 2eda351676651b411453185df7320d12b43e92d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
-- NOTE: this is unfinished and untested

import nat

data Vector : Type -> Nat -> Type where
   Empty : (A:Type) -> Vector A Zero
   Cell : (A:Type) -> (n:Nat) -> A -> Vector A n -> Vector A (Succ n)

mapV : (A:Type) -> (B:Type) -> (n:Nat) -> (A -> B) -> Vector A n -> Vector B n
mapV A B _ f (Empty _) = Empty B
mapV A B (Succ n) f (Cell _ _ x xs) = Cell B n (f x) (mapV A B n f xs)

appendV : (A:Type) -> (n:Nat) -> (m:Nat) -> Vector A n -> Vector A m -> Vector A (plusNat n m)
appendV A _ _ (Empty _) ys = ys
appendV A (Succ n) m (Cell _ _ x xs) ys = appendV A n (Succ m) xs (Cell A m x ys)