Z3:将 int 排序转换为位向量

Tin*_*hen 4 integer bitvector smt z3

:变量 x 被定义为 int 排序方式 (declare-const x Int)

有什么方法可以将 x 转换为位向量排序吗?因为有时x涉及到int理论无法处理的&、|、^等位运算。

我不想一开始就将变量 x 定义为位向量,因为我认为 int 理论支持的运算(例如,+、-、*、/)除了位运算之外,运行速度比位向量支持的运算快得多。

所以实际上,我想根据需要将 int 排序转换为位向量排序,反之亦然。

Tay*_*son 5

是的,您可以使用诸如bv2int和 之类的东西int2bv。请注意,位向量长度很重要,并且 int2bv 是参数化的(需要位向量长度)。

这是一个最小的例子(rise4fun链接: http: //rise4fun.com/Z3/wxcp):

(declare-fun x () (_ BitVec 32))
(declare-fun y () Int)
(declare-fun z () (_ BitVec 16))
(assert (= y 129))
(assert (= (bv2int x) y))
; (assert (= ((_ int2bv 32) y) x)) ; try with this uncommented
(assert (= ((_ int2bv 16) y) z))
(check-sat)
(get-model)
(get-value (x y z)) ; gives ((x #x00000000) (y 129) (z #x0081))
Run Code Online (Sandbox Code Playgroud)

另一个例子在这里:

Z3:int2bv 的异常

目前看来这些功能可能存在一些问题:使用 Z3 检查溢出

bv2nat这些也可能在其他求解器(和)中以不同的名称调用nat2bvhttp://smtlib.cs.uiowa.edu/theories/FixedSizeBitVectors.smt2