- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一个将位 vector 公式转换为命题逻辑形式的函数。一种称为“位爆炸”的策略将此类位 vector 表达式处理为 PL 形式。
我一直在尝试创建一个接受位 vector 表达式并对其应用位爆炸策略的程序。但是由于我是这个主题的新手,所以我无法弄清楚如何在对表达式进行位爆破后打印出输出。
#include<z3++.h>
#include<iostream>
using namespace std;
using namespace z3;
int main()
{ context c;
tactic t = tactic(c, "bit-blast");
expr x = c.bv_const("x", 16);
expr y = c.bv_const("y", 16);
expr z = c.bv_const("z", 16);
goal g(c);
g.add(z == x + y);
std::cout<<g;
}
这是我试过的代码,但它不接受表达式“z = x + y”但是我做的过程是正确的吗?如果不是,我应该如何在对其应用 bit-blast 后打印出表达式。?
谢谢。
最佳答案
使用==
,而不是=
。即,z == x + y
。然后,您当然必须应用策略:
#include<z3++.h>
#include<iostream>
using namespace std;
using namespace z3;
int main()
{ context c;
tactic t = tactic(c, "bit-blast");
expr x = c.bv_const("x", 16);
expr y = c.bv_const("y", 16);
expr z = c.bv_const("z", 16);
goal g(c);
g.add(z == x + y);
apply_result r = t(g);
std::cout << r << endl;
return 0;
}
这会打印经过位爆破的目标;太长了就不放了。
如果你想提取实际的表达式,你需要做更多的编程。 (顺便说一句:您确实需要先研究 API https://z3prover.github.io/api/html/z3_09_09_8h_source.html。)
这是一个示例(我正在更改原始表达式,因此输出足够小以便于理解。):
#include<z3++.h>
#include<iostream>
using namespace std;
using namespace z3;
int main()
{ context c;
tactic t = tactic(c, "bit-blast");
expr x = c.bv_const("x", 2);
expr y = c.bv_const("y", 2);
goal g(c);
g.add(y == ~x);
apply_result r = t(g);
if(r.size() > 0)
{
expr res = r[0].as_expr();
cout << res << endl;
}
else
{
cout << "tactic failed" << endl;
}
return 0;
}
这打印:
$ c++ a.cpp -lz3; ./a.out
(and (not (= k!0 k!2)) (not (= k!1 k!3)))
是的,你会得到 k!0
等作为索引,这对你来说很难关联回你的 x
和 y
;但这是不可避免的:bit-blaster 将引入新变量,并且 API 具有重建所需内容的所有细节:https://z3prover.github.io/api/html/z3_09_09_8h_source.html
关于c++ - 如何使用 'bit-blast' 方法以命题逻辑形式打印给定的公式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56819440/
前言请注意,这是一项作业。第一个问题已经问了一个问题。所以我们有数据类型: data BoolProp : ??? where ptrue : BoolProp true pfalse :
我是依赖类型的新手,有 Haskell 经验,正在慢慢学习 Idris。作为练习,我想编写霍夫曼编码。目前我正在尝试编写一个证明,证明代码树的“扁平化”会产生一个前缀代码,但被量词卡住了。 我有一个简
我是一名优秀的程序员,十分优秀!