3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-24 01:25:31 +00:00

activate non-overflow bounds

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
Nikolaj Bjorner 2022-12-12 20:11:01 -08:00
parent a5f12e9d57
commit 6c7f556496
2 changed files with 14 additions and 0 deletions

View file

@ -80,6 +80,9 @@ namespace polysat {
if (is_always_true(is_positive, p1, q1))
return;
if (first)
activate(s, is_positive);
if (try_viable(s, is_positive, p(), q(), p1, q1))
return;
@ -91,6 +94,16 @@ namespace polysat {
}
void umul_ovfl_constraint::activate(solver& s, bool is_positive) {
// TODO - remove to enable
return;
if (!is_positive) {
signed_constraint sc(this, is_positive);
s.add_clause(~sc, s.eq(p()), s.eq(q()), s.ule(p(), p()*q()), false);
s.add_clause(~sc, s.eq(p()), s.eq(q()), s.ule(q(), p()*q()), false);
}
}
/**
* if p constant, q, propagate inequality
*/

View file

@ -30,6 +30,7 @@ namespace polysat {
static lbool eval(pdd const& p, pdd const& q);
bool narrow_bound(solver& s, bool is_positive, pdd const& p0, pdd const& q0, pdd const& p, pdd const& q);
bool try_viable(solver& s, bool is_positive, pdd const& p0, pdd const& q0, pdd const& p, pdd const& q);
void activate(solver& s, bool is_positive);
public:
~umul_ovfl_constraint() override {}