/*++ Copyright (c) 2011 Microsoft Corporation Module Name: var_queue.h Abstract: SAT variable priority queue. Author: Leonardo de Moura (leonardo) 2011-05-21. Revision History: --*/ #pragma once #include "util/heap.h" class var_queue { typedef unsigned var; struct lt { svector & m_activity; lt(svector & act):m_activity(act) {} bool operator()(var v1, var v2) const { return m_activity[v1] > m_activity[v2]; } }; heap m_queue; public: var_queue(svector & act):m_queue(128, lt(act)) {} void activity_increased_eh(var v) { if (m_queue.contains(v)) m_queue.decreased(v); } void activity_changed_eh(var v, bool up) { if (m_queue.contains(v)) { if (up) m_queue.decreased(v); else m_queue.increased(v); } } void mk_var_eh(var v) { m_queue.reserve(v+1); unassign_var_eh(v); } void del_var_eh(var v) { if (m_queue.contains(v)) m_queue.erase(v); } void unassign_var_eh(var v) { if (!m_queue.contains(v)) m_queue.insert(v); } void reset() { m_queue.reset(); } bool empty() const { return m_queue.empty(); } var next_var() { SASSERT(!empty()); return m_queue.erase_min(); } var min_var() { SASSERT(!empty()); return m_queue.min_value(); } bool more_active(var v1, var v2) const { return m_queue.less_than(v1, v2); } std::ostream& display(std::ostream& out) const { bool first = true; for (auto v : m_queue) { if (first) { first = false; } else { out << " "; } out << v; } return out; } }; inline std::ostream& operator<<(std::ostream& out, var_queue const& queue) { return queue.display(out); }