mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-25 08:54:35 +00:00 
			
		
		
		
	revamp configuration parameter names for fixedpoint
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
		
							parent
							
								
									f748a03ac7
								
							
						
					
					
						commit
						ddbff6f77b
					
				
					 12 changed files with 358 additions and 246 deletions
				
			
		|  | @ -272,34 +272,34 @@ namespace datalog { | |||
| 
 | ||||
| 
 | ||||
|     bool context::generate_proof_trace() const { return m_params->generate_proof_trace(); } | ||||
|     bool context::output_profile() const { return m_params->output_profile(); } | ||||
|     bool context::output_tuples() const { return m_params->output_tuples(); } | ||||
|     bool context::use_map_names() const { return m_params->use_map_names(); } | ||||
|     bool context::fix_unbound_vars() const { return m_params->fix_unbound_vars(); } | ||||
|     symbol context::default_table() const { return m_params->default_table(); } | ||||
|     symbol context::default_relation() const { return m_params->default_relation(); } // external_relation_plugin::get_name()); 
 | ||||
|     symbol context::default_table_checker() const { return m_params->default_table_checker(); } | ||||
|     bool context::default_table_checked() const { return m_params->default_table_checked(); } | ||||
|     bool context::dbg_fpr_nonempty_relation_signature() const { return m_params->dbg_fpr_nonempty_relation_signature(); } | ||||
|     unsigned context::dl_profile_milliseconds_threshold() const { return m_params->profile_timeout_milliseconds(); } | ||||
|     bool context::all_or_nothing_deltas() const { return m_params->all_or_nothing_deltas(); } | ||||
|     bool context::compile_with_widening() const { return m_params->compile_with_widening(); } | ||||
|     bool context::unbound_compressor() const { return m_params->unbound_compressor(); } | ||||
|     bool context::similarity_compressor() const { return m_params->similarity_compressor(); } | ||||
|     unsigned context::similarity_compressor_threshold() const { return m_params->similarity_compressor_threshold(); } | ||||
|     bool context::output_profile() const { return m_params->datalog_output_profile(); } | ||||
|     bool context::output_tuples() const { return m_params->datalog_print_tuples(); } | ||||
|     bool context::use_map_names() const { return m_params->datalog_use_map_names(); } | ||||
|     bool context::fix_unbound_vars() const { return m_params->xform_fix_unbound_vars(); } | ||||
|     symbol context::default_table() const { return m_params->datalog_default_table(); } | ||||
|     symbol context::default_relation() const { return m_params->datalog_default_relation(); } // external_relation_plugin::get_name()); 
 | ||||
|     symbol context::default_table_checker() const { return m_params->datalog_default_table_checker(); } | ||||
|     bool context::default_table_checked() const { return m_params->datalog_default_table_checked(); } | ||||
|     bool context::dbg_fpr_nonempty_relation_signature() const { return m_params->datalog_dbg_fpr_nonempty_relation_signature(); } | ||||
|     unsigned context::dl_profile_milliseconds_threshold() const { return m_params->datalog_profile_timeout_milliseconds(); } | ||||
|     bool context::all_or_nothing_deltas() const { return m_params->datalog_all_or_nothing_deltas(); } | ||||
|     bool context::compile_with_widening() const { return m_params->datalog_compile_with_widening(); } | ||||
|     bool context::unbound_compressor() const { return m_params->datalog_unbound_compressor(); } | ||||
|     bool context::similarity_compressor() const { return m_params->datalog_similarity_compressor(); } | ||||
|     unsigned context::similarity_compressor_threshold() const { return m_params->datalog_similarity_compressor_threshold(); } | ||||
|     unsigned context::soft_timeout() const { return m_fparams.m_soft_timeout; } | ||||
|     unsigned context::initial_restart_timeout() const { return m_params->initial_restart_timeout(); }  | ||||
|     bool context::generate_explanations() const { return m_params->generate_explanations(); } | ||||
|     bool context::explanations_on_relation_level() const { return m_params->explanations_on_relation_level(); } | ||||
|     bool context::magic_sets_for_queries() const { return m_params->magic_sets_for_queries();  } | ||||
|     bool context::eager_emptiness_checking() const { return m_params->eager_emptiness_checking(); } | ||||
|     unsigned context::initial_restart_timeout() const { return m_params->datalog_initial_restart_timeout(); }  | ||||
|     bool context::generate_explanations() const { return m_params->datalog_generate_explanations(); } | ||||
|     bool context::explanations_on_relation_level() const { return m_params->datalog_explanations_on_relation_level(); } | ||||
|     bool context::magic_sets_for_queries() const { return m_params->datalog_magic_sets_for_queries();  } | ||||
|     bool context::eager_emptiness_checking() const { return m_params->datalog_eager_emptiness_checking(); } | ||||
| 
 | ||||
|     bool context::bit_blast() const { return m_params->bit_blast(); } | ||||
|     bool context::karr() const { return m_params->karr(); } | ||||
|     bool context::scale() const { return m_params->scale(); } | ||||
|     bool context::magic() const { return m_params->magic(); } | ||||
|     bool context::quantify_arrays() const { return m_params->quantify_arrays(); } | ||||
|     bool context::instantiate_quantifiers() const { return m_params->instantiate_quantifiers(); } | ||||
|     bool context::bit_blast() const { return m_params->xform_bit_blast(); } | ||||
|     bool context::karr() const { return m_params->xform_karr(); } | ||||
|     bool context::scale() const { return m_params->xform_scale(); } | ||||
|     bool context::magic() const { return m_params->xform_magic(); } | ||||
|     bool context::quantify_arrays() const { return m_params->xform_quantify_arrays(); } | ||||
|     bool context::instantiate_quantifiers() const { return m_params->xform_instantiate_quantifiers(); } | ||||
| 
 | ||||
| 
 | ||||
|     void context::register_finite_sort(sort * s, sort_kind k) { | ||||
|  | @ -1153,7 +1153,7 @@ namespace datalog { | |||
|         expr_ref fml(m); | ||||
|         expr_ref_vector rules(m); | ||||
|         svector<symbol> names; | ||||
|         bool use_fixedpoint_extensions = m_params->print_with_fixedpoint_extensions(); | ||||
|         bool use_fixedpoint_extensions = m_params->print_fixedpoint_extensions(); | ||||
|         bool print_low_level = m_params->print_low_level_smt2(); | ||||
|         bool do_declare_vars = m_params->print_with_variable_declarations(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,82 +2,147 @@ def_module_params('fixedpoint', | |||
|                   description='fixedpoint parameters', | ||||
|                   export=True, | ||||
|                   params=(('timeout', UINT, UINT_MAX, 'set timeout'), | ||||
|                           ('engine', SYMBOL, 'auto-config', 'Select: auto-config, datalog, pdr, bmc'), | ||||
| 			  ('default_table', SYMBOL, 'sparse', 'default table implementation: sparse, hashtable, bitvector, interval'), | ||||
|                           ('default_relation', SYMBOL, 'pentagon', 'default relation implementation: external_relation, pentagon'), | ||||
|                           ('generate_explanations', BOOL, False, '(DATALOG) produce explanations for produced facts when using the datalog engine'), | ||||
|                           ('use_map_names', BOOL, True, "(DATALOG) use names from map files when displaying tuples"), | ||||
|                           ('bit_blast', BOOL, False, '(PDR) bit-blast bit-vectors'), | ||||
|                           ('explanations_on_relation_level', BOOL, False, '(DATALOG) if true, explanations are generated as history of each relation, rather than per fact (generate_explanations must be set to true for this option to have any effect)'), | ||||
|                           ('magic_sets_for_queries', BOOL, False, "(DATALOG) magic set transformation will be used for queries"), | ||||
|                           ('magic', BOOL, False, "perform symbolic magic set transformation"), | ||||
|                           ('scale', BOOL, False, "add scaling variable to linear real arithemtic clauses"), | ||||
|                           ('unbound_compressor', BOOL, True, "auxiliary relations will be introduced to avoid unbound variables in rule heads"), | ||||
|                           ('similarity_compressor', BOOL, True, "(DATALOG) rules that differ only in values of constants will be merged into a single rule"), | ||||
|                           ('similarity_compressor_threshold', UINT, 11, "(DATALOG) if similarity_compressor is on, this value determines how many similar rules there must be in order for them to be merged"), | ||||
|                           ('all_or_nothing_deltas', BOOL, False, "(DATALOG) compile rules so that it is enough for the delta relation in union and widening operations to determine only whether the updated relation was modified or not"), | ||||
|                           ('compile_with_widening', BOOL, False, "(DATALOG) widening will be used to compile recursive rules"), | ||||
|                           ('eager_emptiness_checking', BOOL, True, "(DATALOG) emptiness of affected relations will be checked after each instruction, so that we may ommit unnecessary instructions"), | ||||
|                           ('default_table_checked', BOOL, False, "if true, the detault table will be default_table inside a wrapper that checks that its results are the same as of default_table_checker table"), | ||||
|                           ('default_table_checker', SYMBOL, 'null', "see default_table_checked"), | ||||
| 
 | ||||
| 
 | ||||
|                           ('initial_restart_timeout', UINT, 0, "length of saturation run before the first restart (in ms), zero means no restarts"), | ||||
|                           ('output_profile', BOOL, False, "determines whether profile informations should be output when outputting Datalog rules or instructions"), | ||||
|                           ('inline_linear', BOOL, True, "try linear inlining method"), | ||||
|                           ('inline_eager', BOOL, True, "try eager inlining of rules"), | ||||
|                           ('inline_linear_branch', BOOL, False, "try linear inlining method with potential expansion"), | ||||
|                           ('fix_unbound_vars', BOOL, False, "fix unbound variables in tail"), | ||||
|                           ('output_tuples', BOOL, True, "determines whether tuples for output predicates should be output"), | ||||
|                           ('print_with_fixedpoint_extensions', BOOL, True, "use SMT-LIB2 fixedpoint extensions, instead of pure SMT2, when printing rules"), | ||||
|                           ('print_low_level_smt2', BOOL, False, "use (faster) low-level SMT2 printer (the printer is scalable but the result may not be as readable)"), | ||||
|                           ('print_with_variable_declarations', BOOL, True, "use variable declarations when displaying rules (instead of attempting to use original names)"), | ||||
|                           ('bfs_model_search', BOOL, True, "PDR: use BFS strategy for expanding model search"),     | ||||
|                           ('use_farkas', BOOL, True, "PDR: use lemma generator based on Farkas (for linear real arithmetic)"), | ||||
|                           ('generate_proof_trace', BOOL, False, "PDR: trace for 'sat' answer as proof object"), | ||||
|                           ('flexible_trace', BOOL, False, "PDR: allow PDR generate long counter-examples " | ||||
|                                                           "by extending candidate trace within search area"), | ||||
|                           ('unfold_rules', UINT, 0, "PDR: unfold rules statically using iterative squarring"), | ||||
|                           ('use_model_generalizer', BOOL, False, "PDR: use model for backwards propagation (instead of symbolic simulation)"), | ||||
|                           ('validate_result', BOOL, False, "PDR validate result (by proof checking or model checking)"), | ||||
|                           ('simplify_formulas_pre', BOOL, False, "PDR: simplify derived formulas before inductive propagation"), | ||||
|                           ('simplify_formulas_post', BOOL, False, "PDR: simplify derived formulas after inductive propagation"), | ||||
|                           ('slice', BOOL, True, "PDR: simplify clause set using slicing"), | ||||
| 	                  ('karr',  BOOL, False, "Add linear invariants to clauses using Karr's method"), | ||||
| 	                  ('quantify_arrays', BOOL, False, "create quantified Horn clauses from clauses with arrays"), | ||||
| 	                  ('instantiate_quantifiers', BOOL, False, "instantiate quantified Horn clauses using E-matching heuristic"), | ||||
|                           ('coalesce_rules', BOOL, False, "BMC: coalesce rules"), | ||||
|                           ('use_multicore_generalizer', BOOL, False, "PDR: extract multiple cores for blocking states"), | ||||
|                           ('use_inductive_generalizer', BOOL, True, "PDR: generalize lemmas using induction strengthening"), | ||||
|                           ('use_arith_inductive_generalizer', BOOL, False, "PDR: generalize lemmas using arithmetic heuristics for induction strengthening"), | ||||
| 	                  ('use_convex_closure_generalizer', BOOL, False, "PDR: generalize using convex closures of lemmas"), | ||||
| 	                  ('use_convex_interior_generalizer', BOOL, False, "PDR: generalize using convex interiors of lemmas"), | ||||
|                           ('cache_mode', UINT, 0, "PDR: use no (0), symbolic (1) or explicit cache (2) for model search"), | ||||
|                           ('inductive_reachability_check', BOOL, False, "PDR: assume negation of the cube on the previous level when " | ||||
|                                                                         "checking for reachability (not only during cube weakening)"), | ||||
|                           ('max_num_contexts', UINT, 500, "PDR: maximal number of contexts to create"), | ||||
|                           ('try_minimize_core', BOOL, False, "PDR: try to reduce core size (before inductive minimization)"), | ||||
|                           ('profile_timeout_milliseconds', UINT, 0, "instructions and rules that took less than the threshold will not be printed when printed the instruction/rule list"), | ||||
|                           ('dbg_fpr_nonempty_relation_signature', BOOL, False, | ||||
|                                      "if true, finite_product_relation will attempt to avoid creating inner relation with empty signature " | ||||
|                                      "by putting in half of the table columns, if it would have been empty otherwise"), | ||||
|                           ('print_answer', BOOL, False, 'print answer instance(s) to query'), | ||||
|                           ('print_certificate', BOOL, False, 'print certificate for reachability or non-reachability'), | ||||
|                           ('print_boogie_certificate', BOOL, False, 'print certificate for reachability or non-reachability using a format understood by Boogie'), | ||||
|                           ('print_statistics',  BOOL, False, 'print statistics'), | ||||
| 			  ('use_utvpi', BOOL, True, 'PDR: Enable UTVPI strategy'), | ||||
| 	                  ('tab_selection', SYMBOL, 'weight', 'selection method for tabular strategy: weight (default), first, var-use'), | ||||
| 	                  ('full_expand', BOOL, False, 'DUALITY: Fully expand derivation trees'), | ||||
| 	                  ('no_conj', BOOL, False, 'DUALITY: No forced covering (conjectures)'), | ||||
| 	                  ('feasible_edges', BOOL, True, 'DUALITY: Don\'t expand definitley infeasible edges'), | ||||
| 	                  ('use_underapprox', BOOL, False, 'DUALITY: Use underapproximations'), | ||||
| 			  ('stratified_inlining', BOOL, False, 'DUALITY: Use stratified inlining'), | ||||
| 			  ('recursion_bound', UINT, UINT_MAX, 'DUALITY: Recursion bound for stratified inlining'), | ||||
| 			  ('profile', BOOL, False, 'DUALITY: profile run time'), | ||||
| 			  ('mbqi', BOOL, True, 'DUALITY: use model-based quantifier instantion'), | ||||
| 			  ('batch_expand', BOOL, False, 'DUALITY: use batch expansion'), | ||||
|                           ('dump_aig', SYMBOL, '', 'Dump clauses in AIG text format (AAG) to the given file name'), | ||||
| 			  ('conjecture_file', STRING, '', 'DUALITY: save conjectures to file'), | ||||
|                           ('engine', SYMBOL, 'auto-config',  | ||||
|                            'Select: auto-config, datalog, duality, pdr, bmc'), | ||||
| 			  ('datalog.default_table', SYMBOL, 'sparse',  | ||||
|                            'default table implementation: sparse, hashtable, bitvector, interval'), | ||||
|                           ('datalog.default_relation', SYMBOL, 'pentagon',  | ||||
|                            'default relation implementation: external_relation, pentagon'), | ||||
|                           ('datalog.generate_explanations', BOOL, False,  | ||||
|                            'produce explanations for produced facts when using the datalog engine'), | ||||
|                           ('datalog.use_map_names', BOOL, True,  | ||||
|                             "use names from map files when displaying tuples"), | ||||
|                           ('datalog.magic_sets_for_queries', BOOL, False,  | ||||
|                            "magic set transformation will be used for queries"), | ||||
|                           ('datalog.explanations_on_relation_level', BOOL, False,  | ||||
|                            'if true, explanations are generated as history of each relation, ' +  | ||||
|                            'rather than per fact (generate_explanations must be set to true for ' +  | ||||
|                            'this option to have any effect)'), | ||||
|                           ('datalog.unbound_compressor', BOOL, True,  | ||||
|                            "auxiliary relations will be introduced to avoid unbound variables " +  | ||||
|                            "in rule heads"), | ||||
|                           ('datalog.similarity_compressor', BOOL, True,  | ||||
|                            "rules that differ only in values of constants will be merged into " +  | ||||
|                            "a single rule"), | ||||
|                           ('datalog.similarity_compressor_threshold', UINT, 11,  | ||||
|                            "if similarity_compressor is on, this value determines how many " +  | ||||
|                            "similar rules there must be in order for them to be merged"), | ||||
|                           ('datalog.all_or_nothing_deltas', BOOL, False,  | ||||
|                            "compile rules so that it is enough for the delta relation in " + | ||||
|                            "union and widening operations to determine only whether the " +  | ||||
|                            "updated relation was modified or not"), | ||||
|                           ('datalog.compile_with_widening', BOOL, False,  | ||||
|                            "widening will be used to compile recursive rules"), | ||||
|                           ('datalog.eager_emptiness_checking', BOOL, True,  | ||||
|                            "emptiness of affected relations will be checked after each instruction, " + | ||||
|                            "so that we may ommit unnecessary instructions"), | ||||
|                           ('datalog.default_table_checked', BOOL, False, "if true, the detault " + | ||||
|                            'table will be default_table inside a wrapper that checks that its results ' + | ||||
|                            'are the same as of default_table_checker table'), | ||||
|                           ('datalog.default_table_checker', SYMBOL, 'null', "see default_table_checked"), | ||||
|                           ('datalog.initial_restart_timeout', UINT, 0,  | ||||
|                            "length of saturation run before the first restart (in ms), " +  | ||||
|                            "zero means no restarts"), | ||||
|                           ('datalog.output_profile', BOOL, False,  | ||||
|                            "determines whether profile information should be " +  | ||||
|                            "output when outputting Datalog rules or instructions"), | ||||
|                           ('datalog.print.tuples', BOOL, True,  | ||||
|                            "determines whether tuples for output predicates should be output"), | ||||
|                           ('datalog.profile_timeout_milliseconds', UINT, 0,  | ||||
|                            "instructions and rules that took less than the threshold " + | ||||
|                            "will not be printed when printed the instruction/rule list"), | ||||
|                           ('datalog.dbg_fpr_nonempty_relation_signature', BOOL, False, | ||||
|                            "if true, finite_product_relation will attempt to avoid creating " + | ||||
|                            "inner relation with empty signature by putting in half of the " + | ||||
|                            "table columns, if it would have been empty otherwise"), | ||||
| 	                  ('duality.full_expand', BOOL, False, 'Fully expand derivation trees'), | ||||
| 	                  ('duality.no_conj', BOOL, False, 'No forced covering (conjectures)'), | ||||
| 	                  ('duality.feasible_edges', BOOL, True,  | ||||
|                            'Don\'t expand definitley infeasible edges'), | ||||
| 	                  ('duality.use_underapprox', BOOL, False, 'Use underapproximations'), | ||||
| 			  ('duality.stratified_inlining', BOOL, False, 'Use stratified inlining'), | ||||
| 			  ('duality.recursion_bound', UINT, UINT_MAX,  | ||||
|                            'Recursion bound for stratified inlining'), | ||||
| 			  ('duality.profile', BOOL, False, 'profile run time'), | ||||
| 			  ('duality.mbqi', BOOL, True, 'use model-based quantifier instantion'), | ||||
| 			  ('duality.batch_expand', BOOL, False, 'use batch expansion'), | ||||
| 			  ('duality.conjecture_file', STRING, '', 'save conjectures to file'), | ||||
|                           ('pdr.bfs_model_search', BOOL, True,  | ||||
|                            "use BFS strategy for expanding model search"),     | ||||
|                           ('pdr.farkas', BOOL, True,  | ||||
|                            "use lemma generator based on Farkas (for linear real arithmetic)"), | ||||
|                           ('generate_proof_trace', BOOL, False, "trace for 'sat' answer as proof object"), | ||||
|                           ('pdr.flexible_trace', BOOL, False,  | ||||
|                            "allow PDR generate long counter-examples " + | ||||
|                            "by extending candidate trace within search area"), | ||||
|                           ('pdr.use_model_generalizer', BOOL, False,  | ||||
|                            "use model for backwards propagation (instead of symbolic simulation)"), | ||||
|                           ('pdr.validate_result', BOOL, False,  | ||||
|                            "validate result (by proof checking or model checking)"), | ||||
|                           ('pdr.simplify_formulas_pre', BOOL, False,  | ||||
|                            "simplify derived formulas before inductive propagation"), | ||||
|                           ('pdr.simplify_formulas_post', BOOL, False,  | ||||
|                            "simplify derived formulas after inductive propagation"), | ||||
|                           ('pdr.use_multicore_generalizer', BOOL, False,  | ||||
|                            "extract multiple cores for blocking states"), | ||||
|                           ('pdr.use_inductive_generalizer', BOOL, True,  | ||||
|                            "generalize lemmas using induction strengthening"), | ||||
|                           ('pdr.use_arith_inductive_generalizer', BOOL, False,  | ||||
|                            "generalize lemmas using arithmetic heuristics for induction strengthening"), | ||||
| 	                  ('pdr.use_convex_closure_generalizer', BOOL, False,  | ||||
|                            "generalize using convex closures of lemmas"), | ||||
| 	                  ('pdr.use_convex_interior_generalizer', BOOL, False,  | ||||
|                            "generalize using convex interiors of lemmas"), | ||||
|                           ('pdr.cache_mode', UINT, 0, "use no (0), symbolic (1) or explicit " +  | ||||
|                            "cache (2) for model search"), | ||||
|                           ('pdr.inductive_reachability_check', BOOL, False,  | ||||
|                            "assume negation of the cube on the previous level when " + | ||||
|                            "checking for reachability (not only during cube weakening)"), | ||||
|                           ('pdr.max_num_contexts', UINT, 500, "maximal number of contexts to create"), | ||||
|                           ('pdr.try_minimize_core', BOOL, False,  | ||||
|                            "try to reduce core size (before inductive minimization)"), | ||||
| 			  ('pdr.utvpi', BOOL, True, 'Enable UTVPI strategy'), | ||||
|                           ('print.fixedpoint_extensions', BOOL, True,  | ||||
|                            "use SMT-LIB2 fixedpoint extensions, instead of pure SMT2, " +  | ||||
|                            "when printing rules"), | ||||
|                           ('print.low_level_smt2', BOOL, False,  | ||||
|                            "use (faster) low-level SMT2 printer (the printer is scalable " +  | ||||
|                            "but the result may not be as readable)"), | ||||
|                           ('print.with_variable_declarations', BOOL, True,  | ||||
|                            "use variable declarations when displaying rules " + | ||||
|                            "(instead of attempting to use original names)"), | ||||
|                           ('print.answer', BOOL, False, 'print answer instance(s) to query'), | ||||
|                           ('print.certificate', BOOL, False,  | ||||
|                            'print certificate for reachability or non-reachability'), | ||||
|                           ('print.boogie_certificate', BOOL, False,  | ||||
|                            'print certificate for reachability or non-reachability using a ' + | ||||
|                            'format understood by Boogie'), | ||||
|                           ('print.statistics',  BOOL, False, 'print statistics'), | ||||
|                           ('print.aig', SYMBOL, '',  | ||||
|                            'Dump clauses in AIG text format (AAG) to the given file name'), | ||||
| 	                  ('tab.selection', SYMBOL, 'weight', | ||||
|                            'selection method for tabular strategy: weight (default), first, var-use'), | ||||
|                           ('xform.bit_blast', BOOL, False,  | ||||
|                            'bit-blast bit-vectors'), | ||||
|                           ('xform.magic', BOOL, False,  | ||||
|                            "perform symbolic magic set transformation"), | ||||
|                           ('xform.scale', BOOL, False,  | ||||
|                            "add scaling variable to linear real arithemtic clauses"), | ||||
|                           ('xform.inline_linear', BOOL, True, "try linear inlining method"), | ||||
|                           ('xform.inline_eager', BOOL, True, "try eager inlining of rules"), | ||||
|                           ('xform.inline_linear_branch', BOOL, False,  | ||||
|                            "try linear inlining method with potential expansion"), | ||||
|                           ('xform.fix_unbound_vars', BOOL, False, "fix unbound variables in tail"), | ||||
|                           ('xform.unfold_rules', UINT, 0,  | ||||
|                            "unfold rules statically using iterative squarring"), | ||||
|                           ('xform.slice', BOOL, True, "simplify clause set using slicing"), | ||||
| 	                  ('xform.karr',  BOOL, False,  | ||||
|                            "Add linear invariants to clauses using Karr's method"), | ||||
| 	                  ('xform.quantify_arrays', BOOL, False,  | ||||
|                            "create quantified Horn clauses from clauses with arrays"), | ||||
| 	                  ('xform.instantiate_quantifiers', BOOL, False,  | ||||
|                            "instantiate quantified Horn clauses using E-matching heuristic"), | ||||
|                           ('xform.coalesce_rules', BOOL, False, "coalesce rules"), | ||||
|                           )) | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue