summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMorgan Deters <mdeters@gmail.com>2012-06-18 21:33:00 +0000
committerMorgan Deters <mdeters@gmail.com>2012-06-18 21:33:00 +0000
commit09590d6e174d810cde3c223da375ac798901aa3d (patch)
tree87f258c90a243d906ed8367b97ad97e382bf7d94
parent8adb4e13c5c28059ed9271522137daf341942a75 (diff)
final sources (?) for competition
-rw-r--r--Makefile9
-rw-r--r--contrib/Makefile.am1
-rwxr-xr-xcontrib/run-script-smtcomp201251
3 files changed, 56 insertions, 5 deletions
diff --git a/Makefile b/Makefile
index d0e7b2ebc..5b1acecbd 100644
--- a/Makefile
+++ b/Makefile
@@ -43,7 +43,7 @@ examples: all
YEAR := $(shell date +%Y)
submission submission-main:
- @if [ -n "`ls src/parser/*/generated`" ]; then \
+ @if [ -n "`ls src/parser/*/generated 2>/dev/null`" ]; then \
echo 'ERROR:' >&2; \
echo 'ERROR: Please make maintainer-clean first.' >&2; \
echo 'ERROR:' >&2; \
@@ -58,13 +58,12 @@ submission submission-main:
# main track
mkdir -p cvc4-smtcomp-$(YEAR)
cp -p builds/bin/cvc4 cvc4-smtcomp-$(YEAR)/cvc4
- ( echo '#!/bin/sh'; \
- echo 'exec ./cvc4 -L smt2 --no-checking --no-interactive' ) > cvc4-smtcomp-$(YEAR)/run
+ cp contrib/run-script-smtcomp2012 cvc4-smtcomp-$(YEAR)/run
chmod 755 cvc4-smtcomp-$(YEAR)/run
tar cf cvc4-smtcomp-$(YEAR).tar cvc4-smtcomp-$(YEAR)
submission-application:
# application track is a separate build because it has different preprocessor #defines
- @if [ -n "`ls src/parser/*/generated`" ]; then \
+ @if [ -n "`ls src/parser/*/generated 2>/dev/null`" ]; then \
echo 'ERROR:' >&2; \
echo 'ERROR: Please make maintainer-clean first.' >&2; \
echo 'ERROR:' >&2; \
@@ -85,7 +84,7 @@ submission-application:
tar cf cvc4-application-smtcomp-$(YEAR).tar cvc4-application-smtcomp-$(YEAR)
submission-parallel:
# parallel track can't be built with -cln, so it's a separate build
- @if [ -n "`ls src/parser/*/generated`" ]; then \
+ @if [ -n "`ls src/parser/*/generated 2>/dev/null`" ]; then \
echo 'ERROR:' >&2; \
echo 'ERROR: Please make maintainer-clean first.' >&2; \
echo 'ERROR:' >&2; \
diff --git a/contrib/Makefile.am b/contrib/Makefile.am
index 815c3377d..facf5a21c 100644
--- a/contrib/Makefile.am
+++ b/contrib/Makefile.am
@@ -11,6 +11,7 @@ EXTRA_DIST = \
configure-in-place \
depgraph \
get-antlr-3.4 \
+ run-script-smtcomp2012 \
theoryskel/kinds \
theoryskel/Makefile \
theoryskel/Makefile.am \
diff --git a/contrib/run-script-smtcomp2012 b/contrib/run-script-smtcomp2012
new file mode 100755
index 000000000..bad8482c2
--- /dev/null
+++ b/contrib/run-script-smtcomp2012
@@ -0,0 +1,51 @@
+#!/bin/bash
+
+cat >bench-$$.smt2
+trap 'rm bench-$$.smt2' EXIT
+
+logic=$(expr "$(head -n 1 bench-$$.smt2)" : '^ *(set-logic *\([A-Z_]*\) *) *$')
+
+# use: trywith [params..]
+# to attempt a run. Only thing printed on stdout is "sat" or "unsat", in
+# which case this run script terminates immediately. Otherwise, this
+# function returns normally.
+function trywith {
+ result="$(./cvc4 -L smt2 --no-checking --no-interactive "$@" bench-$$.smt2)"
+ case "$result" in
+ sat|unsat) echo "$result"; exit 0;;
+ esac
+}
+
+# use: finishwith [params..]
+# to run cvc4 and let it output whatever it will to stdout.
+function finishwith {
+ ./cvc4 -L smt2 --no-checking --no-interactive "$@" bench-$$.smt2
+}
+
+case "$logic" in
+
+QF_LRA)
+ # 10 minutes with default decision heuristic
+ trywith --tlimit-per=600000
+ # switch to internal decision heuristic
+ finishwith --decision=internal
+ ;;
+AUFLIA)
+ # 60 seconds with default decision heuristic
+ trywith --tlimit-per=60000
+ # try simplification for 60 seconds, default decision heuristic
+ trywith --simplification=batch --tlimit-per=60000
+ # switch to internal decision heuristic
+ finishwith --decision=internal
+ ;;
+QF_AUFBV)
+ trywith --tlimit-per=600000
+ finishwith --decision=justification-stoponly
+ ;;
+*)
+ # just run the default
+ finishwith
+ ;;
+
+esac
+
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback