mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-26 17:29:21 +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()); | ||||
|     } | ||||
|     if (m_r_solver.get_status() == lp_status::INFEASIBLE) { | ||||
|     switch (m_r_solver.get_status()) | ||||
|     { | ||||
|     case lp_status::INFEASIBLE: | ||||
|         fill_not_improvable_zero_sum(); | ||||
|     }  | ||||
|     else if (m_r_solver.get_status() != lp_status::UNBOUNDED) { | ||||
|         break; | ||||
|     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); | ||||
|         break; | ||||
|     } | ||||
|     lp_assert(r_basis_is_OK()); | ||||
|     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) { | ||||
|         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
 | ||||
| } | ||||
| 
 | ||||
|  | @ -747,6 +744,6 @@ template <typename T, typename X> void lp_dual_core_solver<T, X>::solve() { // s | |||
|         one_iteration(); | ||||
|     } 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->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; | ||||
|     case lp_status::DUAL_UNBOUNDED: | ||||
|         lp_unreachable(); | ||||
|     case lp_status::ITERATIONS_EXHAUSTED: | ||||
|         this->m_status = lp_status::ITERATIONS_EXHAUSTED; | ||||
|         break; | ||||
|     case lp_status::TIME_EXHAUSTED: | ||||
|         this->m_status = lp_status::TIME_EXHAUSTED; | ||||
|         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->total_iterations() <= this->m_settings.max_total_number_of_iterations | ||||
|              && | ||||
|              !(this->current_x_is_feasible() && this->m_look_for_feasible_solution_only)); | ||||
| 
 | ||||
|     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; | ||||
|     } | ||||
|     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; | ||||
|     } | ||||
|     if (this->total_iterations() >= this->m_settings.max_total_number_of_iterations) { | ||||
|         this->get_status() = lp_status::ITERATIONS_EXHAUSTED; return true; | ||||
|         this->set_status(lp_status::CANCELLED); | ||||
|         return true; | ||||
|     } | ||||
|     return false; | ||||
| } | ||||
|  |  | |||
|  | @ -182,9 +182,7 @@ unsigned lp_primal_core_solver<T, X>::solve_with_tableau() { | |||
|         if (this->m_settings.get_cancel_flag() | ||||
|             || | ||||
|             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); | ||||
|             break; // from the loop
 | ||||
|         } | ||||
|  |  | |||
|  | @ -71,7 +71,6 @@ enum class lp_status { | |||
|     FEASIBLE, | ||||
|     FLOATING_POINT_ERROR, | ||||
|     TIME_EXHAUSTED, | ||||
|     ITERATIONS_EXHAUSTED, | ||||
|     EMPTY, | ||||
|     UNSTABLE, | ||||
|     CANCELLED | ||||
|  | @ -210,7 +209,6 @@ public: | |||
|     double       harris_feasibility_tolerance { 1e-7 };         // page 179 of Istvan Maros
 | ||||
|     double       ignore_epsilon_of_harris { 10e-5 }; | ||||
|     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
 | ||||
|     // dual section
 | ||||
|     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::FLOATING_POINT_ERROR: return "FLOATING_POINT_ERROR"; | ||||
|     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::UNSTABLE: return "UNSTABLE"; | ||||
|     default: | ||||
|  | @ -62,7 +61,6 @@ lp_status lp_status_from_string(std::string status) { | |||
|     if (status == "FEASIBLE") return lp_status::FEASIBLE; | ||||
|     if (status == "FLOATING_POINT_ERROR") return lp_status::FLOATING_POINT_ERROR; | ||||
|     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; | ||||
|     lp_unreachable(); | ||||
|     return lp_status::UNKNOWN; // it is unreachable
 | ||||
|  |  | |||
|  | @ -158,13 +158,7 @@ public: | |||
|         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: | ||||
|     bool problem_is_empty(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -3095,7 +3095,7 @@ public: | |||
|         default: | ||||
|             TRACE("arith", tout << "status treated as inconclusive: " << status << "\n";); | ||||
|             // 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; | ||||
|         } | ||||
|     } | ||||
|  |  | |||
|  | @ -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; | ||||
|     } | ||||
|      | ||||
|     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 (reader == nullptr) { | ||||
|             std::cout << "cannot compare with primal, the reader is null " << std::endl; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue