(declare-sort Loc 0) (declare-const l0 Loc) (declare-const l1 Loc) (declare-const l2 Loc) (declare-const l3 Loc) (declare-const l4 Loc) (declare-const l5 Loc) (declare-const l6 Loc) (declare-const l7 Loc) (declare-const l8 Loc) (declare-const l9 Loc) (declare-const l10 Loc) (declare-const l11 Loc) (assert (distinct l0 l1 l2 l3 l4 l5 l6 l7 l8 l9 l10 l11)) (define-fun cfg_init ( (pc Loc) (src Loc) (rel Bool) ) Bool (and (= pc src) rel)) (define-fun cfg_trans2 ( (pc Loc) (src Loc) (pc1 Loc) (dst Loc) (rel Bool) ) Bool (and (= pc src) (= pc1 dst) rel)) (define-fun cfg_trans3 ( (pc Loc) (exit Loc) (pc1 Loc) (call Loc) (pc2 Loc) (return Loc) (rel Bool) ) Bool (and (= pc exit) (= pc1 call) (= pc2 return) rel)) (define-fun init_main ( (pc^0 Loc) (a^0 Int) (b^0 Int) (i^0 Int) (n^0 Int) (tmp^0 Int) ) Bool (cfg_init pc^0 l11 true)) (define-fun next_main ( (pc^0 Loc) (a^0 Int) (b^0 Int) (i^0 Int) (n^0 Int) (tmp^0 Int) (pc^post Loc) (a^post Int) (b^post Int) (i^post Int) (n^post Int) (tmp^post Int) ) Bool (or (cfg_trans2 pc^0 l0 pc^post l1 (and (and (and (and (and (<= (+ 0 a^0) 0) (= a^0 a^post)) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l0 pc^post l2 (and (and (and (and (and (<= 1 (+ 0 a^0)) (= a^post (+ -1 a^0))) (= b^post (+ 1 b^0))) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l3 pc^post l0 (and (and (and (and (= a^0 a^post) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l2 pc^post l4 (and (and (and (and (= a^0 a^post) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l5 pc^post l6 (and (and (and (and (= i^post (+ -1 i^0)) (= a^0 a^post)) (= b^0 b^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l6 pc^post l7 (and (and (and (and (= a^0 a^post) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l8 pc^post l5 (and (and (and (and (= a^post (+ -1 a^0)) (= b^post (+ 1 b^0))) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l9 pc^post l5 (and (and (and (and (and (and (<= (+ 0 tmp^0) 0) (<= 0 (+ 0 tmp^0))) (= a^0 a^post)) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l9 pc^post l8 (and (and (and (and (and (<= 1 (+ 0 tmp^0)) (= a^0 a^post)) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l9 pc^post l8 (and (and (and (and (and (<= (+ 1 tmp^0) 0) (= a^0 a^post)) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l7 pc^post l2 (and (and (and (and (and (<= (+ 0 i^0) 0) (= a^0 a^post)) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l7 pc^post l9 (and (and (and (and (and (<= 1 (+ 0 i^0)) (= tmp^post tmp^post)) (= a^0 a^post)) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post))) (cfg_trans2 pc^0 l4 pc^post l3 (and (and (and (and (and (<= (+ 0 b^0) 0) (= a^0 a^post)) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l4 pc^post l6 (and (and (and (and (and (<= 1 (+ 0 b^0)) (= b^post (+ -1 b^0))) (= i^post (+ -1 a^0))) (= a^0 a^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l10 pc^post l3 (and (and (and (and (= a^post (+ 0 n^0)) (= b^post 0)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) (cfg_trans2 pc^0 l11 pc^post l10 (and (and (and (and (= a^0 a^post) (= b^0 b^post)) (= i^0 i^post)) (= n^0 n^post)) (= tmp^0 tmp^post))) ) )