13得票2回答
SICP中统一算法中似乎不必要的情况

我正试图理解SICP中描述的统一算法,这里有详细说明。 特别地,在“extend-if-possible”过程中,有一个检查(标有星号“*”的第一个位置),该检查用于验证右侧的“表达式”是否为当前框架中已绑定到某些内容的变量。(define (extend-if-possible var v...

12得票3回答
在Python中实现Prolog Unification算法?回溯

我正在尝试实现统一,但遇到了问题。虽然已经有了许多例子,但它们只是使问题更加混乱。我感到越来越困惑而不是受到启发: http://www.cs.trincoll.edu/~ram/cpsc352/notes/unification.html https://www.doc.ic.ac.uk...

12得票1回答
Hindley-Milner算法:使用类型确保应用了绑定

我正在实现Hindley-Milner类型推断算法,参考了Mark Jones和Oleg Kiselyov的教程。这两个教程都有一个“应用绑定”(apply bindings)操作,其类型大致为:applyBindings :: TyEnv -> Type -> Type 该函数将...

11得票2回答
什么是最优的“最一般统一器”算法?

问题 什么是最高效的MGU算法?它的时间复杂度是多少?它是否简单到足以在Stack Overflow回答中描述? 我一直在Google上寻找答案,但只找到了通过ACM订阅才能访问的私人PDF。 我在SICP中找到了一个讨论: 这里 说明“最一般的统一算法”是什么: e1 = (+ x? (...

10得票2回答
为什么在Prolog中双重否定不会绑定

假设我有以下理论:a(X) :- \+ b(X). b(X) :- \+ c(X). c(a). 它只是简单地说真,这当然是正确的,a(X)是真的,因为没有b(X)(否定作为有限失败)。由于只有在没有c(X) 的情况下才会有一个b(X),并且我们有c(a),因此可以将其说明为真。然而,我想...

9得票3回答
在Haskell中,如何像Prolog一样匹配等价变量的模式?

在Prolog语言中,我们可以像下面这样做: myFunction a (a:xs) = ... 当myFunction的第一个参数与第二个参数中列表的第一个项目相同时,此函数将评估为...。 现在我的问题是...如何在Haskell中实现类似的功能? 我认为Prolog的模式匹配比H...

8得票1回答
在Idris中使用类型谓词生成运行时证明

我正在使用这种类型来推理可进行可决定解析的字符串: data Every : (a -> Type) -> List a -> Type where Nil : {P : a -> Type} -> Every P [] (::) : {P : a -&...

8得票2回答
`coerce` 和类型变量的实例化

考虑以下的GHCi会话: >:set -XTypeApplications >import Data.Map.Strict >import GHC.Exts >newtype MySet a = MySet (Map a ()) >let member' :: ...

7得票2回答
GHC拒绝ST单子代码,无法统一类型变量?

我写了以下函数: (.>=.) :: Num a => STRef s a -> a -> Bool r .>=. x = runST $ do v <- readSTRef r return $ v >= x 但是当我尝试编译时,我得到了以...

7得票6回答
为什么 "map (filter fst)" 的类型是 "[[(Bool, a)]] -> [[(Bool, a)]]"?

I'm trying to understand why the function map (filter fst) 拥有类型 [[(Bool, a)]] -> [[(Bool, a)]] 如果过滤器必须接收一个返回布尔类型的函数,那么“filter fst”如何起作用,而f...