mirror of
https://github.com/Z3Prover/z3
synced 2025-04-15 13:28:47 +00:00
Merge branch 'master' of https://github.com/Z3Prover/z3
This commit is contained in:
commit
9aaee8616a
|
@ -249,6 +249,7 @@ void grobner::update_order() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool grobner::var_lt::operator()(expr * v1, expr * v2) const {
|
bool grobner::var_lt::operator()(expr * v1, expr * v2) const {
|
||||||
|
if (v1 == v2) return false;
|
||||||
int w1 = 0;
|
int w1 = 0;
|
||||||
int w2 = 0;
|
int w2 = 0;
|
||||||
m_var2weight.find(v1, w1);
|
m_var2weight.find(v1, w1);
|
||||||
|
@ -268,6 +269,8 @@ bool grobner::monomial_lt::operator()(monomial * m1, monomial * m2) const {
|
||||||
for (; it1 != end1; ++it1, ++it2) {
|
for (; it1 != end1; ++it1, ++it2) {
|
||||||
expr * v1 = *it1;
|
expr * v1 = *it1;
|
||||||
expr * v2 = *it2;
|
expr * v2 = *it2;
|
||||||
|
if (v1 == v2)
|
||||||
|
continue;
|
||||||
if (m_var_lt(v1, v2))
|
if (m_var_lt(v1, v2))
|
||||||
return true;
|
return true;
|
||||||
if (v1 != v2)
|
if (v1 != v2)
|
||||||
|
|
|
@ -259,6 +259,8 @@ struct evaluator_cfg : public default_rewriter_cfg {
|
||||||
|
|
||||||
|
|
||||||
br_status mk_array_eq(expr* a, expr* b, expr_ref& result) {
|
br_status mk_array_eq(expr* a, expr* b, expr_ref& result) {
|
||||||
|
return BR_FAILED;
|
||||||
|
// disabled until made more efficient
|
||||||
if (a == b) {
|
if (a == b) {
|
||||||
result = m().mk_true();
|
result = m().mk_true();
|
||||||
return BR_DONE;
|
return BR_DONE;
|
||||||
|
@ -271,6 +273,7 @@ struct evaluator_cfg : public default_rewriter_cfg {
|
||||||
conj.push_back(m().mk_eq(else1, else2));
|
conj.push_back(m().mk_eq(else1, else2));
|
||||||
args1.push_back(a);
|
args1.push_back(a);
|
||||||
args2.push_back(b);
|
args2.push_back(b);
|
||||||
|
// TBD: this is too inefficient.
|
||||||
for (unsigned i = 0; i < stores.size(); ++i) {
|
for (unsigned i = 0; i < stores.size(); ++i) {
|
||||||
args1.resize(1); args1.append(stores[i].size() - 1, stores[i].c_ptr());
|
args1.resize(1); args1.append(stores[i].size() - 1, stores[i].c_ptr());
|
||||||
args2.resize(1); args2.append(stores[i].size() - 1, stores[i].c_ptr());
|
args2.resize(1); args2.append(stores[i].size() - 1, stores[i].c_ptr());
|
||||||
|
|
Loading…
Reference in a new issue