29、单项式和子句谓词抽象的复杂性与算法

单项式和子句谓词抽象的复杂性与算法

1. 引言

在程序验证领域,推断循环不变式是一个关键问题。为了降低推断的复杂度,人们提出了多种抽象技术,如谓词抽象和模板抽象。本文将聚焦于两种受限的抽象问题:单项式抽象和子句抽象,并探讨它们的复杂性和相关算法。

2. 背景知识
2.1 无循环程序的简单编程语言

我们使用一种简单的无循环编程语言SimpPL,它支持标量变量(Scalars)和可变映射或数组(Maps)。该语言支持对标量表达式(Expr)进行算术运算,对数组表达式(MapExpr)进行选择 - 更新推理。以下是该语言的语法定义:

x, y ∈ Scalars
X, Y ∈ Maps
e ∈ Expr ::= x | c | e ± e | sel(E, e)
E ∈ MapExpr ::= X | upd(E, e, e)
s, t ∈ Stmt ::= skip | assert φ | assume φ | x := e | X := E | havoc x | havoc X | s; s | s ⋄ s
φ, ψ ∈ Formula ::= e ≤ e | φ ∧ φ | ¬φ | ...

其中, sel upd 是用于选择或更新数组的解释符号。 havoc 操作会为其参数分配一个类型一致(标量或映射)的任意值。 s; t 表示两个语句的顺序组合, s ⋄ t 表示非确定

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值