- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我发誓曾经有一件T恤出售,上面写着不朽的文字:
<小时/>哪一部分
你不明白吗?
<小时/>就我而言,答案是......全部!
特别是,我经常在 Haskell 论文中看到这样的符号,但我不知道它的含义。我不知道它应该是数学的哪个分支。
我当然认识希腊字母表中的字母和诸如“∉”之类的符号(这通常意味着某物不是集合的元素)。
另一方面,我以前从未见过“⊢”( Wikipedia claims it might mean "partition" )。我也不熟悉这里 vinculum 的使用。 (通常,它表示分数,但这里的情况似乎并非如此。)
如果有人至少能告诉我从哪里开始理解这堆符号的含义,那将会很有帮助。
最佳答案
:
表示有类型ε
表示在。 (同样,∉
表示“不在”。)Γ
通常用于指代环境或上下文;在这种情况下,它可以被认为是一组类型注释,将标识符与其类型配对。因此,x : σ ∈ Γ
意味着环境 Γ
包含 x
具有类型 σ
的事实。<⊢
可以理解为证明或确定。 Γ ⊢ x : σ
表示环境 Γ
确定 x
的类型为 σ
。,
是一种将特定的附加假设包含到环境Г
中的方法。Г, x : τ ⊢ e : τ'
表示环境 Г
, 以及附加的、压倒一切的假设,即 x
具有类型 τ
,证明 e
具有类型 τ'
。根据要求:运算符优先级,从最高到最低:
λ x 。 e
, ∀ α 。 σ
,以及 τ → τ'
,let x = e0 in e1
,以及用于函数应用的空白。:
ε
和 ∉
,
(左关联)⊢
关于haskell - Hindley-Milner 的哪一部分是你不明白的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12532552/
我发誓曾经有一件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有种* -> * (即它是一个未知类型的构造函数)。因此,
let a = b in c可以被认为是 (\a -> c) b 的语法糖。 ,但在一般的打字设置中,情况并非如此。例如,在米尔纳微积分 let a = \x -> x in (a True, a 1
我正在制作一种强类型玩具函数式编程语言。它使用 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
Hindley-Milner 是一个类型系统,它是许多众所周知的函数式编程语言的类型系统的基础。 Damas-Milner 是一种在 Hindley-Milner 类型系统中推断(推导出?)类型的算法
有人曾经在 SML 中向我展示了一个小技巧,他们在他们的 REPL 中写出了大约 3 或 4 个函数,最后一个值的结果类型非常长(就像许多页面滚动很长)。 有谁知道什么代码会生成这么长的类型,或者是否
我是一名优秀的程序员,十分优秀!