khammurabi 0.2
Sign up to get free protection for your applications and to get access to all the features.
- data/khammurabi-0.2/docs/classes/Array.html +563 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000004.html +21 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000005.html +18 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000006.html +27 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000007.html +23 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000008.html +29 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000009.html +47 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000010.html +19 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000011.html +22 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000012.html +22 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000013.html +22 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000014.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000015.html +20 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000016.html +29 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000017.html +25 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000018.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000019.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000020.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000021.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000022.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000023.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000024.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000025.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000026.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000027.html +16 -0
- data/khammurabi-0.2/docs/classes/Array.src/M000028.html +16 -0
- data/khammurabi-0.2/docs/classes/FalseClass.html +139 -0
- data/khammurabi-0.2/docs/classes/FalseClass.src/M000003.html +16 -0
- data/khammurabi-0.2/docs/classes/Fixnum.html +139 -0
- data/khammurabi-0.2/docs/classes/Fixnum.src/M000041.html +22 -0
- data/khammurabi-0.2/docs/classes/Hash.html +163 -0
- data/khammurabi-0.2/docs/classes/Hash.src/M000001.html +28 -0
- data/khammurabi-0.2/docs/classes/Hash.src/M000002.html +22 -0
- data/khammurabi-0.2/docs/classes/Hostilities.html +187 -0
- data/khammurabi-0.2/docs/classes/Hostilities.src/M000043.html +16 -0
- data/khammurabi-0.2/docs/classes/Hostilities.src/M000044.html +16 -0
- data/khammurabi-0.2/docs/classes/Hostilities.src/M000045.html +16 -0
- data/khammurabi-0.2/docs/classes/Hostilities.src/M000046.html +24 -0
- data/khammurabi-0.2/docs/classes/MK.html +330 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.html +200 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.src/M000194.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.src/M000195.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDelete.src/M000196.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.html +197 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.src/M000106.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.src/M000107.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectDeleteFromWorkingMemory.src/M000108.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectInsert.html +182 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectInsert.src/M000292.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectInsert.src/M000293.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.html +199 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.src/M000289.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.src/M000290.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ActionObjectModifyWorkingMemory.src/M000291.html +34 -0
- data/khammurabi-0.2/docs/classes/MK/ActionOutput.html +236 -0
- data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000226.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000227.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000228.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000229.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ActionOutput.src/M000230.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.html +273 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000282.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000283.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000284.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000285.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000286.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000287.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ArbitratorNode.src/M000288.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.html +475 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000329.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000330.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000331.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000332.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000333.html +26 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000334.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000335.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000336.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000337.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000338.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000339.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000340.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000341.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000342.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000343.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000344.html +31 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000345.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000346.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000347.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000348.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Cluster.src/M000349.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.html +521 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000305.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000306.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000307.html +29 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000308.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000309.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000310.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000311.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000312.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000313.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000314.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000315.html +32 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000316.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000317.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000318.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000319.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000320.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000321.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000322.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000323.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000324.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000325.html +30 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000326.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000327.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ClusterManager.src/M000328.html +39 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.html +271 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000186.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000187.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000188.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000189.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000190.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000191.html +33 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000192.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantObjectOperation.src/M000193.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.html +185 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.src/M000251.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.src/M000252.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ConstantTestNode.src/M000253.html +41 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.html +770 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000115.html +30 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000116.html +32 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000117.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000118.html +29 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000119.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000120.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000121.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000122.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000123.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000124.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000125.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000126.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000127.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000128.html +153 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000129.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000130.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000131.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000132.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000133.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000134.html +46 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000135.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000136.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000137.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000138.html +29 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000139.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000140.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000141.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000142.html +27 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000143.html +26 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000144.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000145.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Engine.src/M000146.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/EqualityTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/EqualityTest.src/M000092.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/EqualityTest.src/M000093.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/EqualityTest.src/M000094.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/FalseTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/FalseTest.src/M000397.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/FalseTest.src/M000398.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/FalseTest.src/M000399.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.html +823 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000361.html +28 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000362.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000363.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000364.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000365.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000366.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000367.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000368.html +26 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000369.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000370.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000371.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000372.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000373.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000374.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000375.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000376.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000377.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000378.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000379.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000380.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000381.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000382.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000383.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000384.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000385.html +31 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000386.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000387.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000388.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000389.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000390.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000391.html +50 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000392.html +31 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000393.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000394.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000395.html +17 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNode.src/M000396.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.html +261 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000276.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000277.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000278.html +30 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000279.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000280.html +29 -0
- data/khammurabi-0.2/docs/classes/MK/GraphNodeJoiner.src/M000281.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.src/M000095.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.src/M000096.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanOrEqualTest.src/M000097.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.src/M000112.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.src/M000113.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/GreaterThanTest.src/M000114.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/IncorporatorTest.html +139 -0
- data/khammurabi-0.2/docs/classes/MK/IncorporatorTest.src/M000294.html +36 -0
- data/khammurabi-0.2/docs/classes/MK/InequalityTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/InequalityTest.src/M000231.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/InequalityTest.src/M000232.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/InequalityTest.src/M000233.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.html +194 -0
- data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.src/M000083.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.src/M000084.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/InstantiatorNode.src/M000085.html +45 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.src/M000109.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.src/M000110.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanOrEqualTest.src/M000111.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanTest.src/M000089.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanTest.src/M000090.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/LessThanTest.src/M000091.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Message.html +167 -0
- data/khammurabi-0.2/docs/classes/MK/Message.src/M000081.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Message.src/M000082.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.html +291 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000243.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000244.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000245.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000246.html +35 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000247.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000248.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000249.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenArbitratorNode.src/M000250.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.html +219 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000161.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000162.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000163.html +54 -0
- data/khammurabi-0.2/docs/classes/MK/MultiChildrenSelectorNode.src/M000164.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.html +564 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000059.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000060.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000061.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000062.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000063.html +29 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000064.html +36 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000065.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000066.html +28 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000067.html +26 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000068.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000069.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000070.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000071.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000072.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000073.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000074.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000075.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000076.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000077.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000078.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000079.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectDescription.src/M000080.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.html +256 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000180.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000181.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000182.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000183.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000184.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectGraphWrapper.src/M000185.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.src/M000400.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.src/M000401.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDEqualityTest.src/M000402.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.src/M000056.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.src/M000057.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectIDInequalityTest.src/M000058.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.html +290 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000098.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000099.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000100.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000101.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000102.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000103.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000104.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectOperation.src/M000105.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProduction.html +223 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000239.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000240.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000241.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProduction.src/M000242.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.html +211 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.src/M000273.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.src/M000274.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ObjectProductionAction.src/M000275.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.html +259 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.src/M000298.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.src/M000299.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.src/M000300.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.src/M000301.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.src/M000302.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.src/M000303.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Pair.src/M000304.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.html +289 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000174.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000175.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000176.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000177.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000178.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeNode.src/M000179.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.html +230 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000234.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000235.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000236.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000237.html +36 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreePrinter.src/M000238.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.html +219 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000170.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000171.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000172.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ReteParseTreeToObjectDescriptionConverter.src/M000173.html +60 -0
- data/khammurabi-0.2/docs/classes/MK/RootNode.html +181 -0
- data/khammurabi-0.2/docs/classes/MK/RootNode.src/M000295.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/RootNode.src/M000296.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/RootNode.src/M000297.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.html +247 -0
- data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000165.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000166.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000167.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000168.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/TestIDRegistrar.src/M000169.html +28 -0
- data/khammurabi-0.2/docs/classes/MK/TestNode.html +203 -0
- data/khammurabi-0.2/docs/classes/MK/TestNode.src/M000350.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/TestNode.src/M000351.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/TestNode.src/M000352.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.html +541 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000254.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000255.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000256.html +31 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000257.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000258.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000259.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000260.html +28 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000261.html +26 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000262.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000263.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000264.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000265.html +33 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000266.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000267.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000268.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000269.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000270.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000271.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/Token.src/M000272.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.html +369 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000211.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000212.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000213.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000214.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000215.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000216.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000217.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000218.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000219.html +34 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000220.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000221.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000222.html +31 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000223.html +92 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000224.html +31 -0
- data/khammurabi-0.2/docs/classes/MK/TokenCluster.src/M000225.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/TokenClusterManager.html +156 -0
- data/khammurabi-0.2/docs/classes/MK/TokenClusterManager.src/M000209.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/TokenClusterManager.src/M000210.html +34 -0
- data/khammurabi-0.2/docs/classes/MK/TrueTest.html +177 -0
- data/khammurabi-0.2/docs/classes/MK/TrueTest.src/M000053.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/TrueTest.src/M000054.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/TrueTest.src/M000055.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.html +258 -0
- data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000203.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000204.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000205.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000206.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000207.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/UniqueTokenAssurerNode.src/M000208.html +62 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.html +275 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000153.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000154.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000155.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000156.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000157.html +30 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000158.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000159.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ValueTest.src/M000160.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.html +260 -0
- data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000197.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000198.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000199.html +48 -0
- data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000200.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000201.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/VariableObjectOperation.src/M000202.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.html +317 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000353.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000354.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000355.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000356.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000357.html +23 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000358.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000359.html +25 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNode.src/M000360.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.html +249 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000147.html +22 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000148.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000149.html +16 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000150.html +19 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000151.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/VariableTestNodeExecutor.src/M000152.html +216 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccEngine.html +191 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccEngine.src/M000051.html +122 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccEngine.src/M000052.html +69 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccParseInput.html +172 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccParseInput.src/M000049.html +24 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccParseInput.src/M000050.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccParseSpecification.html +174 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccParseSpecification.src/M000047.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/XiaccParseSpecification.src/M000048.html +20 -0
- data/khammurabi-0.2/docs/classes/MK/ZombieNode.html +181 -0
- data/khammurabi-0.2/docs/classes/MK/ZombieNode.src/M000086.html +21 -0
- data/khammurabi-0.2/docs/classes/MK/ZombieNode.src/M000087.html +18 -0
- data/khammurabi-0.2/docs/classes/MK/ZombieNode.src/M000088.html +17 -0
- data/khammurabi-0.2/docs/classes/Object.html +345 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000029.html +21 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000030.html +19 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000031.html +24 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000032.html +19 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000033.html +18 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000034.html +22 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000035.html +16 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000036.html +16 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000037.html +16 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000038.html +16 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000039.html +16 -0
- data/khammurabi-0.2/docs/classes/Object.src/M000040.html +16 -0
- data/khammurabi-0.2/docs/classes/TrueClass.html +139 -0
- data/khammurabi-0.2/docs/classes/TrueClass.src/M000042.html +16 -0
- data/khammurabi-0.2/docs/created.rid +1 -0
- data/khammurabi-0.2/docs/files/License_txt.html +136 -0
- data/khammurabi-0.2/docs/files/ReadMe_txt.html +351 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectDeleteFromWorkingMemory_rb.html +109 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectDelete_rb.html +109 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectInsert_rb.html +109 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ActionObjectModifyWorkingMemory_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ActionOutput_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ArbitratorNode_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ArrayAddon_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/BooleanAddon_rb.html +101 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ClusterManager2_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ClusterManager_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/Cluster_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ConstantObjectOperation_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ConstantTestNode_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/Engine_rb.html +128 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/FixnumAddon_rb.html +101 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/GraphNodeJoiner_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/GraphNode_rb.html +109 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/HashAddon_rb.html +101 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/Hostilities_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/InstantiatorNode_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/Message_rb.html +101 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/MultiChildrenArbitratorNode_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/MultiChildrenSelectorNode_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectAddon_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectDescription_rb.html +112 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectGraphWrapper_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectOperation_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectProductionAction_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ObjectProduction_rb.html +109 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/Pair_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/QueryNode_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ReteParseTreeNode_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ReteParseTreePrinter_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ReteParseTreeToObjectDescriptionConverter_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/RootNode_rb.html +109 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/TestIDRegistrar_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/TestNode_rb.html +109 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/TokenClusterManager_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/TokenCluster_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/Token_rb.html +112 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/UniqueTokenAssurerNode_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ValueTestSuite_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/VariableObjectOperation_rb.html +112 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/VariableTestNodeExecutor_rb.html +110 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/VariableTestNode_rb.html +111 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/XiaccEngine_rb.html +126 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/XiaccParseInput_rb.html +108 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/XiaccParseSpecification_rb.html +101 -0
- data/khammurabi-0.2/docs/files/nist/khammurabi/ZombieNode_rb.html +108 -0
- data/khammurabi-0.2/docs/fr_class_index.html +86 -0
- data/khammurabi-0.2/docs/fr_file_index.html +77 -0
- data/khammurabi-0.2/docs/fr_method_index.html +428 -0
- data/khammurabi-0.2/docs/index.html +24 -0
- data/khammurabi-0.2/docs/rdoc-style.css +208 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectDelete.rb +35 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectDeleteFromWorkingMemory.rb +34 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectInsert.rb +29 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ActionObjectModifyWorkingMemory.rb +53 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ActionOutput.rb +45 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ArbitratorNode.rb +68 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ArrayAddon.rb +201 -0
- data/khammurabi-0.2/lib/nist/khammurabi/BooleanAddon.rb +3 -0
- data/khammurabi-0.2/lib/nist/khammurabi/Cluster.rb +128 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ClusterManager.rb +96 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ClusterManager2.rb +103 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ConstantObjectOperation.rb +92 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ConstantTestNode.rb +59 -0
- data/khammurabi-0.2/lib/nist/khammurabi/Engine.rb +454 -0
- data/khammurabi-0.2/lib/nist/khammurabi/FixnumAddon.rb +14 -0
- data/khammurabi-0.2/lib/nist/khammurabi/GraphNode.rb +305 -0
- data/khammurabi-0.2/lib/nist/khammurabi/GraphNodeJoiner.rb +83 -0
- data/khammurabi-0.2/lib/nist/khammurabi/HashAddon.rb +29 -0
- data/khammurabi-0.2/lib/nist/khammurabi/Hostilities.rb +24 -0
- data/khammurabi-0.2/lib/nist/khammurabi/InstantiatorNode.rb +60 -0
- data/khammurabi-0.2/lib/nist/khammurabi/Message.rb +19 -0
- data/khammurabi-0.2/lib/nist/khammurabi/MultiChildrenArbitratorNode.rb +97 -0
- data/khammurabi-0.2/lib/nist/khammurabi/MultiChildrenSelectorNode.rb +77 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ObjectAddon.rb +63 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ObjectDescription.rb +192 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ObjectGraphWrapper.rb +46 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ObjectOperation.rb +59 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ObjectProduction.rb +45 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ObjectProductionAction.rb +31 -0
- data/khammurabi-0.2/lib/nist/khammurabi/Pair.rb +49 -0
- data/khammurabi-0.2/lib/nist/khammurabi/QueryNode.rb +44 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ReteParseTreeNode.rb +66 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ReteParseTreePrinter.rb +58 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ReteParseTreeToObjectDescriptionConverter.rb +76 -0
- data/khammurabi-0.2/lib/nist/khammurabi/RootNode.rb +32 -0
- data/khammurabi-0.2/lib/nist/khammurabi/TODO +7 -0
- data/khammurabi-0.2/lib/nist/khammurabi/TestIDRegistrar.rb +63 -0
- data/khammurabi-0.2/lib/nist/khammurabi/TestNode.rb +33 -0
- data/khammurabi-0.2/lib/nist/khammurabi/Token.rb +168 -0
- data/khammurabi-0.2/lib/nist/khammurabi/TokenCluster.rb +177 -0
- data/khammurabi-0.2/lib/nist/khammurabi/TokenClusterManager.rb +36 -0
- data/khammurabi-0.2/lib/nist/khammurabi/UniqueTokenAssurerNode.rb +100 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ValueTestSuite.rb +239 -0
- data/khammurabi-0.2/lib/nist/khammurabi/VariableObjectOperation.rb +87 -0
- data/khammurabi-0.2/lib/nist/khammurabi/VariableTestNode.rb +73 -0
- data/khammurabi-0.2/lib/nist/khammurabi/VariableTestNodeExecutor.rb +246 -0
- data/khammurabi-0.2/lib/nist/khammurabi/XiaccEngine.rb +201 -0
- data/khammurabi-0.2/lib/nist/khammurabi/XiaccParseInput.rb +27 -0
- data/khammurabi-0.2/lib/nist/khammurabi/XiaccParseSpecification.rb +25 -0
- data/khammurabi-0.2/lib/nist/khammurabi/ZombieNode.rb +24 -0
- data/khammurabi-0.2/tests/test_action_object_delete.rb +91 -0
- data/khammurabi-0.2/tests/test_action_object_insert.rb +89 -0
- data/khammurabi-0.2/tests/test_action_object_modify.rb +103 -0
- data/khammurabi-0.2/tests/test_array_addon.rb +214 -0
- data/khammurabi-0.2/tests/test_cluster.rb +188 -0
- data/khammurabi-0.2/tests/test_cluster_graph.rb +393 -0
- data/khammurabi-0.2/tests/test_cluster_manager.rb +204 -0
- data/khammurabi-0.2/tests/test_constant_object_operation.rb +112 -0
- data/khammurabi-0.2/tests/test_constant_test_node.rb +142 -0
- data/khammurabi-0.2/tests/test_constant_test_node_graph.rb +404 -0
- data/khammurabi-0.2/tests/test_graph.rb +843 -0
- data/khammurabi-0.2/tests/test_graph_node_joiner.rb +94 -0
- data/khammurabi-0.2/tests/test_hash_addon.rb +90 -0
- data/khammurabi-0.2/tests/test_insurance_with_variables.rb +143 -0
- data/khammurabi-0.2/tests/test_multi_children_arbitrator_node.rb +149 -0
- data/khammurabi-0.2/tests/test_multi_children_selector_node.rb +203 -0
- data/khammurabi-0.2/tests/test_object_description.rb +177 -0
- data/khammurabi-0.2/tests/test_person_graph.rb +202 -0
- data/khammurabi-0.2/tests/test_root_node.rb +101 -0
- data/khammurabi-0.2/tests/test_token.rb +166 -0
- data/khammurabi-0.2/tests/test_token_cluster.rb +324 -0
- data/khammurabi-0.2/tests/test_unique_token_assurer_node.rb +146 -0
- data/khammurabi-0.2/tests/test_value_tests.rb +131 -0
- data/khammurabi-0.2/tests/test_variable_object_operation.rb +181 -0
- data/khammurabi-0.2/tests/test_variable_test_node.rb +445 -0
- data/khammurabi-0.2/tests/test_variable_test_node_graph.rb +587 -0
- data/khammurabi-0.2/tests/test_zombie_node.rb +130 -0
- 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
|