mirror of
https://github.com/Z3Prover/z3
synced 2025-06-06 14:13:23 +00:00
remove the bound on total iterations in simplex
Signed-off-by: Lev Nachmanson <levnach@hotmail.com>
This commit is contained in:
parent
1618c970df
commit
ad98c2df8e
10 changed files with 16 additions and 36 deletions
|
@ -179,11 +179,17 @@ void lar_core_solver::solve() {
|
||||||
}
|
}
|
||||||
lp_assert(!settings().use_tableau() || r_basis_is_OK());
|
lp_assert(!settings().use_tableau() || r_basis_is_OK());
|
||||||
}
|
}
|
||||||
if (m_r_solver.get_status() == lp_status::INFEASIBLE) {
|
switch (m_r_solver.get_status())
|
||||||
|
{
|
||||||
|
case lp_status::INFEASIBLE:
|
||||||
fill_not_improvable_zero_sum();
|
fill_not_improvable_zero_sum();
|
||||||
}
|
break;
|
||||||
else if (m_r_solver.get_status() != lp_status::UNBOUNDED) {
|
case lp_status::CANCELLED:
|
||||||
|
case lp_status::UNBOUNDED: // do nothing in these cases
|
||||||
|
break;
|
||||||
|
default: // adjust the status to optimal
|
||||||
m_r_solver.set_status(lp_status::OPTIMAL);
|
m_r_solver.set_status(lp_status::OPTIMAL);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
lp_assert(r_basis_is_OK());
|
lp_assert(r_basis_is_OK());
|
||||||
lp_assert(m_r_solver.non_basic_columns_are_set_correctly());
|
lp_assert(m_r_solver.non_basic_columns_are_set_correctly());
|
||||||
|
|
|
@ -100,10 +100,7 @@ template <typename T, typename X> bool lp_dual_core_solver<T, X>::done() {
|
||||||
if (this->get_status() == lp_status::OPTIMAL) {
|
if (this->get_status() == lp_status::OPTIMAL) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (this->total_iterations() > this->m_settings.max_total_number_of_iterations) { // debug !!!!
|
|
||||||
this->set_status(lp_status::ITERATIONS_EXHAUSTED);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false; // todo, need to be more cases
|
return false; // todo, need to be more cases
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -747,6 +744,6 @@ template <typename T, typename X> void lp_dual_core_solver<T, X>::solve() { // s
|
||||||
one_iteration();
|
one_iteration();
|
||||||
} while (this->get_status() != lp_status::FLOATING_POINT_ERROR && this->get_status() != lp_status::DUAL_UNBOUNDED && this->get_status() != lp_status::OPTIMAL &&
|
} while (this->get_status() != lp_status::FLOATING_POINT_ERROR && this->get_status() != lp_status::DUAL_UNBOUNDED && this->get_status() != lp_status::OPTIMAL &&
|
||||||
this->iters_with_no_cost_growing() <= this->m_settings.max_number_of_iterations_with_no_improvements
|
this->iters_with_no_cost_growing() <= this->m_settings.max_number_of_iterations_with_no_improvements
|
||||||
&& this->total_iterations() <= this->m_settings.max_total_number_of_iterations);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,9 +31,6 @@ template <typename T, typename X> void lp_dual_simplex<T, X>::decide_on_status_a
|
||||||
break;
|
break;
|
||||||
case lp_status::DUAL_UNBOUNDED:
|
case lp_status::DUAL_UNBOUNDED:
|
||||||
lp_unreachable();
|
lp_unreachable();
|
||||||
case lp_status::ITERATIONS_EXHAUSTED:
|
|
||||||
this->m_status = lp_status::ITERATIONS_EXHAUSTED;
|
|
||||||
break;
|
|
||||||
case lp_status::TIME_EXHAUSTED:
|
case lp_status::TIME_EXHAUSTED:
|
||||||
this->m_status = lp_status::TIME_EXHAUSTED;
|
this->m_status = lp_status::TIME_EXHAUSTED;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -956,8 +956,6 @@ template <typename T, typename X> unsigned lp_primal_core_solver<T, X>::solve()
|
||||||
&&
|
&&
|
||||||
this->iters_with_no_cost_growing() <= this->m_settings.max_number_of_iterations_with_no_improvements
|
this->iters_with_no_cost_growing() <= this->m_settings.max_number_of_iterations_with_no_improvements
|
||||||
&&
|
&&
|
||||||
this->total_iterations() <= this->m_settings.max_total_number_of_iterations
|
|
||||||
&&
|
|
||||||
!(this->current_x_is_feasible() && this->m_look_for_feasible_solution_only));
|
!(this->current_x_is_feasible() && this->m_look_for_feasible_solution_only));
|
||||||
|
|
||||||
lp_assert(this->get_status() == lp_status::FLOATING_POINT_ERROR
|
lp_assert(this->get_status() == lp_status::FLOATING_POINT_ERROR
|
||||||
|
@ -1097,10 +1095,8 @@ template <typename T, typename X> bool lp_primal_core_solver<T, X>::done() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (this->m_iters_with_no_cost_growing >= this->m_settings.max_number_of_iterations_with_no_improvements) {
|
if (this->m_iters_with_no_cost_growing >= this->m_settings.max_number_of_iterations_with_no_improvements) {
|
||||||
this->get_status() = lp_status::ITERATIONS_EXHAUSTED; return true;
|
this->set_status(lp_status::CANCELLED);
|
||||||
}
|
return true;
|
||||||
if (this->total_iterations() >= this->m_settings.max_total_number_of_iterations) {
|
|
||||||
this->get_status() = lp_status::ITERATIONS_EXHAUSTED; return true;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -182,9 +182,7 @@ unsigned lp_primal_core_solver<T, X>::solve_with_tableau() {
|
||||||
if (this->m_settings.get_cancel_flag()
|
if (this->m_settings.get_cancel_flag()
|
||||||
||
|
||
|
||||||
this->iters_with_no_cost_growing() > this->m_settings.max_number_of_iterations_with_no_improvements
|
this->iters_with_no_cost_growing() > this->m_settings.max_number_of_iterations_with_no_improvements
|
||||||
||
|
) {
|
||||||
this->total_iterations() > this->m_settings.max_total_number_of_iterations
|
|
||||||
) {
|
|
||||||
this->set_status(lp_status::CANCELLED);
|
this->set_status(lp_status::CANCELLED);
|
||||||
break; // from the loop
|
break; // from the loop
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,7 +71,6 @@ enum class lp_status {
|
||||||
FEASIBLE,
|
FEASIBLE,
|
||||||
FLOATING_POINT_ERROR,
|
FLOATING_POINT_ERROR,
|
||||||
TIME_EXHAUSTED,
|
TIME_EXHAUSTED,
|
||||||
ITERATIONS_EXHAUSTED,
|
|
||||||
EMPTY,
|
EMPTY,
|
||||||
UNSTABLE,
|
UNSTABLE,
|
||||||
CANCELLED
|
CANCELLED
|
||||||
|
@ -210,7 +209,6 @@ public:
|
||||||
double harris_feasibility_tolerance { 1e-7 }; // page 179 of Istvan Maros
|
double harris_feasibility_tolerance { 1e-7 }; // page 179 of Istvan Maros
|
||||||
double ignore_epsilon_of_harris { 10e-5 };
|
double ignore_epsilon_of_harris { 10e-5 };
|
||||||
unsigned max_number_of_iterations_with_no_improvements { 2000000 };
|
unsigned max_number_of_iterations_with_no_improvements { 2000000 };
|
||||||
unsigned max_total_number_of_iterations { 20000000 };
|
|
||||||
double time_limit; // the maximum time limit of the total run time in seconds
|
double time_limit; // the maximum time limit of the total run time in seconds
|
||||||
// dual section
|
// dual section
|
||||||
double dual_feasibility_tolerance { 1e-7 }; // page 71 of the PhD thesis of Achim Koberstein
|
double dual_feasibility_tolerance { 1e-7 }; // page 71 of the PhD thesis of Achim Koberstein
|
||||||
|
|
|
@ -45,7 +45,6 @@ const char* lp_status_to_string(lp_status status) {
|
||||||
case lp_status::FEASIBLE: return "FEASIBLE";
|
case lp_status::FEASIBLE: return "FEASIBLE";
|
||||||
case lp_status::FLOATING_POINT_ERROR: return "FLOATING_POINT_ERROR";
|
case lp_status::FLOATING_POINT_ERROR: return "FLOATING_POINT_ERROR";
|
||||||
case lp_status::TIME_EXHAUSTED: return "TIME_EXHAUSTED";
|
case lp_status::TIME_EXHAUSTED: return "TIME_EXHAUSTED";
|
||||||
case lp_status::ITERATIONS_EXHAUSTED: return "ITERATIONS_EXHAUSTED";
|
|
||||||
case lp_status::EMPTY: return "EMPTY";
|
case lp_status::EMPTY: return "EMPTY";
|
||||||
case lp_status::UNSTABLE: return "UNSTABLE";
|
case lp_status::UNSTABLE: return "UNSTABLE";
|
||||||
default:
|
default:
|
||||||
|
@ -62,7 +61,6 @@ lp_status lp_status_from_string(std::string status) {
|
||||||
if (status == "FEASIBLE") return lp_status::FEASIBLE;
|
if (status == "FEASIBLE") return lp_status::FEASIBLE;
|
||||||
if (status == "FLOATING_POINT_ERROR") return lp_status::FLOATING_POINT_ERROR;
|
if (status == "FLOATING_POINT_ERROR") return lp_status::FLOATING_POINT_ERROR;
|
||||||
if (status == "TIME_EXHAUSTED") return lp_status::TIME_EXHAUSTED;
|
if (status == "TIME_EXHAUSTED") return lp_status::TIME_EXHAUSTED;
|
||||||
if (status == "ITERATIONS_EXHAUSTED") return lp_status::ITERATIONS_EXHAUSTED;
|
|
||||||
if (status == "EMPTY") return lp_status::EMPTY;
|
if (status == "EMPTY") return lp_status::EMPTY;
|
||||||
lp_unreachable();
|
lp_unreachable();
|
||||||
return lp_status::UNKNOWN; // it is unreachable
|
return lp_status::UNKNOWN; // it is unreachable
|
||||||
|
|
|
@ -158,13 +158,7 @@ public:
|
||||||
m_settings.time_limit = time_limit_in_seconds;
|
m_settings.time_limit = time_limit_in_seconds;
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_max_iterations_per_stage(unsigned max_iterations) {
|
|
||||||
m_settings.max_total_number_of_iterations = max_iterations;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned get_max_iterations_per_stage() const {
|
|
||||||
return m_settings.max_total_number_of_iterations;
|
|
||||||
}
|
|
||||||
protected:
|
protected:
|
||||||
bool problem_is_empty();
|
bool problem_is_empty();
|
||||||
|
|
||||||
|
|
|
@ -3095,7 +3095,7 @@ public:
|
||||||
default:
|
default:
|
||||||
TRACE("arith", tout << "status treated as inconclusive: " << status << "\n";);
|
TRACE("arith", tout << "status treated as inconclusive: " << status << "\n";);
|
||||||
// TENTATIVE_UNBOUNDED, UNBOUNDED, TENTATIVE_DUAL_UNBOUNDED, DUAL_UNBOUNDED,
|
// TENTATIVE_UNBOUNDED, UNBOUNDED, TENTATIVE_DUAL_UNBOUNDED, DUAL_UNBOUNDED,
|
||||||
// FLOATING_POINT_ERROR, TIME_EXAUSTED, ITERATIONS_EXHAUSTED, EMPTY, UNSTABLE
|
// FLOATING_POINT_ERROR, TIME_EXAUSTED, EMPTY, UNSTABLE
|
||||||
return l_undef;
|
return l_undef;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2651,10 +2651,6 @@ void run_lar_solver(argument_parser & args_parser, lar_solver * solver, mps_read
|
||||||
solver->settings().presolve_with_double_solver_for_lar = true;
|
solver->settings().presolve_with_double_solver_for_lar = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string iter = args_parser.get_option_value("--max_iters");
|
|
||||||
if (!iter.empty()) {
|
|
||||||
solver->settings().max_total_number_of_iterations = atoi(iter.c_str());
|
|
||||||
}
|
|
||||||
if (args_parser.option_is_used("--compare_with_primal")){
|
if (args_parser.option_is_used("--compare_with_primal")){
|
||||||
if (reader == nullptr) {
|
if (reader == nullptr) {
|
||||||
std::cout << "cannot compare with primal, the reader is null " << std::endl;
|
std::cout << "cannot compare with primal, the reader is null " << std::endl;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue