summaryrefslogtreecommitdiff
path: root/test/regress/regress1/rewriterules/length_trick3_int.smt2
diff options
context:
space:
mode:
Diffstat (limited to 'test/regress/regress1/rewriterules/length_trick3_int.smt2')
-rw-r--r--test/regress/regress1/rewriterules/length_trick3_int.smt244
1 files changed, 44 insertions, 0 deletions
diff --git a/test/regress/regress1/rewriterules/length_trick3_int.smt2 b/test/regress/regress1/rewriterules/length_trick3_int.smt2
new file mode 100644
index 000000000..d58bf55fe
--- /dev/null
+++ b/test/regress/regress1/rewriterules/length_trick3_int.smt2
@@ -0,0 +1,44 @@
+;; Same than length.smt2 but the nil case is not a rewrite rule
+;; So here the rewrite rules have no guards length
+
+(set-logic AUFLIA)
+(set-info :status unsat)
+
+;; don't use a datatypes for currently focusing in uf
+(declare-sort list 0)
+
+(declare-fun cons (Int list) list)
+(declare-fun nil () list)
+
+
+;;define length
+(declare-fun length (list) Int)
+
+(assert (= (length nil) 0))
+
+(assert (forall ((?e Int) (?l list)) (! (= (length (cons ?e ?l)) (+ 1 (length ?l))) :rewrite-rule)))
+
+(declare-fun ten_one_cons (list) list)
+
+(assert (forall ((?l list)) (! (= (ten_one_cons ?l)
+ (cons 1 (cons 1 (cons 1 (cons 1 (cons 1 (cons 1 (cons 1 (cons 1 (cons 1 (cons 1 ?l) )))))))))
+ ) :rewrite-rule)))
+
+(assert (not (= (length (ten_one_cons nil))
+ 10)))
+
+(check-sat)
+
+(declare-fun ten_one_ten (list) list)
+
+(assert (forall ((?l list)) (! (= (ten_one_ten ?l)
+ (ten_one_cons (ten_one_cons (ten_one_cons (ten_one_cons (ten_one_cons (ten_one_cons (ten_one_cons (ten_one_cons (ten_one_cons (ten_one_cons ?l) )))))))))
+ ) :rewrite-rule)))
+
+(declare-fun two_one_ten (list) list)
+
+(assert (forall ((?l list)) (! (= (two_one_ten ?l)
+ (ten_one_cons (ten_one_cons ?l))
+ ) :rewrite-rule)))
+
+(exit)
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback