3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-15 13:28:47 +00:00

add_constraint API

This commit is contained in:
Matteo 2017-10-17 16:55:52 +02:00 committed by Arie Gurfinkel
parent 3c7165780c
commit 65885f7eba
9 changed files with 40 additions and 27 deletions

View file

@ -619,6 +619,10 @@ extern "C" {
Z3_CATCH; Z3_CATCH;
} }
void Z3_API Z3_fixedpoint_add_constraint (Z3_context c, Z3_fixedpoint d, Z3_ast e, unsigned lvl){
to_fixedpoint_ref(d)->ctx().add_constraint(to_expr(e), lvl);
}
#include "api_datalog_spacer.inc" #include "api_datalog_spacer.inc"
}; };

View file

@ -367,7 +367,7 @@ extern "C" {
void Z3_API Z3_fixedpoint_set_reduce_app_callback( void Z3_API Z3_fixedpoint_set_reduce_app_callback(
Z3_context c, Z3_fixedpoint d, Z3_fixedpoint_reduce_app_callback_fptr cb); Z3_context c, Z3_fixedpoint d, Z3_fixedpoint_reduce_app_callback_fptr cb);
typedef void (*Z3_fixedpoint_new_lemma_eh)(void *state, Z3_ast *lemma, unsigned level); typedef void (*Z3_fixedpoint_new_lemma_eh)(void *state, Z3_ast lemma, unsigned level);
typedef void (*Z3_fixedpoint_predecessor_eh)(void *state); typedef void (*Z3_fixedpoint_predecessor_eh)(void *state);
typedef void (*Z3_fixedpoint_unfold_eh)(void *state); typedef void (*Z3_fixedpoint_unfold_eh)(void *state);
@ -377,6 +377,8 @@ extern "C" {
Z3_fixedpoint_predecessor_eh predecessor_eh, Z3_fixedpoint_predecessor_eh predecessor_eh,
Z3_fixedpoint_unfold_eh unfold_eh); Z3_fixedpoint_unfold_eh unfold_eh);
void Z3_fixedpoint_add_constraint (Z3_context c, Z3_fixedpoint d, Z3_ast e, unsigned lvl);
/*@}*/ /*@}*/
/*@}*/ /*@}*/

View file

