mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-26 17:29:21 +00:00 
			
		
		
		
	more general predicate recognizer for quantified Horn clauses
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
		
							parent
							
								
									6a18015622
								
							
						
					
					
						commit
						2c54bbba5f
					
				
					 1 changed files with 20 additions and 3 deletions
				
			
		|  | @ -90,6 +90,24 @@ class horn_tactic : public tactic { | |||
|             m_ctx.register_predicate(to_app(a)->get_decl(), true); | ||||
|         } | ||||
| 
 | ||||
|         void check_predicate(expr* a) { | ||||
|             expr* a1 = 0; | ||||
|             while (true) { | ||||
|                 if (is_quantifier(a)) { | ||||
|                     a = to_quantifier(a)->get_expr(); | ||||
|                     continue; | ||||
|                 } | ||||
|                 if (m.is_not(a, a1)) { | ||||
|                     a = a1; | ||||
|                     continue; | ||||
|                 } | ||||
|                 if (is_predicate(a)) { | ||||
|                     register_predicate(a); | ||||
|                 } | ||||
|                 break; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         enum formula_kind { IS_RULE, IS_QUERY, IS_NONE }; | ||||
| 
 | ||||
|         formula_kind get_formula_kind(expr_ref& f) { | ||||
|  | @ -100,12 +118,11 @@ class horn_tactic : public tactic { | |||
|             datalog::flatten_or(f, args); | ||||
|             for (unsigned i = 0; i < args.size(); ++i) { | ||||
|                 a = args[i].get();     | ||||
|                 check_predicate(a); | ||||
|                 if (m.is_not(a, a1) && is_predicate(a1)) { | ||||
|                     register_predicate(a1); | ||||
|                     body.push_back(a1); | ||||
|                 } | ||||
|                 else if (is_predicate(a)) { | ||||
|                     register_predicate(a); | ||||
|                     if (head) { | ||||
|                         return IS_NONE; | ||||
|                     } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue