mirror of
https://github.com/Z3Prover/z3
synced 2025-06-18 11:58:31 +00:00
Merge branch 'master' of https://github.com/z3prover/z3
This commit is contained in:
commit
28a0c2d18f
13 changed files with 66 additions and 54 deletions
|
@ -1092,15 +1092,15 @@ extern "C" {
|
||||||
Z3_CATCH;
|
Z3_CATCH;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Z3_API Z3_solver_propagate_consequence(Z3_context c, Z3_solver_callback s, unsigned num_fixed, Z3_ast const* fixed_ids, unsigned num_eqs, Z3_ast const* eq_lhs, Z3_ast const* eq_rhs, Z3_ast conseq) {
|
bool Z3_API Z3_solver_propagate_consequence(Z3_context c, Z3_solver_callback s, unsigned num_fixed, Z3_ast const* fixed_ids, unsigned num_eqs, Z3_ast const* eq_lhs, Z3_ast const* eq_rhs, Z3_ast conseq) {
|
||||||
Z3_TRY;
|
Z3_TRY;
|
||||||
LOG_Z3_solver_propagate_consequence(c, s, num_fixed, fixed_ids, num_eqs, eq_lhs, eq_rhs, conseq);
|
LOG_Z3_solver_propagate_consequence(c, s, num_fixed, fixed_ids, num_eqs, eq_lhs, eq_rhs, conseq);
|
||||||
RESET_ERROR_CODE();
|
RESET_ERROR_CODE();
|
||||||
expr* const * _fixed_ids = (expr* const*) fixed_ids;
|
expr* const * _fixed_ids = (expr* const*) fixed_ids;
|
||||||
expr* const * _eq_lhs = (expr*const*) eq_lhs;
|
expr* const * _eq_lhs = (expr*const*) eq_lhs;
|
||||||
expr* const * _eq_rhs = (expr*const*) eq_rhs;
|
expr* const * _eq_rhs = (expr*const*) eq_rhs;
|
||||||
reinterpret_cast<user_propagator::callback*>(s)->propagate_cb(num_fixed, _fixed_ids, num_eqs, _eq_lhs, _eq_rhs, to_expr(conseq));
|
return reinterpret_cast<user_propagator::callback*>(s)->propagate_cb(num_fixed, _fixed_ids, num_eqs, _eq_lhs, _eq_rhs, to_expr(conseq));
|
||||||
Z3_CATCH;
|
Z3_CATCH_RETURN(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Z3_API Z3_solver_propagate_created(Z3_context c, Z3_solver s, Z3_created_eh created_eh) {
|
void Z3_API Z3_solver_propagate_created(Z3_context c, Z3_solver s, Z3_created_eh created_eh) {
|
||||||
|
|
|
@ -4496,14 +4496,14 @@ namespace z3 {
|
||||||
Z3_solver_propagate_consequence(ctx(), cb, fixed.size(), _fixed.ptr(), lhs.size(), _lhs.ptr(), _rhs.ptr(), conseq);
|
Z3_solver_propagate_consequence(ctx(), cb, fixed.size(), _fixed.ptr(), lhs.size(), _lhs.ptr(), _rhs.ptr(), conseq);
|
||||||
}
|
}
|
||||||
|
|
||||||
void propagate(expr_vector const& fixed, expr const& conseq) {
|
bool propagate(expr_vector const& fixed, expr const& conseq) {
|
||||||
assert(cb);
|
assert(cb);
|
||||||
assert((Z3_context)conseq.ctx() == (Z3_context)ctx());
|
assert((Z3_context)conseq.ctx() == (Z3_context)ctx());
|
||||||
array<Z3_ast> _fixed(fixed);
|
array<Z3_ast> _fixed(fixed);
|
||||||
Z3_solver_propagate_consequence(ctx(), cb, _fixed.size(), _fixed.ptr(), 0, nullptr, nullptr, conseq);
|
return Z3_solver_propagate_consequence(ctx(), cb, _fixed.size(), _fixed.ptr(), 0, nullptr, nullptr, conseq);
|
||||||
}
|
}
|
||||||
|
|
||||||
void propagate(expr_vector const& fixed,
|
bool propagate(expr_vector const& fixed,
|
||||||
expr_vector const& lhs, expr_vector const& rhs,
|
expr_vector const& lhs, expr_vector const& rhs,
|
||||||
expr const& conseq) {
|
expr const& conseq) {
|
||||||
assert(cb);
|
assert(cb);
|
||||||
|
@ -4513,7 +4513,7 @@ namespace z3 {
|
||||||
array<Z3_ast> _lhs(lhs);
|
array<Z3_ast> _lhs(lhs);
|
||||||
array<Z3_ast> _rhs(rhs);
|
array<Z3_ast> _rhs(rhs);
|
||||||
|
|
||||||
Z3_solver_propagate_consequence(ctx(), cb, _fixed.size(), _fixed.ptr(), lhs.size(), _lhs.ptr(), _rhs.ptr(), conseq);
|
return Z3_solver_propagate_consequence(ctx(), cb, _fixed.size(), _fixed.ptr(), lhs.size(), _lhs.ptr(), _rhs.ptr(), conseq);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -252,21 +252,29 @@ namespace Microsoft.Z3
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Propagate consequence
|
/// Propagate consequence
|
||||||
|
/// <returns>
|
||||||
|
/// <see langword="true" /> if the propagated expression is new for the solver;
|
||||||
|
/// <see langword="false" /> if the propagation was ignored
|
||||||
|
/// </returns>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void Propagate(IEnumerable<Expr> terms, Expr conseq)
|
public bool Propagate(IEnumerable<Expr> terms, Expr conseq)
|
||||||
{
|
{
|
||||||
Propagate(terms, new EqualityPairs(), conseq);
|
return Propagate(terms, new EqualityPairs(), conseq);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Propagate consequence
|
/// Propagate consequence
|
||||||
|
/// <returns>
|
||||||
|
/// <see langword="true" /> if the propagated expression is new for the solver;
|
||||||
|
/// <see langword="false" /> if the propagation was ignored
|
||||||
|
/// </returns>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public void Propagate(IEnumerable<Expr> terms, EqualityPairs equalities, Expr conseq)
|
public bool Propagate(IEnumerable<Expr> terms, EqualityPairs equalities, Expr conseq)
|
||||||
{
|
{
|
||||||
var nTerms = Z3Object.ArrayToNative(terms.ToArray());
|
var nTerms = Z3Object.ArrayToNative(terms.ToArray());
|
||||||
var nLHS = Z3Object.ArrayToNative(equalities.LHS.ToArray());
|
var nLHS = Z3Object.ArrayToNative(equalities.LHS.ToArray());
|
||||||
var nRHS = Z3Object.ArrayToNative(equalities.RHS.ToArray());
|
var nRHS = Z3Object.ArrayToNative(equalities.RHS.ToArray());
|
||||||
Native.Z3_solver_propagate_consequence(ctx.nCtx, this.callback, (uint)nTerms.Length, nTerms, (uint)equalities.Count, nLHS, nRHS, conseq.NativeObject);
|
return Native.Z3_solver_propagate_consequence(ctx.nCtx, this.callback, (uint)nTerms.Length, nTerms, (uint)equalities.Count, nLHS, nRHS, conseq.NativeObject) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -11704,7 +11704,7 @@ class UserPropagateBase:
|
||||||
num_eqs = len(eqs)
|
num_eqs = len(eqs)
|
||||||
_lhs, _num_lhs = _to_ast_array([x for x, y in eqs])
|
_lhs, _num_lhs = _to_ast_array([x for x, y in eqs])
|
||||||
_rhs, _num_rhs = _to_ast_array([y for x, y in eqs])
|
_rhs, _num_rhs = _to_ast_array([y for x, y in eqs])
|
||||||
Z3_solver_propagate_consequence(e.ctx.ref(), ctypes.c_void_p(
|
return Z3_solver_propagate_consequence(e.ctx.ref(), ctypes.c_void_p(
|
||||||
self.cb), num_fixed, _ids, num_eqs, _lhs, _rhs, e.ast)
|
self.cb), num_fixed, _ids, num_eqs, _lhs, _rhs, e.ast)
|
||||||
|
|
||||||
def conflict(self, deps = [], eqs = []):
|
def conflict(self, deps = [], eqs = []):
|
||||||
|
|
|
@ -7150,11 +7150,15 @@ extern "C" {
|
||||||
This is a callback a client may invoke during the fixed_eh callback.
|
This is a callback a client may invoke during the fixed_eh callback.
|
||||||
The callback adds a propagation consequence based on the fixed values of the
|
The callback adds a propagation consequence based on the fixed values of the
|
||||||
\c ids.
|
\c ids.
|
||||||
|
The solver might discard the propagation in case it is true in the current state.
|
||||||
|
The function returns false in this case; otw. the function returns true.
|
||||||
|
At least one propagation in the final callback has to return true in order to
|
||||||
|
prevent the solver from finishing.
|
||||||
|
|
||||||
def_API('Z3_solver_propagate_consequence', VOID, (_in(CONTEXT), _in(SOLVER_CALLBACK), _in(UINT), _in_array(2, AST), _in(UINT), _in_array(4, AST), _in_array(4, AST), _in(AST)))
|
def_API('Z3_solver_propagate_consequence', BOOL, (_in(CONTEXT), _in(SOLVER_CALLBACK), _in(UINT), _in_array(2, AST), _in(UINT), _in_array(4, AST), _in_array(4, AST), _in(AST)))
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void Z3_API Z3_solver_propagate_consequence(Z3_context c, Z3_solver_callback cb, unsigned num_fixed, Z3_ast const* fixed, unsigned num_eqs, Z3_ast const* eq_lhs, Z3_ast const* eq_rhs, Z3_ast conseq);
|
bool Z3_API Z3_solver_propagate_consequence(Z3_context c, Z3_solver_callback cb, unsigned num_fixed, Z3_ast const* fixed, unsigned num_eqs, Z3_ast const* eq_lhs, Z3_ast const* eq_rhs, Z3_ast conseq);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
\brief Check whether the assertions in a given solver are consistent or not.
|
\brief Check whether the assertions in a given solver are consistent or not.
|
||||||
|
|
|
@ -213,7 +213,7 @@ namespace lp {
|
||||||
|
|
||||||
void lar_solver::fill_explanation_from_crossed_bounds_column(explanation& evidence) const {
|
void lar_solver::fill_explanation_from_crossed_bounds_column(explanation& evidence) const {
|
||||||
lp_assert(static_cast<int>(get_column_type(m_crossed_bounds_column)) >= static_cast<int>(column_type::boxed));
|
lp_assert(static_cast<int>(get_column_type(m_crossed_bounds_column)) >= static_cast<int>(column_type::boxed));
|
||||||
lp_assert(!m_mpq_lar_core_solver.m_r_solver.column_is_feasible(m_crossed_bounds_column));
|
lp_assert(!column_is_feasible(m_crossed_bounds_column));
|
||||||
|
|
||||||
// this is the case when the lower bound is in conflict with the upper one
|
// this is the case when the lower bound is in conflict with the upper one
|
||||||
const ul_pair& ul = m_columns_to_ul_pairs[m_crossed_bounds_column];
|
const ul_pair& ul = m_columns_to_ul_pairs[m_crossed_bounds_column];
|
||||||
|
@ -673,7 +673,7 @@ namespace lp {
|
||||||
m_mpq_lar_core_solver.m_r_solver.add_delta_to_x_and_track_feasibility(bj, -A_r().get_val(c) * delta);
|
m_mpq_lar_core_solver.m_r_solver.add_delta_to_x_and_track_feasibility(bj, -A_r().get_val(c) * delta);
|
||||||
TRACE("change_x_del",
|
TRACE("change_x_del",
|
||||||
tout << "changed basis column " << bj << ", it is " <<
|
tout << "changed basis column " << bj << ", it is " <<
|
||||||
(m_mpq_lar_core_solver.m_r_solver.column_is_feasible(bj) ? "feas" : "inf") << std::endl;);
|
(column_is_feasible(bj) ? "feas" : "inf") << std::endl;);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1327,7 +1327,7 @@ namespace lp {
|
||||||
became_feas.clear();
|
became_feas.clear();
|
||||||
for (unsigned j : m_mpq_lar_core_solver.m_r_solver.inf_heap()) {
|
for (unsigned j : m_mpq_lar_core_solver.m_r_solver.inf_heap()) {
|
||||||
lp_assert(m_mpq_lar_core_solver.m_r_heading[j] >= 0);
|
lp_assert(m_mpq_lar_core_solver.m_r_heading[j] >= 0);
|
||||||
if (m_mpq_lar_core_solver.m_r_solver.column_is_feasible(j))
|
if (column_is_feasible(j))
|
||||||
became_feas.push_back(j);
|
became_feas.push_back(j);
|
||||||
}
|
}
|
||||||
for (unsigned j : became_feas)
|
for (unsigned j : became_feas)
|
||||||
|
@ -1738,16 +1738,18 @@ namespace lp {
|
||||||
lconstraint_kind kind,
|
lconstraint_kind kind,
|
||||||
const mpq& right_side,
|
const mpq& right_side,
|
||||||
constraint_index constr_index) {
|
constraint_index constr_index) {
|
||||||
|
TRACE("lar_solver_feas", tout << "j = " << j << " was " << (this->column_is_feasible(j)?"feas":"non-feas") << std::endl;);
|
||||||
m_constraints.activate(constr_index);
|
m_constraints.activate(constr_index);
|
||||||
if (column_has_upper_bound(j))
|
if (column_has_upper_bound(j))
|
||||||
update_column_type_and_bound_with_ub(j, kind, right_side, constr_index);
|
update_column_type_and_bound_with_ub(j, kind, right_side, constr_index);
|
||||||
else
|
else
|
||||||
update_column_type_and_bound_with_no_ub(j, kind, right_side, constr_index);
|
update_column_type_and_bound_with_no_ub(j, kind, right_side, constr_index);
|
||||||
|
TRACE("lar_solver_feas", tout << "j = " << j << " became " << (this->column_is_feasible(j)?"feas":"non-feas") << ", and " << (this->column_is_bounded(j)? "bounded":"non-bounded") << std::endl;);
|
||||||
}
|
}
|
||||||
// clang-format on
|
// clang-format on
|
||||||
void lar_solver::insert_to_columns_with_changed_bounds(unsigned j) {
|
void lar_solver::insert_to_columns_with_changed_bounds(unsigned j) {
|
||||||
m_columns_with_changed_bounds.insert(j);
|
m_columns_with_changed_bounds.insert(j);
|
||||||
TRACE("lar_solver", tout << "column " << j << (m_mpq_lar_core_solver.m_r_solver.column_is_feasible(j) ? " feas" : " non-feas") << "\n";);
|
TRACE("lar_solver", tout << "column " << j << (column_is_feasible(j) ? " feas" : " non-feas") << "\n";);
|
||||||
}
|
}
|
||||||
// clang-format off
|
// clang-format off
|
||||||
void lar_solver::update_column_type_and_bound_check_on_equal(unsigned j,
|
void lar_solver::update_column_type_and_bound_check_on_equal(unsigned j,
|
||||||
|
|
|
@ -481,6 +481,7 @@ class lar_solver : public column_namer {
|
||||||
unsigned map_term_index_to_column_index(unsigned j) const;
|
unsigned map_term_index_to_column_index(unsigned j) const;
|
||||||
bool column_is_fixed(unsigned j) const;
|
bool column_is_fixed(unsigned j) const;
|
||||||
bool column_is_free(unsigned j) const;
|
bool column_is_free(unsigned j) const;
|
||||||
|
bool column_is_feasible(unsigned j) const { return m_mpq_lar_core_solver.m_r_solver.column_is_feasible(j);}
|
||||||
unsigned column_to_reported_index(unsigned j) const;
|
unsigned column_to_reported_index(unsigned j) const;
|
||||||
lp_settings& settings();
|
lp_settings& settings();
|
||||||
lp_settings const& settings() const;
|
lp_settings const& settings() const;
|
||||||
|
|
|
@ -539,30 +539,22 @@ public:
|
||||||
return m_basis_heading[j] >= 0;
|
return m_basis_heading[j] >= 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void update_x_with_feasibility_tracking(unsigned j, const X & v) {
|
|
||||||
TRACE("lar_solver", tout << "j = " << j << ", v = " << v << "\n";);
|
|
||||||
m_x[j] = v;
|
|
||||||
track_column_feasibility(j);
|
|
||||||
}
|
|
||||||
|
|
||||||
void add_delta_to_x_and_track_feasibility(unsigned j, const X & del) {
|
void add_delta_to_x_and_track_feasibility(unsigned j, const X & del) {
|
||||||
TRACE("lar_solver", tout << "del = " << del << ", was x[" << j << "] = " << m_x[j] << "\n";);
|
TRACE("lar_solver_feas_bug", tout << "del = " << del << ", was x[" << j << "] = " << m_x[j] << "\n";);
|
||||||
m_x[j] += del;
|
m_x[j] += del;
|
||||||
TRACE("lar_solver", tout << "became x[" << j << "] = " << m_x[j] << "\n";);
|
TRACE("lar_solver_feas_bug", tout << "became x[" << j << "] = " << m_x[j] << "\n";);
|
||||||
track_column_feasibility(j);
|
track_column_feasibility(j);
|
||||||
}
|
}
|
||||||
|
|
||||||
void update_x(unsigned j, const X & v) {
|
void update_x(unsigned j, const X & v) {
|
||||||
m_x[j] = v;
|
m_x[j] = v;
|
||||||
TRACE("lar_solver", tout << "j = " << j << ", v = " << v << (column_is_feasible(j)? " feas":" non-feas") << "\n";);
|
TRACE("lar_solver_feas", tout << "not tracking feas j = " << j << ", v = " << v << (column_is_feasible(j)? " feas":" non-feas") << "\n";);
|
||||||
}
|
}
|
||||||
// clang-format on
|
|
||||||
void add_delta_to_x(unsigned j, const X& delta) {
|
void add_delta_to_x(unsigned j, const X& delta) {
|
||||||
m_x[j] += delta;
|
m_x[j] += delta;
|
||||||
TRACE("lar_solver", tout << "j = " << j << " v = " << m_x[j] << " delta = " << delta << (column_is_feasible(j) ? " feas" : " non-feas") << "\n";);
|
TRACE("lar_solver_feas", tout << "not tracking feas j = " << j << " v = " << m_x[j] << " delta = " << delta << (column_is_feasible(j) ? " feas" : " non-feas") << "\n";);
|
||||||
}
|
}
|
||||||
// clang-format off
|
|
||||||
|
|
||||||
void track_column_feasibility(unsigned j) {
|
void track_column_feasibility(unsigned j) {
|
||||||
if (column_is_feasible(j))
|
if (column_is_feasible(j))
|
||||||
|
@ -573,7 +565,7 @@ public:
|
||||||
void insert_column_into_inf_heap(unsigned j) {
|
void insert_column_into_inf_heap(unsigned j) {
|
||||||
if (!m_inf_heap.contains(j)) {
|
if (!m_inf_heap.contains(j)) {
|
||||||
m_inf_heap.insert(j);
|
m_inf_heap.insert(j);
|
||||||
TRACE("lar_solver_inf_heap", tout << "insert into heap j = " << j << "\n";);
|
TRACE("lar_solver_inf_heap", tout << "insert into inf_heap j = " << j << "\n";);
|
||||||
}
|
}
|
||||||
lp_assert(!column_is_feasible(j));
|
lp_assert(!column_is_feasible(j));
|
||||||
}
|
}
|
||||||
|
@ -586,7 +578,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
void clear_inf_heap() {
|
void clear_inf_heap() {
|
||||||
TRACE("lar_solver",);
|
TRACE("lar_solver_feas",);
|
||||||
m_inf_heap.clear();
|
m_inf_heap.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,15 +43,19 @@ namespace user_solver {
|
||||||
m_prop.push_back(prop_info(explain, v, r));
|
m_prop.push_back(prop_info(explain, v, r));
|
||||||
}
|
}
|
||||||
|
|
||||||
void solver::propagate_cb(
|
bool solver::propagate_cb(
|
||||||
unsigned num_fixed, expr* const* fixed_ids,
|
unsigned num_fixed, expr* const* fixed_ids,
|
||||||
unsigned num_eqs, expr* const* eq_lhs, expr* const* eq_rhs,
|
unsigned num_eqs, expr* const* eq_lhs, expr* const* eq_rhs,
|
||||||
expr* conseq) {
|
expr* conseq) {
|
||||||
|
auto* n = ctx.get_enode(conseq);
|
||||||
|
if (n && s().value(ctx.enode2literal(n)) == l_true)
|
||||||
|
return false;
|
||||||
m_fixed_ids.reset();
|
m_fixed_ids.reset();
|
||||||
for (unsigned i = 0; i < num_fixed; ++i)
|
for (unsigned i = 0; i < num_fixed; ++i)
|
||||||
m_fixed_ids.push_back(get_th_var(fixed_ids[i]));
|
m_fixed_ids.push_back(get_th_var(fixed_ids[i]));
|
||||||
m_prop.push_back(prop_info(num_fixed, m_fixed_ids.data(), num_eqs, eq_lhs, eq_rhs, expr_ref(conseq, m)));
|
m_prop.push_back(prop_info(num_fixed, m_fixed_ids.data(), num_eqs, eq_lhs, eq_rhs, expr_ref(conseq, m)));
|
||||||
DEBUG_CODE(validate_propagation(););
|
DEBUG_CODE(validate_propagation(););
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void solver::register_cb(expr* e) {
|
void solver::register_cb(expr* e) {
|
||||||
|
|
|
@ -135,7 +135,7 @@ namespace user_solver {
|
||||||
|
|
||||||
bool has_fixed() const { return (bool)m_fixed_eh; }
|
bool has_fixed() const { return (bool)m_fixed_eh; }
|
||||||
|
|
||||||
void propagate_cb(unsigned num_fixed, expr* const* fixed_ids, unsigned num_eqs, expr* const* lhs, expr* const* rhs, expr* conseq) override;
|
bool propagate_cb(unsigned num_fixed, expr* const* fixed_ids, unsigned num_eqs, expr* const* lhs, expr* const* rhs, expr* conseq) override;
|
||||||
void register_cb(expr* e) override;
|
void register_cb(expr* e) override;
|
||||||
bool next_split_cb(expr* e, unsigned idx, lbool phase) override;
|
bool next_split_cb(expr* e, unsigned idx, lbool phase) override;
|
||||||
|
|
||||||
|
|
|
@ -83,7 +83,7 @@ void theory_user_propagator::add_expr(expr* term, bool ensure_enode) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void theory_user_propagator::propagate_cb(
|
bool theory_user_propagator::propagate_cb(
|
||||||
unsigned num_fixed, expr* const* fixed_ids,
|
unsigned num_fixed, expr* const* fixed_ids,
|
||||||
unsigned num_eqs, expr* const* eq_lhs, expr* const* eq_rhs,
|
unsigned num_eqs, expr* const* eq_lhs, expr* const* eq_rhs,
|
||||||
expr* conseq) {
|
expr* conseq) {
|
||||||
|
@ -96,8 +96,9 @@ void theory_user_propagator::propagate_cb(
|
||||||
ctx.mark_as_relevant((expr*)_conseq);
|
ctx.mark_as_relevant((expr*)_conseq);
|
||||||
|
|
||||||
if (ctx.lit_internalized(_conseq) && ctx.get_assignment(ctx.get_literal(_conseq)) == l_true)
|
if (ctx.lit_internalized(_conseq) && ctx.get_assignment(ctx.get_literal(_conseq)) == l_true)
|
||||||
return;
|
return false;
|
||||||
m_prop.push_back(prop_info(num_fixed, fixed_ids, num_eqs, eq_lhs, eq_rhs, _conseq));
|
m_prop.push_back(prop_info(num_fixed, fixed_ids, num_eqs, eq_lhs, eq_rhs, _conseq));
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void theory_user_propagator::register_cb(expr* e) {
|
void theory_user_propagator::register_cb(expr* e) {
|
||||||
|
|
|
@ -130,7 +130,7 @@ namespace smt {
|
||||||
|
|
||||||
bool has_fixed() const { return (bool)m_fixed_eh; }
|
bool has_fixed() const { return (bool)m_fixed_eh; }
|
||||||
|
|
||||||
void propagate_cb(unsigned num_fixed, expr* const* fixed_ids, unsigned num_eqs, expr* const* lhs, expr* const* rhs, expr* conseq) override;
|
bool propagate_cb(unsigned num_fixed, expr* const* fixed_ids, unsigned num_eqs, expr* const* lhs, expr* const* rhs, expr* conseq) override;
|
||||||
void register_cb(expr* e) override;
|
void register_cb(expr* e) override;
|
||||||
bool next_split_cb(expr* e, unsigned idx, lbool phase) override;
|
bool next_split_cb(expr* e, unsigned idx, lbool phase) override;
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ namespace user_propagator {
|
||||||
class callback {
|
class callback {
|
||||||
public:
|
public:
|
||||||
virtual ~callback() = default;
|
virtual ~callback() = default;
|
||||||
virtual void propagate_cb(unsigned num_fixed, expr* const* fixed_ids, unsigned num_eqs, expr* const* eq_lhs, expr* const* eq_rhs, expr* conseq) = 0;
|
virtual bool propagate_cb(unsigned num_fixed, expr* const* fixed_ids, unsigned num_eqs, expr* const* eq_lhs, expr* const* eq_rhs, expr* conseq) = 0;
|
||||||
virtual void register_cb(expr* e) = 0;
|
virtual void register_cb(expr* e) = 0;
|
||||||
virtual bool next_split_cb(expr* e, unsigned idx, lbool phase) = 0;
|
virtual bool next_split_cb(expr* e, unsigned idx, lbool phase) = 0;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue