- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Haskell 接受以下类型的定义
data Lam = Func (Lam -> Lam)
打算代表
untyped lambda-terms .例如,Church 的 bool 值就是这种类型
trueChurch :: Lam
trueChurch = Func (\x -> Func (\y -> x))
falseChurch :: Lam
falseChurch = Func (\x -> Func (\y -> y))
构造函数
Func :: (Lam -> Lam) -> Lam
有这个反函数
lamUnfold :: Lam -> (Lam -> Lam)
lamUnfold (Func f) = f
这两个函数定义了
Lam -> Lam
之间的类型同构和
Lam
.当我们查看这些类型的基数(大小)时,这是令人惊讶的。由于上面的 Church bool 值,
Lam
的红衣主教至少为 2,因此
Lam -> Lam
中有更多元素比
Lam -> Bool
.后者是
Lam
的子类型类型,即
Lam
的幂集,并由
Cantor's theorem它已经拥有比
Lam
更多的元素做。
Lam
类型怎么存在不违反康托尔定理?
Lam -> Lam
的元素不会是所有集合论函数(根据康托尔定理,它们大于
Lam
),而只是连续函数。如果是,定义这种连续性的拓扑是什么,为什么是
Lam -> Lam
类型的 Haskell 术语连续换吗?
最佳答案
可能解决悖论的最简单方法是观察并非每个(集合论)函数都可以表示为 lambda 项。
每个有效的 lambda 项都可以通过从最多可数集中选择有限数量的语法产生式并最多应用它们多次来获得。因此,所有 lambda 项的集合是可数集合的可数并集,因此它本身是可数的。0 该论点透明地适用于 Haskell 类型:获得类型 Lam
的项的唯一方法是调用构造函数,并且在任何给定的时间点,即使您的程序没有终止,构造函数也可能只被调用了有限次。因此,在整个执行过程中,程序最多可能会遇到无数个不同的 Lam
值(value)观。在实践中,鉴于计算机内存是有限的,您的程序实际能够操作的术语数量会少一些。
从集合论上讲,没有什么能阻止你将通过掷硬币无数次获得的位串视为有效函数 ℕ → 𝟐:它满足函数的集合论定义,因为它恰好分配了域的每个元素(位串中的位置)的域(掷硬币的结果)。但是考虑到构造这样一个函数需要做出无限多的任意选择1,它没有对应的 lambda 项。
(更正式地说:在 ZFC 的语言中添加一个符号 f,并且对于每个自然数 n,随机选择 'f(n) = 0' 或 'f(n) = 1' 之一作为公理。如果我们选择一个定义 f 的公理的有限子集,显然与 ZFC 一致,存在满足该有限子集的函数。由 compactness theorem ,与 ZFC 一致,存在满足所有公理的函数 f。)
无需调用复杂的概念,如连续性。以上所有内容仅来自对基数本身的考虑,同时注意 lambda 项(以及 Haskell 中的类型项)的来源。
0 如果您从一组不可数的变量符号开始,这在技术上是错误的。但即便如此,您也可以选择一个可数无限的 lambda 项子集,整个集合中的每个 lambda 项都将是 α 等价的。如果您使用 de Bruijn 索引而不是变量符号,该问题也会消失。
1 当然,假设抛硬币确实是不确定的和独立的。
关于haskell - Haskell 中嵌入的无类型 lambda 演算的基数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69338921/
正如标题所说,我需要制作一个函数,在二进制补码中的 2 个碱基、DEC 和 HEX 之间进行转换。该值使用的位数从一开始就已知。 在深入研究之后,我发现了以下算法: 给定一个 DEC 中的数字。 获取
我的用户文档具有以下格式: { userId: "", userAttributes: [ "", "", ... ""
根据这个: Selectivity is the value between 0 and 1, and it is the fraction of rows returned after applyi
这个词有它 FillChar 是用相同值的字节填充内存补丁的最快方法(不是零,因为有 ZeroMemory),但是是否有等效于用相同的序列填充内存(四字节)整数或基数?像 FillInt 或 Fill
我正在努力寻找建模 1 : 0,1 关系的最佳方法(“可能有一个”或“最多有一个”)。我相信这被称为 Z 基数。 例如,假设我有两个类 Widget和 WidgetTest .并非所有 Widget
我使用parseInt找到了一个片段;它用于获取窗口高度。 这是代码: parseInt($(window).height(), 20); 我很困惑为什么使用 20 作为第二个参数。为什么不是 10
要将十进制数转换为基数 2,我使用: int base2 = 10; Convert.ToString(base2, 2); 输出:1010 但是我怎么能做相反的事情呢?即: 输入:1010输出:10
这是一张真实 table 的再现。假设我有这段代码: CREATE TABLE `testTable` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
由于十六进制(基数 16)使用 0-9A-F,并且(我在这里假设)基数 17 使用 0-9A-G,依此类推。什么符号用过一次0-9A-Z都用完了。 最佳答案 你的问题没有标准答案。 “Base 36”
我正在寻找支持 radix 的浏览器列表Number.toString() 中的参数在 JavaScript 中。全部执行toString ,但我找不到他们是否都支持 radix toString 的
这个问题已经有答案了: What is the radix parameter in Java, and how does it work? (6 个回答) 已关闭 5 年前。 public clas
为什么 (73).toString(36) 返回 21 而 (0.73).toString(36) 返回 0。 qa2voha2volfpsnhmyhqia4i 而不是 0.21? 最佳答案 这是因为
我目前正在研究数据库,我看到 degree 和 cardinality 用作相同的术语,或在某些其他学位定义为否。关系中涉及的实体的数量,并进一步分类为一元、二元和三元。 某些放置度数定义为关系类型的
UML(统一建模语言)中的运算符*和运算符0..*有什么区别? 我看到了这两个基数运算符,但是现在我不必使用哪个基数运算符了。 最佳答案 符号“*”是“0 .. *”的快捷方式。在这种情况下使用的正确
我有位于目录“someApp”中的 Angular 应用程序。网址是 http://example-domain/someApp/#/对于一些带有路径的状态 url 是:http://example-
我想一劳永逸地知道如何编写 UML 基数,因为我经常不得不讨论它们(因此非常欢迎证据和来源:) 如果我想解释一下 Mother可以有几个Child任但是 Child有一个而且只有一个 Mother ,
进行字符算术时,规则是以 10 为基数还是以 8 为基数进行计算?我的书上说'A' = 101(基数为8)或65(基数为10),但是当我将基数为8的字符值插入到我的书给出的关于说明这一点的示例中时,我
该程序是将 4 进制数转换为 2 进制数,并且应该就地完成 #include #include void shiftr(char num[],int i) { memmove(num+i,n
这个问题已经有答案了: JavaScript parseInt is giving me wrong number, what I'm doing wrong? [duplicate] (1 个回答)
我遇到了一个小错误,它似乎表明当您传入图像数据作为其源时,在图像完全加载之前调用了 onload 函数。 这是 HTML 这是 JavaScript: var can
我是一名优秀的程序员,十分优秀!