-
Notifications
You must be signed in to change notification settings - Fork 50
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
support qf-bvlra in Yices2 CDCL(T) (#515)
* support qf-bvlra * add logic in the manual
- Loading branch information
1 parent
742f189
commit 5df56b7
Showing
19 changed files
with
1,176 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
147 changes: 147 additions & 0 deletions
147
...verage/smtlib/QF_BVLRA/20240414-mapf_r/makespan/coef_1.25/corridor/corridor_000_k2_B.smt2
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,147 @@ | ||
(set-info :smt-lib-version 2.6) | ||
(set-logic QF_BVLRA) | ||
(set-info :source | | ||
Generated by: Tomas Kolarik | ||
Generated on: 2024-04-14 | ||
Generator: gitlab.com/Tomaqa/mapf_r | ||
Application: Multi-Agent Path-Finding with Continuous Time | ||
Target solver: Z3, CVC4, MathSAT | ||
Publications: Tomas Kolarik, Stefan Ratschan and Pavel Surynek: "Multi-Agent Path-Finding with Continuous Time Using SAT Modulo Linear Real Arithmetic" in ICAART, SCITEPRESS, 2024. | ||
The benchmarks mimic MAPF problems with continuous time where the objective time must be sub-optimal, bounded by a user-specified coefficient. In the original solver, a simulator checks whether there are collisions between particular agents, according to the current model. This check is missing in the case of the final 'check-sat'. The benchmarks also lack commands for preferring certain variables during the search which is of huge importance when searching for short paths in a graph. However, the final plan must still avoid all collisions encountered by the original solver and the objective time must obey the sub-optimal coefficient. Producing models is crucial for the application since the intended solver communicates values of particular variables with the simulator. This communication is ommited though for simplicity. The final 'get-value' allows to compare with the original solver that the objective time indeed obeys the coefficient. Filenames without the extensions correspond to filenames of resulting plans of the original solver. | ||
|) | ||
(set-info :license "https://creativecommons.org/licenses/by/4.0/") | ||
(set-info :category "industrial") | ||
(declare-const objtime Real) | ||
(declare-const oo Real) | ||
(declare-const eps Real) | ||
(declare-const A0.V<0> (_ BitVec 16)) | ||
(declare-const A0.atime<0> Real) | ||
(assert (= A0.atime<0> 0)) | ||
(declare-const A0.rtime<0> Real) | ||
(declare-const A0.wtime<0> Real) | ||
(declare-const A0.mtime<0> Real) | ||
(assert (= (+ A0.rtime<0> (+ (* (- 1) A0.wtime<0>) (* (- 1) A0.mtime<0>))) 0)) | ||
(assert (<= 0 A0.wtime<0>)) | ||
(assert (<= 0 A0.mtime<0>)) | ||
(declare-const wpref0 Bool) | ||
(assert (or (= A0.wtime<0> 0) (not wpref0))) | ||
(declare-const A0.ppref<0> Bool) | ||
(declare-const A0.spref<0><1> Bool) | ||
(declare-const A0.spref<0><2> Bool) | ||
(declare-const A0.spref<0><3> Bool) | ||
(declare-const A1.V<0> (_ BitVec 16)) | ||
(declare-const A1.atime<0> Real) | ||
(assert (= A1.atime<0> 0)) | ||
(declare-const A1.rtime<0> Real) | ||
(declare-const A1.wtime<0> Real) | ||
(declare-const A1.mtime<0> Real) | ||
(assert (= (+ A1.rtime<0> (+ (* (- 1) A1.wtime<0>) (* (- 1) A1.mtime<0>))) 0)) | ||
(assert (<= 0 A1.wtime<0>)) | ||
(assert (<= 0 A1.mtime<0>)) | ||
(declare-const wpref1 Bool) | ||
(assert (or (= A1.wtime<0> 0) (not wpref1))) | ||
(declare-const A1.ppref<0> Bool) | ||
(declare-const A1.spref<0><1> Bool) | ||
(declare-const A1.spref<0><2> Bool) | ||
(declare-const A1.spref<0><3> Bool) | ||
(assert (= A1.V<0> (_ bv3 16))) | ||
(assert (= A0.V<0> (_ bv0 16))) | ||
(assert (or (= A0.wtime<0> 0) (= A1.wtime<0> 0))) | ||
(assert (or (= A0.V<0> (_ bv0 16)) (not A0.ppref<0>))) | ||
(assert (or (= A1.V<0> (_ bv3 16)) (not A1.ppref<0>))) | ||
(declare-const A0.V<1> (_ BitVec 16)) | ||
(declare-const A0.atime<1> Real) | ||
(assert (= (+ A0.atime<0> (+ A0.rtime<0> (* (- 1) A0.atime<1>))) 0)) | ||
(declare-const A0.rtime<1> Real) | ||
(declare-const A0.wtime<1> Real) | ||
(declare-const A0.mtime<1> Real) | ||
(assert (= (+ A0.rtime<1> (+ (* (- 1) A0.wtime<1>) (* (- 1) A0.mtime<1>))) 0)) | ||
(assert (<= 0 A0.wtime<1>)) | ||
(assert (<= 0 A0.mtime<1>)) | ||
(declare-const A0.ppref<1> Bool) | ||
(declare-const A0.spref<1><1> Bool) | ||
(declare-const A0.spref<1><2> Bool) | ||
(declare-const A0.spref<1><3> Bool) | ||
(declare-const A1.V<1> (_ BitVec 16)) | ||
(declare-const A1.atime<1> Real) | ||
(assert (= (+ A1.atime<0> (+ A1.rtime<0> (* (- 1) A1.atime<1>))) 0)) | ||
(declare-const A1.rtime<1> Real) | ||
(declare-const A1.wtime<1> Real) | ||
(declare-const A1.mtime<1> Real) | ||
(assert (= (+ A1.rtime<1> (+ (* (- 1) A1.wtime<1>) (* (- 1) A1.mtime<1>))) 0)) | ||
(assert (<= 0 A1.wtime<1>)) | ||
(assert (<= 0 A1.mtime<1>)) | ||
(declare-const A1.ppref<1> Bool) | ||
(declare-const A1.spref<1><1> Bool) | ||
(declare-const A1.spref<1><2> Bool) | ||
(declare-const A1.spref<1><3> Bool) | ||
(assert (or (= A0.V<1> (_ bv1 16)) (not A0.ppref<1>))) | ||
(assert (or (= A0.mtime<0> 1) (not (and (= A0.V<0> (_ bv0 16)) (= A0.V<1> (_ bv1 16)))))) | ||
(assert (or (= A0.V<1> (_ bv1 16)) (not (= A0.V<0> (_ bv0 16))))) | ||
(assert (or (= A0.V<1> (_ bv1 16)) (not (and A0.spref<0><1> (= A0.V<0> (_ bv0 16)))))) | ||
(assert (or (= A1.mtime<0> 1) (not (and (= A1.V<0> (_ bv3 16)) (= A1.V<1> (_ bv1 16)))))) | ||
(assert (or (and (= A1.wtime<0> 0) (= A1.mtime<0> 0)) (not (and (= A1.V<0> (_ bv3 16)) (= A1.V<1> (_ bv3 16)))))) | ||
(assert (or (or (= A1.V<1> (_ bv1 16)) (= A1.V<1> (_ bv3 16))) (not (= A1.V<0> (_ bv3 16))))) | ||
(declare-const A0.V<2> (_ BitVec 16)) | ||
(declare-const A0.atime<2> Real) | ||
(assert (= (+ A0.atime<1> (+ A0.rtime<1> (* (- 1) A0.atime<2>))) 0)) | ||
(declare-const A0.rtime<2> Real) | ||
(declare-const A0.wtime<2> Real) | ||
(declare-const A0.mtime<2> Real) | ||
(assert (= (+ A0.rtime<2> (+ (* (- 1) A0.wtime<2>) (* (- 1) A0.mtime<2>))) 0)) | ||
(assert (<= 0 A0.wtime<2>)) | ||
(assert (<= 0 A0.mtime<2>)) | ||
(declare-const A0.ppref<2> Bool) | ||
(declare-const A0.spref<2><1> Bool) | ||
(declare-const A0.spref<2><2> Bool) | ||
(declare-const A0.spref<2><3> Bool) | ||
(declare-const A1.V<2> (_ BitVec 16)) | ||
(declare-const A1.atime<2> Real) | ||
(assert (= (+ A1.atime<1> (+ A1.rtime<1> (* (- 1) A1.atime<2>))) 0)) | ||
(declare-const A1.rtime<2> Real) | ||
(declare-const A1.wtime<2> Real) | ||
(declare-const A1.mtime<2> Real) | ||
(assert (= (+ A1.rtime<2> (+ (* (- 1) A1.wtime<2>) (* (- 1) A1.mtime<2>))) 0)) | ||
(assert (<= 0 A1.wtime<2>)) | ||
(assert (<= 0 A1.mtime<2>)) | ||
(declare-const A1.ppref<2> Bool) | ||
(declare-const A1.spref<2><1> Bool) | ||
(declare-const A1.spref<2><2> Bool) | ||
(declare-const A1.spref<2><3> Bool) | ||
(assert (or (= A0.V<2> (_ bv2 16)) (not A0.ppref<2>))) | ||
(assert (or (= A0.mtime<1> 1) (not (and (= A0.V<1> (_ bv1 16)) (= A0.V<2> (_ bv3 16)))))) | ||
(assert (or (= A0.mtime<1> 1) (not (and (= A0.V<1> (_ bv1 16)) (= A0.V<2> (_ bv2 16)))))) | ||
(assert (or (= A0.mtime<1> 1) (not (and (= A0.V<1> (_ bv1 16)) (= A0.V<2> (_ bv0 16)))))) | ||
(assert (or (or (= A0.V<2> (_ bv0 16)) (or (= A0.V<2> (_ bv2 16)) (= A0.V<2> (_ bv3 16)))) (not (= A0.V<1> (_ bv1 16))))) | ||
(assert (or (= A0.V<2> (_ bv2 16)) (not (and A0.spref<1><1> (= A0.V<1> (_ bv1 16)))))) | ||
(assert (or (= A0.V<2> (_ bv3 16)) (not (and A0.spref<1><2> (= A0.V<1> (_ bv1 16)))))) | ||
(assert (or (= A0.mtime<1> 1) (not (and (= A0.V<1> (_ bv0 16)) (= A0.V<2> (_ bv1 16)))))) | ||
(assert (or (= A0.V<2> (_ bv1 16)) (not (= A0.V<1> (_ bv0 16))))) | ||
(assert (or (= A0.V<2> (_ bv1 16)) (not (and A0.spref<1><1> (= A0.V<1> (_ bv0 16)))))) | ||
(assert (or (= A1.mtime<1> 1) (not (and (= A1.V<1> (_ bv1 16)) (= A1.V<2> (_ bv3 16)))))) | ||
(assert (or (= A1.mtime<1> 1) (not (and (= A1.V<1> (_ bv1 16)) (= A1.V<2> (_ bv2 16)))))) | ||
(assert (or (= A1.mtime<1> 1) (not (and (= A1.V<1> (_ bv1 16)) (= A1.V<2> (_ bv0 16)))))) | ||
(assert (or (or (= A1.V<2> (_ bv0 16)) (or (= A1.V<2> (_ bv3 16)) (= A1.V<2> (_ bv2 16)))) (not (= A1.V<1> (_ bv1 16))))) | ||
(assert (or (= A1.V<2> (_ bv3 16)) (not (and A1.spref<1><1> (= A1.V<1> (_ bv1 16)))))) | ||
(assert (or (= A1.V<2> (_ bv2 16)) (not (and A1.spref<1><2> (= A1.V<1> (_ bv1 16)))))) | ||
(assert (or (= A1.mtime<1> 1) (not (and (= A1.V<1> (_ bv3 16)) (= A1.V<2> (_ bv1 16)))))) | ||
(assert (or (and (= A1.mtime<1> 0) (= A1.wtime<1> 0)) (not (and (= A1.V<1> (_ bv3 16)) (= A1.V<2> (_ bv3 16)))))) | ||
(assert (or (not (and (= A1.V<0> (_ bv3 16)) (= A1.V<1> (_ bv3 16)))) (= A1.V<2> (_ bv3 16)))) | ||
(assert (or (or (= A1.V<2> (_ bv3 16)) (= A1.V<2> (_ bv1 16))) (not (= A1.V<1> (_ bv3 16))))) | ||
(declare-const kass2 Bool) | ||
(assert (or (= objtime A1.wtime<2>) (not kass2))) | ||
(assert (or (not kass2) (= A1.mtime<2> 0))) | ||
(assert (or (not kass2) (= objtime A0.wtime<2>))) | ||
(assert (or (not kass2) (= A0.mtime<2> 0))) | ||
(push 1) | ||
(assert kass2) | ||
(assert (= A1.V<2> (_ bv3 16))) | ||
(assert (= A0.V<2> (_ bv2 16))) | ||
(assert (let ((def_266 (ite (<= A1.atime<2> 0) 0 A1.atime<2>))) (= objtime (ite (<= A0.atime<2> def_266) def_266 A0.atime<2>)))) | ||
(set-info :status sat) | ||
(check-sat) | ||
(assert (<= 2 objtime)) | ||
(assert (<= objtime (/ 9 4))) | ||
(set-info :status sat) | ||
(check-sat) | ||
(exit) |
2 changes: 2 additions & 0 deletions
2
...e/smtlib/QF_BVLRA/20240414-mapf_r/makespan/coef_1.25/corridor/corridor_000_k2_B.smt2.gold
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
sat | ||
sat |
1 change: 1 addition & 0 deletions
1
...mtlib/QF_BVLRA/20240414-mapf_r/makespan/coef_1.25/corridor/corridor_000_k2_B.smt2.options
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
--incremental |
Oops, something went wrong.