构造演算
构造演算(CoC)是高阶有类型 lambda 演算,这里的类型是一级值。因此在 CoC 内有可能定义从整数到类型、从类型到类型的函数,同从整数到整数的函数一样。CoC 是强规范化的。
CoC 最初由 Thierry Coquand 开发。
CoC 是 Coq 定理证明器早期版本的基础;它后来的版本建造在归纳构造演算之上,这是带有对归纳数据类型的天然支持的 CoC 扩展。在最初的 CoC 中,归纳数据类型必须模拟为它们的多态解构函数。
构造演算的基础
构造演算可以被当作 Curry-Howard同构的扩展。Curry-Howard 同构把在简单类型 lambda 演算中项关联上在直觉命题逻辑中自然演绎证明。构造演算扩展了这个同构为在完全的直觉谓词逻辑中的证明,这包括了量化陈述(它也叫做"命题")的证明。
项
在构造演算中项使用如下规则构造:
- T 是项(也叫做类型)
- P 是项(也叫做命题,所有命题的类型)
- 变量
是项 - 如果
和
是项,则如下也是项
data:image/s3,"s3://crabby-images/32f62/32f6214d3529274677de52e364a385b107ab06e7" alt="{\displaystyle \mathbf {(} AB)}"
- (
) - (
)
构造演算有 5 种对象类型:
- 证明,它是其类型都是命题的那些项
- 命题,也叫做小类型
- 谓词,它是返回命题的函数
- 大类型,它是谓词的类型。(P 是大类型的例子)
- T 自身,它是大类型的类型。
判断
在构造演算中,判断是类型推理:
data:image/s3,"s3://crabby-images/87c3b/87c3b03e4155fa86d133fe4280adb315046c2ef8" alt="{\displaystyle x_{1}:A_{1},x_{2}:A_{2},\ldots \vdash t:B}"
它可以被读作蕴涵
- 如果变量
分别有类型
,则项
有类型
。
构造演算的有效判断是从推理规则集合可推导的。在下面,我们使用
来指示类型指派的序列
,并使用 K 来指示要么 P 要么 T。我们将写
来指示“
有类型
,和
有类型
”。我们将写
来指示用项
代换在项
中变量
的结果。
推理规则用如下形式写成
data:image/s3,"s3://crabby-images/34983/34983d6e88386e1358a7ccf302099e4e8745f09e" alt="{\displaystyle {\Gamma \vdash A:B} \over {\Gamma '\vdash C:D}"
它指示着
- 如果
是有效判断,则
也是。
构造演算的推理规则
data:image/s3,"s3://crabby-images/6ae63/6ae63bfdd3fbc0b17537b38bd546a7af428c50e8" alt="{\displaystyle {} \over {}\vdash P:T}"
data:image/s3,"s3://crabby-images/5a019/5a01980fb8212f99396cdf917d20571395be4058" alt="{\displaystyle {\Gamma \vdash A:K \over {\Gamma ,x:A\vdash x:A}"
data:image/s3,"s3://crabby-images/5fcd6/5fcd64df0cc932c5e8c7c7c99aaa071751c8d7c4" alt="{\displaystyle {\Gamma ,x:A\vdash t:B:K \over {\Gamma \vdash (\lambda x:A.t):(\forall x:A.B):K}"
data:image/s3,"s3://crabby-images/abf61/abf618b2eab425d5b19130984158525869681f8d" alt="{\displaystyle {\Gamma \vdash M:(\forall x:A.B)\qquad \qquad \Gamma \vdash N:A \over {\Gamma \vdash MN:B(x:=N)}"
定义逻辑运算
构造演算在引入基本算子的时候是非常简约的:唯一形成命题的逻辑算子是
。但是,这个唯一的算子足够定义所有其他逻辑算子:
data:image/s3,"s3://crabby-images/dbae8/dbae80cc9af4a8e39a41ebe5ceaaed5ed227245a" alt="{\displaystyle {\begin{matrix}A\Rightarrow B&\equiv &\forall x:A.B&(x\notin B)\\A\wedge B&\equiv &\forall C:P.(A\Rightarrow B\Rightarrow C)\Rightarrow C&\\A\vee B&\equiv &\forall C:P.(A\Rightarrow C)\Rightarrow (B\Rightarrow C)\Rightarrow C&\\\neg A&\equiv &\forall C:P.(A\Rightarrow C)&\\\exists x:A.B&\equiv &\forall C:P.(\forall x:A.(B\Rightarrow C))\Rightarrow C&\end{matrix}"
定义数据类型
在构造演算中可以定义计算机科学中使用的基本数据类型:
- 布尔
data:image/s3,"s3://crabby-images/a5781/a57812bb196e49648c400dd24e001999bc836069" alt="{\displaystyle \forall A:P.A\Rightarrow A\Rightarrow A}"
- 自然数
data:image/s3,"s3://crabby-images/0f03c/0f03ca30c431f29b47b7fe4cd31308cfda521a7c" alt="{\displaystyle \forall A:P.(A\Rightarrow A)\Rightarrow (A\Rightarrow A)}"
- 乘积
data:image/s3,"s3://crabby-images/7599f/7599f71e0c2e92780a2389a45387a7a6a2f2de7b" alt="{\displaystyle A\times B}"
data:image/s3,"s3://crabby-images/a656a/a656aa98f20043ceb491aaea41bc224b85917eb5" alt="{\displaystyle A\wedge B}"
- 不交并
data:image/s3,"s3://crabby-images/942d0/942d01796ca3b28884117e28dde84f6ef9514ee9" alt="{\displaystyle A+B}"
data:image/s3,"s3://crabby-images/0d253/0d2535c61aa8a25aae2923977f7b33dda4a8cfc0" alt="{\displaystyle A\vee B}"
参见
引用