Z3 如何将 expr 转换为 SMT?

How does Z3 convert expr to SMT?

在尝试了解 Z3 工具时,我对 Z3 如何构造表达式感到困惑。 另外,我是新手,我已经看过相关的问题,但他们没有回答我的问题。

使用Z3,(比如cpp实现),假设有一个表达式

expr e1=((x[0]=tru && y[0]!=tru)||(x[0]!=tru &&y[0]=tru));

其中 tru 是重言式。

打印此表达式时,该工具显示以下树:

 (let ((a!1 (and (or x0 (not x0)) (distinct y0 (or x0 (not x0))))))
      (or a!1 (or x0 (not x0))))

这不是我想要我的 e1 代表的。这似乎是我所写内容的efficient/pretty/shorthand。

首先,我能否以某种方式自己将 expr 转换为 SMT,以便检查它是否被正确翻译?

其次,有没有办法以我表示的简单方式打印表达式,而不是以 SMT 语言的有效结构(使用子树,如 a!1 等)?也许我可以关闭一个开关?这可能需要对该工具有深入的了解,因此我相应地标记了这个问题。

有些"translation"是不可避免的。当 Z3 为您的表达式构建解析树时,它会将它们重写为内部形式。这不仅仅是为了"efficiency."还有一些表面形式只是没有内部表示,而是被重写了。

当然,漂亮的印刷是另一回事。有很多方法可以控制漂亮打印的完成方式。如果您 运行 z3 -p 并查看漂亮打印部分的输出,您会看到:

[module] pp, description: pretty printer
    bounded (bool) (default: false)
    bv_literals (bool) (default: true)
    bv_neg (bool) (default: false)
    decimal (bool) (default: false)
    decimal_precision (unsigned int) (default: 10)
    fixed_indent (bool) (default: false)
    flat_assoc (bool) (default: true)
    fp_real_literals (bool) (default: false)
    max_depth (unsigned int) (default: 5)
    max_indent (unsigned int) (default: 4294967295)
    max_num_lines (unsigned int) (default: 4294967295)
    max_ribbon (unsigned int) (default: 80)
    max_width (unsigned int) (default: 80)
    min_alias_size (unsigned int) (default: 10)
    pretty_proof (bool) (default: false)
    simplify_implies (bool) (default: true)
    single_line (bool) (default: false)

您可以尝试使用这些设置来控制漂亮打印的完成方式,这可能更符合您的需求。特别是,根据您的问题描述,我建议设置以下两个参数:

    pp.max_depth      --> 4294967295
    pp.min_alias_size --> 4294967295

(数字并不重要,只要使它们足够大即可。)这两个设置应避免漂亮打印机创建 a!1 子树,如您所见。

不幸的是,这些选项的确切含义并没有得到很好的记录。其中一些,您可以从他们的名字中猜出,其他的您可以尝试一下,看看它们的影响是什么。但是,如果您真的想知道它们如何更改输出,则必须深入研究 z3 源代码本身。祝你好运!