- 1、本文档共32页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第7课程序验证
中国科大 第7章 程序验证 内容概述 程序逻辑:描述和论证程序行为的逻辑 Hoare逻辑 Dijkstra最弱前条件演算 从程序到定理 验证条件生成 从定理到证明 定理证明器 判定过程 循环不变式的推断 以George C. Necula教授的讲稿为主来介绍 程 序 逻 辑 Hoare逻辑 良形公式(well-formed formula)的形式为 { P } C { Q } C是程序片段 需要介绍编程语言 P 和Q是断言 需要介绍断言及推理规则 { P } C { Q }称为程序规范 需要介绍规范语言及推理规则 Hoare逻辑也称为语言的一种公理语义 作为例子的核心编程语言 语法 整数表达式 E ::= n | x | ?E | E + E | E ? E | E ? E | ( E ) 布尔表达式 B ::= true | false | !B | B B | B || B | E E | ( B ) 命令 C ::= x = E | C ; C | if B { C } else { C } | while B { C } 例子 y = 1; z = 0; while (z != x) { z = z +1; y = y ? z } Hoare逻辑 断言语言 用来描述程序变量满足的性质,如x==5, x+y 30 通常,断言P, Q的语法同编程语言布尔表达式的语法有些区别:如可以出现量词 Hoare逻辑的良形公式 { P } C { Q } C是一段程序,P和Q分别是C的前条件和后条件 例如 { x == 5 } x = x + 1 { x == 6 } Hoare逻辑 Hoare逻辑良形公式{ P } C { Q }的解释 部分正确性 在满足P的任何状态下执行C,若C终止则结果状态一定满足Q。记作 ? ?par { P } C { Q } 完全正确性 在满足P的任何状态下执行C,则C一定终止并且结果状态一定满足Q。记作 ? ?tot { P } C { Q } 通常建议用部分正确性证明+终止性证明来得到完全正确性证明 Hoare逻辑 ? 例1 Succ ? 例2 Fac1 { ? } { x = 0 } a = x + 1; y = 1; if (a -1 == 0 ) { z = 0; y = 1; while ( z != x ) { } else { z = z + 1; y = a; y = y ? z; } } { y == x + 1 } { y == x ! } Hoare逻辑 ? 例2 Fac1 ? 例3 Fac2 { x = 0 } x0是辅助的逻辑变量 y = 1; { x = 0 ? x == x0 } z = 0; y = 1; while ( z != x ) { while ( x != 0 ) { z = z + 1; y = y ? x; y = y ? z; x = x ? 1; } } { y == x ! } { y == x0 ! } Hoare逻辑 部分正确性的证明规则 赋值公理 赋值公理的实例 { 2 == 2 } x = 2 { x == 2 } { 2 == 4 } x = 2 { x == 4 } { 2 == y } x = 2 { x == y } { 2 0 } x = 2 { x 0 } { x + 1 + 5 == y } x = x + 1 { x + 5 ==y } { x + 1 0 ? y 0 } x = x + 1 { x 0 ? y 0 } Hoare逻辑 部分正确性的证明规则 赋值公理 复合规则 条件规则 循环规则 Hoare逻辑 部分正确性的证明规则 推论规则 ?AR P?? P 表示P?? P在谓词逻辑的自然演绎演 算中可以证明 Hoare逻辑 n = 0 function mult(m, n) { { (0 == m?0) ? (0 = n) } x = 0 ; { (x == m?0) ? (0 = n) } y = 0 ; { (x == m?y) ? (y = n) } while y n do { { (x+m == m?(y+1)) ? ((y+1) = n) } x = x + m ; { (x == m?(y+1)) ? ((y+1) = n) } y = y + 1 ; { (x == m?y) ? (y = n) }
您可能关注的文档
- 第18课股权估价模型.ppt
- 第1课sas初阶.doc
- 第1课原子与化学反应.doc
- 第1课 数控加工实用基础.ppt
- 第19课支原体衣原体立克次体.doc
- 第1课多媒体技术概论 - 科学出版社职教技术出版中心.ppt
- 第1课短信订购及上行协议 - 任信了.doc
- 第19课大数据与视频监控.doc
- 第17课印制板质量与标准.ppt
- 第1课课 - 济南大学材料学院.doc
- DB23_T 3866-2024冰上龙舟赛事组织服务规范.docx
- DB32 2163-2012 棉纱单位可比综合电耗限额及计算方法.docx
- DB32∕T 2429-2013 棉花田间生长发育观察记载规范.docx
- DB23_T 3820-2024 工业互联网综合平台数据质量管理规范.docx
- DB23_T 3474-2023非煤智慧矿山信息系统技术规范.docx
- DB3201_T 1106-2022 工程地质层划分技术规范.docx
- DB33T 2515-2022公共机构“零碳”管理与评价规范.docx
- DB3301_T 0415-2023 装修垃圾收运处置管理规范.docx
- DB3311/T 106―2019“丽水山居”民宿服务要求与评价规范.docx
- DB3201T 1127-2022 慈善捐赠受赠管理规范.docx
最近下载
- 金蝶云苍穹考试认证理论考题汇总(精华版).pdf VIP
- 钢梯设计图集15J401.pdf VIP
- 在项目规划评审会上的致辞发言3.docx
- 建筑工程图集 G410-1~2:1.5m×6.0m预应力混凝土屋面板(2004年合订本).pdf VIP
- 《康复评定技术》课件——第十七章 常见神经疾病的评定技术.ppt VIP
- 山东省水产品出口贸易现状、问题及对策分析.docx VIP
- 2025年上海黄浦区中考模拟语文试卷(含答案) .pdf VIP
- 《综合与实践:白昼时长规律的探究》教案.docx VIP
- 2025年妇产科护理技术规范.pdf VIP
- 施工现场高温季节安全防护与防暑管理培训.pptx VIP
文档评论(0)