fond
Model Checking Contest @ Petri Nets 2017
7th edition, Zaragoza, Spain, June 27, 2017
Execution of r160-ebro-149443467200176
Last Updated
June 27, 2017

About the Execution of ITS-Tools for S_SwimmingPool-PT-08

Execution Summary
Max Memory
Used (MB)
Time wait (ms) CPU Usage (ms) I/O Wait (ms) Computed Result Execution
Status
5300.860 3511926.00 3539142.00 618.70 T??????????????? normal

Execution Chart

We display below the execution chart for this examination (boot time has been removed).

Trace from the execution

Waiting for the VM to be ready (probing ssh)
...................
=====================================================================
Generated by BenchKit 2-3253
Executing tool itstools
Input is S_SwimmingPool-PT-08, examination is LTLCardinality
Time confinement is 3600 seconds
Memory confinement is 16384 MBytes
Number of cores is 4
Run identifier is r160-ebro-149443467200176
=====================================================================


--------------------
content from stdout:

=== Data for post analysis generated by BenchKit (invocation template)

The expected result is a vector of booleans
BOOL_VECTOR

here is the order used to build the result vector(from text file)
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-0
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-1
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-10
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-11
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-12
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-13
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-14
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-15
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-2
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-3
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-4
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-5
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-6
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-7
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-8
FORMULA_NAME SwimmingPool-PT-08-LTLCardinality-9

=== Now, execution of the tool begins

BK_START 1496714805945


Using solver YICES2 to compute partial order matrices.
Built C files in :
/home/mcc/execution
its-ltl command run as :

/home/mcc/BenchKit/eclipse/plugins/fr.lip6.move.gal.itstools.binaries_1.0.0.201705302212/bin/its-ltl-linux64 --gc-threshold 2000000 -i /home/mcc/execution/LTLCardinality.pnml.gal -t CGAL -LTL /home/mcc/execution/LTLCardinality.ltl -c -stutter-deadlock
Read 16 LTL properties
Checking formula 0 : !(("InBath<=Dress"))
Formula 0 simplified : !"InBath<=Dress"
Presburger conditions satisfied. Using coverability to approximate state space in K-Induction.
// Phase 1: matrix 7 rows 9 cols
invariant : 1'Entered + 1'WaitBag + 1'Undress + 1'InBath + 1'Dress + 1'Dressed + 1'Out= 160
invariant : 1'WaitBag + 1'Undress + 1'Dress + 1'Dressed + 1'Cabins= 80
invariant : 1'Undress + 1'InBath + 1'Dress + 1'Bags= 120
Running compilation step : CommandLine [args=[gcc, -c, -I/home/mcc/BenchKit//lts_install_dir//include, -I., -std=c99, -fPIC, -O3, model.c], workingDir=/home/mcc/execution]
Exit code :0
Running link step : CommandLine [args=[gcc, -shared, -o, gal.so, model.o], workingDir=/home/mcc/execution]
Exit code :0
Exit code :0
FORMULA SwimmingPool-PT-08-LTLCardinality-0 TRUE TECHNIQUES PARTIAL_ORDER EXPLICIT LTSMIN SAT_SMT
Exit code :255
Detected timeout of ITS tools.

BK_STOP 1496718317871

--------------------
content from stderr:

+ export BINDIR=/home/mcc/BenchKit/
+ BINDIR=/home/mcc/BenchKit/
++ pwd
+ export MODEL=/home/mcc/execution
+ MODEL=/home/mcc/execution
+ [[ LTLCardinality = StateSpace ]]
+ /home/mcc/BenchKit//runeclipse.sh /home/mcc/execution LTLCardinality -its -ltsminpath /home/mcc/BenchKit//lts_install_dir/ -smt
+ ulimit -s 65536
+ java -Dosgi.requiredJavaVersion=1.6 -Xss8m -Xms40m -Xmx8192m -Declipse.pde.launch=true -Dfile.encoding=UTF-8 -classpath /home/mcc/BenchKit//eclipse/plugins/org.eclipse.equinox.launcher_1.3.201.v20161025-1711.jar org.eclipse.equinox.launcher.Main -application fr.lip6.move.gal.application.pnmcc -data /home/mcc/BenchKit//workspace -os linux -ws gtk -arch x86_64 -nl en_US -consoleLog -pnfolder /home/mcc/execution -examination LTLCardinality -yices2path /home/mcc/BenchKit//yices/bin/yices -its -ltsminpath /home/mcc/BenchKit//lts_install_dir/ -smt
Jun 06, 2017 2:06:48 AM fr.lip6.move.gal.application.MccTranslator transformPNML
INFO: Parsing pnml file : /home/mcc/execution/model.pnml
Jun 06, 2017 2:06:48 AM fr.lip6.move.gal.nupn.PTNetReader loadFromXML
INFO: Load time of PNML (sax parser for PT used): 55 ms
Jun 06, 2017 2:06:48 AM fr.lip6.move.gal.pnml.togal.PTGALTransformer handlePage
INFO: Transformed 9 places.
Jun 06, 2017 2:06:48 AM fr.lip6.move.gal.pnml.togal.PTGALTransformer handlePage
INFO: Transformed 7 transitions.
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.instantiate.GALRewriter flatten
INFO: Flatten gal took : 44 ms
Jun 06, 2017 2:06:49 AM fr.lip6.move.serialization.SerializationUtil systemToFile
INFO: Time to serialize gal into /home/mcc/execution/LTLCardinality.pnml.gal : 11 ms
Jun 06, 2017 2:06:49 AM fr.lip6.move.serialization.SerializationUtil serializePropertiesForITSLTLTools
INFO: Time to serialize properties into /home/mcc/execution/LTLCardinality.ltl : 2 ms
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.KInductionSolver computeAndDeclareInvariants
INFO: Computed 3 place invariants in 13 ms
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.KInductionSolver init
INFO: Proved 9 variables to be positive in 50 ms
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver computeAblingMatrix
INFO: Computing symmetric may disable matrix : 7 transitions.
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver printStats
INFO: Computation of Completed :0/7 took 2 ms. Total solver calls (SAT/UNSAT): 2(1/1)
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver printStats
INFO: Computation of Complete disable matrix. took 19 ms. Total solver calls (SAT/UNSAT): 20(9/11)
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver computeAblingMatrix
INFO: Computing symmetric may enable matrix : 7 transitions.
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver printStats
INFO: Computation of Complete enable matrix. took 14 ms. Total solver calls (SAT/UNSAT): 20(11/9)
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver computeCoEnablingMatrix
INFO: Computing symmetric co enabling matrix : 7 transitions.
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver printStats
INFO: Computation of Finished enabling matrix. took 16 ms. Total solver calls (SAT/UNSAT): 28(28/0)
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver computeDoNotAccord
INFO: Computing Do-Not-Accords matrix : 7 transitions.
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2smt.bmc.NecessaryEnablingsolver printStats
INFO: Computation of Completed DNA matrix. took 36 ms. Total solver calls (SAT/UNSAT): 12(0/12)
Jun 06, 2017 2:06:49 AM fr.lip6.move.gal.gal2pins.Gal2PinsTransformerNext transform
INFO: Built C files in 220ms conformant to PINS in folder :/home/mcc/execution
Jun 06, 2017 2:06:50 AM fr.lip6.move.gal.itstools.Runner runTool
INFO: Standard error output from running tool CommandLine [args=[/home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq, ./gal.so, -p, --pins-guards, --when, --ltl, (LTLAP0==true)], workingDir=/home/mcc/execution]
pins2lts-seq, 0.001: Registering PINS so language module
pins2lts-seq, 0.001: Loading model from ./gal.so
pins2lts-seq, 0.002: library has no initializer
pins2lts-seq, 0.002: loading model GAL
pins2lts-seq, 0.002: completed loading model GAL
pins2lts-seq, 0.002: Initializing POR dependencies: labels 24, guards 7
pins2lts-seq, 0.003: LTL layer: formula: (LTLAP0==true)
pins2lts-seq, 0.003: Expression is: (LTLAP0 == true )
pins2lts-seq, 0.003: buchi has 2 states
pins2lts-seq, 0.003: state 0: accepting
pins2lts-seq, 0.004: -> 1, | !(LTLAP0 == true )
pins2lts-seq, 0.004: state 1: accepting
pins2lts-seq, 0.004: -> 1, | true
pins2lts-seq, 0.004: Forcing the use of a cycle proviso. For best results use --proviso=color.
pins2lts-seq, 0.004: There are 25 state labels and 1 edge labels
pins2lts-seq, 0.004: State length is 10, there are 9 groups
pins2lts-seq, 0.004: Running scc search strategy
pins2lts-seq, 0.004: Using a tree for state storage
pins2lts-seq, 0.004: Visible groups: 0 / 9, labels: 1 / 25
pins2lts-seq, 0.004: POR cycle proviso: stack (ltl)
pins2lts-seq, 0.008: state space 1 levels, 1 states 0 transitions

Jun 06, 2017 2:06:50 AM fr.lip6.move.gal.itstools.Runner runTool
INFO: Standard error output from running tool CommandLine [args=[/home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq, ./gal.so, -p, --pins-guards, --when, --ltl, (LTLAP1==true)], workingDir=/home/mcc/execution]
pins2lts-seq, 0.000: Registering PINS so language module
pins2lts-seq, 0.000: Loading model from ./gal.so
pins2lts-seq, 0.000: library has no initializer
pins2lts-seq, 0.000: loading model GAL
pins2lts-seq, 0.000: completed loading model GAL
pins2lts-seq, 0.000: Initializing POR dependencies: labels 24, guards 7
pins2lts-seq, 0.000: LTL layer: formula: (LTLAP1==true)
pins2lts-seq, 0.000: Expression is: (LTLAP1 == true )
pins2lts-seq, 0.000: buchi has 2 states
pins2lts-seq, 0.000: state 0: accepting
pins2lts-seq, 0.000: -> 1, | !(LTLAP1 == true )
pins2lts-seq, 0.000: state 1: accepting
pins2lts-seq, 0.000: -> 1, | true
pins2lts-seq, 0.000: Forcing the use of a cycle proviso. For best results use --proviso=color.
pins2lts-seq, 0.001: There are 25 state labels and 1 edge labels
pins2lts-seq, 0.001: State length is 10, there are 9 groups
pins2lts-seq, 0.001: Running scc search strategy
pins2lts-seq, 0.001: Using a tree for state storage
pins2lts-seq, 0.001: Visible groups: 0 / 9, labels: 1 / 25
pins2lts-seq, 0.001: POR cycle proviso: stack (ltl)
*** segmentation fault ***

Please send information on how to reproduce this problem to:
ltsmin-support@lists.utwente.nl
along with all output preceding this message.
In addition, include the following information:
Package: ltsmin 2.1
Stack trace:
0: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(HREprintStack+0x18) [0x4311a8]
1: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x431226]
2: /lib/x86_64-linux-gnu/libpthread.so.0(+0xf890) [0x7f51d9314890]
3: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x44bed8]
4: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(qsortr+0x20b) [0x45916b]
5: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x4505fb]
6: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x4468b2]
7: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41cb25]
8: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c33a]
9: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c2e4]
10: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(main+0x81a) [0x41b47a]
11: /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf5) [0x7f51d8c7ab45]
12: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c13d]

LTS min runner thread failed on error :java.lang.RuntimeException: Unexpected exception when executing ltsmin :CommandLine [args=[/home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq, ./gal.so, -p, --pins-guards, --when, --ltl, (LTLAP1==true)], workingDir=/home/mcc/execution]
Status WARNING: fr.lip6.move.gal code=255 pins2lts-seq, 0.000: Registering PINS so language module
pins2lts-seq, 0.000: Loading model from ./gal.so
pins2lts-seq, 0.000: library has no initializer
pins2lts-seq, 0.000: loading model GAL
pins2lts-seq, 0.000: completed loading model GAL
pins2lts-seq, 0.000: Initializing POR dependencies: labels 24, guards 7
pins2lts-seq, 0.000: LTL layer: formula: (LTLAP1==true)
pins2lts-seq, 0.000: Expression is: (LTLAP1 == true )
pins2lts-seq, 0.000: buchi has 2 states
pins2lts-seq, 0.000: state 0: accepting
pins2lts-seq, 0.000: -> 1, | !(LTLAP1 == true )
pins2lts-seq, 0.000: state 1: accepting
pins2lts-seq, 0.000: -> 1, | true
pins2lts-seq, 0.000: Forcing the use of a cycle proviso. For best results use --proviso=color.
pins2lts-seq, 0.001: There are 25 state labels and 1 edge labels
pins2lts-seq, 0.001: State length is 10, there are 9 groups
pins2lts-seq, 0.001: Running scc search strategy
pins2lts-seq, 0.001: Using a tree for state storage
pins2lts-seq, 0.001: Visible groups: 0 / 9, labels: 1 / 25
pins2lts-seq, 0.001: POR cycle proviso: stack (ltl)
*** segmentation fault ***

