mirror of
https://github.com/Z3Prover/z3
synced 2025-05-08 00:05:46 +00:00
52 lines
1.6 KiB
C++
52 lines
1.6 KiB
C++
/*++
|
|
Copyright (c) 2021 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
polysat unsigned <= constraint
|
|
|
|
Author:
|
|
|
|
Nikolaj Bjorner (nbjorner) 2021-03-19
|
|
Jakob Rath 2021-04-6
|
|
|
|
--*/
|
|
#pragma once
|
|
#include "math/polysat/constraint.h"
|
|
|
|
|
|
namespace polysat {
|
|
|
|
class ule_constraint final : public constraint {
|
|
friend class constraint_manager;
|
|
|
|
pdd m_lhs;
|
|
pdd m_rhs;
|
|
|
|
ule_constraint(constraint_manager& m, pdd const& l, pdd const& r):
|
|
constraint(m, ckind_t::ule_t), m_lhs(l), m_rhs(r) {
|
|
m_vars.append(l.free_vars());
|
|
for (auto v : r.free_vars())
|
|
if (!m_vars.contains(v))
|
|
m_vars.push_back(v);
|
|
}
|
|
|
|
public:
|
|
~ule_constraint() override {}
|
|
pdd const& lhs() const { return m_lhs; }
|
|
pdd const& rhs() const { return m_rhs; }
|
|
std::ostream& display(std::ostream& out, lbool status) const override;
|
|
std::ostream& display(std::ostream& out) const override;
|
|
bool is_always_false(bool is_positive, pdd const& lhs, pdd const& rhs) const;
|
|
bool is_always_false(bool is_positive) const override;
|
|
bool is_currently_false(solver& s, bool is_positive) const override;
|
|
bool is_currently_true(solver& s, bool is_positive) const override;
|
|
void narrow(solver& s, bool is_positive) override;
|
|
inequality as_inequality(bool is_positive) const override;
|
|
unsigned hash() const override;
|
|
bool operator==(constraint const& other) const override;
|
|
bool is_eq() const override { return m_rhs.is_zero(); }
|
|
pdd const& p() const { SASSERT(is_eq()); return m_lhs; }
|
|
};
|
|
|
|
}
|