- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Haskell 中,我们可以编写以下数据类型:
data Fix f = Fix { unFix :: f (Fix f) }
f
有种
* -> *
(即它是一个未知类型的构造函数)。因此,
Fix
有种
(* -> *) -> *
.我想知道是否
Fix
是 Hindley Milner 类型系统中的有效类型构造函数。
Fix
不是 Hindley Milner 类型系统中的有效类型构造函数,因为 HM 中的所有类型变量都必须是具体的(即必须具有类型
*
)。真的是这样吗?如果 HM 中的类型变量并不总是具体的,那么 HM 会变得不可判定吗?
最佳答案
重要的是类型构造函数是形成一阶术语语言(没有类型构造函数表达式的归约行为)还是高阶语言(在类型级别具有 lambda 或类似构造)。
在前一种情况下,Fix
产生的约束总是以最一般的方式统一(假设我们坚持 HM)。在每个 c a b ~ t
方程,t
必须解析为与 c a b
形状相同的具体类型应用程序表达式, 自 c a b
不可能简化为其他表达方式。更高种类的参数不是问题,因为它们也只是以静态方式坐在那里,例如 c [] ~ c f
由 f = []
解决.
在后一种情况下,c a b ~ t
可能或可能无法解决。在某些情况下,它可以通过 c = \a b -> t
解决,在其他情况下,没有最通用的统一符。
关于haskell - 我们可以在 Hindley Milner 类型系统的构造函数位置有类型变量吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37064353/
我发誓曾经有一件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
我是一名优秀的程序员,十分优秀!