mirror of
https://github.com/Z3Prover/z3
synced 2025-08-28 05:58:55 +00:00
keep
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
commit
147b3600d9
29 changed files with 239 additions and 120 deletions
|
@ -325,7 +325,7 @@ namespace {
|
|||
ast_manager & m_manager;
|
||||
ptr_vector<expr> m_queue;
|
||||
unsigned m_head;
|
||||
int m_bs_num_bool_vars; //!< Number of boolean variable before starting to search.
|
||||
bool_var m_bs_num_bool_vars; //!< Number of boolean variable before starting to search.
|
||||
ptr_vector<expr> m_queue2;
|
||||
unsigned m_head2;
|
||||
svector<scope> m_scopes;
|
||||
|
@ -513,7 +513,7 @@ namespace {
|
|||
smt_params &m_params;
|
||||
ptr_vector<expr> m_queue;
|
||||
unsigned m_head;
|
||||
int m_bs_num_bool_vars; //!< Number of boolean variable before starting to search.
|
||||
bool_var m_bs_num_bool_vars; //!< Number of boolean variable before starting to search.
|
||||
bool_var_act_queue m_delayed_queue;
|
||||
svector<scope> m_scopes;
|
||||
public:
|
||||
|
@ -745,7 +745,7 @@ namespace {
|
|||
ast_manager & m_manager;
|
||||
ptr_vector<expr> m_queue;
|
||||
unsigned m_head;
|
||||
int m_bs_num_bool_vars; //!< Number of boolean variable before starting to search.
|
||||
bool_var m_bs_num_bool_vars; //!< Number of boolean variable before starting to search.
|
||||
svector<queue_entry> m_queue2;
|
||||
svector<scope> m_scopes;
|
||||
unsigned m_current_generation;
|
||||
|
|
|
@ -1395,7 +1395,7 @@ namespace smt {
|
|||
SASSERT(get_bdata(v).is_enode());
|
||||
lbool val = get_assignment(v);
|
||||
TRACE("propagate_bool_var_enode_bug", tout << "var: " << v << " #" << bool_var2expr(v)->get_id() << "\n";);
|
||||
SASSERT(v < static_cast<int>(m_b_internalized_stack.size()));
|
||||
SASSERT(v < m_b_internalized_stack.size());
|
||||
enode * n = bool_var2enode(v);
|
||||
|
||||
CTRACE("mk_bool_var", !n, tout << "No enode for " << v << "\n";);
|
||||
|
@ -1986,7 +1986,7 @@ namespace smt {
|
|||
void context::remove_lit_occs(clause const& cls, unsigned nbv) {
|
||||
if (!track_occs()) return;
|
||||
for (literal l : cls) {
|
||||
if (l.var() < static_cast<int>(nbv))
|
||||
if (l.var() < nbv)
|
||||
dec_ref(l);
|
||||
}
|
||||
}
|
||||
|
@ -2264,7 +2264,7 @@ namespace smt {
|
|||
SASSERT(cls->get_num_atoms() == cls->get_num_literals());
|
||||
for (unsigned j = 0; j < 2; j++) {
|
||||
literal l = cls->get_literal(j);
|
||||
if (l.var() < static_cast<int>(num_bool_vars)) {
|
||||
if (l.var() < num_bool_vars) {
|
||||
// This boolean variable was not deleted during backtracking
|
||||
//
|
||||
// So, it is still a watch literal. I remove the watch, since
|
||||
|
@ -4096,7 +4096,7 @@ namespace smt {
|
|||
expr * * atoms = m_conflict_resolution->get_lemma_atoms();
|
||||
for (unsigned i = 0; i < num_lits; i++) {
|
||||
literal l = lits[i];
|
||||
if (l.var() >= static_cast<int>(num_bool_vars)) {
|
||||
if (l.var() >= num_bool_vars) {
|
||||
// This boolean variable was deleted during backtracking, it need to be recreated.
|
||||
// Remark: atom may be a negative literal (not a). Z3 creates Boolean variables for not-gates that
|
||||
// are nested in terms. Example: let f be a uninterpreted function from Bool -> Int.
|
||||
|
|
|
@ -263,7 +263,7 @@ namespace smt {
|
|||
*/
|
||||
bool context::check_th_diseq_propagation() const {
|
||||
TRACE("check_th_diseq_propagation", tout << "m_propagated_th_diseqs.size() " << m_propagated_th_diseqs.size() << "\n";);
|
||||
int num = get_num_bool_vars();
|
||||
unsigned num = get_num_bool_vars();
|
||||
if (inconsistent() || get_manager().limit().is_canceled()) {
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -296,7 +296,7 @@ namespace smt {
|
|||
|
||||
void context::display_hot_bool_vars(std::ostream & out) const {
|
||||
out << "hot bool vars:\n";
|
||||
int num = get_num_bool_vars();
|
||||
unsigned num = get_num_bool_vars();
|
||||
for (bool_var v = 0; v < num; v++) {
|
||||
double val = get_activity(v)/m_bvar_inc;
|
||||
if (val > 10.00) {
|
||||
|
|
|
@ -22,6 +22,7 @@ Revision History:
|
|||
#include "util/vector.h"
|
||||
#include "util/hashtable.h"
|
||||
#include "util/lbool.h"
|
||||
#include "util/sat_literal.h"
|
||||
|
||||
class model;
|
||||
|
||||
|
@ -29,9 +30,9 @@ namespace smt {
|
|||
/**
|
||||
\brief A boolean variable is just an integer.
|
||||
*/
|
||||
typedef int bool_var;
|
||||
typedef sat::bool_var bool_var;
|
||||
|
||||
const bool_var null_bool_var = -1;
|
||||
const bool_var null_bool_var = sat::null_bool_var;
|
||||
const bool_var true_bool_var = 0;
|
||||
const bool_var first_bool_var = 1;
|
||||
|
||||
|
|
|
@ -190,8 +190,7 @@ namespace smt {
|
|||
}
|
||||
|
||||
expr * theory_str::mk_string(const char * str) {
|
||||
symbol sym(str);
|
||||
return u.str.mk_string(sym);
|
||||
return u.str.mk_string(str);
|
||||
}
|
||||
|
||||
void theory_str::collect_statistics(::statistics & st) const {
|
||||
|
|
|
@ -53,11 +53,11 @@ public:
|
|||
u(m), delim("!"), m_next(0) {}
|
||||
~str_value_factory() override {}
|
||||
expr * get_some_value(sort * s) override {
|
||||
return u.str.mk_string(symbol("some value"));
|
||||
return u.str.mk_string("some value");
|
||||
}
|
||||
bool get_some_values(sort * s, expr_ref & v1, expr_ref & v2) override {
|
||||
v1 = u.str.mk_string(symbol("value 1"));
|
||||
v2 = u.str.mk_string(symbol("value 2"));
|
||||
v1 = u.str.mk_string("value 1");
|
||||
v2 = u.str.mk_string("value 2");
|
||||
return true;
|
||||
}
|
||||
expr * get_fresh_value(sort * s) override {
|
||||
|
@ -65,10 +65,11 @@ public:
|
|||
while (true) {
|
||||
std::ostringstream strm;
|
||||
strm << delim << std::hex << (m_next++) << std::dec << delim;
|
||||
symbol sym(strm.str());
|
||||
std::string s(strm.str());
|
||||
symbol sym(s);
|
||||
if (m_strings.contains(sym)) continue;
|
||||
m_strings.insert(sym);
|
||||
return u.str.mk_string(sym);
|
||||
return u.str.mk_string(s);
|
||||
}
|
||||
}
|
||||
sort* seq = nullptr;
|
||||
|
|
|
@ -1337,9 +1337,8 @@ namespace smt {
|
|||
rw(arg_subst);
|
||||
TRACE("str_fl", tout << "ival = " << ival << ", string arg evaluates to " << mk_pp(arg_subst, m) << std::endl;);
|
||||
|
||||
symbol arg_str;
|
||||
if (u.str.is_string(arg_subst, arg_str)) {
|
||||
zstring arg_zstr(arg_str.bare_str());
|
||||
zstring arg_zstr;
|
||||
if (u.str.is_string(arg_subst, arg_zstr)) {
|
||||
rational arg_value;
|
||||
if (string_integer_conversion_valid(arg_zstr, arg_value)) {
|
||||
if (ival != arg_value) {
|
||||
|
@ -1365,9 +1364,8 @@ namespace smt {
|
|||
(*replacer)(arg, arg_subst);
|
||||
rw(arg_subst);
|
||||
TRACE("str_fl", tout << "ival = " << ival << ", string arg evaluates to " << mk_pp(arg_subst, m) << std::endl;);
|
||||
symbol arg_str;
|
||||
if (u.str.is_string(arg_subst, arg_str)) {
|
||||
zstring arg_zstr(arg_str.bare_str());
|
||||
zstring arg_zstr;
|
||||
if (u.str.is_string(arg_subst, arg_zstr)) {
|
||||
if (ival >= rational::zero() && ival <= rational(u.max_char())) {
|
||||
// check that arg_subst has length 1 and that the codepoints are the same
|
||||
if (arg_zstr.length() != 1 || rational(arg_zstr[0]) != ival) {
|
||||
|
@ -1396,9 +1394,8 @@ namespace smt {
|
|||
rw(e_subst);
|
||||
TRACE("str_fl", tout << "ival = " << ival << ", string arg evaluates to " << mk_pp(e_subst, m) << std::endl;);
|
||||
|
||||
symbol e_str;
|
||||
if (u.str.is_string(e_subst, e_str)) {
|
||||
zstring e_zstr(e_str.bare_str());
|
||||
zstring e_zstr;
|
||||
if (u.str.is_string(e_subst, e_zstr)) {
|
||||
// if arg is negative, e must be empty
|
||||
// if arg is non-negative, e must be valid AND cannot contain leading zeroes
|
||||
|
||||
|
@ -1436,9 +1433,8 @@ namespace smt {
|
|||
(*replacer)(e, e_subst);
|
||||
rw(e_subst);
|
||||
TRACE("str_fl", tout << "ival = " << ival << ", string arg evaluates to " << mk_pp(e_subst, m) << std::endl;);
|
||||
symbol e_str;
|
||||
if (u.str.is_string(e_subst, e_str)) {
|
||||
zstring e_zstr(e_str.bare_str());
|
||||
zstring e_zstr;
|
||||
if (u.str.is_string(e_subst, e_zstr)) {
|
||||
// if arg is out of range, e must be empty
|
||||
// if arg is in range, e must be valid
|
||||
if (ival <= rational::zero() || ival >= rational(u.max_char())) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue