Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

remove operation with doubles #6623

Merged
merged 36 commits into from
Mar 8, 2023
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
885e93c
before rm lu
levnach Mar 4, 2023
60a5c39
rm get_column_in_lu_mode
levnach Mar 4, 2023
69c8043
rm lu
levnach Mar 4, 2023
1e8bf76
rm lu
levnach Mar 4, 2023
1bbb359
rm_lp
levnach Mar 4, 2023
a2a1208
rm_lu
levnach Mar 4, 2023
832b804
rm lu
levnach Mar 4, 2023
9c11283
rm lu
levnach Mar 5, 2023
0a9516d
rm lu
levnach Mar 6, 2023
5c69cc6
rm lu
levnach Mar 6, 2023
15f41d7
rm lu
levnach Mar 6, 2023
6c78d25
rm lu
levnach Mar 6, 2023
1bf416d
rm lu
levnach Mar 6, 2023
0784243
cleanup
levnach Mar 6, 2023
5379fb8
rm breakpoints
levnach Mar 6, 2023
547254a
rm dealing with doubles
levnach Mar 6, 2023
4e948ce
Revert "rm dealing with doubles"
levnach Mar 6, 2023
1c2c108
rm lu
levnach Mar 6, 2023
5495b2b
rm lu
levnach Mar 6, 2023
e9b902e
rm lu
levnach Mar 6, 2023
4dfc708
rm scaler
levnach Mar 6, 2023
a37fd87
rm square_sparse_matrix
levnach Mar 6, 2023
4e90cfe
more cleanup
levnach Mar 6, 2023
a9aa3f5
rm dead code
levnach Mar 6, 2023
3c737b6
rp precise
levnach Mar 7, 2023
3b18c87
remove many methods dealing with double
levnach Mar 7, 2023
3b6e2cc
rm lu related fields from lp_core_solver_base.h
levnach Mar 7, 2023
0aad503
remove dead code
levnach Mar 7, 2023
826c42c
more dead code removal
levnach Mar 7, 2023
81fd093
remove more dead code
levnach Mar 7, 2023
29f6525
more dead code
levnach Mar 8, 2023
8c5b316
rm dead code
levnach Mar 8, 2023
9d964fc
more dead code
levnach Mar 8, 2023
78a3602
fix lp_tst
levnach Mar 8, 2023
5577314
more dead code
levnach Mar 8, 2023
d80ab99
replace lp_assert(false) with UNREACHABLE
levnach Mar 8, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 0 additions & 10 deletions src/math/lp/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ z3_add_component(lp
binary_heap_upair_queue.cpp
core_solver_pretty_printer.cpp
dense_matrix.cpp
eta_matrix.cpp
emonics.cpp
factorization.cpp
factorization_factory_imp.cpp
Expand All @@ -19,13 +18,8 @@ z3_add_component(lp
lar_solver.cpp
lar_core_solver.cpp
lp_core_solver_base.cpp
lp_dual_core_solver.cpp
lp_dual_simplex.cpp
lp_primal_core_solver.cpp
lp_primal_simplex.cpp
lp_settings.cpp
lp_solver.cpp
lu.cpp
lp_utils.cpp
matrix.cpp
mon_eq.cpp
Expand All @@ -45,10 +39,6 @@ z3_add_component(lp
nra_solver.cpp
permutation_matrix.cpp
random_updater.cpp
row_eta_matrix.cpp
scaler.cpp
square_dense_submatrix.cpp
square_sparse_matrix.cpp
static_matrix.cpp
COMPONENT_DEPENDENCIES
util
Expand Down
35 changes: 0 additions & 35 deletions src/math/lp/breakpoint.h

This file was deleted.

1 change: 0 additions & 1 deletion src/math/lp/core_solver_pretty_printer.h
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,6 @@ class core_solver_pretty_printer {
return T_to_string(m_exact_column_norms[col]);
}

void print_exact_norms();

void print_approx_norms();

Expand Down
67 changes: 6 additions & 61 deletions src/math/lp/core_solver_pretty_printer_def.h
Original file line number Diff line number Diff line change
Expand Up @@ -59,22 +59,13 @@ core_solver_pretty_printer<T, X>::core_solver_pretty_printer(const lp_core_solve
}

template <typename T, typename X> void core_solver_pretty_printer<T, X>::init_costs() {
if (!m_core_solver.use_tableau()) {
vector<T> local_y(m_core_solver.m_m());
m_core_solver.solve_yB(local_y);
for (unsigned i = 0; i < ncols(); i++) {
if (m_core_solver.m_basis_heading[i] < 0) {
T t = m_core_solver.m_costs[i] - m_core_solver.m_A.dot_product_with_column(local_y, i);
set_coeff(m_costs, m_cost_signs, i, t, m_core_solver.column_name(i));
}
}
} else {

for (unsigned i = 0; i < ncols(); i++) {
if (m_core_solver.m_basis_heading[i] < 0) {
set_coeff(m_costs, m_cost_signs, i, m_core_solver.m_d[i], m_core_solver.column_name(i));
}
}
}

}

template <typename T, typename X> core_solver_pretty_printer<T, X>::~core_solver_pretty_printer() {
Expand All @@ -97,7 +88,7 @@ template <typename T, typename X> T core_solver_pretty_printer<T, X>::current_co
}

template <typename T, typename X> void core_solver_pretty_printer<T, X>::init_m_A_and_signs() {
if (numeric_traits<T>::precise() && m_core_solver.m_settings.use_tableau()) {
if (numeric_traits<T>::precise() ) {
for (unsigned column = 0; column < ncols(); column++) {
vector<T> t(nrows(), zero_of_type<T>());
for (const auto & c : m_core_solver.m_A.m_columns[column]){
Expand Down Expand Up @@ -125,23 +116,7 @@ template <typename T, typename X> void core_solver_pretty_printer<T, X>::init_m_
m_rs[row] += t[row] * m_core_solver.m_x[column];
}
}
} else {
for (unsigned column = 0; column < ncols(); column++) {
m_core_solver.solve_Bd(column, m_ed_buff, m_w_buff); // puts the result into m_core_solver.m_ed
string name = m_core_solver.column_name(column);
for (unsigned row = 0; row < nrows(); row ++) {
set_coeff(
m_A[row],
m_signs[row],
column,
m_ed_buff[row],
name);
m_rs[row] += m_ed_buff[row] * m_core_solver.m_x[column];
}
if (!m_core_solver.use_tableau())
m_exact_column_norms.push_back(current_column_norm() + T(1)); // a conversion missing 1 -> T
}
}
}
}

template <typename T, typename X> void core_solver_pretty_printer<T, X>::init_column_widths() {
Expand Down Expand Up @@ -190,11 +165,7 @@ template <typename T, typename X> unsigned core_solver_pretty_printer<T, X>:: ge
w = cellw;
}
}
if (!m_core_solver.use_tableau()) {
w = std::max(w, (unsigned)T_to_string(m_exact_column_norms[column]).size());
if (!m_core_solver.m_column_norms.empty())
w = std::max(w, (unsigned)T_to_string(m_core_solver.m_column_norms[column]).size());
}

return w;
}

Expand Down Expand Up @@ -315,41 +286,15 @@ template <typename T, typename X> void core_solver_pretty_printer<T, X>::print_u
m_out << std::endl;
}

