3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-06 17:44:08 +00:00

more tactic descriptions

This commit is contained in:
Nikolaj Bjorner 2023-01-05 20:23:01 -08:00
parent 0d8a472aac
commit c07b6ab38f
10 changed files with 233 additions and 46 deletions

View file

@ -59,6 +59,7 @@ def find_tactic_name(path):
m = is_tac_name.search(line)
if m:
return m.group(1)
print(f"no tactic in {path}")
return ""
def presort_files():

View file

@ -9,6 +9,14 @@ Author:
Mikolas Janota
Tactic Documentation
## Tactic bv_bound_chk
### Short Description
Attempts to detect inconsistencies of bounds on bv expressions.
### Notes
* does not support proofs, does not support cores

View file

@ -13,6 +13,34 @@ Author:
Nikolaj Bjorner (nbjorner) 2022-10-30
Tactic Documentation
## Tactic bv-slice
### Short Description
Slices bit-vectors into sub-ranges to allow simplifying sub-ranges.
### Long Description
It rewrites a state using bit-vector slices.
Slices are extracted from bit-vector equality assertions.
An equality assertion may equate a sub-range of a bit-vector
with a constant. The tactic ensures that all occurrences of the
subrange are replaced by the constants to allow additional
simplification
### Example
```z3 ignore-errors
(declare-const x (_ BitVec 32))
(declare-const y (_ BitVec 32))
(assert (= ((_ extract 31 16) x) (_ bv123 16)))
(assert (= ((_ extract 15 0) x) ((_ extract 16 1) y)))
(assert (= (bvadd x x) y))
(apply bv-slice)
```
--*/
#pragma once

View file

@ -14,7 +14,29 @@ Author:
Nikolaj and Nuno
Notes:
Tactic Documentation:
## Tactic dom-simplify
### Short Description
Apply dominator simplification rules
### Long Description
Dominator-based simplification is a context dependent simplification function that uses a dominator tree to control the number of paths it
visits during simplification. The expression DAG may have an exponential number of paths, but only paths corresponding to a dominator
tree are visited. Since the paths selected by the dominator trees are limited, the simplifier may easily fail to simplify within a context.
### Example
```z3
(declare-const a Bool)
(declare-const b Bool)
(assert (and a (or a b)))
(apply dom-simplify)
```
--*/

View file

@ -5,20 +5,42 @@ Module Name:
occf_tactic.h
Abstract:
Put clauses in the assertion set in
OOC (one constraint per clause) form.
Constraints occurring in formulas that
are not clauses are ignored.
The formula can be put into CNF by
using mk_sat_preprocessor strategy.
Author:
Leonardo de Moura (leonardo) 2011-12-28.
Revision History:
Tactic Documentation:
## Tactic occf
### Short Description
Put goal in one constraint per clause normal form
### Long Description
Put clauses in the assertion set in
OOC (one constraint per clause) form.
Constraints occurring in formulas that
are not clauses are ignored.
The formula can be put into CNF by
using `mk_sat_preprocessor` strategy.
### Example
```z3
(declare-const x Int)
(declare-const y Int)
(assert (or (= x y) (> x (- y))))
(assert (or (= x y) (< x (- y))))
(apply occf)
```
### Notes
* Does not support proofs
* only clauses are considered
--*/
#pragma once

View file

@ -13,7 +13,20 @@ Author:
Nikolaj (nbjorner) 2011-05-31
Notes:
Tactic Documentation:
## Tactic symmetry-reduce
### Short Description
Apply symmetry reduction
### Long Description
The tactic applies symmetry reduction for uninterpreted functions and equalities.
It applies a straight-forward adaption of an algorithm proposed for veriT.
--*/
#pragma once

View file

@ -7,43 +7,63 @@ Module Name:
Abstract:
Puts an assertion set in CNF.
Auxiliary variables are used to avoid blowup.
Features:
- Efficient encoding is used for commonly used patterns such as:
(iff a (iff b c))
(or (not (or a b)) (not (or a c)) (not (or b c)))
- Efficient encoding is used for chains of if-then-elses
- Distributivity is applied to non-shared nodes if the blowup is acceptable.
- The features above can be disabled/enabled using parameters.
- The assertion-set is only modified if the resultant set of clauses
is "acceptable".
Notes:
- Term-if-then-else expressions are not handled by this strategy.
This kind of expression should be processed by other strategies.
- Quantifiers are treated as "theory" atoms. They are viewed
as propositional variables by this strategy.
- The assertion set may contain free variables.
- This strategy assumes the assertion_set_rewriter was
used before invoking it.
In particular, it is more effective when "and" operators
were eliminated.
Author:
Leonardo (leonardo) 2011-12-29
Tactic Documentation:
## Tactic tseitin-cnf
### Short Description
Convert goal into CNF using tseitin-like encoding (note: quantifiers are ignored).
### Long Description
Puts an assertion set in CNF.
Auxiliary variables are used to avoid blowup.
Features:
- Efficient encoding is used for commonly used patterns such as:
`(iff a (iff b c))`
`(or (not (or a b)) (not (or a c)) (not (or b c)))`
- Efficient encoding is used for chains of if-then-elses
- Distributivity is applied to non-shared nodes if the blowup is acceptable.
- The features above can be disabled/enabled using parameters.
- The assertion-set is only modified if the resultant set of clauses is "acceptable".
Notes:
- Term-if-then-else expressions are not handled by this strategy.
This kind of expression should be processed by other strategies.
- Quantifiers are treated as "theory" atoms. They are viewed
as propositional variables by this strategy.
- The assertion set may contain free variables.
- This strategy assumes the assertion_set_rewriter was used before invoking it.
In particular, it is more effective when "and" operators
were eliminated.
### Example
```z3
(declare-const a Bool)
(declare-const b Bool)
(declare-const c Bool)
(assert (= a (= b c)))
(apply tseitin-cnf)
```
--*/
#pragma once

View file

@ -13,7 +13,45 @@ Author:
Christoph (cwinter) 2012-10-26
Notes:
Tactic Description
## Tactic macro-finder
### Short Description
Identifies and applies macros.
### Long Description
It finds implicit macro definitions in quantifiers.
A main instance of a macro an equality that defines a function `f` using some term `t` that does not contain `f`.
Other instances of macros are also recognized by the macro finder.
* `(forall (x) (= (f x) t))`
* `not (= (p x) t)` is recognized as `(p x) = (not t)`
* `(iff (= (f x) t) cond)` rewrites to `(f x) = (if cond t else (k x))`
* add clause `(not (= (k x) t))`
* `(= (+ (f x) s) t)` becomes `(= (f x) (- t s))`
* `(= (+ (* -1 (f x)) x) t)` becomes `(= (f x) (- (- t s)))`
### Example
```z3
(declare-fun f (Int) Int)
(declare-fun p (Int) Bool)
(assert (forall ((x Int)) (= (+ (f x) x) 3)))
(assert (p (f 8)))
(apply macro-finder)
```
### Notes
* Supports proofs, unsat cores, but not goals with recursive function definitions.
--*/
#pragma once

View file

@ -21,8 +21,10 @@ Notes:
#include "ast/macros/macro_manager.h"
#include "ast/macros/macro_finder.h"
#include "ast/macros/quasi_macros.h"
#include "ast/recfun_decl_plugin.h"
#include "tactic/ufbv/quasi_macros_tactic.h"
class quasi_macros_tactic : public tactic {
struct imp {
@ -41,6 +43,12 @@ class quasi_macros_tactic : public tactic {
bool produce_proofs = g->proofs_enabled();
bool produce_unsat_cores = g->unsat_core_enabled();
recfun::util rec(m());
if (!rec.get_rec_funs().empty()) {
result.push_back(g.get());
return;
}
macro_manager mm(m_manager);
quasi_macros qm(m_manager, mm);

View file

@ -13,7 +13,34 @@ Author:
Christoph (cwinter) 2012-10-26
Notes:
Tactic Description
## Tactic quasi-macro-finder
### Short Description
dentifies and applies quasi-macros.
### Long Description
A quasi macro defines a function symbol that contains more arguments than the number of bound variables it defines.
The additional arguments are functions of the bound variables.
### Example
```z3
(declare-fun f (Int Int Int) Int)
(declare-fun p (Int) Bool)
(declare-const a Int)
(assert (forall ((x Int) (y Int)) (= (f x y 1) (* 2 x y))))
(assert (p (f 8 a (+ a 8))))
(apply quasi-macros)
```
### Notes
* Supports proofs and cores
--*/
#pragma once