我有兴趣推广一些计算工具以使用Cayley Table,这意味着基于查找表的乘法运算。
我可以创建一个最小的实现,如下所示:
date CayleyTable = CayleyTable {
ct_name :: ByteString,
ct_products :: V.Vector (V.Vector Int)
} deriving (Read, Show)
instance Eq (CayleyTable) where
(==) a b = ct_name a == ct_name b
data CTElement = CTElement {
ct_cayleytable :: CayleyTable,
ct_index :: !Int
}
instance Eq (CTElement) where
(==) a b = assert (ct_cayleytable a == ct_cayleytable b) $
ct_index a == ct_index b
instance Show (CTElement) where
show = ("CTElement" ++) . show . ctp_index
a **** b = assert (ct_cayleytable a == ct_cayleytable b) $
((ct_cayleytable a) ! a) ! b
然而,这种方法存在许多问题,首先是通过比较进行运行时类型检查,但包括无法正常工作ByteString
的事实。read
知道我应该如何正确地做到这一点吗?
我可以想象使用提供乘法并验证其类型一致性的类型类创建一系列 newtypes ,等等,除非在执行 IOCTElement1
时CTElement2
。Int
CTElement
理想情况下,也可能有一些技巧可以只传递这个ct_cayleytable
指针的一个副本,也许使用像 的隐式参数?cayleytable
,但这不能很好地处理多个不兼容的 Cayley 表,并且通常令人讨厌。
另外,我已经收集到向量的索引可以被视为一个comonad。是否有任何好的comonad 实例用于vector 或任何可能有助于平滑这种类型检查的东西,即使最终在运行时进行检查?