Curry-Howard同构讲义 前言 Curry-Howard同构, 也被称为"命题作为类型"范式, 陈述了形式逻辑系统与计算性演算之间惊人的联系. 它自这样的观察开始, 一个推论A → B 与一类从A 到B 的函数有关 [译注: 这里强调的是一个推论和一类有关, 一类也就是一个类型], 因为从A → B 和A 推出B 可以被视为将第一个假设应用于第二个, 正如将一个从A 到B 的函数应用于A 的一个元素产生B 的一个元素. 类似地, 可以说通过实际从B 推出A 来证明推论A → B 就像构造一个函数, 其将定义域A 的任意元素都映射至B 的元素.
实际上, 这是一个很老的想法了, 应该归功于Brouwer, Kolmogorov和Heyting, 即从A 到B 的推论的一个构造性证明, 是一个将A 的证明变换为B 的证明的过程. Curry-Howard同构形式化了这个想法, 例如命题直觉主义逻辑中的证明可以被表示为简单类型λ 项. 可证明的定理不外乎是非空类型.
这种类比, 最初由Haskell Brooks Curry于1930年代发现, 也适用于其他的逻辑系统. 似乎所有和证明相关的概念都可以基于计算来解释, 而各种lambda演算和相近系统的一切句法特征都可以用证明论的语言来陈述. 例如, 谓词逻辑中的量化对应于依赖积, 二阶逻辑与多态有关, 而古典逻辑中的反证法是控制运算符 (例如异常) 的近亲. 而且, 各种逻辑形式化 (Hilbert风格, 自然演绎, 相继式演算) 可由相对应的计算模型 (组合子逻辑, λ 演算, 显式替换演算) 来模拟.
自William Howard的1969年的工作起人们理解到这种命题作为类型的对应不仅仅是意外得来的珍品, 而且是一种根本性的原理. 证明正规化和切消是另一种计算的模型, 等价于β 规约. 证明论和计算理论不过是一体两面而已.
第1章 无类型λ 演算 λ 演算是一种计算的模型, 它在另一种这样的模型Turing机器出现数年之前被发明出来. 对于后者而言, 计算被表达为读写纸带, 以及根据纸带的内容施行操作. Turing机器就像命令式语言 (比如Java或C) 的程序. 与之相对地, 在λ 演算中, 人们关心函数, 而函数可以将函数作为参数, 以及返回函数作为结果. 用编程的术语来说, λ 演算是一个极其简单的高阶函数式编程语言. 本章我们只讨论无类型λ 演算, 之后我们将引入诸多变体, 其中λ 项被归为各种类型.
第1.1节 温和的引入 在λ 演算之中计算以λ 项表达. 它们类似于数学中使用的匿名函数记号n ↦ n 2 . 然而, 数学家使用这样的记号来指称作为数学对象的函数 (被定义为序对的集合). 与之相对地, λ 项是形式表达式 (字符串), 从直觉上说, 以最纯粹的形式表达了函数和函数的应用. 因此, 一个λ 项是如下形式之一:
一个变量; 一个抽象λ x . M , 其中x 是一个变量, M 是一个λ 项; 一个应用M ⁡ N (M 应用于N ), 其中M 和N 是λ 项. 在一个抽象λ x . M 中, 变量x 代表函数参数 (或者说形式参数), 它可能出现在函数的体M 之中, 但不必总是如此. 在一个应用M ⁡ N 之中, 运算符M 和参数N 的形状没有限制, 它们都可以是任意的λ 项.举个例子, λ 项I = λ x . x 从直觉上表示了一个将任意的参数映射至自身的函数, 即恒等函数. 再举一个, K = λ x λ y x 代表了这样的一个函数, 其将任意的参数x 映射至总是返回x 的常函数. 最后一个例子, I ⁡ K 表达了将函数I 应用于参数K .
在数学中, 我们通常将函数应用的参数写在括号里, 例如若函数是f , 参数是4 , 那么就记成f ⁡ ( 4 ) . 在λ 演算中, 我们则会将其记成f ⁡ 4 . 尽管如此, 括号的运用并不能被完全消除. 例如, 记号λ x x y 是有歧义的. 如果我们想要表达的是将I 应用于y , 那么就应该写成( λ x x ) ⁡ y . 或者, 可以用λ x ( x ⁡ y ) 来表示一个x 上的抽象, 其体为x ⁡ y . 后一种情况下, 按照惯例是使用点记号的, 即写作λ x . x ⁡ y . 类似地, 我们也需要使用括号来消除应用的歧义. 例如, I ⁡ ( K ⁡ K ) 表达了将I 应用于K ⁡ K .
如果λ x M 代表一个函数, N 代表一个参数, 那么应用( λ x M ) ⁡ N 的"值"可以通过将M 中的x 替换为N 计算得到. 这样一个替换的结果以M [ x ≔ N ] 表示, 而我们可以用β 规约规则来形式化这个计算: ( λ x M ) ⁡ N → β M [ x ≔ N ] . 例如,( I ⁡ K ) ⁡ z = ( ( λ x x ) ⁡ K ) ⁡ z → β x [ x ≔ K ] ⁡ z = K ⁡ z = ( λ y λ x y ) ⁡ z → β λ x z . 这个计算表达式的值的过程与通常的数学实践是类似的. 如果f ⁡ ( n ) = n 2 , 那么f ⁡ ( 4 ) = 4 2 , 并且我们是通过在f 定义的体中将n 替换为4 从应用f ⁡ ( 4 ) 得到结果4 2 的. 编程语言上的类比即按名调用的参数传递机制, 其中过程的形式参数被全部替换以实际的参数表达式.
一个λ 抽象λ x M 中的变量x 在M 中被绑定 (或者说局部于), 就非常类似于一个过程的形式参数被认为局部于该过程. 与之相对的是, 一个变量y , 若没有与其对应的抽象, 则被称为自由的 (或者全局的), 这就类似于大多数编程语言中的全局变量. 因此, 在λ x . x ⁡ y 之中, x 是绑定的, 而y 是自由的.
当绑定变量和自由变量重名时会引起一些混乱. 例如, 在x ⁡ ( λ x . x ⁡ y ) 中, 显然有两个不同的x : 自由的 (全局的) x 和绑定的 (局部的) x , 绑定的x "遮住了"体内自由的x . [译注: 换言之, 若体内的x 没有λ 绑定的包裹, 则会是一个自由变量.] 若我们转而考虑λ 项x ⁡ ( λ z . z ⁡ y ) , 那就没有歧义了. 再举另外一种引起混乱的例子, ( λ x . x ⁡ y ) [ y ≔ x ] 应该将( λ x . x ⁡ y ) 中的y 替换为自由变量x , 但是λ x . x ⁡ x 并非预期的结果. 在后一个项中, 我们失去了形式参数x 和自由变量x 之间的区别 (自由变量已被lambda捕获). 如果我们使用一个绑定变量z , 那么混乱就消失了: ( λ z . z ⁡ y ) [ y ≔ x ] = λ z . z ⁡ x .
过程的局部变量总可以被换名而不影响程序的含义. 类似地, 在λ 演算中我们也不在乎绑定变量的名字. λ 项λ x x 和λ y y 都代表着恒等函数. 正因如此, 通常假定只有绑定变量不同的项是等同的. 这给了我们选取绑定变量以避免混乱 (比如说变量捕获) 的自由.
第1.2节 预项和λ 项 现在我们定义预项的概念, 并将λ 项作为预项的等价类引入. 本节相当乏味, 但对于使得我们的形式化精确而言是必要的. 然而, 为了理解本书的大部分内容, 前一节对于λ 项的非形式化理解就足够了.
1.2.1. 定义. 令
Υ 代表一个可数无穷的符号集合, 之后就将其称为变量 (当其他种类的变量可能造成歧义的时候, 也将其称为对象变量或者
λ 变量). 我们通过归纳定义预项的概念如下:
每个变量都是一个预项. 如果M , N 是预项, 那么( M ⁡ N ) 也是一个预项. 如果x 是一个变量而M 是一个预项, 那么( λ x M ) 也是一个预项. 所有预项构成的集合记作
Λ − .
预项, 正如上面所定义的那样, 是完全括号化的. 如预项( λ f ( ( λ u ( f ⁡ ( u ⁡ u ) ) ) ⁡ ( λ v ( f ⁡ ( v ⁡ v ) ) ) ) ) 所呈现的, 括号的重度使用是相当笨拙的. 因此, 我们引入一些记号上的约定, 每当不致引起歧义时我们非正式地使用它们.
1.2.2. 约定. 一个项最外部的括号被省略. 应用向左结合: ( ( P ⁡ Q ) ⁡ R ) 被缩略为( P ⁡ Q ⁡ R ) . 抽象向右结合: ( λ x ( λ y P ) ) 被缩略为( λ x λ y P ) . 一个抽象的序列( λ x 1 ( λ x 2 … ( λ x n P ) … ) ) 可以被记成( λ x 1 x 2 … x n . P ) , 在这种情形之下P 最外面的括号 (如果有的话) 通常被省略. [原注: 这个点代表了一个辖域尽可能向右延伸的左括号.] 例子. 根据i, ( λ v ( v ⁡ v ) ) 可以被缩略为λ v ( v ⁡ v ) . 根据i和ii, ( ( ( λ x x ) ⁡ ( λ y y ) ) ⁡ ( λ z z ) ) 可以被缩略为( λ x x ) ⁡ ( λ y y ) ⁡ ( λ z z ) . 根据i和iii, ( λ x ( λ y ( x ⁡ y ) ) ) 被记为λ x λ y ( x ⁡ y ) , 或者根据i和iv记作λ x y . x ⁡ y . ( λ f ( ( λ u ( f ⁡ ( u ⁡ u ) ) ) ⁡ ( λ v ( f ⁡ ( v ⁡ v ) ) ) ) ) 记作λ f . ( λ u . f ⁡ ( u ⁡ u ) ) ⁡ ( λ v . f ⁡ ( v ⁡ v ) ) .1.2.3. 定义. 定义M 的自由变量的集合FV ⁡ ( M ) 如下.FV ⁡ ( x ) = { x } ; FV ⁡ ( λ x P ) = FV ⁡ ( P ) − { x } ; FV ⁡ ( P ⁡ Q ) = FV ⁡ ( P ) ∪ FV ⁡ ( Q ) .
例子. 令x , y , z 是不同的变量, 那么FV ⁡ ( ( λ x x ) ⁡ ( λ y . x ⁡ y ⁡ z ) ) = { x , z } . 这里有两种x 的出现: 一个在λ x 下, 一个在λ y 下. M 中一个x 的出现被称为绑定的, 如果它在形状为λ x L 的M 的一部分中, 反之则被称为自由的. 于是, x ∈ FV ⁡ ( M ) 当且仅当M 中存在x 的一个自由出现.
1.2.4. 定义. 将M 中的x 替换为N , 记作M [ x ≔ N ] , 是有定义的当且仅当不存在M 中x 的自由出现满足其在形式为λ y L 的M 的一部分中, 并且y ∈ FV ⁡ ( N ) . [译注: 直觉就是N 中的自由变量不能被y 捕获.] 在这样的情况下, M [ x ≔ N ] 由下列等式给出:x [ x ≔ N ] = N ; y [ x ≔ N ] = y , 如果 x ≠ y ; ( P ⁡ Q ) [ x ≔ N ] = P [ x ≔ N ] ⁡ Q [ x ≔ N ] ; ( λ x P ) [ x ≔ N ] = λ x P ; ( λ y P ) [ x ≔ N ] = λ y P [ x ≔ N ] , 如果 x ≠ y . [原注: 在我们的元记号中, 替换绑定得比其他任何东西都要强, 所以说在第三行, 最右边的替换是应用于Q 的, 而不是应用于P [ x ≔ N ] ⁡ Q 的. (译注: 补充说一句, 真要是后一种情况, 那这个定义是否良定都很可疑了, 因为P [ x ≔ N ] ⁡ Q 不比P ⁡ Q 小.)] [译注: 读者应该注意到在这个定义里, 如果( P ⁡ Q ) [ x ≔ N ] 有定义, 那么P [ x ≔ N ] 和Q [ x ≔ N ] 也就有定义, 并且如果( λ y P ) [ x ≔ N ] 有定义, 其中x ≠ y , 那么P [ x ≔ N ] 也就有定义. 否则的话, 替换就不是良定的了.]
1.2.5. 引理. 如果x ∉ FV ⁡ ( M ) , 那么M [ x ≔ N ] 有定义, 并且M [ x ≔ N ] = M . 如果M [ x ≔ N ] 有定义, 那么y ∈ FV ⁡ ( M [ x ≔ N ] ) 当且仅当要么y ∈ FV ⁡ ( M ) 且x ≠ y , 要么y ∈ FV ⁡ ( N ) 且x ∈ FV ⁡ ( M ) . 替换M [ x ≔ x ] 有定义, 且M [ x ≔ x ] = M . 如果M [ x ≔ y ] 有定义, 那么M [ x ≔ y ] 与M 拥有相同的长度. 证明. 在
M 上施行归纳. 作为例子, 我们细致地证明i. 显然
M [ x ≔ N ] 是有定义的. 为了证明
M [ x ≔ N ] = M 我们考虑以下情形. 如果
M 是一个变量
y , 那么必有
y ≠ x , 并且
y [ x ≔ N ] = y . 如果
M = P ⁡ Q , 那么
x ∉ FV ⁡ ( P ) 且
x ∉ FV ⁡ ( Q ) , 于是根据归纳假设有
P [ x ≔ N ] = P 且
Q [ x ≔ N ] = Q , 因此
( P ⁡ Q ) [ x ≔ N ] = P [ x ≔ N ] ⁡ Q [ x ≔ N ] = P ⁡ Q . 最后, 如果
M 是一个抽象, 要么
M = λ x P 要么
M = λ y P , 其中
x ≠ y . 在前一种情况下,
( λ x P ) [ x ≔ N ] = λ x P . 在后一种情况下, 我们有
x ∉ FV ⁡ ( P ) , 于是根据归纳假设,
( λ y P ) [ x ≔ N ] = λ y P [ x ≔ N ] = λ y P .
◻
1.2.6. 引理. 假定M [ x ≔ N ] 是有定义的, 并且N [ y ≔ L ] 和M [ x ≔ N ] [ y ≔ L ] 也都是有定义的, 其中x ≠ y . 如果x ∉ FV ⁡ ( L ) 或者y ∉ FV ⁡ ( M ) , 那么M [ y ≔ L ] 是有定义的, M [ y ≔ L ] [ x ≔ N [ y ≔ L ] ] 也是有定义的, 并且M [ x ≔ N ] [ y ≔ L ] = M [ y ≔ L ] [ x ≔ N [ y ≔ L ] ] .
1.2.7. 引理.
1.2.8. 定义. 关系
= α (
α 变换) 是
Λ − 上满足下列条件的最小的传递自反关系:
如果y ∉ FV ⁡ ( M ) 并且M [ x ≔ y ] 有定义, 那么λ x M = α λ y . M [ x ≔ y ] . 如果M = α N , 那么对于所有的变量x , λ x M = α λ x N . 如果M = α N , 那么M ⁡ Z = α N ⁡ Z . 如果M = α N , 那么Z ⁡ M = α Z ⁡ N . [译注: 后三条是在说
= α 是一个兼容关系.]
例子. 令x , y 是不同的变量, 那么λ x y . x ⁡ y = α λ y x . y ⁡ x , 但是λ x . x ⁡ y ≠ α λ y . y ⁡ x .
1.2.9. 引理. α 变换的关系是一个等价关系.
1.2.10. 引理. 如果M = α N , 那么FV ⁡ ( M ) = FV ⁡ ( N ) .
定义1.2.14. 定义λ 项的集合Λ 为= α 的商集:Λ = { [ M ] α | M ∈ Λ − } , 其中[ M ] α = { N ∈ Λ − | M = α N } .
例子.
定义1.2.15. 一个λ 项M 的自由变量FV ⁡ ( M ) 定义如下. 令M = [ M ′ ] α , 那么FV ⁡ ( M ) = FV ⁡ ( M ′ ) . 如果FV ⁡ ( M ) = ∅ , 那么就称M 是封闭的或者它是一个组合子. 引理1.2.10确保了任何对于M ′ 的选择都会产生相同的结果.
定义1.2.16.
记号1.2.17.
引理1.2.18. 以下等式是合理的:FV ⁡ ( x ) = { x } ; FV ⁡ ( λ x P ) = FV ⁡ ( P ) − { x } ; FV ⁡ ( P ⁡ Q ) = FV ⁡ ( P ) ∪ FV ⁡ ( Q ) .
引理1.2.19.
引理1.2.20.
定义1.2.21.
第1.3节 规约 1.3.1. 定义. 一个
Λ 上的关系
≻ 是兼容的当且仅当它对于所有的
M , N , Z ∈ Λ 满足下列条件.
对于所有的变量x , 如果M ≻ N , 那么λ x . M ≻ λ x . N . 如果M ≻ N , 那么M ⁡ Z ≻ N ⁡ Z . 如果M ≻ N , 那么Z ⁡ M ≻ Z ⁡ N . [译注: 兼容的直觉就是上下文中的关系.]
1.3.2. 定义. Λ 上满足( λ x . P ) ⁡ Q → β P [ x ≔ Q ] 的最小兼容关系→ β 被称为β 规约. 具有形式( λ x P ) ⁡ Q 的项被称为β 可规约项, 而P [ x ≔ Q ] 被称为是由收缩这个可规约项产生的. 一个项M 是β 规范形式 (记号M ∈ NF β ) 当且仅当不存在这样的N 满足M → β N , 即M 并不包含一个β 可规约项.
1.3.3. 定义. 关系↠ β (多步β 规约) 是→ β 的传递且自反闭包. → β 的传递闭包记作→ β + . 关系= β (被称为β 等价或者β 变换) 是包含→ β 的最小等价关系. 一个β 规约序列是一个有限或无限的序列M 0 → β M 1 → β M 2 → β ⋯ 例子1.3.5. ( λ x . x ⁡ x ) ⁡ ( λ z z ) → β ( x ⁡ x ) [ x ≔ λ z z ] = ( λ z z ) ⁡ ( λ y y ) .( λ z z ) ⁡ ( λ y y ) → β z [ z ≔ λ y y ] = λ y y .( λ x . x ⁡ x ) ⁡ ( λ z z ) ↠ β λ y y .( λ x x ) ⁡ y ⁡ z = β y ⁡ ( ( λ x x ) ⁡ z ) .例子1.3.6. (一些常见的λ 项). 令I = λ x x , K = λ x y . x 以及S = λ x y z . x ⁡ z ⁡ ( y ⁡ z ) , 那么S ⁡ K ⁡ K ↠ β I . 令ω = λ x . x ⁡ x 以及Ω = ω ⁡ ω , 那么Ω → β Ω → β Ω → β ⋯ . 令Y = λ f . ( λ x . f ⁡ ( x ⁡ x ) ) ⁡ ( λ x . f ⁡ ( x ⁡ x ) ) , 那么Y → β Y ′ → β Y ″ → β ⋯ , 其中Y , Y ′ , Y ″ , ⋯ 各不相同. 定义1.3.9.
命题1.3.10. 令
= ext 是满足下列条件的最小关系:
如果M = β N , 那么M = ext N ; 如果M ⁡ x = ext N ⁡ x 且x ∉ FV ⁡ ( M ) ∪ FV ⁡ ( N ) , 那么M = ext N ; 如果P = ext Q , 那么P ⁡ Z = ext Q ⁡ Z 且Z ⁡ P = ext Q ⁡ P . 那么,
M = ext N 当且仅当
M = β η N . [译注:
= ext 即所谓的外延相等的概念.]
引理1.3.11.
第1.4节 Church-Rosser定理 既然一个λ 项M 可能包含数个β 可规约项, 那么可能存在多个N 满足M → β N . 例如, K ⁡ ( I ⁡ I ) → β λ x . I ⁡ I 和K ⁡ ( I ⁡ I ) → β K ⁡ I .
定义1.4.1. 令
⇒ β 是满足下列条件的
Λ 上的最小关系:
对于所有变量x , x ⇒ β x . 如果P ⇒ β Q , 那么λ x . P ⇒ β λ x . Q . 如果P 1 ⇒ β Q 1 且P 2 ⇒ β Q 2 , 那么P 1 ⁡ P 2 ⇒ β Q 1 ⁡ Q 2 . 如果P 1 ⇒ β Q 1 且P 2 ⇒ β Q 2 , 那么( λ x . P 1 ) ⁡ P 2 ⇒ β Q 1 [ x ≔ Q 2 ] . 引理1.4.2. 如果M → β N , 那么M ⇒ β N . 定义1.4.3. 令M ⁎ (M 的complete development) 定义为:x ⁎ = x ; ( λ x M ) ⁎ = λ x M ⁎ ; ( M ⁡ N ) ⁎ = M ⁎ ⁡ N ⁎ , 如果 M 不是一个抽象; ( ( λ x M ) ⁡ N ) ⁎ = M ⁎ [ x ≔ N ⁎ ] .
第1.5节 最左规约是正规化 定义1.5.1. 一个项M 是正规化的 (记号M ∈ WN β ) 当且仅当存在一个从M 开始的规约序列终于正规形式N , 那么我们称M 有正规形式N . 一个项M 是强正规化的 (M ∈ SN β 或者仅仅M ∈ SN ) 如果从M 开始的规约序列都是有限的. 如果M ∉ SN β , 那么我们记M ∈ ∞ β . 类似的记号也用于其他规约概念.
任何强正规化的项也是正规化的, 反之则不然, 如K ⁡ I ⁡ Ω . 但是, 定理1.5.8陈述了一个正规形式, 如果存在的话, 总是可由重复规约最左可规约项得到, 最左可规约项即其λ 向左走得最远的可规约项. 以下记号和定义对于证明定理1.5.8而言是方便的.
向量记号. 令n ≥ 0 . 如果P → = P 1 , … , P n , 那么我们记M ⁡ P 1 ⁡ … ⁡ P n 为M ⁡ P → . 特别地, 如果n = 0 , 即P → 为空, 那么M ⁡ P → 就是M . 类似地, 如果z → = z 1 , … , z n , 那么我们记λ z 1 … z n . M 为λ z → . M . 又一次, 如果n = 0 , 即z → 为空, 那么λ z → . M 就是M .
定义1.5.2. 对于不是正规形式的项
M , 我们记
M → l β N 如果N 是通过M 收缩最左可规约项得到的.M → h β N 如果N 是通过M 收缩头部可规约项得到的.M → i β N 如果N 是通过M 收缩内部可规约项得到的.引理1.5.3. 如果M → h β N , 那么λ x M → h β λ x N . 定义1.5.4.
第1.6节 永恒规约和守恒定理 第1.7节 可表达性和不可判定性 无类型λ 演算是如此之简单, 以至于它的强大是令人惊讶的. 本节我们将展示实际上λ 演算可以被视为递归论的另一种形式化.
我们可以使用λ 项表示各种各样的构造, 例如真值:true = λ x y . x ; false = λ x y . y ; if P then Q else R = P ⁡ Q ⁡ R . 很容易看出来if true then P else Q ↠ β P ; if false then P else Q ↠ β Q . 另一种有用的构造是序对〈 M , N 〉 = λ x . x ⁡ M ⁡ N π 1 = λ p . p ⁡ ( λ x y . x ) π 2 = λ p . p ⁡ ( λ x y . y ) 正如所期望的我们有π i ⁡ 〈 M 1 , M 2 〉 ↠ β M i
定义1.7.1. 在λ 中我们可以将自然数表示为Church数码:c n = λ f x . f n ⁡ ( x ) 其中f n ⁡ ( x ) 是f ⁡ ( f ⁡ ( ⋯ ( x ) ⋯ ) ) 的缩略形式, f 出现了n 次. 有时我们将c n 记成n , 于是0 = λ f x . x 1 = λ f x . f ⁡ x 2 = λ f x . f ⁡ ( f ⁡ x )
定义1.7.2. 一个部分函数
f : ℕ k → ℕ 是
λ 可定义的当且仅当存在
F ∈ Λ 满足:
如果f ⁡ ( n 1 , … , n k ) = m , 那么F ⁡ c n 1 ⁡ … ⁡ c n k = β c m . 如果f ⁡ ( n 1 , … , n k ) 是未定义的, 那么F ⁡ c n 1 ⁡ … ⁡ c n k 没有规范形式. 我们称项
F 定义了函数
f .
例子1.7.3. 下列项定义了一些常见函数.
后继: succ = λ n f x . f ⁡ ( n ⁡ f ⁡ x ) . 加法: add = λ m n f x . m ⁡ f ⁡ ( n ⁡ f ⁡ x ) . 乘法: mult = λ m n f x . m ⁡ ( n ⁡ f ) ⁡ x . 幂: exp = λ m n f x . m ⁡ n ⁡ f ⁡ x . [注记: 不知是笔误还是有意为之, 实际上这里的幂的定义的参数顺序与通行认知相反. 并且, 其实f 和x 也可以不用写出来即可定义幂.] 常零函数: zero = λ m . 0 . k 元参数的第i 投影: Π i k = λ m 1 … m k . m i .命题1.7.4. 原始递归函数是λ 可定义的.
第1.8节 注记 λ 演算和与之相关的组合子逻辑是在1930年左右分别由Alonzo Church [9 , 10 ] 和Haskell B. Curry引入的. 起初, 这种演算是某意图作为逻辑基础的系统的一部分. 不幸的是, Church的学生Kleene和Rosser发现原始的系统是不一致的, 而Curry简化了这个结果, 其现在被称为Curry悖论. 最终, 仅处理λ 项, 规约以及变换的子系统, 也就是我们称之为λ 演算的东西, 被单独进行研究.
λ 绑定和α 变换的概念在直觉上是非常清晰的, 然而在第1.2节我们看到为了正确地处理它们, 许多技术性的困难必须被克服. 当人们遇到实际实现的问题时, 这个事情就变得尤为重要了. 一种古典的解决方案是使用变量的匿名表示 (所谓的de Bruijn索引). 想要了解更多此方面内容和相关主题, 见例如[18 , 19 , 24 ] .
第1.9节 练习 练习1.2. 修改定义1.2.4以使得操作M [ x ≔ N ] 对于所有的M , N 和x 都有定义, 然后证明M [ x ≔ N ] = α M ′ [ x ≔ N ′ ] 对于所有的M = α M ′ 和N = α N ′ 均成立 (参照引理1.2.11).
第2章 直觉主义逻辑 "逻辑"一词具有多种含义, 从日常推理到复杂的形式系统. 在大多数情况下, 逻辑被用来将陈述划分为"真"和"假". 也就是说, 人们所说的逻辑通常指的是二值古典逻辑 的诸多变种之一.
的确, 古典逻辑在需要精确推理的情况下不论如何都可以被视为一种标准, 特别是在数学和计算机科学领域. 古典逻辑的原则作为工具是极其有用的, 其可以用来对于日常生活或者数学中出现的推理模式进行描述和分类.
然而, 明白以下事实也是重要的. 首先, 没有任何规则系统可以捕获丰富而又繁杂的人类思想世界, 因此每种逻辑都只能用作受限目的的工具, 而不可能是面对一切问题的终极神谕.
而且, 古典逻辑的原则, 尽管很容易为我们的直觉所接受, 并不是唯一可能的推理原则(集). 从特定的角度而言 (特别是对于拥有计算机科学背景的读者), 实际上使用别的原则(集)可能是更好的. 让我们稍微仔细地检视一下.
古典逻辑基于真性 的基础概念. 陈述的真性是一种绝对 性质, 在于其独立于任何的推理, 理解, 或者动作. 一个良形式且无歧义的声明陈述要么是真要么是假, 不论我们 (或者任何其他人) 是否以任何方式知道它, 证明它, 或者验证它. 在这种情况下, 假 的含义实际上等于不真 , 而这是由排中律 表达的, 其断言不论p 的意义为何, p ∨ ¬ p 总是成立. (排中律也被称为tertium non datur .)
无需多言, p ∨ ¬ p 中所包含的信息是相当有限的. 例如, 请看以下句子:
在数字π 的十进制表示中, 存在七个7 连成一排. 可能没人能够确定这个句子是真是假, 然而我们却被迫接受要么这个声明成立, 要么其否定成立. 另一个有名的例子是:存在无理数x 和y 使得x y 是有理数. 这个事实的证明非常简单: 如果2 2 是有理数, 那么我们取x = y = 2 ; 否则的话, 取x = 2 2 而y = 2 .这个证明的问题在于我们并不知道哪一种可能性是正确的. 但是还有另外一种不同的论证: 对于x = 2 和y = 2 ⁢ log 2 3 , 我们有x y = 3 ∈ ℚ . 我们称后一个证明是构造性 的, 而前者不是.
这样的例子刻画了古典逻辑的某些缺陷. 诚然如此, 在许多应用中, 我们想要寻求问题的实际解, 而不仅仅是知道某个解存在. 因此, 我们想要将能提供实际解的证明方法和不能提供的方法区分开来. 于是, 从非常实际的角度来看, 考虑逻辑的构造性方法也是有意义的.
满足我们的期望并且只接受构造性 推理的逻辑在传统上被称为直觉主义逻辑 . 为了解释这个名字, 我们需要回忆直觉主义逻辑的哲学基础, 其可以被精确和简单地表述为以下原则: 不存在绝对的真性, 只存在理想化数学家 (创造性主体 ) 的知识和直觉性构造. 一个逻辑判断只有在创造性主体可以验证其正确性时才能被认为是真 . 接受这种观念不可避免地拒绝了排中律这个一致的原则. 正如我们从高贵的Houyhnhnms [464]中学到的 [译注: 出自格列佛游记]:
(...) 理性教导我们只有在确定时才肯定或者否定; 若是超出了我们的知识, 则两者皆不可行. 第2.1节 BHK解释 直觉主义命题逻辑, 也被称为直觉主义命题演算 (缩写为IPC), 其语言和古典命题逻辑相同 [译注: 即句法相同].
2.1.1. 定义. 给定一个命题变量的无限集合
PV , 我们将公式的集合
Φ 定义为满足下列条件的最小集合:
每个命题变量和常量⊥ 都在Φ 中; 如果φ , ψ ∈ Φ , 那么( φ → ψ ) , ( φ ∨ ψ ) , ( φ ∧ ψ ) ∈ Φ . 变量和
⊥ 被称为原子公式. 一个公式
φ 的子公式是
φ 的一部分 (未必proper), 其自身是也是一个公式.
也就是说, 我们基本的联结词是: 推出→ , 析取∨ , 合取∧ , 以及常量⊥ (谬). 否定¬ 和等价↔ 是缩略形式, 常量⊤ (真) 也是如此:
¬ φ 是φ → ⊥ 的缩略;φ ↔ ψ 是( φ → ψ ) ∧ ( ψ → φ ) 的缩略;⊤ 是⊥ → ⊥ 的缩略.2.1.2. 约定. 我们往往默认推出是右结合的, 例如我们可以记φ → ψ → ϑ 而不是φ → ( ψ → ϑ ) . 我们假定否定具有最高的优先级, 推出则是最低的, ∨ 和∧ 之间平行. 也就是说, ¬ p ∧ q → r 的意思是( ( ¬ p ) ∧ q ) → r . 当然, 我们省略最外面的括号. 为了理解直觉主义逻辑, 我们应该忘掉真性 的古典概念. 现在我们关于一个逻辑陈述的判断不再是基于任何赋予该陈述的真值了, 而是在于我们通过显式证明或者说构造 澄清该陈述的能力. 其影响在于, 我们不应该试图通过真值表来定义逻辑联结词 (古典逻辑中一般是这样做的), 而是应该基于它们的构造来解释复合公式的意义.
这样的解释经常由所谓的Brouwer-Heyting-Kolmogorov解释 给出, 简写为BHK解释 . 我们可以将BHK解释阐述为以下一集规则, 而其算法性的风味之后会将我们引至Curry-Howard同构.
φ 1 ∧ φ 2 的一个构造由φ 1 的一个构造和φ 2 的一个构造构成;φ 1 ∨ φ 2 的一个构造由一个指示子i ∈ { 1 , 2 } 和φ i 的一个构造构成;φ 1 → φ 2 的一个构造是一个将每个φ 1 的构造转换为φ 2 的一个构造的方法 (函数);不存在⊥ 的构造. 我们并不刻画命题变量的构造是什么, 这是因为命题变量的意义只有在其被一个具体的陈述替换时才能得知, 然后我们可以提出关于那个陈述的构造的问题. 与之相对的是, ⊥ 代表了一个压根没有可能构造的陈述.
否定¬ φ 被理解为φ → ⊥ , 即我们可以在假定φ 会导致谬时断言¬ φ . 换言之, 则是
¬ φ 的构造是一个将每个φ 的构造转换为一个并不存在的对象的方法.¬ φ 和φ → ⊥ 的等价当然也在古典逻辑中成立, 但是应该注意到直觉主义的¬ φ 要强于只是不存在φ 的构造 .读者应该意识到BHK解释远非意图作为构造性语义的精确而又完整的描述. 特别是构造 的概念, 其是非形式化的, 可以按照各种各样的方式理解.
2.1.3. 例子. 考虑以下公式:
⊥ → p ;p → q → p ;( p → q → r ) → ( p → q ) → p → r ;p → ¬ ¬ p ;¬ ¬ ¬ p → ¬ p ;( p → q ) → ( ¬ q → ¬ p ) ;¬ ( p ∨ q ) ↔ ( ¬ p ∧ ¬ q ) ;( ( p ∧ q ) → r ) ↔ ( p → ( q → r ) ) ;¬ ¬ ( p ∨ ¬ p ) ;( p ∨ ¬ p ) → ¬ ¬ p → p .以上公式都可被赋予一个BHK解释. 例如, 公式i的构造在于可以安全地认为
⊥ 的构造是不可能的. (与之对比的是, 我们没有
q → p 的构造, 因为我们不能一般地排除
q 的构造的存在.) 公式iv的构造, 即对于
p → ( ( p → ⊥ ) → ⊥ ) 的构造, 如下:
给定p 的一个构造, 现在给出( ( p → ⊥ ) → ⊥ ) 的一个构造: 取p → ⊥ 的一个构造, 这是将p 的构造转换为⊥ 的构造的方法. 既然我们已经有了p 的构造, 那么我们就可以用这个方法得到⊥ 的构造. 读者应该能够自行发现其他公式的BHK解释 (练习2.2).
2.1.4. 例子. 以下每个公式都是一个古典重言, 但是并不存在一个构造, 尽管其中一些与前一个例子中的公式类似或者
对偶 .
( ( p → q ) → p ) → p ;p ∨ ¬ p ;¬ ¬ p → p ;( ¬ q → ¬ p ) → ( p → q ) ;¬ ( p ∧ q ) ↔ ( ¬ p ∨ ¬ q ) ;( p → q ) → ( ¬ p → q ) → q ;( ( p ↔ q ) ↔ r ) ↔ ( p ↔ ( q ↔ r ) ) ;( p → q ) ↔ ( ¬ p ∨ q ) ;( p ∨ q → p ) ∨ ( p ∨ q → q ) ;( ¬ ¬ p → p ) → p ∨ ¬ p .例如, 公式iii似乎和
例子2.1.3 的iv表达了相同的原则. 类似地, 公式iv和
例子2.1.3 的vi经常被视为反证法的两种模式. 公式v和
例子2.1.3 的vii都被称为
De Morgan律 , 表达了合取与析取之间的古典对偶.
这些例子表明古典逻辑的某种对称在我们转向构造性语义时消失了, 例如否定不再是对合 了, 即φ 和¬ ¬ φ 不能被视为等同的了. 然而, 我们也应该注意到iii表达了一个比ii弱的性质, 因为我们没有x的构造.
并不那么令人意外的是, 分类讨论证明这一原则vi并非构造性的. 实际上, 这只是不能用排中律的一个简单后果而已, 即我们不能先验地将一个论证划分为不同的情形. 但是, 不仅是否定或者假可能造成困难, 这可能有点令人意外. 比如说, 公式i (称为Peirce律 ) 是纯粹推论性的, 但是我们仍然不能找到其构造. 另一个例子是公式vii, 其表达了等价的古典结合律. 我们可以使用真值表验证它, 但是从构造性的角度来看, 这个结合性质似乎纯粹是意外而已.
公式viii可以被视为基于否定和析取的对于古典推出的定义. 从构造性角度而言, 这个定义并不可行. 我们还可以说更多: → , ⊥ , ∨ , ∧ 中的每一个都不可由其他联结词定义 (见练习2.26).
第2.2节 自然演绎 为了形式化直觉主义命题逻辑, 我们定义了一个被称为自然演绎的证明系统, 用NJ ⁡ ( → , ⊥ , ∧ , ∨ ) 表示, 或者就简单地记作NJ . 自然演绎的规则精确地表达了第2.1节 的非形式化语义的想法.
2.2.1. 定义. 自然演绎中的一个判断 是一个序对, 被记作Γ ⊢ φ (读作"Γ 证明了φ "), 其由一个有限的公式集合Γ 和一个公式φ 构成. 我们在书写判断的时候使用了多种简化, 例如记φ 1 , φ 2 ⊢ ψ 而不是{ φ 1 , φ 2 } ⊢ ψ , 记Γ , Δ 而不是Γ ∪ Δ , 记Γ , φ 而不是Γ ∪ { φ } . 特别地, 记号⊢ φ 代表∅ ⊢ φ . Γ ⊢ φ 的一个形式证明 或推导 是一个有限的判断的树, 满足以下条件:根标签是Γ ⊢ φ ; 所有的叶子都是公理 , 即具有形式Γ , φ ⊢ φ 的判断; 每个母结点的标签都由其女之标签由图2.1的规则得到. 如果这样一个证明存在, 那么我们称Γ ⊢ φ 是可证明的 或可推导的 , 记作Γ ⊢ N φ . 对于无限的Γ , Γ ⊢ N φ 的意思是对于某个Γ 的有限子集Γ 0 有Γ 0 ⊢ N φ .通常我们省略⊢ N 中的标记N . 注意到若是如此那么记号Γ ⊢ φ 就过载了. 它既表达一个判断的可证明性, 也代表判断本身. 然而, 其用意在上下文中总是明确的. 如果⊢ φ , 那么我们称φ 是一个定理 . [原注: 一般而言, 定理指的是在某个逻辑系统中可证明的公式.] 这个证明系统由一个公理模式 (axiom scheme) 和一些规则构成. 对于每个逻辑联结词 (除了
⊥ ) 我们有一或两个
引入 规则和一或两个
消去 规则. 对于某个联结词
∘ 的引入规则刻画了形式为
φ ∘ ψ 的结论是如何被推导出来的. 消去规则刻画了
φ ∘ ψ 是怎样用来推导其他公式的. 观察到自然演绎的规则可以被视为对于BHK解释的形式化, 其中
构造 应该被读作
证明 . 的确如此, 例如考虑推出的情况. 规则
(→ I) 的前提
Γ , φ ⊢ ψ 可以被理解为在提供
φ 的一个证明的情况下从
Γ 推出
ψ 的能力. 这就足以导出这条规则里的推论了. 消去规则
(→ E) 对应于相同的想法: 如果我们有一个
φ → ψ 的证明, 那么我们可以将
φ 的一个证明转换为
ψ 的一个证明. 在某种意义上, 规则
(→ E) 可以被视为规则
(→ I) 的逆. 类似的观察 (称为
反转原理 , 见Prawitz
[25 ] ) 也可应用于其他联结词. 规则
(⊥ E) (称为
ex falso sequitur quodlibet , 或者就
ex falso ) 是其中的一个例外, 因为并不存在与之匹配的引入规则. [译注: ex falso也被称为爆炸原理.]
Γ , φ ⊢ φ ( Ax ) Γ , φ ⊢ ψ Γ ⊢ φ → ψ (→ I) Γ ⊢ φ → ψ Γ ⊢ φ Γ ⊢ ψ (→ E) Γ ⊢ φ Γ ⊢ ψ Γ ⊢ φ ∧ ψ (∧ I) Γ ⊢ φ ∧ ψ Γ ⊢ φ (∧ E) Γ ⊢ φ ∧ ψ Γ ⊢ ψ Γ ⊢ φ Γ ⊢ φ ∨ ψ (∨ I) Γ ⊢ ψ Γ ⊢ φ ∨ ψ Γ , φ ⊢ ϑ Γ , ψ ⊢ ϑ Γ ⊢ φ ∨ ψ Γ ⊢ ϑ (∨ E) Γ ⊢ ⊥ Γ ⊢ φ (⊥ E) 图2.1: 直觉主义自然演绎NJ
2.2.2. 记号. 有时考虑命题逻辑的片段也是有用的, 其中一些联结词并不出现. 例如, 在第2.6节, 我们讨论了直觉主义命题逻辑的推论片段IPC ⁡ ( → ) . NJ 的仅有公理模式和关于推论的规则构成的子系统记作NJ ⁡ ( → ) . 这种约定也可以应用于其他片段, 例如IPC ⁡ ( → , ∧ , ∨ ) 是所谓的正片段 (positive fragment), 也被称为极小逻辑 , NJ ⁡ ( → , ∧ , ∨ ) 则代表NJ 的与之相配的子系统.
2.2.3. 例子. 我们给出对于我们最喜欢的公式的样例证明. 以下, 公式
φ , ψ , ϑ 可以是任意的:
φ ⊢ φ ⊢ φ → φ (→ I) φ , ψ ⊢ φ φ ⊢ ψ → φ (→ I) ⊢ φ → ( ψ → φ ) (→ I) 这里, Γ 是{ φ → ( ψ → ϑ ) , φ → ψ , φ } 的缩略.Γ ⊢ φ → ( ψ → ϑ ) Γ ⊢ φ Γ ⊢ ψ → ϑ (→ E) Γ ⊢ φ → ψ Γ ⊢ φ Γ ⊢ ψ (→ E) Γ ⊢ ϑ (→ E) φ → ( ψ → ϑ ) , φ → ψ ⊢ φ → ϑ (→ I) φ → ( ψ → ϑ ) ⊢ ( φ → ψ ) → ( φ → ϑ ) (→ I) ⊢ ( φ → ( ψ → ϑ ) ) → ( φ → ψ ) → ( φ → ϑ ) (→ I) 2.2.4. 引理. 直觉主义命题逻辑在弱化和替换下封闭, 即Γ ⊢ φ 可以推出Γ , ψ ⊢ φ 并且Γ [ p ≔ ψ ] ⊢ φ [ p ≔ ψ ] , 其中[ p ≔ ψ ] 代表将命题变量p 的全部出现替换以ψ . [译注: 因为没有绑定结构, 所以对于替换的描述非常简单.]
证明. 对于证明的大小进行归纳 (练习2.3).
◻
以上的结果有时也被描述为以下是直觉主义命题逻辑的导出 (或者说兼容 ) 规则:Γ ⊢ φ Γ , ψ ⊢ φ Γ ⊢ φ Γ [ p ≔ ψ ] ⊢ φ [ p ≔ ψ ]
第2.3节 古典逻辑的代数语义 在这接下来的一节中我们将要引入直觉主义逻辑的一种代数语义. 为了帮助读者更好地理解, 我们从古典逻辑开始. 通常来说, 古典命题公式的语义被定义成这样, 其使得每个联结词都可以被视为施行于真值的集合𝔹 = { 0 , 1 } 上的操作. 也就是说, 我们实际上是在处理一个代数系统〈 𝔹 , ∨ , ∧ , → , − , 0 , 1 〉 其中0 ∨ 1 = 1 , 0 ∧ 1 = 0 , 0 → 1 = 1 , 等等. 如果我们为该系统赋予一个序使得0 < 1 , 那么我们有以下性质:a ≤ b 当且仅当 a → b = 1 . 真值的代数和集合的代数之间存在显见的相似之处. 逻辑运算∨ 和∧ 表现得就非常类似于集合论的∪ 和∩ . 等式A ∪ B = { x | ( x ∈ A ) ∨ ( x ∈ B ) } 陈述了诸多类同中的一例. 以类似的方式, 否定对应于补− A (相对于某个固定的论域) 而推论对应于− A ∪ B .
我们现在即将引入的布尔代数 的概念是真值的代数和集合的代数的泛化. 我们先从一个更弱因而也更宽泛的概念格 开始.
2.3.1. 定义. 一个格是一个偏序〈 A , ≤ 〉 , 其满足对于每个A 的二元素子集{ a , b } , A 中存在它的最小上界和最大下界. 我们记sup A ⁡ { a , b } 为a ⊔ b , inf A ⁡ { a , b } 为a ⊓ b . 与集合论的运算相类比, 我们称⊔ 为并 (或者join), ⊓ 为交 (或者meet). 格的top (相应地, bottom) 若存在, 通常被记为1 (相应地, 0 ).
2.3.2. 引理. 在一个格中, 以下条件等价:
a ≤ b ;a ⊓ b = a ;a ⊔ b = b .证明. 即得.
◻
2.3.3. 例子. 每个线序, 例如真值的集合𝔹 , 是一个格. 每个在集合的并与交下封闭的集族也是一个格. 但是, 相对于∪ 和∩ 的封闭性并不是集族成为格的必要条件. 一个例子是Euclid平面的所有凸子集的族. (一个集合A 是凸的当且仅当对于所有的a , b ∈ A , 连接a 与b 的线段被包含在A 中.)
2.3.4. 引理. 以下等式在每个格中都是成立的:
a ⊔ a = a 和a ⊓ a = a ;a ⊔ b = b ⊔ a 和a ⊓ b = b ⊓ a ;( a ⊔ b ) ⊔ c = a ⊔ ( b ⊔ c ) 和( a ⊓ b ) ⊓ c = a ⊓ ( b ⊓ c ) ;( a ⊔ b ) ⊓ a = a 和( a ⊓ b ) ⊔ a = a .证明. 常规的应用定义而已. [译注: 这四条性质分别被称为幂等律, 交换律, 结合律, 吸收律.]
◻
2.3.5. 定义. 格A 被称为分配的, 如果以下等式在A 中成立:( a ⊔ b ) ⊓ c = ( a ⊓ c ) ⊔ ( b ⊓ c ) ;( a ⊓ b ) ⊔ c = ( a ⊔ c ) ⊓ ( b ⊔ c ) . 假定格A 拥有top元素1 和bottom元素0 , 我们称b 是a 的补当且仅当a ⊔ b = 1 且a ⊓ b = 0 . 2.3.6. 引理. 令b 是a 在某分配格A 中的补, 那么b 是A 中满足a ⊓ b = 0 的最大元素. 特别地, a 最多只有一个补.
证明. 设
a ⊓ c = 0 , 那么
c ≤ b , 因为
c = 1 ⊓ c = ( a ⊔ b ) ⊓ c = ( a ⊓ c ) ⊔ ( b ⊓ c ) = 0 ⊔ ( b ⊓ c ) = b ⊓ c . ◻
2.3.7. 定义. 一个布尔代数是一个带有top和bottom元素的分配格B , 其满足每个B 的元素a 都有一个补 (记作− a ).
布尔代数经常以形式为ℬ = 〈 B , ⊔ , ⊓ , − , 0 , 1 〉 的代数结构呈现. 在这种情况下, 偏序可以在a ≤ b 和a ⊓ b = a 的等价性 (见引理2.3.2) 的帮助之下被重新构造出来.
2.3.8. 例子. 令
X 是任意的集合. 一个集合域 (
X 上的) 是一个非空的
X 的子集族
ℛ , 其在集合论的并, 交, 补 (相对于
X ) 下封闭. 每个集合域都是一个布尔代数. 集合域的例子如下:
𝒫 ⁡ ( X ) , X 的幂集;{ ∅ , X } ;{ A ⊆ X | A 有限或者 X − A 有限 } .注意到真值的代数
𝔹 (暂时忘却
→ ) 同构于ii.
以下的结果被称为Stone表示定理 .
2.3.9. 定理. 每个布尔代数同构于一个集合域.
我们省略了Stone定理的证明, 因为其会让我们离题太远. 读者在闲暇之余可以花些时间做做练习2.15, 但是现在让我们转向古典命题逻辑的布尔代数语义.
2.3.10. 定义. 布尔代数ℬ = 〈 B , ⊔ , ⊓ , − , 0 , 1 〉 中的一个赋值是任意的从命题变量PV 到B 的映射v . 一个公式φ 相对于赋值v (在ℬ 中) 的值由归纳定义.⟦ p ⟧ v = v ⁡ ( p ) , 对于 p ∈ PV ; ⟦ ⊥ ⟧ v = 0 ; ⟦ φ ∨ ψ ⟧ v = ⟦ φ ⟧ v ⊔ ⟦ ψ ⟧ v ; ⟦ φ ∧ ψ ⟧ v = ⟦ φ ⟧ v ⊓ ⟦ ψ ⟧ v ; ⟦ φ → ψ ⟧ v = − ⟦ φ ⟧ v ⊔ ⟦ ψ ⟧ v . 当⟦ φ ⟧ v = 1 时, 记ℬ , v ⊨ φ . 若对于所有的v 有ℬ , v ⊨ φ , 记ℬ ⊨ φ .
显然, 这种布尔代数语义是通常二值语义的一种泛化. 的确, 一个公式φ 是一个古典重言当且仅当𝔹 ⊨ φ . 实际上, 这种泛化不是本质性的.
2.3.11. 定理. 一个命题公式φ 是一个古典重言当且仅当对于所有的布尔代数ℬ 有ℬ ⊨ φ .
证明. 自右向左是即得的. 为了证明另一个方向, 我们假设对于某个
ℬ 有
ℬ ⊭ φ . 根据Stone表示定理我们不妨设
ℬ 是某个
X 上的一个集合域.
既然
ℬ ⊭ φ , 那么存在某个
ℬ 中的赋值
v 满足
⟦ φ ⟧ v ≠ X . 因此, 存在
x ∈ X 满足
x ∉ ⟦ φ ⟧ v . 定义一个二元赋值
w (即
𝔹 中的一个赋值) 满足
w ⁡ ( p ) = 1 当且仅当
x ∈ ⟦ p ⟧ v . 根据归纳, 可以证明对于所有的公式
ψ :
⟦ ψ ⟧ w = 1 当且仅当 x ∈ ⟦ ψ ⟧ v . 那么,
⟦ φ ⟧ w ≠ 1 .
◻
第2.4节 Heyting代数 现在我们将建立直觉主义命题逻辑的一种语义. 出于这样的目的我们检视了公式相对于可证明性的代数性质. 我们首先观察到可证明的推论表现得几乎就像公式上的一个序关系, 即它是自反的和传递的. 更确切地说, 对于每个Γ 我们有:
Γ ⊢ φ → φ ;如果Γ ⊢ φ → ψ 且Γ ⊢ ψ → ϑ , 那么Γ ⊢ φ → ϑ . 然而, 这个关系并不是反对称的. 但是, 我们可以通过将等价的公式视为等同的来将其转化为一个偏序关系. [译注: 这实际上是格论的一个标准技巧, 其可以从预序中导出一个偏序.] 为了使之精确, 我们令Γ 是一个固定的命题公式集合 (特别地, Γ 可以为空). 我们按照以下方式定义一个关系∼ Γ :φ ∼ Γ ψ 当且仅当 Γ ⊢ φ → ψ 且 Γ ⊢ ψ → φ . 不难看出∼ Γ 是所有公式构成的集合Φ 上的一个等价关系, 并且有 (我们省略∼ Γ 中的下标Γ ):[ ⊥ ] ∼ = { φ | Γ ⊢ ¬ φ } 且 [ ⊤ ] ∼ = { φ | Γ ⊢ φ } . 令L Γ = Φ / ∼ = { [ φ ] ∼ | φ ∈ Φ } , 那么显然由[ φ ] ∼ ≤ Γ [ ψ ] ∼ 当且仅当 Γ ⊢ φ → ψ 定义的关系≤ Γ 是L Γ 上一个良定的偏序. 我们有以下等价:[ φ ] ∼ = [ ψ ] ∼ 当且仅当 [ φ ] ∼ ≤ Γ [ ψ ] ∼ 且 [ ψ ] ∼ ≤ Γ [ φ ] ∼ . 我们接下来的步骤是发现偏序〈 L Γ , ≤ Γ 〉 是一个格. 定义[ φ ] ∼ ⊔ [ ψ ] ∼ = [ φ ∨ ψ ] ∼ ; [ φ ] ∼ ⊓ [ ψ ] ∼ = [ φ ∧ ψ ] ∼ . 运算⊔ 和⊓ 是良定义的, 因为以下是可证明的:( φ ↔ φ ′ ) → ( ψ ↔ ψ ′ ) → ( ( φ ∨ ψ ) ↔ ( φ ′ ∨ ψ ′ ) ) ; ( φ ↔ φ ′ ) → ( ψ ↔ ψ ′ ) → ( ( φ ∧ ψ ) ↔ ( φ ′ ∧ ψ ′ ) ) . 读者应该很容易验证第2.5节 Kripke语义 我们现在引入直觉主义命题逻辑的另一种语义. 这种语义反映了以下想法. 从构造性的角度来看, 我们只能断言我们已经确定了的命题的真性. 但是, 通过学到新的事实, 我们获得了更多的信息, 并且我们可以为我们的现有知识 (state of knowledge) 添加新的命题. 然而, 我们不应该失去我们的知识. 换言之, 现在为真的将永远保持为真, 但是今天还没能确定为真的明天就可能变成真的了. 因此, 我们不得不小心, 只在我们全然不可能断言A 时才断言A 的否定 .
2.5.1. 定义. 一个Kripke模型 是一个具有形式𝒞 = 〈 C , ≤ , ⊩ 〉 的三元组, 其中C 是一个非空集合, 它的元素被称为状态 或者可能世界 , ≤ 是一个C 中的偏序, 而⊩ 是C 的元素和命题变量之间的一个二元关系. 关系⊩ (读作"力迫") 必须满足以下单调性条件.如果 c ≤ c ′ 且 c ⊩ p 那么 c ′ ⊩ p . 直觉在于模型的元素代表了知识状态. 关系≤ 与通过获得更多知识来扩展状态有关. 关系⊩ 决定了在一个给定的状态下哪些命题变量被认为是真的. 我们按照以下方式延拓这个关系来为命题公式提供含义.
2.5.2. 定义. 如果
𝒞 = 〈 C , ≤ , ⊩ 〉 是一个Kripke模型, 那么
c ⊩ φ ∨ ψ 当且仅当c ⊩ φ 或c ⊩ ψ ;c ⊩ φ ∧ ψ 当且仅当c ⊩ φ 且c ⊩ ψ ;c ⊩ φ → ψ 当且仅当对于所有满足c ′ ⊩ φ 的c ′ ≥ c 有c ′ ⊩ ψ ;c ⊩ ⊥ 并不成立.注意到上述定义推出了以下否定的法则:
c ⊩ ¬ φ 当且仅当对于所有的c ′ ≥ c 有c ′ ⊮ φ .记号
⊩ 可以按照多种方式运用. 有时我们记
𝒞 , c ⊩ φ 以明确使用了哪个模型. 当对于所有的
c ∈ C 有
c ⊩ φ 时, 我们记
𝒞 ⊩ φ . 记号
c ⊩ Γ 的意思是对于所有的
φ ∈ Γ 有
c ⊩ φ , 对于记号
𝒞 ⊩ Γ 也是类似的. 最后, 若对于每个Kripke模型
𝒞 和每个
𝒞 的状态
c , 条件
𝒞 , c ⊩ Γ 能够推出
𝒞 , c ⊩ φ , 那么记
Γ ⊩ φ .
2.5.3. 引理. 如果c ≤ c ′ 且c ⊩ φ 那么c ′ ⊩ φ .
2.5.4. 例子. 令C = { c , c ′ , c ″ } , 其中c ≤ c ′ 而c ′ 和c ″ 是不可比较的. 一个Kripke模型𝒞 = 〈 C , ≤ , ⊩ 〉 , 其中
第2.6节 推论片段 最重要的联结词就是推出了. 因此, 研究推出性公式 是有意义的, 也就是仅由这种联结词构成的公式. 这种受限演算的自然演绎系统NJ ⁡ ( → ) 由规则(→ E) 和(→ I) 以及公理模式( Ax ) 构成.
2.6.1. 定理. 自然演绎系统NJ ⁡ ( → ) 相对于Kripke模型是完备的, 即如果→ 是唯一出现在Γ 和φ 中的联结词, 那么条件Γ ⊢ φ 和Γ ⊩ φ 是等价的.
第2.7节 注记 数学中的构造主义深深地根植于19世纪, 甚至是更加遥远的过去. 例如, 直觉主义者他们自己也承认受到Immanuel Kant (1724-1804) 的哲学的启发. 根据Kant, 数学认知的领域诸如时间和空间可直达人类的直觉而并非经验上所"观察"到的. 因此, 数学可被视为纯粹的心灵上的构造.
Leopold Kronecker (1823-1891) 通常被引为第一个显式将构造主义的想法应用于数学的作者. 根据Kronecker, 一个数字的正确定义, 可在有限步骤之内被验证. 而一个存在性陈述的证明, 应该提供一个能够见证这个陈述的显式对象.
为了寻找数学的坚实基础, 许多其他人也加入了Kronecker. 19世纪下半叶, 数学正发生着相当重要的改变. 随着新分支的发展, 包括数理逻辑, 数学研究的主题变得愈发抽象而与现实经验无关. 数学家的活动从探索"真实"世界的性质转移到了创造一个抽象世界. 这引发了关于数学基础的重要问题. 随着悖论的发现, 特别是Russell发现的知名悖论, 这些问题变得紧急起来.
19世纪末和20世纪初, 许多思想和流派得以建立和竞争, 它们意在解释现代数学的概念基础.
第2.8节 练习 第3章 简单类型λ 演算 在逻辑学中, 判断一个公式相对于某个特定的语义是否有效 (valid) 总是核心议题. 或者, 更一般地, 一集假设是否在所有模型中都蕴涵一个公式. 在古典逻辑的"语义传统"之中, 这种问题总是最重要的主题, 而可靠 (sound) 且完备 (complete) 的证明系统的构造主要被视为判断有效性的工具. 在这种情况下, 公式和判断的可证明性是和证明相关的问题之中唯一令人感兴趣的. 人们会问证明是否存在, 但是不必问是哪一个证明.
在证明论中, 视角变得有所不同. 我们想要研究证明的结构, 比较各种证明, 从中选出一些, 以与其他的证明进行区分. 这对于构造性逻辑而言是尤为重要的, 其中证明 (构造) 而不是语义是最终的标准.
因此, 寻求一种简便的证明记号是非常自然的. 例如, 我们可以用M : φ 来表示M 是φ 的一个证明. 若有额外假设Γ , 那么我们或许可以扩展这个记号为Γ ⊢ M : φ 现在, 如果M 和N 分别是φ → ψ 和φ 的证明, 那么由( → E ) 得到的ψ 的证明可以表示为@ ⁡ ( M , N ) : ψ , 或者就简单地记作M ⁡ N : ψ . 这给出了一种"带注解的"( → E ) 规则Γ ⊢ M : φ → ψ Γ ⊢ N : φ Γ ⊢ M ⁡ N : ψ 当试着为( Ax ) 设计一种带注解的版本时, 读者或许会发现给假设命名也是很方便的事情, 例如x : φ , y : ψ ⊢ x : φ 代表使用第一个假设. 这个想法在我们想要注解( → I ) 规则时也派得上用场, 那么discharge一个证明M 中的假设x 可以被记成诸如♯ x . M , ξ x . M , ... 我们为什么不试试lambda呢?Γ , x : φ ⊢ M : ψ Γ ⊢ λ x . M : φ → ψ 是的, 我们得到的就是lambda记号. 用一位著名作家的话来说, 虽然是在完全不同的上下文中, 那就是相似并非刻意也并非偶然, 而是不可避免的. 的确, 一个推论的一个证明代表了一个构造, 而根据BHK解释, 一个推论的一个构造是一个函数.
然而, 不是每个lambda项都可以被用作证明的记号. 例如, 自应用x ⁡ x 似乎并不代表任何命题的证明, 不论由x 注解的假设为何. 所以, 在我们探索证明和项的类似之处 (第4章的事情) 之前, 我们必须寻找合适的lambda演算的子系统.
正如我们所说, BHK解释将推论的构造和函数视为等同的. 在数学中, 一个函数f 总是定义在一个特定的定义域 (domain) A 上, 而值落在一个陪域 (codomain) B 中. 这被记作f : A → B . 类似地, 一个公式φ → ψ 的一个构造也只能被应用于指定的参数上来, 也就是前提 (premise) 的构造. 那么, 其结果是结论 (conclusion) 的构造, 它当然也只能具有特定的类型.
在lambda演算中, 我们可以引入类型来描述项的函数行为. 一个应用M ⁡ N 只有当M 具有形式为σ → τ 的函数类型而N 具有类型σ 时才是可能的. 其结果具有类型τ . 这是一种相当类似于严格定型的编程语言所具有的类型原则.
几乎从一开始表达项的函数性的类型赋予的概念就被纳入了组合子逻辑和lambda演算之中, 自那时起各种类型化演算就得到了全面的研究. 本章我们将引入对于类型概念最基本的形式化: 系统λ → .
第3.1节 Curry风格的简单类型λ 演算 我们从Curry风格的简单类型λ 演算 开始, 其中我们处理和第1章 相同的通常的lambda项.
3.1.1. 定义. 一个推论性命题公式被称为一个简单类型. 所有简单类型构成的集合记作Φ → . 一个环境是具有形式{ x 1 : τ 1 , … , x n : τ n } 的一个有限的序对集合, 其中x i 是不同的λ 变量, τ i 是类型. 也就是说, 环境是从变量到类型的有限的部分函数. 因此, 如果( x : τ ) ∈ Γ , 我们也可以将其写成Γ ⁡ ( x ) = τ . 我们也定义:dom ⁡ ( Γ ) = { x ∈ Υ | ( x : τ ) ∈ Γ , 对于某个 τ } ; rg ⁡ ( Γ ) = { τ ∈ Φ → | ( x : τ ) ∈ Γ , 对于某个 x } . 在其他文献中, 考虑简单类型lambda演算的一种变体是相当常见的, 其中所有的类型都从唯一的一个类型变量构造而来 (因而其被称为类型常量 ). 这样一种lambda演算的计算性质类似于我们的λ → . 但是, 从"逻辑"角度而言这种限制于一个类型常量的情况并不是同样有趣的, 参见练习4.10.
记号. τ → ⋯ → τ → σ 被缩略为τ n → σ , 其中τ 出现了n 次. 环境{ x 1 : τ 1 , … , x n : τ n } 经常被简记作x 1 : τ 1 , … , x n : τ n . 如果dom ⁡ ( Γ ) ∩ dom ⁡ ( Γ ′ ) = ∅ , 那么我们也将Γ ∪ Γ ′ 记作Γ , Γ ′ . 特别地, Γ , x : τ 代表Γ ∪ { x : τ } , 其中假定x ∉ dom ⁡ ( Γ ) . 类似的约定也适用于之后的章节.
定义3.1.2. 一个判断由一个环境, 一个lambda项和一个类型构成, 记作
Γ ⊢ M : τ . 图3.1中的规则定义了系统
λ → 的可推导的规则的概念. (读者必须记住规则
( Var ) 和
( Abs ) 中变量
x 不在
Γ 的定义域之中.) 如果
Γ ⊢ M : τ 是可推导的, 那么我们称
M 在
Γ 中具有类型
τ , 记作
Γ ⊢ λ → M : τ 或者就记成
Γ ⊢ M : τ (参考定义2.2.1).
( Var ) Γ , x : τ ⊢ x : τ ( Abs ) Γ , x : σ ⊢ M : τ Γ ⊢ ( λ x . M ) : σ → τ ( App ) Γ ⊢ M : σ → τ Γ ⊢ N : σ Γ ⊢ ( M ⁡ N ) : τ 图3.1: 简单类型lambda演算λ →
例子3.1.3. 令
σ , τ , ρ 是任意的类型, 那么:
⊢ I : σ → σ ;⊢ K : σ → τ → σ ;⊢ S : ( σ → τ → ρ ) → ( σ → τ ) → σ → ρ .一个形式为M : τ → σ 的类型赋予当然可以被解释为"M 是一个以τ 为定义域σ 为陪域的函数". 但是我们必须明白这里对于"定义域"和"陪域"的理解不是集合论性质的. 在Curry风格的类型化演算中, 类型被更适切地描述为(由项满足的)谓词或者规格 (specification) 而不是集合论性质的函数空间. 在集合论中f : A → B 的含义为f 的参数恰是A 的元素, 而所有的值都必须属于B . 与之相对地, M : τ → σ 仅意味着将M 应用于一个类型为τ 的参数必须产生一个类型为σ 的结果.
本节我们以系统λ → 的一些基本性质作结.
引理3.1.4. 如果Γ ⊢ M : τ , 那么FV ⁡ ( M ) ⊆ dom ⁡ ( Γ ) . 如果Γ , x : τ ⊢ M : σ 并且y ∉ dom ⁡ ( Γ ) ∪ { x } , 那么Γ , y : τ ⊢ M [ x ≔ y ] : σ . 证明. 这两个都可以通过对于
M 的长度进行归纳来证明. 作为一个例子, 我们处理ii的抽象的情形.
设
M = λ z M ′ 和
σ = σ ″ → σ ′ , 并且我们从
Γ , x : τ , z : σ ″ ⊢ M ′ : σ ′ 推导出了
Γ , x : τ ⊢ M : σ . 如果
z ≠ y , 那么根据归纳假设, 我们知道
Γ , y : τ , z : σ ″ ⊢ M ′ [ x ≔ y ] : σ ′ , 因而
Γ , y : τ ⊢ λ z . M ′ [ x ≔ y ] : σ . [译注: 根据前面的约定, 这个记号的含义是对于
M ′ 进行替换, 而不是整个项.] 现在注意到
λ z M ′ [ x ≔ y ] = ( λ z M ′ ) [ x ≔ y ] .
如果
z = y 并且
Γ , x : τ , z : σ ″ ⊢ M ′ : σ ′ , 那么我们可以
◻
引理3.1.5. (Generation lemma). 设
Γ ⊢ M : τ .
如果M 是一个变量x , 那么Γ ⁡ ( x ) = τ . 如果M 是一个应用P ⁡ Q , 那么对于某个σ , Γ ⊢ P : σ → τ 且Γ ⊢ Q : σ . 如果M 是一个抽象λ x N 并且x ∉ dom ⁡ ( Γ ) , 那么τ = τ 1 → τ 2 , 其中Γ , x : τ 1 ⊢ N : τ 2 . 引理3.1.6. 如果Γ ⊢ M : σ 并且对于所有的x ∈ FV ⁡ ( M ) 有Γ ⁡ ( x ) = Γ ′ ⁡ ( x ) , 那么Γ ′ ⊢ M : σ . 如果Γ , x : τ ⊢ M : σ 并且Γ ⊢ N : τ , 那么Γ ⊢ M [ x ≔ N ] : σ . 证明. 我们对于
M 的大小进行归纳.
◻
定理3.1.7. (Subject reduction). 如果Γ ⊢ M : σ 并且M ↠ β N , 那么Γ ⊢ N : σ .
定义3.1.8. 将类型σ 中的类型变量p 替换为类型τ , 记作σ [ p ≔ τ ] , 被定义为:p [ p ≔ τ ] = τ ; q [ p ≔ τ ] = q , 如果 q ≠ p ; ( σ 1 → σ 2 ) [ p ≔ τ ] = σ 1 [ p ≔ τ ] → σ 2 [ p ≔ τ ] . 记号Γ [ p ≔ τ ] 代表{ ( x : σ [ p ≔ τ ] ) | ( x : τ ) ∈ Γ } , 类似的记号还可应用于等式, 等式的集合, 诸如此类.
命题3.1.9. 如果Γ ⊢ M : σ , 那么Γ [ p ≔ τ ] ⊢ M : σ [ p ≔ τ ] .
第3.2节 类型重构算法 一个项M ∈ Λ 是可定型的, 如果存在Γ 和σ 满足Γ ⊢ M : σ . 可定型项的集合是所有λ 项的集合的一个真子集. 因此, 判断系统λ → 中到底哪些项可被赋予类型以及如何有效地找出这些类型成了根本性的问题. 实际上, 从对于三元谓词"Γ ⊢ M : τ "的分析之中我们可以提出许多判定问题. 以下的定义对于每个能够导出具有这种形式的判断的类型赋予系统都是有意义的.
定义3.2.1. 类型检查问题指的是对于一个给定的环境Γ , 一个项M 和一个类型τ , 判断Γ ⊢ M : τ 是否成立. 可定型问题, 又称类型重构问题, 指的是判断一个给定项M 是否是可定型的. 类型居留问题, 又称类型是否为空问题, 指的是对于一个给定的类型τ , 判断是否存在一个封闭项M 满足⊢ M : τ 成立. (那么, 我们称τ 是非空的, 并拥有居民M .) 类型居留问题将在第4章讨论, 本节我们先考虑可定型问题和类型检查问题. 第一眼看上去, 似乎判断一个给定项在一个给定环境之中是否拥有一个给定的类型可能要比判断它到底是否拥有类型来得容易. 然而, 这种印象一般而言是错误的. 对于许多类型赋予系统而言, 可定型问题很容易被规约为类型检查问题. 的确, 为了判断一个项M 是否是可定型的, 其中FV ⁡ ( M ) = { x 1 , … , x n } , 我们可以问是否有x 0 : p ⊢ K ⁡ x 0 ⁡ ( λ x 1 … x n . M ) : p 而这就将可定型问题化为了类型检查问题. 实际上, 在简单类型的情况下, 这两者是等价的 (练习3.11), 尽管将后一个问题规约为前一个问题就不那么简单了. 但是, 对于某些类型赋予系统, 这两个问题并非等价: 比较一下命题13.4.3和定理13.4.4.
现在我们展示可定型问题是如何能够被规约为仅包含二元函数符号→ 的签名上的合一 (unification) 的. 这个签名上的项被视为与简单类型是等同的. 对于每个项M 我们根据归纳定义
想法如下: E M 有解当且仅当M 是可定型的, 而τ M 是M 的 (非形式化的) 类型的模式. 出现在E M 中的类型变量 (未知元) 分为两种: 其中一些对应于M 的自由变量x 的类型, 记作p x , 而其他变量是辅助性的.定义3.2.2. 如果M 是一个变量x , 那么E M = ∅ 且τ M = p x , 其中p x 是一个新鲜 (fresh) 的类型变量. 令M 是一个应用P ⁡ Q . 首先, 第3.3节 Church风格的简单类型λ 演算 定义3.3.5. ( Var ) Γ , x : τ ⊢ x : τ ( Abs ) Γ , x : σ ⊢ M : τ Γ ⊢ ( λ x : σ . M ) : σ → τ ( App ) Γ ⊢ M : σ → τ Γ ⊢ N : σ Γ ⊢ ( M ⁡ N ) : τ 图3.2: Church风格的简单类型lambda演算
第3.4节 Church定型 vs Curry定型 第3.5节 正规化 第3.6节 Church-Rosser性质 第3.7节 可表达性 第3.8节 注记 类型经常被视为一种避免无类型世界中因各种各样的自应用而产生的悖论的方法. 无疑, 悖论给予了20世纪之初创造各种类型理论的动力. 然而, 正如[11 , 12 ] 所指出的那样, 在数学中将对象划分为不同的范畴或者"类型"是自然的, 并且远在这些悖论被发现之前.
形式类型论的历史起源于Russell. Chwistek, Ramsey, Hilbert等其他人的工作对于该主题的建立做出了贡献. 对于简单类型论的一份有影响力的呈现由1940年Church的论文[13 ] 给出. 为此Church引入了简单类型lambda演算, 其为他的类型论的核心语言.
组合子逻辑的类型化版本在数年之前由Curry提出, 在1934年的论文[14 ] 中, 尽管Curry肯定在1928年就已经有想法了, 见[20 , 21 ] . Curry完整的"theory of functionality"后来被证明是不一致的[15 ] 但是随即就由[16 ] 修正. 很快类型就成为组合子理论和lambda演算中的标准概念.
之后类型被证明在编程语言中很有用. 就像无类型的λ 演算为无类型的编程语言提供了基础, 各种类型化的λ 演算为带有类型的编程语言提供了基础. 实际上, 诸如ML [23 ] 等语言的设计启发了类型检查问题和可定型问题的研究. 然而, 正如[22 , pp. 103-104] 所指出的那样, 类型重构算法的主要想法可以追溯至1920年代.
第3.9节 练习 第4章 Curry-Howard同构 既已在第2章讨论了直觉主义逻辑, 在第3章讨论了带类型的lambda演算, 现在开始我们将专注于这二者之间的关系, 也就是Curry-Howard同构. 第3章中我们已然发现这种逻辑和计算之间令人惊讶的类比, 那里我们接受了lambda项可以作为证明的合适记号. 的确, Brouwer-Heyting-Kolmogorov解释, 特别是对于构造性推出的函数式理解, 强烈地支持这一选择.
本章我们将更仔细地检视证明和项之间的对应. 很快我们将会发现, 依赖于对证明形式化的特定选择, 或多或少我们足以将其称为同构 . 在大多数情形下, lambda项可以被视为是对于证明的一种细化 (refinement) 而非是同构的像. 另一方面, 我们也发现这种类比不局限于非空类型和可证明推出的等价, 它可以从宽度 进一步发展, 因为其可以扩展为各种逻辑联结词和数据类型之间的一种对应. 但是, 其也可以从深度 进一步发展. 项规约 (计算) 和证明规范化之间存在一种基础的关系. 公式作为类型的对应的这一方面或许是最重要的.
第4.1节 证明和项 正如我们在第3章中所发现的, λ → 的类型赋予规则可以被视为自然演绎系统NJ ⁡ ( → ) 的注释版本. 以下事实是这种相似性的一个立即推论.
4.1.1. 命题. 如果λ → 中有Γ ⊢ M : φ , 那么IPC ⁡ ( → ) 中rg ⁡ ( Γ ) ⊢ φ . 如果IPC ⁡ ( → ) 中有Δ ⊢ φ , 那么λ → 中Γ ⊢ M : φ , 其中M 是某个项而Γ 是某个满足rg ⁡ ( Γ ) = Δ 的环境. 特别地, 一个推论性公式是一个直觉主义的定理当且仅当其是一个居留 (inhabited) 类型.
证明. 相对于推导 (derivation) 进行简单的归纳.
◻
第4.2节 类型居留 第4.3节 并非确切的同构 第4.4节 证明正规化 第4.5节 和与积 第4.6节 证明者怀疑者对话 回忆一下第2章的BHK解释. 我们可以将一个公式的构造的建立过程想象成一个证明者 和一个怀疑者 之间的对话, 证明者产生构造, 而怀疑者质疑构造是否存在.
证明者1: 我断言( ( p → p ) → ( q → r → q ) → s ) → s 成立.怀疑者1: 真的吗? 让我们假设我给了你一个( p → p ) → ( q → r → q ) → s 的构造, 那么你能给我一个s 的构造吗?证明者2: 通过将你的构造应用于p → p 的一个构造, 然后再将结果应用于q → r → q 的一个构造, 我就能得到你想要的东西.怀疑者2: 嗯...你做出了两个新的断言. 我最怀疑第一个. 你确定你有p → p 的一个构造吗? 假设我给你一个p 的构造, 你能回我一个p 的构造吗?证明者3: 我用相同的构造就可以了!
对话 自证明者作出断言 开始. 基于证明者的断言, 怀疑者给证明者提供一列offer , 然后提出一个挑战 . 这些offer并不包含实际 的构造, 而是怀疑者告诉证明者在她拥有这样的构造的假设下继续. 证明者必须使用这些offer以及之前的offer来完成挑战. 这么做的时候, 证明者是允许引入新的断言的. 然后, 怀疑者一一回应这些断言, 诸如此类.
下面我们呈现另外一个对话, 其从相同的断言开始. 实际上, 最初的三步和之前的对话是一样的.
怀疑者2': 嗯...你做出了两个新的断言. 我最怀疑第二个. 你确定你有q → r → q 的一个构造吗? 如果我给你q 和r 的构造, 你能给我q 的一个构造吗?证明者3': 我可以使用你刚才给我的那个构造!
如果证明者在某一步引入了数个新的断言, 那么怀疑者可以挑战其中任何一个. 但是, 只能是一个, 而且必须来源于证明者最新的那一步. 相反的是, 证明者必须总是回应最新的挑战, 但是她可以使用任何之前怀疑者给出的offer, 包括那些不是来源于最新的一步的offer.
对话在轮到某个玩家而却不能回应时结束 , 在这种情况下另外一名玩家就获胜 了. 这里我们是将对话想成是某种游戏或者辩论. 如果证明者的最后一步在不引入新的断言的情况下就解决了怀疑者最后的挑战的话, 怀疑者就无法回应了. 若是怀疑者的最后一步引入了一个挑战, 但是其无法使用任何怀疑者之前给出的offer解决的话, 那么证明者就没法回应了.
对话可以无限进行下去, 这会被认为是怀疑者的胜利. 例如, 证明者从断言( a → b ) → ( b → a ) → a 开始, 怀疑者提供a → b 和b → a , 并挑战证明者, 要求她提供a 的一个构造. 证明者可以应用第二个offer于b 的一个假想 (alleged) 的构造. 然后, 怀疑者将会要求证明者去构造b . 现在证明者可以通过应用第一个offer于a 的一个假想构造回应, 如此则循环往复.
证明者策略 是与怀疑者辩论的技巧. 每当怀疑者拥有选择时, 即当证明者引入超过一个断言时, 证明者需要预测怀疑者可以做出的所有选择的情况, 并且为每一种选择准备一个回应. 这样的策略可以被表示为树, 其中每一条从根开始的路径都是一个对话, 并且对于每个标有证明者步骤的结点, 其子结点的数目与证明者在她步骤内引入的断言数目一致, 而每个标有怀疑者步骤的结点都是在挑战一个断言. 例如, 以上两个对话可以合在一起形成图4.2中的证明者策略. 一个证明者策略是在获胜 , 如果其所有对话都是由证明者胜出的.
证明者1 怀疑者1 证明者2 怀疑者2 证明者3 怀疑者2' 证明者3' 图4.2: 证明者策略
我们可以从获胜的证明者策略中提取公式的构造. 的确如此, 如果我们接受类型为φ 的简单类型λ 项为φ 的构造, 那么公式的构造是由将怀疑者步骤视为lambda抽象而证明者步骤视为应用得到的, 如图4.3所示.
P1 S1 λ x : ( p → p ) → ( q → r → q ) → s . ⋯ P2 x ⁡ ⋯ ⁡ ⋯ S2 λ y : p . ⋯ P3 y S2' λ u : q . λ v : r . ⋯ P3' u 图4.3: 由策略得到构造
实际上, 我们可以将提取出来的λ 项 (具有η -long normal form) 视为对于策略的一种方便的表示.
第4.7节 带有谬的证明者怀疑者对话 第4.8节 注记 第4.9节 练习 第5章 证明作为组合子 之前的章节中我们重点关注了自然演绎证明和λ 项之间的Curry-Howard同构. 正如我们所看到的, 这个同构联系起了两个世界的许多概念. 本章我们呈现一个相关的另外两种基础概念之间的对应, 即Hilbert风格的证明和组合子逻辑的项.
第5.1节 Hilbert风格的证明 自然演绎在历史上并非形式化证明概念的第一种方式, 它也不是得到最广泛使用的一种. 许多数理逻辑的古典呈现, 例如[], 使用了更传统的Hilbert风格的证明的概念. 通常一个Hilbert风格的证明系统由一集公式 (被称为逻辑公理) 和寥寥几条证明规则构成. 而且, Hilbert风格的证明系统中的形式证明在传统上被定义为公式的序列, 而不是树结构的推导.
本章我们考虑的系统, 正如其他大部分命题逻辑的系统, 仅包含一条证明规则, 其被称为modus ponens或者分离规则:φ φ → ψ ψ 因此, 一个Hilbert风格的证明系统可以被视为与其逻辑公理的集合等同. 以下的定义适用于所有这样的命题系统.
定义5.1.1. 一个公式
φ 的一个证明序列 (或者说一个Hilbert风格的证明) 是一个公式的有限序列
ψ 1 , ψ 2 , … , ψ n 满足
ψ n = φ , 并且对于所有的
i = 1 , … , n ,
要么ψ i 是一条公理, 要么存在j , l < i 满足ψ j = ψ l → ψ i (即ψ i 是由ψ j 和ψ l 通过modus ponens得到的). 如果存在这样一个证明, 那么公式
φ 就被称为一个定理.
定义5.1.2.
定义5.1.5.
( Id ) Γ , φ ⊢ φ ( Ax ) Γ ⊢ φ , 如果 φ 是一条逻辑公理 ( MP ) Γ 1 ⊢ α Γ 2 ⊢ α → β Γ 1 , Γ 2 ⊢ β 图5.1: Hilbert风格系统的树变体
第5.2节 组合子逻辑 Hilbert风格的Curry-Howard等价物该是什么呢?
定义5.2.1. 组合子项的集合
𝒞 定义如下:
所有的对象变量都在𝒞 之中, 即Υ ⊆ 𝒞 . 常量K 和S 都在𝒞 中. 如果G 和H 在𝒞 中, 那么应用( G ⁡ H ) 也在𝒞 中. 第5.3节 带类型的组合子 第5.4节 组合子 vs lambda项 第5.5节 外延性 第5.6节 第5.7节 第5.8节 第6章 古典逻辑和控制运算符 在之前的章节中, 我们已经遇到了化身为各种面目的Curry-Howard同构. 每一种都陈述了某个计算性演算和一个形式逻辑系统之间的对应. 到目前为止, 这些形式逻辑系统都是直觉主义的. 例如, 没有一个能够推导在古典的逻辑中可以看到的双重否定消去原理¬ ¬ φ → φ . 这并非巧合. 事实上, 到大约1990年为止, 许多人相信"并不存在古典逻辑的Curry-Howard同构". 然而, 那个时候Timothy Griffin发现了双重否定消除原理对应于编程语言理论中众所周知的一个控制运算符 的定型. 很快这个想法就经由Chet Murthy得到了推广和完善. 本章呈现了这个发现以及它的一些推论, 例如Kolmogorov从古典逻辑到直觉主义逻辑的双重否定嵌入对应于延续传递风格转换 .
第6.1节 古典命题逻辑 古典逻辑和直觉主义逻辑的不同在于古典逻辑囊括了以下原则:
Tertium non datur (排中律): φ ∨ ¬ φ . 要么φ 成立, 要么φ 不成立.双重否定消除: ¬ ¬ φ → φ . 如果不是φ 不成立的情形, 那么φ 就成立.Peirce律: ( ( φ → ψ ) → φ ) → φ .Reductio ad absurdum: ( ¬ φ → φ ) → φ . 如果假设φ 不成立可以推出φ , 那么φ 必然成立. 古典命题演算 (CPC) 的自然演绎系统是通过将直觉主义版本中的ex falso 规则替换为一个用于进行双重否定消除的规则得到的. 我们研究带有谬的推论性片段; 否定和通常一样还是使用谬定义的.6.1.1. 定义. 推论和谬的古典命题演算的自然演绎呈现NK ⁡ ( → , ⊥ ) 由图6.1的公理和规则定义. 当Γ ⊢ φ 在系统中可以被推导出来时, 我们记Γ ⊢ N φ (有时我们省略N ). 我们使用与第2章一致的术语, 记号和约定.
6.1.2. 例子. 以下是公式( φ → ψ ) → ( ¬ φ → ψ ) → ψ ("分类讨论证明") 的一个推导, 令Γ = { φ → ψ , ¬ φ → ψ , ¬ ψ } .Γ ⊢ ¬ ψ Γ ⊢ ¬ φ → ψ Γ , φ ⊢ ¬ ψ Γ , φ ⊢ φ → ψ Γ , φ ⊢ φ Γ , φ ⊢ ψ Γ , φ ⊢ ⊥ Γ ⊢ ¬ φ Γ ⊢ ψ Γ ⊢ ⊥ φ → ψ , ¬ φ → ψ ⊢ ψ φ → ψ ⊢ ( ¬ φ → ψ ) → ψ ⊢ ( φ → ψ ) → ( ¬ φ → ψ ) → ψ 以下是Peirce律的推导, 令Γ = { ( φ → ψ ) → φ } .Γ , ¬ φ ⊢ ¬ φ Γ , ¬ φ ⊢ ( φ → ψ ) → φ Γ , ¬ φ , φ , ¬ ψ ⊢ ¬ φ Γ , ¬ φ , φ , ¬ ψ ⊢ φ Γ , ¬ φ , φ , ¬ ψ ⊢ ⊥ Γ , ¬ φ , φ ⊢ ψ Γ , ¬ φ ⊢ φ → ψ Γ , ¬ φ ⊢ φ Γ , ¬ φ ⊢ ⊥ Γ ⊢ φ ⊢ ( ( φ → ψ ) → φ ) → φ Γ , φ ⊢ φ ( Ax ) Γ , φ ⊢ ψ Γ ⊢ φ → ψ ( → I ) Γ ⊢ φ → ψ Γ ⊢ φ Γ ⊢ ψ ( → E ) Γ , φ → ⊥ ⊢ ⊥ Γ ⊢ φ ( ¬ E ) 图6.1: 古典命题演算
6.1.3. 例子. ex falso 在NK ⁡ ( → , ⊥ ) 中是一条导出规则. 也就是说, 如果Γ ⊢ ⊥ , 那么也有Γ ⊢ φ .
第6.2节 λ μ 演算 第6.3节 第6.4节 逻辑嵌入和CPS转换 在直觉主义逻辑之中解释古典逻辑, 被称为逻辑嵌入, 自1920年代已被研究. 本节我们研究这样一个嵌入, 其被称为Kolmogorov双重否定转换, 它有一个有趣的计算性解释.
定义6.4.1. (Kolmogorov转换). 按如下方式定义一个转换, 其中α 遍历原子命题:k ⁡ ( α ) = ¬ ¬ α k ⁡ ( φ → ψ ) = ¬ ¬ ( k ⁡ ( φ ) → k ⁡ ( ψ ) ) 而且, k ⁡ ( Γ ) = { k ⁡ ( φ ) | φ ∈ Γ } .
第6.5节 古典证明者怀疑者对话 第6.6节 纯推论片段 第6.7节 合取与析取 第6.8节 注记 第6.9节 练习 第7章 相继式演算 在之前的章节中, 我们已经见过了两种不同类型的证明系统: 自然演绎和Hilbert风格. 每一种都有其优点. 例如, Hilbert风格的形式化是一个从数学角度而言更简单的模型, 而自然演绎的证明在精神上更接近于在数学实践中实际建立的证明.
第三种证明形式化相继式演算 于1930年代由Gerhard Gentzen引入, 自然演绎也是由他引入的. 尽管句法上类似 (至少在某些呈现中), 相继式演算和自然演绎相当不同, 并适用于不同的目的. 尽管自然演绎强调了每个联结词的最基础性质以其引入和消去规则, 相继式演算对于实际证明构造而言是更加合适的工具. 相继式演算的规则 (自下而上阅读) 定义了将复杂公式替换以更简单公式的方法, 最终将最初的任务规约为验证公理. 对于相继式演算而言, 只有引入规则, 而不是引入规则和消去规则. 其中一些规则在一个判断中的⊢ 的右侧引入联结词, 这些规则就类似于自然演绎中的引入规则. 但是, 也有规则在判断的⊢ 的左侧引入联结词, 这些规则代替了自然演绎的消去规则.
在相继式演算中, 我们也会遇到其他新的规则. 相同假设的多重使用 (见第5.6节) 由系统中的显式收缩 规则管理. 类似地, 压根没有用到的假设由削弱 规则管理. 最后, 尽管自然演绎中的绕行 (detour) 由特定的引入和消去规则的序对构成, 相继式演算中存在特定的切 规则来表示绕行. 证明规范化就相当于消除这条规则的应用.
第7.1节 Gentzen的相继式演算LK Gentzen为古典逻辑和直觉主义逻辑都引入了相继式演算; 本节我们呈现一个古典系统. 既然我们非常关心其与自然演绎之间的关系, 而自然演绎一般基于谬(而非否定), 考虑基于谬的相继式演算是比较方便的, 甚至尽管否定才是对于相继式演算而言最为自然的方式.
7.1.1. 定义.
7.1.3. 例子. 这里我们给出一个对于⊢ ( p → q ) → ( q → r ) → ( p → r ) 的推导:p ⊢ p q ⊢ q p , p → q ⊢ q (L→ ) p → q , p ⊢ q (LX) r ⊢ r r , p → q ⊢ r (LW) p → q , r ⊢ r (LX) p → q , r , p ⊢ r (LW) p → q , p , r ⊢ r (LX) p → q , p , q → r ⊢ r (L→ ) p → q , q → r , p ⊢ r (LX) p → q , q → r ⊢ p → r (R→ ) p → q ⊢ ( q → r ) → ( p → r ) (R→ ) ⊢ ( p → q ) → ( q → r ) → ( p → r ) (R→ ) 这个推导利用了结构规则 . 左削弱 规则(LW) 引入了额外的假设,
Axioms: ⊥ ⊢ φ (L⊥ ) φ ⊢ φ (Ax) Structural Rules: Γ ⊢ Σ Γ , φ ⊢ Σ (LW) Γ ⊢ Π Γ ⊢ φ , Π (RW) Γ , φ , ψ , Γ ′ ⊢ Σ Γ , ψ , φ , Γ ′ ⊢ Σ (LX) Γ ⊢ Δ , φ , ψ , Δ ′ Γ ⊢ Δ , ψ , φ , Δ ′ (RX) Γ , φ , φ ⊢ Σ Γ , φ ⊢ Σ (LC) Γ ⊢ φ , φ , Δ Γ ⊢ φ , Δ (RC) Logical Rules: Γ , φ ⊢ Σ Γ , φ ∧ ψ ⊢ Σ (L∧ ) Γ , ψ ⊢ Σ Γ , φ ∧ ψ ⊢ Σ Γ ⊢ φ , Δ Γ ⊢ ψ , Δ Γ ⊢ φ ∧ ψ , Δ (R∧ ) Γ , φ ⊢ Σ Γ , ψ ⊢ Σ Γ , φ ∨ ψ ⊢ Σ (L∨ ) Γ ⊢ φ , Δ Γ ⊢ φ ∨ ψ , Δ (R∨ ) Γ ⊢ ψ , Δ Γ ⊢ φ ∨ ψ , Δ Γ ⊢ φ , Δ Γ , ψ ⊢ Σ Γ , φ → ψ ⊢ Δ , Σ (L→ ) Γ , φ ⊢ ψ , Δ Γ ⊢ φ → ψ , Δ (R→ ) Cut Rule: Γ ⊢ φ , Δ Γ , φ ⊢ Σ Γ ⊢ Δ , Σ (Cut) 图7.1: 古典相继式演算LK
第7.2节 LK的片段 vs 自然演绎 第7.3节 Gentzen的Hauptsatz 第7.4节 切消 vs 正规化 第7.5节 Lorenzen对话 第7.6节 注记 第7.7节 练习 第8章 一阶逻辑 第8.1节 一阶逻辑的句法 8.1.1. 定义. 原子公式 要么是逻辑常量⊥ , 要么是具有形式( r t 1 … t n ) 的表达式, 其中r 是Σ 中一个n 元关系符号, 而t 1 , … , t n 是Σ 上的代数项. 特别地, 每个零元关系符号都构成了一个原子公式.Σ 上的一阶公式 的集合Φ Σ 是满足以下条件的最小集合:所有的原子公式都在Φ Σ 中; 如果φ , ψ ∈ Φ Σ , 那么( φ → ψ ) , ( φ ∨ ψ ) , ( φ ∧ ψ ) ∈ Φ Σ ; 如果φ ∈ Φ Σ 并且a 是一个独立变量, 那么∀ a φ , ∃ a φ ∈ Φ Σ . 和通常一样, ¬ φ 是φ → ⊥ 的缩略, φ ↔ ψ 是( φ → ψ ) ∧ ( ψ → φ ) 的缩略.公式φ 的自由变量集FV ⁡ ( φ ) 的定义如下:FV ⁡ ( r t 1 … t n ) = FV ⁡ ( t 1 ) ∪ ⋯ ∪ FV ⁡ ( t n ) ;FV ⁡ ( φ → ψ ) = FV ⁡ ( φ ∨ ψ ) = FV ⁡ ( φ ∧ ψ ) = FV ⁡ ( φ ) ∪ FV ⁡ ( ψ ) ;FV ⁡ ( ∀ a φ ) = FV ⁡ ( ∃ a φ ) = FV ⁡ ( φ ) − { a } . 也就是说, 量化符号∀ a 和∃ a 绑定了其作用域之中的a . 仅是绑定变量不同的公式是等同的. 如果Γ 是一集公式, 那么FV ⁡ ( Γ ) = ⋃ { FV ⁡ ( γ ) | γ ∈ Γ } . 一个公式是开 的当且仅当其不含有量化符号. 一个句子 , 也被称为封闭 公式, 是不含有自由变量的公式. 如果a 1 , … , a k 是φ 的(以某种固定顺序列出的)自由变量, 那么句子∀ a 1 … ∀ a k φ 被称为φ 的全称闭包 . 从以上定义可以看出一个公式不仅仅是一个
表达式 , 而是一个表达式的
α 等价类, 非常类似于lambda项, 见第1.2节. 我们处理公式上的
α 变换的方式为简单性而妥协了精确性. 为了给出这个定义的一个更加准确的陈述, 我们需要类似于第1.2节的讨论, 诸如
预公式 的概念需要进行刻画. 我们相信读者能够在必要时重构形式化的缺失部分.
实际上, 在逻辑学中将alpha等价的一阶公式视为等同并非惯例. 典型的情况是, 这样的公式被认为是不同的, 尽管相对于任何合理的语义而言它们应该是等价的, 并且在任何合理的证明系统中我们应该能够从一个推出另一个. 但是, 为了呈现的一致性, 我们更愿意在本书讨论的所有逻辑和lambda演算中都默认相对于各种变量绑定的alpha等价性.
8.1.2. 约定. 用于避免括号的
8.1.3. 定义. 替换 一个独立变量以一个项, 记作
φ [ a ≔ t ] , 定义如下:
⊥ [ a ≔ t ] = ⊥ ;( r t 1 … t n ) [ a ≔ t ] = ( r t 1 [ a ≔ t ] … t n [ a ≔ t ] ) ;( φ ∘ ψ ) [ a ≔ t ] = ( φ [ a ≔ t ] ∘ ψ [ a ≔ t ] ) , 其中∘ ∈ { → , ∨ , ∧ } ;( ∇ b φ ) [ a ≔ t ] = ( ∇ b φ [ a ≔ t ] ) , 其中∇ ∈ { ∀ , ∃ } , b ≠ a , b ∉ FV ⁡ ( t ) .同时替换 也可定义, 记作
φ [ a 1 , … , a n ≔ t 1 , … , t n ] , 其方式类似于我们对于lambda项所做的 (见定义1.2.21).
8.1.4. 约定.
第8.2节 非形式化的语义 命题公式的Brouwer-Heyting-Kolmogorov解释 (第2章) 也可被扩展至一阶逻辑. 对此, 我们需要假定独立变量和代数项在特定的对象 的论域中被解释. 既然谓词逻辑表达了这样的对象的性质, 假定解释域非空是很自然的, 即至少存在一个这样的对象. [原注: 在其他牵涉量化的逻辑系统之中, 这种假设并非先验 . 如果我们量化于复合对象 (例如证明) 之上, 那么期望某些量化的论域为空也是合理的. 见评注13.5.1.]
和第2章一样, 原子的解释未加刻画.
第8.3节 证明系统 第8.4节 古典语义 第8.5节 直觉主义逻辑的代数语义 第8.6节 Kripke语义 第8.7节 lambda演算 第8.8节 不可判定性 第8.9节 注记 第8.10节 练习 第9章 一阶算术 算术是所有数学分支都不可避免的一部分. 算术的语言可以用来表达各种具有不同本性的有限对象的性质. 一个具体的例子是, 计算理论中的诸多议题都可以在算术的框架之下讨论. 自从19世纪末Dedekind和Peano的基础性工作起, 算术已经成为逻辑和数学基础中一个主要的研究对象. 本章我们将讨论一阶古典 (Peano) 算术和直觉主义 (Heyting) 算术的基本性质. 我们考虑了各种将算法 (递归函数) 表达为算术的方式, 我们也展示了如何将算术公式实现为 递归函数.
第9.1节 算术的语言 当我们言称算术 时, 我们通常默认隐式的 (underlying) 签名应该由两个二元函数符号+ 和⋅ (分别用于加法和乘法), 一个幺元函数符号s (用于后继), 以及常量0 构成. 然后, 我们还有用于相等的符号= . 我们最初的呈现会遵循这种典型的选择, 但是之后(保守地)扩展这个签名以额外的函数符号会是方便的.
9.1.1. 定义. 算术的标准模型 是自然数集ℕ 并带有对于以上那些符号的通常理解, 意即结构:N = 〈 ℕ , + , ⋅ , s , 0 , = 〉 . 每个数字n ∈ ℕ 在算术的语言中都有一个名字. 数码
第9.2节 Peano算术 第9.3节 Gödel的定理 第9.4节 第9.5节 Heyting算术 第9.6节 Kleene的可实现性解释 第9.7节 注记 第9.8节 练习 第10章 Gödel的系统T 第10.1节 从Heyting算术到系统T 第10.2节 句法 第10.3节 第10.4节 第10.5节 第10.6节 第11章 二阶逻辑和多态 第11.1节 二阶命题逻辑 第11.2节 多态lambda演算 (系统F) 第11.3节 表达力 第11.4节 Curry风格的多态 第11.5节 强规范化 第11.6节 居留问题 第11.7节 高阶多态 第11.8节 注记 第11.9节 练习 第12章 二阶算术 第13章 依赖类型 第14章 纯类型系统和λ 立方 附录A 数学背景 第A.1节 集合论 第A.2节 代数与合一 一个签名是一族函数与关系符号, 其中每个都拥有固定的元数 (可能为零). 零元符号被称为常量. 若不加另外说明, 签名则被认为是有限的.
假定有一个固定的独立变量的无限集合{ a 0 , a 1 , … } . 一个签名Σ 上的一个代数项 (或者就称为项) 要么是一个独立变量, 要么是具有形式( f t 1 … t n ) 的表达式, 其中f 是一个n 元函数符号, 而t 1 , … , t n 是项. 当书写项的时候, 我们经常省略最外面的括号. 符号FV ⁡ ( t ) 代表了所有出现在项t 中的独立变量的集合. 项t 是封闭的当且仅当FV ⁡ ( t ) = ∅ .
一个代数项的形式定义牵扯函数符号的前缀应用. 当然, 从传统上来说一些二元函数符号是以中缀风格书写的, 正常情况下我们就这么做. 我们最喜爱的签名仅包含(中缀)箭头作为唯一的符号. 不难看出这个签名上的代数项可以被视为与简单类型等同, 或者你喜欢的话也可以说是与推论公式等同.
本节我们仅考虑代数签名, 即不包含关系符号的签名. 这样一个签名Σ = { f 1 , … , f n } (其中f i 的元数是r i ) 上的一个代数是一个集合A 以及函数f i A : A r i → A , 即一个系统𝒜 = 〈 A , f 1 A , … , f n A 〉 .
第A.3节 部分递归函数 附录B 部分练习的解答和提示 参考文献 [1] M. Abadi, L. Cardelli, P.-L. Curien, and J.-J. Levy. Explicit substitutions. Journal of Functional Programming, 1(4):375-416, 1991.
[2] A. Abel and T. Altenkirch. A predicative strong normalisation proof for a λ -calculus with interleaving inductive types. In T. Coquand, P. Dybjer, B. Nordström, and J. Smith, editors, Types for Proofs and Programs, International Workshop TYPES'99, volume 1956 of Lecture Notes in Computer Science, pages 21-40. Springer-Verlag, 2000.
[3] H. Abelson and G.J. Sussman with J. Sussman. The Structure and Interpretation of Computer Programs. MIT Press, second edition, 1996.
[4] S. Abramsky. Computational interpretations of linear logic. Theoretical Computer Science, lll(l-2):3-57, 1993.
[5] S. Abramsky and R. Jagadeesan. Games and full completeness for multiplicative linear logic. Journal of Symbolic Logic, 59(2):543-574, 1994.
[6] Z. Adamowicz and P. Zbierski. Logic of Mathematics. A Modern Course of Classical Logic. John Wiley & Sons, 1997.
[7] A. Appel. Compiling with Continuations. Cambridge University Press, 1992.
[8] H. Barendregt and T. Nipkow, editors. Types for Proofs and Programs, International Workshop TYPES'93, volume 806 of Lecture Notes in Computer Science. Springer-Verlag, 1994.
[9] A. Church. A set of postulates for the foundation of logic. Annals of Mathematics, 33(2):346-366, 1932.
[10] A. Church. A set of postulates for the foundation of logic. (Second paper.) Annals of Mathematics, 34(4):839-864, 1933.
[11] R.O. Gandy. The simple theory of types. In R.O. Gandy and J.M.E. Hyland, editors, Logic Colloquium 76, volume 87 of Studies in Logic and the Foundations of Mathematics, pages 173-181. North-Holland, 1977.
[12] F. Kamareddine, T. Laan, and R. Nederpelt. Types in logic and mathematics before 1940. Bulletin of Symbolic Logic, 8(2):185-245, 2002.
[13] A. Church. A formulation of the simple theory of types. Journal of Symbolic Logic, 5(2):56-68, 1940.
[14] H.B. Curry. Functionality in combinatory logic. Proceedings of the National Academy of Science USA, 20(ll):584-590, 1934.
[15] H.B. Curry. The inconsistency of the full theory of combinatory functionality. Journal of Symbolic Logic, 20(1):91, 1955.
[16] H.B. Curry. Consistency of the theory of functionality. Journal of Symbolic Logic, 21(1):110, 1956.
[17] P. Graham. ANSI Common Lisp. Prentice-Hall, 1995.
[18] F. Pfenning and C. Elliot. Higher-order abstract syntax. In Programming Language Design and Implementation, pages 199-208. ACM Press, 1988.
[19] A. Pitts. Nominal logic: A first order theory of names and binding. Information and Computation, 186(2):165-193, 2003.
[20] J.P. Seldin. Curry's anticipation of the types used in programming languages. In Proceedings of the Annual Meeting of the Canadian Society for History and Philosophy of Mathematics, Toronto, 24-26 May 2002, pages 148-163, 2003.
[21] J.P. Seldin. Church and Curry: The lambda calculus and combinatory logic. In Gabbay and Woods [159]. To appear.
[22] J.R. Hindley. Basic Simple Type Theory, volume 42 of Cambridge Tracts in Theoretical Computer Science. Cambridge University Press, 1997.
[23] L.C. Paulson. ML for the Working Programmer. Cambridge University Press, second edition, 1996.
[24] R. Pollack. Closure under alpha-conversion. In Barendregt and Nipkow
[8 ] , pages 313-332.
[25] D. Prawitz. Natural Deduction. A Proof Theoretical Study. Almqvist & Wiksell, 1965.