標準配列パッケージの境界付き配列に似たものを実現したいのですが、repa 配列を使用します。
これを達成するための素晴らしくきれいな方法は何ですか?
これは私が試したものですが、境界をチェックするカスタム関数ですべてをラップするよりも良い方法があるはずです:
import Data.Array.Repa
data C = A | F | L deriving (Eq,Enum,Ord,Bounded,Show)
data Ballot c = Ballot {
vote::Array U (Z :. Int) Int
} deriving Show
mkBallot::(Eq c ,Enum c,Ord c, Bounded c, Show c) => c -> Ballot c
mkBallot c = Ballot $ fromListUnboxed (Z :. max) (genSc c)
where
max = (fromEnum (maxBound `asTypeOf` c)) + 1
genSc::(Eq c,Enum c,Ord c,Bounded c,Show c) => c -> [Int]
genSc c = [ f x | x <- enumFrom (minBound `asTypeOf` c) , let f v = if x == c then 1 else 0]
showScore c b = index (vote b) (Z :. ((fromEnum c)))
また、(sh :. C) の Shape インスタンスを派生させようとしましたが、役に立ちませんでした。データ型の Shape クラスで宣言されたインターフェイスのいくつかを実装する方法について、頭を悩ませることができません。他の誰かに道があることを願って質問を書いていますが、そうでない場合はもう一度やり直します。ありがとうございました!