Merge branch 'master' of gitlab.science.ru.nl:mlubbers/mc1516the
[mc1516the.git] / uppaal / 2.xml
index 862ab1e..dcbd6c3 100644 (file)
@@ -3,15 +3,19 @@
 <nta>\r
        <declaration>// Place global declarations here.
 // Intermediate
-const int N = 13;
+//const int N=13;
 // Advanced
-//const int N = 7
+//const int N = 7;
+//hard from website 1
+const int N=13;
+//hard from website 2
+//const int N=9;
 
-typedef int[0,N-1] id_c;
+typedef int[0, N-1] id_c;
 
 broadcast chan up[N], down[N], left[N], right[N], start, leftRed, rightRed;
 
-chan reg;
+chan reg, finish;
 
 bool grid[6][6];</declaration>\r
        <template>\r
@@ -47,18 +51,22 @@ void register() {
                <transition>\r
                        <source ref="id2"/>\r
                        <target ref="id2"/>\r
-                       <label kind="guard" x="-288" y="-68">x&gt;0 &amp;&amp; !grid[x-1][y]</label>\r
-                       <label kind="synchronisation" x="-288" y="-51">down[id]!</label>\r
-                       <label kind="assignment" x="-288" y="-34">x:=x-1</label>\r
+                       <label kind="guard" x="-280" y="8">x&gt;0 &amp;&amp; !grid[x-1][y]</label>\r
+                       <label kind="synchronisation" x="-153" y="-42">left[id]!</label>\r
+                       <label kind="assignment" x="-340" y="34">grid[x+length-1][y]:=false,
+grid[x-1][y]:=true,
+x:=x-1</label>\r
                        <nail x="-306" y="8"/>\r
                        <nail x="-136" y="0"/>\r
                </transition>\r
                <transition>\r
                        <source ref="id2"/>\r
                        <target ref="id2"/>\r
-                       <label kind="guard" x="-306" y="-204">x+length &lt; 6 &amp;&amp; !grid[x+length][y]</label>\r
-                       <label kind="synchronisation" x="-314" y="-153">up[id]!</label>\r
-                       <label kind="assignment" x="-306" y="-178">x:=x+1</label>\r
+                       <label kind="guard" x="-306" y="-263">x+length &lt; 6 &amp;&amp; !grid[x+length][y]</label>\r
+                       <label kind="synchronisation" x="-170" y="-170">right[id]!</label>\r
+                       <label kind="assignment" x="-331" y="-229">grid[x][y]:=false,
+grid[x+length][y]:=true,
+x:=x+1</label>\r
                        <nail x="-323" y="-102"/>\r
                        <nail x="-195" y="-178"/>\r
                        <nail x="-110" y="-102"/>\r
@@ -85,7 +93,7 @@ void register() {
                <transition>\r
                        <source ref="id3"/>\r
                        <target ref="id5"/>\r
-                       <label kind="synchronisation" x="-228" y="-72">start?</label>\r
+                       <label kind="synchronisation" x="-246" y="-59">start?</label>\r
                </transition>\r
                <transition>\r
                        <source ref="id4"/>\r
@@ -97,44 +105,57 @@ void register() {
                <transition>\r
                        <source ref="id5"/>\r
                        <target ref="id5"/>\r
-                       <label kind="guard" x="-135" y="8">y&gt;0 &amp;&amp; !grid[x][y-1]</label>\r
-                       <label kind="synchronisation" x="-135" y="25">left[id]!</label>\r
-                       <label kind="assignment" x="-135" y="42">y:=y-1</label>\r
+                       <label kind="guard" x="-153" y="153">y&gt;0 &amp;&amp; !grid[x][y-1]</label>\r
+                       <label kind="synchronisation" x="-153" y="119">down[id]!</label>\r
+                       <label kind="assignment" x="-153" y="51">grid[x][y-1]:=true,
+grid[x][y+length-1]:=false,
+y:=y-1</label>\r
                        <nail x="-153" y="42"/>\r
                        <nail x="-34" y="42"/>\r
                </transition>\r
                <transition>\r
                        <source ref="id5"/>\r
                        <target ref="id5"/>\r
-                       <label kind="guard" x="-160" y="-102">y+length &lt; 6 &amp;&amp; !grid[x][y+length]</label>\r
-                       <label kind="synchronisation" x="-160" y="-85">right[id]!</label>\r
-                       <label kind="assignment" x="-160" y="-68">y:=y+1</label>\r
+                       <label kind="guard" x="-161" y="-204">y+length &lt; 6 &amp;&amp; !grid[x][y+length]</label>\r
+                       <label kind="synchronisation" x="-161" y="-178">up[id]!</label>\r
+                       <label kind="assignment" x="-161" y="-153">grid[x][y+length]:=true,
+grid[x][y]:=false,
+y:=y+1</label>\r
                        <nail x="-178" y="-102"/>\r
                        <nail x="-34" y="-102"/>\r
                </transition>\r
        </template>\r
        <template>\r
                <name>Player</name>\r
-               <declaration>int[0,N] registered;</declaration>\r
-               <location id="id6" x="-680" y="-246">\r
+               <declaration>int[0,N] registered;
+bool done = 0;</declaration>\r
+               <location id="id6" x="-476" y="-459">\r
                </location>\r
-               <location id="id7" x="-799" y="-246">\r
+               <location id="id7" x="-663" y="-450">\r
                </location>\r
-               <init ref="id7"/>\r
+               <location id="id8" x="-782" y="-450">\r
+               </location>\r
+               <init ref="id8"/>\r
                <transition>\r
                        <source ref="id7"/>\r
                        <target ref="id6"/>\r
-                       <label kind="guard" x="-781" y="-280">registered == N</label>\r
-                       <label kind="synchronisation" x="-781" y="-263">start!</label>\r
+                       <label kind="synchronisation" x="-612" y="-476">finish?</label>\r
+                       <label kind="assignment" x="-645" y="-454">done := 1</label>\r
                </transition>\r
                <transition>\r
-                       <source ref="id7"/>\r
+                       <source ref="id8"/>\r
                        <target ref="id7"/>\r
-                       <label kind="synchronisation" x="-875" y="-365">reg?</label>\r
-                       <label kind="assignment" x="-926" y="-382">registered := registered+1</label>\r
-                       <nail x="-892" y="-263"/>\r
-                       <nail x="-833" y="-331"/>\r
-                       <nail x="-765" y="-314"/>\r
+                       <label kind="guard" x="-764" y="-484">registered == N</label>\r
+                       <label kind="synchronisation" x="-764" y="-467">start!</label>\r
+               </transition>\r
+               <transition>\r
+                       <source ref="id8"/>\r
+                       <target ref="id8"/>\r
+                       <label kind="synchronisation" x="-833" y="-561">reg?</label>\r
+                       <label kind="assignment" x="-909" y="-578">registered := registered+1</label>\r
+                       <nail x="-875" y="-467"/>\r
+                       <nail x="-816" y="-535"/>\r
+                       <nail x="-748" y="-518"/>\r
                </transition>\r
        </template>\r
        <template>\r
@@ -144,47 +165,100 @@ void register() {
     grid[x][3] = true;
     grid[x+1][3] = true;
 }</declaration>\r
-               <location id="id8" x="51" y="-59">\r
+               <location id="id9" x="42" y="136">\r
+                       <urgent/>\r
+               </location>\r
+               <location id="id10" x="59" y="-238">\r
+                       <urgent/>\r
+               </location>\r
+               <location id="id11" x="493" y="-51">\r
+               </location>\r
+               <location id="id12" x="51" y="-59">\r
                </location>\r
-               <location id="id9" x="-93" y="-68">\r
+               <location id="id13" x="-93" y="-68">\r
                </location>\r
-               <location id="id10" x="-204" y="-68">\r
+               <location id="id14" x="-204" y="-68">\r
                        <urgent/>\r
                </location>\r
-               <init ref="id10"/>\r
+               <branchpoint id="id15" x="187" y="-85">\r
+               </branchpoint>\r
+               <init ref="id14"/>\r
                <transition>\r
-                       <source ref="id8"/>\r
-                       <target ref="id8"/>\r
-                       <label kind="guard" x="-7" y="-42">x &gt; 0 &amp;&amp; grid[x-1][3]</label>\r
-                       <label kind="synchronisation" x="-7" y="-25">leftRed!</label>\r
-                       <label kind="assignment" x="-7" y="-8">x := x-1, grid[x+1][3] := false, grid[x-1][3] := true</label>\r
-                       <nail x="-25" y="42"/>\r
-                       <nail x="178" y="51"/>\r
+                       <source ref="id9"/>\r
+                       <target ref="id12"/>\r
+                       <label kind="guard" x="67" y="38">x &lt;= 0 || grid[x-1][3]</label>\r
+                       <nail x="93" y="8"/>\r
                </transition>\r
                <transition>\r
-                       <source ref="id8"/>\r
-                       <target ref="id8"/>\r
-                       <label kind="guard" x="1" y="-135">x+2 &lt; 6 &amp;&amp; grid[x+2][3]</label>\r
-                       <label kind="synchronisation" x="1" y="-118">rightRed!</label>\r
-                       <label kind="assignment" x="1" y="-101">x := x+1, grid[x][3] := false, grid[x+2][3] := true</label>\r
-                       <nail x="-17" y="-144"/>\r
-                       <nail x="144" y="-136"/>\r
+                       <source ref="id10"/>\r
+                       <target ref="id12"/>\r
+                       <label kind="guard" x="93" y="-187">x+2 &gt;= 6 || grid[x+2][3]</label>\r
+                       <nail x="102" y="-127"/>\r
+               </transition>\r
+               <transition>\r
+                       <source ref="id10"/>\r
+                       <target ref="id12"/>\r
+                       <label kind="guard" x="-136" y="-161">x+2 &lt; 6 &amp;&amp; !grid[x+2][3]</label>\r
+                       <label kind="synchronisation" x="-68" y="-144">rightRed!</label>\r
+                       <label kind="assignment" x="-85" y="-212">grid[x][3]:=false,
+grid[x+2][3]:=true,
+x:=x+1</label>\r
                </transition>\r
                <transition>\r
                        <source ref="id9"/>\r
-                       <target ref="id8"/>\r
-                       <label kind="synchronisation" x="-75" y="-80">start?</label>\r
+                       <target ref="id12"/>\r
+                       <label kind="guard" x="-144" y="-25">x &gt; 0 &amp;&amp; !grid[x-1][3]</label>\r
+                       <label kind="synchronisation" x="-93" y="0">leftRed!</label>\r
+                       <label kind="assignment" x="-144" y="25">grid[x+1][3]:=false,
+grid[x-1][3]:=true,
+x:=x-1</label>\r
                </transition>\r
                <transition>\r
-                       <source ref="id10"/>\r
+                       <source ref="id15"/>\r
                        <target ref="id9"/>\r
+                       <label kind="probability" x="161" y="-34">1</label>\r
+               </transition>\r
+               <transition>\r
+                       <source ref="id15"/>\r
+                       <target ref="id10"/>\r
+                       <label kind="probability" x="178" y="-127">3</label>\r
+               </transition>\r
+               <transition>\r
+                       <source ref="id12"/>\r
+                       <target ref="id15"/>\r
+               </transition>\r
+               <transition>\r
+                       <source ref="id12"/>\r
+                       <target ref="id11"/>\r
+                       <label kind="guard" x="416" y="-93">x == 4</label>\r
+                       <label kind="synchronisation" x="416" y="-76">finish!</label>\r
+               </transition>\r
+               <transition>\r
+                       <source ref="id13"/>\r
+                       <target ref="id12"/>\r
+                       <label kind="synchronisation" x="-75" y="-80">start?</label>\r
+               </transition>\r
+               <transition>\r
+                       <source ref="id14"/>\r
+                       <target ref="id13"/>\r
                        <label kind="synchronisation" x="-186" y="-85">reg!</label>\r
                        <label kind="assignment" x="-186" y="-68">register()</label>\r
                </transition>\r
        </template>\r
        <system>// Place template instantiations here.
 
+
+
+//easy test puzzle
+/*
+RED = RedCar(0,2);
+V1 = VertCar(2, 1, 4, 3);
+V2 = VertCar(3, 2, 5, 2);
+system RED, V1, V2, Player;
+*/
+
 // Intermediate puzzle
+
 H1 = HorzCar(2, 0, 0, 5);
 H2 = HorzCar(2, 1, 2, 5);
 V3 = VertCar(2, 2, 4, 4);
@@ -192,13 +266,14 @@ V4 = VertCar(2, 3, 2, 3);
 V5 = VertCar(3, 4, 5, 2);
 V6 = VertCar(2, 5, 1, 3);
 H7 = HorzCar(2, 6, 3, 4);
-H8 = HorzCar(2, 7, 3, 2);
+RED = RedCar(7, 2); //RED
 V9 = VertCar(3, 8, 0, 0);
 HA = HorzCar(2, 9, 1, 0);
 VB = VertCar(2, 10, 3, 0);
 HC = HorzCar(2, 11, 4, 1);
 HD = HorzCar(2, 12, 4, 0);
-system H1, H2, V3, V4, V5, V6, H7, H8, V9, HA, VB, HC, HD, Player;
+system H1, H2, V3, V4, V5, V6, H7, RED, V9, HA, VB, HC, HD, Player;
+
 
 // Advanced puzzle
 /*
@@ -206,15 +281,50 @@ H1 = HorzCar(2, 0, 0, 5);
 V2 = VertCar(2, 1, 2, 4);
 V3 = VertCar(3, 2, 3, 3);
 V4 = VertCar(3, 3, 0, 2);
-H5 = HorzCar(2, 4, 1, 3);
+RED = RedCar(4, 1);
 H6 = HorzCar(3, 5, 1, 2);
 H7 = HorzCar(3, 6, 3, 0);
-system H1, V2, V3, V4, H5, H6, H7
+system H1, V2, V3, V4, RED, H6, H7, Player;
 */
 
-// List one or more processes to be composed into a system.
+//Hard from website 1
+//Can not be solved
+/*
+V1 = VertCar(2, 0, 0, 3);
+V2 = VertCar(2, 1, 1, 0);
+V3 = VertCar(2, 2, 2, 1);
+V4 = VertCar(2, 3, 3, 4);
+V5 = VertCar(3, 4, 4, 3);
+V6 = VertCar(3, 5, 5, 3);
+H7 = HorzCar(2, 6, 0, 2);
+H8 = HorzCar(3, 7, 0, 5);
+H85= HorzCar(3,12, 1, 4); 
+H9 = HorzCar(2, 8, 2, 0);
+RED = RedCar(9, 2);
+HB = HorzCar(2,10, 4, 0);
+HC = HorzCar(2,11, 4, 1);
+system V1, V2, V3, V4, V5, V6, H7, H8, H85, H9, RED, HB, HC, Player;
+*/
 
-    </system>\r
+//Hard from website 2
+/*
+V1 = VertCar(2, 0, 0, 0);
+V2 = VertCar(3, 1, 2, 3);
+V3 = VertCar(3, 2, 3, 0);
+V4 = VertCar(3, 3, 5, 3);
+H5 = HorzCar(2, 4, 1, 1);
+RED = RedCar(5, 3);
+H7 = HorzCar(2, 6, 3, 5);
+H8 = HorzCar(2, 7, 4, 0);
+H9 = HorzCar(2, 8, 4, 2);
+system V1, V2, V3, V4, H5, RED, H7, H8, H9, Player;
+*/</system>\r
        <queries>\r
+               <query>\r
+                       <formula>E&lt;&gt; Player.done == 1\r
+                       </formula>\r
+                       <comment>\r
+                       </comment>\r
+               </query>\r
        </queries>\r
 </nta>\r