3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2026-07-04 14:26:10 +00:00

conservative expansions

This commit is contained in:
Nikolaj Bjorner 2026-06-06 11:34:26 -07:00
parent 98a7992a65
commit f42172e65a
21 changed files with 564 additions and 35 deletions

View file

@ -0,0 +1,22 @@
(set-info :smt-lib-version 2.6)
(set-logic QF_S)
(set-info :source |
Generated by: Murphy Berzish, Mitja Kulczynski, Federico Mora, Florin Manea, Joel Day, Dirk Nowotka, Vijay Ganesh, Zhengyang Lu
Generated on: 2020-10-01
Description: Translated from a collection of real-world regex queries, AutomataArk, collected by Loris DAntoni and Fang Wang: https://github.com/lorisdanto/automatark
Application: Evaluate solvers on real-world regex queries
Target solver: Z3str3RE, CVC4, OSTRICH, Z3seq, Z3str3, Z3-Trau
Publications: Berzish, M., Kulczynski, M., Mora, F., Manea, F., Day, J. D., Nowotka, D., & Ganesh, V. (2021, July). An SMT solver for regular expressions and linear arithmetic over string length. In CAV 2021.
|)
(set-info :license "https://creativecommons.org/licenses/by/4.0/")
(set-info :category "industrial")
(set-info :status unsat)
(declare-const X String)
(assert (str.in_re X (re.++ (str.to_re "|Connected") (re.+ (re.union (str.to_re " ") (str.to_re "\u{9}") (str.to_re "\u{a}") (str.to_re "\u{c}") (str.to_re "\u{d}"))) (str.to_re "adblock.linkz.com\u{a}"))))
(assert (str.in_re X (re.++ (str.to_re "//u\u{a}") (re.range "\u{0}" "\u{ff}") (re.* (re.union (str.to_re " ") (str.to_re "\u{9}") (str.to_re "\u{a}") (str.to_re "\u{c}") (str.to_re "\u{d}"))))))
(assert (str.in_re X (re.++ (re.* (re.++ (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.union (re.++ (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7"))) (re.++ (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8"))) (re.++ (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8"))) (re.++ (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.* (re.++ (re.union (str.to_re "2") (str.to_re "5") (str.to_re "8")) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7")))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))) (re.union (str.to_re "1") (str.to_re "4") (str.to_re "7"))))) (re.* (re.union (str.to_re "0") (str.to_re "3") (str.to_re "6") (str.to_re "9"))))) (str.to_re "\u{a}"))))
(assert (str.in_re X (re.++ (str.to_re "/.pui") (re.union (str.to_re "?") (str.to_re "\u{5c}") (str.to_re "/")) (str.to_re "/smiU\u{a}"))))
(check-sat)
(exit)