khammurabi 0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (597) hide show
  1. data/khammurabi-0.2/docs/classes/Array.html +563 -0
  2. data/khammurabi-0.2/docs/classes/Array.src/M000004.html +21 -0
  3. data/khammurabi-0.2/docs/classes/Array.src/M000005.html +18 -0
  4. data/khammurabi-0.2/docs/classes/Array.src/M000006.html +27 -0
  5. data/khammurabi-0.2/docs/classes/Array.src/M000007.html +23 -0
  6. data/khammurabi-0.2/docs/classes/Array.src/M000008.html +29 -0
  7. data/khammurabi-0.2/docs/classes/Array.src/M000009.html +47 -0
  8. data/khammurabi-0.2/docs/classes/Array.src/M000010.html +19 -0
  9. data/khammurabi-0.2/docs/classes/Array.src/M000011.html +22 -0
  10. data/khammurabi-0.2/docs/classes/Array.src/M000012.html +22 -0
  11. data/khammurabi-0.2/docs/classes/Array.src/M000013.html +22 -0
  12. data/khammurabi-0.2/docs/classes/Array.src/M000014.html +16 -0
  13. data/khammurabi-0.2/docs/classes/Array.src/M000015.html +20 -0
  14. data/khammurabi-0.2/docs/classes/Array.src/M000016.html +29 -0
  15. data/khammurabi-0.2/docs/classes/Array.src/M000017.html +25 -0
  16. data/khammurabi-0.2/docs/classes/Array.src/M000018.html +16 -0
  17. data/khammurabi-0.2/docs/classes/Array.src/M000019.html +16 -0
  18. data/khammurabi-0.2/docs/classes/Array.src/M000020.html +16 -0
  19. data/khammurabi-0.2/docs/classes/Array.src/M000021.html +16 -0
  20. data/khammurabi-0.2/docs/classes/Array.src/M000022.html +16 -0
  21. data/khammurabi-0.2/docs/classes/Array.src/M000023.html +16 -0
  22. data/khammurabi-0.2/docs/classes/Array.src/M000024.html +16 -0
  23. data/khammurabi-0.2/docs/classes/Array.src/M000025.html +16 -0
  24. data/khammurabi-0.2/docs/classes/Array.src/M000026.html +16 -0
  25. data/khammurabi-0.2/docs/classes/Array.src/M000027.html +16 -0
  26. data/khammurabi-0.2/docs/classes/Array.src/M000028.html +16 -0
  27. data/khammurabi-0.2/docs/classes/FalseClass.html +139 -0
  28. data/khammurabi-0.2/docs/classes/FalseClass.src/M000003.html +16 -0
  29. data/khammurabi-0.2/docs/classes/Fixnum.html +139 -0
  30. data/khammurabi-0.2/docs/classes/Fixnum.src/M000041.html +22 -0
  31. data/khammurabi-0.2/docs/classes/Hash.html +163 -0
  32. data/khammurabi-0.2/docs/classes/Hash.src/M000001.html +28 -0
  33. data/khammurabi-0.2/docs/classes/Hash.src/M000002.html +22 -0
  34. data/khammurabi-0.2/docs/classes/Hostilities.html +187 -0
  35. data/khammurabi-0.2/docs/classes/Hostilities.src/M000043.html +16 -0
  36. data/khammurabi-0.2/docs/classes/Hostilities.src/M000044.html +16 -0
  37. data/khammurabi-0.2/docs/classes/Hostilities.src/M000045.html +16 -0
  38. data/khammurabi-0.2/docs/classes/Hostilities.src/M000046.html +24 -0
  39. data/khammurabi-0.2/docs/classes/MK.html +330 -0
  40. data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.html +200 -0
  41. data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.src/M000194.html +22 -0
  42. data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.src/M000195.html +19 -0
  43. data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.src/M000196.html +18 -0
  44. data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.html +197 -0
  45. data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.src/M000106.html +22 -0
  46. data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.src/M000107.html +19 -0
  47. data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.src/M000108.html +18 -0
  48. data/khammurabi-0.2/docs/classes/MK/ActionObjectInsert.html +182 -0
  49. data/khammurabi-0.2/docs/classes/MK/ActionObjectInsert.src/M000292.html +22 -0
  50. data/khammurabi-0.2/docs/classes/MK/ActionObjectInsert.src/M000293.html +18 -0
  51. data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.html +199 -0
  52. data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.src/M000289.html +23 -0
  53. data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.src/M000290.html +20 -0
  54. data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.src/M000291.html +34 -0
  55. data/khammurabi-0.2/docs/classes/MK/ActionOutput.html +236 -0
  56. data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000226.html +22 -0
  57. data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000227.html +20 -0
  58. data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000228.html +19 -0
  59. data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000229.html +19 -0
  60. data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000230.html +16 -0
  61. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.html +273 -0
  62. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000282.html +20 -0
  63. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000283.html +25 -0
  64. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000284.html +23 -0
  65. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000285.html +20 -0
  66. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000286.html +22 -0
  67. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000287.html +22 -0
  68. data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000288.html +16 -0
  69. data/khammurabi-0.2/docs/classes/MK/Cluster.html +475 -0
  70. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000329.html +20 -0
  71. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000330.html +19 -0
  72. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000331.html +16 -0
  73. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000332.html +24 -0
  74. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000333.html +26 -0
  75. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000334.html +24 -0
  76. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000335.html +20 -0
  77. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000336.html +21 -0
  78. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000337.html +21 -0
  79. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000338.html +18 -0
  80. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000339.html +16 -0
  81. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000340.html +25 -0
  82. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000341.html +16 -0
  83. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000342.html +16 -0
  84. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000343.html +16 -0
  85. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000344.html +31 -0
  86. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000345.html +16 -0
  87. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000346.html +20 -0
  88. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000347.html +16 -0
  89. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000348.html +16 -0
  90. data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000349.html +16 -0
  91. data/khammurabi-0.2/docs/classes/MK/ClusterManager.html +521 -0
  92. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000305.html +20 -0
  93. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000306.html +20 -0
  94. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000307.html +29 -0
  95. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000308.html +23 -0
  96. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000309.html +21 -0
  97. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000310.html +16 -0
  98. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000311.html +16 -0
  99. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000312.html +21 -0
  100. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000313.html +21 -0
  101. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000314.html +18 -0
  102. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000315.html +32 -0
  103. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000316.html +20 -0
  104. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000317.html +20 -0
  105. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000318.html +18 -0
  106. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000319.html +22 -0
  107. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000320.html +16 -0
  108. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000321.html +21 -0
  109. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000322.html +23 -0
  110. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000323.html +16 -0
  111. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000324.html +16 -0
  112. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000325.html +30 -0
  113. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000326.html +16 -0
  114. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000327.html +18 -0
  115. data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000328.html +39 -0
  116. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.html +271 -0
  117. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000186.html +19 -0
  118. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000187.html +23 -0
  119. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000188.html +25 -0
  120. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000189.html +23 -0
  121. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000190.html +22 -0
  122. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000191.html +33 -0
  123. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000192.html +21 -0
  124. data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000193.html +16 -0
  125. data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.html +185 -0
  126. data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.src/M000251.html +20 -0
  127. data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.src/M000252.html +23 -0
  128. data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.src/M000253.html +41 -0
  129. data/khammurabi-0.2/docs/classes/MK/Engine.html +770 -0
  130. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000115.html +30 -0
  131. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000116.html +32 -0
  132. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000117.html +19 -0
  133. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000118.html +29 -0
  134. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000119.html +18 -0
  135. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000120.html +18 -0
  136. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000121.html +20 -0
  137. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000122.html +22 -0
  138. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000123.html +21 -0
  139. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000124.html +18 -0
  140. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000125.html +19 -0
  141. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000126.html +16 -0
  142. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000127.html +16 -0
  143. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000128.html +153 -0
  144. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000129.html +16 -0
  145. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000130.html +19 -0
  146. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000131.html +24 -0
  147. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000132.html +16 -0
  148. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000133.html +16 -0
  149. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000134.html +46 -0
  150. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000135.html +16 -0
  151. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000136.html +16 -0
  152. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000137.html +20 -0
  153. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000138.html +29 -0
  154. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000139.html +16 -0
  155. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000140.html +16 -0
  156. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000141.html +20 -0
  157. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000142.html +27 -0
  158. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000143.html +26 -0
  159. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000144.html +23 -0
  160. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000145.html +19 -0
  161. data/khammurabi-0.2/docs/classes/MK/Engine.src/M000146.html +25 -0
  162. data/khammurabi-0.2/docs/classes/MK/EqualityTest.html +177 -0
  163. data/khammurabi-0.2/docs/classes/MK/EqualityTest.src/M000092.html +19 -0
  164. data/khammurabi-0.2/docs/classes/MK/EqualityTest.src/M000093.html +20 -0
  165. data/khammurabi-0.2/docs/classes/MK/EqualityTest.src/M000094.html +19 -0
  166. data/khammurabi-0.2/docs/classes/MK/FalseTest.html +177 -0
  167. data/khammurabi-0.2/docs/classes/MK/FalseTest.src/M000397.html +19 -0
  168. data/khammurabi-0.2/docs/classes/MK/FalseTest.src/M000398.html +20 -0
  169. data/khammurabi-0.2/docs/classes/MK/FalseTest.src/M000399.html +19 -0
  170. data/khammurabi-0.2/docs/classes/MK/GraphNode.html +823 -0
  171. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000361.html +28 -0
  172. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000362.html +20 -0
  173. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000363.html +16 -0
  174. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000364.html +19 -0
  175. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000365.html +16 -0
  176. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000366.html +16 -0
  177. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000367.html +20 -0
  178. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000368.html +26 -0
  179. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000369.html +19 -0
  180. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000370.html +19 -0
  181. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000371.html +23 -0
  182. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000372.html +16 -0
  183. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000373.html +16 -0
  184. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000374.html +19 -0
  185. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000375.html +19 -0
  186. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000376.html +16 -0
  187. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000377.html +19 -0
  188. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000378.html +16 -0
  189. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000379.html +25 -0
  190. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000380.html +19 -0
  191. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000381.html +24 -0
  192. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000382.html +20 -0
  193. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000383.html +23 -0
  194. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000384.html +16 -0
  195. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000385.html +31 -0
  196. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000386.html +16 -0
  197. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000387.html +22 -0
  198. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000388.html +19 -0
  199. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000389.html +19 -0
  200. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000390.html +25 -0
  201. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000391.html +50 -0
  202. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000392.html +31 -0
  203. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000393.html +18 -0
  204. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000394.html +18 -0
  205. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000395.html +17 -0
  206. data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000396.html +16 -0
  207. data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.html +261 -0
  208. data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000276.html +23 -0
  209. data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000277.html +22 -0
  210. data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000278.html +30 -0
  211. data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000279.html +19 -0
  212. data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000280.html +29 -0
  213. data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000281.html +19 -0
  214. data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.html +177 -0
  215. data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.src/M000095.html +19 -0
  216. data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.src/M000096.html +20 -0
  217. data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.src/M000097.html +19 -0
  218. data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.html +177 -0
  219. data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.src/M000112.html +19 -0
  220. data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.src/M000113.html +20 -0
  221. data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.src/M000114.html +20 -0
  222. data/khammurabi-0.2/docs/classes/MK/IncorporatorTest.html +139 -0
  223. data/khammurabi-0.2/docs/classes/MK/IncorporatorTest.src/M000294.html +36 -0
  224. data/khammurabi-0.2/docs/classes/MK/InequalityTest.html +177 -0
  225. data/khammurabi-0.2/docs/classes/MK/InequalityTest.src/M000231.html +19 -0
  226. data/khammurabi-0.2/docs/classes/MK/InequalityTest.src/M000232.html +20 -0
  227. data/khammurabi-0.2/docs/classes/MK/InequalityTest.src/M000233.html +19 -0
  228. data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.html +194 -0
  229. data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.src/M000083.html +22 -0
  230. data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.src/M000084.html +20 -0
  231. data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.src/M000085.html +45 -0
  232. data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.html +177 -0
  233. data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.src/M000109.html +19 -0
  234. data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.src/M000110.html +20 -0
  235. data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.src/M000111.html +19 -0
  236. data/khammurabi-0.2/docs/classes/MK/LessThanTest.html +177 -0
  237. data/khammurabi-0.2/docs/classes/MK/LessThanTest.src/M000089.html +19 -0
  238. data/khammurabi-0.2/docs/classes/MK/LessThanTest.src/M000090.html +20 -0
  239. data/khammurabi-0.2/docs/classes/MK/LessThanTest.src/M000091.html +19 -0
  240. data/khammurabi-0.2/docs/classes/MK/Message.html +167 -0
  241. data/khammurabi-0.2/docs/classes/MK/Message.src/M000081.html +20 -0
  242. data/khammurabi-0.2/docs/classes/MK/Message.src/M000082.html +18 -0
  243. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.html +291 -0
  244. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000243.html +20 -0
  245. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000244.html +25 -0
  246. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000245.html +23 -0
  247. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000246.html +35 -0
  248. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000247.html +23 -0
  249. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000248.html +22 -0
  250. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000249.html +22 -0
  251. data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000250.html +16 -0
  252. data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.html +219 -0
  253. data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000161.html +22 -0
  254. data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000162.html +23 -0
  255. data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000163.html +54 -0
  256. data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000164.html +18 -0
  257. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.html +564 -0
  258. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000059.html +21 -0
  259. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000060.html +21 -0
  260. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000061.html +18 -0
  261. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000062.html +24 -0
  262. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000063.html +29 -0
  263. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000064.html +36 -0
  264. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000065.html +23 -0
  265. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000066.html +28 -0
  266. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000067.html +26 -0
  267. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000068.html +16 -0
  268. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000069.html +18 -0
  269. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000070.html +18 -0
  270. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000071.html +16 -0
  271. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000072.html +16 -0
  272. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000073.html +16 -0
  273. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000074.html +16 -0
  274. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000075.html +16 -0
  275. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000076.html +16 -0
  276. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000077.html +22 -0
  277. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000078.html +24 -0
  278. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000079.html +23 -0
  279. data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000080.html +16 -0
  280. data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.html +256 -0
  281. data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000180.html +19 -0
  282. data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000181.html +21 -0
  283. data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000182.html +21 -0
  284. data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000183.html +16 -0
  285. data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000184.html +19 -0
  286. data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000185.html +16 -0
  287. data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.html +177 -0
  288. data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.src/M000400.html +19 -0
  289. data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.src/M000401.html +20 -0
  290. data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.src/M000402.html +19 -0
  291. data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.html +177 -0
  292. data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.src/M000056.html +19 -0
  293. data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.src/M000057.html +20 -0
  294. data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.src/M000058.html +19 -0
  295. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.html +290 -0
  296. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000098.html +19 -0
  297. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000099.html +23 -0
  298. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000100.html +18 -0
  299. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000101.html +18 -0
  300. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000102.html +16 -0
  301. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000103.html +16 -0
  302. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000104.html +19 -0
  303. data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000105.html +16 -0
  304. data/khammurabi-0.2/docs/classes/MK/ObjectProduction.html +223 -0
  305. data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000239.html +24 -0
  306. data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000240.html +21 -0
  307. data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000241.html +19 -0
  308. data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000242.html +19 -0
  309. data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.html +211 -0
  310. data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.src/M000273.html +19 -0
  311. data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.src/M000274.html +16 -0
  312. data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.src/M000275.html +19 -0
  313. data/khammurabi-0.2/docs/classes/MK/Pair.html +259 -0
  314. data/khammurabi-0.2/docs/classes/MK/Pair.src/M000298.html +21 -0
  315. data/khammurabi-0.2/docs/classes/MK/Pair.src/M000299.html +18 -0
  316. data/khammurabi-0.2/docs/classes/MK/Pair.src/M000300.html +18 -0
  317. data/khammurabi-0.2/docs/classes/MK/Pair.src/M000301.html +20 -0
  318. data/khammurabi-0.2/docs/classes/MK/Pair.src/M000302.html +16 -0
  319. data/khammurabi-0.2/docs/classes/MK/Pair.src/M000303.html +18 -0
  320. data/khammurabi-0.2/docs/classes/MK/Pair.src/M000304.html +22 -0
  321. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.html +289 -0
  322. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000174.html +22 -0
  323. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000175.html +24 -0
  324. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000176.html +20 -0
  325. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000177.html +18 -0
  326. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000178.html +19 -0
  327. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000179.html +16 -0
  328. data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.html +230 -0
  329. data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000234.html +20 -0
  330. data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000235.html +18 -0
  331. data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000236.html +21 -0
  332. data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000237.html +36 -0
  333. data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000238.html +16 -0
  334. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.html +219 -0
  335. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000170.html +20 -0
  336. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000171.html +18 -0
  337. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000172.html +16 -0
  338. data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000173.html +60 -0
  339. data/khammurabi-0.2/docs/classes/MK/RootNode.html +181 -0
  340. data/khammurabi-0.2/docs/classes/MK/RootNode.src/M000295.html +22 -0
  341. data/khammurabi-0.2/docs/classes/MK/RootNode.src/M000296.html +19 -0
  342. data/khammurabi-0.2/docs/classes/MK/RootNode.src/M000297.html +21 -0
  343. data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.html +247 -0
  344. data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000165.html +18 -0
  345. data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000166.html +20 -0
  346. data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000167.html +18 -0
  347. data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000168.html +20 -0
  348. data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000169.html +28 -0
  349. data/khammurabi-0.2/docs/classes/MK/TestNode.html +203 -0
  350. data/khammurabi-0.2/docs/classes/MK/TestNode.src/M000350.html +18 -0
  351. data/khammurabi-0.2/docs/classes/MK/TestNode.src/M000351.html +20 -0
  352. data/khammurabi-0.2/docs/classes/MK/TestNode.src/M000352.html +16 -0
  353. data/khammurabi-0.2/docs/classes/MK/Token.html +541 -0
  354. data/khammurabi-0.2/docs/classes/MK/Token.src/M000254.html +24 -0
  355. data/khammurabi-0.2/docs/classes/MK/Token.src/M000255.html +16 -0
  356. data/khammurabi-0.2/docs/classes/MK/Token.src/M000256.html +31 -0
  357. data/khammurabi-0.2/docs/classes/MK/Token.src/M000257.html +16 -0
  358. data/khammurabi-0.2/docs/classes/MK/Token.src/M000258.html +16 -0
  359. data/khammurabi-0.2/docs/classes/MK/Token.src/M000259.html +18 -0
  360. data/khammurabi-0.2/docs/classes/MK/Token.src/M000260.html +28 -0
  361. data/khammurabi-0.2/docs/classes/MK/Token.src/M000261.html +26 -0
  362. data/khammurabi-0.2/docs/classes/MK/Token.src/M000262.html +16 -0
  363. data/khammurabi-0.2/docs/classes/MK/Token.src/M000263.html +20 -0
  364. data/khammurabi-0.2/docs/classes/MK/Token.src/M000264.html +20 -0
  365. data/khammurabi-0.2/docs/classes/MK/Token.src/M000265.html +33 -0
  366. data/khammurabi-0.2/docs/classes/MK/Token.src/M000266.html +16 -0
  367. data/khammurabi-0.2/docs/classes/MK/Token.src/M000267.html +16 -0
  368. data/khammurabi-0.2/docs/classes/MK/Token.src/M000268.html +19 -0
  369. data/khammurabi-0.2/docs/classes/MK/Token.src/M000269.html +24 -0
  370. data/khammurabi-0.2/docs/classes/MK/Token.src/M000270.html +16 -0
  371. data/khammurabi-0.2/docs/classes/MK/Token.src/M000271.html +18 -0
  372. data/khammurabi-0.2/docs/classes/MK/Token.src/M000272.html +16 -0
  373. data/khammurabi-0.2/docs/classes/MK/TokenCluster.html +369 -0
  374. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000211.html +16 -0
  375. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000212.html +16 -0
  376. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000213.html +16 -0
  377. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000214.html +16 -0
  378. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000215.html +16 -0
  379. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000216.html +16 -0
  380. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000217.html +16 -0
  381. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000218.html +19 -0
  382. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000219.html +34 -0
  383. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000220.html +19 -0
  384. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000221.html +25 -0
  385. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000222.html +31 -0
  386. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000223.html +92 -0
  387. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000224.html +31 -0
  388. data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000225.html +16 -0
  389. data/khammurabi-0.2/docs/classes/MK/TokenClusterManager.html +156 -0
  390. data/khammurabi-0.2/docs/classes/MK/TokenClusterManager.src/M000209.html +19 -0
  391. data/khammurabi-0.2/docs/classes/MK/TokenClusterManager.src/M000210.html +34 -0
  392. data/khammurabi-0.2/docs/classes/MK/TrueTest.html +177 -0
  393. data/khammurabi-0.2/docs/classes/MK/TrueTest.src/M000053.html +19 -0
  394. data/khammurabi-0.2/docs/classes/MK/TrueTest.src/M000054.html +20 -0
  395. data/khammurabi-0.2/docs/classes/MK/TrueTest.src/M000055.html +19 -0
  396. data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.html +258 -0
  397. data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000203.html +22 -0
  398. data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000204.html +22 -0
  399. data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000205.html +20 -0
  400. data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000206.html +18 -0
  401. data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000207.html +18 -0
  402. data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000208.html +62 -0
  403. data/khammurabi-0.2/docs/classes/MK/ValueTest.html +275 -0
  404. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000153.html +19 -0
  405. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000154.html +16 -0
  406. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000155.html +16 -0
  407. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000156.html +16 -0
  408. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000157.html +30 -0
  409. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000158.html +18 -0
  410. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000159.html +18 -0
  411. data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000160.html +18 -0
  412. data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.html +260 -0
  413. data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000197.html +20 -0
  414. data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000198.html +25 -0
  415. data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000199.html +48 -0
  416. data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000200.html +19 -0
  417. data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000201.html +21 -0
  418. data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000202.html +16 -0
  419. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.html +317 -0
  420. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000353.html +24 -0
  421. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000354.html +21 -0
  422. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000355.html +21 -0
  423. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000356.html +25 -0
  424. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000357.html +23 -0
  425. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000358.html +25 -0
  426. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000359.html +25 -0
  427. data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000360.html +19 -0
  428. data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.html +249 -0
  429. data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000147.html +22 -0
  430. data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000148.html +20 -0
  431. data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000149.html +16 -0
  432. data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000150.html +19 -0
  433. data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000151.html +21 -0
  434. data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000152.html +216 -0
  435. data/khammurabi-0.2/docs/classes/MK/XiaccEngine.html +191 -0
  436. data/khammurabi-0.2/docs/classes/MK/XiaccEngine.src/M000051.html +122 -0
  437. data/khammurabi-0.2/docs/classes/MK/XiaccEngine.src/M000052.html +69 -0
  438. data/khammurabi-0.2/docs/classes/MK/XiaccParseInput.html +172 -0
  439. data/khammurabi-0.2/docs/classes/MK/XiaccParseInput.src/M000049.html +24 -0
  440. data/khammurabi-0.2/docs/classes/MK/XiaccParseInput.src/M000050.html +20 -0
  441. data/khammurabi-0.2/docs/classes/MK/XiaccParseSpecification.html +174 -0
  442. data/khammurabi-0.2/docs/classes/MK/XiaccParseSpecification.src/M000047.html +21 -0
  443. data/khammurabi-0.2/docs/classes/MK/XiaccParseSpecification.src/M000048.html +20 -0
  444. data/khammurabi-0.2/docs/classes/MK/ZombieNode.html +181 -0
  445. data/khammurabi-0.2/docs/classes/MK/ZombieNode.src/M000086.html +21 -0
  446. data/khammurabi-0.2/docs/classes/MK/ZombieNode.src/M000087.html +18 -0
  447. data/khammurabi-0.2/docs/classes/MK/ZombieNode.src/M000088.html +17 -0
  448. data/khammurabi-0.2/docs/classes/Object.html +345 -0
  449. data/khammurabi-0.2/docs/classes/Object.src/M000029.html +21 -0
  450. data/khammurabi-0.2/docs/classes/Object.src/M000030.html +19 -0
  451. data/khammurabi-0.2/docs/classes/Object.src/M000031.html +24 -0
  452. data/khammurabi-0.2/docs/classes/Object.src/M000032.html +19 -0
  453. data/khammurabi-0.2/docs/classes/Object.src/M000033.html +18 -0
  454. data/khammurabi-0.2/docs/classes/Object.src/M000034.html +22 -0
  455. data/khammurabi-0.2/docs/classes/Object.src/M000035.html +16 -0
  456. data/khammurabi-0.2/docs/classes/Object.src/M000036.html +16 -0
  457. data/khammurabi-0.2/docs/classes/Object.src/M000037.html +16 -0
  458. data/khammurabi-0.2/docs/classes/Object.src/M000038.html +16 -0
  459. data/khammurabi-0.2/docs/classes/Object.src/M000039.html +16 -0
  460. data/khammurabi-0.2/docs/classes/Object.src/M000040.html +16 -0
  461. data/khammurabi-0.2/docs/classes/TrueClass.html +139 -0
  462. data/khammurabi-0.2/docs/classes/TrueClass.src/M000042.html +16 -0
  463. data/khammurabi-0.2/docs/created.rid +1 -0
  464. data/khammurabi-0.2/docs/files/License_txt.html +136 -0
  465. data/khammurabi-0.2/docs/files/ReadMe_txt.html +351 -0
  466. data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectDeleteFromWorkingMemory_rb.html +109 -0
  467. data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectDelete_rb.html +109 -0
  468. data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectInsert_rb.html +109 -0
  469. data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectModifyWorkingMemory_rb.html +111 -0
  470. data/khammurabi-0.2/docs/files/nist/khammurabi/ActionOutput_rb.html +110 -0
  471. data/khammurabi-0.2/docs/files/nist/khammurabi/ArbitratorNode_rb.html +108 -0
  472. data/khammurabi-0.2/docs/files/nist/khammurabi/ArrayAddon_rb.html +110 -0
  473. data/khammurabi-0.2/docs/files/nist/khammurabi/BooleanAddon_rb.html +101 -0
  474. data/khammurabi-0.2/docs/files/nist/khammurabi/ClusterManager2_rb.html +108 -0
  475. data/khammurabi-0.2/docs/files/nist/khammurabi/ClusterManager_rb.html +108 -0
  476. data/khammurabi-0.2/docs/files/nist/khammurabi/Cluster_rb.html +110 -0
  477. data/khammurabi-0.2/docs/files/nist/khammurabi/ConstantObjectOperation_rb.html +111 -0
  478. data/khammurabi-0.2/docs/files/nist/khammurabi/ConstantTestNode_rb.html +111 -0
  479. data/khammurabi-0.2/docs/files/nist/khammurabi/Engine_rb.html +128 -0
  480. data/khammurabi-0.2/docs/files/nist/khammurabi/FixnumAddon_rb.html +101 -0
  481. data/khammurabi-0.2/docs/files/nist/khammurabi/GraphNodeJoiner_rb.html +110 -0
  482. data/khammurabi-0.2/docs/files/nist/khammurabi/GraphNode_rb.html +109 -0
  483. data/khammurabi-0.2/docs/files/nist/khammurabi/HashAddon_rb.html +101 -0
  484. data/khammurabi-0.2/docs/files/nist/khammurabi/Hostilities_rb.html +108 -0
  485. data/khammurabi-0.2/docs/files/nist/khammurabi/InstantiatorNode_rb.html +110 -0
  486. data/khammurabi-0.2/docs/files/nist/khammurabi/Message_rb.html +101 -0
  487. data/khammurabi-0.2/docs/files/nist/khammurabi/MultiChildrenArbitratorNode_rb.html +108 -0
  488. data/khammurabi-0.2/docs/files/nist/khammurabi/MultiChildrenSelectorNode_rb.html +108 -0
  489. data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectAddon_rb.html +108 -0
  490. data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectDescription_rb.html +112 -0
  491. data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectGraphWrapper_rb.html +108 -0
  492. data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectOperation_rb.html +110 -0
  493. data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectProductionAction_rb.html +111 -0
  494. data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectProduction_rb.html +109 -0
  495. data/khammurabi-0.2/docs/files/nist/khammurabi/Pair_rb.html +108 -0
  496. data/khammurabi-0.2/docs/files/nist/khammurabi/QueryNode_rb.html +111 -0
  497. data/khammurabi-0.2/docs/files/nist/khammurabi/ReteParseTreeNode_rb.html +108 -0
  498. data/khammurabi-0.2/docs/files/nist/khammurabi/ReteParseTreePrinter_rb.html +111 -0
  499. data/khammurabi-0.2/docs/files/nist/khammurabi/ReteParseTreeToObjectDescriptionConverter_rb.html +111 -0
  500. data/khammurabi-0.2/docs/files/nist/khammurabi/RootNode_rb.html +109 -0
  501. data/khammurabi-0.2/docs/files/nist/khammurabi/TestIDRegistrar_rb.html +108 -0
  502. data/khammurabi-0.2/docs/files/nist/khammurabi/TestNode_rb.html +109 -0
  503. data/khammurabi-0.2/docs/files/nist/khammurabi/TokenClusterManager_rb.html +110 -0
  504. data/khammurabi-0.2/docs/files/nist/khammurabi/TokenCluster_rb.html +108 -0
  505. data/khammurabi-0.2/docs/files/nist/khammurabi/Token_rb.html +112 -0
  506. data/khammurabi-0.2/docs/files/nist/khammurabi/UniqueTokenAssurerNode_rb.html +110 -0
  507. data/khammurabi-0.2/docs/files/nist/khammurabi/ValueTestSuite_rb.html +108 -0
  508. data/khammurabi-0.2/docs/files/nist/khammurabi/VariableObjectOperation_rb.html +112 -0
  509. data/khammurabi-0.2/docs/files/nist/khammurabi/VariableTestNodeExecutor_rb.html +110 -0
  510. data/khammurabi-0.2/docs/files/nist/khammurabi/VariableTestNode_rb.html +111 -0
  511. data/khammurabi-0.2/docs/files/nist/khammurabi/XiaccEngine_rb.html +126 -0
  512. data/khammurabi-0.2/docs/files/nist/khammurabi/XiaccParseInput_rb.html +108 -0
  513. data/khammurabi-0.2/docs/files/nist/khammurabi/XiaccParseSpecification_rb.html +101 -0
  514. data/khammurabi-0.2/docs/files/nist/khammurabi/ZombieNode_rb.html +108 -0
  515. data/khammurabi-0.2/docs/fr_class_index.html +86 -0
  516. data/khammurabi-0.2/docs/fr_file_index.html +77 -0
  517. data/khammurabi-0.2/docs/fr_method_index.html +428 -0
  518. data/khammurabi-0.2/docs/index.html +24 -0
  519. data/khammurabi-0.2/docs/rdoc-style.css +208 -0
  520. data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectDelete.rb +35 -0
  521. data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectDeleteFromWorkingMemory.rb +34 -0
  522. data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectInsert.rb +29 -0
  523. data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectModifyWorkingMemory.rb +53 -0
  524. data/khammurabi-0.2/lib/nist/khammurabi/ActionOutput.rb +45 -0
  525. data/khammurabi-0.2/lib/nist/khammurabi/ArbitratorNode.rb +68 -0
  526. data/khammurabi-0.2/lib/nist/khammurabi/ArrayAddon.rb +201 -0
  527. data/khammurabi-0.2/lib/nist/khammurabi/BooleanAddon.rb +3 -0
  528. data/khammurabi-0.2/lib/nist/khammurabi/Cluster.rb +128 -0
  529. data/khammurabi-0.2/lib/nist/khammurabi/ClusterManager.rb +96 -0
  530. data/khammurabi-0.2/lib/nist/khammurabi/ClusterManager2.rb +103 -0
  531. data/khammurabi-0.2/lib/nist/khammurabi/ConstantObjectOperation.rb +92 -0
  532. data/khammurabi-0.2/lib/nist/khammurabi/ConstantTestNode.rb +59 -0
  533. data/khammurabi-0.2/lib/nist/khammurabi/Engine.rb +454 -0
  534. data/khammurabi-0.2/lib/nist/khammurabi/FixnumAddon.rb +14 -0
  535. data/khammurabi-0.2/lib/nist/khammurabi/GraphNode.rb +305 -0
  536. data/khammurabi-0.2/lib/nist/khammurabi/GraphNodeJoiner.rb +83 -0
  537. data/khammurabi-0.2/lib/nist/khammurabi/HashAddon.rb +29 -0
  538. data/khammurabi-0.2/lib/nist/khammurabi/Hostilities.rb +24 -0
  539. data/khammurabi-0.2/lib/nist/khammurabi/InstantiatorNode.rb +60 -0
  540. data/khammurabi-0.2/lib/nist/khammurabi/Message.rb +19 -0
  541. data/khammurabi-0.2/lib/nist/khammurabi/MultiChildrenArbitratorNode.rb +97 -0
  542. data/khammurabi-0.2/lib/nist/khammurabi/MultiChildrenSelectorNode.rb +77 -0
  543. data/khammurabi-0.2/lib/nist/khammurabi/ObjectAddon.rb +63 -0
  544. data/khammurabi-0.2/lib/nist/khammurabi/ObjectDescription.rb +192 -0
  545. data/khammurabi-0.2/lib/nist/khammurabi/ObjectGraphWrapper.rb +46 -0
  546. data/khammurabi-0.2/lib/nist/khammurabi/ObjectOperation.rb +59 -0
  547. data/khammurabi-0.2/lib/nist/khammurabi/ObjectProduction.rb +45 -0
  548. data/khammurabi-0.2/lib/nist/khammurabi/ObjectProductionAction.rb +31 -0
  549. data/khammurabi-0.2/lib/nist/khammurabi/Pair.rb +49 -0
  550. data/khammurabi-0.2/lib/nist/khammurabi/QueryNode.rb +44 -0
  551. data/khammurabi-0.2/lib/nist/khammurabi/ReteParseTreeNode.rb +66 -0
  552. data/khammurabi-0.2/lib/nist/khammurabi/ReteParseTreePrinter.rb +58 -0
  553. data/khammurabi-0.2/lib/nist/khammurabi/ReteParseTreeToObjectDescriptionConverter.rb +76 -0
  554. data/khammurabi-0.2/lib/nist/khammurabi/RootNode.rb +32 -0
  555. data/khammurabi-0.2/lib/nist/khammurabi/TODO +7 -0
  556. data/khammurabi-0.2/lib/nist/khammurabi/TestIDRegistrar.rb +63 -0
  557. data/khammurabi-0.2/lib/nist/khammurabi/TestNode.rb +33 -0
  558. data/khammurabi-0.2/lib/nist/khammurabi/Token.rb +168 -0
  559. data/khammurabi-0.2/lib/nist/khammurabi/TokenCluster.rb +177 -0
  560. data/khammurabi-0.2/lib/nist/khammurabi/TokenClusterManager.rb +36 -0
  561. data/khammurabi-0.2/lib/nist/khammurabi/UniqueTokenAssurerNode.rb +100 -0
  562. data/khammurabi-0.2/lib/nist/khammurabi/ValueTestSuite.rb +239 -0
  563. data/khammurabi-0.2/lib/nist/khammurabi/VariableObjectOperation.rb +87 -0
  564. data/khammurabi-0.2/lib/nist/khammurabi/VariableTestNode.rb +73 -0
  565. data/khammurabi-0.2/lib/nist/khammurabi/VariableTestNodeExecutor.rb +246 -0
  566. data/khammurabi-0.2/lib/nist/khammurabi/XiaccEngine.rb +201 -0
  567. data/khammurabi-0.2/lib/nist/khammurabi/XiaccParseInput.rb +27 -0
  568. data/khammurabi-0.2/lib/nist/khammurabi/XiaccParseSpecification.rb +25 -0
  569. data/khammurabi-0.2/lib/nist/khammurabi/ZombieNode.rb +24 -0
  570. data/khammurabi-0.2/tests/test_action_object_delete.rb +91 -0
  571. data/khammurabi-0.2/tests/test_action_object_insert.rb +89 -0
  572. data/khammurabi-0.2/tests/test_action_object_modify.rb +103 -0
  573. data/khammurabi-0.2/tests/test_array_addon.rb +214 -0
  574. data/khammurabi-0.2/tests/test_cluster.rb +188 -0
  575. data/khammurabi-0.2/tests/test_cluster_graph.rb +393 -0
  576. data/khammurabi-0.2/tests/test_cluster_manager.rb +204 -0
  577. data/khammurabi-0.2/tests/test_constant_object_operation.rb +112 -0
  578. data/khammurabi-0.2/tests/test_constant_test_node.rb +142 -0
  579. data/khammurabi-0.2/tests/test_constant_test_node_graph.rb +404 -0
  580. data/khammurabi-0.2/tests/test_graph.rb +843 -0
  581. data/khammurabi-0.2/tests/test_graph_node_joiner.rb +94 -0
  582. data/khammurabi-0.2/tests/test_hash_addon.rb +90 -0
  583. data/khammurabi-0.2/tests/test_insurance_with_variables.rb +143 -0
  584. data/khammurabi-0.2/tests/test_multi_children_arbitrator_node.rb +149 -0
  585. data/khammurabi-0.2/tests/test_multi_children_selector_node.rb +203 -0
  586. data/khammurabi-0.2/tests/test_object_description.rb +177 -0
  587. data/khammurabi-0.2/tests/test_person_graph.rb +202 -0
  588. data/khammurabi-0.2/tests/test_root_node.rb +101 -0
  589. data/khammurabi-0.2/tests/test_token.rb +166 -0
  590. data/khammurabi-0.2/tests/test_token_cluster.rb +324 -0
  591. data/khammurabi-0.2/tests/test_unique_token_assurer_node.rb +146 -0
  592. data/khammurabi-0.2/tests/test_value_tests.rb +131 -0
  593. data/khammurabi-0.2/tests/test_variable_object_operation.rb +181 -0
  594. data/khammurabi-0.2/tests/test_variable_test_node.rb +445 -0
  595. data/khammurabi-0.2/tests/test_variable_test_node_graph.rb +587 -0
  596. data/khammurabi-0.2/tests/test_zombie_node.rb +130 -0
  597. metadata +790 -0
@@ -0,0 +1,445 @@
1
+ module MK
2
+
3
+ require 'test/unit'
4
+ require 'stringio'
5
+
6
+ require 'nist/khammurabi/Engine'
7
+ require 'nist/khammurabi/TestNode'
8
+ require 'nist/khammurabi/VariableTestNode'
9
+ require 'nist/khammurabi/InstantiatorNode'
10
+ require 'nist/khammurabi/ObjectProduction'
11
+ require 'nist/khammurabi/ArrayAddon'
12
+ require 'nist/khammurabi/GraphNode'
13
+ require 'nist/khammurabi/ValueTestSuite'
14
+ require 'nist/khammurabi/ReteParseTreePrinter'
15
+ require 'nist/khammurabi/ZombieNode'
16
+ require 'nist/khammurabi/Cluster'
17
+ require 'nist/khammurabi/TokenCluster'
18
+ require 'nist/khammurabi/ClusterManager'
19
+
20
+ class Tester_Variable
21
+ attr :val1, true
22
+ attr :val2, true
23
+ attr :val3, true
24
+
25
+ def initialize
26
+ @val1 = @val2 = @val3 = nil
27
+ end
28
+ def setValues( a, b, c )
29
+ @val1 = a
30
+ @val2 = b
31
+ @val3 = c
32
+ end
33
+ def to_s
34
+ "val1: #{self.val1} val2: #{self.val2} val3: #{self.val3}"
35
+ end
36
+ end
37
+
38
+ class Tester_Variable2
39
+ attr :val0, true
40
+ attr :val1, true
41
+ attr :val2, true
42
+ attr :val3, true
43
+
44
+ def initialize
45
+ @val0 = @val1 = @val2 = @val3 = nil
46
+ end
47
+ def setValues( a, b, c, d )
48
+ self.val0 = a
49
+ self.val1 = b
50
+ self.val2 = c
51
+ self.val3 = d
52
+ end
53
+ end
54
+
55
+ # This class fascilitates VariableTestNode testing with hand-build-graphs
56
+ # "inequality" in the testing means that the tests that some VariableTestNode's use
57
+ # are inequality tests (the test the VariableTestNode uses returns true when the objects input into it are unequal),
58
+ # not that the tokens input are unequal
59
+ class Test_Variable_Test_Node < Test::Unit::TestCase
60
+
61
+ attr_accessor :graphA
62
+
63
+ def objectA
64
+ t = Tester_Variable.new
65
+ t.val1 = 5
66
+ t.val2 = 10
67
+ #t.val3 = 15
68
+ t
69
+ end
70
+
71
+ def objectB
72
+ t = Tester_Variable.new
73
+ t.val1 = 2
74
+ t.val2 = 10
75
+ #t.val3 = 15
76
+ t
77
+ end
78
+
79
+ def objectC
80
+ t = Tester_Variable.new
81
+ t.val1 = 3
82
+ t.val2 = 10
83
+ #t.val3 = 15
84
+ t
85
+ end
86
+
87
+ # Two VariableObjectOperations with equality
88
+ def test_two_with_equality
89
+ engine = MK::Engine.new
90
+ vtne = MK::VariableTestNodeExecutor.init( engine )
91
+ vtn1 = MK::VariableTestNode.init( "vtn1", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
92
+ vtn2 = MK::VariableTestNode.init( "vtn2", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
93
+ j1 = MK::GraphNodeJoiner.init( "j1", vtn1, vtn2, engine )
94
+ vtn1.setChild( j1 )
95
+ vtn2.setChild( j1 )
96
+ zn = MK::ZombieNode.init( "zn1", engine )
97
+ zn.setParent( j1 )
98
+ j1.setChild( zn )
99
+ vtne.variableTestNodes = [ vtn1, vtn2 ]
100
+
101
+ cm = ClusterManager.new
102
+
103
+ token1 = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
104
+ token2 = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
105
+ cm.createCluster( [ token1 ], TokenCluster )
106
+ cm.createCluster( [ token2 ], TokenCluster )
107
+
108
+ vtn1.registerToken( token1 )
109
+ vtn1.execute
110
+
111
+ assert( vtn1.tokens.size == 1, "vtn1.tokens.size != 1, bad" )
112
+
113
+ vtn2.registerToken( token2 )
114
+ vtn2.execute
115
+
116
+ assert( vtn1.tokens.size == 0, "vtn1.tokens.size != 0, bad" )
117
+ assert( vtn2.tokens.size == 0, "vtn2.tokens.size != 0, bad" )
118
+
119
+ assert( zn.tokens.size == 1, "zn.tokens.size != 1, bad" )
120
+ end
121
+
122
+ # Three VariableObjectOperations with equality
123
+ def test_three_with_equality
124
+ engine = MK::Engine.new
125
+ vtne = MK::VariableTestNodeExecutor.init( engine )
126
+ vtn1 = MK::VariableTestNode.init( "vtn1", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
127
+ vtn2 = MK::VariableTestNode.init( "vtn2", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
128
+ vtn3 = MK::VariableTestNode.init( "vtn3", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
129
+ j1 = MK::GraphNodeJoiner.init( "j1", vtn1, vtn2, engine )
130
+ j2 = MK::GraphNodeJoiner.init( "j2", j1, vtn3, engine )
131
+ zn = MK::ZombieNode.init( "zombie, *shiver*", engine )
132
+ cm = ClusterManager.new
133
+
134
+ vtn1.setChild( j1 )
135
+ vtn2.setChild( j1 )
136
+ j1.setChild( j2 )
137
+ vtn3.setChild( j2 )
138
+
139
+ zn.setParent( j2 )
140
+ j2.setChild( zn )
141
+
142
+ vtne.variableTestNodes = [ vtn1, vtn2, vtn3 ]
143
+
144
+ token1 = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
145
+ token2 = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
146
+ token3 = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
147
+ badToken = Token.init( ObjectGraphWrapper.init( objectB ), "+", Time.now )
148
+
149
+ cm.createCluster( [ token1 ], TokenCluster )
150
+ cm.createCluster( [ token2 ], TokenCluster )
151
+ cm.createCluster( [ token3 ], TokenCluster )
152
+ cm.createCluster( [ badToken ], TokenCluster )
153
+
154
+ vtn1.registerToken( token1 )
155
+ assert( vtn1.tokens.size == 1, "vtn1.tokens.size != 1, bad" )
156
+ vtn2.registerToken( token2 )
157
+ assert( vtn2.tokens.size == 1, "vtn2.tokens.size != 1, bad" )
158
+
159
+ vtn3.registerToken( badToken )
160
+ vtn3.execute
161
+ [ vtn1, vtn2, vtn3 ].each { |node| assert( node.tokens.size == 1, "Node token size isn't 1, bad" ) }
162
+
163
+ vtn3.registerToken( token3 )
164
+ vtn3.execute
165
+
166
+ assert( zn.tokens.size == 1, "zn.tokens.size != 1, bad" )
167
+ otherNodes = [ vtn1, vtn2, j1, j2 ]
168
+ otherNodes.each { |on| assert( on.tokens.size == 0, "I got a node of type #{on.class} that has a token, but it shouldn't" ) }
169
+ assert( vtn3.tokens.size == 1, "vtn3.tokens.size != 1, bad" )
170
+ end
171
+
172
+ # Test a graph with many nodes
173
+ def test_many_with_equality
174
+ size = 20
175
+ engine = MK::Engine.new
176
+ vtne = MK::VariableTestNodeExecutor.init( engine )
177
+ vtns = Array.new
178
+ tokens = Array.new
179
+ cm = ClusterManager.new
180
+ size.times do |a|
181
+ vtns[ a ] = MK::VariableTestNode.init( "vtn1", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
182
+ vtne.addVariableTestNode( vtns[ a ] )
183
+ tokens[ a ] = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
184
+ cm.createCluster( [ tokens[ a ] ], TokenCluster )
185
+ end
186
+
187
+ # join all the leaves together
188
+ graphLeaves = Array.new
189
+ graphLeaves.concat( vtns )
190
+ bottom = nil
191
+ name = 0
192
+ while graphLeaves.size > 1
193
+ joiner = GraphNodeJoiner.init( name, graphLeaves.first, graphLeaves.second, engine )
194
+ joiner.debug = false # self.debug
195
+ name = name + 1
196
+ graphLeaves.first.setChild( joiner )
197
+ graphLeaves.second.setChild( joiner )
198
+ bottom = joiner
199
+ graphLeaves.shift
200
+ graphLeaves.shift
201
+ graphLeaves.unshift( joiner )
202
+ end
203
+
204
+ zn = ZombieNode.init( "zombie, *shudder*", engine )
205
+ zn.setParent( bottom )
206
+ bottom.setChild( zn )
207
+
208
+ ( size - 1 ).times do |a|
209
+ vtns[ a ].registerToken( tokens[ a ] )
210
+ vtns[ a ].execute
211
+ assert( vtns[ a ].tokens.size == 1, "vtns[#{a}].tokens.size != 1, bad" )
212
+ end
213
+
214
+ ( size - 1 ).times { |a| assert( vtns[ a ].tokens.size == 1, "vtns[#{a}].tokens.size != 1, bad" ) }
215
+
216
+ vtns[ -1 ].registerToken( tokens[ -1 ] )
217
+ vtns[ -1 ].execute
218
+
219
+ size.times { |a| assert( vtns[ a ].tokens.size == 0, "vtns[#{a}].tokens.size != 0, bad" ) }
220
+ assert( zn.tokens.size == 1, "zn.tokens.size != 1, bad" )
221
+ end
222
+
223
+ # Three VariableObjectOperations with equality with two variables (one node is missing in the second variable)
224
+ def test_three_with_equality2
225
+ engine = MK::Engine.new
226
+ vtne = MK::VariableTestNodeExecutor.init( engine )
227
+ rn = RootNode.new
228
+ vtn1 = MK::VariableTestNode.init( "vtn1", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
229
+ vtn2 = MK::VariableTestNode.init( "vtn2", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
230
+ vtn3 = MK::VariableTestNode.init( "vtn3", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
231
+ vtne2 = MK::VariableTestNodeExecutor.init( engine )
232
+ vtn1_2 = MK::VariableTestNode.init( "vtn1_2", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val2", true, "Y" ), vtne2, engine, nil, level = 1 )
233
+ vtn3_2 = MK::VariableTestNode.init( "vtn3_2", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val2", true, "Y" ), vtne2, engine, nil, level = 1 )
234
+ rn.setChildren( [ vtn1, vtn2, vtn3 ] )
235
+
236
+ j1 = MK::GraphNodeJoiner.init( "j1", vtn2, vtn1_2, engine )
237
+ j2 = MK::GraphNodeJoiner.init( "j2", j1, vtn3_2, engine )
238
+ zn = MK::ZombieNode.init( "zombie, *shiver*", engine )
239
+ cm = ClusterManager.new
240
+
241
+ vtn1.makeChildConnection( vtn1_2 )
242
+ vtn2.addChild( j1 )
243
+ vtn3.makeChildConnection( vtn3_2 )
244
+ vtn1_2.addChild( j1 )
245
+ vtn3_2.makeChildConnection( j2 )
246
+ j1.makeChildConnection( j2 )
247
+ j2.makeChildConnection( zn )
248
+
249
+ vtne.variableTestNodes = [ vtn1, vtn2, vtn3 ]
250
+ vtne2.variableTestNodes = [ vtn1_2, vtn3_2 ]
251
+ vtne2.name = "VTNE2"
252
+
253
+ #[ vtn1, vtn2, vtn3, vtn1_2, vtn3_2, vtne, vtne2, j1, j2, zn ].each { |e| e.debug = true }
254
+
255
+ token1 = Token.init( ObjectGraphWrapper.init( objectA ), Token.add, Time.now, 0 )
256
+ token2 = Token.init( ObjectGraphWrapper.init( objectA ), Token.add, Time.now, 1 )
257
+ token3 = Token.init( ObjectGraphWrapper.init( objectA ), Token.add, Time.now, 2 )
258
+ badToken = Token.init( ObjectGraphWrapper.init( objectB ), Token.add, Time.now, 3 )
259
+
260
+ cm.createCluster( [ token1 ], TokenCluster )
261
+ cm.createCluster( [ token2 ], TokenCluster )
262
+ cm.createCluster( [ token3 ], TokenCluster )
263
+ cm.createCluster( [ badToken ], TokenCluster )
264
+
265
+ #print "Registering 1\n"
266
+ vtn1.registerToken( token1 )
267
+ assert( vtn1.tokens.size == 1, "vtn1.tokens.size != 1, bad" )
268
+ #print "Registering 2\n"
269
+ vtn2.registerToken( token2 )
270
+ assert( vtn2.tokens.size == 1, "vtn2.tokens.size != 1, bad" )
271
+
272
+ #print "Registering bad\n"
273
+ vtn3.registerToken( badToken )
274
+ vtn3.execute
275
+ [ vtn1, vtn2, vtn3 ].each { |node| assert( node.tokens.size == 1, "Node token size isn't 1, bad" ) }
276
+
277
+ #print "Registering 3\n"
278
+ vtn3.registerToken( token3 )
279
+ vtn3.execute
280
+
281
+ #[ vtn1, vtn2, vtn3, vtn1_2, vtn3_2, j1, j2, zn ].each { |node| print "I am a #{node.class} with name: #{node.name} and have #{node.tokens.size} tokens\n" }
282
+ assert( zn.tokens.size == 1, "zn.tokens.size != 1, bad. it is: #{zn.tokens.size}" )
283
+ otherNodes = [ vtn1, vtn2, j1, j2 ]
284
+ otherNodes.each { |on| assert( on.tokens.size == 0, "I got a node of type #{on.class} that has a token, but it shouldn't" ) }
285
+ assert( vtn3.tokens.size == 1, "vtn3.tokens.size != 1, bad" )
286
+ end
287
+
288
+ def test_two_with_inequality
289
+ engine = MK::Engine.new
290
+ vtne = MK::VariableTestNodeExecutor.init( engine )
291
+ vtn1 = MK::VariableTestNode.init( "vtn1", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
292
+ vtn2 = MK::VariableTestNode.init( "vtn2", MK::VariableObjectOperation.init( MK::InequalityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
293
+ j1 = MK::GraphNodeJoiner.init( "j1", vtn1, vtn2, engine )
294
+ vtn1.setChild( j1 )
295
+ vtn2.setChild( j1 )
296
+ zn = MK::ZombieNode.init( "zn1", engine )
297
+ zn.setParent( j1 )
298
+ j1.setChild( zn )
299
+ vtne.variableTestNodes = [ vtn1, vtn2 ]
300
+
301
+ cm = ClusterManager.new
302
+
303
+ token1 = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
304
+ token2 = Token.init( ObjectGraphWrapper.init( objectB ), "+", Time.now )
305
+ cm.createCluster( [ token1 ], TokenCluster )
306
+ cm.createCluster( [ token2 ], TokenCluster )
307
+
308
+ vtn1.registerToken( token1 )
309
+ vtn1.execute
310
+
311
+ assert( vtn1.tokens.size == 1, "vtn1.tokens.size != 1, bad" )
312
+
313
+ vtn2.registerToken( token2 )
314
+ vtn2.execute
315
+
316
+ assert( vtn1.tokens.size == 0, "vtn1.tokens.size != 0, bad" )
317
+ assert( vtn2.tokens.size == 0, "vtn2.tokens.size != 0, bad" )
318
+
319
+ assert( zn.tokens.size == 1, "zn.tokens.size != 1, bad" )
320
+ end
321
+
322
+ def test_three_with_inequality
323
+ engine = MK::Engine.new
324
+ vtne = MK::VariableTestNodeExecutor.init( engine )
325
+ vtn1 = MK::VariableTestNode.init( "vtn1", MK::VariableObjectOperation.init( MK::EqualityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
326
+ vtn2 = MK::VariableTestNode.init( "vtn2", MK::VariableObjectOperation.init( MK::InequalityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
327
+ vtn3 = MK::VariableTestNode.init( "vtn3", MK::VariableObjectOperation.init( MK::InequalityTest.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
328
+ j1 = MK::GraphNodeJoiner.init( "j1", vtn1, vtn2, engine )
329
+ j2 = MK::GraphNodeJoiner.init( "j2", j1, vtn3, engine )
330
+ zn = MK::ZombieNode.init( "zombie, *shiver*", engine )
331
+ cm = ClusterManager.new
332
+
333
+ vtn1.setChild( j1 )
334
+ vtn2.setChild( j1 )
335
+ j1.setChild( j2 )
336
+ vtn3.setChild( j2 )
337
+
338
+ zn.setParent( j2 )
339
+ j2.setChild( zn )
340
+
341
+ vtne.variableTestNodes = [ vtn1, vtn2, vtn3 ]
342
+
343
+ token1 = Token.init( ObjectGraphWrapper.init( objectA ), "+", Time.now )
344
+ token2 = Token.init( ObjectGraphWrapper.init( objectB ), "+", Time.now )
345
+ token3 = Token.init( ObjectGraphWrapper.init( objectC ), "+", Time.now )
346
+ badToken = Token.init( ObjectGraphWrapper.init( objectB ), "+", Time.now )
347
+
348
+ cm.createCluster( [ token1 ], TokenCluster )
349
+ cm.createCluster( [ token2 ], TokenCluster )
350
+ cm.createCluster( [ token3 ], TokenCluster )
351
+ cm.createCluster( [ badToken ], TokenCluster )
352
+
353
+ vtn1.registerToken( token1 )
354
+ assert( vtn1.tokens.size == 1, "vtn1.tokens.size != 1, bad" )
355
+ vtn2.registerToken( token2 )
356
+ assert( vtn2.tokens.size == 1, "vtn2.tokens.size != 1, bad" )
357
+
358
+ vtn3.registerToken( token3 )
359
+ vtn3.execute
360
+
361
+ assert( zn.tokens.size == 1, "zn.tokens.size != 1, bad" )
362
+ otherNodes = [ vtn1, vtn2, j1, j2 ]
363
+ otherNodes.each { |on| assert( on.tokens.size == 0, "I got a node of type #{on.class} that has a token, but it shouldn't" ) }
364
+
365
+ vtn3.registerToken( badToken )
366
+ vtn3.execute
367
+ assert( vtn3.tokens.size == 1, "vtn3.tokens.size != 1, bad" )
368
+ end
369
+
370
+ # Test a graph with many nodes
371
+ def test_many_with_inequality
372
+ size = 20
373
+ engine = MK::Engine.new
374
+ vtne = MK::VariableTestNodeExecutor.init( engine )
375
+ vtns = Array.new
376
+ tokens = Array.new
377
+ cm = ClusterManager.new
378
+ onoff = true
379
+ size.times do |a|
380
+ onoff = ( onoff == false )
381
+ test = MK::EqualityTest if onoff == true
382
+ test = MK::InequalityTest if onoff == false
383
+ vtns[ a ] = MK::VariableTestNode.init( "vtn1", MK::VariableObjectOperation.init( test.new, "@val1", true, "X" ), vtne, engine, nil, level = 0 )
384
+ vtne.addVariableTestNode( vtns[ a ] )
385
+ object = objectA if onoff == true
386
+ object = objectB if onoff == false
387
+ tokens[ a ] = Token.init( ObjectGraphWrapper.init( object ), "+", Time.now )
388
+ cm.createCluster( [ tokens[ a ] ], TokenCluster )
389
+ end
390
+
391
+ # join all the leaves together
392
+ graphLeaves = Array.new
393
+ graphLeaves.concat( vtns )
394
+ bottom = nil
395
+ name = 0
396
+ while graphLeaves.size > 1
397
+ joiner = GraphNodeJoiner.init( name, graphLeaves.first, graphLeaves.second, engine )
398
+ joiner.debug = false # self.debug
399
+ name = name + 1
400
+ graphLeaves.first.setChild( joiner )
401
+ graphLeaves.second.setChild( joiner )
402
+ bottom = joiner
403
+ graphLeaves.shift
404
+ graphLeaves.shift
405
+ graphLeaves.unshift( joiner )
406
+ end
407
+
408
+ zn = ZombieNode.init( "zombie, *shudder*", engine )
409
+ zn.setParent( bottom )
410
+ bottom.setChild( zn )
411
+
412
+ ( size - 1 ).times do |a|
413
+ vtns[ a ].registerToken( tokens[ a ] )
414
+ vtns[ a ].execute
415
+ assert( vtns[ a ].tokens.size == 1, "vtns[#{a}].tokens.size != 1, bad" )
416
+ end
417
+
418
+ ( size - 1 ).times { |a| assert( vtns[ a ].tokens.size == 1, "vtns[#{a}].tokens.size != 1, bad" ) }
419
+
420
+ vtns[ -1 ].registerToken( tokens[ -1 ] )
421
+ vtns[ -1 ].execute
422
+
423
+ size.times { |a| assert( vtns[ a ].tokens.size == 0, "vtns[#{a}].tokens.size != 0, bad" ) }
424
+ assert( zn.tokens.size == 1, "zn.tokens.size != 1, bad" )
425
+ end
426
+
427
+ def self.suite
428
+ suite = Test::Unit::TestSuite.new
429
+ suite << self.new( 'test_two_with_equality' )
430
+ suite << self.new( 'test_three_with_equality' )
431
+ suite << self.new( 'test_three_with_equality2' )
432
+ suite << self.new( 'test_three_with_inequality' )
433
+ suite << self.new( 'test_many_with_equality' )
434
+ suite << self.new( 'test_two_with_inequality' )
435
+ suite << self.new( 'test_many_with_inequality' ) # This test is slow.. comment out when not needed
436
+ suite
437
+ end
438
+
439
+ end
440
+
441
+ require 'test/unit/ui/console/testrunner'
442
+
443
+ Test::Unit::UI::Console::TestRunner.run( Test_Variable_Test_Node )
444
+
445
+ end
@@ -0,0 +1,587 @@
1
+ module MK
2
+
3
+ require 'test/unit'
4
+ require 'stringio'
5
+
6
+ require 'nist/khammurabi/Engine'
7
+ require 'nist/khammurabi/TestNode'
8
+ require 'nist/khammurabi/VariableTestNode'
9
+ require 'nist/khammurabi/InstantiatorNode'
10
+ require 'nist/khammurabi/ObjectProduction'
11
+ require 'nist/khammurabi/ArrayAddon'
12
+ require 'nist/khammurabi/GraphNode'
13
+ require 'nist/khammurabi/ValueTestSuite'
14
+ require 'nist/khammurabi/ReteParseTreePrinter'
15
+
16
+ class Tester
17
+ attr :val1, true
18
+ attr :val2, true
19
+ attr :val3, true
20
+
21
+ def initialize
22
+ @val1 = @val2 = @val3 = nil
23
+ end
24
+ def setValues( a, b, c )
25
+ @val1 = a
26
+ @val2 = b
27
+ @val3 = c
28
+ end
29
+ def to_s
30
+ "val1: #{self.val1} val2: #{self.val2} val3: #{self.val3}"
31
+ end
32
+ end
33
+
34
+ class Tester2
35
+ attr :val0, true
36
+ attr :val1, true
37
+ attr :val2, true
38
+ attr :val3, true
39
+
40
+ def initialize
41
+ @val0 = @val1 = @val2 = @val3 = nil
42
+ end
43
+ def setValues( a, b, c, d )
44
+ self.val0 = a
45
+ self.val1 = b
46
+ self.val2 = c
47
+ self.val3 = d
48
+ end
49
+ end
50
+
51
+ class Test_Variable_Test_Node_Graph < Test::Unit::TestCase
52
+
53
+ attr_accessor :graphA
54
+
55
+ def objectA
56
+ t = Tester.new
57
+ t.val1 = 5
58
+ t.val2 = 10
59
+ #t.val3 = 15
60
+ t
61
+ end
62
+
63
+ def test_two_variables
64
+ size = 2
65
+ objects = Array.new( size ) { Tester.new }
66
+ objects[ 0 ].val1 = objects[ 0 ].val2 = objects[ 1 ].val1 = 6
67
+ objects[ 1 ].val2 = 7
68
+ objects[ 0 ].val3 = objects[ 1 ].val3 = 8
69
+
70
+ objectProduction = ObjectProduction.new
71
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
72
+ objectDescriptions.each_index do |idx|
73
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
74
+ objectDescriptions[ idx ].parseObject
75
+ objectDescriptions[ idx ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
76
+ objectProduction.addObjectDescription( objectDescriptions[ idx ] )
77
+ end
78
+
79
+ graph = Engine.new
80
+ graph.addObjectProduction( objectProduction )
81
+ #graph.setDebugging( true )
82
+ graph.compile
83
+
84
+ #printer = ReteParseTreePrinter.init( graph.root )
85
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
86
+
87
+ ( objects.size - 1 ).times { |idx| graph.addObject( objects[ idx ] ) }
88
+
89
+ oin = graph.leaf( objectProduction )
90
+
91
+ instantiations = oin.instantiations
92
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
93
+
94
+ graph.addObject( objects[ -1 ] )
95
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
96
+ Token.resetTokenIDCount
97
+ end
98
+
99
+ def test_two_variables_with_nonequality
100
+ size = 2
101
+ objects = Array.new( size ) { Tester.new }
102
+ objects[ 0 ].val1 = objects[ 0 ].val2 = objects[ 1 ].val1 = 6
103
+ objects[ 1 ].val2 = 7
104
+ objects[ 0 ].val3 = 1
105
+ objects[ 1 ].val3 = 2
106
+
107
+ objectProduction = ObjectProduction.new
108
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
109
+ objectDescriptions.each_index do |idx|
110
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
111
+ objectDescriptions[ idx ].parseObject
112
+ objectDescriptions[ idx ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
113
+ objectProduction.addObjectDescription( objectDescriptions[ idx ] )
114
+ end
115
+
116
+ graph = Engine.new
117
+ graph.addObjectProduction( objectProduction )
118
+ #graph.setDebugging( true )
119
+ graph.compile
120
+
121
+ ( objects.size ).times { |idx| graph.addObject( objects[ idx ] ) }
122
+
123
+ oin = graph.leaf( objectProduction )
124
+
125
+ instantiations = oin.instantiations
126
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
127
+
128
+ # Match the objects now and make sure it works
129
+ finalObject = Tester.new
130
+ finalObject.val1, finalObject.val2, finalObject.val3 = 6, 6, 2
131
+ graph.addObject( finalObject )
132
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
133
+ Token.resetTokenIDCount
134
+ end
135
+
136
+ def test_two_variables_with_nonequality2
137
+ size = 2
138
+ objects = Array.new( size ) { Tester.new }
139
+ objects[ 0 ].setValues( 6, 7, nil )
140
+ objects[ 1 ].setValues( 7, 8, nil )
141
+
142
+ objectProduction = ObjectProduction.new
143
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
144
+ objectDescriptions.each_index do |idx|
145
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
146
+ objectDescriptions[ idx ].parseObject
147
+ objectProduction.addObjectDescription( objectDescriptions[ idx ] )
148
+ end
149
+
150
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val2", "Y", MK::InequalityTest.new )
151
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
152
+
153
+ graph = Engine.new
154
+ graph.addObjectProduction( objectProduction )
155
+ #graph.setDebugging( true )
156
+ graph.compile
157
+
158
+ #printer = ReteParseTreePrinter.init( graph.root )
159
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
160
+ #exit
161
+
162
+ ( objects.size - 1 ).times { |idx| graph.addObject( objects[ idx ] ) }
163
+
164
+ oin = graph.leaf( objectProduction )
165
+
166
+ instantiations = oin.instantiations
167
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
168
+
169
+ # Match the objects now and make sure it works
170
+ graph.addObject( objects[ -1 ] )
171
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
172
+ Token.resetTokenIDCount
173
+ end
174
+
175
+ def test_three_variables
176
+ size = 3
177
+ objects = Array.new( size ) { Tester.new }
178
+ objects[ 0 ].val1, objects[ 1 ].val1, objects[ 2 ].val1 = 6, 10, 6
179
+ objects[ 0 ].val2, objects[ 1 ].val2, objects[ 2 ].val2 = 2, 2, 8
180
+ objects[ 0 ].val1, objects[ 1 ].val3, objects[ 2 ].val3 = 42, 7, 7
181
+
182
+ objectProduction = ObjectProduction.new
183
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
184
+ objectDescriptions.each_index do |idx|
185
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
186
+ objectDescriptions[ idx ].parseObject
187
+ end
188
+
189
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
190
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
191
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
192
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
193
+
194
+ objectDescriptions.each { |od| objectProduction.addObjectDescription( od ) }
195
+
196
+ graph = Engine.new
197
+ graph.addObjectProduction( objectProduction )
198
+ #graph.setDebugging( true )
199
+ graph.compile
200
+
201
+ #printer = ReteParseTreePrinter.init( graph.root )
202
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
203
+ #exit
204
+
205
+ ( objects.size - 1 ).times do |idx|
206
+ #print "\n\nAdding object idx: #{idx} and it is: #{objects[idx].to_s}\n\n"
207
+ graph.addObject( objects[ idx ] )
208
+ end
209
+
210
+ oin = graph.leaf( objectProduction )
211
+
212
+ instantiations = oin.instantiations
213
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
214
+
215
+ #print "\n\nAdding object idx: #{objects.size - 1} it is: #{objects[-1].to_s}\n\n"
216
+ graph.addObject( objects[ -1 ] )
217
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
218
+ Token.resetTokenIDCount
219
+ end
220
+
221
+ def test_three_same_variables
222
+ size = 3
223
+ objects = Array.new( size ) { Tester.new }
224
+ objects[ 0 ].setValues( 5, 5, 5 )
225
+ objects[ 1 ].setValues( 5, 5, 5 )
226
+ objects[ 2 ].setValues( 5, 5, 5 )
227
+
228
+ objectProduction = ObjectProduction.new
229
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
230
+ objectDescriptions.each_index do |idx|
231
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
232
+ objectDescriptions[ idx ].parseObject
233
+ end
234
+
235
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
236
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
237
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
238
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
239
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
240
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
241
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val1", "Z", MK::EqualityTest.new )
242
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val1", "Z", MK::EqualityTest.new )
243
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val1", "Z", MK::EqualityTest.new )
244
+
245
+ objectDescriptions.each { |od| objectProduction.addObjectDescription( od ) }
246
+
247
+ #self.outfile = "outfile"
248
+ #self.type == 2
249
+
250
+ graph = Engine.new
251
+ graph.addObjectProduction( objectProduction )
252
+ #graph.setDebugging( true )
253
+ graph.compile
254
+
255
+ #print "TEST_THREE_SAME_VARIABLES\n"
256
+ #printer = ReteParseTreePrinter.init( graph.root )
257
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
258
+ #exit
259
+
260
+ ( objects.size - 1 ).times do |idx|
261
+ #print "\n\nadding object idx: #{idx} and it is: #{objects[idx].to_s}\n\n"
262
+ graph.addObject( objects[ idx ] )
263
+ end
264
+
265
+ oin = graph.leaf( objectProduction )
266
+ instantiations = oin.instantiations
267
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
268
+
269
+ #print "\n\nadding object idx: #{objects.size - 1} it is: #{objects[-1].to_s}\n\n"
270
+ graph.addObject( objects[ -1 ] )
271
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
272
+ Token.resetTokenIDCount
273
+ end
274
+
275
+ def test_three_variables9
276
+ size = 3
277
+ objects = Array.new( size ) { Tester.new }
278
+ objects[ 0 ].setValues( 6, 1, 2 )
279
+ objects[ 1 ].setValues( 10, 1, 3 )
280
+ objects[ 2 ].setValues( 7, 2, 3 )
281
+
282
+ objectProduction = ObjectProduction.new
283
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
284
+ objectDescriptions.each_index do |idx|
285
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
286
+ objectDescriptions[ idx ].parseObject
287
+ end
288
+
289
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
290
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
291
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val2", "X", MK::InequalityTest.new )
292
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val3", "Y", MK::InequalityTest.new )
293
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
294
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
295
+
296
+ objectDescriptions.each { |od| objectProduction.addObjectDescription( od ) }
297
+
298
+ #self.outfile = "outfile"
299
+ #self.type == 2
300
+
301
+ graph = Engine.new
302
+ graph.addObjectProduction( objectProduction )
303
+ #graph.setDebugging( true )
304
+ graph.compile
305
+
306
+ #printer = ReteParseTreePrinter.init( graph.root )
307
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
308
+ #exit
309
+
310
+ ( objects.size - 1 ).times do |idx|
311
+ #print "\n\nadding object idx: #{idx} and it is: #{objects[idx].to_s}\n\n"
312
+ graph.addObject( objects[ idx ] )
313
+ end
314
+
315
+ oin = graph.leaf( objectProduction )
316
+ instantiations = oin.instantiations
317
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
318
+
319
+ #print "\n\nadding object idx: #{objects.size - 1} it is: #{objects[-1].to_s}\n\n"
320
+ graph.addObject( objects[ -1 ] )
321
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
322
+ Token.resetTokenIDCount
323
+ end
324
+
325
+ def test_four_same_variables
326
+ size = 4
327
+ objects = Array.new( size ) { Tester.new }
328
+ objects[ 0 ].setValues( 5, 5, 5 )
329
+ objects[ 1 ].setValues( 5, 5, 5 )
330
+ objects[ 2 ].setValues( 5, 5, 5 )
331
+ objects[ 3 ].setValues( 5, 5, 5 )
332
+
333
+ objectProduction = ObjectProduction.new
334
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
335
+ objectDescriptions.each_index do |idx|
336
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
337
+ objectDescriptions[ idx ].parseObject
338
+ end
339
+
340
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
341
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
342
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
343
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val2", "X", MK::EqualityTest.new )
344
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
345
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
346
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
347
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val3", "Y", MK::EqualityTest.new )
348
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val1", "Z", MK::EqualityTest.new )
349
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val1", "Z", MK::EqualityTest.new )
350
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val1", "Z", MK::EqualityTest.new )
351
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val1", "Z", MK::EqualityTest.new )
352
+
353
+ objectDescriptions.each { |od| objectProduction.addObjectDescription( od ) }
354
+
355
+ #self.outfile = "outfile"
356
+ #self.type == 2
357
+
358
+ graph = Engine.new
359
+ graph.addObjectProduction( objectProduction )
360
+ #graph.setDebugging( true )
361
+ graph.compile
362
+
363
+ #printer = ReteParseTreePrinter.init( graph.root )
364
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
365
+ #exit
366
+
367
+ ( objects.size - 1 ).times do |idx|
368
+ #print "\n\nadding object idx: #{idx} and it is: #{objects[idx].to_s}\n\n"
369
+ graph.addObject( objects[ idx ] )
370
+ end
371
+
372
+ oin = graph.leaf( objectProduction )
373
+ instantiations = oin.instantiations
374
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
375
+
376
+ #print "\n\nadding object idx: #{objects.size - 1} it is: #{objects[-1].to_s}\n\n"
377
+ graph.addObject( objects[ -1 ] )
378
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
379
+ Token.resetTokenIDCount
380
+ end
381
+
382
+ def test_four_variables
383
+ size = 4
384
+ objects = Array.new( size ) { Tester.new }
385
+ objects[ 0 ].setValues( 2, 101, 1000 )
386
+ objects[ 1 ].setValues( 5, 3, 4 )
387
+ objects[ 2 ].setValues( 2, 102, 4 )
388
+ objects[ 3 ].setValues( 3, 2, 99 )
389
+
390
+ objectProduction = ObjectProduction.new
391
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
392
+ objectDescriptions.each_index do |idx|
393
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
394
+ objectDescriptions[ idx ].parseObject
395
+ end
396
+
397
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val1", "X", MK::EqualityTest.new )
398
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val1", "X", MK::EqualityTest.new )
399
+
400
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
401
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val2", "Y", MK::InequalityTest.new )
402
+
403
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
404
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
405
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val3", "Z", MK::InequalityTest.new )
406
+ #print "equality: id0: #{objectDescriptions[0].object_id} od1: #{objectDescriptions[1].object_id}\n"
407
+ #print "#{objectDescriptions[0]===objectDescriptions[1]}\n"
408
+ #exit
409
+
410
+ objectDescriptions.each { |od| objectProduction.addObjectDescription( od ) }
411
+
412
+ graph = Engine.new
413
+ graph.addObjectProduction( objectProduction )
414
+ graph.compile
415
+
416
+ #printer = ReteParseTreePrinter.init( graph.root )
417
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
418
+ #exit
419
+
420
+ ( objects.size - 1 ).times do |idx|
421
+ i = ( objects.size - 1 ) - idx
422
+ #print "\n\nadding object idx: #{idx}\n\n"
423
+ graph.addObject( objects[ i ] )
424
+ end
425
+
426
+ oin = graph.leaf( objectProduction )
427
+
428
+ instantiations = oin.instantiations
429
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
430
+
431
+ #print "\n\nadding object idx: #{objects.size - 1}\n\n"
432
+ graph.addObject( objects[ 0 ] )
433
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
434
+ Token.resetTokenIDCount
435
+ end
436
+
437
+ def test_five_variables
438
+ size = 5
439
+ objects = Array.new( size ) { Tester2.new }
440
+ # only variables in this test
441
+ objects[ 0 ].setValues( 5, 1, 2, 3 )
442
+ objects[ 1 ].setValues( 5, 2, 2, 3 )
443
+ objects[ 2 ].setValues( 5, 3, 2, 3 )
444
+ objects[ 3 ].setValues( 5, 4, 2, 3 )
445
+ objects[ 4 ].setValues( 7, 5, 2, 3 )
446
+
447
+ objectProduction = ObjectProduction.new
448
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
449
+ objectDescriptions.each_index do |idx|
450
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
451
+ objectDescriptions[ idx ].parseObject
452
+ #objectDescriptions[ idx ][ "@clusters" ].testMe = false
453
+ end
454
+
455
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val0", "X", MK::EqualityTest.new )
456
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val0", "X", MK::EqualityTest.new )
457
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val0", "X", MK::EqualityTest.new )
458
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val0", "X", MK::EqualityTest.new )
459
+ objectDescriptions[ 4 ].setObjectAsVariable( "@val0", "X", MK::InequalityTest.new )
460
+
461
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
462
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
463
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
464
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
465
+ objectDescriptions[ 4 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
466
+
467
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
468
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
469
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
470
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
471
+ objectDescriptions[ 4 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
472
+
473
+ objectDescriptions.each { |od| objectProduction.addObjectDescription( od ) }
474
+
475
+ graph = Engine.new
476
+ graph.addObjectProduction( objectProduction )
477
+ #graph.setDebugging( true )
478
+ graph.compile
479
+
480
+ #printer = ReteParseTreePrinter.init( graph.root )
481
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
482
+ #exit
483
+
484
+ ( objects.size - 1 ).times do |idx|
485
+ #i = ( objects.size - 1 ) - idx
486
+ #print "\n\nadding object idx: #{idx}\n\n"
487
+ graph.addObject( objects[ idx ] )
488
+ #exit if idx == 1
489
+ end
490
+
491
+ oin = graph.leaf( objectProduction )
492
+
493
+ instantiations = oin.instantiations
494
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
495
+
496
+ #print "\n\nadding object idx: #{objects.size - 1}\n\n"
497
+ graph.addObject( objects[ -1 ] )
498
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
499
+ Token.resetTokenIDCount
500
+ end
501
+
502
+ def test_five_variables_with_many_inequalities
503
+ size = 5
504
+ objects = Array.new( size ) { Tester2.new }
505
+ # only variables in this test
506
+ objects[ 0 ].setValues( 6, 1, 10, 3 )
507
+ objects[ 1 ].setValues( 5, 2, 2, 2 )
508
+ objects[ 2 ].setValues( 100, 3, 2, 3 )
509
+ objects[ 3 ].setValues( 5, 4, 2, 4 )
510
+ objects[ 4 ].setValues( 7, 5, 10, 4 )
511
+
512
+ objectProduction = ObjectProduction.new
513
+ objectDescriptions = Array.new( size ) { ObjectDescription.new }
514
+ objectDescriptions.each_index do |idx|
515
+ objectDescriptions[ idx ].objectDescribing = objects[ idx ]
516
+ objectDescriptions[ idx ].parseObject
517
+ #objectDescriptions[ idx ][ "@clusters" ].testMe = false
518
+ end
519
+
520
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val0", "X", MK::InequalityTest.new )
521
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val0", "X", MK::EqualityTest.new )
522
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val0", "X", MK::InequalityTest.new )
523
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val0", "X", MK::EqualityTest.new )
524
+ objectDescriptions[ 4 ].setObjectAsVariable( "@val0", "X", MK::InequalityTest.new )
525
+
526
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val2", "Y", MK::InequalityTest.new )
527
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
528
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
529
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val2", "Y", MK::EqualityTest.new )
530
+ objectDescriptions[ 4 ].setObjectAsVariable( "@val2", "Y", MK::InequalityTest.new )
531
+
532
+ objectDescriptions[ 0 ].setObjectAsVariable( "@val3", "Z", MK::InequalityTest.new )
533
+ objectDescriptions[ 1 ].setObjectAsVariable( "@val3", "Z", MK::InequalityTest.new )
534
+ objectDescriptions[ 2 ].setObjectAsVariable( "@val3", "Z", MK::InequalityTest.new )
535
+ objectDescriptions[ 3 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
536
+ objectDescriptions[ 4 ].setObjectAsVariable( "@val3", "Z", MK::EqualityTest.new )
537
+
538
+ objectDescriptions.each { |od| objectProduction.addObjectDescription( od ) }
539
+
540
+ graph = Engine.new
541
+ graph.addObjectProduction( objectProduction )
542
+ #graph.setDebugging( true )
543
+ graph.compile
544
+
545
+ #printer = ReteParseTreePrinter.init( graph.root )
546
+ #print "\n\n" + printer.printOn( StringIO.new ).string + "\n\n"
547
+ #exit
548
+
549
+ ( objects.size - 1 ).times do |idx|
550
+ #i = ( objects.size - 1 ) - idx
551
+ #print "\n\nadding object idx: #{idx}\n\n"
552
+ graph.addObject( objects[ idx ] )
553
+ #exit if idx == 1
554
+ end
555
+
556
+ oin = graph.leaf( objectProduction )
557
+
558
+ instantiations = oin.instantiations
559
+ assert( instantiations.size == 0, "Instantiations size isn't 0, it's #{instantiations.size}" )
560
+
561
+ #print "\n\nadding object idx: #{objects.size - 1}\n\n"
562
+ graph.addObject( objects[ -1 ] )
563
+ assert( instantiations.size == 1, "Instantiations size isn't 1, it's #{instantiations.size}" )
564
+ Token.resetTokenIDCount
565
+ end
566
+
567
+ def self.suite
568
+ suite = Test::Unit::TestSuite.new
569
+ suite << self.new( 'test_two_variables' )
570
+ suite << self.new( 'test_two_variables_with_nonequality' )
571
+ suite << self.new( 'test_two_variables_with_nonequality2' )
572
+ suite << self.new( 'test_three_same_variables' )
573
+ suite << self.new( 'test_three_variables9' )
574
+ suite << self.new( 'test_four_variables' )
575
+ suite << self.new( 'test_four_same_variables' )
576
+ suite << self.new( 'test_five_variables' )
577
+ suite << self.new( 'test_five_variables_with_many_inequalities' )
578
+ suite
579
+ end
580
+
581
+ end
582
+
583
+ require 'test/unit/ui/console/testrunner'
584
+
585
+ Test::Unit::UI::Console::TestRunner.run( Test_Variable_Test_Node_Graph )
586
+
587
+ end