harper_book_Chapter_2---归纳定义

本文深入探讨了归纳定义在编程语言中的作用,介绍了判断、推理规则和派生的概念。通过引理和定理,阐述了归纳定义如何用于证明自然数的性质,如前后继关系的单射性。同时,讨论了迭代和同步归纳定义,以及如何通过规则定义函数,如自然数的加法。归纳定义和规则归纳法是理解抽象绑定树和自然数属性的关键工具。
摘要由CSDN通过智能技术生成

归纳定义是学习编程语言不可缺少的工具。在这一章中,我们将发展归纳定义的基本框架,并给出一些使用它们的例子。归纳定义由一组规则组成,用于派生各种形式的判断或断言。判断是关于一个或多个某种抽象绑定树的语句。这些规则规定了判断有效的必要和充分条件,从而充分确定了判断的意义。

2.1. 判断

我们从抽象绑定树的判断或断言的概念开始。我们将使用许多形式的判断,包括这些例子:

               n   nat                                                         n  is  a  natural  number

               n_1+n_2=n                                               n  is  the  sum  of  n_1  and  n_2

               \zeta   type                                                        \zeta  is  a  type

               e:\zeta                                                             expression  e  has  type  \zeta

               e\Downarrow v                                                            expression  e  has  value  v

一个判断表明一个或多个抽象的约束树具有某种属性或彼此之间存在某种关系。属性或关系本身被称为判断形式,而判断一个或多个对象具有该属性或处于该关系中,则被称为该判断形式的一个实例。判断形式也叫做谓词,构成一个实例的对象就是它的主语。我们写一个JJa,来表示J持有abt  a的判断。相应地,我们有时以符号表示的判断形式−J-J,或J-,用破折号表示缺乏论证J .当它并不重要强调的主题的判断,我们写J代表一个未指明的判断,也就是说,一些判断形式的实例。对于特定的判断形式,我们可以自由地使用前缀、中缀或混合固定表示法(如上面的示例所示),以增强可读性。

2.2. 推理规则

判断形式的归纳定义由判断形式的规则集合构成

                                                                     \frac{J_1...J_k}{J}                                                                             (2.1)

其中JJ_1,...,J_k是所有被定义的形式的判断。横线以上的判断称为定则的前提,横线以下的判断称为定则的结论。如果一个规则没有前提(也就是说,当k=0时),这个规则就称为公理;否则,它被称为一个适当的规则。

推理规则可以被理解为,前提对于结论是充分的:为

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值