- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
来自 https://ghc.haskell.org/trac/ghc/wiki/DependentHaskell ,
unlike Coq and Agda, Haskell relies on the consistency of a coercion language, which is not threatened by * :: *. See the paper for more details.
最佳答案
Coq 和 Agda 是依赖类型的总语言。它们的灵感来自于它们相关的类型理论基础,其中涉及(类型化的)lambda 演算,它(强)归一化。这意味着减少任何 lambda 项最终必须停止。
这一特性使得使用 Coq 和 Agda 作为证明系统成为可能:人们可以使用它们来证明数学事实。事实上,通过 Curry-Howard 对应关系,如果
someExpression :: someType
someType
对应于逻辑(直觉)重言式。
undefined :: someType
undefined :: Data.Void.Void
,例如对应于逻辑“假”命题。这很糟糕,但这是为无限递归付出的必要代价,它允许非终止程序。
* :: *
到 Coq/Agda 使得逻辑不再一致。我们可以使用 Girard 悖论推导出“错误”的证明。那将是非常糟糕的,因为我们甚至可以证明像
lemma :: Int :~: String
这样的东西。 , 并导出一个强制函数
coerce :: Int -> String
.
lemma :: Int :~: String
lemma = -- exploit Girard's paradox here
-- using Haskell syntax:
coerce :: Int -> String
coerce x = case lemma of Refl -> x
coerce
只会执行不安全的强制转换,重新解释底层位——毕竟,
lemma
证明了这一点。 ,说明这些类型完全一样!这样我们甚至会失去运行时类型的安全性。厄运在等待。
* :: *
无论如何我们都是不一致的,所以我们可以简单地拥有
lemma = undefined
coerce
反正!因此,添加
* :: *
并没有真正增加问题的数量。这只是不一致的另一个来源。
coerce
中那么是类型安全的。好吧,在 Haskell
case lemma of Refl ->...
强制评估
lemma
.这只能触发异常,或者无法终止,所以
...
部分永远达不到。 Haskell 无法优化
coerce
作为一个不安全的 Actor ,不像 Agda/Coq。
case lemma1 of
Refl -> case lemma2 of
Refl -> ...
...
Refl -> expression
expression
确实有所需的类型。在 Coq 中,程序员必须使用复杂的匹配形式(依赖匹配)来证明在何处以及如何利用类型等式。在 Haskell 中,编译器为我们编写了这个证明(在 Coq 中,类型系统更丰富,我认为这将涉及更高阶的统一,这是无法确定的)。这个证明不是用 Haskell 写的!事实上,Haskell 是不一致的,所以我们不能依赖它。相反,Haskell 使用另一种自定义强制语言来保证是一致的。我们只需要依靠它。
trans :: a :~: b -> b :~: c -> a :~: c
trans Refl Refl = Refl
GADTtransitivity.trans
:: forall a_au9 b_aua c_aub.
a_au9 :~: b_aua -> b_aua :~: c_aub -> a_au9 :~: c_aub
[GblId, Arity=2, Caf=NoCafRefs, Str=DmdType]
GADTtransitivity.trans =
\ (@ a_auB)
(@ b_auC)
(@ c_auD)
(ds_dLB :: a_auB :~: b_auC)
(ds1_dLC :: b_auC :~: c_auD) ->
case ds_dLB of _ [Occ=Dead] { Refl cobox0_auF ->
case ds1_dLC of _ [Occ=Dead] { Refl cobox1_auG ->
(Data.Type.Equality.$WRefl @ * @ a_auB)
`cast` ((<a_auB>_N :~: (Sym cobox0_auF ; Sym cobox1_auG))_R
:: ((a_auB :~: a_auB) :: *) ~R# ((a_auB :~: c_auD) :: *))
}
}
cast
最后,它利用了强制语言中的证明
(<a_auB>_N :~: (Sym cobox0_auF ; Sym cobox1_auG))_R
Sym cobox0_auF ; Sym cobox1_auG
我猜它使用对称
Sym
和及物性
;
达到预期目标:
Refl :: a_auB :~: a_auB
的证明确实可以安全地投给通缉
a_auB :~: c_auD
.
cast
最终在运行时减少为不安全的强制转换(
case
仍然评估两个输入证明,以保持类型安全)。但是,拥有中间证明可以有力地确保编译器做的是正确的事情。
关于haskell - 依赖强制语言的一致性是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47742519/
GhostScript PDF/A 生成好像有错误 当您通过 GhostScript 生成 PDF/A 文档时,当您单击 Adobe Reader 时,会出现一个一致性选项卡,其中显示: “一致性
我有一个需要测试的 XPath 引擎实现。 是否有一组标准的一致性测试可以用来验证是否符合 XPath 规范(与 XSLT 相关)。 什么将是完美的 XML 文档 XPath 表达式和预期的结果。 最
帮助我了解在这种情况下我可以期望与 MongoDB 的一致性级别。 我们正在运行一个副本集,其中 Mongoid 中的 consistency 标志设置为 strong,这意味着只读到 master。
假设我有一个采用一个参数的方法。 此参数应满足以下要求: 'of type':方法需要知道参数属于特定类(或子类)。 'implements interface':方法需要知道参数实现了特定的接口(i
当协议(protocol)将属性声明为可选而具体类型将其声明为非可选时,如何使具体类型符合协议(protocol)? 这是问题所在: protocol Track { var trackNum
我正在考虑使用浏览器的 navigator.mimeTypes 数组作为第三级用户/浏览器标识符。例如,当我在 Chrome 上运行时... console.log(navigator.mimeTyp
我有以下协议(protocol): protocol ProtoAInput { func funcA() } protocol ProtoA { var input: ProtoAI
如果选择“最终”一致性,则发生写入的区域内的一致性是什么? 如果我只需要区域强一致性,应该选择哪个选项? 最佳答案 如果您需要在主要区域内进行强读取,则应该选择强一致性或有界过时一致性。 关于azur
您好,我是一名初学者,目前正在尝试学习 java 编程。课本上的问题: 编写一个程序来帮助人们决定是否购买混合动力汽车。你的程序的输入应该是:•新车的成本•预计每年行驶里程•预计汽油价格 •每加仑英里
我正在尝试制作一个可以在 UILabel 上使用的 Swift 协议(protocol), UITextField , 和 UITextView包含他们的text , attributedText ,
我有一个类扩展: extension UICollectionViewCell { class func registerFromNibInCollectionView(collectionV
为了在 Swift 中模拟对象进行测试,我通常遵循这样的模式:编写一个协议(protocol)来描述我想要的对象的行为,然后使用 Cuckoo 为其生成模拟以进行测试。 通常,这些协议(protoco
假设我有两个非通用协议(protocol)(1) protocol StringValue { var asString: String {get} } protocol StringProv
我有一组协议(protocol)可以在 UITableView 中显示一个元素: protocol TableRepresentableRow { var title: String { get
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
用“class”标记 CacheManager 解决了我的问题。 案例:一个简单的缓存器,mutating get 不是我想要的,那么对于引用类型或类类型应该怎么做? protocol Cacher
我想要一个符合协议(protocol)的变量,但是 swift 编译器告诉我协议(protocol)没有确认。 protocol A {} protocol B { var a : A { g
如果我有一个类 Christmas 和一个协议(protocol) Merry,要使 Christmas 符合 Merry,很多人会这样做: class Christmas { ... } e
@objc public protocol P1 { func p1foo() } @objc public protocol P2 { func p2foo() } class A: NSO
我有一些结构符合的基本协议(protocol)(模型)。它们也符合 Hashable protocol Model {} struct Contact: Model, Hashable { v
我是一名优秀的程序员,十分优秀!