** 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-logic QF_UFBV) [GOOD] ; --- tuples --- [GOOD] ; --- sums --- [GOOD] ; --- literal constants --- [GOOD] ; --- top level inputs --- [GOOD] (declare-fun s0 () (_ BitVec 8)) [GOOD] (declare-fun s1 () (_ BitVec 16)) [GOOD] (declare-fun s2 () (_ BitVec 16)) [GOOD] ; --- constant tables --- [GOOD] ; --- non-constant tables --- [GOOD] ; --- uninterpreted constants --- [GOOD] (declare-fun g ((_ BitVec 8) (_ BitVec 16)) (_ BitVec 32)) [GOOD] ; --- user defined functions --- [GOOD] ; --- assignments --- [GOOD] (define-fun s3 () Bool (= s1 s2)) [GOOD] (define-fun s4 () (_ BitVec 32) (g s0 s1)) [GOOD] (define-fun s5 () (_ BitVec 32) (g s0 s2)) [GOOD] (define-fun s6 () Bool (= s4 s5)) [GOOD] (define-fun s7 () Bool (=> s3 s6)) [GOOD] ; --- delayedEqualities --- [GOOD] ; --- formula --- [GOOD] (assert s7) [SEND] (check-sat) [RECV] sat [SEND] (get-value (s0)) [RECV] ((s0 #x00)) [SEND] (get-value (s1)) [RECV] ((s1 #x0000)) [SEND] (get-value (s2)) [RECV] ((s2 #x0000)) [GOOD] (set-option :pp.max_depth 4294967295) [GOOD] (set-option :pp.min_alias_size 4294967295) [GOOD] (set-option :model.inline_def true ) [SEND] (get-value (g)) [RECV] ((g ((as const (Array (_ BitVec 8) (_ BitVec 16) (_ BitVec 32))) #x00000000))) *** Solver : Z3 *** Exit code: ExitSuccess FINAL:Satisfiable. Model: s0 = 0 :: Int8 s1 = 0 :: Word16 s2 = 0 :: Word16 g :: (Int8, Word16) -> Word32 g (_, _) = 0 DONE!