mirror of
https://github.com/Z3Prover/z3
synced 2025-04-06 17:44:08 +00:00
clean up fresh definitions on a pop
Signed-off-by: Lev Nachmanson <levnach@hotmail.com>
This commit is contained in:
parent
b027761845
commit
ca7c128d3f
|
@ -335,10 +335,10 @@ namespace lp {
|
||||||
|
|
||||||
bijection m_k2s;
|
bijection m_k2s;
|
||||||
bij_map<lar_term> m_fresh_k2xt_terms;
|
bij_map<lar_term> m_fresh_k2xt_terms;
|
||||||
// m_row2fresh_defs[i] is the set of all k
|
// m_row2fresh_defs[i] is the set of all fresh variables xt
|
||||||
// such that pairs (k, m_fresh_k2xt_terms[k]) is a fresh definition introduced for row i.
|
// such that pairs (xt, m_fresh_k2xt_terms[xt]) is a fresh definition introduced for row i
|
||||||
// When row i is changed all entries depending on m_fresh_k2xt_terms[k].m_xt should be recalculated,
|
// When row i is changed all entries depending on m_fresh_k2xt_terms[xt] should be recalculated,
|
||||||
// and the corresponding fresh definitions disregarded. These definitions should not be persisted in Release mode.
|
// and the corresponding fresh definitions removed.
|
||||||
std::unordered_map<unsigned, std_vector<unsigned>> m_row2fresh_defs;
|
std::unordered_map<unsigned, std_vector<unsigned>> m_row2fresh_defs;
|
||||||
|
|
||||||
indexed_uint_set m_changed_rows;
|
indexed_uint_set m_changed_rows;
|
||||||
|
@ -448,6 +448,7 @@ namespace lp {
|
||||||
}
|
}
|
||||||
|
|
||||||
void eliminate_last_term_column() {
|
void eliminate_last_term_column() {
|
||||||
|
// change only the rows in m_l_matrix, and update m_e_matrix lazily
|
||||||
unsigned j = m_l_matrix.column_count() - 1;
|
unsigned j = m_l_matrix.column_count() - 1;
|
||||||
make_sure_j_is_in_the_last_row_of_l_matrix();
|
make_sure_j_is_in_the_last_row_of_l_matrix();
|
||||||
const auto &last_e_row = m_l_matrix.m_rows.back();
|
const auto &last_e_row = m_l_matrix.m_rows.back();
|
||||||
|
@ -460,7 +461,6 @@ namespace lp {
|
||||||
}
|
}
|
||||||
unsigned last_row_index= m_l_matrix.row_count() - 1;
|
unsigned last_row_index= m_l_matrix.row_count() - 1;
|
||||||
m_l_matrix.divide_row(last_row_index, alpha); // divide the last row by alpha
|
m_l_matrix.divide_row(last_row_index, alpha); // divide the last row by alpha
|
||||||
std_vector<unsigned> rows_to_change;
|
|
||||||
|
|
||||||
auto &column = m_l_matrix.m_columns[j];
|
auto &column = m_l_matrix.m_columns[j];
|
||||||
int pivot_col_cell_index = -1;
|
int pivot_col_cell_index = -1;
|
||||||
|
@ -486,12 +486,8 @@ namespace lp {
|
||||||
auto & c = column.back();
|
auto & c = column.back();
|
||||||
SASSERT(c.var() != last_row_index);
|
SASSERT(c.var() != last_row_index);
|
||||||
m_l_matrix.pivot_row_to_row_given_cell(last_row_index, c, j);
|
m_l_matrix.pivot_row_to_row_given_cell(last_row_index, c, j);
|
||||||
rows_to_change.push_back(c.var());
|
m_changed_rows.insert(c.var());
|
||||||
}
|
}
|
||||||
|
|
||||||
for (unsigned i : rows_to_change) {
|
|
||||||
recalculate_entry(i);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void make_sure_j_is_in_the_last_row_of_l_matrix() {
|
void make_sure_j_is_in_the_last_row_of_l_matrix() {
|
||||||
|
@ -521,7 +517,7 @@ namespace lp {
|
||||||
}
|
}
|
||||||
m_var_register.shrink(m_e_matrix.column_count());
|
m_var_register.shrink(m_e_matrix.column_count());
|
||||||
|
|
||||||
SASSERT(m_row2fresh_defs.find(i) == m_row2fresh_defs.end());
|
remove_irrelevant_fresh_defs_for_row(i);
|
||||||
|
|
||||||
if (m_k2s.has_val(i)) {
|
if (m_k2s.has_val(i)) {
|
||||||
remove_from_S(i);
|
remove_from_S(i);
|
||||||
|
@ -744,7 +740,10 @@ namespace lp {
|
||||||
}
|
}
|
||||||
|
|
||||||
void delete_column(unsigned j) {
|
void delete_column(unsigned j) {
|
||||||
NOT_IMPLEMENTED_YET();
|
SASSERT(j >= m_e_matrix.column_count());
|
||||||
|
SASSERT(m_k2s.has_key(j) == false);
|
||||||
|
SASSERT(m_k2s.has_val(j) == false);
|
||||||
|
SASSERT(m_columns_to_terms.find(j) == m_columns_to_terms.end());
|
||||||
}
|
}
|
||||||
|
|
||||||
void clear_e_row(unsigned ei) {
|
void clear_e_row(unsigned ei) {
|
||||||
|
@ -794,17 +793,22 @@ namespace lp {
|
||||||
for (const auto& p : m_e_matrix.column(this->lar_solver_to_local(j))) {
|
for (const auto& p : m_e_matrix.column(this->lar_solver_to_local(j))) {
|
||||||
m_changed_rows.insert(p.var()); // TODO: is it necessary?
|
m_changed_rows.insert(p.var()); // TODO: is it necessary?
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void remove_irrelevant_fresh_defs_for_row(unsigned ei) {
|
||||||
|
auto it = m_row2fresh_defs.find(ei);
|
||||||
|
if (it == m_row2fresh_defs.end()) return;
|
||||||
|
for (unsigned xt: it->second) {
|
||||||
|
m_fresh_k2xt_terms.erase_by_second_key(xt);
|
||||||
|
}
|
||||||
|
m_row2fresh_defs.erase(it);
|
||||||
|
}
|
||||||
|
|
||||||
void remove_irrelevant_fresh_defs() {
|
void remove_irrelevant_fresh_defs() {
|
||||||
for (unsigned ei : m_changed_rows) {
|
for (unsigned ei : m_changed_rows) {
|
||||||
auto it = m_row2fresh_defs.find(ei);
|
remove_irrelevant_fresh_defs_for_row(ei);
|
||||||
if (it == m_row2fresh_defs.end()) continue;
|
|
||||||
for (unsigned xt: it->second) {
|
|
||||||
m_fresh_k2xt_terms.erase_by_second_key(xt);
|
|
||||||
}
|
|
||||||
m_row2fresh_defs.erase(it);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -928,8 +932,8 @@ namespace lp {
|
||||||
}
|
}
|
||||||
|
|
||||||
std::cout << std::endl;
|
std::cout << std::endl;
|
||||||
std::cout << "the other entry:";
|
std::cout << "column " << p.var() << " is subst by entry:";
|
||||||
print_entry(m_k2s[p.var()],std::cout) << std::endl;
|
print_entry(m_k2s[p.var()],std::cout) << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2091,7 +2095,8 @@ namespace lp {
|
||||||
}
|
}
|
||||||
|
|
||||||
// The idea is to remove this fresh definition when the row h changes.
|
// The idea is to remove this fresh definition when the row h changes.
|
||||||
// The row can change if it depends on the term that is deleted, or on a variable that becomes fixed/unfixed
|
// The row can change if it depends on the term that is deleted, or on a variable that becomes fixed/unfixed
|
||||||
|
// fr_j is a fresh variable
|
||||||
void register_var_in_fresh_defs(unsigned h, unsigned fr_j) {
|
void register_var_in_fresh_defs(unsigned h, unsigned fr_j) {
|
||||||
auto it = m_row2fresh_defs.find(h);
|
auto it = m_row2fresh_defs.find(h);
|
||||||
if (it == m_row2fresh_defs.end()) {
|
if (it == m_row2fresh_defs.end()) {
|
||||||
|
|
Loading…
Reference in a new issue