template <typename T, typename X> void core_solver_pretty_printer<T, X>::print_exact_norms() {
if (m_core_solver.use_tableau()) return;
int blanks = m_title_width + 1 - static_cast<int>(m_exact_norm_title.size());
m_out << m_exact_norm_title;
print_blanks_local(blanks, m_out);
for (unsigned i = 0; i < ncols(); i++) {
string s = get_exact_column_norm_string(i);
int blanks = m_column_widths[i] - static_cast<int>(s.size());
print_blanks_local(blanks, m_out);
m_out << s << " ";
}
m_out << std::endl;
}

template <typename T, typename X> void core_solver_pretty_printer<T, X>::print_approx_norms() {
if (m_core_solver.use_tableau()) return;
int blanks = m_title_width + 1 - static_cast<int>(m_approx_norm_title.size());
m_out << m_approx_norm_title;
print_blanks_local(blanks, m_out);
for (unsigned i = 0; i < ncols(); i++) {
string s = T_to_string(m_core_solver.m_column_norms[i]);
int blanks = m_column_widths[i] - static_cast<int>(s.size());
print_blanks_local(blanks, m_out);
m_out << s << " ";
}
m_out << std::endl;
return;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

add comment in code to mark for deletion

}

template <typename T, typename X> void core_solver_pretty_printer<T, X>::print() {
for (unsigned i = 0; i < nrows(); i++) {
print_row(i);
}
print_exact_norms();
if (!m_core_solver.m_column_norms.empty())
print_approx_norms();
m_out << std::endl;
if (m_core_solver.inf_set().size()) {
m_out << "inf columns: ";
Expand Down
43 changes: 0 additions & 43 deletions src/math/lp/eta_matrix.cpp

This file was deleted.

98 changes: 0 additions & 98 deletions src/math/lp/eta_matrix.h

This file was deleted.

Loading