** Calling: z3 -nw -in -smt2 [GOOD] ; Automatically generated by SBV. Do not edit. [GOOD] (set-option :print-success true) [GOOD] (set-option :global-declarations true) [GOOD] (set-option :smtlib2_compliant true) [GOOD] (set-option :diagnostic-output-channel "stdout") [GOOD] (set-option :produce-models true) [GOOD] (set-option :pp.max_depth 4294967295) [GOOD] (set-option :pp.min_alias_size 4294967295) [GOOD] (set-option :model.inline_def true ) [GOOD] (set-logic ALL) ; has unbounded values, using catch-all. [GOOD] ; --- tuples --- [GOOD] (declare-datatypes ((SBVTuple2 2)) ((par (T1 T2) ((mkSBVTuple2 (proj_1_SBVTuple2 T1) (proj_2_SBVTuple2 T2)))))) [GOOD] ; --- sums --- [GOOD] ; --- ADTs --- [GOOD] ; User defined ADT: Expr [GOOD] (declare-datatype Expr (par (nm val) ( (Val (getVal_1 val)) (Var (getVar_1 nm)) (Add (getAdd_1 (Expr nm val)) (getAdd_2 (Expr nm val))) (Mul (getMul_1 (Expr nm val)) (getMul_2 (Expr nm val))) (Let (getLet_1 nm) (getLet_2 (Expr nm val)) (getLet_3 (Expr nm val))) ))) [GOOD] ; --- literal constants --- [GOOD] (define-fun s1 () (Expr String Int) ((as Let (Expr String Int)) "a" ((as Mul (Expr String Int)) ((as Val (Expr String Int)) 3) ((as Add (Expr String Int)) ((as Val (Expr String Int)) 3) ((as Val (Expr String Int)) 4))) ((as Add (Expr String Int)) ((as Var (Expr String Int)) "a") ((as Add (Expr String Int)) ((as Val (Expr String Int)) 3) ((as Val (Expr String Int)) 4))))) [GOOD] (define-fun s3 () (Seq (SBVTuple2 String Int)) (as seq.empty (Seq (SBVTuple2 String Int)))) [GOOD] (define-fun s5 () Int 28) [GOOD] ; --- top level inputs --- [GOOD] (declare-fun s0 () (Expr String Int)) [GOOD] ; --- constant tables --- [GOOD] ; --- non-constant tables --- [GOOD] ; --- uninterpreted constants --- [GOOD] ; --- user defined functions --- [GOOD] ; |get @(SBV [([Char],Integer)] -> SBV [Char] -> SBV Integer)| :: [(SString, SInteger)] -> SString -> SInteger [Recursive] [GOOD] (define-fun-rec |get @(SBV [([Char],Integer)] -> SBV [Char] -> SBV Integer)| ((l2_s0 (Seq (SBVTuple2 String Int))) (l2_s1 String)) Int (let ((l2_s3 0)) (let ((l2_s9 1)) (let ((l2_s2 (seq.len l2_s0))) (let ((l2_s4 (= l2_s2 l2_s3))) (let ((l2_s5 (seq.nth l2_s0 l2_s3))) (let ((l2_s6 (proj_1_SBVTuple2 l2_s5))) (let ((l2_s7 (= l2_s1 l2_s6))) (let ((l2_s8 (proj_2_SBVTuple2 l2_s5))) (let ((l2_s10 (- l2_s2 l2_s9))) (let ((l2_s11 (seq.extract l2_s0 l2_s9 l2_s10))) (let ((l2_s12 (|get @(SBV [([Char],Integer)] -> SBV [Char] -> SBV Integer)| l2_s11 l2_s1))) (let ((l2_s13 (ite l2_s7 l2_s8 l2_s12))) (let ((l2_s14 (ite l2_s4 l2_s3 l2_s13))) l2_s14)))))))))))))) [GOOD] ; |eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| :: [(SString, SInteger)] -> Expr String Integer -> SInteger [Recursive] [Refers to: |get @(SBV [([Char],Integer)] -> SBV [Char] -> SBV Integer)|] [GOOD] (define-fun-rec |eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| ((l1_s0 (Seq (SBVTuple2 String Int))) (l1_s1 (Expr String Int))) Int (let ((l1_s2 ((as is-Val Bool) l1_s1))) (let ((l1_s3 (getVal_1 l1_s1))) (let ((l1_s4 ((as is-Var Bool) l1_s1))) (let ((l1_s5 (getVar_1 l1_s1))) (let ((l1_s6 (|get @(SBV [([Char],Integer)] -> SBV [Char] -> SBV Integer)| l1_s0 l1_s5))) (let ((l1_s7 ((as is-Add Bool) l1_s1))) (let ((l1_s8 (getAdd_1 l1_s1))) (let ((l1_s9 (|eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| l1_s0 l1_s8))) (let ((l1_s10 (getAdd_2 l1_s1))) (let ((l1_s11 (|eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| l1_s0 l1_s10))) (let ((l1_s12 (+ l1_s9 l1_s11))) (let ((l1_s13 ((as is-Mul Bool) l1_s1))) (let ((l1_s14 (getMul_1 l1_s1))) (let ((l1_s15 (|eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| l1_s0 l1_s14))) (let ((l1_s16 (getMul_2 l1_s1))) (let ((l1_s17 (|eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| l1_s0 l1_s16))) (let ((l1_s18 (* l1_s15 l1_s17))) (let ((l1_s19 (getLet_1 l1_s1))) (let ((l1_s20 (getLet_2 l1_s1))) (let ((l1_s21 (|eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| l1_s0 l1_s20))) (let ((l1_s22 ((as mkSBVTuple2 (SBVTuple2 String Int)) l1_s19 l1_s21))) (let ((l1_s23 (seq.unit l1_s22))) (let ((l1_s24 (seq.++ l1_s23 l1_s0))) (let ((l1_s25 (getLet_3 l1_s1))) (let ((l1_s26 (|eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| l1_s24 l1_s25))) (let ((l1_s27 (ite l1_s13 l1_s18 l1_s26))) (let ((l1_s28 (ite l1_s7 l1_s12 l1_s27))) (let ((l1_s29 (ite l1_s4 l1_s6 l1_s28))) (let ((l1_s30 (ite l1_s2 l1_s3 l1_s29))) l1_s30)))))))))))))))))))))))))))))) [GOOD] ; --- assignments --- [GOOD] (define-fun s2 () Bool (= s0 s1)) [GOOD] (define-fun s4 () Int (|eval @(SBV [([Char],Integer)] -> SBV (Expr [Char] Integer) -> SBV Integer)| s3 s0)) [GOOD] (define-fun s6 () Bool (distinct s4 s5)) [GOOD] ; --- delayedEqualities --- [GOOD] ; --- formula --- [GOOD] (assert s2) [GOOD] (assert s6) [SEND] (check-sat) [RECV] unsat All good. *** Solver : Z3 *** Exit code: ExitSuccess