control_to_EPN.mvc 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824
  1. include "primitives.alh"
  2. include "modelling.alh"
  3. include "object_operations.alh"
  4. All_RAM Control2EPN {
  5. Composite schedule {
  6. {Contains} Failure failure {}
  7. {Contains} Success success {}
  8. {Contains} Atomic init_ports {
  9. LHS {}
  10. RHS {
  11. Post_Encapsulated_PetriNet/Place post_ports_00 {
  12. label = "00"
  13. value_name = $
  14. String function value(model : Element, name : String, mapping : Element):
  15. return "cmdDown"!
  16. $
  17. value_tokens = $
  18. Integer function value(model : Element, name : String, mapping : Element):
  19. return 0!
  20. $
  21. }
  22. Post_Encapsulated_PetriNet/Port post_ports_10 {
  23. label = "10"
  24. value_name = $
  25. String function value(model : Element, name : String, mapping : Element):
  26. return "cmdDown"!
  27. $
  28. }
  29. Post_Encapsulated_PetriNet/PortPlace (post_ports_10, post_ports_00) {
  30. label = "20"
  31. }
  32. Post_Encapsulated_PetriNet/Place post_ports_01 {
  33. label = "01"
  34. value_name = $
  35. String function value(model : Element, name : String, mapping : Element):
  36. return "cmdNeutral"!
  37. $
  38. value_tokens = $
  39. Integer function value(model : Element, name : String, mapping : Element):
  40. return 0!
  41. $
  42. }
  43. Post_Encapsulated_PetriNet/Port post_ports_11 {
  44. label = "11"
  45. value_name = $
  46. String function value(model : Element, name : String, mapping : Element):
  47. return "cmdNeutral"!
  48. $
  49. }
  50. Post_Encapsulated_PetriNet/PortPlace (post_ports_11, post_ports_01) {
  51. label = "21"
  52. }
  53. Post_Encapsulated_PetriNet/Place post_ports_02 {
  54. label = "02"
  55. value_name = $
  56. String function value(model : Element, name : String, mapping : Element):
  57. return "cmdUp"!
  58. $
  59. value_tokens = $
  60. Integer function value(model : Element, name : String, mapping : Element):
  61. return 0!
  62. $
  63. }
  64. Post_Encapsulated_PetriNet/Port post_ports_12 {
  65. label = "12"
  66. value_name = $
  67. String function value(model : Element, name : String, mapping : Element):
  68. return "cmdUp"!
  69. $
  70. }
  71. Post_Encapsulated_PetriNet/PortPlace (post_ports_12, post_ports_02) {
  72. label = "22"
  73. }
  74. Post_Encapsulated_PetriNet/Place post_ports_03 {
  75. label = "03"
  76. value_name = $
  77. String function value(model : Element, name : String, mapping : Element):
  78. return "objDetected"!
  79. $
  80. value_tokens = $
  81. Integer function value(model : Element, name : String, mapping : Element):
  82. return 0!
  83. $
  84. }
  85. Post_Encapsulated_PetriNet/Port post_ports_13 {
  86. label = "13"
  87. value_name = $
  88. String function value(model : Element, name : String, mapping : Element):
  89. return "objDetected"!
  90. $
  91. }
  92. Post_Encapsulated_PetriNet/PortPlace (post_ports_13, post_ports_03) {
  93. label = "23"
  94. }
  95. Post_Encapsulated_PetriNet/Place post_ports_04 {
  96. label = "04"
  97. value_name = $
  98. String function value(model : Element, name : String, mapping : Element):
  99. return "no_objDetected"!
  100. $
  101. value_tokens = $
  102. Integer function value(model : Element, name : String, mapping : Element):
  103. return 0!
  104. $
  105. }
  106. Post_Encapsulated_PetriNet/Port post_ports_14 {
  107. label = "14"
  108. value_name = $
  109. String function value(model : Element, name : String, mapping : Element):
  110. return "no_objDetected"!
  111. $
  112. }
  113. Post_Encapsulated_PetriNet/PortPlace (post_ports_14, post_ports_04) {
  114. label = "24"
  115. }
  116. Post_Encapsulated_PetriNet/Place post_ports_05 {
  117. label = "05"
  118. value_name = $
  119. String function value(model : Element, name : String, mapping : Element):
  120. return "up"!
  121. $
  122. value_tokens = $
  123. Integer function value(model : Element, name : String, mapping : Element):
  124. // Set the detected output based on the initial state
  125. Element states
  126. String state
  127. states = allInstances(model, "PW_Control/State")
  128. while (read_nr_out(states) > 0):
  129. state = set_pop(states)
  130. if (value_eq(read_attribute(model, state, "isInitial"), True)):
  131. if (read_type(model, state) == "PW_Control/Up"):
  132. return 1!
  133. else:
  134. return 0!
  135. $
  136. }
  137. Post_Encapsulated_PetriNet/Port post_ports_15 {
  138. label = "15"
  139. value_name = $
  140. String function value(model : Element, name : String, mapping : Element):
  141. return "up"!
  142. $
  143. }
  144. Post_Encapsulated_PetriNet/PortPlace (post_ports_15, post_ports_05) {
  145. label = "25"
  146. }
  147. Post_Encapsulated_PetriNet/Place post_ports_06 {
  148. label = "06"
  149. value_name = $
  150. String function value(model : Element, name : String, mapping : Element):
  151. return "neutral"!
  152. $
  153. value_tokens = $
  154. Integer function value(model : Element, name : String, mapping : Element):
  155. // Set the detected output based on the initial state
  156. Element states
  157. String state
  158. states = allInstances(model, "PW_Control/State")
  159. while (read_nr_out(states) > 0):
  160. state = set_pop(states)
  161. if (value_eq(read_attribute(model, state, "isInitial"), True)):
  162. if (read_type(model, state) == "PW_Control/Neutral"):
  163. return 1!
  164. else:
  165. return 0!
  166. $
  167. }
  168. Post_Encapsulated_PetriNet/Port post_ports_16 {
  169. label = "16"
  170. value_name = $
  171. String function value(model : Element, name : String, mapping : Element):
  172. return "neutral"!
  173. $
  174. }
  175. Post_Encapsulated_PetriNet/PortPlace (post_ports_16, post_ports_06) {
  176. label = "26"
  177. }
  178. Post_Encapsulated_PetriNet/Place post_ports_07 {
  179. label = "07"
  180. value_name = $
  181. String function value(model : Element, name : String, mapping : Element):
  182. return "down"!
  183. $
  184. value_tokens = $
  185. Integer function value(model : Element, name : String, mapping : Element):
  186. // Set the detected output based on the initial state
  187. Element states
  188. String state
  189. states = allInstances(model, "PW_Control/State")
  190. while (read_nr_out(states) > 0):
  191. state = set_pop(states)
  192. if (value_eq(read_attribute(model, state, "isInitial"), True)):
  193. if (read_type(model, state) == "PW_Control/Down"):
  194. return 1!
  195. else:
  196. return 0!
  197. $
  198. }
  199. Post_Encapsulated_PetriNet/Port post_ports_17 {
  200. label = "17"
  201. value_name = $
  202. String function value(model : Element, name : String, mapping : Element):
  203. return "down"!
  204. $
  205. }
  206. Post_Encapsulated_PetriNet/PortPlace (post_ports_17, post_ports_07) {
  207. label = "27"
  208. }
  209. Post_Encapsulated_PetriNet/Place post_ports_08 {
  210. label = "08"
  211. value_name = $
  212. String function value(model : Element, name : String, mapping : Element):
  213. return "interrupt"!
  214. $
  215. value_tokens = $
  216. Integer function value(model : Element, name : String, mapping : Element):
  217. return 0!
  218. $
  219. }
  220. Post_Encapsulated_PetriNet/Port post_ports_18 {
  221. label = "18"
  222. value_name = $
  223. String function value(model : Element, name : String, mapping : Element):
  224. return "interrupt"!
  225. $
  226. }
  227. Post_Encapsulated_PetriNet/PortPlace (post_ports_18, post_ports_08) {
  228. label = "28"
  229. }
  230. }
  231. }
  232. {Contains} ForAll create_states {
  233. LHS {
  234. Pre_PW_Control/State {
  235. label = "0"
  236. }
  237. }
  238. RHS {
  239. Post_PW_Control/State post_cs_0 {
  240. label = "0"
  241. }
  242. Post_Encapsulated_PetriNet/Place post_cs_1 {
  243. label = "1"
  244. value_name = $
  245. String function value(model : Element, name : String, mapping : Element):
  246. return read_attribute(model, mapping["0"], "name")!
  247. $
  248. value_tokens = $
  249. Integer function value(model : Element, name : String, mapping : Element):
  250. if (value_eq(read_attribute(model, mapping["0"], "isInitial"), True)):
  251. return 1!
  252. else:
  253. return 0!
  254. $
  255. }
  256. Post_CTRL2EPN_link (post_cs_0, post_cs_1) {
  257. label = "2"
  258. }
  259. }
  260. }
  261. {Contains} ForAll create_transitions {
  262. LHS {
  263. Pre_PW_Control/State pre_ct_0 {
  264. label = "0"
  265. }
  266. Pre_PW_Control/State pre_ct_1 {
  267. label = "1"
  268. }
  269. Pre_PW_Control/Transition pre_ct_2 (pre_ct_0, pre_ct_1) {
  270. label = "2"
  271. }
  272. Pre_Encapsulated_PetriNet/Place pre_ct_3 {
  273. label = "3"
  274. }
  275. Pre_Encapsulated_PetriNet/Place pre_ct_4 {
  276. label = "4"
  277. }
  278. Pre_CTRL2EPN_link (pre_ct_1, pre_ct_3) {
  279. label = "5"
  280. }
  281. Pre_CTRL2EPN_link (pre_ct_2, pre_ct_4) {
  282. label = "6"
  283. }
  284. Pre_Encapsulated_PetriNet/Place pre_ct_7 {
  285. label = "7"
  286. }
  287. Pre_Encapsulated_PetriNet/Port pre_ct_8 {
  288. label = "8"
  289. }
  290. Pre_Encapsulated_PetriNet/PortPlace (pre_ct_8, pre_ct_7) {
  291. label = "9"
  292. }
  293. Pre_Encapsulated_PetriNet/Place pre_ct_10 {
  294. label = "10"
  295. }
  296. Pre_Encapsulated_PetriNet/Port pre_ct_11 {
  297. label = "11"
  298. }
  299. Pre_Encapsulated_PetriNet/PortPlace (pre_ct_11, pre_ct_10) {
  300. label = "12"
  301. }
  302. Pre_Encapsulated_PetriNet/Place pre_ct_13 {
  303. label = "13"
  304. }
  305. Pre_Encapsulated_PetriNet/Port pre_ct_14 {
  306. label = "14"
  307. }
  308. Pre_Encapsulated_PetriNet/PortPlace (pre_ct_14, pre_ct_13) {
  309. label = "15"
  310. }
  311. constraint = $
  312. Boolean function constraint (host_model : Element, mapping : Element):
  313. // Check whether the bound primary places match with the state
  314. String type_0
  315. String type_1
  316. String type_2
  317. String name_9
  318. String name_12
  319. String name_15
  320. type_0 = read_type(host_model, mapping["0"])
  321. type_1 = read_type(host_model, mapping["1"])
  322. type_2 = read_type(host_model, mapping["2"])
  323. name_9 = read_attribute(host_model, mapping["9"], "name")
  324. name_12 = read_attribute(host_model, mapping["12"], "name")
  325. name_15 = read_attribute(host_model, mapping["15"], "name")
  326. // Source part
  327. if (type_0 == "PW_Control/Up"):
  328. if (name_9 != "up"):
  329. return False!
  330. elif (type_0 == "PW_Control/Neutral"):
  331. if (name_9 != "neutral"):
  332. return False!
  333. elif (type_0 == "PW_Control/Down"):
  334. if (name_9 != "down"):
  335. return False!
  336. // Target part
  337. if (type_1 == "PW_Control/Up"):
  338. if (name_12 != "up"):
  339. return False!
  340. elif (type_1 == "PW_Control/Neutral"):
  341. if (name_12 != "neutral"):
  342. return False!
  343. elif (type_1 == "PW_Control/Down"):
  344. if (name_12 != "down"):
  345. return False!
  346. // Link part
  347. if (type_2 == "PW_Control/UpPressed"):
  348. if (name_15 != "cmdUp"):
  349. return False!
  350. elif (type_2 == "PW_Control/NonePressed"):
  351. if (name_15 != "cmdNeutral"):
  352. return False!
  353. elif (type_2 == "PW_Control/DownPressed"):
  354. if (name_15 != "cmdDown"):
  355. return False!
  356. // All passed, so OK!
  357. return True!
  358. $
  359. }
  360. RHS {
  361. Post_PW_Control/State post_ct_0 {
  362. label = "0"
  363. }
  364. Post_PW_Control/State post_ct_1 {
  365. label = "1"
  366. }
  367. Post_PW_Control/Transition post_ct_2 (post_ct_0, post_ct_1) {
  368. label = "2"
  369. }
  370. Post_Encapsulated_PetriNet/Place post_ct_3 {
  371. label = "3"
  372. }
  373. Post_Encapsulated_PetriNet/Place post_ct_4 {
  374. label = "4"
  375. }
  376. Post_CTRL2EPN_link (post_ct_0, post_ct_3) {
  377. label = "5"
  378. }
  379. Post_CTRL2EPN_link (post_ct_1, post_ct_4) {
  380. label = "6"
  381. }
  382. Post_Encapsulated_PetriNet/Place post_ct_7 {
  383. label = "7"
  384. }
  385. Post_Encapsulated_PetriNet/Port post_ct_8 {
  386. label = "8"
  387. }
  388. Post_Encapsulated_PetriNet/PortPlace (post_ct_8, post_ct_7) {
  389. label = "9"
  390. }
  391. Post_Encapsulated_PetriNet/Place post_ct_10 {
  392. label = "10"
  393. }
  394. Post_Encapsulated_PetriNet/Port post_ct_11 {
  395. label = "11"
  396. }
  397. Post_Encapsulated_PetriNet/PortPlace (post_ct_11, post_ct_10) {
  398. label = "12"
  399. }
  400. Post_Encapsulated_PetriNet/Place post_ct_13 {
  401. label = "13"
  402. }
  403. Post_Encapsulated_PetriNet/Port post_ct_14 {
  404. label = "14"
  405. }
  406. Post_Encapsulated_PetriNet/PortPlace (post_ct_14, post_ct_13) {
  407. label = "15"
  408. }
  409. Post_Encapsulated_PetriNet/Transition post_ct_16 {
  410. label = "16"
  411. }
  412. Post_Encapsulated_PetriNet/P2T (post_ct_3, post_ct_16) {
  413. label = "17"
  414. }
  415. Post_Encapsulated_PetriNet/T2P (post_ct_16, post_ct_4) {
  416. label = "18"
  417. }
  418. Post_Encapsulated_PetriNet/P2T (post_ct_7, post_ct_16) {
  419. label = "19"
  420. }
  421. Post_Encapsulated_PetriNet/T2P (post_ct_16, post_ct_10) {
  422. label = "20"
  423. }
  424. Post_Encapsulated_PetriNet/P2T (post_ct_13, post_ct_16) {
  425. label = "21"
  426. }
  427. Post_Encapsulated_PetriNet/T2P (post_ct_16, post_ct_13) {
  428. label = "22"
  429. }
  430. Post_CTRL2EPN_tlink (post_ct_2, post_ct_16) {
  431. label = "100"
  432. }
  433. }
  434. }
  435. {Contains} ForAll check_object {
  436. LHS {
  437. Pre_PW_Control/State pre_co_0 {
  438. label = "0"
  439. }
  440. Pre_PW_Control/State pre_co_1 {
  441. label = "1"
  442. }
  443. Pre_PW_Control/Transition pre_co_2 (pre_co_0, pre_co_1) {
  444. label = "2"
  445. constraint_objDetected = $
  446. Boolean function constraint(value : String):
  447. return (bool_or(value == "Y", value == "N"))!
  448. $
  449. }
  450. Pre_Encapsulated_PetriNet/Place pre_co_3 {
  451. label = "3"
  452. }
  453. Pre_Encapsulated_PetriNet/Place pre_co_4 {
  454. label = "4"
  455. }
  456. Pre_CTRL2EPN_link (pre_co_0, pre_co_3) {
  457. label = "5"
  458. }
  459. Pre_CTRL2EPN_link (pre_co_1, pre_co_4) {
  460. label = "6"
  461. }
  462. Pre_Encapsulated_PetriNet/Place pre_co_8 {
  463. label = "8"
  464. }
  465. Pre_Encapsulated_PetriNet/Port pre_co_11 {
  466. label = "11"
  467. constraint_name = $
  468. Boolean function constraint(value : String):
  469. return (bool_or(value == "objDetected", value == "no_objDetected"))!
  470. $
  471. }
  472. Pre_Encapsulated_PetriNet/PortPlace (pre_co_11, pre_co_8) {
  473. label = "12"
  474. }
  475. Pre_Encapsulated_PetriNet/Transition pre_co_15 {
  476. label = "15"
  477. }
  478. Pre_Encapsulated_PetriNet/P2T (pre_co_3, pre_co_15) {
  479. label = "16"
  480. }
  481. Pre_Encapsulated_PetriNet/T2P (pre_co_15, pre_co_4) {
  482. label = "17"
  483. }
  484. Pre_CTRL2EPN_tlink (pre_co_2, pre_co_15) {
  485. label = "100"
  486. }
  487. constraint = $
  488. Boolean function constraint (host_model : Element, mapping : Element):
  489. // Check whether the bound primary places match with the state
  490. String s1_value
  491. String ps1_type
  492. s1_value = read_attribute(host_model, mapping["2"], "objDetected")
  493. ps1_type = read_attribute(host_model, mapping["11"], "name")
  494. if (s1_value == "Y"):
  495. return (ps1_type == "objDetected")!
  496. elif (s1_value == "N"):
  497. return (ps1_type == "no_objDetected")!
  498. else:
  499. return False!
  500. $
  501. }
  502. RHS {
  503. Post_PW_Control/State post_co_0 {
  504. label = "0"
  505. }
  506. Post_PW_Control/State post_co_1 {
  507. label = "1"
  508. }
  509. Post_PW_Control/Transition post_co_2 (post_co_0, post_co_1) {
  510. label = "2"
  511. }
  512. Post_Encapsulated_PetriNet/Place post_co_3 {
  513. label = "3"
  514. }
  515. Post_Encapsulated_PetriNet/Place post_co_4 {
  516. label = "4"
  517. }
  518. Post_CTRL2EPN_link (post_co_0, post_co_3) {
  519. label = "5"
  520. }
  521. Post_CTRL2EPN_link (post_co_1, post_co_4) {
  522. label = "6"
  523. }
  524. Post_Encapsulated_PetriNet/Place post_co_8 {
  525. label = "8"
  526. }
  527. Post_Encapsulated_PetriNet/Port post_co_11 {
  528. label = "11"
  529. }
  530. Post_Encapsulated_PetriNet/PortPlace (post_co_11, post_co_8) {
  531. label = "12"
  532. }
  533. Post_Encapsulated_PetriNet/Transition post_co_15 {
  534. label = "15"
  535. }
  536. Post_Encapsulated_PetriNet/P2T (post_co_3, post_co_15) {
  537. label = "16"
  538. }
  539. Post_Encapsulated_PetriNet/T2P (post_co_15, post_co_4) {
  540. label = "17"
  541. }
  542. Post_Encapsulated_PetriNet/P2T (post_co_8, post_co_15) {
  543. label = "9"
  544. }
  545. Post_Encapsulated_PetriNet/T2P (post_co_15, post_co_4) {
  546. label = "10"
  547. }
  548. Post_CTRL2EPN_tlink (post_co_2, post_co_15) {
  549. label = "100"
  550. }
  551. }
  552. }
  553. {Contains} ForAll fix_interrupt {
  554. LHS {
  555. Pre_PW_Control/State pre_fi_0 {
  556. label = "0"
  557. }
  558. Pre_PW_Control/State pre_fi_1 {
  559. label = "1"
  560. constraint_isError = $
  561. Boolean function constraint(value : Boolean):
  562. return value!
  563. $
  564. }
  565. Pre_Encapsulated_PetriNet/Place pre_fi_2 {
  566. label = "2"
  567. }
  568. Pre_Encapsulated_PetriNet/Place pre_fi_3 {
  569. label = "3"
  570. }
  571. Pre_CTRL2EPN_link (pre_fi_0, pre_fi_2) {
  572. label = "4"
  573. }
  574. Pre_CTRL2EPN_link (pre_fi_1, pre_fi_3) {
  575. label = "5"
  576. }
  577. Pre_Encapsulated_PetriNet/Place pre_fi_6 {
  578. label = "6"
  579. }
  580. Pre_Encapsulated_PetriNet/Place pre_fi_12 {
  581. label = "12"
  582. }
  583. Pre_Encapsulated_PetriNet/Port pre_fi_13 {
  584. label = "13"
  585. }
  586. Pre_Encapsulated_PetriNet/PortPlace (pre_fi_13, pre_fi_12) {
  587. label = "14"
  588. }
  589. Pre_Encapsulated_PetriNet/Port pre_fi_15 {
  590. label = "15"
  591. constraint_name = $
  592. Boolean function constraint(value : String):
  593. return (value == "interrupt")!
  594. $
  595. }
  596. Pre_Encapsulated_PetriNet/PortPlace (pre_fi_15, pre_fi_6) {
  597. label = "16"
  598. }
  599. constraint = $
  600. Boolean function constraint (host_model : Element, mapping : Element):
  601. // Check whether the bound primary places match with the state
  602. String s_err_type
  603. String p_name
  604. s_err_type = read_type(host_model, mapping["1"])
  605. p_name = read_attribute(host_model, mapping["13"], "name")
  606. if (s_err_type == "Up"):
  607. return (p_name == "up")!
  608. elif (s_err_type == "Neutral"):
  609. return (p_name == "neutral")!
  610. elif (s_err_type == "Down"):
  611. return (p_name == "down")!
  612. else:
  613. return False!
  614. $
  615. }
  616. RHS {
  617. Post_PW_Control/State post_fi_0 {
  618. label = "0"
  619. }
  620. Post_PW_Control/State post_fi_1 {
  621. label = "1"
  622. }
  623. Post_Encapsulated_PetriNet/Place post_fi_2 {
  624. label = "2"
  625. }
  626. Post_Encapsulated_PetriNet/Place post_fi_3 {
  627. label = "3"
  628. }
  629. Post_CTRL2EPN_link (post_fi_0, post_fi_2) {
  630. label = "4"
  631. }
  632. Post_CTRL2EPN_link (post_fi_1, post_fi_3) {
  633. label = "5"
  634. }
  635. Post_Encapsulated_PetriNet/Place post_fi_6 {
  636. label = "6"
  637. }
  638. Post_Encapsulated_PetriNet/Place post_fi_12 {
  639. label = "12"
  640. }
  641. Post_Encapsulated_PetriNet/Port post_fi_13 {
  642. label = "13"
  643. }
  644. Post_Encapsulated_PetriNet/PortPlace (post_fi_13, post_fi_12) {
  645. label = "14"
  646. }
  647. Post_Encapsulated_PetriNet/Port post_fi_15 {
  648. label = "15"
  649. }
  650. Post_Encapsulated_PetriNet/PortPlace (post_fi_15, post_fi_6) {
  651. label = "16"
  652. }
  653. Post_Encapsulated_PetriNet/Transition post_fi_7 {
  654. label = "7"
  655. }
  656. Post_Encapsulated_PetriNet/P2T (post_fi_2, post_fi_7) {
  657. label = "8"
  658. }
  659. Post_Encapsulated_PetriNet/T2P (post_fi_7, post_fi_3) {
  660. label = "9"
  661. }
  662. Post_Encapsulated_PetriNet/P2T (post_fi_6, post_fi_7) {
  663. label = "10"
  664. }
  665. Post_Encapsulated_PetriNet/T2P (post_fi_7, post_fi_12) {
  666. label = "11"
  667. }
  668. }
  669. }
  670. {Contains} ForAll fix_interrupt_self {
  671. LHS {
  672. Pre_PW_Control/State pre_fis_0 {
  673. label = "0"
  674. constraint_isError = $
  675. Boolean function constraint(value : Boolean):
  676. return value!
  677. $
  678. }
  679. Pre_Encapsulated_PetriNet/Place pre_fis_1 {
  680. label = "1"
  681. }
  682. Pre_CTRL2EPN_link (pre_fis_0, pre_fis_1) {
  683. label = "2"
  684. }
  685. Pre_Encapsulated_PetriNet/Place pre_fis_3 {
  686. label = "3"
  687. }
  688. Pre_Encapsulated_PetriNet/Port pre_fis_4 {
  689. label = "4"
  690. constraint_name = $
  691. Boolean function constraint(value : String):
  692. return (value == "interrupt")!
  693. $
  694. }
  695. Pre_Encapsulated_PetriNet/PortPlace (pre_fis_4, pre_fis_3) {
  696. label = "5"
  697. }
  698. Pre_Encapsulated_PetriNet/Place pre_fis_6 {
  699. label = "6"
  700. }
  701. Pre_Encapsulated_PetriNet/Port pre_fis_7 {
  702. label = "7"
  703. }
  704. Pre_Encapsulated_PetriNet/PortPlace (pre_fis_7, pre_fis_6) {
  705. label = "8"
  706. }
  707. constraint = $
  708. Boolean function constraint (host_model : Element, mapping : Element):
  709. // Check whether the bound primary places match with the state
  710. String s_err_type
  711. String p_name
  712. s_err_type = read_type(host_model, mapping["0"])
  713. p_name = read_attribute(host_model, mapping["7"], "name")
  714. if (s_err_type == "Up"):
  715. return (p_name == "up")!
  716. elif (s_err_type == "Neutral"):
  717. return (p_name == "neutral")!
  718. elif (s_err_type == "Down"):
  719. return (p_name == "down")!
  720. else:
  721. return False!
  722. $
  723. }
  724. RHS {
  725. Post_PW_Control/State post_fis_0 {
  726. label = "0"
  727. }
  728. Post_Encapsulated_PetriNet/Place post_fis_1 {
  729. label = "1"
  730. }
  731. Post_CTRL2EPN_link (post_fis_0, post_fis_1) {
  732. label = "2"
  733. }
  734. Post_Encapsulated_PetriNet/Place post_fis_3 {
  735. label = "3"
  736. }
  737. Post_Encapsulated_PetriNet/Port post_fis_4 {
  738. label = "4"
  739. }
  740. Post_Encapsulated_PetriNet/PortPlace (post_fis_4, post_fis_3) {
  741. label = "5"
  742. }
  743. Post_Encapsulated_PetriNet/Place post_fis_6 {
  744. label = "6"
  745. }
  746. Post_Encapsulated_PetriNet/Port post_fis_7 {
  747. label = "7"
  748. }
  749. Post_Encapsulated_PetriNet/PortPlace (post_fis_7, post_fis_6) {
  750. label = "8"
  751. }
  752. Post_Encapsulated_PetriNet/Transition post_fis_9 {
  753. label = "9"
  754. }
  755. Post_Encapsulated_PetriNet/P2T (post_fis_3, post_fis_9) {
  756. label = "10"
  757. }
  758. Post_Encapsulated_PetriNet/T2P (post_fis_9, post_fis_6) {
  759. label = "11"
  760. }
  761. Post_Encapsulated_PetriNet/P2T (post_fis_1, post_fis_9) {
  762. label = "12"
  763. }
  764. Post_Encapsulated_PetriNet/T2P (post_fis_9, post_fis_1) {
  765. label = "13"
  766. }
  767. }
  768. }
  769. }
  770. Initial (schedule, init_ports) {}
  771. OnSuccess (init_ports, create_states) {}
  772. OnSuccess (create_states, create_transitions) {}
  773. OnSuccess (create_transitions, check_object) {}
  774. OnSuccess (check_object, fix_interrupt) {}
  775. OnSuccess (fix_interrupt, fix_interrupt_self) {}
  776. OnSuccess (fix_interrupt_self, success) {}
  777. OnFailure (init_ports, create_states) {}
  778. OnFailure (create_states, create_transitions) {}
  779. OnFailure (create_transitions, check_object) {}
  780. OnFailure (check_object, fix_interrupt) {}
  781. OnFailure (fix_interrupt, fix_interrupt_self) {}
  782. OnFailure (fix_interrupt_self, success) {}
  783. }