3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-04 16:44:07 +00:00

remove term sorting by the span

Signed-off-by: Lev Nachmanson <levnach@hotmail.com>
This commit is contained in:
Lev Nachmanson 2025-03-15 12:33:09 -10:00 committed by Lev Nachmanson
parent 12203fc69a
commit 22cfab3d42

View file

@ -1408,39 +1408,12 @@ namespace lp {
sorted_changed_terms.push_back(j);
}
bool sort_by_weight = true;
if (sort_by_weight)
// Sort by term_weight descending
std::sort(sorted_changed_terms.begin(), sorted_changed_terms.end(),
[this](unsigned j1, unsigned j2) {
return term_weight(lra.get_term(j1)) > term_weight(lra.get_term(j2) );
});
else {
std::sort(sorted_changed_terms.begin(), sorted_changed_terms.end(),
[this](unsigned j1, unsigned j2) {
// First check if both columns are boxed
bool j1_is_boxed = lia.is_boxed(j1);
bool j2_is_boxed = lia.is_boxed(j2);
// Sort by term_weight descending
std::sort(sorted_changed_terms.begin(), sorted_changed_terms.end(),
[this](unsigned j1, unsigned j2) {
return term_weight(lra.get_term(j1)) > term_weight(lra.get_term(j2) );
});
// If one is boxed and the other isn't, prefer the boxed one
if (j1_is_boxed && !j2_is_boxed)
return true;
if (!j1_is_boxed && j2_is_boxed)
return false;
// If both are boxed, compare spans (prefer smaller spans)
if (j1_is_boxed && j2_is_boxed) {
mpq span1 = lra.bound_span_x(j1);
mpq span2 = lra.bound_span_x(j2);
if (span1 != span2)
return span1 < span2;
}
// Fall back to weight comparison
return term_weight(lra.get_term(j1)) > term_weight(lra.get_term(j2));
});
}
lia_move r = lia_move::undef;
// Process sorted terms
TRACE("dio",