; Automatically generated by map2smt (set-logic HORN) (declare-fun new2 (Int) Bool) (declare-fun new1 (Int Int Int) Bool) (declare-fun diff_new4 (Int Int Int) Bool) (declare-fun not_fun_diff_new4 () Bool) (declare-fun constr (Bool) Bool) (declare-fun weak_diff () Bool) (declare-fun ff () Bool) (assert (forall ( (A Int) (B Int) (C Int) (D Int) (E Int) (F Int) ) (=> (and (diff_new4 A B C) (diff_new4 D E F) (and (and (= A D) (= C F)) (not (= B E))) ) not_fun_diff_new4 ) ) ) (assert (forall ( (A Int) (B Int) (C Int) (D Int) ) (=> (and (= D 0) (= B 0) (= A (+ 1 D)) ) (diff_new4 A B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Int) (D Int) (E Int) ) (=> (and (= B (+ 1 D)) (= A (+ 1 E)) (diff_new4 E D C) ) (diff_new4 A B C) ) ) ) (assert (forall ( (A Int) ) (=> (= A 0) (new2 A) ) ) ) (assert (forall ( (A Int) (B Int) ) (=> (and (= A (+ 1 B)) (new2 B) ) (new2 A) ) ) ) (assert (forall ( (A Int) (B Int) ) (=> (and (>= A 0) (= A 0) (new2 B) ) (new1 A B B) ) ) ) (assert (forall ( (A Int) (B Int) (C Int) (D Int) ) (=> (and (>= D 0) (>= A 0) (= C 0) (= B 0) (= A (+ 1 D)) ) (new1 A B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Int) (D Int) (E Int) (F Int) (G Int) ) (=> (and (>= D 0) (>= A 0) (= C (+ 1 E)) (= A (+ 1 D)) (diff_new4 F E G) weak_diff (new1 D B F) ) (new1 A B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Int) ) (=> (and (>= A 0) (= (- B C) 0) (new1 A C B) ) ff ) ) ) (assert weak_diff ) (assert (not ff)) (check-sat)