Idrisで依存型に触れる
Haskellで同時に書いてみると依存型の威力がわかりやすい
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
関数の引数に型を取れる
idr(hs)Idris> :t the
the : (a : Type) -> a -> a
idr(hs)-- 型を返す関数を定義
isSingleton : Bool -> Type
isSingleton True = Nat
isSingleton False = List Nat
sum : (single : Bool) -> isSingleton single -> Nat -- 型宣言に関数を使用
sum True x = x
sum False [] = 0
sum False (x :: xs) = x + sum False xs
single
は値
ここでは Bool
型の値
single
の値によって、第2引数が要請する型が変わる
型宣言で自然数演算ができる
定義.idr(hs)(++) : Vect n a -> Vect m a -> Vect (n + m) a -- 型宣言内で加算
(++) Nil ys = ys
(++) (x :: xs) ys = x :: (xs ++ ys)
実行.idr(hs)xs : Vect 5 Int
xs = [1,2,3,4,5]
ys : Vect 3 Int
ys = [6,7,8]
xs ++ ys -- > [1, 2, 3, 4, 5, 6, 7, 8] : Vect 8 Int
こういう要素数を型内演算で表現するのって動的にはどうするんだ?
入力で2つのVect型を受け入れるときとか
普通に肩検査するのか
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
Vectの要素にアクセスする関数index
引数にFinとVectを使って定義されている
idr(hs)index : Fin n -> Vect n a -> a
この定義内の n
は Nat
のみを許容するがこの宣言だけでは明示されていない
これは Fin
(や Vect
)の型定義から推論できるのでわざわざ書かなくていい