3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-14 21:08:46 +00:00

z3str3: mk_value searches equivalence class of terms for candidate model variables

This commit is contained in:
Murphy Berzish 2020-02-04 13:11:48 -05:00 committed by Nikolaj Bjorner
parent 69cab61de3
commit 4535228fe2
2 changed files with 42 additions and 2 deletions

View file

@ -9621,6 +9621,21 @@ namespace smt {
if (hasEqc) {
return to_app(n_eqc);
} else {
theory_var curr = get_var(n);
if (curr != null_theory_var) {
curr = m_find.find(curr);
theory_var first = curr;
do {
expr* a = get_ast(curr);
zstring val;
if (candidate_model.find(a, val)) {
return to_app(mk_string(val));
}
curr = m_find.next(curr);
}
while (curr != first && curr != null_theory_var);
}
// fail to find
return nullptr;
}
}

View file

@ -28,6 +28,7 @@
#include "ast/rewriter/seq_rewriter.h"
#include "ast/rewriter/expr_replacer.h"
#include "smt_kernel.h"
#include "model/model_smt2_pp.h"
namespace smt {
@ -641,7 +642,7 @@ namespace smt {
bool len_exists = v.get_value(arg2, len);
ENSURE(pos_exists);
ENSURE(len_exists);
TRACE("str_fl", tout << "reduce substring term: base=" << mk_pp(term, m) << ", pos=" << pos.to_string() << ", len=" << len.to_string() << std::endl;);
TRACE("str_fl", tout << "reduce substring term: base=" << mk_pp(term, m) << " (length="<<base_chars.size()<<"), pos=" << pos.to_string() << ", len=" << len.to_string() << std::endl;);
// Case 1: pos < 0 or pos >= strlen(base) or len < 0
// ==> (Substr ...) = ""
if (pos.is_neg() || pos >= rational(base_chars.size()) || len.is_neg()) {
@ -954,6 +955,23 @@ namespace smt {
precondition.push_back(m.mk_eq(u.str.mk_length(var), mk_int(e.get_value())));
}
TRACE_CODE(
if(is_trace_enabled("str_fl")) {
tout << "formulas asserted to bitvector subsolver:" << std::endl;
for (auto e : fixed_length_assumptions) {
tout << mk_pp(e, subsolver.m()) << std::endl;
}
tout << "variable to character mappings:" << std::endl;
for (auto &entry : var_to_char_subterm_map) {
tout << mk_pp(entry.m_key, get_manager()) << ":";
for (auto e : entry.m_value) {
tout << " " << mk_pp(e, subsolver.m());
}
tout << std::endl;
}
}
);
TRACE("str_fl", tout << "calling subsolver" << std::endl;);
lbool subproblem_status = subsolver.check(fixed_length_assumptions);
@ -966,7 +984,7 @@ namespace smt {
expr_substitution subst(m);
// model_smt2_pp(std::cout, m, *subModel, 2);
//model_smt2_pp(std::cout, m, *subModel, 2);
for (auto entry : var_to_char_subterm_map) {
svector<unsigned> assignment;
expr * var = entry.m_key;
@ -984,6 +1002,13 @@ namespace smt {
model.insert(var, strValue);
subst.insert(var, mk_string(strValue));
}
TRACE_CODE(
if (is_trace_enabled("str_fl")) {
for (auto entry : model) {
tout << mk_pp(entry.m_key, m) << " = " << entry.m_value << std::endl;
}
}
);
for (auto entry : uninterpreted_to_char_subterm_map) {
svector<unsigned> assignment;
expr * var = entry.m_key;