gecoder-with-gecode 0.9.0 → 0.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (919) hide show
  1. data/CHANGES +6 -0
  2. data/README +1 -1
  3. data/THANKS +18 -0
  4. data/example/equation_system.rb +3 -1
  5. data/example/magic_sequence.rb +3 -1
  6. data/example/queens.rb +3 -1
  7. data/example/send_more_money.rb +24 -30
  8. data/example/send_most_money.rb +15 -26
  9. data/example/square_tiling.rb +3 -1
  10. data/example/sudoku-set.rb +3 -1
  11. data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
  12. data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
  13. data/ext/gecode-2.2.0/Makefile.dep +8056 -0
  14. data/ext/gecode-2.2.0/Makefile.in +1590 -0
  15. data/ext/gecode-2.2.0/changelog.in +2698 -0
  16. data/ext/gecode-2.2.0/configure +13112 -0
  17. data/ext/gecode-2.2.0/configure.ac +273 -0
  18. data/ext/gecode-2.2.0/configure.ac.in +269 -0
  19. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
  20. data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
  21. data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
  22. data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
  23. data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
  24. data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
  25. data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
  26. data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
  27. data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
  28. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
  29. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
  30. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
  31. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
  32. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
  33. data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
  34. data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
  35. data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
  36. data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
  37. data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
  38. data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
  39. data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
  40. data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
  41. data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
  42. data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
  43. data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
  44. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
  45. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
  46. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
  47. data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
  48. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
  49. data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
  50. data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
  51. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
  52. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
  53. data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
  54. data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
  55. data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
  56. data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
  57. data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
  58. data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
  59. data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
  60. data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
  61. data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
  62. data/ext/gecode-2.2.0/examples/crew.cc +286 -0
  63. data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
  64. data/ext/gecode-2.2.0/examples/domino.cc +297 -0
  65. data/ext/gecode-2.2.0/examples/donald.cc +107 -0
  66. data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
  67. data/ext/gecode-2.2.0/examples/golf.cc +297 -0
  68. data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
  69. data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
  70. data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
  71. data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
  72. data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
  73. data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
  74. data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
  75. data/ext/gecode-2.2.0/examples/knights.cc +220 -0
  76. data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
  77. data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
  78. data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
  79. data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
  80. data/ext/gecode-2.2.0/examples/money.cc +105 -0
  81. data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
  82. data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
  83. data/ext/gecode-2.2.0/examples/partition.cc +141 -0
  84. data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
  85. data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
  86. data/ext/gecode-2.2.0/examples/photo.cc +170 -0
  87. data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
  88. data/ext/gecode-2.2.0/examples/queens.cc +147 -0
  89. data/ext/gecode-2.2.0/examples/queens.js +57 -0
  90. data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
  91. data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
  92. data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
  93. data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
  94. data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
  95. data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
  96. data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
  97. data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
  98. data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
  99. data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
  100. data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
  101. data/ext/gecode-2.2.0/examples/support.hh +338 -0
  102. data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
  103. data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
  104. data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
  105. data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
  106. data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
  107. data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
  108. data/ext/gecode-2.2.0/gecode.m4 +1046 -0
  109. data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
  110. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
  111. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
  112. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
  113. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
  114. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
  115. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
  116. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
  117. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
  118. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
  119. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
  120. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
  121. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
  122. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
  123. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
  124. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
  125. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
  126. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
  127. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
  128. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
  129. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
  130. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
  131. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
  132. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
  133. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
  134. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
  135. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
  136. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
  137. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
  138. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
  139. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
  140. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
  141. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
  142. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
  143. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
  144. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
  145. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
  146. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
  147. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
  148. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
  149. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
  150. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
  151. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
  152. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
  153. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
  154. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
  155. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
  156. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
  157. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
  158. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
  159. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
  160. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
  161. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
  162. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
  163. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
  164. data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
  165. data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
  166. data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
  167. data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
  168. data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
  169. data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
  170. data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
  171. data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
  172. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
  173. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
  174. data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
  175. data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
  176. data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
  177. data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
  178. data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
  179. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
  180. data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
  181. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
  182. data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
  183. data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
  184. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
  185. data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
  186. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
  187. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
  188. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
  189. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
  190. data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
  191. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
  192. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
  193. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
  194. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
  195. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
  196. data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
  197. data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
  198. data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
  199. data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
  200. data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
  201. data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
  202. data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
  203. data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
  204. data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
  205. data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
  206. data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
  207. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
  208. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
  209. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
  210. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
  211. data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
  212. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
  213. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
  214. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
  215. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
  216. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
  217. data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
  218. data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
  219. data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
  220. data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
  221. data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
  222. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
  223. data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
  224. data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
  225. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
  226. data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
  227. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
  228. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
  229. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
  230. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
  231. data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
  232. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
  233. data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
  234. data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
  235. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
  236. data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
  237. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
  238. data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
  239. data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
  240. data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
  241. data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
  242. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
  243. data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
  244. data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
  245. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
  246. data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
  247. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
  248. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
  249. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
  250. data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
  251. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
  252. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
  253. data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
  254. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
  255. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
  256. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
  257. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
  258. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
  259. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
  260. data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
  261. data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
  262. data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
  263. data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
  264. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
  265. data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
  266. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
  267. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
  268. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
  269. data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
  270. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
  271. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
  272. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
  273. data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
  274. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
  275. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
  276. data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
  277. data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
  278. data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
  279. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
  280. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
  281. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
  282. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
  283. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
  284. data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
  285. data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
  286. data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
  287. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
  288. data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
  289. data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
  290. data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
  291. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
  292. data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
  293. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
  294. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
  295. data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
  296. data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
  297. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
  298. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
  299. data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
  300. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
  301. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
  302. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
  303. data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
  304. data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
  305. data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
  306. data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
  307. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
  308. data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
  309. data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
  310. data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
  311. data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
  312. data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
  313. data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
  314. data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
  315. data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
  316. data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
  317. data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
  318. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
  319. data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
  320. data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
  321. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
  322. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
  323. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
  324. data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
  325. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
  326. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
  327. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
  328. data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
  329. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
  330. data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
  331. data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
  332. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
  333. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
  334. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
  335. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
  336. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
  337. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
  338. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
  339. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
  340. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
  341. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
  342. data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
  343. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
  344. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
  345. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
  346. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
  347. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
  348. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
  349. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
  350. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
  351. data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
  352. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
  353. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
  354. data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
  355. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
  356. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
  357. data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
  358. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
  359. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
  360. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
  361. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
  362. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
  363. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
  364. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
  365. data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
  366. data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
  367. data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
  368. data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
  369. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
  370. data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
  371. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
  372. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
  373. data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
  374. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
  375. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
  376. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
  377. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
  378. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
  379. data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
  380. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
  381. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
  382. data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
  383. data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
  384. data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
  385. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
  386. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
  387. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
  388. data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
  389. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
  390. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
  391. data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
  392. data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
  393. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
  394. data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
  395. data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
  396. data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
  397. data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
  398. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
  399. data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
  400. data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
  401. data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
  402. data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
  403. data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
  404. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
  405. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
  406. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
  407. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
  408. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
  409. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
  410. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
  411. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
  412. data/ext/gecode-2.2.0/gecode/search.hh +759 -0
  413. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
  414. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
  415. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
  416. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
  417. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
  418. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
  419. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
  420. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
  421. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
  422. data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
  423. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
  424. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
  425. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
  426. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
  427. data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
  428. data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
  429. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
  430. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
  431. data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
  432. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
  433. data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
  434. data/ext/gecode-2.2.0/gecode/set.hh +970 -0
  435. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
  436. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
  437. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
  438. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
  439. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
  440. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
  441. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
  442. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
  443. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
  444. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
  445. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
  446. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
  447. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
  448. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
  449. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
  450. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
  451. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
  452. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
  453. data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
  454. data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
  455. data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
  456. data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
  457. data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
  458. data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
  459. data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
  460. data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
  461. data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
  462. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
  463. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
  464. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
  465. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
  466. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
  467. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
  468. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
  469. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
  470. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
  471. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
  472. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
  473. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
  474. data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
  475. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
  476. data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
  477. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
  478. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
  479. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
  480. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
  481. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
  482. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
  483. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
  484. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
  485. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
  486. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
  487. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
  488. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
  489. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
  490. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
  491. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
  492. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
  493. data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
  494. data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
  495. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
  496. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
  497. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
  498. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
  499. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
  500. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
  501. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
  502. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
  503. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
  504. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
  505. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
  506. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
  507. data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
  508. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
  509. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
  510. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
  511. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
  512. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
  513. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
  514. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
  515. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
  516. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
  517. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
  518. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
  519. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
  520. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
  521. data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
  522. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
  523. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
  524. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
  525. data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
  526. data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
  527. data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
  528. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
  529. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
  530. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
  531. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
  532. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
  533. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
  534. data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
  535. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
  536. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
  537. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
  538. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
  539. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
  540. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
  541. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
  542. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
  543. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
  544. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
  545. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
  546. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
  547. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
  548. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
  549. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
  550. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
  551. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
  552. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
  553. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
  554. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
  555. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
  556. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
  557. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
  558. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
  559. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
  560. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
  561. data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
  562. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
  563. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
  564. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
  565. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
  566. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
  567. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
  568. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
  569. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
  570. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
  571. data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
  572. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
  573. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
  574. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
  575. data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
  576. data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
  577. data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
  578. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
  579. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
  580. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
  581. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
  582. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
  583. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
  584. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
  585. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
  586. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
  587. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
  588. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
  589. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
  590. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
  591. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
  592. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
  593. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
  594. data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
  595. data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
  596. data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
  597. data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
  598. data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
  599. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
  600. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
  601. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
  602. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
  603. data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
  604. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
  605. data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
  606. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
  607. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
  608. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
  609. data/ext/gecode-2.2.0/test/assign.cc +181 -0
  610. data/ext/gecode-2.2.0/test/assign.hh +93 -0
  611. data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
  612. data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
  613. data/ext/gecode-2.2.0/test/branch.cc +563 -0
  614. data/ext/gecode-2.2.0/test/branch.hh +144 -0
  615. data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
  616. data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
  617. data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
  618. data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
  619. data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
  620. data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
  621. data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
  622. data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
  623. data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
  624. data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
  625. data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
  626. data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
  627. data/ext/gecode-2.2.0/test/int.cc +688 -0
  628. data/ext/gecode-2.2.0/test/int.hh +267 -0
  629. data/ext/gecode-2.2.0/test/int.icc +266 -0
  630. data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
  631. data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
  632. data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
  633. data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
  634. data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
  635. data/ext/gecode-2.2.0/test/int/count.cc +357 -0
  636. data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
  637. data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
  638. data/ext/gecode-2.2.0/test/int/element.cc +333 -0
  639. data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
  640. data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
  641. data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
  642. data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
  643. data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
  644. data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
  645. data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
  646. data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
  647. data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
  648. data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
  649. data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
  650. data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
  651. data/ext/gecode-2.2.0/test/search.cc +618 -0
  652. data/ext/gecode-2.2.0/test/set.cc +753 -0
  653. data/ext/gecode-2.2.0/test/set.hh +286 -0
  654. data/ext/gecode-2.2.0/test/set.icc +108 -0
  655. data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
  656. data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
  657. data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
  658. data/ext/gecode-2.2.0/test/set/int.cc +473 -0
  659. data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
  660. data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
  661. data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
  662. data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
  663. data/ext/gecode-2.2.0/test/set/select.cc +299 -0
  664. data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
  665. data/ext/gecode-2.2.0/test/test.cc +287 -0
  666. data/ext/gecode-2.2.0/test/test.hh +175 -0
  667. data/ext/gecode-2.2.0/test/test.icc +93 -0
  668. data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
  669. data/lib/gecoder/bindings.rb +7 -5
  670. data/lib/gecoder/bindings/bindings.rb +8 -8
  671. data/lib/gecoder/interface.rb +4 -2
  672. data/lib/gecoder/interface/binding_changes.rb +1 -1
  673. data/lib/gecoder/interface/branch.rb +1 -1
  674. data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
  675. data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
  676. data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
  677. data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
  678. data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
  679. data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
  680. data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
  681. data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
  682. data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
  683. data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
  684. data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
  685. data/lib/gecoder/interface/convenience.rb +99 -0
  686. data/lib/gecoder/interface/enum_wrapper.rb +1 -1
  687. data/lib/gecoder/interface/mixin.rb +486 -0
  688. data/lib/gecoder/interface/search.rb +23 -22
  689. data/lib/gecoder/version.rb +1 -1
  690. data/specs/branch.rb +5 -3
  691. data/specs/constraints/bool/boolean.rb +3 -1
  692. data/specs/constraints/bool/linear.rb +3 -1
  693. data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
  694. data/specs/constraints/bool_enum/channel.rb +3 -1
  695. data/specs/constraints/fixnum_enum/element.rb +3 -1
  696. data/specs/constraints/int/arithmetic.rb +3 -1
  697. data/specs/constraints/int/channel.rb +3 -1
  698. data/specs/constraints/int/linear.rb +3 -1
  699. data/specs/constraints/int/linear_properties.rb +3 -1
  700. data/specs/constraints/int_enum/arithmetic.rb +3 -1
  701. data/specs/constraints/int_enum/channel.rb +3 -1
  702. data/specs/constraints/int_enum/count.rb +3 -1
  703. data/specs/constraints/int_enum/distinct.rb +3 -1
  704. data/specs/constraints/int_enum/element.rb +3 -1
  705. data/specs/constraints/int_enum/sort.rb +3 -1
  706. data/specs/constraints/property_helper.rb +10 -10
  707. data/specs/constraints/reification_sugar.rb +3 -1
  708. data/specs/constraints/selected_set/select.rb +6 -5
  709. data/specs/constraints/selected_set/select_properties.rb +12 -10
  710. data/specs/constraints/set/channel.rb +3 -1
  711. data/specs/constraints/set/domain.rb +4 -4
  712. data/specs/constraints/set/relation.rb +4 -4
  713. data/specs/constraints/set_enum/channel.rb +3 -1
  714. data/specs/constraints/set_enum/distinct.rb +3 -1
  715. data/specs/constraints/set_enum/element.rb +77 -0
  716. data/specs/enum_wrapper.rb +1 -1
  717. data/specs/mixin.rb +78 -0
  718. data/specs/model.rb +5 -5
  719. data/specs/search.rb +20 -14
  720. data/specs/selected_set.rb +3 -3
  721. data/specs/set_elements.rb +2 -2
  722. data/tasks/distribution.rake +25 -4
  723. metadata +739 -602
  724. data/example/money.rb +0 -36
  725. data/ext/gecode-2.1.1/Makefile.dep +0 -7622
  726. data/ext/gecode-2.1.1/Makefile.in +0 -1568
  727. data/ext/gecode-2.1.1/changelog.in +0 -2459
  728. data/ext/gecode-2.1.1/configure +0 -11631
  729. data/ext/gecode-2.1.1/configure.ac +0 -249
  730. data/ext/gecode-2.1.1/configure.ac.in +0 -245
  731. data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
  732. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
  733. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
  734. data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
  735. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
  736. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
  737. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
  738. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
  739. data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
  740. data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
  741. data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
  742. data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
  743. data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
  744. data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
  745. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
  746. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
  747. data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
  748. data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
  749. data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
  750. data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
  751. data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
  752. data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
  753. data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
  754. data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
  755. data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
  756. data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
  757. data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
  758. data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
  759. data/ext/gecode-2.1.1/gecode.m4 +0 -956
  760. data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
  761. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
  762. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
  763. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
  764. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
  765. data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
  766. data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
  767. data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
  768. data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
  769. data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
  770. data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
  771. data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
  772. data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
  773. data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
  774. data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
  775. data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
  776. data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
  777. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
  778. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
  779. data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
  780. data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
  781. data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
  782. data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
  783. data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
  784. data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
  785. data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
  786. data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
  787. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
  788. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
  789. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
  790. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
  791. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
  792. data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
  793. data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
  794. data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
  795. data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
  796. data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
  797. data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
  798. data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
  799. data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
  800. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
  801. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
  802. data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
  803. data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
  804. data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
  805. data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
  806. data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
  807. data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
  808. data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
  809. data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
  810. data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
  811. data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
  812. data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
  813. data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
  814. data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
  815. data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
  816. data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
  817. data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
  818. data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
  819. data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
  820. data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
  821. data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
  822. data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
  823. data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
  824. data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
  825. data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
  826. data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
  827. data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
  828. data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
  829. data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
  830. data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
  831. data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
  832. data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
  833. data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
  834. data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
  835. data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
  836. data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
  837. data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
  838. data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
  839. data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
  840. data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
  841. data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
  842. data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
  843. data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
  844. data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
  845. data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
  846. data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
  847. data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
  848. data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
  849. data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
  850. data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
  851. data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
  852. data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
  853. data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
  854. data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
  855. data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
  856. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
  857. data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
  858. data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
  859. data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
  860. data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
  861. data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
  862. data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
  863. data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
  864. data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
  865. data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
  866. data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
  867. data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
  868. data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
  869. data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
  870. data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
  871. data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
  872. data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
  873. data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
  874. data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
  875. data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
  876. data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
  877. data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
  878. data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
  879. data/ext/gecode-2.1.1/gecode/search.hh +0 -752
  880. data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
  881. data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
  882. data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
  883. data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
  884. data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
  885. data/ext/gecode-2.1.1/gecode/set.hh +0 -970
  886. data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
  887. data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
  888. data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
  889. data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
  890. data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
  891. data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
  892. data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
  893. data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
  894. data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
  895. data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
  896. data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
  897. data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
  898. data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
  899. data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
  900. data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
  901. data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
  902. data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
  903. data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
  904. data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
  905. data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
  906. data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
  907. data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
  908. data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
  909. data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
  910. data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
  911. data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
  912. data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
  913. data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
  914. data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
  915. data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
  916. data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
  917. data/lib/gecoder/interface/model.rb +0 -453
  918. data/lib/gecoder/interface/model_sugar.rb +0 -84
  919. data/specs/constraints/set_enum/select.rb +0 -73
@@ -1,1000 +0,0 @@
1
- /* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
2
- /*
3
- * Main authors:
4
- * Christian Schulte <schulte@gecode.org>
5
- *
6
- * Copyright:
7
- * Christian Schulte, 2004
8
- *
9
- * Last modified:
10
- * $Date: 2008-02-25 00:16:01 +0100 (Mon, 25 Feb 2008) $ by $Author: schulte $
11
- * $Revision: 6288 $
12
- *
13
- * This file is part of Gecode, the generic constraint
14
- * development environment:
15
- * http://www.gecode.org
16
- *
17
- * Permission is hereby granted, free of charge, to any person obtaining
18
- * a copy of this software and associated documentation files (the
19
- * "Software"), to deal in the Software without restriction, including
20
- * without limitation the rights to use, copy, modify, merge, publish,
21
- * distribute, sublicense, and/or sell copies of the Software, and to
22
- * permit persons to whom the Software is furnished to do so, subject to
23
- * the following conditions:
24
- *
25
- * The above copyright notice and this permission notice shall be
26
- * included in all copies or substantial portions of the Software.
27
- *
28
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
29
- * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
30
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
31
- * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
32
- * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
33
- * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
34
- * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
35
- *
36
- */
37
-
38
- namespace Gecode { namespace Int { namespace Bool {
39
-
40
- /// Binary Boolean disjunction propagator (subsumed)
41
- template<class BV>
42
- class OrTrueSubsumed : public BoolBinary<BV,BV> {
43
- protected:
44
- using BoolBinary<BV,BV>::x0;
45
- using BoolBinary<BV,BV>::x1;
46
- /// Constructor for cloning \a p
47
- OrTrueSubsumed(Space* home, bool share, OrTrueSubsumed& p);
48
- public:
49
- /// Constructor
50
- OrTrueSubsumed(Space* home, BV b0, BV b1);
51
- /// Constructor for rewriting \a p during cloning
52
- OrTrueSubsumed(Space* home, bool share, Propagator& p,
53
- BV b0, BV b1);
54
- /// Copy propagator during cloning
55
- virtual Actor* copy(Space* home, bool share);
56
- /// Perform propagation
57
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
58
- /// Specification for this propagator
59
- virtual Reflection::ActorSpec spec(const Space* home,
60
- Reflection::VarMap& m) const;
61
- /// Post using specification
62
- static void post(Space* home, Reflection::VarMap& vars,
63
- const Reflection::ActorSpec& spec);
64
- /// Actor type identifier of this propagator
65
- static Support::Symbol ati(void);
66
- };
67
-
68
- template <class BV>
69
- forceinline
70
- OrTrueSubsumed<BV>::OrTrueSubsumed
71
- (Space* home, BV b0, BV b1)
72
- : BoolBinary<BV,BV>(home,b0,b1) {}
73
-
74
- template <class BV>
75
- forceinline
76
- OrTrueSubsumed<BV>::OrTrueSubsumed
77
- (Space* home, bool share, OrTrueSubsumed<BV>& p)
78
- : BoolBinary<BV,BV>(home,share,p) {}
79
-
80
- template <class BV>
81
- forceinline
82
- OrTrueSubsumed<BV>::OrTrueSubsumed(Space* home, bool share, Propagator& p,
83
- BV b0, BV b1)
84
- : BoolBinary<BV,BV>(home,share,p,b0,b1) {}
85
-
86
- template <class BV>
87
- Actor*
88
- OrTrueSubsumed<BV>::copy(Space* home, bool share) {
89
- return new (home) OrTrueSubsumed<BV>(home,share,*this);
90
- }
91
-
92
- template <class BV>
93
- ExecStatus
94
- OrTrueSubsumed<BV>::propagate(Space* home, ModEventDelta) {
95
- return ES_SUBSUMED(this,home);
96
- }
97
-
98
- template <class BV>
99
- inline Support::Symbol
100
- OrTrueSubsumed<BV>::ati(void) {
101
- return Reflection::mangle<BV>("Gecode::Int::Bool::OrTrueSubsumed");
102
- }
103
-
104
- template <class BV>
105
- Reflection::ActorSpec
106
- OrTrueSubsumed<BV>::spec(const Space* home, Reflection::VarMap& m) const {
107
- return BoolBinary<BV,BV>::spec(home, m, ati());
108
- }
109
-
110
- template<class BV>
111
- void
112
- OrTrueSubsumed<BV>::post(Space* home, Reflection::VarMap& vars,
113
- const Reflection::ActorSpec& spec) {
114
- spec.checkArity(2);
115
- BV b0(home, vars, spec[0]);
116
- BV b1(home, vars, spec[1]);
117
- (void) new (home) OrTrueSubsumed<BV>(home,b0,b1);
118
- }
119
-
120
-
121
- /*
122
- * Binary Boolean disjunction propagator (true)
123
- *
124
- */
125
-
126
- template <class BVA, class BVB>
127
- forceinline
128
- BinOrTrue<BVA,BVB>::BinOrTrue(Space* home, BVA b0, BVB b1)
129
- : BoolBinary<BVA,BVB>(home,b0,b1) {}
130
-
131
- template <class BVA, class BVB>
132
- forceinline
133
- BinOrTrue<BVA,BVB>::BinOrTrue(Space* home, bool share, BinOrTrue<BVA,BVB>& p)
134
- : BoolBinary<BVA,BVB>(home,share,p) {}
135
-
136
- template <class BVA, class BVB>
137
- forceinline
138
- BinOrTrue<BVA,BVB>::BinOrTrue(Space* home, bool share, Propagator& p,
139
- BVA b0, BVB b1)
140
- : BoolBinary<BVA,BVB>(home,share,p,b0,b1) {}
141
-
142
- template <class BVA, class BVB>
143
- Actor*
144
- BinOrTrue<BVA,BVB>::copy(Space* home, bool share) {
145
- return new (home) BinOrTrue<BVA,BVB>(home,share,*this);
146
- }
147
-
148
- template <class BVA, class BVB>
149
- inline ExecStatus
150
- BinOrTrue<BVA,BVB>::post(Space* home, BVA b0, BVB b1) {
151
- switch (bool_test(b0,b1)) {
152
- case BT_SAME:
153
- GECODE_ME_CHECK(b0.one(home));
154
- break;
155
- case BT_COMP:
156
- break;
157
- case BT_NONE:
158
- if (b0.zero()) {
159
- GECODE_ME_CHECK(b1.one(home));
160
- } else if (b1.zero()) {
161
- GECODE_ME_CHECK(b0.one(home));
162
- } else if (!b0.one() && !b1.one()) {
163
- (void) new (home) BinOrTrue<BVA,BVB>(home,b0,b1);
164
- }
165
- break;
166
- default: GECODE_NEVER;
167
- }
168
- return ES_OK;
169
- }
170
-
171
- template <class BVA, class BVB>
172
- ExecStatus
173
- BinOrTrue<BVA,BVB>::propagate(Space* home, ModEventDelta) {
174
- #define GECODE_INT_STATUS(S0,S1) \
175
- ((BVA::S0<<(1*BVA::BITS))|(BVB::S1<<(0*BVB::BITS)))
176
- switch ((x0.status() << (1*BVA::BITS)) | (x1.status() << (0*BVB::BITS))) {
177
- case GECODE_INT_STATUS(NONE,NONE):
178
- GECODE_NEVER;
179
- case GECODE_INT_STATUS(NONE,ZERO):
180
- GECODE_ME_CHECK(x0.one_none(home)); break;
181
- case GECODE_INT_STATUS(NONE,ONE):
182
- x0.cancel(home,this,PC_BOOL_VAL); break;
183
- case GECODE_INT_STATUS(ZERO,NONE):
184
- GECODE_ME_CHECK(x1.one_none(home)); break;
185
- case GECODE_INT_STATUS(ZERO,ZERO):
186
- return ES_FAILED;
187
- case GECODE_INT_STATUS(ZERO,ONE):
188
- break;
189
- case GECODE_INT_STATUS(ONE,NONE):
190
- x1.cancel(home,this,PC_BOOL_VAL); break;
191
- case GECODE_INT_STATUS(ONE,ZERO):
192
- break;
193
- case GECODE_INT_STATUS(ONE,ONE):
194
- break;
195
- default:
196
- GECODE_NEVER;
197
- }
198
- return ES_SUBSUMED(this,sizeof(*this));
199
- #undef GECODE_INT_STATUS
200
- }
201
-
202
- template <class BVA, class BVB>
203
- Support::Symbol
204
- BinOrTrue<BVA,BVB>::ati(void) {
205
- return Reflection::mangle<BVA,BVB>("Gecode::Int::Bool::BinOrTrue");
206
- }
207
-
208
- template <class BVA, class BVB>
209
- Reflection::ActorSpec
210
- BinOrTrue<BVA,BVB>::spec(const Space* home, Reflection::VarMap& m) const {
211
- return BoolBinary<BVA,BVB>::spec(home, m, ati());
212
- }
213
-
214
- template<class BVA, class BVB>
215
- void
216
- BinOrTrue<BVA,BVB>::post(Space* home, Reflection::VarMap& vars,
217
- const Reflection::ActorSpec& spec) {
218
- spec.checkArity(2);
219
- BVA b0(home, vars, spec[0]);
220
- BVB b1(home, vars, spec[1]);
221
- (void) new (home) BinOrTrue<BVA,BVB>(home,b0,b1);
222
- }
223
-
224
- /*
225
- * Boolean disjunction propagator (true)
226
- *
227
- */
228
-
229
- template <class BV>
230
- forceinline
231
- TerOrTrue<BV>::TerOrTrue(Space* home, BV b0, BV b1, BV b2)
232
- : BoolBinary<BV,BV>(home,b0,b1), x2(b2) {}
233
-
234
- template<class BV>
235
- forceinline size_t
236
- TerOrTrue<BV>::dispose(Space* home) {
237
- (void) BoolBinary<BV,BV>::dispose(home);
238
- return sizeof(*this);
239
- }
240
-
241
- template <class BV>
242
- forceinline
243
- TerOrTrue<BV>::TerOrTrue(Space* home, bool share, TerOrTrue<BV>& p)
244
- : BoolBinary<BV,BV>(home,share,p) {
245
- x2.update(home,share,p.x2);
246
- }
247
-
248
- template <class BV>
249
- forceinline
250
- TerOrTrue<BV>::TerOrTrue(Space* home, bool share, Propagator& p,
251
- BV b0, BV b1, BV b2)
252
- : BoolBinary<BV,BV>(home,share,p,b0,b1) {
253
- x2.update(home,share,b2);
254
- }
255
-
256
- template <class BV>
257
- Actor*
258
- TerOrTrue<BV>::copy(Space* home, bool share) {
259
- assert(x0.none() && x1.none());
260
- if (x2.one())
261
- return new (home) OrTrueSubsumed<BV>(home,share,*this,x0,x1);
262
- else if (x2.zero())
263
- return new (home) BinOrTrue<BV,BV>(home,share,*this,x0,x1);
264
- else
265
- return new (home) TerOrTrue<BV>(home,share,*this);
266
- }
267
-
268
- template <class BV>
269
- forceinline ExecStatus
270
- TerOrTrue<BV>::post(Space* home, BV b0, BV b1, BV b2) {
271
- (void) new (home) TerOrTrue<BV>(home,b0,b1,b2);
272
- return ES_OK;
273
- }
274
-
275
- template <class BV>
276
- ExecStatus
277
- TerOrTrue<BV>::propagate(Space* home, ModEventDelta) {
278
- #define GECODE_INT_STATUS(S0,S1,S2) \
279
- ((BV::S0<<(2*BV::BITS))|(BV::S1<<(1*BV::BITS))|(BV::S2<<(0*BV::BITS)))
280
- switch ((x0.status() << (2*BV::BITS)) | (x1.status() << (1*BV::BITS)) |
281
- (x2.status() << (0*BV::BITS))) {
282
- case GECODE_INT_STATUS(NONE,NONE,NONE):
283
- case GECODE_INT_STATUS(NONE,NONE,ZERO):
284
- case GECODE_INT_STATUS(NONE,NONE,ONE):
285
- GECODE_NEVER;
286
- case GECODE_INT_STATUS(NONE,ZERO,NONE):
287
- std::swap(x1,x2); x1.subscribe(home,this,PC_BOOL_VAL);
288
- return ES_FIX;
289
- case GECODE_INT_STATUS(NONE,ZERO,ZERO):
290
- GECODE_ME_CHECK(x0.one_none(home)); break;
291
- case GECODE_INT_STATUS(NONE,ZERO,ONE):
292
- case GECODE_INT_STATUS(NONE,ONE,NONE):
293
- case GECODE_INT_STATUS(NONE,ONE,ZERO):
294
- case GECODE_INT_STATUS(NONE,ONE,ONE):
295
- x0.cancel(home,this,PC_BOOL_VAL); break;
296
- case GECODE_INT_STATUS(ZERO,NONE,NONE):
297
- std::swap(x0,x2); x0.subscribe(home,this,PC_BOOL_VAL);
298
- return ES_FIX;
299
- case GECODE_INT_STATUS(ZERO,NONE,ZERO):
300
- GECODE_ME_CHECK(x1.one_none(home)); break;
301
- case GECODE_INT_STATUS(ZERO,NONE,ONE):
302
- x1.cancel(home,this,PC_BOOL_VAL); break;
303
- case GECODE_INT_STATUS(ZERO,ZERO,NONE):
304
- GECODE_ME_CHECK(x2.one_none(home)); break;
305
- case GECODE_INT_STATUS(ZERO,ZERO,ZERO):
306
- return ES_FAILED;
307
- case GECODE_INT_STATUS(ZERO,ZERO,ONE):
308
- case GECODE_INT_STATUS(ZERO,ONE,NONE):
309
- case GECODE_INT_STATUS(ZERO,ONE,ZERO):
310
- case GECODE_INT_STATUS(ZERO,ONE,ONE):
311
- break;
312
- case GECODE_INT_STATUS(ONE,NONE,NONE):
313
- case GECODE_INT_STATUS(ONE,NONE,ZERO):
314
- case GECODE_INT_STATUS(ONE,NONE,ONE):
315
- x1.cancel(home,this,PC_BOOL_VAL); break;
316
- case GECODE_INT_STATUS(ONE,ZERO,NONE):
317
- case GECODE_INT_STATUS(ONE,ZERO,ZERO):
318
- case GECODE_INT_STATUS(ONE,ZERO,ONE):
319
- case GECODE_INT_STATUS(ONE,ONE,NONE):
320
- case GECODE_INT_STATUS(ONE,ONE,ZERO):
321
- case GECODE_INT_STATUS(ONE,ONE,ONE):
322
- break;
323
- default:
324
- GECODE_NEVER;
325
- }
326
- return ES_SUBSUMED(this,sizeof(*this));
327
- #undef GECODE_INT_STATUS
328
- }
329
-
330
- template <class BV>
331
- Support::Symbol
332
- TerOrTrue<BV>::ati(void) {
333
- return Reflection::mangle<BV>("Gecode::Int::Bool::TerOrTrue");
334
- }
335
-
336
- template <class BV>
337
- Reflection::ActorSpec
338
- TerOrTrue<BV>::spec(const Space* home, Reflection::VarMap& m) const {
339
- return BoolBinary<BV,BV>::spec(home, m, ati())
340
- << x2.spec(home, m);
341
- }
342
-
343
- template<class BV>
344
- void
345
- TerOrTrue<BV>::post(Space* home, Reflection::VarMap& vars,
346
- const Reflection::ActorSpec& spec) {
347
- spec.checkArity(3);
348
- BV b0(home, vars, spec[0]);
349
- BV b1(home, vars, spec[1]);
350
- BV b2(home, vars, spec[2]);
351
- (void) new (home) TerOrTrue<BV>(home,b0,b1,b2);
352
- }
353
-
354
- /*
355
- * Boolean disjunction propagator (true)
356
- *
357
- */
358
-
359
- template <class BV>
360
- forceinline
361
- QuadOrTrue<BV>::QuadOrTrue(Space* home, BV b0, BV b1, BV b2, BV b3)
362
- : BoolBinary<BV,BV>(home,b0,b1), x2(b2), x3(b3) {}
363
-
364
- template<class BV>
365
- forceinline size_t
366
- QuadOrTrue<BV>::dispose(Space* home) {
367
- (void) BoolBinary<BV,BV>::dispose(home);
368
- return sizeof(*this);
369
- }
370
-
371
- template <class BV>
372
- forceinline
373
- QuadOrTrue<BV>::QuadOrTrue(Space* home, bool share, QuadOrTrue<BV>& p)
374
- : BoolBinary<BV,BV>(home,share,p) {
375
- x2.update(home,share,p.x2);
376
- x3.update(home,share,p.x3);
377
- }
378
-
379
- template <class BV>
380
- forceinline
381
- QuadOrTrue<BV>::QuadOrTrue(Space* home, bool share, Propagator& p,
382
- BV b0, BV b1, BV b2, BV b3)
383
- : BoolBinary<BV,BV>(home,share,p,b0,b1) {
384
- x2.update(home,share,b2);
385
- x3.update(home,share,b3);
386
- }
387
-
388
- template <class BV>
389
- Actor*
390
- QuadOrTrue<BV>::copy(Space* home, bool share) {
391
- assert(x0.none() && x1.none());
392
- if (x2.one() || x3.one())
393
- return new (home) OrTrueSubsumed<BV>(home,share,*this,x0,x1);
394
- else if (x2.zero() && x3.zero())
395
- return new (home) BinOrTrue<BV,BV>(home,share,*this,x0,x1);
396
- else if (x2.zero())
397
- return new (home) TerOrTrue<BV>(home,share,*this,x0,x1,x3);
398
- else if (x3.zero())
399
- return new (home) TerOrTrue<BV>(home,share,*this,x0,x1,x2);
400
- else
401
- return new (home) QuadOrTrue<BV>(home,share,*this);
402
- }
403
-
404
- template <class BV>
405
- forceinline ExecStatus
406
- QuadOrTrue<BV>::post(Space* home, BV b0, BV b1, BV b2, BV b3) {
407
- (void) new (home) QuadOrTrue<BV>(home,b0,b1,b2,b3);
408
- return ES_OK;
409
- }
410
-
411
- template <class BV>
412
- ExecStatus
413
- QuadOrTrue<BV>::propagate(Space* home, ModEventDelta) {
414
- #define GECODE_INT_STATUS(S0,S1,S2,S3) \
415
- ((BV::S0 << (3*BV::BITS)) | (BV::S1 << (2*BV::BITS)) | \
416
- (BV::S2 << (1*BV::BITS)) | (BV::S3 << (0*BV::BITS)))
417
- switch ((x0.status() << (3*BV::BITS)) | (x1.status() << (2*BV::BITS)) |
418
- (x2.status() << (1*BV::BITS)) | (x3.status() << (0*BV::BITS))) {
419
- case GECODE_INT_STATUS(NONE,NONE,NONE,NONE):
420
- case GECODE_INT_STATUS(NONE,NONE,NONE,ZERO):
421
- case GECODE_INT_STATUS(NONE,NONE,NONE,ONE):
422
- case GECODE_INT_STATUS(NONE,NONE,ZERO,NONE):
423
- case GECODE_INT_STATUS(NONE,NONE,ZERO,ZERO):
424
- case GECODE_INT_STATUS(NONE,NONE,ZERO,ONE):
425
- case GECODE_INT_STATUS(NONE,NONE,ONE,NONE):
426
- case GECODE_INT_STATUS(NONE,NONE,ONE,ZERO):
427
- case GECODE_INT_STATUS(NONE,NONE,ONE,ONE):
428
- GECODE_NEVER;
429
- case GECODE_INT_STATUS(NONE,ZERO,NONE,NONE):
430
- case GECODE_INT_STATUS(NONE,ZERO,NONE,ZERO):
431
- std::swap(x1,x2); x1.subscribe(home,this,PC_BOOL_VAL,false);
432
- return ES_FIX;
433
- case GECODE_INT_STATUS(NONE,ZERO,NONE,ONE):
434
- x0.cancel(home,this,PC_BOOL_VAL); break;
435
- case GECODE_INT_STATUS(NONE,ZERO,ZERO,NONE):
436
- std::swap(x1,x3); x1.subscribe(home,this,PC_BOOL_VAL,false);
437
- return ES_FIX;
438
- case GECODE_INT_STATUS(NONE,ZERO,ZERO,ZERO):
439
- GECODE_ME_CHECK(x0.one_none(home)); break;
440
- case GECODE_INT_STATUS(NONE,ZERO,ZERO,ONE):
441
- case GECODE_INT_STATUS(NONE,ZERO,ONE,NONE):
442
- case GECODE_INT_STATUS(NONE,ZERO,ONE,ZERO):
443
- case GECODE_INT_STATUS(NONE,ZERO,ONE,ONE):
444
- case GECODE_INT_STATUS(NONE,ONE,NONE,NONE):
445
- case GECODE_INT_STATUS(NONE,ONE,NONE,ZERO):
446
- case GECODE_INT_STATUS(NONE,ONE,NONE,ONE):
447
- case GECODE_INT_STATUS(NONE,ONE,ZERO,NONE):
448
- case GECODE_INT_STATUS(NONE,ONE,ZERO,ZERO):
449
- case GECODE_INT_STATUS(NONE,ONE,ZERO,ONE):
450
- case GECODE_INT_STATUS(NONE,ONE,ONE,NONE):
451
- case GECODE_INT_STATUS(NONE,ONE,ONE,ZERO):
452
- case GECODE_INT_STATUS(NONE,ONE,ONE,ONE):
453
- x0.cancel(home,this,PC_BOOL_VAL); break;
454
- case GECODE_INT_STATUS(ZERO,NONE,NONE,NONE):
455
- case GECODE_INT_STATUS(ZERO,NONE,NONE,ZERO):
456
- std::swap(x0,x2); x0.subscribe(home,this,PC_BOOL_VAL,false);
457
- return ES_FIX;
458
- case GECODE_INT_STATUS(ZERO,NONE,NONE,ONE):
459
- x1.cancel(home,this,PC_BOOL_VAL); break;
460
- case GECODE_INT_STATUS(ZERO,NONE,ZERO,NONE):
461
- std::swap(x0,x3); x0.subscribe(home,this,PC_BOOL_VAL,false);
462
- return ES_FIX;
463
- case GECODE_INT_STATUS(ZERO,NONE,ZERO,ZERO):
464
- GECODE_ME_CHECK(x1.one_none(home)); break;
465
- case GECODE_INT_STATUS(ZERO,NONE,ZERO,ONE):
466
- x1.cancel(home,this,PC_BOOL_VAL); break;
467
- case GECODE_INT_STATUS(ZERO,NONE,ONE,NONE):
468
- case GECODE_INT_STATUS(ZERO,NONE,ONE,ZERO):
469
- case GECODE_INT_STATUS(ZERO,NONE,ONE,ONE):
470
- x1.cancel(home,this,PC_BOOL_VAL); break;
471
- case GECODE_INT_STATUS(ZERO,ZERO,NONE,NONE):
472
- std::swap(x0,x2); x0.subscribe(home,this,PC_BOOL_VAL,false);
473
- std::swap(x1,x3); x1.subscribe(home,this,PC_BOOL_VAL,false);
474
- return ES_FIX;
475
- case GECODE_INT_STATUS(ZERO,ZERO,NONE,ZERO):
476
- GECODE_ME_CHECK(x2.one_none(home)); break;
477
- case GECODE_INT_STATUS(ZERO,ZERO,NONE,ONE):
478
- break;
479
- case GECODE_INT_STATUS(ZERO,ZERO,ZERO,NONE):
480
- GECODE_ME_CHECK(x3.one_none(home)); break;
481
- case GECODE_INT_STATUS(ZERO,ZERO,ZERO,ZERO):
482
- return ES_FAILED;
483
- case GECODE_INT_STATUS(ZERO,ZERO,ZERO,ONE):
484
- case GECODE_INT_STATUS(ZERO,ZERO,ONE,NONE):
485
- case GECODE_INT_STATUS(ZERO,ZERO,ONE,ZERO):
486
- case GECODE_INT_STATUS(ZERO,ZERO,ONE,ONE):
487
- case GECODE_INT_STATUS(ZERO,ONE,NONE,NONE):
488
- case GECODE_INT_STATUS(ZERO,ONE,NONE,ZERO):
489
- case GECODE_INT_STATUS(ZERO,ONE,NONE,ONE):
490
- case GECODE_INT_STATUS(ZERO,ONE,ZERO,NONE):
491
- case GECODE_INT_STATUS(ZERO,ONE,ZERO,ZERO):
492
- case GECODE_INT_STATUS(ZERO,ONE,ZERO,ONE):
493
- case GECODE_INT_STATUS(ZERO,ONE,ONE,NONE):
494
- case GECODE_INT_STATUS(ZERO,ONE,ONE,ZERO):
495
- case GECODE_INT_STATUS(ZERO,ONE,ONE,ONE):
496
- break;
497
- case GECODE_INT_STATUS(ONE,NONE,NONE,NONE):
498
- case GECODE_INT_STATUS(ONE,NONE,NONE,ZERO):
499
- case GECODE_INT_STATUS(ONE,NONE,NONE,ONE):
500
- case GECODE_INT_STATUS(ONE,NONE,ZERO,NONE):
501
- case GECODE_INT_STATUS(ONE,NONE,ZERO,ZERO):
502
- case GECODE_INT_STATUS(ONE,NONE,ZERO,ONE):
503
- case GECODE_INT_STATUS(ONE,NONE,ONE,NONE):
504
- case GECODE_INT_STATUS(ONE,NONE,ONE,ZERO):
505
- case GECODE_INT_STATUS(ONE,NONE,ONE,ONE):
506
- x1.cancel(home,this,PC_BOOL_VAL); break;
507
- case GECODE_INT_STATUS(ONE,ZERO,NONE,NONE):
508
- case GECODE_INT_STATUS(ONE,ZERO,NONE,ZERO):
509
- case GECODE_INT_STATUS(ONE,ZERO,NONE,ONE):
510
- case GECODE_INT_STATUS(ONE,ZERO,ZERO,NONE):
511
- case GECODE_INT_STATUS(ONE,ZERO,ZERO,ZERO):
512
- case GECODE_INT_STATUS(ONE,ZERO,ZERO,ONE):
513
- case GECODE_INT_STATUS(ONE,ZERO,ONE,NONE):
514
- case GECODE_INT_STATUS(ONE,ZERO,ONE,ZERO):
515
- case GECODE_INT_STATUS(ONE,ZERO,ONE,ONE):
516
- case GECODE_INT_STATUS(ONE,ONE,NONE,NONE):
517
- case GECODE_INT_STATUS(ONE,ONE,NONE,ZERO):
518
- case GECODE_INT_STATUS(ONE,ONE,NONE,ONE):
519
- case GECODE_INT_STATUS(ONE,ONE,ZERO,NONE):
520
- case GECODE_INT_STATUS(ONE,ONE,ZERO,ZERO):
521
- case GECODE_INT_STATUS(ONE,ONE,ZERO,ONE):
522
- case GECODE_INT_STATUS(ONE,ONE,ONE,NONE):
523
- case GECODE_INT_STATUS(ONE,ONE,ONE,ZERO):
524
- case GECODE_INT_STATUS(ONE,ONE,ONE,ONE):
525
- break;
526
- default:
527
- GECODE_NEVER;
528
- }
529
- return ES_SUBSUMED(this,sizeof(*this));
530
- #undef GECODE_INT_STATUS
531
- }
532
-
533
- template <class BV>
534
- Support::Symbol
535
- QuadOrTrue<BV>::ati(void) {
536
- return Reflection::mangle<BV>("Gecode::Int::Bool::QuadOrTrue");
537
- }
538
-
539
- template <class BV>
540
- Reflection::ActorSpec
541
- QuadOrTrue<BV>::spec(const Space* home, Reflection::VarMap& m) const {
542
- return BoolBinary<BV,BV>::spec(home, m, ati())
543
- << x2.spec(home, m)
544
- << x3.spec(home, m);
545
- }
546
-
547
- template<class BV>
548
- void
549
- QuadOrTrue<BV>::post(Space* home, Reflection::VarMap& vars,
550
- const Reflection::ActorSpec& spec) {
551
- spec.checkArity(4);
552
- BV b0(home, vars, spec[0]);
553
- BV b1(home, vars, spec[1]);
554
- BV b2(home, vars, spec[2]);
555
- BV b3(home, vars, spec[3]);
556
- (void) new (home) QuadOrTrue<BV>(home,b0,b1,b2,b3);
557
- }
558
-
559
- /*
560
- * Boolean disjunction propagator
561
- *
562
- */
563
-
564
- template <class BVA, class BVB, class BVC>
565
- forceinline
566
- Or<BVA,BVB,BVC>::Or(Space* home, BVA b0, BVB b1, BVC b2)
567
- : BoolTernary<BVA,BVB,BVC>(home,b0,b1,b2) {}
568
-
569
- template <class BVA, class BVB, class BVC>
570
- forceinline
571
- Or<BVA,BVB,BVC>::Or(Space* home, bool share, Or<BVA,BVB,BVC>& p)
572
- : BoolTernary<BVA,BVB,BVC>(home,share,p) {}
573
-
574
- template <class BVA, class BVB, class BVC>
575
- forceinline
576
- Or<BVA,BVB,BVC>::Or(Space* home, bool share, Propagator& p,
577
- BVA b0, BVB b1, BVC b2)
578
- : BoolTernary<BVA,BVB,BVC>(home,share,p,b0,b1,b2) {}
579
-
580
- template <class BVA, class BVB, class BVC>
581
- Actor*
582
- Or<BVA,BVB,BVC>::copy(Space* home, bool share) {
583
- if (x2.one()) {
584
- assert(x0.none() && x1.none());
585
- return new (home) BinOrTrue<BVA,BVB>(home,share,*this,x0,x1);
586
- } else if (x0.zero()) {
587
- assert(x1.none() && x2.none());
588
- return new (home) Eq<BVB,BVC>(home,share,*this,x1,x2);
589
- } else if (x1.zero()) {
590
- assert(x0.none() && x2.none());
591
- return new (home) Eq<BVA,BVC>(home,share,*this,x0,x2);
592
- } else {
593
- return new (home) Or<BVA,BVB,BVC>(home,share,*this);
594
- }
595
- }
596
-
597
- template <class BVA, class BVB, class BVC>
598
- inline ExecStatus
599
- Or<BVA,BVB,BVC>::post(Space* home, BVA b0, BVB b1, BVC b2) {
600
- if (b2.zero()) {
601
- GECODE_ME_CHECK(b0.zero(home));
602
- GECODE_ME_CHECK(b1.zero(home));
603
- } else if (b2.one()) {
604
- return BinOrTrue<BVA,BVB>::post(home,b0,b1);
605
- } else {
606
- switch (bool_test(b0,b1)) {
607
- case BT_SAME:
608
- return Eq<BVA,BVC>::post(home,b0,b2);
609
- case BT_COMP:
610
- GECODE_ME_CHECK(b2.one(home));
611
- break;
612
- case BT_NONE:
613
- if (b0.one() || b1.one()) {
614
- GECODE_ME_CHECK(b2.one(home));
615
- } else if (b0.zero()) {
616
- return Eq<BVB,BVC>::post(home,b1,b2);
617
- } else if (b1.zero()) {
618
- return Eq<BVA,BVC>::post(home,b0,b2);
619
- } else {
620
- (void) new (home) Or<BVA,BVB,BVC>(home,b0,b1,b2);
621
- }
622
- break;
623
- default: GECODE_NEVER;
624
- }
625
- }
626
- return ES_OK;
627
- }
628
-
629
- template <class BVA, class BVB, class BVC>
630
- ExecStatus
631
- Or<BVA,BVB,BVC>::propagate(Space* home, ModEventDelta) {
632
- #define GECODE_INT_STATUS(S0,S1,S2) \
633
- ((BVA::S0<<(2*BVA::BITS))|(BVB::S1<<(1*BVB::BITS))|(BVC::S2<<(0*BVC::BITS)))
634
- switch ((x0.status() << (2*BVA::BITS)) | (x1.status() << (1*BVB::BITS)) |
635
- (x2.status() << (0*BVC::BITS))) {
636
- case GECODE_INT_STATUS(NONE,NONE,NONE):
637
- GECODE_NEVER;
638
- case GECODE_INT_STATUS(NONE,NONE,ZERO):
639
- GECODE_ME_CHECK(x0.zero_none(home));
640
- GECODE_ME_CHECK(x1.zero_none(home));
641
- break;
642
- case GECODE_INT_STATUS(NONE,NONE,ONE):
643
- return ES_FIX;
644
- case GECODE_INT_STATUS(NONE,ZERO,NONE):
645
- switch (bool_test(x0,x2)) {
646
- case BT_SAME: return ES_SUBSUMED(this,home);
647
- case BT_COMP: return ES_FAILED;
648
- case BT_NONE: return ES_FIX;
649
- default: GECODE_NEVER;
650
- }
651
- GECODE_NEVER;
652
- case GECODE_INT_STATUS(NONE,ZERO,ZERO):
653
- GECODE_ME_CHECK(x0.zero_none(home)); break;
654
- case GECODE_INT_STATUS(NONE,ZERO,ONE):
655
- GECODE_ME_CHECK(x0.one_none(home)); break;
656
- case GECODE_INT_STATUS(NONE,ONE,NONE):
657
- x0.cancel(home,this,PC_BOOL_VAL);
658
- GECODE_ME_CHECK(x2.one_none(home));
659
- break;
660
- case GECODE_INT_STATUS(NONE,ONE,ZERO):
661
- return ES_FAILED;
662
- case GECODE_INT_STATUS(NONE,ONE,ONE):
663
- x0.cancel(home,this,PC_BOOL_VAL); break;
664
- case GECODE_INT_STATUS(ZERO,NONE,NONE):
665
- switch (bool_test(x1,x2)) {
666
- case BT_SAME: return ES_SUBSUMED(this,home);
667
- case BT_COMP: return ES_FAILED;
668
- case BT_NONE: return ES_FIX;
669
- default: GECODE_NEVER;
670
- }
671
- GECODE_NEVER;
672
- case GECODE_INT_STATUS(ZERO,NONE,ZERO):
673
- GECODE_ME_CHECK(x1.zero_none(home)); break;
674
- case GECODE_INT_STATUS(ZERO,NONE,ONE):
675
- GECODE_ME_CHECK(x1.one_none(home)); break;
676
- case GECODE_INT_STATUS(ZERO,ZERO,NONE):
677
- GECODE_ME_CHECK(x2.zero_none(home)); break;
678
- case GECODE_INT_STATUS(ZERO,ZERO,ZERO):
679
- break;
680
- case GECODE_INT_STATUS(ZERO,ZERO,ONE):
681
- return ES_FAILED;
682
- case GECODE_INT_STATUS(ZERO,ONE,NONE):
683
- GECODE_ME_CHECK(x2.one_none(home)); break;
684
- case GECODE_INT_STATUS(ZERO,ONE,ZERO):
685
- return ES_FAILED;
686
- case GECODE_INT_STATUS(ZERO,ONE,ONE):
687
- break;
688
- case GECODE_INT_STATUS(ONE,NONE,NONE):
689
- x1.cancel(home,this,PC_BOOL_VAL);
690
- GECODE_ME_CHECK(x2.one_none(home)); break;
691
- case GECODE_INT_STATUS(ONE,NONE,ZERO):
692
- return ES_FAILED;
693
- case GECODE_INT_STATUS(ONE,NONE,ONE):
694
- x1.cancel(home,this,PC_BOOL_VAL); break;
695
- case GECODE_INT_STATUS(ONE,ZERO,NONE):
696
- GECODE_ME_CHECK(x2.one_none(home)); break;
697
- case GECODE_INT_STATUS(ONE,ZERO,ZERO):
698
- return ES_FAILED;
699
- case GECODE_INT_STATUS(ONE,ZERO,ONE):
700
- break;
701
- case GECODE_INT_STATUS(ONE,ONE,NONE):
702
- GECODE_ME_CHECK(x2.one_none(home)); break;
703
- case GECODE_INT_STATUS(ONE,ONE,ZERO):
704
- return ES_FAILED;
705
- case GECODE_INT_STATUS(ONE,ONE,ONE):
706
- break;
707
- default:
708
- GECODE_NEVER;
709
- }
710
- return ES_SUBSUMED(this,sizeof(*this));
711
- #undef GECODE_INT_STATUS
712
- }
713
-
714
- template <class BVA, class BVB, class BVC>
715
- Support::Symbol
716
- Or<BVA,BVB,BVC>::ati(void) {
717
- return Reflection::mangle<BVA,BVB,BVC>("Gecode::Int::Bool::Or");
718
- }
719
-
720
- template <class BVA, class BVB, class BVC>
721
- Reflection::ActorSpec
722
- Or<BVA,BVB,BVC>::spec(const Space* home, Reflection::VarMap& m) const {
723
- return BoolTernary<BVA,BVB,BVC>::spec(home, m, ati());
724
- }
725
-
726
- template<class BVA, class BVB, class BVC>
727
- void
728
- Or<BVA,BVB,BVC>::post(Space* home, Reflection::VarMap& vars,
729
- const Reflection::ActorSpec& spec) {
730
- spec.checkArity(3);
731
- BVA b0(home, vars, spec[0]);
732
- BVB b1(home, vars, spec[1]);
733
- BVB b2(home, vars, spec[2]);
734
- (void) new (home) Or<BVA,BVB,BVC>(home,b0,b1,b2);
735
- }
736
-
737
- /*
738
- * N-ary Boolean disjunction propagator (true)
739
- *
740
- */
741
-
742
- template<class BV>
743
- forceinline
744
- NaryOrTrue<BV>::NaryOrTrue(Space* home, ViewArray<BV>& b)
745
- : BinaryPropagator<BV,PC_BOOL_VAL>(home,
746
- b[b.size()-2],
747
- b[b.size()-1]), x(b) {
748
- assert(x.size() > 2);
749
- x.size(x.size()-2);
750
- }
751
-
752
- template<class BV>
753
- PropCost
754
- NaryOrTrue<BV>::cost(ModEventDelta) const {
755
- return cost_lo(x.size(),PC_LINEAR_LO);
756
- }
757
-
758
- template<class BV>
759
- forceinline
760
- NaryOrTrue<BV>::NaryOrTrue(Space* home, bool share, NaryOrTrue<BV>& p)
761
- : BinaryPropagator<BV,PC_BOOL_VAL>(home,share,p) {
762
- x.update(home,share,p.x);
763
- }
764
-
765
- template<class BV>
766
- Actor*
767
- NaryOrTrue<BV>::copy(Space* home, bool share) {
768
- int n = x.size();
769
- if (n > 0) {
770
- // Check whether the original has already been purged
771
- if (x[0].one()) {
772
- x.size(1); // The rest does not matter any longer
773
- return new (home) OrTrueSubsumed<BV>(home,share,*this,x0,x1);
774
- }
775
- // Eliminate all zeros and find a one
776
- for (int i=n; i--; )
777
- if (x[i].one()) {
778
- // Only keep the one
779
- x[0]=x[i]; x.size(1);
780
- return new (home) OrTrueSubsumed<BV>(home,share,*this,x0,x1);
781
- } else if (x[i].zero()) {
782
- // Eliminate the zero
783
- x[i]=x[--n];
784
- }
785
- x.size(n);
786
- }
787
- switch (n) {
788
- case 0:
789
- return new (home) BinOrTrue<BV,BV>(home,share,*this,x0,x1);
790
- case 1:
791
- return new (home) TerOrTrue<BV>(home,share,*this,x0,x1,x[0]);
792
- case 2:
793
- return new (home) QuadOrTrue<BV>(home,share,*this,x0,x1,x[0],x[1]);
794
- default:
795
- return new (home) NaryOrTrue<BV>(home,share,*this);
796
- }
797
- }
798
-
799
- template<class BV>
800
- inline ExecStatus
801
- NaryOrTrue<BV>::post(Space* home, ViewArray<BV>& b) {
802
- for (int i=b.size(); i--; )
803
- if (b[i].one())
804
- return ES_OK;
805
- else if (b[i].zero())
806
- b.move_lst(i);
807
- if (b.size() == 0)
808
- return ES_FAILED;
809
- if (b.size() == 1) {
810
- GECODE_ME_CHECK(b[0].one(home));
811
- } else if (b.size() == 2) {
812
- return BinOrTrue<BV,BV>::post(home,b[0],b[1]);
813
- } else if (b.size() == 3) {
814
- return TerOrTrue<BV>::post(home,b[0],b[1],b[2]);
815
- } else if (b.size() == 4) {
816
- return QuadOrTrue<BV>::post(home,b[0],b[1],b[2],b[3]);
817
- } else {
818
- (void) new (home) NaryOrTrue(home,b);
819
- }
820
- return ES_OK;
821
- }
822
-
823
- template<class BV>
824
- forceinline ExecStatus
825
- NaryOrTrue<BV>::resubscribe(Space* home, BV& x0, BV x1) {
826
- if (x0.zero()) {
827
- int n = x.size();
828
- for (int i=n; i--; )
829
- if (x[i].one()) {
830
- x.size(n);
831
- return ES_SUBSUMED(this,home);
832
- } else if (x[i].zero()) {
833
- x[i] = x[--n];
834
- } else {
835
- // New unassigned view found
836
- assert(!x[i].zero() && !x[i].one());
837
- // Rewrite if there is just one view left
838
- if (i == 0) {
839
- BV y = x[0]; x.size(0);
840
- GECODE_REWRITE(this,(BinOrTrue<BV,BV>::post(home,x1,y)));
841
- }
842
- // Move to x0 and subscribe
843
- x0=x[i]; x[i]=x[--n];
844
- x.size(n);
845
- x0.subscribe(home,this,PC_BOOL_VAL,false);
846
- return ES_FIX;
847
- }
848
- // All views have been assigned!
849
- x.size(0);
850
- GECODE_ME_CHECK(x1.one(home));
851
- return ES_SUBSUMED(this,sizeof(*this));
852
- }
853
- return ES_FIX;
854
- }
855
-
856
- template<class BV>
857
- ExecStatus
858
- NaryOrTrue<BV>::propagate(Space* home, ModEventDelta) {
859
- if (x0.one() || x1.one())
860
- return ES_SUBSUMED(this,home);
861
- GECODE_ES_CHECK(resubscribe(home,x0,x1));
862
- GECODE_ES_CHECK(resubscribe(home,x1,x0));
863
- return ES_FIX;
864
- }
865
-
866
- template <class BV>
867
- Support::Symbol
868
- NaryOrTrue<BV>::ati(void) {
869
- return Reflection::mangle<BV>("Gecode::Int::Bool::NaryOrTrue");
870
- }
871
-
872
- template<class BV>
873
- Reflection::ActorSpec
874
- NaryOrTrue<BV>::spec(const Space* home, Reflection::VarMap& m) const {
875
- return BinaryPropagator<BV,PC_BOOL_VAL>::spec(home, m, ati())
876
- << x.spec(home, m);
877
- }
878
-
879
- template<class BV>
880
- void
881
- NaryOrTrue<BV>::post(Space* home, Reflection::VarMap& vars,
882
- const Reflection::ActorSpec& spec) {
883
- spec.checkArity(3);
884
- BV b0(home, vars, spec[0]);
885
- BV b1(home, vars, spec[1]);
886
- ViewArray<BV> b(home, vars, spec[2]);
887
- ViewArray<BV> bb(home, b.size()+2);
888
- for (int i=b.size(); i--;)
889
- bb[i] = b[i];
890
- bb[b.size()] = b0;
891
- bb[b.size()+1] = b1;
892
- (void) new (home) NaryOrTrue<BV>(home,bb);
893
- }
894
-
895
- /*
896
- * N-ary Boolean disjunction propagator
897
- *
898
- */
899
-
900
- template<class BV>
901
- forceinline
902
- NaryOr<BV>::NaryOr(Space* home, ViewArray<BV>& b, BV c)
903
- : NaryOnePropagator<BV,PC_BOOL_VAL>(home,b,c) {}
904
-
905
- template<class BV>
906
- forceinline
907
- NaryOr<BV>::NaryOr(Space* home, bool share, NaryOr<BV>& p)
908
- : NaryOnePropagator<BV,PC_BOOL_VAL>(home,share,p) {}
909
-
910
- template<class BV>
911
- Actor*
912
- NaryOr<BV>::copy(Space* home, bool share) {
913
- if (x.size() == 1)
914
- return new (home) Eq<BV,BV>(home,share,*this,x[0],y);
915
- if (x.size() == 2)
916
- return new (home) Or<BV,BV,BV>(home,share,*this,x[0],x[1],y);
917
- return new (home) NaryOr<BV>(home,share,*this);
918
- }
919
-
920
- template<class BV>
921
- inline ExecStatus
922
- NaryOr<BV>::post(Space* home, ViewArray<BV>& b, BV c) {
923
- if (c.one())
924
- return NaryOrTrue<BV>::post(home,b);
925
- if (c.zero()) {
926
- for (int i=b.size(); i--; )
927
- GECODE_ME_CHECK(b[i].zero(home));
928
- return ES_OK;
929
- }
930
- for (int i=b.size(); i--; )
931
- if (b[i].one()) {
932
- GECODE_ME_CHECK(c.one_none(home));
933
- return ES_OK;
934
- } else if (b[i].zero()) {
935
- b.move_lst(i);
936
- }
937
- if (b.size() == 0) {
938
- GECODE_ME_CHECK(c.zero_none(home));
939
- } else if (b.size() == 1) {
940
- return Eq<BV,BV>::post(home,b[0],c);
941
- } else if (b.size() == 2) {
942
- return Or<BV,BV,BV>::post(home,b[0],b[1],c);
943
- } else {
944
- (void) new (home) NaryOr(home,b,c);
945
- }
946
- return ES_OK;
947
- }
948
-
949
- template<class BV>
950
- ExecStatus
951
- NaryOr<BV>::propagate(Space* home, ModEventDelta) {
952
- if (y.zero()) {
953
- for (int i = x.size(); i--; )
954
- GECODE_ME_CHECK(x[i].zero(home));
955
- return ES_SUBSUMED(this,sizeof(*this));
956
- }
957
- if (y.one())
958
- GECODE_REWRITE(this,NaryOrTrue<BV>::post(home,x));
959
- for (int i = x.size(); i--; ) {
960
- if (x[i].one()) {
961
- GECODE_ME_CHECK(y.one_none(home));
962
- return ES_SUBSUMED(this,home);
963
- }
964
- if (x[i].zero())
965
- x.move_lst(i);
966
- }
967
- if (x.size() == 0) {
968
- GECODE_ME_CHECK(y.zero_none(home));
969
- return ES_SUBSUMED(this,sizeof(*this));
970
- }
971
- return ES_FIX;
972
- }
973
-
974
- template <class BV>
975
- Support::Symbol
976
- NaryOr<BV>::ati(void) {
977
- return Reflection::mangle<BV>("Gecode::Int::Bool::NaryOr");
978
- }
979
-
980
- template<class BV>
981
- Reflection::ActorSpec
982
- NaryOr<BV>::spec(const Space* home, Reflection::VarMap& m) const {
983
- return NaryOnePropagator<BV,PC_BOOL_VAL>::spec(home, m, ati());
984
- }
985
-
986
- template<class BV>
987
- void
988
- NaryOr<BV>::post(Space* home, Reflection::VarMap& vars,
989
- const Reflection::ActorSpec& spec) {
990
- spec.checkArity(2);
991
- ViewArray<BV> b(home, vars, spec[0]);
992
- BV b0(home, vars, spec[1]);
993
- (void) new (home) NaryOr<BV>(home,b,b0);
994
- }
995
-
996
-
997
- }}}
998
-
999
- // STATISTICS: int-prop
1000
-