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
@@ -0,0 +1,2116 @@
1
+ /* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
2
+ /*
3
+ * Main authors:
4
+ * Christian Schulte <schulte@gecode.org>
5
+ * Guido Tack <tack@gecode.org>
6
+ *
7
+ * Contributing authors:
8
+ * Mikael Lagerkvist <lagerkvist@gecode.org>
9
+ *
10
+ * Copyright:
11
+ * Christian Schulte, 2002
12
+ * Guido Tack, 2004
13
+ *
14
+ * Last modified:
15
+ * $Date: 2008-08-06 10:39:34 +0200 (Wed, 06 Aug 2008) $ by $Author: raphael $
16
+ * $Revision: 7494 $
17
+ *
18
+ * This file is part of Gecode, the generic constraint
19
+ * development environment:
20
+ * http://www.gecode.org
21
+ *
22
+ * Permission is hereby granted, free of charge, to any person obtaining
23
+ * a copy of this software and associated documentation files (the
24
+ * "Software"), to deal in the Software without restriction, including
25
+ * without limitation the rights to use, copy, modify, merge, publish,
26
+ * distribute, sublicense, and/or sell copies of the Software, and to
27
+ * permit persons to whom the Software is furnished to do so, subject to
28
+ * the following conditions:
29
+ *
30
+ * The above copyright notice and this permission notice shall be
31
+ * included in all copies or substantial portions of the Software.
32
+ *
33
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
34
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
35
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
36
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
37
+ * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
38
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
39
+ * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
40
+ *
41
+ */
42
+
43
+ #ifndef __GECODE_INT_HH__
44
+ #define __GECODE_INT_HH__
45
+
46
+ #include <climits>
47
+ #include <iostream>
48
+
49
+ #include "gecode/kernel.hh"
50
+ #include "gecode/iter.hh"
51
+
52
+ /*
53
+ * Configure linking
54
+ *
55
+ */
56
+ #if !defined(GECODE_STATIC_LIBS) && \
57
+ (defined(__CYGWIN__) || defined(__MINGW32__) || defined(_MSC_VER))
58
+
59
+ #ifdef GECODE_BUILD_INT
60
+ #define GECODE_INT_EXPORT __declspec( dllexport )
61
+ #else
62
+ #define GECODE_INT_EXPORT __declspec( dllimport )
63
+ #endif
64
+
65
+ #else
66
+
67
+ #ifdef GECODE_GCC_HAS_CLASS_VISIBILITY
68
+ #define GECODE_INT_EXPORT __attribute__ ((visibility("default")))
69
+ #else
70
+ #define GECODE_INT_EXPORT
71
+ #endif
72
+
73
+ #endif
74
+
75
+ /**
76
+ * \namespace Gecode::Int
77
+ * \brief Finite domain integers
78
+ *
79
+ * The Gecode::Int namespace contains all functionality required
80
+ * to program propagators and branchings for finite domain integers.
81
+ * In addition, all propagators and branchings for finite domain
82
+ * integers provided by %Gecode are contained as nested namespaces.
83
+ *
84
+ */
85
+
86
+ #include "gecode/int/exception.icc"
87
+
88
+ namespace Gecode { namespace Int {
89
+
90
+ /**
91
+ * \brief Numerical limits for integer variables
92
+ *
93
+ * The integer limits are chosen such changing the sign is always possible
94
+ * without overflow.
95
+ * \ingroup TaskModelIntVars
96
+ */
97
+ namespace Limits {
98
+ /// Largest allowed integer value
99
+ const int max = INT_MAX - 1;
100
+ /// Smallest allowed integer value
101
+ const int min = -max;
102
+ /// Check whether integer \a n is in range, otherwise throw out of limits with information \a l
103
+ void check(int n, const char* l);
104
+ /// Check whether double \a n is in integer range, otherwise throw out of limits exception with information \a l
105
+ void check(double n, const char* l);
106
+ }
107
+
108
+ }}
109
+
110
+ #include "gecode/int/limits.icc"
111
+
112
+ namespace Gecode {
113
+
114
+ class IntSetRanges;
115
+
116
+ /**
117
+ * \brief Integer sets
118
+ *
119
+ * Integer sets are the means to specify arbitrary sets
120
+ * of integers to be used as domains for integer variables.
121
+ * \ingroup TaskModelIntVars TaskModelSetVars
122
+ */
123
+ class IntSet : public SharedHandle {
124
+ friend class IntSetRanges;
125
+ private:
126
+ /// %Range (intervals) of integers
127
+ class Range {
128
+ public:
129
+ int min, max;
130
+ };
131
+ class IntSetObject : public SharedHandle::Object {
132
+ public:
133
+ /// Number of ranges
134
+ int n;
135
+ /// Array of ranges
136
+ Range* r;
137
+ /// Allocate object with \a m elements
138
+ GECODE_INT_EXPORT static IntSetObject* allocate(int m);
139
+ /// Return copy of object
140
+ GECODE_INT_EXPORT SharedHandle::Object* copy(void) const;
141
+ /// Delete object
142
+ GECODE_INT_EXPORT virtual ~IntSetObject(void);
143
+ };
144
+ /// Sort ranges according to increasing minimum
145
+ class MinInc;
146
+ /// Normalize the first \a n elements of \a r
147
+ GECODE_INT_EXPORT void normalize(Range* r, int n);
148
+ /// Initialize as range with minimum \a n and maximum \a m
149
+ GECODE_INT_EXPORT void init(int n, int m);
150
+ /// Initialize with \a n integers from array \a r
151
+ GECODE_INT_EXPORT void init(const int r[], int n);
152
+ /// Initialize with \a n ranges from array \a r
153
+ GECODE_INT_EXPORT void init(const int r[][2], int n);
154
+ public:
155
+ /// \name Constructors and initialization
156
+ //@{
157
+ /// Initialize as empty set
158
+ IntSet(void);
159
+ /** \brief Initialize as range with minimum \a n and maximum \a m
160
+ *
161
+ * Note that the set is empty if \a n is larger than \a m
162
+ */
163
+ IntSet(int n, int m);
164
+ /// Initialize with \a n integers from array \a r
165
+ IntSet(const int r[], int n);
166
+ /** \brief Initialize with \a n ranges from array \a r
167
+ *
168
+ * For position \a i in the array \a r, the minimum is \a r[\a i][0]
169
+ * and the maximum is \a r[\a i][1].
170
+ */
171
+ IntSet(const int r[][2], int n);
172
+ /// Initialize with range iterator \a i
173
+ template <class I>
174
+ explicit IntSet(I& i);
175
+ #ifdef __INTEL_COMPILER
176
+ /// Initialize with range iterator \a i
177
+ IntSet(const IntSet& s);
178
+ /// Initialize with range iterator \a i
179
+ IntSet(IntSet& s);
180
+ #endif
181
+ //@}
182
+
183
+ /// \name Range length
184
+ //@{
185
+ /// Return number of ranges of the specification
186
+ int size(void) const;
187
+ //@}
188
+
189
+ /// \name Range access
190
+ //@{
191
+ /// Return minimum of range at position \a i
192
+ int min(int i) const;
193
+ /// Return maximum of range at position \a i
194
+ int max(int i) const;
195
+ /// Return width of range at position \a i
196
+ unsigned int width(int i) const;
197
+ //@}
198
+
199
+ /// \name Entire set access
200
+ //@{
201
+ /// Return minimum of entire set
202
+ int min(void) const;
203
+ /// Return maximum of entire set
204
+ int max(void) const;
205
+ //@}
206
+
207
+ /// \name Predefined value
208
+ //@{
209
+ /// Empty set
210
+ GECODE_INT_EXPORT static const IntSet empty;
211
+ //@}
212
+ };
213
+
214
+ /**
215
+ * \brief Range iterator for integer sets
216
+ *
217
+ * \ingroup TaskModelIntVars TaskModelSetVars
218
+ */
219
+ class IntSetRanges {
220
+ private:
221
+ /// Current range
222
+ const IntSet::Range* i;
223
+ /// End range
224
+ const IntSet::Range* e;
225
+ public:
226
+ /// \name Constructors and initialization
227
+ //@{
228
+ /// Default constructor
229
+ IntSetRanges(void);
230
+ /// Initialize with ranges for set \a s
231
+ IntSetRanges(const IntSet& s);
232
+ /// Initialize with ranges for set \a s
233
+ void init(const IntSet& s);
234
+ //@}
235
+
236
+ /// \name Iteration control
237
+ //@{
238
+ /// Test whether iterator is still at a range or done
239
+ bool operator()(void) const;
240
+ /// Move iterator to next range (if possible)
241
+ void operator++(void);
242
+ //@}
243
+
244
+ /// \name Range access
245
+ //@{
246
+ /// Return smallest value of range
247
+ int min(void) const;
248
+ /// Return largest value of range
249
+ int max(void) const;
250
+ /// Return width of range (distance between minimum and maximum)
251
+ unsigned int width(void) const;
252
+ //@}
253
+ };
254
+
255
+ /**
256
+ * \brief Value iterator for integer sets
257
+ *
258
+ * \ingroup TaskModelIntVars TaskModelSetVars
259
+ */
260
+ class IntSetValues : public Iter::Ranges::ToValues<IntSetRanges> {
261
+ public:
262
+ /// \name Constructors and initialization
263
+ //@{
264
+ /// Default constructor
265
+ IntSetValues(void);
266
+ /// Initialize with values for \a s
267
+ IntSetValues(const IntSet& s);
268
+ /// Initialize with values for \a s
269
+ void init(const IntSet& s);
270
+ //@}
271
+ };
272
+
273
+ }
274
+
275
+ /**
276
+ * \brief Print integer set \a s
277
+ * \relates Gecode::IntSet
278
+ */
279
+ GECODE_INT_EXPORT std::ostream&
280
+ operator<<(std::ostream&, const Gecode::IntSet& s);
281
+
282
+ #include "gecode/int/int-set.icc"
283
+
284
+ #include "gecode/int/var-imp.icc"
285
+
286
+ namespace Gecode {
287
+
288
+ namespace Int {
289
+ class IntView;
290
+ }
291
+
292
+ /**
293
+ * \brief Integer variables
294
+ *
295
+ * \ingroup TaskModelIntVars
296
+ */
297
+ class IntVar : public VarBase<Int::IntVarImp> {
298
+ friend class IntVarArray;
299
+ private:
300
+ using VarBase<Int::IntVarImp>::varimp;
301
+ /**
302
+ * \brief Initialize variable with range domain
303
+ *
304
+ * The variable is created with a domain ranging from \a min
305
+ * to \a max. No exceptions are thrown.
306
+ */
307
+ void _init(Space* home, int min, int max);
308
+ /**
309
+ * \brief Initialize variable with arbitrary domain
310
+ *
311
+ * The variable is created with a domain described by \a d.
312
+ * No exceptions are thrown.
313
+ */
314
+ void _init(Space* home, const IntSet& d);
315
+ public:
316
+ /// \name Constructors and initialization
317
+ //@{
318
+ /// Default constructor
319
+ IntVar(void);
320
+ /// Initialize from integer variable \a x
321
+ IntVar(const IntVar& x);
322
+ /// Initialize from integer view \a x
323
+ IntVar(const Int::IntView& x);
324
+ /// Initialize from reflection variable \a x
325
+ IntVar(const Reflection::Var& x);
326
+ /**
327
+ * \brief Initialize variable with range domain
328
+ *
329
+ * The variable is created with a domain ranging from \a min
330
+ * to \a max. The following exceptions might be thrown:
331
+ * - If \a min is greater than \a max, an exception of type
332
+ * Gecode::Int::VariableEmptyDomain is thrown.
333
+ * - If \a min or \a max exceed the limits for integers as defined
334
+ * in Gecode::Int::Limits, an exception of type
335
+ * Gecode::Int::OutOfLimits is thrown.
336
+ */
337
+ GECODE_INT_EXPORT IntVar(Space* home, int min ,int max);
338
+ /**
339
+ * \brief Initialize variable with arbitrary domain
340
+ *
341
+ * The variable is created with a domain described by \a d.
342
+ * The following exceptions might be thrown:
343
+ * - If \a d is empty, an exception of type
344
+ * Gecode::Int::VariableEmptyDomain is thrown.
345
+ * - If \a d contains values that exceed the limits for integers
346
+ * as defined in Gecode::Int::Limits, an exception of type
347
+ * Gecode::Int::OutOfLimits is thrown.
348
+ */
349
+ GECODE_INT_EXPORT IntVar(Space* home, const IntSet& d);
350
+ /**
351
+ * \brief Initialize variable with range domain
352
+ *
353
+ * The variable is created with a domain ranging from \a min
354
+ * to \a max. The following exceptions might be thrown:
355
+ * - If \a min is greater than \a max, an exception of type
356
+ * Gecode::Int::VariableEmptyDomain is thrown.
357
+ * - If \a min or \a max exceed the limits for integers as defined
358
+ * in Gecode::Int::Limits, an exception of type
359
+ * Gecode::Int::OutOfLimits is thrown.
360
+ */
361
+ GECODE_INT_EXPORT void init(Space* home, int min, int max);
362
+ /**
363
+ * \brief Initialize variable with arbitrary domain
364
+ *
365
+ * The variable is created with a domain described by \a d.
366
+ * The following exceptions might be thrown:
367
+ * - If \a d is empty, an exception of type
368
+ * Gecode::Int::VariableEmptyDomain is thrown.
369
+ * - If \a d contains values that exceed the limits for integers
370
+ * as defined in Gecode::Int::Limits, an exception of type
371
+ * Gecode::Int::OutOfLimits is thrown.
372
+ */
373
+ GECODE_INT_EXPORT void init(Space* home, const IntSet& d);
374
+ //@}
375
+
376
+ /// \name Value access
377
+ //@{
378
+ /// Return minimum of domain
379
+ int min(void) const;
380
+ /// Return maximum of domain
381
+ int max(void) const;
382
+ /// Return median of domain
383
+ int med(void) const;
384
+ /**
385
+ * \brief Return assigned value
386
+ *
387
+ * Throws an exception of type Int::ValOfUnassignedVar if variable
388
+ * is not yet assigned.
389
+ *
390
+ */
391
+ int val(void) const;
392
+
393
+ /// Return size (cardinality) of domain
394
+ unsigned int size(void) const;
395
+ /// Return width of domain (distance between maximum and minimum)
396
+ unsigned int width(void) const;
397
+ //@}
398
+
399
+ /// \name Domain tests
400
+ //@{
401
+ /// Test whether domain is a range
402
+ bool range(void) const;
403
+ /// Test whether view is assigned
404
+ bool assigned(void) const;
405
+
406
+ /// Test whether \a n is contained in domain
407
+ bool in(int n) const;
408
+ //@}
409
+
410
+ /// \name Cloning
411
+ //@{
412
+ /// Update this variable to be a clone of variable \a x
413
+ void update(Space* home, bool share, IntVar& x);
414
+ //@}
415
+ };
416
+
417
+
418
+ /**
419
+ * \brief %Range iterator for integer variables
420
+ * \ingroup TaskModelIntVars
421
+ */
422
+ class IntVarRanges : public Int::IntVarImpFwd {
423
+ public:
424
+ /// \name Constructors and initialization
425
+ //@{
426
+ /// Default constructor
427
+ IntVarRanges(void);
428
+ /// Initialize with ranges for integer variable \a x
429
+ IntVarRanges(const IntVar& x);
430
+ /// Initialize with ranges for integer variable \a x
431
+ void init(const IntVar& x);
432
+ //@}
433
+ };
434
+
435
+ /**
436
+ * \brief Value iterator for integer variables
437
+ * \ingroup TaskModelIntVars
438
+ */
439
+ class IntVarValues : public Iter::Ranges::ToValues<IntVarRanges> {
440
+ public:
441
+ /// \name Constructors and initialization
442
+ //@{
443
+ /// Default constructor
444
+ IntVarValues(void);
445
+ /// Initialize with values for \a x
446
+ IntVarValues(const IntVar& x);
447
+ /// Initialize with values \a x
448
+ void init(const IntVar& x);
449
+ //@}
450
+ };
451
+
452
+ namespace Int {
453
+ class BoolView;
454
+ }
455
+
456
+ /**
457
+ * \brief Boolean integer variables
458
+ *
459
+ * \ingroup TaskModelIntVars
460
+ */
461
+ class BoolVar : public VarBase<Int::BoolVarImp> {
462
+ friend class BoolVarArray;
463
+ private:
464
+ using VarBase<Int::BoolVarImp>::varimp;
465
+ /**
466
+ * \brief Initialize Boolean variable with range domain
467
+ *
468
+ * The variable is created with a domain ranging from \a min
469
+ * to \a max. No exceptions are thrown.
470
+ */
471
+ void _init(Space* home, int min, int max);
472
+ public:
473
+ /// \name Constructors and initialization
474
+ //@{
475
+ /// Default constructor
476
+ BoolVar(void);
477
+ /// Initialize from Boolean variable \a x
478
+ BoolVar(const BoolVar& x);
479
+ /// Initialize from Boolean view \a x
480
+ BoolVar(const Int::BoolView& x);
481
+ /// Initialize from reflection variable \a x
482
+ BoolVar(const Reflection::Var& x);
483
+ /**
484
+ * \brief Initialize Boolean variable with range domain
485
+ *
486
+ * The variable is created with a domain ranging from \a min
487
+ * to \a max. The following exceptions might be thrown:
488
+ * - If \a min is greater than \a max, an exception of type
489
+ * Gecode::Int::VariableEmptyDomain is thrown.
490
+ * - If \a min is less than 0 or \a max is greater than 1,
491
+ * an exception of type
492
+ * Gecode::Int::NotZeroOne is thrown.
493
+ */
494
+ GECODE_INT_EXPORT BoolVar(Space* home, int min, int max);
495
+ /**
496
+ * \brief Initialize Boolean variable with range domain
497
+ *
498
+ * The variable is created with a domain ranging from \a min
499
+ * to \a max. The following exceptions might be thrown:
500
+ * - If \a min is greater than \a max, an exception of type
501
+ * Gecode::Int::VariableEmptyDomain is thrown.
502
+ * - If \a min is less than 0 or \a max is greater than 1,
503
+ * an exception of type
504
+ * Gecode::Int::NotZerOne is thrown.
505
+ */
506
+ GECODE_INT_EXPORT void init(Space* home, int min, int max);
507
+ //@}
508
+
509
+ /// \name Value access
510
+ //@{
511
+ /// Return minimum of domain
512
+ int min(void) const;
513
+ /// Return maximum of domain
514
+ int max(void) const;
515
+ /// Return median of domain
516
+ int med(void) const;
517
+ /**
518
+ * \brief Return assigned value
519
+ *
520
+ * Throws an exception of type Int::ValOfUnassignedVar if variable
521
+ * is not yet assigned.
522
+ *
523
+ */
524
+ int val(void) const;
525
+
526
+ /// Return size (cardinality) of domain
527
+ unsigned int size(void) const;
528
+ /// Return width of domain (distance between maximum and minimum)
529
+ unsigned int width(void) const;
530
+ //@}
531
+
532
+ /// \name Domain tests
533
+ //@{
534
+ /// Test whether domain is a range
535
+ bool range(void) const;
536
+ /// Test whether view is assigned
537
+ bool assigned(void) const;
538
+
539
+ /// Test whether \a n is contained in domain
540
+ bool in(int n) const;
541
+ //@}
542
+
543
+ /// \name Boolean domain tests
544
+ //@{
545
+ /// Test whether domain is zero
546
+ bool zero(void) const;
547
+ /// Test whether domain is one
548
+ bool one(void) const;
549
+ /// Test whether domain is neither zero nor one
550
+ bool none(void) const;
551
+ //@}
552
+
553
+ /// \name Cloning
554
+ //@{
555
+ /// Update this variable to be a clone of variable \a x
556
+ void update(Space* home, bool share, BoolVar& x);
557
+ //@}
558
+
559
+ };
560
+
561
+ }
562
+
563
+ /**
564
+ * \brief Print integer variable \a x
565
+ * \relates Gecode::IntVar
566
+ */
567
+ std::ostream&
568
+ operator<<(std::ostream&, const Gecode::IntVar& x);
569
+ /**
570
+ * \brief Print Boolean variable \a x
571
+ * \relates Gecode::BoolVar
572
+ */
573
+ std::ostream&
574
+ operator<<(std::ostream&, const Gecode::BoolVar& x);
575
+
576
+ #include "gecode/int/view.icc"
577
+ #include "gecode/int/propagator.icc"
578
+
579
+ namespace Gecode {
580
+
581
+ /**
582
+ * \defgroup TaskModelIntArgs Argument arrays
583
+ *
584
+ * Argument arrays are just good enough for passing arguments
585
+ * with automatic memory management.
586
+ * \ingroup TaskModelInt
587
+ */
588
+
589
+ //@{
590
+ /// Passing integer arguments
591
+ typedef PrimArgArray<int> IntArgs;
592
+ /// Passing integer variables
593
+ typedef VarArgArray<IntVar> IntVarArgs;
594
+ /// Passing Boolean variables
595
+ typedef VarArgArray<BoolVar> BoolVarArgs;
596
+ /// Passing set arguments
597
+ typedef PrimArgArray<IntSet> IntSetArgs;
598
+ //@}
599
+
600
+ /**
601
+ * \defgroup TaskModelIntVarArrays Variable arrays
602
+ *
603
+ * Variable arrays can store variables. They are typically used
604
+ * for storing the variables being part of a solution (script). However,
605
+ * they can also be used for temporary purposes (even though
606
+ * memory is not reclaimed until the space it is created for
607
+ * is deleted).
608
+ * \ingroup TaskModelInt
609
+ */
610
+
611
+ /**
612
+ * \brief Integer variable array
613
+ * \ingroup TaskModelIntVarArrays
614
+ */
615
+ class IntVarArray : public VarArray<IntVar> {
616
+ public:
617
+ /// \name Creation and initialization
618
+ //@{
619
+ /// Default constructor (array of size 0)
620
+ IntVarArray(void);
621
+ /// Allocate array for \a n integer variables (variables are uninitialized)
622
+ IntVarArray(Space* home, int n);
623
+ /// Initialize from integer variable array \a a (share elements)
624
+ IntVarArray(const IntVarArray& a);
625
+ /**
626
+ * \brief Initialize array with \a n new variables
627
+ *
628
+ * The variables are created with a domain ranging from \a min
629
+ * to \a max. The following execptions might be thrown:
630
+ * - If \a min is greater than \a max, an exception of type
631
+ * Gecode::Int::VariableEmptyDomain is thrown.
632
+ * - If \a min or \a max exceed the limits for integers as defined
633
+ * in Gecode::Int::Limits, an exception of type
634
+ * Gecode::Int::OutOfLimits is thrown.
635
+ */
636
+ GECODE_INT_EXPORT
637
+ IntVarArray(Space* home, int n, int min, int max);
638
+ /**
639
+ * \brief Initialize array with \a n new variables
640
+ *
641
+ * The variables are created with a domain described by \a s.
642
+ * The following execptions might be thrown:
643
+ * - If \a s is empty, an exception of type
644
+ * Gecode::Int::VariableEmptyDomain is thrown.
645
+ * - If \a s contains values that exceed the limits for integers
646
+ * as defined in Gecode::Int::Limits, an exception of type
647
+ * Gecode::Int::OutOfLimits is thrown.
648
+ */
649
+ GECODE_INT_EXPORT
650
+ IntVarArray(Space* home, int n, const IntSet& s);
651
+ //@}
652
+ };
653
+
654
+ /**
655
+ * \brief Boolean variable array
656
+ * \ingroup TaskModelIntVarArrays
657
+ */
658
+ class BoolVarArray : public VarArray<BoolVar> {
659
+ public:
660
+ /// \name Creation and initialization
661
+ //@{
662
+ /// Default constructor (array of size 0)
663
+ BoolVarArray(void);
664
+ /// Allocate array for \a n Boolean variables (variables are uninitialized)
665
+ BoolVarArray(Space* home, int n);
666
+ /// Initialize from Boolean variable array \a a (share elements)
667
+ BoolVarArray(const BoolVarArray& a);
668
+ /**
669
+ * \brief Initialize array with \a n new variables
670
+ *
671
+ * The variables are created with a domain ranging from \a min
672
+ * to \a max. The following execptions might be thrown:
673
+ * - If \a min is greater than \a max, an exception of type
674
+ * Gecode::Int::VariableEmptyDomain is thrown.
675
+ * - If \a min is less than 0 or \a max is greater than 1,
676
+ * an exception of type
677
+ * Gecode::Int::NotZeroOne is thrown.
678
+ */
679
+ GECODE_INT_EXPORT
680
+ BoolVarArray(Space* home, int n, int min, int max);
681
+ //@}
682
+ };
683
+
684
+ }
685
+
686
+ #include "gecode/int/array.icc"
687
+
688
+ namespace Gecode {
689
+
690
+ /**
691
+ * \brief Relation types for integers
692
+ * \ingroup TaskModelInt
693
+ */
694
+ enum IntRelType {
695
+ IRT_EQ, ///< Equality (\f$=\f$)
696
+ IRT_NQ, ///< Disequality (\f$\neq\f$)
697
+ IRT_LQ, ///< Less or equal (\f$\leq\f$)
698
+ IRT_LE, ///< Less (\f$<\f$)
699
+ IRT_GQ, ///< Greater or equal (\f$\geq\f$)
700
+ IRT_GR ///< Greater (\f$>\f$)
701
+ };
702
+
703
+ /**
704
+ * \brief Operation types for Booleans
705
+ * \ingroup TaskModelInt
706
+ */
707
+ enum BoolOpType {
708
+ BOT_AND, ///< Conjunction
709
+ BOT_OR, ///< Disjunction
710
+ BOT_IMP, ///< Implication
711
+ BOT_EQV, ///< Equivalence
712
+ BOT_XOR ///< Exclusive or
713
+ };
714
+
715
+ /**
716
+ * \brief Consistency levels for integer propagators
717
+ *
718
+ * The descriptions are meant to be suggestions. It is not
719
+ * required that a propagator achieves full domain consistency or
720
+ * full bounds consistency. It is more like: which level
721
+ * of consistency comes closest.
722
+ *
723
+ * If in the description of a constraint below no consistency level
724
+ * is mentioned, the propagator for the constraint implements
725
+ * domain consistency.
726
+ * \ingroup TaskModelInt
727
+ */
728
+ enum IntConLevel {
729
+ ICL_VAL, ///< Value consistency (naive)
730
+ ICL_BND, ///< Bounds consistency
731
+ ICL_DOM, ///< Domain consistency
732
+ ICL_DEF ///< The default consistency for a constraint
733
+ };
734
+
735
+
736
+
737
+ /**
738
+ * \defgroup TaskModelIntDomain Domain constraints
739
+ * \ingroup TaskModelInt
740
+ *
741
+ */
742
+
743
+ //@{
744
+ /// Propagates \f$ l\leq x\leq m\f$
745
+ GECODE_INT_EXPORT void
746
+ dom(Space* home, IntVar x, int l, int m,
747
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
748
+ /// Propagates \f$ l\leq x_i\leq m\f$ for all \f$0\leq i<|x|\f$
749
+ GECODE_INT_EXPORT void
750
+ dom(Space* home, const IntVarArgs& x, int l, int m,
751
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
752
+
753
+ /// Propagates \f$ x\in s \f$
754
+ GECODE_INT_EXPORT void
755
+ dom(Space* home, IntVar x, const IntSet& s,
756
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
757
+ /// Propagates \f$ x_i\in s\f$ for all \f$0\leq i<|x|\f$
758
+ GECODE_INT_EXPORT void
759
+ dom(Space* home, const IntVarArgs& x, const IntSet& s,
760
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
761
+
762
+ /// Post propagator for \f$ (l\leq x \leq m) \Leftrightarrow b\f$
763
+ GECODE_INT_EXPORT void
764
+ dom(Space* home, IntVar x, int l, int m, BoolVar b,
765
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
766
+ /// Post propagator for \f$ (x \in s) \Leftrightarrow b\f$
767
+ GECODE_INT_EXPORT void
768
+ dom(Space* home, IntVar x, const IntSet& s, BoolVar b,
769
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
770
+ //@}
771
+
772
+
773
+ /**
774
+ * \defgroup TaskModelIntRelInt Simple relation constraints over integer variables
775
+ * \ingroup TaskModelInt
776
+ */
777
+ //@{
778
+ /** \brief Post propagator for \f$ x_0 \sim_r x_1\f$
779
+ *
780
+ * Supports both bounds (\a icl = ICL_BND) and
781
+ * domain consistency (\a icl = ICL_DOM, default).
782
+ */
783
+ GECODE_INT_EXPORT void
784
+ rel(Space* home, IntVar x0, IntRelType r, IntVar x1,
785
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
786
+ /** \brief Post propagators for \f$ x_i \sim_r y \f$ for all \f$0\leq i<|x|\f$
787
+ *
788
+ * Supports both bounds (\a icl = ICL_BND) and
789
+ * domain consistency (\a icl = ICL_DOM, default).
790
+ */
791
+ GECODE_INT_EXPORT void
792
+ rel(Space* home, const IntVarArgs& x, IntRelType r, IntVar y,
793
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
794
+ /// Propagates \f$ x \sim_r c\f$
795
+ GECODE_INT_EXPORT void
796
+ rel(Space* home, IntVar x, IntRelType r, int c,
797
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
798
+ /// Propagates \f$ x_i \sim_r c \f$ for all \f$0\leq i<|x|\f$
799
+ GECODE_INT_EXPORT void
800
+ rel(Space* home, const IntVarArgs& x, IntRelType r, int c,
801
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
802
+ /** \brief Post propagator for \f$ (x_0 \sim_r x_1)\Leftrightarrow b\f$
803
+ *
804
+ * Supports both bounds (\a icl = ICL_BND) and
805
+ * domain consistency (\a icl = ICL_DOM, default).
806
+ */
807
+ GECODE_INT_EXPORT void
808
+ rel(Space* home, IntVar x0, IntRelType r, IntVar x1, BoolVar b,
809
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
810
+ /** \brief Post propagator for \f$(x \sim_r c)\Leftrightarrow b\f$
811
+ *
812
+ * Supports both bounds (\a icl = ICL_BND) and
813
+ * domain consistency (\a icl = ICL_DOM, default).
814
+ */
815
+ GECODE_INT_EXPORT void
816
+ rel(Space* home, IntVar x, IntRelType r, int c, BoolVar b,
817
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
818
+ /** \brief Post propagator for pairwise relation on \a x.
819
+ *
820
+ * States that the elements of \a x are in the following relation:
821
+ * - if \a r = IRT_EQ, then all elements of \a x must be equal.
822
+ * Supports both bounds (\a icl = ICL_BND) and
823
+ * domain consistency (\a icl = ICL_DOM, default).
824
+ * - if \a r = IRT_LE, \a r = IRT_LQ, \a r = IRT_GR, or \a r = IRT_GQ,
825
+ * then the elements of \a x are ordered with respt to \a r.
826
+ * Supports domain consistency (\a icl = ICL_DOM, default).
827
+ * - if \a r = IRT_NQ, then all elements of \a x must be pairwise
828
+ * distinct (corresponds to the distinct constraint).
829
+ * Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
830
+ * and domain consistency (\a icl = ICL_DOM).
831
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
832
+ * the same unassigned variable multiply.
833
+ *
834
+ */
835
+ GECODE_INT_EXPORT void
836
+ rel(Space* home, const IntVarArgs& x, IntRelType r,
837
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
838
+ /** \brief Post propagator for relation between \a x and \a y.
839
+ *
840
+ * Note that for the inequality relations this corresponds to
841
+ * the lexical order between \a x and \a y.
842
+ *
843
+ * Supports both bounds (\a icl = ICL_BND) and
844
+ * domain consistency (\a icl = ICL_DOM, default).
845
+ *
846
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
847
+ * \a x and \a y are of different size.
848
+ */
849
+ GECODE_INT_EXPORT void
850
+ rel(Space* home, const IntVarArgs& x, IntRelType r, const IntVarArgs& y,
851
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
852
+ //@}
853
+
854
+
855
+ /**
856
+ * \defgroup TaskModelIntRelBool Simple relation constraints over Boolean variables
857
+ * \ingroup TaskModelInt
858
+ */
859
+ //@{
860
+ /// Post propagator for \f$ x_0 \sim_r x_1\f$
861
+ GECODE_INT_EXPORT void
862
+ rel(Space* home, BoolVar x0, IntRelType r, BoolVar x1,
863
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
864
+ /// Post propagator for \f$(x_0 \sim_r x_1)\Leftrightarrow b\f$
865
+ GECODE_INT_EXPORT void
866
+ rel(Space* home, BoolVar x0, IntRelType r, BoolVar x1, BoolVar b,
867
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
868
+ /// Post propagator for \f$ x_i \sim_r y \f$ for all \f$0\leq i<|x|\f$
869
+ GECODE_INT_EXPORT void
870
+ rel(Space* home, const BoolVarArgs& x, IntRelType r, BoolVar y,
871
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
872
+ /**
873
+ * \brief Propagates \f$ x \sim_r n\f$
874
+ *
875
+ * Throws an exception of type Int::NotZeroOne, if \a n is neither
876
+ * 0 or 1.
877
+ */
878
+ GECODE_INT_EXPORT void
879
+ rel(Space* home, BoolVar x, IntRelType r, int n,
880
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
881
+ /**
882
+ * \brief Propagates \f$(x \sim_r n)\Leftrightarrow b\f$
883
+ *
884
+ * Throws an exception of type Int::NotZeroOne, if \a n is neither
885
+ * 0 or 1.
886
+ */
887
+ GECODE_INT_EXPORT void
888
+ rel(Space* home, BoolVar x, IntRelType r, int n, BoolVar b,
889
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
890
+ /**
891
+ * \brief Propagates \f$ x_i \sim_r n \f$ for all \f$0\leq i<|x|\f$
892
+ *
893
+ * Throws an exception of type Int::NotZeroOne, if \a n is neither
894
+ * 0 or 1.
895
+ */
896
+ GECODE_INT_EXPORT void
897
+ rel(Space* home, const BoolVarArgs& x, IntRelType r, int n,
898
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
899
+ /** \brief Post propagator for relation between \a x and \a y.
900
+ *
901
+ * Note that for the inequality relations this corresponds to
902
+ * the lexical order between \a x and \a y.
903
+ *
904
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
905
+ * \a x and \a y are of different size.
906
+ */
907
+ GECODE_INT_EXPORT void
908
+ rel(Space* home, const BoolVarArgs& x, IntRelType r, const BoolVarArgs& y,
909
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
910
+ /** \brief Post propagator for pairwise relation on \a x.
911
+ *
912
+ * States that the elements of \a x are in the following relation:
913
+ * - if \a r = IRT_EQ, then all elements of \a x must be equal.
914
+ * - if \a r = IRT_LE, \a r = IRT_LQ, \a r = IRT_GR, or \a r = IRT_GQ,
915
+ * then the elements of \a x are ordered with respt to \a r.
916
+ * - if \a r = IRT_NQ, then all elements of \a x must be pairwise
917
+ * distinct (corresponds to the distinct constraint).
918
+ *
919
+ */
920
+ GECODE_INT_EXPORT void
921
+ rel(Space* home, const BoolVarArgs& x, IntRelType r,
922
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
923
+ /** \brief Post propagator for Boolean operation on \a x0 and \a x1
924
+ *
925
+ * Posts propagator for \f$ x_0 \diamond_{\mathit{o}} x_1 = x_2\f$
926
+ */
927
+ GECODE_INT_EXPORT void
928
+ rel(Space* home, BoolVar x0, BoolOpType o, BoolVar x1, BoolVar x2,
929
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
930
+ /** \brief Post propagator for Boolean operation on \a x0 and \a x1
931
+ *
932
+ * Posts propagator for \f$ x_0 \diamond_{\mathit{o}} x_1 = n\f$
933
+ *
934
+ * Throws an exception of type Int::NotZeroOne, if \a n is neither
935
+ * 0 or 1.
936
+ */
937
+ GECODE_INT_EXPORT void
938
+ rel(Space* home, BoolVar x0, BoolOpType o, BoolVar x1, int n,
939
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
940
+ /** \brief Post propagator for Boolean operation on \a x
941
+ *
942
+ * Posts propagator for \f$ x_0 \diamond_{\mathit{o}} \cdots
943
+ * \diamond_{\mathit{o}} x_{|x|-1}= y\f$
944
+ *
945
+ * Throws an exception of type Int::TooFewArguments, if \f$|x|<2\f$
946
+ * and \a o is BOT_IMP, BOT_EQV, or BOT_XOR.
947
+ */
948
+ GECODE_INT_EXPORT void
949
+ rel(Space* home, BoolOpType o, const BoolVarArgs& x, BoolVar y,
950
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
951
+ /** \brief Post propagator for Boolean operation on \a x
952
+ *
953
+ * Posts propagator for \f$ x_0 \diamond_{\mathit{o}} \cdots
954
+ * \diamond_{\mathit{o}} x_{|x|-1}= n\f$
955
+ *
956
+ * Throws an exception of type Int::NotZeroOne, if \a n is neither
957
+ * 0 or 1.
958
+ *
959
+ * Throws an exception of type Int::TooFewArguments, if \f$|x|<2\f$
960
+ * and \a o is BOT_IMP, BOT_EQV, or BOT_XOR.
961
+ */
962
+ GECODE_INT_EXPORT void
963
+ rel(Space* home, BoolOpType o, const BoolVarArgs& x, int n,
964
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
965
+ //@}
966
+
967
+
968
+ /**
969
+ * \defgroup TaskModelIntElement Element constraints
970
+ * \ingroup TaskModelInt
971
+ */
972
+
973
+ //@{
974
+ /** \brief Post propagator for \f$ n_{x_0}=x_1\f$
975
+ *
976
+ * Throws an exception of type Int::OutOfLimits, if
977
+ * the integers in \a n exceed the limits in Int::Limits.
978
+ */
979
+ GECODE_INT_EXPORT void
980
+ element(Space* home, const IntArgs& n, IntVar x0, IntVar x1,
981
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
982
+ /** \brief Post propagator for \f$ n_{x_0}=x_1\f$
983
+ *
984
+ * Throws an exception of type Int::OutOfLimits, if
985
+ * the integers in \a n exceed the limits in Int::Limits.
986
+ */
987
+ GECODE_INT_EXPORT void
988
+ element(Space* home, const IntArgs& n, IntVar x0, BoolVar x1,
989
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
990
+ /** \brief Post propagator for \f$ n_{x_0}=x_1\f$
991
+ *
992
+ * Throws an exception of type Int::OutOfLimits, if
993
+ * the integers in \a n exceed the limits in Int::Limits.
994
+ */
995
+ GECODE_INT_EXPORT void
996
+ element(Space* home, const IntArgs& n, IntVar x0, int x1,
997
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
998
+ /** \brief Post propagator for \f$ x_{y_0}=y_1\f$
999
+ *
1000
+ * Supports both bounds (\a icl = ICL_BND) and
1001
+ * domain consistency (\a icl = ICL_DOM, default).
1002
+ */
1003
+ GECODE_INT_EXPORT void
1004
+ element(Space* home, const IntVarArgs& x, IntVar y0, IntVar y1,
1005
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1006
+ /** \brief Post propagator for \f$ x_{y_0}=y_1\f$
1007
+ *
1008
+ * Supports both bounds (\a icl = ICL_BND) and
1009
+ * domain consistency (\a icl = ICL_DOM, default).
1010
+ */
1011
+ GECODE_INT_EXPORT void
1012
+ element(Space* home, const IntVarArgs& x, IntVar y0, int y1,
1013
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1014
+ /// Post propagator for \f$ x_{y_0}=y_1\f$
1015
+ GECODE_INT_EXPORT void
1016
+ element(Space* home, const BoolVarArgs& x, IntVar y0, BoolVar y1,
1017
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1018
+ /// Post propagator for \f$ x_{y_0}=y_1\f$
1019
+ GECODE_INT_EXPORT void
1020
+ element(Space* home, const BoolVarArgs& x, IntVar y0, int y1,
1021
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1022
+ //@}
1023
+
1024
+
1025
+ /**
1026
+ * \defgroup TaskModelIntDistinct Distinct constraints
1027
+ * \ingroup TaskModelInt
1028
+ */
1029
+
1030
+ //@{
1031
+ /** \brief Post propagator for \f$ x_i\neq x_j\f$ for all \f$0\leq i\neq j<|x|\f$
1032
+ *
1033
+ * Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
1034
+ * and domain consistency (\a icl = ICL_DOM).
1035
+ *
1036
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1037
+ * the same unassigned variable multiply.
1038
+ */
1039
+ GECODE_INT_EXPORT void
1040
+ distinct(Space* home, const IntVarArgs& x,
1041
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1042
+ /** \brief Post propagator for \f$ x_i+n_i\neq x_j+n_j\f$ for all \f$0\leq i\neq j<|x|\f$
1043
+ *
1044
+ * \li Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
1045
+ * and domain consistency (\a icl = ICL_DOM).
1046
+ * \li Throws an exception of type Int::OutOfLimits, if
1047
+ * the integers in \a n exceed the limits in Int::Limits
1048
+ * or if the sum of \a n and \a x exceed the limits.
1049
+ * \li Throws an exception of type Int::ArgumentSizeMismatch, if
1050
+ * \a x and \a n are of different size.
1051
+ * \li Throws an exception of type Int::ArgumentSame, if \a x contains
1052
+ * the same unassigned variable multiply.
1053
+ */
1054
+ GECODE_INT_EXPORT void
1055
+ distinct(Space* home, const IntArgs& n, const IntVarArgs& x,
1056
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1057
+ //@}
1058
+
1059
+
1060
+ /**
1061
+ * \defgroup TaskModelIntChannel Channel constraints
1062
+ * \ingroup TaskModelInt
1063
+ */
1064
+
1065
+ //@{
1066
+ /** \brief Post propagator for \f$ x_i = j\leftrightarrow y_j=i\f$ for all \f$0\leq i<|x|\f$
1067
+ *
1068
+ * \li Supports domain (\a icl = ICL_DOM) and value propagation (all other
1069
+ * values for \a icl).
1070
+ * \li Throws an exception of type Int::ArgumentSizeMismatch, if
1071
+ * \a x and \a y are of different size.
1072
+ * \li Throws an exception of type Int::ArgumentSame, if \a x or
1073
+ * \a y contain the same unassigned variable multiply. Note that a
1074
+ * variable can occur in both \a x and \a y, but not more than
1075
+ * once in either \a x or \a y.
1076
+ */
1077
+ GECODE_INT_EXPORT void
1078
+ channel(Space* home, const IntVarArgs& x, const IntVarArgs& y,
1079
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1080
+
1081
+ /** \brief Post propagator for \f$ x_i - \mathit{xoff} = j\leftrightarrow y_j - \mathit{yoff} = i\f$ for all \f$0\leq i<|x|\f$
1082
+ *
1083
+ * \li Supports domain (\a icl = ICL_DOM) and value propagation (all other
1084
+ * values for \a icl).
1085
+ * \li Throws an exception of type Int::ArgumentSizeMismatch, if
1086
+ * \a x and \a y are of different size.
1087
+ * \li Throws an exception of type Int::ArgumentSame, if \a x or
1088
+ * \a y contain the same unassigned variable multiply. Note that a
1089
+ * variable can occur in both \a x and \a y, but not more than
1090
+ * once in either \a x or \a y.
1091
+ */
1092
+ GECODE_INT_EXPORT void
1093
+ channel(Space* home, const IntVarArgs& x, unsigned int xoff,
1094
+ const IntVarArgs& y, unsigned int yoff,
1095
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1096
+
1097
+ /// Post propagator for channeling a Boolean and an integer variable \f$ x_0 = x_1\f$
1098
+ GECODE_INT_EXPORT void
1099
+ channel(Space* home, BoolVar x0, IntVar x1,
1100
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1101
+ /// Post propagator for channeling an integer and a Boolean variable \f$ x_0 = x_1\f$
1102
+ forceinline void
1103
+ channel(Space* home, IntVar x0, BoolVar x1,
1104
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
1105
+ channel(home,x1,x0,icl,pk);
1106
+ }
1107
+ /** \brief Post propagator for channeling Boolean and integer variables \f$ x_i = 1\leftrightarrow y=i+o\f$
1108
+ *
1109
+ * Throws an exception of type Int::ArgumentSame, if \a x
1110
+ * contains the same unassigned variable multiply.
1111
+ */
1112
+ GECODE_INT_EXPORT void
1113
+ channel(Space* home, const BoolVarArgs& x, IntVar y, int o=0,
1114
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1115
+ //@}
1116
+
1117
+
1118
+ /**
1119
+ * \defgroup TaskModelIntGraph Graph constraints
1120
+ * \ingroup TaskModelInt
1121
+ */
1122
+
1123
+ //@{
1124
+ /** \brief Post propagator such that \a x forms a circuit
1125
+ *
1126
+ * \a x forms a circuit if the graph with edges \f$i\to j\f$ where
1127
+ * \f$x_i=j\f$ has a single cycle covering all nodes.
1128
+ *
1129
+ * Supports domain (\a icl = ICL_DOM) and value propagation (all
1130
+ * other values for \a icl), where this refers to whether value or
1131
+ * domain consistent distinct in enforced on \a x.
1132
+ *
1133
+ * Throws an exception of type Int::ArgumentSame, if \a x
1134
+ * contains the same unassigned variable multiply.
1135
+ */
1136
+ GECODE_INT_EXPORT void
1137
+ circuit(Space* home, const IntVarArgs& x,
1138
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1139
+ //@}
1140
+
1141
+
1142
+ /**
1143
+ * \defgroup TaskModelIntScheduling Scheduling constraints
1144
+ * \ingroup TaskModelInt
1145
+ */
1146
+ //@{
1147
+ /**
1148
+ * \brief Post propagators for the cumulatives constraint.
1149
+ *
1150
+ * This function creates propagators for the cumulatives constraint
1151
+ * presented in <em> "A new multi-resource cumulatives constraint
1152
+ * with negative heights"</em>, Nicolas Beldiceanu and Mats
1153
+ * Carlsson, Principles and Practice of Constraint Programming 2002.
1154
+ *
1155
+ * The constraint models a set of machines and a set of tasks that
1156
+ * should be assigned to the machines. The machines have a positive
1157
+ * resource limit and the tasks each have a resource usage that can
1158
+ * be either positive, negative, or zero. The constraint is enforced
1159
+ * over each point in time for a machine where there is at least one
1160
+ * task assigned.
1161
+ *
1162
+ * The limit for a machine is either the maximum amount available at
1163
+ * any given time (\a at_most = true), or else the least amount to
1164
+ * be used (\a at_most = false).
1165
+ *
1166
+ * \param machine \f$ machine_i \f$ is the machine assigned to task \f$ i \f$
1167
+ * \param start \f$ start_i \f$ is the start date assigned to task \f$ i \f$
1168
+ * \param duration \f$ duration_i \f$ is the duration of task \f$ i \f$
1169
+ * \param end \f$ end_i \f$ is the end date assigned to task \f$ i \f$
1170
+ * \param height \f$ height_i \f$ is the height is the amount of
1171
+ * resources consumed by task \f$ i \f$
1172
+ * \param limit \f$ limit_r \f$ is the amount of resource available
1173
+ * for machine \f$ r \f$
1174
+ * \param at_most \a at_most tells if the amount of resources used
1175
+ * for a machine should be less than the limit (\a at_most
1176
+ * = true) or greater than the limit (\a at_most = false)
1177
+ * \param icl Supports value-consistency only (\a icl = ICL_VAL, default).
1178
+ *
1179
+ * \exception Int::ArgumentSizeMismatch thrown if the sizes of the arguments
1180
+ * representing tasks does not match.
1181
+ * \exception Int::OutOfLimits thrown if any numerical argument is
1182
+ * larger than Int::Limits::max or less than
1183
+ * Int::Limits::min.
1184
+ */
1185
+ GECODE_INT_EXPORT void
1186
+ cumulatives(Space* home, const IntVarArgs& machine,
1187
+ const IntVarArgs& start, const IntVarArgs& duration,
1188
+ const IntVarArgs& end, const IntVarArgs& height,
1189
+ const IntArgs& limit, bool at_most,
1190
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1191
+ /** \brief Post propagators for the cumulatives constraint.
1192
+ *
1193
+ * \copydoc cumulatives()
1194
+ */
1195
+ GECODE_INT_EXPORT void
1196
+ cumulatives(Space* home, const IntArgs& machine,
1197
+ const IntVarArgs& start, const IntVarArgs& duration,
1198
+ const IntVarArgs& end, const IntVarArgs& height,
1199
+ const IntArgs& limit, bool at_most,
1200
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1201
+ /** \brief Post propagators for the cumulatives constraint.
1202
+ *
1203
+ * \copydoc cumulatives()
1204
+ */
1205
+ GECODE_INT_EXPORT void
1206
+ cumulatives(Space* home, const IntVarArgs& machine,
1207
+ const IntVarArgs& start, const IntArgs& duration,
1208
+ const IntVarArgs& end, const IntVarArgs& height,
1209
+ const IntArgs& limit, bool at_most,
1210
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1211
+ /** \brief Post propagators for the cumulatives constraint.
1212
+ *
1213
+ * \copydoc cumulatives()
1214
+ */
1215
+ GECODE_INT_EXPORT void
1216
+ cumulatives(Space* home, const IntArgs& machine,
1217
+ const IntVarArgs& start, const IntArgs& duration,
1218
+ const IntVarArgs& end, const IntVarArgs& height,
1219
+ const IntArgs& limit, bool at_most,
1220
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1221
+ /** \brief Post propagators for the cumulatives constraint.
1222
+ *
1223
+ * \copydoc cumulatives()
1224
+ */
1225
+ GECODE_INT_EXPORT void
1226
+ cumulatives(Space* home, const IntVarArgs& machine,
1227
+ const IntVarArgs& start, const IntVarArgs& duration,
1228
+ const IntVarArgs& end, const IntArgs& height,
1229
+ const IntArgs& limit, bool at_most,
1230
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1231
+ /** \brief Post propagators for the cumulatives constraint.
1232
+ *
1233
+ * \copydoc cumulatives()
1234
+ */
1235
+ GECODE_INT_EXPORT void
1236
+ cumulatives(Space* home, const IntArgs& machine,
1237
+ const IntVarArgs& start, const IntVarArgs& duration,
1238
+ const IntVarArgs& end, const IntArgs& height,
1239
+ const IntArgs& limit, bool at_most,
1240
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1241
+ /** \brief Post propagators for the cumulatives constraint.
1242
+ *
1243
+ * \copydoc cumulatives()
1244
+ */
1245
+ GECODE_INT_EXPORT void
1246
+ cumulatives(Space* home, const IntVarArgs& machine,
1247
+ const IntVarArgs& start, const IntArgs& duration,
1248
+ const IntVarArgs& end, const IntArgs& height,
1249
+ const IntArgs& limit, bool at_most,
1250
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1251
+ /** \brief Post propagators for the cumulatives constraint.
1252
+ *
1253
+ * \copydoc cumulatives()
1254
+ */
1255
+ GECODE_INT_EXPORT void
1256
+ cumulatives(Space* home, const IntArgs& machine,
1257
+ const IntVarArgs& start, const IntArgs& duration,
1258
+ const IntVarArgs& end, const IntArgs& height,
1259
+ const IntArgs& limit, bool at_most,
1260
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1261
+ //@}
1262
+
1263
+
1264
+ /**
1265
+ * \defgroup TaskModelIntSorted Sorted constraints
1266
+ *
1267
+ * All sorted constraints support bounds consistency.
1268
+ *
1269
+ * \ingroup TaskModelInt
1270
+ */
1271
+ //@{
1272
+ /**
1273
+ * \brief Post propagator that \a y is \a x sorted in increasing order
1274
+ *
1275
+ * Might throw the following exceptions:
1276
+ * - Int::ArgumentSizeMismatch, if \a x and \a y differ in size.
1277
+ * - Int::ArgumentSame, if \a x or \a y contain
1278
+ * shared unassigned variables.
1279
+ */
1280
+ GECODE_INT_EXPORT void
1281
+ sorted(Space* home, const IntVarArgs& x, const IntVarArgs& y,
1282
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1283
+
1284
+ /**
1285
+ * \brief Post propagator that \a y is \a x sorted in increasing order
1286
+ *
1287
+ * The values in \a z describe the sorting permutation, that is
1288
+ * \f$\forall i\in\{0,\dots,|x|-1\}: x_i=y_{z_i} \f$.
1289
+ *
1290
+ * Might throw the following exceptions:
1291
+ * - Int::ArgumentSizeMismatch, if \a x and \a y differ in size.
1292
+ * - Int::ArgumentSame, if \a x or \a y contain
1293
+ * shared unassigned variables.
1294
+ */
1295
+ GECODE_INT_EXPORT void
1296
+ sorted(Space*, const IntVarArgs& x, const IntVarArgs& y,
1297
+ const IntVarArgs& z,
1298
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1299
+ //@}
1300
+
1301
+
1302
+ /**
1303
+ * \defgroup TaskModelIntCard Cardinality constraints
1304
+ * \ingroup TaskModelInt
1305
+ *
1306
+ * \note
1307
+ * Domain consistency on the extended cardinality variables of
1308
+ * the Global Cardinality Propagator is only obtained if they are bounds
1309
+ * consistent, otherwise the problem of enforcing domain consistency
1310
+ * on the cardinality variables is NP-complete as proved by
1311
+ * \ref CardVarNPCompl "Qumiper et. al. in
1312
+ * Improved Algorithms for the Global Cardinality Constraint"
1313
+ */
1314
+
1315
+ //@{
1316
+ /** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}\sim_r m\f$
1317
+ *
1318
+ * Supports domain consistent propagation only.
1319
+ */
1320
+ GECODE_INT_EXPORT void
1321
+ count(Space* home, const IntVarArgs& x, int n, IntRelType r, int m,
1322
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1323
+ /** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}\sim_r m\f$
1324
+ *
1325
+ * Supports domain consistent propagation only.
1326
+ */
1327
+ GECODE_INT_EXPORT void
1328
+ count(Space* home, const IntVarArgs& x, IntVar y, IntRelType r, int m,
1329
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1330
+ /** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}\sim_r m\f$
1331
+ *
1332
+ * Supports domain consistent propagation only.
1333
+ *
1334
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1335
+ * \a x and \a y are of different size.
1336
+ */
1337
+ GECODE_INT_EXPORT void
1338
+ count(Space* home, const IntVarArgs& x, const IntArgs& y, IntRelType r, int m,
1339
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1340
+ /** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}\sim_r z\f$
1341
+ *
1342
+ * Supports domain consistent propagation only.
1343
+ */
1344
+ GECODE_INT_EXPORT void
1345
+ count(Space* home, const IntVarArgs& x, int n, IntRelType r, IntVar z,
1346
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1347
+ /** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}\sim_r z\f$
1348
+ *
1349
+ * Supports domain consistent propagation only.
1350
+ */
1351
+ GECODE_INT_EXPORT void
1352
+ count(Space* home, const IntVarArgs& x, IntVar y, IntRelType r, IntVar z,
1353
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1354
+ /** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}\sim_r z\f$
1355
+ *
1356
+ * Supports domain consistent propagation only.
1357
+ *
1358
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1359
+ * \a x and \a y are of different size.
1360
+ */
1361
+ GECODE_INT_EXPORT void
1362
+ count(Space* home, const IntVarArgs& x, const IntArgs& y, IntRelType r, IntVar z,
1363
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1364
+
1365
+ /** \brief Posts a global count (cardinality) constraint
1366
+ *
1367
+ * Posts the constraint that
1368
+ * \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=j\}=c_j\f$ and
1369
+ * \f$ \bigcup_i \{x_i\} \subseteq \{0,\ldots,|c|-1\}\f$
1370
+ * (no other value occurs).
1371
+ *
1372
+ * Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
1373
+ * and domain consistency (\a icl = ICL_DOM).
1374
+ *
1375
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1376
+ * the same unassigned variable multiply.
1377
+ */
1378
+ GECODE_INT_EXPORT void
1379
+ count(Space* home, const IntVarArgs& x, const IntVarArgs& c,
1380
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1381
+
1382
+ /** \brief Posts a global count (cardinality) constraint
1383
+ *
1384
+ * Posts the constraint that
1385
+ * \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=j\}\in c_j\f$ and
1386
+ * \f$ \bigcup_i \{x_i\} \subseteq \{0,\ldots,|c|-1\}\f$
1387
+ * (no other value occurs).
1388
+ *
1389
+ * Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
1390
+ * and domain consistency (\a icl = ICL_DOM).
1391
+ *
1392
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1393
+ * the same unassigned variable multiply.
1394
+ */
1395
+ GECODE_INT_EXPORT void
1396
+ count(Space* home, const IntVarArgs& x, const IntSetArgs& c,
1397
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1398
+
1399
+ /** \brief Posts a global count (cardinality) constraint
1400
+ *
1401
+ * Posts the constraint that
1402
+ * \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=v_j\}=c_j\f$ and
1403
+ * \f$ \bigcup_i \{x_i\} \subseteq \bigcup_j \{v_j\}\f$
1404
+ * (no other value occurs).
1405
+ *
1406
+ * Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
1407
+ * and domain consistency (\a icl = ICL_DOM).
1408
+ *
1409
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1410
+ * the same unassigned variable multiply.
1411
+ *
1412
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1413
+ * \a cards and \a values are of different size.
1414
+ */
1415
+ GECODE_INT_EXPORT void
1416
+ count(Space* home, const IntVarArgs& x,
1417
+ const IntVarArgs& c, const IntArgs& v,
1418
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1419
+
1420
+ /** \brief Posts a global count (cardinality) constraint
1421
+ *
1422
+ * Posts the constraint that
1423
+ * \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=v_j\}\in c_j\f$ and
1424
+ * \f$ \bigcup_i \{x_i\} \subseteq \bigcup_j \{v_j\}\f$
1425
+ * (no other value occurs).
1426
+ *
1427
+ * Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
1428
+ * and domain consistency (\a icl = ICL_DOM).
1429
+ *
1430
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1431
+ * the same unassigned variable multiply.
1432
+ *
1433
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1434
+ * \a cards and \a values are of different size.
1435
+ */
1436
+ GECODE_INT_EXPORT void
1437
+ count(Space* home, const IntVarArgs& x,
1438
+ const IntSetArgs& c, const IntArgs& v,
1439
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1440
+
1441
+ /** \brief Posts a global count (cardinality) constraint
1442
+ *
1443
+ * Posts the constraint that
1444
+ * \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=v_j\}\in c\f$ and
1445
+ * \f$ \bigcup_i \{x_i\} \subseteq \bigcup_j \{v_j\}\f$
1446
+ * (no other value occurs).
1447
+ *
1448
+ * Supports value (\a icl = ICL_VAL, default), bounds (\a icl = ICL_BND),
1449
+ * and domain consistency (\a icl = ICL_DOM).
1450
+ *
1451
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1452
+ * the same unassigned variable multiply.
1453
+ *
1454
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1455
+ * \a cards and \a values are of different size.
1456
+ */
1457
+ GECODE_INT_EXPORT void
1458
+ count(Space* home, const IntVarArgs& x,
1459
+ const IntSet& c, const IntArgs& v,
1460
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1461
+
1462
+ //@}
1463
+
1464
+ /**
1465
+ * \defgroup TaskModelIntExt Extensional constraints
1466
+ * \ingroup TaskModelInt
1467
+ *
1468
+ * Extensional constraints support different ways of how the
1469
+ * extensionally defined relation between the variables is defined.
1470
+ * Examples include specification by a %DFA or a table.
1471
+ *
1472
+ * A %DFA can be defined by a regular expression, for regular expressions
1473
+ * see the module MiniModel.
1474
+ */
1475
+ //@{
1476
+
1477
+ /**
1478
+ * \brief Deterministic finite automaton (%DFA)
1479
+ *
1480
+ * After initialization, the start state is always zero.
1481
+ * The final states are contiguous ranging from the first to the
1482
+ * last final state.
1483
+ */
1484
+ class DFA : public SharedHandle {
1485
+ private:
1486
+ /// Implementation of DFA
1487
+ class DFAI;
1488
+ public:
1489
+ /// Specification of a %DFA transition
1490
+ class Transition {
1491
+ public:
1492
+ int i_state; ///< input state
1493
+ int symbol; ///< symbol
1494
+ int o_state; ///< output state
1495
+ };
1496
+ /// Iterator for %DFA transitions (sorted by symbols)
1497
+ class Transitions {
1498
+ private:
1499
+ /// Current transition
1500
+ const Transition* c_trans;
1501
+ /// End of transitions
1502
+ const Transition* e_trans;
1503
+ public:
1504
+ /// Initialize to all transitions of DFA \a d
1505
+ Transitions(const DFA& d);
1506
+ /// Initialize to transitions of DFA \a d for symbol \a n
1507
+ Transitions(const DFA& d, int n);
1508
+ /// Test whether iterator still at a transition
1509
+ bool operator()(void) const;
1510
+ /// Move iterator to next transition
1511
+ void operator++(void);
1512
+ /// Return in-state of current transition
1513
+ int i_state(void) const;
1514
+ /// Return symbol of current transition
1515
+ int symbol(void) const;
1516
+ /// Return out-state of current transition
1517
+ int o_state(void) const;
1518
+ };
1519
+ /// Iterator for %DFA symbols
1520
+ class Symbols {
1521
+ private:
1522
+ /// Current transition
1523
+ const Transition* c_trans;
1524
+ /// End of transitions
1525
+ const Transition* e_trans;
1526
+ public:
1527
+ /// Initialize to symbols of DFA \a d
1528
+ Symbols(const DFA& d);
1529
+ /// Test whether iterator still at a symbol
1530
+ bool operator()(void) const;
1531
+ /// Move iterator to next symbol
1532
+ void operator++(void);
1533
+ /// Return current symbol
1534
+ int val(void) const;
1535
+ };
1536
+ public:
1537
+ friend class Transitions;
1538
+ /// Initialize for DFA accepting the empty word
1539
+ DFA(void);
1540
+ /**
1541
+ * \brief Initialize DFA
1542
+ *
1543
+ * - Start state is given by \a s.
1544
+ * - %Transitions are described by \a t, where the last element
1545
+ * must have -1 as value for \c i_state.
1546
+ * - Final states are given by \a f, where the last final element
1547
+ * must be -1.
1548
+ * - Minimizes the DFA, if \a minimize is true.
1549
+ * - Note that the transitions must be deterministic.
1550
+ */
1551
+ GECODE_INT_EXPORT
1552
+ DFA(int s, Transition t[], int f[], bool minimize=true);
1553
+ /// Initialize by DFA \a d (DFA is shared)
1554
+ DFA(const DFA& d);
1555
+ /// Return the number of states
1556
+ unsigned int n_states(void) const;
1557
+ /// Return the number of symbols
1558
+ unsigned int n_symbols(void) const;
1559
+ /// Return the number of transitions
1560
+ unsigned int n_transitions(void) const;
1561
+ /// Return the number of the first final state
1562
+ int final_fst(void) const;
1563
+ /// Return the number of the last final state
1564
+ int final_lst(void) const;
1565
+ /// Return smallest symbol in DFA
1566
+ int symbol_min(void) const;
1567
+ /// Return largest symbol in DFA
1568
+ int symbol_max(void) const;
1569
+
1570
+ /// Initialize DFA from reflection specification
1571
+ GECODE_INT_EXPORT DFA(Reflection::VarMap& vm, Reflection::Arg* arg);
1572
+ /// Create reflection specification for the DFA
1573
+ GECODE_INT_EXPORT Reflection::Arg* spec(Reflection::VarMap& vm) const;
1574
+ };
1575
+
1576
+ /**
1577
+ * \brief Post propagator for extensional constraint described by a DFA
1578
+ *
1579
+ * The elements of \a x must be a word of the language described by
1580
+ * the DFA \a d.
1581
+ *
1582
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1583
+ * the same unassigned variable multiply. If shared occurences of variables
1584
+ * are required, unshare should be used.
1585
+ */
1586
+ GECODE_INT_EXPORT void
1587
+ extensional(Space* home, const IntVarArgs& x, DFA d,
1588
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1589
+
1590
+ /**
1591
+ * \brief Post propagator for extensional constraint described by a DFA
1592
+ *
1593
+ * The elements of \a x must be a word of the language described by
1594
+ * the DFA \a d.
1595
+ *
1596
+ * Throws an exception of type Int::ArgumentSame, if \a x contains
1597
+ * the same unassigned variable multiply. If shared occurences of variables
1598
+ * are required, unshare should be used.
1599
+ */
1600
+ GECODE_INT_EXPORT void
1601
+ extensional(Space* home, const BoolVarArgs& x, DFA d,
1602
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1603
+
1604
+ /** \brief Class represeting a set of tuples.
1605
+ *
1606
+ * A TupleSet is used for storing an extensional representation of a
1607
+ * constraint. After a TupleSet is finalized, no more tuples may be
1608
+ * added to it.
1609
+ */
1610
+ class TupleSet : public SharedHandle {
1611
+ public:
1612
+ /** \brief Type of a tuple
1613
+ *
1614
+ * The arity of the tuple is left implicit.
1615
+ */
1616
+ typedef int* Tuple;
1617
+
1618
+ /// Class for table data
1619
+ class TupleSetI;
1620
+ /// Get implementation
1621
+ TupleSetI* implementation(void);
1622
+
1623
+ /// Construct empty tuple
1624
+ TupleSet(void);
1625
+ /// Initialize by TupleSet \a d (tuple set is shared)
1626
+ TupleSet(const TupleSet& d);
1627
+
1628
+ /// Add tuple to tuple set
1629
+ void add(const IntArgs& tuple);
1630
+ /// Finalize tuple set
1631
+ void finalize(void);
1632
+ /// Is tuple set finalized
1633
+ bool finalized(void) const;
1634
+ /// Arity of tuple set
1635
+ int arity(void) const;
1636
+ /// Number of tuples
1637
+ int tuples(void) const;
1638
+ /// Get tuple i
1639
+ Tuple operator[](int i) const;
1640
+ /// Minimum domain size
1641
+ int min(void) const;
1642
+ /// Maximum domain size
1643
+ int max(void) const;
1644
+
1645
+ /// Initialize TupleSet from reflection specification
1646
+ GECODE_INT_EXPORT TupleSet(Reflection::VarMap& vm, Reflection::Arg* arg);
1647
+ /// Create reflection specification for the TupleSet
1648
+ GECODE_INT_EXPORT Reflection::Arg* spec(Reflection::VarMap& vm) const;
1649
+ };
1650
+
1651
+ /** \brief Post propagator for \f$x\in T\f$.
1652
+ *
1653
+ * \li Supports implementations optimized for memory (\a pk = \a
1654
+ * PK_MEMORY, default) and speed (\a pk = \a PK_SPEED).
1655
+ * \li Supports domain consistency (\a icl = ICL_DOM, default) only.
1656
+ * \li Throws an exception of type Int::ArgumentSizeMismatch, if
1657
+ * \a x and \a t are of different size.
1658
+ *
1659
+ * \warning If the domains for the \f$x_i\f$ are not dense and
1660
+ * have similar bounds, lots of memory will be wasted (memory
1661
+ * consumption is in \f$
1662
+ * O\left(|x|\cdot\min_i(\underline{x_i})\cdot\max_i(\overline{x_i})\right)\f$
1663
+ * for the basic algorithm (\a pk = \a PK_MEMORY) and additionally \f$
1664
+ * O\left(|x|^2\cdot\min_i(\underline{x_i})\cdot\max_i(\overline{x_i})\right)\f$
1665
+ * for the incremental algorithm (\a pk = \a PK_SPEED).
1666
+ */
1667
+ GECODE_INT_EXPORT void
1668
+ extensional(Space* home, const IntVarArgs& x, const TupleSet& t,
1669
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1670
+
1671
+ /** \brief Post propagator for \f$x\in T\f$.
1672
+ *
1673
+ * \li Supports implementations optimized for memory (\a pk = \a
1674
+ * PK_MEMORY, default) and speed (\a pk = \a PK_SPEED).
1675
+ * \li Supports domain consistency (\a icl = ICL_DOM, default) only.
1676
+ * \li Throws an exception of type Int::ArgumentSizeMismatch, if
1677
+ * \a x and \a t are of different size.
1678
+ */
1679
+ GECODE_INT_EXPORT void
1680
+ extensional(Space* home, const BoolVarArgs& x, const TupleSet& t,
1681
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1682
+ //@}
1683
+ }
1684
+
1685
+ #include "gecode/int/extensional/dfa.icc"
1686
+ #include "gecode/int/extensional/tuple-set.icc"
1687
+
1688
+ namespace Gecode {
1689
+
1690
+ /**
1691
+ * \defgroup TaskModelIntArith Arithmetic constraints
1692
+ * \ingroup TaskModelInt
1693
+ */
1694
+
1695
+ //@{
1696
+ /** \brief Post propagator for \f$ \min\{x_0,x_1\}=x_2\f$
1697
+ *
1698
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1699
+ * and domain consistency (\a icl = ICL_DOM).
1700
+ */
1701
+ GECODE_INT_EXPORT void
1702
+ min(Space* home, IntVar x0, IntVar x1, IntVar x2,
1703
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1704
+ /** \brief Post propagator for \f$ \min x=y\f$
1705
+ *
1706
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1707
+ * and domain consistency (\a icl = ICL_DOM).
1708
+ *
1709
+ * If \a x is empty, an exception of type Int::TooFewArguments is thrown.
1710
+ */
1711
+ GECODE_INT_EXPORT void
1712
+ min(Space* home, const IntVarArgs& x, IntVar y,
1713
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1714
+ /** \brief Post propagator for \f$ \max\{x_0,x_1\}=x_2\f$
1715
+ *
1716
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1717
+ * and domain consistency (\a icl = ICL_DOM).
1718
+ */
1719
+ GECODE_INT_EXPORT void
1720
+ max(Space* home, IntVar x0, IntVar x1, IntVar x2,
1721
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1722
+ /** \brief Post propagator for \f$ \max x=y\f$
1723
+ *
1724
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1725
+ * and domain consistency (\a icl = ICL_DOM).
1726
+ *
1727
+ * If \a x is empty, an exception of type Int::TooFewArguments is thrown.
1728
+ */
1729
+ GECODE_INT_EXPORT void
1730
+ max(Space* home, const IntVarArgs& x, IntVar y,
1731
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1732
+
1733
+ /** \brief Post propagator for \f$ |x_0|=x_1\f$
1734
+ *
1735
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1736
+ * and domain consistency (\a icl = ICL_DOM).
1737
+ */
1738
+ GECODE_INT_EXPORT void
1739
+ abs(Space* home, IntVar x0, IntVar x1,
1740
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1741
+
1742
+ /** \brief Post propagator for \f$x_0\cdot x_1=x_2\f$
1743
+ *
1744
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1745
+ * and domain consistency (\a icl = ICL_DOM).
1746
+ */
1747
+ GECODE_INT_EXPORT void
1748
+ mult(Space* home, IntVar x0, IntVar x1, IntVar x2,
1749
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1750
+
1751
+ /** \brief Post propagator for \f$x_0\cdot x_0=x_1\f$
1752
+ *
1753
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1754
+ * and domain consistency (\a icl = ICL_DOM).
1755
+ */
1756
+ GECODE_INT_EXPORT void
1757
+ sqr(Space* home, IntVar x0, IntVar x1,
1758
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1759
+
1760
+ /** \brief Post propagator for \f$\lfloor\sqrt{x_0}\rfloor=x_1\f$
1761
+ *
1762
+ * Supports both bounds consistency (\a icl = ICL_BND, default)
1763
+ * and domain consistency (\a icl = ICL_DOM).
1764
+ */
1765
+ GECODE_INT_EXPORT void
1766
+ sqrt(Space* home, IntVar x0, IntVar x1,
1767
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1768
+
1769
+ /** \brief Post propagator for \f$x_0\mathrm{div} x_1=x_2 \land x_0\mathrm{mod} x_1 = x_3\f$
1770
+ *
1771
+ * Supports bounds consistency (\a icl = ICL_BND, default).
1772
+ */
1773
+ GECODE_INT_EXPORT void
1774
+ divmod(Space* home, IntVar x0, IntVar x1, IntVar x2, IntVar x3,
1775
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1776
+
1777
+ /** \brief Post propagator for \f$x_0\mathrm{div} x_1=x_2\f$
1778
+ *
1779
+ * Supports bounds consistency (\a icl = ICL_BND, default).
1780
+ */
1781
+ GECODE_INT_EXPORT void
1782
+ div(Space* home, IntVar x0, IntVar x1, IntVar x2,
1783
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1784
+
1785
+ /** \brief Post propagator for \f$x_0\mathrm{mod} x_1=x_2\f$
1786
+ *
1787
+ * Supports bounds consistency (\a icl = ICL_BND, default).
1788
+ */
1789
+ GECODE_INT_EXPORT void
1790
+ mod(Space* home, IntVar x0, IntVar x1, IntVar x2,
1791
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1792
+ //@}
1793
+
1794
+ /**
1795
+ * \defgroup TaskModelIntLinearInt Linear constraints over integer variables
1796
+ * \ingroup TaskModelInt
1797
+ *
1798
+ * All variants for linear constraints over integer variables share
1799
+ * the following properties:
1800
+ * - Bounds consistency (over the real numbers) is supported for
1801
+ * all constraints (actually, for disequlities always domain consistency
1802
+ * is used as it is cheaper). Domain consistency is supported for all
1803
+ * non-reified constraint. As bounds consistency for inequalities
1804
+ * coincides with domain consistency, the only
1805
+ * real variation is for linear equations. Domain consistent
1806
+ * linear equations have exponential complexity, so use with care!
1807
+ * - Variables occurring multiply in the argument arrays are replaced
1808
+ * by a single occurrence: for example, \f$ax+bx\f$ becomes
1809
+ * \f$(a+b)x\f$.
1810
+ * - If in the above simplification the value for \f$(a+b)\f$ (or for
1811
+ * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1812
+ * defined in Int::Limits, an exception of type
1813
+ * Int::OutOfLimits is thrown.
1814
+ * - Assume the constraint
1815
+ * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1816
+ * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the maximal
1817
+ * available precision (at least \f$2^{48}\f$), an exception of
1818
+ * type Int::OutOfLimits is thrown.
1819
+ * - In all other cases, the created propagators are accurate (that
1820
+ * is, they will not silently overflow during propagation).
1821
+ */
1822
+ //@{
1823
+ /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i\sim_r c\f$
1824
+ GECODE_INT_EXPORT void
1825
+ linear(Space* home, const IntVarArgs& x,
1826
+ IntRelType r, int c,
1827
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1828
+ /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i\sim_r y\f$
1829
+ GECODE_INT_EXPORT void
1830
+ linear(Space* home, const IntVarArgs& x,
1831
+ IntRelType r, IntVar y,
1832
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1833
+ /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i\sim_r c\right)\Leftrightarrow b\f$
1834
+ GECODE_INT_EXPORT void
1835
+ linear(Space* home, const IntVarArgs& x,
1836
+ IntRelType r, int c, BoolVar b,
1837
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1838
+ /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i\sim_r y\right)\Leftrightarrow b\f$
1839
+ GECODE_INT_EXPORT void
1840
+ linear(Space* home, const IntVarArgs& x,
1841
+ IntRelType r, IntVar y, BoolVar b,
1842
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1843
+ /** \brief Post propagator for \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$
1844
+ *
1845
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1846
+ * \a a and \a x are of different size.
1847
+ */
1848
+ GECODE_INT_EXPORT void
1849
+ linear(Space* home, const IntArgs& a, const IntVarArgs& x,
1850
+ IntRelType r, int c,
1851
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1852
+ /** \brief Post propagator for \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r y\f$
1853
+ *
1854
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1855
+ * \a a and \a x are of different size.
1856
+ */
1857
+ GECODE_INT_EXPORT void
1858
+ linear(Space* home, const IntArgs& a, const IntVarArgs& x,
1859
+ IntRelType r, IntVar y,
1860
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1861
+ /** \brief Post propagator for \f$\left(\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\right)\Leftrightarrow b\f$
1862
+ *
1863
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1864
+ * \a a and \a x are of different size.
1865
+ */
1866
+ GECODE_INT_EXPORT void
1867
+ linear(Space* home, const IntArgs& a, const IntVarArgs& x,
1868
+ IntRelType r, int c, BoolVar b,
1869
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1870
+ /** \brief Post propagator for \f$\left(\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r y\right)\Leftrightarrow b\f$
1871
+ *
1872
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1873
+ * \a a and \a x are of different size.
1874
+ */
1875
+ GECODE_INT_EXPORT void
1876
+ linear(Space* home, const IntArgs& a, const IntVarArgs& x,
1877
+ IntRelType r, IntVar y, BoolVar b,
1878
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1879
+ //@}
1880
+
1881
+
1882
+ /**
1883
+ * \defgroup TaskModelIntLinearBool Linear constraints over Boolean variables
1884
+ * \ingroup TaskModelInt
1885
+ *
1886
+ * All variants for linear constraints over Boolean variables share
1887
+ * the following properties:
1888
+ * - Bounds consistency (over the real numbers) is supported for
1889
+ * all constraints (actually, for disequlities always domain consistency
1890
+ * is used as it is cheaper).
1891
+ * - Variables occurring multiply in the argument arrays are replaced
1892
+ * by a single occurrence: for example, \f$ax+bx\f$ becomes
1893
+ * \f$(a+b)x\f$.
1894
+ * - If in the above simplification the value for \f$(a+b)\f$ (or for
1895
+ * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1896
+ * defined in Int::Limits, an exception of type
1897
+ * Int::OutOfLimits is thrown.
1898
+ * - Assume the constraint
1899
+ * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1900
+ * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
1901
+ * for integers as defined in Int::Limits, an exception of
1902
+ * type Int::OutOfLimits is thrown.
1903
+ * - In all other cases, the created propagators are accurate (that
1904
+ * is, they will not silently overflow during propagation).
1905
+ */
1906
+ //@{
1907
+ /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i\sim_r c\f$
1908
+ GECODE_INT_EXPORT void
1909
+ linear(Space* home, const BoolVarArgs& x,
1910
+ IntRelType r, int c,
1911
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1912
+ /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i\sim_r c\right)\Leftrightarrow b\f$
1913
+ GECODE_INT_EXPORT void
1914
+ linear(Space* home, const BoolVarArgs& x,
1915
+ IntRelType r, int c, BoolVar b,
1916
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1917
+ /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i\sim_r y\f$
1918
+ GECODE_INT_EXPORT void
1919
+ linear(Space* home, const BoolVarArgs& x,
1920
+ IntRelType r, IntVar y,
1921
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1922
+ /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i\sim_r y\right)\Leftrightarrow b\f$
1923
+ GECODE_INT_EXPORT void
1924
+ linear(Space* home, const BoolVarArgs& x,
1925
+ IntRelType r, IntVar y, BoolVar b,
1926
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1927
+ /** \brief Post propagator for \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$
1928
+ *
1929
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1930
+ * \a a and \a x are of different size.
1931
+ */
1932
+ GECODE_INT_EXPORT void
1933
+ linear(Space* home, const IntArgs& a, const BoolVarArgs& x,
1934
+ IntRelType r, int c,
1935
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1936
+ /** \brief Post propagator for \f$\left(\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\right)\Leftrightarrow b\f$
1937
+ *
1938
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1939
+ * \a a and \a x are of different size.
1940
+ */
1941
+ GECODE_INT_EXPORT void
1942
+ linear(Space* home, const IntArgs& a, const BoolVarArgs& x,
1943
+ IntRelType r, int c, BoolVar b,
1944
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1945
+ /** \brief Post propagator for \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r y\f$
1946
+ *
1947
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1948
+ * \a a and \a x are of different size.
1949
+ */
1950
+ GECODE_INT_EXPORT void
1951
+ linear(Space* home, const IntArgs& a, const BoolVarArgs& x,
1952
+ IntRelType r, IntVar y,
1953
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1954
+ /** \brief Post propagator for \f$\left(\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r y\right)\Leftrightarrow b\f$
1955
+ *
1956
+ * Throws an exception of type Int::ArgumentSizeMismatch, if
1957
+ * \a a and \a x are of different size.
1958
+ */
1959
+ GECODE_INT_EXPORT void
1960
+ linear(Space* home, const IntArgs& a, const BoolVarArgs& x,
1961
+ IntRelType r, IntVar y, BoolVar b,
1962
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1963
+ //@}
1964
+
1965
+
1966
+ /**
1967
+ * \defgroup TaskModelIntUnshare Unsharing variables
1968
+ * \ingroup TaskModelInt
1969
+ *
1970
+ * Unsharing replaces multiple occurences of the same variable by
1971
+ * fresh yet equal (enforced through propagators for equality)
1972
+ * variables: after unsharing a variable appears at most once. Note
1973
+ * that this is only done for not yet assigned variables (as all
1974
+ * propagators can handle multiple occurences of the same variable
1975
+ * provided it is already assigned).
1976
+ *
1977
+ * Unsharing is useful for constraints that only accept variable
1978
+ * arrays without multiple occurences of the same variable, for
1979
+ * example extensional.
1980
+ *
1981
+ * \ingroup TaskModelInt
1982
+ */
1983
+ //@{
1984
+ /**
1985
+ * \brief Replace multiple variable occurences in \a x by fresh variables
1986
+ *
1987
+ * Supports domain consistency (\a icl = ICL_DOM, default) and
1988
+ * bounds consistency (\a icl = ICL_BND).
1989
+ *
1990
+ */
1991
+ GECODE_INT_EXPORT void
1992
+ unshare(Space* home, IntVarArgs& x,
1993
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1994
+ /// Replace multiple variable occurences in \a x by fresh variables
1995
+ GECODE_INT_EXPORT void
1996
+ unshare(Space* home, BoolVarArgs& x,
1997
+ IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
1998
+ //@}
1999
+
2000
+
2001
+ /**
2002
+ * \defgroup TaskModelIntBranch Branching
2003
+ * \ingroup TaskModelInt
2004
+ */
2005
+ //@{
2006
+ /// Which variable to select for branching
2007
+ enum IntVarBranch {
2008
+ INT_VAR_NONE, ///< First unassigned
2009
+ INT_VAR_MIN_MIN, ///< With smallest min
2010
+ INT_VAR_MIN_MAX, ///< With largest min
2011
+ INT_VAR_MAX_MIN, ///< With smallest max
2012
+ INT_VAR_MAX_MAX, ///< With largest max
2013
+ INT_VAR_SIZE_MIN, ///< With smallest domain size
2014
+ INT_VAR_SIZE_MAX, ///< With largest domain size
2015
+ /** \brief With smallest degree
2016
+ *
2017
+ * The degree of a variable is defined as the number of dependant
2018
+ * propagators. In case of ties, choose the variable with smallest
2019
+ * domain.
2020
+ */
2021
+ INT_VAR_DEGREE_MIN,
2022
+ /** \brief With largest degree
2023
+ *
2024
+ * The degree of a variable is defined as the number of dependant
2025
+ * propagators. In case of ties, choose the variable with smallest
2026
+ * domain.
2027
+ */
2028
+ INT_VAR_DEGREE_MAX,
2029
+ INT_VAR_SIZE_DEGREE_MIN, ///< With smallest domain size divided by degree
2030
+ INT_VAR_SIZE_DEGREE_MAX, ///< With largest domain size divided by degree
2031
+ /** \brief With smallest min-regret
2032
+ *
2033
+ * The min-regret of a variable is the difference between the
2034
+ * smallest and second-smallest value still in the domain.
2035
+ */
2036
+ INT_VAR_REGRET_MIN_MIN,
2037
+ /** \brief With largest min-regret
2038
+ *
2039
+ * The min-regret of a variable is the difference between the
2040
+ * smallest and second-smallest value still in the domain.
2041
+ */
2042
+ INT_VAR_REGRET_MIN_MAX,
2043
+ /** \brief With smallest max-regret
2044
+ *
2045
+ * The max-regret of a variable is the difference between the
2046
+ * largest and second-largest value still in the domain.
2047
+ */
2048
+ INT_VAR_REGRET_MAX_MIN,
2049
+ /** \brief With largest max-regret
2050
+ *
2051
+ * The max-regret of a variable is the difference between the
2052
+ * largest and second-largest value still in the domain.
2053
+ */
2054
+ INT_VAR_REGRET_MAX_MAX
2055
+ };
2056
+
2057
+ /// Which values to select first for branching
2058
+ enum IntValBranch {
2059
+ INT_VAL_MIN, ///< Select smallest value
2060
+ INT_VAL_MED, ///< Select median value
2061
+ INT_VAL_MAX, ///< Select maximal value
2062
+ INT_VAL_SPLIT_MIN, ///< Select lower half of domain
2063
+ INT_VAL_SPLIT_MAX ///< Select upper half of domain
2064
+ };
2065
+
2066
+ /// Branch over \a x with variable selection \a vars and value selection \a vals
2067
+ GECODE_INT_EXPORT void
2068
+ branch(Space* home, const IntVarArgs& x,
2069
+ IntVarBranch vars, IntValBranch vals);
2070
+ /// Branch over \a x with variable selection \a vars and value selection \a vals
2071
+ GECODE_INT_EXPORT void
2072
+ branch(Space* home, const BoolVarArgs& x,
2073
+ IntVarBranch vars, IntValBranch vals);
2074
+
2075
+ //@}
2076
+
2077
+ /**
2078
+ * \defgroup TaskModelIntAssign Assigning
2079
+ * \ingroup TaskModelInt
2080
+ */
2081
+ //@{
2082
+ /// Which value to select for assignment
2083
+ enum IntAssign {
2084
+ INT_ASSIGN_MIN, ///< Select smallest value
2085
+ INT_ASSIGN_MED, ///< Select median value
2086
+ INT_ASSIGN_MAX ///< Select maximum value
2087
+ };
2088
+
2089
+ /// Assign all \a x with value selection \a vals
2090
+ GECODE_INT_EXPORT void
2091
+ assign(Space* home, const IntVarArgs& x, IntAssign vals);
2092
+ /// Assign all \a x with value selection \a vals
2093
+ GECODE_INT_EXPORT void
2094
+ assign(Space* home, const BoolVarArgs& x, IntAssign vals);
2095
+
2096
+ //@}
2097
+
2098
+ }
2099
+
2100
+ /** \relates Gecode::DFA
2101
+ * Print DFA \a d
2102
+ */
2103
+ GECODE_INT_EXPORT std::ostream&
2104
+ operator<<(std::ostream&, const Gecode::DFA& d);
2105
+
2106
+ /** \relates Gecode::TupleSet
2107
+ * Print TupleSet \a ts
2108
+ */
2109
+ GECODE_INT_EXPORT std::ostream&
2110
+ operator<<(std::ostream&, const Gecode::TupleSet& ts);
2111
+
2112
+ #endif
2113
+
2114
+ // IFDEF: GECODE_HAS_INT_VARS
2115
+ // STATISTICS: int-post
2116
+