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

replace_re axiom placeholder

@ahelwer - illustrates placeholder for one approach for axiomatizing replace_re
This commit is contained in:
Nikolaj Bjorner 2021-12-08 03:40:24 -08:00
parent 773a2ae7bc
commit a5bd115235
2 changed files with 25 additions and 0 deletions

View file

@ -1030,6 +1030,29 @@ namespace seq {
add_clause(le, emp);
}
/**
* Assume that r has the property that if r accepts string p
* then r does *not* accept any suffix of p. It is conceptually easy to
* convert a deterministic automaton for a regex to a suffix blocking acceptor
* by redirecting removing outgoing edges from accepting states and redirecting them
* to a sink. Alternative, introduce a different string membership predicate that is
* prefix sensitive.
*
* Let e = replace_re(s, r, t)
* Then a claim is that the following axioms suffice to encode str.replace_re
*
* s = "" => e = t
* r = "" => e = s + t
* s not in .*r.* => e = t
* s = x + y + [z] + u & y + [z] in r & x + y not in .*r.* => e = x + t + u
*/
void axioms::replace_re_axiom(expr* e) {
expr* s = nullptr, *r = nullptr, *t = nullptr;
VERIFY(seq.str.is_replace_re(e, s, r, t));
NOT_IMPLEMENTED_YET();
}
/**
Unit is injective:
@ -1171,4 +1194,5 @@ namespace seq {
return bound_tracker;
}
}

View file

@ -106,6 +106,7 @@ namespace seq {
void unit_axiom(expr* n);
void length_axiom(expr* n);
void unroll_not_contains(expr* e);
void replace_re_axiom(expr* e);
expr_ref length_limit(expr* s, unsigned k);
expr_ref is_digit(expr* ch);