@ -596,6 +596,11 @@ namespace datalog {
m_engine->add_callback(state, new_lemma_eh, predecessor_eh, unfold_eh); m_engine->add_callback(state, new_lemma_eh, predecessor_eh, unfold_eh);
} }
void add_constraint (expr *c, unsigned lvl){
ensure_engine();
m_engine->add_constraint(c, lvl);
}
private: private:
/** /**

View file

@ -112,6 +112,9 @@ namespace datalog {
const t_unfold_eh unfold_eh) { const t_unfold_eh unfold_eh) {
throw default_exception(std::string("add_lemma_exchange_callbacks is not supported for ") + m_name); throw default_exception(std::string("add_lemma_exchange_callbacks is not supported for ") + m_name);
} }
virtual void add_constraint (expr *c, unsigned lvl){
throw default_exception(std::string("add_constraint is not supported for ") + m_name);
}
virtual void updt_params() {} virtual void updt_params() {}
virtual void cancel() {} virtual void cancel() {}
virtual void cleanup() {} virtual void cleanup() {}

View file

@ -45,15 +45,15 @@ namespace spacer {
m_predecessor_eh(predecessor_eh), m_predecessor_eh(predecessor_eh),
m_unfold_eh(unfold_eh) {} m_unfold_eh(unfold_eh) {}
inline bool new_lemma() override { return true; } inline bool new_lemma() override { return m_new_lemma_eh != nullptr; }
void new_lemma_eh(expr *lemma, unsigned level) override; void new_lemma_eh(expr *lemma, unsigned level) override;
inline bool predecessor() override { return true; } inline bool predecessor() override { return m_predecessor_eh != nullptr; }
void predecessor_eh() override; void predecessor_eh() override;
inline bool unfold() override { return true; } inline bool unfold() override { return m_unfold_eh != nullptr; }
void unfold_eh() override; void unfold_eh() override;

View file

@ -1229,21 +1229,21 @@ void lemma::mk_expr_core() {
normalize(m_body, m_body); normalize(m_body, m_body);
if (!m_zks.empty() && has_zk_const(m_body)) { if (!m_zks.empty() && has_zk_const(m_body)) {
app_ref_vector zks(m); app_ref_vector zks(m);
zks.append(m_zks); zks.append(m_zks);
zks.reverse(); zks.reverse();
expr_abstract(m, 0, expr_abstract(m, 0,
zks.size(), (expr* const*)zks.c_ptr(), m_body, zks.size(), (expr* const*)zks.c_ptr(), m_body,
m_body); m_body);
ptr_buffer<sort> sorts; ptr_buffer<sort> sorts;
svector<symbol> names; svector<symbol> names;
for (unsigned i=0, sz=zks.size(); i < sz; ++i) { for (unsigned i=0, sz=zks.size(); i < sz; ++i) {
sorts.push_back(get_sort(zks.get(i))); sorts.push_back(get_sort(zks.get(i)));
names.push_back(zks.get(i)->get_decl()->get_name()); names.push_back(zks.get(i)->get_decl()->get_name());
} }
m_body = m.mk_quantifier(true, zks.size(), m_body = m.mk_quantifier(true, zks.size(),
sorts.c_ptr(), sorts.c_ptr(),
names.c_ptr(), names.c_ptr(),
m_body, 15, symbol(m_body->get_id())); m_body, 15, symbol(m_body->get_id()));
} }
SASSERT(m_body); SASSERT(m_body);
@ -3590,17 +3590,11 @@ expr_ref context::get_constraints (unsigned level)
return m_pm.mk_and (constraints); return m_pm.mk_and (constraints);
} }
void context::add_constraints (unsigned level, const expr_ref& c) void context::add_constraint (unsigned level, const expr_ref& c)
{ {
if (!c.get()) { return; } if (!c.get()) { return; }
if (m.is_true(c)) { return; } if (m.is_true(c)) { return; }
expr_ref_vector constraints (m);
constraints.push_back (c);
flatten_and (constraints);
for (unsigned i = 0, sz = constraints.size(); i < sz; ++i) {
expr *c = constraints.get (i);
expr *e1, *e2; expr *e1, *e2;
if (m.is_implies(c, e1, e2)) { if (m.is_implies(c, e1, e2)) {
SASSERT (is_app (e1)); SASSERT (is_app (e1));
@ -3613,7 +3607,6 @@ void context::add_constraints (unsigned level, const expr_ref& c)
} }
else{ else{
this->m_stats.m_num_lemmas_discarded++; this->m_stats.m_num_lemmas_discarded++;
}
} }
} }
} }

View file

@ -882,7 +882,7 @@ public:
pob& get_root() const { return m_pob_queue.get_root(); } pob& get_root() const { return m_pob_queue.get_root(); }
expr_ref get_constraints (unsigned lvl); expr_ref get_constraints (unsigned lvl);
void add_constraints (unsigned lvl, const expr_ref& c); void add_constraint (unsigned lvl, const expr_ref& c);
void new_lemma_eh(pred_transformer &pt, lemma *lem); void new_lemma_eh(pred_transformer &pt, lemma *lem);

View file

@ -360,3 +360,7 @@ void dl_interface::add_callback(void *state,
const datalog::t_unfold_eh unfold_eh){ const datalog::t_unfold_eh unfold_eh){
m_context->callbacks().push_back(alloc(user_callback, *m_context, state, new_lemma_eh, predecessor_eh, unfold_eh)); m_context->callbacks().push_back(alloc(user_callback, *m_context, state, new_lemma_eh, predecessor_eh, unfold_eh));
} }
void dl_interface::add_constraint (expr *c, unsigned lvl){
m_context->add_constraint(c,lvl);
}

View file

@ -84,6 +84,8 @@ public:
const datalog::t_predecessor_eh predecessor_eh, const datalog::t_predecessor_eh predecessor_eh,
const datalog::t_unfold_eh unfold_eh); const datalog::t_unfold_eh unfold_eh);
void add_constraint (expr *c, unsigned lvl);
}; };
} }