首页 > 解决方案 > Z3 探测包含某个变量的子句

问题描述

我有一个问题,我有超过 50 个不同数组的约束。我想应用一种策略,只简化包含某个数组的约束:例如

g = Goal()
a = Array("a", IntSort(), IntSort())
b = Array("b", IntSort(), IntSort())
g.add(a[0] == 0)
g.add(a[0] == b[1])
g.add(b[2] == b[1])

p = Probe('contains-var')
t = If(p[a], 'ctx-simplify', 'skip')
t(g)

应该简化为

[[a[0] == 0, 0 == b[1], b[2] == b[1]]

这可能吗?

标签: z3smtz3py

解决方案


推荐阅读