mirror of
https://github.com/Z3Prover/z3
synced 2025-04-24 17:45:32 +00:00
na
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
parent
55a908e357
commit
0d78a10630
3 changed files with 28 additions and 28 deletions
|
@ -15,16 +15,13 @@ Author:
|
|||
|
||||
namespace polysat {
|
||||
|
||||
|
||||
constraint* constraint::eq(unsigned lvl, pdd const& p, p_dependency_ref& d) {
|
||||
return alloc(eq_constraint, lvl, p, dep);
|
||||
}
|
||||
|
||||
std::ostream& constraint::display(std::ostream& out) const {
|
||||
switch (kind()) {
|
||||
case ckind_t::eq_t:
|
||||
return out << p() << " == 0";
|
||||
case ckind_t::ule_t:
|
||||
return out << lhs() << " <=u " << rhs();
|
||||
case ckind_t::sle_t:
|
||||
return out << lhs() << " <=s " << rhs();
|
||||
}
|
||||
return out;
|
||||
return out << p() << " == 0";
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -22,40 +22,42 @@ namespace polysat {
|
|||
|
||||
enum ckind_t { eq_t, ule_t, sle_t };
|
||||
|
||||
class eq_constraint;
|
||||
class ule_constraint;
|
||||
|
||||
class constraint {
|
||||
unsigned m_level;
|
||||
ckind_t m_kind;
|
||||
pdd m_poly;
|
||||
pdd m_other;
|
||||
p_dependency_ref m_dep;
|
||||
unsigned_vector m_vars;
|
||||
constraint(unsigned lvl, pdd const& p, pdd const& q, p_dependency_ref& dep, ckind_t k):
|
||||
m_level(lvl), m_kind(k), m_poly(p), m_other(q), m_dep(dep) {
|
||||
m_vars.append(p.free_vars());
|
||||
if (q != p)
|
||||
for (auto v : q.free_vars())
|
||||
m_vars.insert(v);
|
||||
}
|
||||
constraint(unsigned lvl, p_dependency_ref& dep, ckind_t k):
|
||||
m_level(lvl), m_kind(k), m_dep(dep) {}
|
||||
public:
|
||||
static constraint* eq(unsigned lvl, pdd const& p, p_dependency_ref& d) {
|
||||
return alloc(constraint, lvl, p, p, d, ckind_t::eq_t);
|
||||
}
|
||||
static constraint* ule(unsigned lvl, pdd const& p, pdd const& q, p_dependency_ref& d) {
|
||||
return alloc(constraint, lvl, p, q, d, ckind_t::ule_t);
|
||||
}
|
||||
static constraint* eq(unsigned lvl, pdd const& p, p_dependency_ref& d);
|
||||
bool is_eq() const { return m_kind == ckind_t::eq_t; }
|
||||
bool is_ule() const { return m_kind == ckind_t::ule_t; }
|
||||
bool is_sle() const { return m_kind == ckind_t::sle_t; }
|
||||
ckind_t kind() const { return m_kind; }
|
||||
pdd const & p() const { return m_poly; }
|
||||
pdd const & lhs() const { return m_poly; }
|
||||
pdd const & rhs() const { return m_other; }
|
||||
std::ostream& display(std::ostream& out) const;
|
||||
virtual std::ostream& display(std::ostream& out) const = 0;
|
||||
eq_constraint& to_eq() { return *dynamic_cast<eq_constraint*>(this); }
|
||||
eq_constraint const& to_eq() { return *dynamic_cast<eq_constraint const*>(this); }
|
||||
p_dependency* dep() const { return m_dep; }
|
||||
unsigned_vector& vars() { return m_vars; }
|
||||
unsigned level() const { return m_level; }
|
||||
};
|
||||
|
||||
class eq_constraint : public constraint {
|
||||
pdd m_poly;
|
||||
public:
|
||||
eq_constraint(unsigned lvl, pdd const& p, pdd const& q, p_dependency_ref& dep,):
|
||||
constraint(lvl, dep, ckind_t::eq_t), m_poly(p) {
|
||||
m_vars.append(p.free_vars());
|
||||
}
|
||||
pdd const & p() const { return m_poly; }
|
||||
std::ostream& display(std::ostream& out) const override;
|
||||
};
|
||||
|
||||
inline std::ostream& operator<<(std::ostream& out, constraint const& c) { return c.display(out); }
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
#endif
|
||||
#include <utility>
|
||||
|
||||
#include "util/util.h"
|
||||
#include "math/polysat/log.h"
|
||||
|
||||
#if POLYSAT_LOGGING_ENABLED
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue