mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-22 23:44:34 +00:00 
			
		
		
		
	fix push/pop bugs in optimize context, add example to c++, fix bug in arithemtic bounds axiom addition
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
		
							parent
							
								
									31f16d7aa4
								
							
						
					
					
						commit
						3f8083dfa6
					
				
					 3 changed files with 34 additions and 1 deletions
				
			
		|  | @ -972,7 +972,29 @@ void substitute_example() { | |||
|     std::cout << new_f << std::endl; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| void opt_example() { | ||||
|     context c; | ||||
|     optimize opt(c); | ||||
|     params p(c); | ||||
|     p.set("priority",c.str_symbol("pareto")); | ||||
|     opt.set(p); | ||||
|     expr x = c.int_const("x"); | ||||
|     expr y = c.int_const("y"); | ||||
|     opt.add(10 >= x && x >= 0); | ||||
|     opt.add(10 >= y && y >= 0); | ||||
|     opt.add(x + y <= 11); | ||||
|     optimize::handle h1 = opt.maximize(x); | ||||
|     optimize::handle h2 = opt.maximize(y); | ||||
|     check_result r = sat; | ||||
|     while (true) { | ||||
|         if (sat == opt.check()) { | ||||
|             std::cout << x << ": " << opt.lower(h1) << " " << y << ": " << opt.lower(h2) << "\n"; | ||||
|         } | ||||
|         else { | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| int main() { | ||||
|     try { | ||||
|  | @ -1012,6 +1034,7 @@ int main() { | |||
|         expr_vector_example(); std::cout << "\n"; | ||||
|         exists_expr_vector_example(); std::cout << "\n"; | ||||
|         substitute_example(); std::cout << "\n"; | ||||
|         opt_example(); std::cout << "\n"; | ||||
|         std::cout << "done\n"; | ||||
|     } | ||||
|     catch (exception & ex) { | ||||
|  |  | |||
|  | @ -139,6 +139,7 @@ namespace opt { | |||
|         for (; it != end; ++it) { | ||||
|             dealloc(it->m_value); | ||||
|         } | ||||
|         m_maxsmts.reset(); | ||||
|     } | ||||
| 
 | ||||
|     void context::push() { | ||||
|  | @ -149,21 +150,29 @@ namespace opt { | |||
|         for (unsigned i = 0; i < n; ++i) { | ||||
|             m_scoped_state.pop(); | ||||
|         } | ||||
|         m_model.reset(); | ||||
|         reset_maxsmts(); | ||||
|         m_optsmt.reset();         | ||||
|         m_hard_constraints.reset(); | ||||
|     } | ||||
| 
 | ||||
|     void context::set_hard_constraints(ptr_vector<expr>& fmls) { | ||||
|         m_scoped_state.set(fmls); | ||||
|         m_model.reset(); | ||||
|     } | ||||
| 
 | ||||
|     void context::add_hard_constraint(expr* f) {  | ||||
|         m_scoped_state.add(f); | ||||
|         m_model.reset(); | ||||
|     } | ||||
| 
 | ||||
|     unsigned context::add_soft_constraint(expr* f, rational const& w, symbol const& id) {  | ||||
|         m_model.reset(); | ||||
|         return m_scoped_state.add(f, w, id); | ||||
|     } | ||||
| 
 | ||||
|     unsigned context::add_objective(app* t, bool is_max) { | ||||
|         m_model.reset(); | ||||
|         return m_scoped_state.add(t, is_max); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -3090,6 +3090,7 @@ namespace smt { | |||
|         SASSERT(m_to_patch.empty()); | ||||
|         m_to_check.reset(); | ||||
|         m_in_to_check.reset(); | ||||
|         m_new_atoms.reset(); | ||||
|         CASSERT("arith", wf_rows()); | ||||
|         CASSERT("arith", wf_columns()); | ||||
|         CASSERT("arith", valid_row_assignment()); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue