fond
Model Checking Contest 2019
9th edition, Prague, Czech Republic, April 7, 2019 (TOOLympics)
Execution of r198-smll-155272319500362
Last Updated
Apr 15, 2019

About the Execution of ITS-Tools.M for PolyORBLF-PT-S06J04T06

Execution Summary
Max Memory
Used (MB)
Time wait (ms) CPU Usage (ms) I/O Wait (ms) Computed Result Execution
Status
15919.180 3045686.00 3073042.00 10688.10 [undef] Cannot compute

Execution Chart

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

Trace from the execution

Formatting '/data/fkordon/mcc2019-input.r198-smll-155272319500362.qcow2', fmt=qcow2 size=4294967296 backing_file='/data/fkordon/mcc2019-input.qcow2' encryption=off cluster_size=65536 lazy_refcounts=off
Waiting for the VM to be ready (probing ssh)
....................
=====================================================================
Generated by BenchKit 2-3957
Executing tool itstoolsm
Input is PolyORBLF-PT-S06J04T06, examination is UpperBounds
Time confinement is 3600 seconds
Memory confinement is 16384 MBytes
Number of cores is 4
Run identifier is r198-smll-155272319500362
=====================================================================

--------------------
preparation of the directory to be used:
/home/mcc/execution
total 15M
-rw-r--r-- 1 mcc users 8.6K Feb 12 09:28 CTLCardinality.txt
-rw-r--r-- 1 mcc users 32K Feb 12 09:28 CTLCardinality.xml
-rw-r--r-- 1 mcc users 15K Feb 8 09:55 CTLFireability.txt
-rw-r--r-- 1 mcc users 54K Feb 8 09:55 CTLFireability.xml
-rw-r--r-- 1 mcc users 4.0K Mar 10 17:31 GenericPropertiesDefinition.xml
-rw-r--r-- 1 mcc users 109 Feb 24 15:05 GlobalProperties.txt
-rw-r--r-- 1 mcc users 347 Feb 24 15:05 GlobalProperties.xml
-rw-r--r-- 1 mcc users 5.6K Feb 5 00:38 LTLCardinality.txt
-rw-r--r-- 1 mcc users 18K Feb 5 00:38 LTLCardinality.xml
-rw-r--r-- 1 mcc users 28K Feb 4 22:39 LTLFireability.txt
-rw-r--r-- 1 mcc users 89K Feb 4 22:39 LTLFireability.xml
-rw-r--r-- 1 mcc users 6.5K Feb 4 12:54 ReachabilityCardinality.txt
-rw-r--r-- 1 mcc users 24K Feb 4 12:54 ReachabilityCardinality.xml
-rw-r--r-- 1 mcc users 6.4K Feb 1 08:25 ReachabilityFireability.txt
-rw-r--r-- 1 mcc users 27K Feb 1 08:25 ReachabilityFireability.xml
-rw-r--r-- 1 mcc users 2.5K Feb 4 22:24 UpperBounds.txt
-rw-r--r-- 1 mcc users 5.2K Feb 4 22:24 UpperBounds.xml
-rw-r--r-- 1 mcc users 5 Jan 29 09:34 equiv_col

-rw-r--r-- 1 mcc users 10 Jan 29 09:34 instance
-rw-r--r-- 1 mcc users 6 Jan 29 09:34 iscolored
-rw-r--r-- 1 mcc users 15M Mar 10 17:31 model.pnml

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

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

The expected result is a vector of positive values
NUM_VECTOR

here is the order used to build the result vector(from text file)
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-00
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-01
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-02
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-03
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-04
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-05
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-06
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-07
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-08
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-09
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-10
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-11
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-12
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-13
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-14
FORMULA_NAME PolyORBLF-PT-S06J04T06-UpperBounds-15

=== Now, execution of the tool begins

BK_START 1553951159604

Running greatSPN : CommandLine [args=[/home/mcc/BenchKit//greatspn//bin/pinvar, /home/mcc/execution/gspn], workingDir=/home/mcc/execution]
P-invariant computation with GreatSPN timed out. Skipping.
Running greatSPN : CommandLine [args=[/home/mcc/BenchKit//greatspn//bin/RGMEDD2, /home/mcc/execution/gspn, -META, -varord-only], workingDir=/home/mcc/execution]
Run of greatSPN captured in /home/mcc/execution/outPut.txt
Using order generated by GreatSPN with heuristic : META
Invoking ITS tools like this :CommandLine [args=[/home/mcc/BenchKit/itstools/plugins/fr.lip6.move.gal.itstools.binaries_1.0.0.201903251645/bin/its-reach-linux64, --gc-threshold, 2000000, --quiet, -i, /home/mcc/execution/UpperBounds.pnml.gal, -t, CGAL, -reachable-file, UpperBounds.prop, --nowitness, --load-order, /home/mcc/execution/model.ord], workingDir=/home/mcc/execution]

its-reach command run as :

/home/mcc/BenchKit/itstools/plugins/fr.lip6.move.gal.itstools.binaries_1.0.0.201903251645/bin/its-reach-linux64 --gc-threshold 2000000 --quiet -i /home/mcc/execution/UpperBounds.pnml.gal -t CGAL -reachable-file UpperBounds.prop --nowitness --load-order /home/mcc/execution/model.ord
Successfully loaded order from file /home/mcc/execution/model.ord
Loading property file UpperBounds.prop.
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-00 with value :cIdleTasks
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-01 with value :Abort_Check_Sources_E_2+Abort_Check_Sources_E_3+Abort_Check_Sources_E_4+Abort_Check_Sources_E_5+Abort_Check_Sources_E_6+Abort_Check_Sources_E_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-02 with value :EnablePollingB_4+EnablePollingB_3+EnablePollingB_5+EnablePollingB_6+EnablePollingB_2+EnablePollingB_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-03 with value :P_1159_3+P_1159_2+P_1159_5+P_1159_4+P_1159_6+P_1159_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-04 with value :Check_Sources_B_1+Check_Sources_B_2+Check_Sources_B_3+Check_Sources_B_4+Check_Sources_B_5+Check_Sources_B_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-05 with value :Check_Sources_E_3+Check_Sources_E_4+Check_Sources_E_5+Check_Sources_E_6+Check_Sources_E_1+Check_Sources_E_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-06 with value :P_1113_5+P_1113_4+P_1113_1+P_1113_2+P_1113_3+P_1113_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-07 with value :P_1155_6+P_1155_1+P_1155_5+P_1155_4+P_1155_3+P_1155_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-08 with value :NotifyEventJobCompletedE_3
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-09 with value :NotifyEventEndOfCheckSourcesB_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-10 with value :NotifyEventJobCompletedE_3
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-11 with value :EnablePollingB_4
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-12 with value :NotifyEventJobQueuedE_5
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-13 with value :ModifiedSrc_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-14 with value :P_2579_2_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-15 with value :P_1119_4_2
Invoking ITS tools like this :CommandLine [args=[/home/mcc/BenchKit/itstools/plugins/fr.lip6.move.gal.itstools.binaries_1.0.0.201903251645/bin/its-reach-linux64, --gc-threshold, 2000000, --quiet, -i, /home/mcc/execution/UpperBounds.pnml.gal, -t, CGAL, -reachable-file, UpperBounds.prop, --nowitness], workingDir=/home/mcc/execution]

its-reach command run as :

/home/mcc/BenchKit/itstools/plugins/fr.lip6.move.gal.itstools.binaries_1.0.0.201903251645/bin/its-reach-linux64 --gc-threshold 2000000 --quiet -i /home/mcc/execution/UpperBounds.pnml.gal -t CGAL -reachable-file UpperBounds.prop --nowitness
Loading property file UpperBounds.prop.
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-00 with value :cIdleTasks
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-01 with value :Abort_Check_Sources_E_2+Abort_Check_Sources_E_3+Abort_Check_Sources_E_4+Abort_Check_Sources_E_5+Abort_Check_Sources_E_6+Abort_Check_Sources_E_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-02 with value :EnablePollingB_4+EnablePollingB_3+EnablePollingB_5+EnablePollingB_6+EnablePollingB_2+EnablePollingB_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-03 with value :P_1159_3+P_1159_2+P_1159_5+P_1159_4+P_1159_6+P_1159_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-04 with value :Check_Sources_B_1+Check_Sources_B_2+Check_Sources_B_3+Check_Sources_B_4+Check_Sources_B_5+Check_Sources_B_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-05 with value :Check_Sources_E_3+Check_Sources_E_4+Check_Sources_E_5+Check_Sources_E_6+Check_Sources_E_1+Check_Sources_E_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-06 with value :P_1113_5+P_1113_4+P_1113_1+P_1113_2+P_1113_3+P_1113_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-07 with value :P_1155_6+P_1155_1+P_1155_5+P_1155_4+P_1155_3+P_1155_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-08 with value :NotifyEventJobCompletedE_3
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-09 with value :NotifyEventEndOfCheckSourcesB_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-10 with value :NotifyEventJobCompletedE_3
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-11 with value :EnablePollingB_4
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-12 with value :NotifyEventJobQueuedE_5
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-13 with value :ModifiedSrc_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-14 with value :P_2579_2_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-15 with value :P_1119_4_2
Invoking ITS tools like this :CommandLine [args=[/home/mcc/BenchKit/itstools/plugins/fr.lip6.move.gal.itstools.binaries_1.0.0.201903251645/bin/its-reach-linux64, --gc-threshold, 2000000, --quiet, -i, /home/mcc/execution/UpperBounds.pnml.gal, -t, CGAL, -reachable-file, UpperBounds.prop, --nowitness], workingDir=/home/mcc/execution]

its-reach command run as :

/home/mcc/BenchKit/itstools/plugins/fr.lip6.move.gal.itstools.binaries_1.0.0.201903251645/bin/its-reach-linux64 --gc-threshold 2000000 --quiet -i /home/mcc/execution/UpperBounds.pnml.gal -t CGAL -reachable-file UpperBounds.prop --nowitness
Loading property file UpperBounds.prop.
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-00 with value :cIdleTasks
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-01 with value :Abort_Check_Sources_E_2+Abort_Check_Sources_E_3+Abort_Check_Sources_E_4+Abort_Check_Sources_E_5+Abort_Check_Sources_E_6+Abort_Check_Sources_E_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-02 with value :EnablePollingB_4+EnablePollingB_3+EnablePollingB_5+EnablePollingB_6+EnablePollingB_2+EnablePollingB_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-03 with value :P_1159_3+P_1159_2+P_1159_5+P_1159_4+P_1159_6+P_1159_1
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-04 with value :Check_Sources_B_1+Check_Sources_B_2+Check_Sources_B_3+Check_Sources_B_4+Check_Sources_B_5+Check_Sources_B_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-05 with value :Check_Sources_E_3+Check_Sources_E_4+Check_Sources_E_5+Check_Sources_E_6+Check_Sources_E_1+Check_Sources_E_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-06 with value :P_1113_5+P_1113_4+P_1113_1+P_1113_2+P_1113_3+P_1113_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-07 with value :P_1155_6+P_1155_1+P_1155_5+P_1155_4+P_1155_3+P_1155_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-08 with value :NotifyEventJobCompletedE_3
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-09 with value :NotifyEventEndOfCheckSourcesB_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-10 with value :NotifyEventJobCompletedE_3
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-11 with value :EnablePollingB_4
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-12 with value :NotifyEventJobQueuedE_5
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-13 with value :ModifiedSrc_2
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-14 with value :P_2579_2_6
Read [bounds] property : PolyORBLF-PT-S06J04T06-UpperBounds-15 with value :P_1119_4_2

BK_STOP 1553954205290

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

+ export BINDIR=/home/mcc/BenchKit/
+ BINDIR=/home/mcc/BenchKit/
++ pwd
+ export MODEL=/home/mcc/execution
+ MODEL=/home/mcc/execution
+ [[ UpperBounds = StateSpace ]]
+ /home/mcc/BenchKit//runeclipse.sh /home/mcc/execution UpperBounds -its -ltsminpath /home/mcc/BenchKit//lts_install_dir/ -greatspnpath /home/mcc/BenchKit//greatspn/ -order META -manyOrder -smt
+ ulimit -s 65536
+ [[ -z '' ]]
+ export LTSMIN_MEM_SIZE=8589934592
+ LTSMIN_MEM_SIZE=8589934592
+ /home/mcc/BenchKit//itstools/its-tools -data /home/mcc/execution/workspace -pnfolder /home/mcc/execution -examination UpperBounds -z3path /home/mcc/BenchKit//z3/bin/z3 -yices2path /home/mcc/BenchKit//yices/bin/yices -its -ltsminpath /home/mcc/BenchKit//lts_install_dir/ -greatspnpath /home/mcc/BenchKit//greatspn/ -order META -manyOrder -smt -vmargs -Dosgi.locking=none -Declipse.stateSaveDelayInterval=-1 -Dosgi.configuration.area=/tmp/.eclipse -Xss8m -Xms40m -Xmx8192m -Dfile.encoding=UTF-8 -Dosgi.requiredJavaVersion=1.6
Mar 30, 2019 1:06:02 PM fr.lip6.move.gal.application.Application start
INFO: Running its-tools with arguments : [-pnfolder, /home/mcc/execution, -examination, UpperBounds, -z3path, /home/mcc/BenchKit//z3/bin/z3, -yices2path, /home/mcc/BenchKit//yices/bin/yices, -its, -ltsminpath, /home/mcc/BenchKit//lts_install_dir/, -greatspnpath, /home/mcc/BenchKit//greatspn/, -order, META, -manyOrder, -smt]
Mar 30, 2019 1:06:02 PM fr.lip6.move.gal.application.MccTranslator transformPNML
INFO: Parsing pnml file : /home/mcc/execution/model.pnml
Mar 30, 2019 1:06:03 PM fr.lip6.move.gal.nupn.PTNetReader loadFromXML
INFO: Load time of PNML (sax parser for PT used): 917 ms
Mar 30, 2019 1:06:03 PM fr.lip6.move.gal.pnml.togal.PTGALTransformer handlePage
INFO: Transformed 632 places.
Mar 30, 2019 1:06:04 PM fr.lip6.move.gal.pnml.togal.PTGALTransformer handlePage
INFO: Transformed 10500 transitions.
Mar 30, 2019 1:06:09 PM fr.lip6.move.gal.instantiate.GALRewriter flatten
INFO: Flatten gal took : 3292 ms
Mar 30, 2019 1:06:11 PM fr.lip6.move.gal.semantics.DeterministicNextBuilder getDeterministicNext
INFO: Input system was already deterministic with 10500 transitions.
Mar 30, 2019 1:06:11 PM fr.lip6.move.gal.application.StructuralToGreatSPN handlePage
INFO: Transformed 632 places.
Mar 30, 2019 1:06:11 PM fr.lip6.move.gal.application.StructuralToGreatSPN handlePage
INFO: Transformed 10500 transitions.
Mar 30, 2019 1:06:42 PM fr.lip6.move.serialization.SerializationUtil systemToFile
INFO: Time to serialize gal into /home/mcc/execution/UpperBounds.pnml.gal : 317 ms
Mar 30, 2019 1:06:42 PM fr.lip6.move.serialization.SerializationUtil serializePropertiesForITSTools
INFO: Time to serialize properties into /home/mcc/execution/UpperBounds.prop : 1 ms
ITS-tools command line returned an error code 137
Mar 30, 2019 1:25:06 PM fr.lip6.move.gal.instantiate.GALRewriter flatten
INFO: Flatten gal took : 2704 ms
Mar 30, 2019 1:25:06 PM fr.lip6.move.serialization.SerializationUtil systemToFile
INFO: Time to serialize gal into /home/mcc/execution/UpperBounds.pnml.gal : 153 ms
Mar 30, 2019 1:25:06 PM fr.lip6.move.serialization.SerializationUtil serializePropertiesForITSTools
INFO: Time to serialize properties into /home/mcc/execution/UpperBounds.prop : 2 ms
ITS-tools command line returned an error code 137
Mar 30, 2019 1:42:18 PM fr.lip6.move.gal.instantiate.GALRewriter flatten
INFO: Flatten gal took : 2000 ms
Mar 30, 2019 1:42:18 PM fr.lip6.move.serialization.SerializationUtil systemToFile
INFO: Time to serialize gal into /home/mcc/execution/UpperBounds.pnml.gal : 83 ms
Mar 30, 2019 1:42:18 PM fr.lip6.move.serialization.SerializationUtil serializePropertiesForITSTools
INFO: Time to serialize properties into /home/mcc/execution/UpperBounds.prop : 0 ms
ITS-tools command line returned an error code 137

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="PolyORBLF-PT-S06J04T06"
export BK_EXAMINATION="UpperBounds"
export BK_TOOL="itstoolsm"
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

# this is for BenchKit: explicit launching of the test
echo "====================================================================="
echo " Generated by BenchKit 2-3957"
echo " Executing tool itstoolsm"
echo " Input is PolyORBLF-PT-S06J04T06, examination is UpperBounds"
echo " Time confinement is $BK_TIME_CONFINEMENT seconds"
echo " Memory confinement is 16384 MBytes"
echo " Number of cores is 4"
echo " Run identifier is r198-smll-155272319500362"
echo "====================================================================="
echo
echo "--------------------"
echo "preparation of the directory to be used:"

tar xzf /home/mcc/BenchKit/INPUTS/PolyORBLF-PT-S06J04T06.tgz
mv PolyORBLF-PT-S06J04T06 execution
cd execution
if [ "UpperBounds" = "GlobalProperties" ] ; then
rm -f GenericPropertiesVerdict.xml
fi
if [ "UpperBounds" = "UpperBounds" ] ; then
rm -f GenericPropertiesVerdict.xml
fi
pwd
ls -lh

echo
echo "--------------------"
echo "content from stdout:"
echo
echo "=== Data for post analysis generated by BenchKit (invocation template)"
echo
if [ "UpperBounds" = "UpperBounds" ] ; then
echo "The expected result is a vector of positive values"
echo NUM_VECTOR
elif [ "UpperBounds" != "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 "UpperBounds.txt" ] ; then
echo "here is the order used to build the result vector(from text file)"
for x in $(grep Property UpperBounds.txt | cut -d ' ' -f 2 | sort -u) ; do
echo "FORMULA_NAME $x"
done
elif [ -f "UpperBounds.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 '' UpperBounds.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 ;