- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
考虑以下程序(在 Haskell 中,但可以是任何 HM 推断的语言):
x = []
y = x!!0
使用 HM(或通过运行编译器),我们推断:
x :: forall t. [t]
y :: forall a. a
我理解这是如何发生的,按照通常的泛化/实例化规则进行游戏,但我不确定是否需要像 forall a.一个
。
一个问题是:因为我们在这里有越界访问,所以可以排除该程序作为有效示例。相反,我们可以说我们推断出的通用类型是程序错误的标志吗?如果是,我们是否也可以使用这个“事实”在其他情况下故意不检查无效程序?
下一个程序有更奇怪的类型:
c = []
d = (c!!0) + (1 :: Int)
推断类型:
c :: forall t. [t]
d :: Int
...尽管 d
是从 c
中提取的!
我们能否在不排除有效程序的情况下增强 HM 以在此处做得更好?
编辑:我怀疑编辑这是使用部分函数的产物(在本例中为!!0
)。但是请看:
c = []
d = case c of [] -> 0; (x:_) -> x + (1 :: Int)
现在没有使用偏函数。然而,c::forall t。 [t]
和 d::Int
。
最佳答案
术语的 Hindley-Milner 类型不取决于其子术语的值,仅取决于它们的类型。 HM 类型检查器永远不会评估表达式,只会对它们进行类型检查,因此它会将您的 x
视为“a
的列表”,而不是“空列表” a
”,就像人类在对您的程序进行非正式类型检查时所做的那样。
有些类型系统会将您的程序标记为类型不正确,例如dependent types ,但是如果没有显式类型声明,它们就没有类型推断,这是 Haskell/ML 程序员享受的奢侈品之一,感谢 HM。
使用 HM 的扩展(GADTs)Haskell 可以为“安全列表”定义一个类型
data Empty
data NonEmpty
data SafeList a b where
Nil :: SafeList a Empty
Cons:: a -> SafeList a b -> SafeList a NonEmpty
(!!) :: SafeList a NonEmpty -> Int -> a
-- etc
这会使 Nil!!0
成为类型错误。
关于haskell - Hindley-Milner 概括变坏了吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27587759/
我发誓曾经有一件T恤出售,上面写着不朽的文字: 哪一部分 你不明白吗? 就我而言,答案是......全部! 特别是,我经常在 Haskell 论文中看到这样的符号,但我不知道它的含义。我不知道它应该是
考虑以下程序(在 Haskell 中,但可以是任何 HM 推断的语言): x = [] y = x!!0 使用 HM(或通过运行编译器),我们推断: x :: forall t. [t] y :: f
在 Haskell 中,我们可以编写以下数据类型: data Fix f = Fix { unFix :: f (Fix f) } 类型变量f有种* -> * (即它是一个未知类型的构造函数)。因此,
我正在制作一种强类型玩具函数式编程语言。它使用 Hindley Milner 算法作为类型推断算法。 实现算法时,我有一个问题是如何推断相互递归函数的类型。 let rec f n = if n ==
我正在阅读关于 Hindley–Milner Type Inference 的维基百科文章试图从中找出一些道理。到目前为止,这是我所理解的: 类型分为单型或多型。 Monotype 进一步分类为类型常
我试图推断以下表达式的类型: let rec fix f = f (fix f) 应指定类型(a -> a) -> a 使用自下而上算法(在概括hindley-milner类型推理算法中描述)并添加以
我正在寻找关于著名 Damas-Hindley-Milner algorithm 的信息为函数式语言进行类型推断,尤其是关于实现的信息。 我已经知道如何执行 Algorithm W ,但我听说最近的新
当存在重载函数时,Hindley-Milner 算法如何工作? 以简单的形式(没有重载),它看起来很干净: y = arr[x1] //it's Generic. x1: int, arr: T[],
我正在尝试通过用我常用的语言 Clojure 实现算法 W 来自学 Hindley-Milner 类型推理。我遇到了 let 推理的问题,我不确定我是否做错了什么,或者我期望的结果是否需要算法之外的东
如果我正确理解 Haskell 中的 ST monad,runST 以巧妙的方式使用 2 级类型,以确保计算在转义 monad 时不会引用任何其他线程。 我有一种带有 Hindley-Milner 类
我正在尝试通过用我常用的语言 Clojure 实现算法 W 来自学 Hindley-Milner 类型推理。我遇到了 let 推理的问题,我不确定我是否做错了什么,或者我期望的结果是否需要算法之外的东
我读到 Rust 使用 Hindley-Milner 有很好的类型推断。 Rust 也有可变变量,据我所知,当 HM 算法处理可变性时必须有一些约束,因为它可能过度泛化。以下代码: let mut a
我正在开发一个用 Java 编写的基于数据流的简单系统(想象它就像一个 LabView 编辑器/运行时)。用户可以在编辑器中将 block 连接在一起,我需要类型推断来确保数据流图是正确的,然而,大多
我无法理解维基百科上给出的 HM 系统的 letrec 定义,这里:https://en.wikipedia.org/wiki/Hindley%E2%80%93Milner_type_system#R
下'What is Hindley Milner'它指出: Hindley-Milner is a restriction of System F, which allows more types b
PyPy 是否在编译时进行静态类型检查以在编译时捕获类型错误?如果不是,像 HM 类型推断这样的东西是否有助于在编译时捕获这些错误? 最佳答案 否 在两个帐户上。 (我假设 PyPy 是指具有 JIT
我最近一直在学习 λ 演算。我理解无类型和有类型 λ 演算之间的区别。但是,我不太清楚 之间的区别。 Hindley-Milner 型系统 和 类型化 λ 演算 .是关于parametric poly
有人曾经在 SML 中向我展示了一个小技巧,他们在他们的 REPL 中写出了大约 3 或 4 个函数,最后一个值的结果类型非常长(就像许多页面滚动很长)。 有谁知道什么代码会生成这么长的类型,或者是否
以下对 compose 函数的 Hindley-Milner 类型签名的尝试是否正确? // compose :: (f -> [f]) -> (f -> f -> f) -> [f] -> f co
我正在按照 Mark Jones 的教程实现 Hindley-Milner 类型推理算法和 Oleg Kiselyov .这两个都有一个“应用绑定(bind)”操作,其类型大致为 applyBindi
我是一名优秀的程序员,十分优秀!