; Automatically generated by map2smt (set-logic HORN) (declare-fun new6 (Int Bool) Bool) (declare-fun new5 (Int Bool) Bool) (declare-fun new4 (Int Int Bool Int Bool) Bool) (declare-fun new37 (Int Bool) Bool) (declare-fun new36 (Int Bool Int) Bool) (declare-fun new34 (Int Bool) Bool) (declare-fun new3 (Int Int Bool Int Bool) Bool) (declare-fun new26 (Int Bool) Bool) (declare-fun new25 (Int Bool Int) Bool) (declare-fun new23 (Int Bool) Bool) (declare-fun new2 (Int Int Bool Int Bool) Bool) (declare-fun new15 (Int Bool) Bool) (declare-fun new14 (Int Bool) Bool) (declare-fun new1 (Int Int Bool Int Bool) Bool) (declare-fun ff () Bool) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new37 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new37 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new37 A B) ) (new37 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new37 A B) ) (new37 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new37 A B) ) (new37 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (= B false) (>= (- C A) 1) (<= (- A C) (- 1)) ) (new36 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B true) (= B true) (<= (- A C) (- 1)) (<= C (- D 1)) (new34 A B) ) (new36 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B false) (= B false) (>= (- D A) 1) (>= (- C A) 1) (<= (- A C) (- 1)) (<= C (- D 1)) (new34 A B) ) (new36 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B true) (>= C A) (<= (- A C) (- 1)) ) (new36 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B true) (>= C D) (<= (- A C) (- 1)) (new36 A B C) ) (new36 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B false) (>= (- D A) 1) (>= C D) (<= (- A C) (- 1)) (new36 A B C) ) (new36 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B false) (>= C D) (<= (- D A) (- 1)) (<= (- A C) (- 1)) (new36 A B C) ) (new36 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new34 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new34 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new34 A B) ) (new34 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new34 A B) ) (new34 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new34 A B) ) (new34 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new26 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new26 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new26 A B) ) (new26 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new26 A B) ) (new26 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new26 A B) ) (new26 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (= B false) (>= (- C A) 1) (<= (- A C) (- 1)) ) (new25 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B true) (= B true) (<= (- A C) (- 1)) (<= C (- D 1)) (new23 A B) ) (new25 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B false) (= B false) (>= (- D A) 1) (>= (- C A) 1) (<= (- A C) (- 1)) (<= C (- D 1)) (new23 A B) ) (new25 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B true) (>= C A) (<= (- A C) (- 1)) ) (new25 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B true) (>= C D) (<= (- A C) (- 1)) (new25 A B C) ) (new25 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B false) (>= (- D A) 1) (>= C D) (<= (- A C) (- 1)) (new25 A B C) ) (new25 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) (D Int) ) (=> (and (= B false) (>= C D) (<= (- D A) (- 1)) (<= (- A C) (- 1)) (new25 A B C) ) (new25 A B C) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new23 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new23 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new23 A B) ) (new23 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new23 A B) ) (new23 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new23 A B) ) (new23 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new15 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new15 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new15 A B) ) (new15 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new15 A B) ) (new15 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new15 A B) ) (new15 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new14 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new14 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new14 A B) ) (new14 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new14 A B) ) (new14 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new14 A B) ) (new14 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new6 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new6 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new6 A B) ) (new6 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new6 A B) ) (new6 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new6 A B) ) (new6 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B false) (new5 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (= B true) (new5 A B) ) ) ) (assert (forall ( (A Int) (B Bool) ) (=> (and (= B true) (new5 A B) ) (new5 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (>= (- C A) 1) (new5 A B) ) (new5 A B) ) ) ) (assert (forall ( (A Int) (B Bool) (C Int) ) (=> (and (= B false) (<= (- C A) (- 1)) (new5 A B) ) (new5 A B) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C false) (= D false) (= C false) (<= (- A B) (- 1)) (<= (- A B) (- 1)) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C true) (= D true) (= C true) (<= (- A B) (- 1)) (<= A (- B 1)) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C true) (= D true) (= C true) (<= (- A B) (- 1)) (<= A (- B 1)) (new5 B C) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C true) (= D true) (= C true) (<= (- A B) (- 1)) (<= A (- B 1)) (new6 B D) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C true) (= C true) (= C true) (<= (- A B) (- 1)) (<= A (- D 1)) (new5 B C) ) (new4 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C false) (= C false) (= C false) (>= (- D B) 1) (>= (- D B) 1) (<= (- A B) (- 1)) (<= (- A B) (- 1)) (<= A (- D 1)) (new5 B C) ) (new4 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C false) (= C false) (= C false) (<= (- D B) (- 1)) (<= (- D B) (- 1)) (<= (- A B) (- 1)) (<= (- A B) (- 1)) (<= A (- D 1)) (new5 B C) ) (new4 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C true) (>= A E) (<= (- A B) (- 1)) (new4 A B C B D) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C false) (>= A E) (<= (- E B) (- 1)) (<= (- A B) (- 1)) (new4 A B C B D) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C true) (>= A E) (<= (- E B) (- 1)) (<= (- A B) (- 1)) (new4 A B C B D) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C false) (>= A E) (<= (- E B) (- 1)) (<= (- E B) (- 1)) (<= (- A B) (- 1)) (new4 A B C B D) ) (new4 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C false) (= D false) (= C false) (<= (- A B) (- 1)) (<= (- A B) (- 1)) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C true) (= D true) (= C true) (<= (- A B) (- 1)) (<= A (- B 1)) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C true) (= D true) (= C true) (<= (- A B) (- 1)) (<= A (- B 1)) (new14 B C) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C true) (= D true) (= C true) (<= (- A B) (- 1)) (<= A (- B 1)) (new15 B D) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C true) (= C true) (= C true) (<= (- A B) (- 1)) (<= A (- D 1)) (new14 B C) ) (new3 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C false) (= C false) (= C false) (>= (- D B) 1) (>= (- D B) 1) (<= (- A B) (- 1)) (<= (- A B) (- 1)) (<= A (- D 1)) (new14 B C) ) (new3 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C false) (= C false) (= C false) (<= (- D B) (- 1)) (<= (- D B) (- 1)) (<= (- A B) (- 1)) (<= (- A B) (- 1)) (<= A (- D 1)) (new14 B C) ) (new3 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C true) (>= A E) (<= (- A B) (- 1)) (new3 A B C B D) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C false) (>= A E) (<= (- E B) (- 1)) (<= (- A B) (- 1)) (new3 A B C B D) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C true) (>= A E) (<= (- E B) (- 1)) (<= (- A B) (- 1)) (new3 A B C B D) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C false) (>= A E) (<= (- E B) (- 1)) (<= (- E B) (- 1)) (<= (- A B) (- 1)) (new3 A B C B D) ) (new3 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C false) (= D false) (= C false) (>= (- A B) 1) (>= (- A B) 1) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C true) (= C true) (= C true) (>= (- A B) 1) (<= A (- D 1)) (new23 B C) ) (new2 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C false) (= C false) (= C false) (>= (- D B) 1) (>= (- D B) 1) (>= (- A B) 1) (>= (- A B) 1) (<= A (- D 1)) (new23 B C) ) (new2 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A B) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A B) (new25 B C A) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A B) (new26 B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A E) (new2 A B C B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C false) (>= (- E B) 1) (>= (- A B) 1) (>= A E) (new2 A B C B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C false) (>= (- A B) 1) (>= A E) (<= (- E B) (- 1)) (new2 A B C B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C true) (>= (- E B) 1) (>= (- A B) 1) (>= A E) (new2 A B C B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C false) (>= (- E B) 1) (>= (- E B) 1) (>= (- A B) 1) (>= A E) (new2 A B C B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C true) (>= (- A B) 1) (>= A E) (<= (- E B) (- 1)) (new2 A B C B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C false) (>= (- A B) 1) (>= A E) (<= (- E B) (- 1)) (<= (- E B) (- 1)) (new2 A B C B D) ) (new2 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= C false) (= D false) (= C false) (>= (- A B) 1) (>= (- A B) 1) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C true) (= C true) (= C true) (>= (- A B) 1) (<= A (- D 1)) (new34 B C) ) (new1 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Int) ) (=> (and (= C false) (= C false) (= C false) (>= (- D B) 1) (>= (- D B) 1) (>= (- A B) 1) (>= (- A B) 1) (<= A (- D 1)) (new34 B C) ) (new1 A B C B C) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A B) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A B) (new36 B C A) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A B) (new37 B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C true) (>= (- A B) 1) (>= A E) (new1 A B C B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C false) (>= (- E B) 1) (>= (- A B) 1) (>= A E) (new1 A B C B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D true) (= C false) (>= (- A B) 1) (>= A E) (<= (- E B) (- 1)) (new1 A B C B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C true) (>= (- E B) 1) (>= (- A B) 1) (>= A E) (new1 A B C B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C false) (>= (- E B) 1) (>= (- E B) 1) (>= (- A B) 1) (>= A E) (new1 A B C B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C true) (>= (- A B) 1) (>= A E) (<= (- E B) (- 1)) (new1 A B C B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Int) (B Int) (C Bool) (D Bool) (E Int) ) (=> (and (= D false) (= C false) (>= (- A B) 1) (>= A E) (<= (- E B) (- 1)) (<= (- E B) (- 1)) (new1 A B C B D) ) (new1 A B C B D) ) ) ) (assert (forall ( (A Bool) (B Bool) (C Int) (D Int) ) (=> (and (= A true) (= B false) (<= C (- D 1)) (new1 D C A C B) ) ff ) ) ) (assert (forall ( (A Bool) (B Bool) (C Int) (D Int) ) (=> (and (= A false) (= B true) (<= C (- D 1)) (new2 D C A C B) ) ff ) ) ) (assert (forall ( (A Bool) (B Bool) (C Int) (D Int) ) (=> (and (= A true) (= B false) (>= C (+ D 1)) (new3 D C A C B) ) ff ) ) ) (assert (forall ( (A Bool) (B Bool) (C Int) (D Int) ) (=> (and (= A false) (= B true) (>= C (+ D 1)) (new4 D C A C B) ) ff ) ) ) (assert (not ff)) (check-sat)