Please send information on how to reproduce this problem to:
ltsmin-support@lists.utwente.nl
along with all output preceding this message.
In addition, include the following information:
Package: ltsmin 2.1
Stack trace:
0: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(HREprintStack+0x18) [0x4311a8]
1: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x431226]
2: /lib/x86_64-linux-gnu/libpthread.so.0(+0xf890) [0x7f51d9314890]
3: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x44bed8]
4: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(qsortr+0x20b) [0x45916b]
5: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x4505fb]
6: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x4468b2]
7: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41cb25]
8: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c33a]
9: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c2e4]
10: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(main+0x81a) [0x41b47a]
11: /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf5) [0x7f51d8c7ab45]
12: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c13d]
null
java.lang.RuntimeException: Unexpected exception when executing ltsmin :CommandLine [args=[/home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq, ./gal.so, -p, --pins-guards, --when, --ltl, (LTLAP1==true)], workingDir=/home/mcc/execution]
Status WARNING: fr.lip6.move.gal code=255 pins2lts-seq, 0.000: Registering PINS so language module
pins2lts-seq, 0.000: Loading model from ./gal.so
pins2lts-seq, 0.000: library has no initializer
pins2lts-seq, 0.000: loading model GAL
pins2lts-seq, 0.000: completed loading model GAL
pins2lts-seq, 0.000: Initializing POR dependencies: labels 24, guards 7
pins2lts-seq, 0.000: LTL layer: formula: (LTLAP1==true)
pins2lts-seq, 0.000: Expression is: (LTLAP1 == true )
pins2lts-seq, 0.000: buchi has 2 states
pins2lts-seq, 0.000: state 0: accepting
pins2lts-seq, 0.000: -> 1, | !(LTLAP1 == true )
pins2lts-seq, 0.000: state 1: accepting
pins2lts-seq, 0.000: -> 1, | true
pins2lts-seq, 0.000: Forcing the use of a cycle proviso. For best results use --proviso=color.
pins2lts-seq, 0.001: There are 25 state labels and 1 edge labels
pins2lts-seq, 0.001: State length is 10, there are 9 groups
pins2lts-seq, 0.001: Running scc search strategy
pins2lts-seq, 0.001: Using a tree for state storage
pins2lts-seq, 0.001: Visible groups: 0 / 9, labels: 1 / 25
pins2lts-seq, 0.001: POR cycle proviso: stack (ltl)
*** segmentation fault ***

Please send information on how to reproduce this problem to:
ltsmin-support@lists.utwente.nl
along with all output preceding this message.
In addition, include the following information:
Package: ltsmin 2.1
Stack trace:
0: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(HREprintStack+0x18) [0x4311a8]
1: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x431226]
2: /lib/x86_64-linux-gnu/libpthread.so.0(+0xf890) [0x7f51d9314890]
3: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x44bed8]
4: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(qsortr+0x20b) [0x45916b]
5: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x4505fb]
6: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x4468b2]
7: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41cb25]
8: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c33a]
9: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c2e4]
10: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq(main+0x81a) [0x41b47a]
11: /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf5) [0x7f51d8c7ab45]
12: /home/mcc/BenchKit//lts_install_dir//bin/pins2lts-seq() [0x41c13d]
null
at fr.lip6.move.gal.application.LTSminRunner$1.run(LTSminRunner.java:130)
at java.lang.Thread.run(Thread.java:748)
Jun 06, 2017 3:05:17 AM fr.lip6.move.gal.itstools.ProcessController$1 run
WARNING: null
Jun 06, 2017 3:05:17 AM fr.lip6.move.gal.itstools.ProcessController forwardStream
WARNING: Stream closed
Jun 06, 2017 3:05:17 AM fr.lip6.move.gal.itstools.ProcessController forwardStream
WARNING: Stream closed

Sequence of Actions to be Executed by the VM

This is useful if one wants to reexecute the tool in the VM from the submitted image disk.

set -x
# this is for BenchKit: configuration of major elements for the test
export BK_INPUT="S_SwimmingPool-PT-08"
export BK_EXAMINATION="LTLCardinality"
export BK_TOOL="itstools"
export BK_RESULT_DIR="/tmp/BK_RESULTS/OUTPUTS"
export BK_TIME_CONFINEMENT="3600"
export BK_MEMORY_CONFINEMENT="16384"

# this is specific to your benchmark or test

export BIN_DIR="$HOME/BenchKit/bin"

# remove the execution directoty if it exists (to avoid increse of .vmdk images)
if [ -d execution ] ; then
rm -rf execution
fi

tar xzf /home/mcc/BenchKit/INPUTS/S_SwimmingPool-PT-08.tgz
mv S_SwimmingPool-PT-08 execution

# this is for BenchKit: explicit launching of the test

cd execution
echo "====================================================================="
echo " Generated by BenchKit 2-3253"
echo " Executing tool itstools"
echo " Input is S_SwimmingPool-PT-08, examination is LTLCardinality"
echo " Time confinement is $BK_TIME_CONFINEMENT seconds"
echo " Memory confinement is 16384 MBytes"
echo " Number of cores is 4"
echo " Run identifier is r160-ebro-149443467200176"
echo "====================================================================="
echo
echo "--------------------"
echo "content from stdout:"
echo
echo "=== Data for post analysis generated by BenchKit (invocation template)"
echo
if [ "LTLCardinality" = "UpperBounds" ] ; then
echo "The expected result is a vector of positive values"
echo NUM_VECTOR
elif [ "LTLCardinality" != "StateSpace" ] ; then
echo "The expected result is a vector of booleans"
echo BOOL_VECTOR
else
echo "no data necessary for post analysis"
fi
echo
if [ -f "LTLCardinality.txt" ] ; then
echo "here is the order used to build the result vector(from text file)"
for x in $(grep Property LTLCardinality.txt | cut -d ' ' -f 2 | sort -u) ; do
echo "FORMULA_NAME $x"
done
elif [ -f "LTLCardinality.xml" ] ; then # for cunf (txt files deleted;-)
echo echo "here is the order used to build the result vector(from xml file)"
for x in $(grep '' LTLCardinality.xml | cut -d '>' -f 2 | cut -d '<' -f 1 | sort -u) ; do
echo "FORMULA_NAME $x"
done
fi
echo
echo "=== Now, execution of the tool begins"
echo
echo -n "BK_START "
date -u +%s%3N
echo
timeout -s 9 $BK_TIME_CONFINEMENT bash -c "/home/mcc/BenchKit/BenchKit_head.sh 2> STDERR ; echo ; echo -n \"BK_STOP \" ; date -u +%s%3N"
if [ $? -eq 137 ] ; then
echo
echo "BK_TIME_CONFINEMENT_REACHED"
fi
echo
echo "--------------------"
echo "content from stderr:"
echo
cat STDERR ;