mirror of
https://github.com/Z3Prover/z3
synced 2025-06-06 06:03:23 +00:00
prioritize decisions on variables of larger bit width
This commit is contained in:
parent
3687d69f2b
commit
66496c034f
4 changed files with 30 additions and 28 deletions
|
@ -3,11 +3,11 @@ Copyright (c) 2011 Microsoft Corporation
|
||||||
|
|
||||||
Module Name:
|
Module Name:
|
||||||
|
|
||||||
var_queue.h
|
pvar_queue.h
|
||||||
|
|
||||||
Abstract:
|
Abstract:
|
||||||
|
|
||||||
SAT variable priority queue.
|
polysat variable priority queue.
|
||||||
|
|
||||||
Author:
|
Author:
|
||||||
|
|
||||||
|
@ -21,61 +21,63 @@ Revision History:
|
||||||
#include "util/heap.h"
|
#include "util/heap.h"
|
||||||
|
|
||||||
|
|
||||||
|
class pvar_queue {
|
||||||
class var_queue {
|
|
||||||
typedef unsigned var;
|
typedef unsigned var;
|
||||||
|
|
||||||
struct lt {
|
class lt {
|
||||||
svector<unsigned> & m_activity;
|
unsigned_vector const& m_size;
|
||||||
lt(svector<unsigned> & act):m_activity(act) {}
|
unsigned_vector const& m_activity;
|
||||||
bool operator()(var v1, var v2) const { return m_activity[v1] > m_activity[v2]; }
|
public:
|
||||||
|
lt(unsigned_vector const& sz, unsigned_vector const& act): m_size(sz), m_activity(act) {}
|
||||||
|
bool operator()(var v1, var v2) const {
|
||||||
|
return m_size[v1] > m_size[v2]
|
||||||
|
|| (m_size[v1] == m_size[v2] && m_activity[v1] > m_activity[v2]);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
heap<lt> m_queue;
|
|
||||||
|
heap<lt> m_queue;
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
pvar_queue(unsigned_vector const& sz, unsigned_vector const& act): m_queue(128, lt(sz, act)) {}
|
||||||
var_queue(svector<unsigned> & act):m_queue(128, lt(act)) {}
|
|
||||||
|
|
||||||
void activity_increased_eh(var v) {
|
void activity_increased_eh(var v) {
|
||||||
if (m_queue.contains(v))
|
if (m_queue.contains(v))
|
||||||
m_queue.decreased(v);
|
m_queue.decreased(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
void activity_changed_eh(var v, bool up) {
|
void activity_changed_eh(var v, bool up) {
|
||||||
if (m_queue.contains(v)) {
|
if (m_queue.contains(v)) {
|
||||||
if (up)
|
if (up)
|
||||||
m_queue.decreased(v);
|
m_queue.decreased(v);
|
||||||
else
|
else
|
||||||
m_queue.increased(v);
|
m_queue.increased(v);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void mk_var_eh(var v) {
|
void mk_var_eh(var v) {
|
||||||
m_queue.reserve(v+1);
|
m_queue.reserve(v+1);
|
||||||
unassign_var_eh(v);
|
unassign_var_eh(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
void del_var_eh(var v) {
|
void del_var_eh(var v) {
|
||||||
if (m_queue.contains(v))
|
if (m_queue.contains(v))
|
||||||
m_queue.erase(v);
|
m_queue.erase(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
void unassign_var_eh(var v) {
|
void unassign_var_eh(var v) {
|
||||||
if (!m_queue.contains(v))
|
if (!m_queue.contains(v))
|
||||||
m_queue.insert(v);
|
m_queue.insert(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
void reset() {
|
void reset() {
|
||||||
m_queue.reset();
|
m_queue.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool empty() const { return m_queue.empty(); }
|
bool empty() const { return m_queue.empty(); }
|
||||||
|
|
||||||
var next_var() { SASSERT(!empty()); return m_queue.erase_min(); }
|
var next_var() { SASSERT(!empty()); return m_queue.erase_min(); }
|
||||||
|
|
||||||
var min_var() { SASSERT(!empty()); return m_queue.min_value(); }
|
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 {
|
std::ostream& display(std::ostream& out) const {
|
||||||
bool first = true;
|
bool first = true;
|
||||||
|
@ -95,6 +97,6 @@ public:
|
||||||
const_iterator end() const { return m_queue.end(); }
|
const_iterator end() const { return m_queue.end(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
inline std::ostream& operator<<(std::ostream& out, var_queue const& queue) {
|
inline std::ostream& operator<<(std::ostream& out, pvar_queue const& queue) {
|
||||||
return queue.display(out);
|
return queue.display(out);
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,7 @@ namespace polysat {
|
||||||
m_simplify(*this),
|
m_simplify(*this),
|
||||||
m_restart(*this),
|
m_restart(*this),
|
||||||
m_bvars(*this),
|
m_bvars(*this),
|
||||||
m_free_pvars(m_activity),
|
m_free_pvars(m_size, m_activity),
|
||||||
m_constraints(*this),
|
m_constraints(*this),
|
||||||
m_names(*this),
|
m_names(*this),
|
||||||
m_slicing(*this),
|
m_slicing(*this),
|
||||||
|
|
|
@ -34,6 +34,7 @@ Author:
|
||||||
#include "math/polysat/search_state.h"
|
#include "math/polysat/search_state.h"
|
||||||
#include "math/polysat/assignment.h"
|
#include "math/polysat/assignment.h"
|
||||||
#include "math/polysat/trail.h"
|
#include "math/polysat/trail.h"
|
||||||
|
#include "math/polysat/pvar_queue.h"
|
||||||
#include "math/polysat/viable.h"
|
#include "math/polysat/viable.h"
|
||||||
#include "math/polysat/log.h"
|
#include "math/polysat/log.h"
|
||||||
#include <limits>
|
#include <limits>
|
||||||
|
@ -170,7 +171,7 @@ namespace polysat {
|
||||||
simplify m_simplify;
|
simplify m_simplify;
|
||||||
restart m_restart;
|
restart m_restart;
|
||||||
bool_var_manager m_bvars; // Map boolean variables to constraints
|
bool_var_manager m_bvars; // Map boolean variables to constraints
|
||||||
var_queue m_free_pvars; // free poly vars
|
pvar_queue m_free_pvars; // free poly vars
|
||||||
stats m_stats;
|
stats m_stats;
|
||||||
random_gen m_rand;
|
random_gen m_rand;
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,6 @@ Author:
|
||||||
#include "util/map.h"
|
#include "util/map.h"
|
||||||
#include "util/rlimit.h"
|
#include "util/rlimit.h"
|
||||||
#include "util/scoped_ptr_vector.h"
|
#include "util/scoped_ptr_vector.h"
|
||||||
#include "util/var_queue.h"
|
|
||||||
#include "util/ref_vector.h"
|
#include "util/ref_vector.h"
|
||||||
#include "util/sat_literal.h"
|
#include "util/sat_literal.h"
|
||||||
#include "math/dd/dd_pdd.h"
|
#include "math/dd/dd_pdd.h"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue