gecoder-with-gecode 0.9.0 → 0.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (919) hide show
  1. data/CHANGES +6 -0
  2. data/README +1 -1
  3. data/THANKS +18 -0
  4. data/example/equation_system.rb +3 -1
  5. data/example/magic_sequence.rb +3 -1
  6. data/example/queens.rb +3 -1
  7. data/example/send_more_money.rb +24 -30
  8. data/example/send_most_money.rb +15 -26
  9. data/example/square_tiling.rb +3 -1
  10. data/example/sudoku-set.rb +3 -1
  11. data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
  12. data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
  13. data/ext/gecode-2.2.0/Makefile.dep +8056 -0
  14. data/ext/gecode-2.2.0/Makefile.in +1590 -0
  15. data/ext/gecode-2.2.0/changelog.in +2698 -0
  16. data/ext/gecode-2.2.0/configure +13112 -0
  17. data/ext/gecode-2.2.0/configure.ac +273 -0
  18. data/ext/gecode-2.2.0/configure.ac.in +269 -0
  19. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
  20. data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
  21. data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
  22. data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
  23. data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
  24. data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
  25. data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
  26. data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
  27. data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
  28. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
  29. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
  30. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
  31. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
  32. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
  33. data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
  34. data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
  35. data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
  36. data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
  37. data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
  38. data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
  39. data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
  40. data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
  41. data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
  42. data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
  43. data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
  44. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
  45. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
  46. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
  47. data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
  48. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
  49. data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
  50. data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
  51. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
  52. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
  53. data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
  54. data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
  55. data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
  56. data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
  57. data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
  58. data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
  59. data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
  60. data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
  61. data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
  62. data/ext/gecode-2.2.0/examples/crew.cc +286 -0
  63. data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
  64. data/ext/gecode-2.2.0/examples/domino.cc +297 -0
  65. data/ext/gecode-2.2.0/examples/donald.cc +107 -0
  66. data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
  67. data/ext/gecode-2.2.0/examples/golf.cc +297 -0
  68. data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
  69. data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
  70. data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
  71. data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
  72. data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
  73. data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
  74. data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
  75. data/ext/gecode-2.2.0/examples/knights.cc +220 -0
  76. data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
  77. data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
  78. data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
  79. data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
  80. data/ext/gecode-2.2.0/examples/money.cc +105 -0
  81. data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
  82. data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
  83. data/ext/gecode-2.2.0/examples/partition.cc +141 -0
  84. data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
  85. data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
  86. data/ext/gecode-2.2.0/examples/photo.cc +170 -0
  87. data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
  88. data/ext/gecode-2.2.0/examples/queens.cc +147 -0
  89. data/ext/gecode-2.2.0/examples/queens.js +57 -0
  90. data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
  91. data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
  92. data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
  93. data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
  94. data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
  95. data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
  96. data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
  97. data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
  98. data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
  99. data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
  100. data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
  101. data/ext/gecode-2.2.0/examples/support.hh +338 -0
  102. data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
  103. data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
  104. data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
  105. data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
  106. data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
  107. data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
  108. data/ext/gecode-2.2.0/gecode.m4 +1046 -0
  109. data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
  110. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
  111. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
  112. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
  113. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
  114. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
  115. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
  116. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
  117. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
  118. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
  119. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
  120. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
  121. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
  122. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
  123. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
  124. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
  125. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
  126. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
  127. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
  128. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
  129. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
  130. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
  131. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
  132. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
  133. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
  134. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
  135. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
  136. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
  137. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
  138. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
  139. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
  140. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
  141. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
  142. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
  143. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
  144. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
  145. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
  146. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
  147. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
  148. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
  149. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
  150. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
  151. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
  152. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
  153. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
  154. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
  155. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
  156. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
  157. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
  158. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
  159. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
  160. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
  161. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
  162. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
  163. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
  164. data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
  165. data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
  166. data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
  167. data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
  168. data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
  169. data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
  170. data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
  171. data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
  172. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
  173. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
  174. data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
  175. data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
  176. data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
  177. data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
  178. data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
  179. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
  180. data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
  181. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
  182. data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
  183. data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
  184. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
  185. data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
  186. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
  187. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
  188. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
  189. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
  190. data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
  191. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
  192. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
  193. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
  194. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
  195. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
  196. data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
  197. data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
  198. data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
  199. data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
  200. data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
  201. data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
  202. data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
  203. data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
  204. data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
  205. data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
  206. data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
  207. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
  208. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
  209. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
  210. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
  211. data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
  212. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
  213. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
  214. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
  215. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
  216. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
  217. data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
  218. data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
  219. data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
  220. data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
  221. data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
  222. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
  223. data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
  224. data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
  225. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
  226. data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
  227. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
  228. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
  229. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
  230. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
  231. data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
  232. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
  233. data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
  234. data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
  235. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
  236. data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
  237. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
  238. data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
  239. data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
  240. data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
  241. data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
  242. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
  243. data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
  244. data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
  245. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
  246. data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
  247. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
  248. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
  249. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
  250. data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
  251. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
  252. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
  253. data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
  254. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
  255. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
  256. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
  257. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
  258. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
  259. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
  260. data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
  261. data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
  262. data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
  263. data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
  264. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
  265. data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
  266. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
  267. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
  268. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
  269. data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
  270. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
  271. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
  272. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
  273. data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
  274. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
  275. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
  276. data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
  277. data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
  278. data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
  279. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
  280. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
  281. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
  282. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
  283. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
  284. data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
  285. data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
  286. data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
  287. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
  288. data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
  289. data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
  290. data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
  291. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
  292. data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
  293. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
  294. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
  295. data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
  296. data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
  297. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
  298. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
  299. data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
  300. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
  301. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
  302. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
  303. data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
  304. data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
  305. data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
  306. data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
  307. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
  308. data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
  309. data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
  310. data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
  311. data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
  312. data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
  313. data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
  314. data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
  315. data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
  316. data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
  317. data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
  318. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
  319. data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
  320. data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
  321. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
  322. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
  323. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
  324. data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
  325. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
  326. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
  327. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
  328. data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
  329. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
  330. data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
  331. data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
  332. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
  333. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
  334. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
  335. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
  336. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
  337. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
  338. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
  339. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
  340. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
  341. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
  342. data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
  343. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
  344. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
  345. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
  346. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
  347. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
  348. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
  349. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
  350. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
  351. data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
  352. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
  353. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
  354. data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
  355. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
  356. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
  357. data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
  358. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
  359. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
  360. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
  361. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
  362. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
  363. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
  364. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
  365. data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
  366. data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
  367. data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
  368. data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
  369. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
  370. data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
  371. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
  372. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
  373. data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
  374. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
  375. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
  376. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
  377. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
  378. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
  379. data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
  380. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
  381. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
  382. data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
  383. data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
  384. data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
  385. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
  386. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
  387. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
  388. data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
  389. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
  390. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
  391. data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
  392. data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
  393. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
  394. data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
  395. data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
  396. data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
  397. data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
  398. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
  399. data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
  400. data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
  401. data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
  402. data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
  403. data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
  404. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
  405. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
  406. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
  407. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
  408. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
  409. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
  410. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
  411. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
  412. data/ext/gecode-2.2.0/gecode/search.hh +759 -0
  413. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
  414. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
  415. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
  416. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
  417. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
  418. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
  419. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
  420. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
  421. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
  422. data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
  423. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
  424. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
  425. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
  426. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
  427. data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
  428. data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
  429. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
  430. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
  431. data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
  432. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
  433. data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
  434. data/ext/gecode-2.2.0/gecode/set.hh +970 -0
  435. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
  436. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
  437. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
  438. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
  439. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
  440. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
  441. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
  442. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
  443. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
  444. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
  445. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
  446. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
  447. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
  448. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
  449. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
  450. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
  451. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
  452. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
  453. data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
  454. data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
  455. data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
  456. data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
  457. data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
  458. data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
  459. data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
  460. data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
  461. data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
  462. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
  463. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
  464. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
  465. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
  466. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
  467. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
  468. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
  469. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
  470. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
  471. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
  472. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
  473. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
  474. data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
  475. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
  476. data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
  477. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
  478. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
  479. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
  480. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
  481. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
  482. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
  483. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
  484. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
  485. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
  486. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
  487. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
  488. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
  489. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
  490. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
  491. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
  492. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
  493. data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
  494. data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
  495. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
  496. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
  497. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
  498. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
  499. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
  500. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
  501. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
  502. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
  503. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
  504. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
  505. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
  506. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
  507. data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
  508. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
  509. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
  510. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
  511. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
  512. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
  513. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
  514. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
  515. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
  516. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
  517. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
  518. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
  519. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
  520. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
  521. data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
  522. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
  523. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
  524. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
  525. data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
  526. data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
  527. data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
  528. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
  529. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
  530. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
  531. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
  532. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
  533. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
  534. data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
  535. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
  536. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
  537. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
  538. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
  539. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
  540. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
  541. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
  542. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
  543. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
  544. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
  545. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
  546. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
  547. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
  548. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
  549. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
  550. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
  551. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
  552. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
  553. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
  554. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
  555. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
  556. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
  557. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
  558. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
  559. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
  560. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
  561. data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
  562. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
  563. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
  564. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
  565. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
  566. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
  567. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
  568. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
  569. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
  570. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
  571. data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
  572. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
  573. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
  574. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
  575. data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
  576. data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
  577. data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
  578. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
  579. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
  580. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
  581. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
  582. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
  583. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
  584. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
  585. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
  586. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
  587. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
  588. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
  589. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
  590. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
  591. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
  592. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
  593. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
  594. data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
  595. data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
  596. data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
  597. data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
  598. data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
  599. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
  600. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
  601. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
  602. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
  603. data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
  604. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
  605. data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
  606. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
  607. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
  608. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
  609. data/ext/gecode-2.2.0/test/assign.cc +181 -0
  610. data/ext/gecode-2.2.0/test/assign.hh +93 -0
  611. data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
  612. data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
  613. data/ext/gecode-2.2.0/test/branch.cc +563 -0
  614. data/ext/gecode-2.2.0/test/branch.hh +144 -0
  615. data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
  616. data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
  617. data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
  618. data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
  619. data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
  620. data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
  621. data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
  622. data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
  623. data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
  624. data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
  625. data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
  626. data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
  627. data/ext/gecode-2.2.0/test/int.cc +688 -0
  628. data/ext/gecode-2.2.0/test/int.hh +267 -0
  629. data/ext/gecode-2.2.0/test/int.icc +266 -0
  630. data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
  631. data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
  632. data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
  633. data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
  634. data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
  635. data/ext/gecode-2.2.0/test/int/count.cc +357 -0
  636. data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
  637. data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
  638. data/ext/gecode-2.2.0/test/int/element.cc +333 -0
  639. data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
  640. data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
  641. data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
  642. data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
  643. data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
  644. data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
  645. data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
  646. data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
  647. data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
  648. data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
  649. data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
  650. data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
  651. data/ext/gecode-2.2.0/test/search.cc +618 -0
  652. data/ext/gecode-2.2.0/test/set.cc +753 -0
  653. data/ext/gecode-2.2.0/test/set.hh +286 -0
  654. data/ext/gecode-2.2.0/test/set.icc +108 -0
  655. data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
  656. data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
  657. data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
  658. data/ext/gecode-2.2.0/test/set/int.cc +473 -0
  659. data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
  660. data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
  661. data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
  662. data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
  663. data/ext/gecode-2.2.0/test/set/select.cc +299 -0
  664. data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
  665. data/ext/gecode-2.2.0/test/test.cc +287 -0
  666. data/ext/gecode-2.2.0/test/test.hh +175 -0
  667. data/ext/gecode-2.2.0/test/test.icc +93 -0
  668. data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
  669. data/lib/gecoder/bindings.rb +7 -5
  670. data/lib/gecoder/bindings/bindings.rb +8 -8
  671. data/lib/gecoder/interface.rb +4 -2
  672. data/lib/gecoder/interface/binding_changes.rb +1 -1
  673. data/lib/gecoder/interface/branch.rb +1 -1
  674. data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
  675. data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
  676. data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
  677. data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
  678. data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
  679. data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
  680. data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
  681. data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
  682. data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
  683. data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
  684. data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
  685. data/lib/gecoder/interface/convenience.rb +99 -0
  686. data/lib/gecoder/interface/enum_wrapper.rb +1 -1
  687. data/lib/gecoder/interface/mixin.rb +486 -0
  688. data/lib/gecoder/interface/search.rb +23 -22
  689. data/lib/gecoder/version.rb +1 -1
  690. data/specs/branch.rb +5 -3
  691. data/specs/constraints/bool/boolean.rb +3 -1
  692. data/specs/constraints/bool/linear.rb +3 -1
  693. data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
  694. data/specs/constraints/bool_enum/channel.rb +3 -1
  695. data/specs/constraints/fixnum_enum/element.rb +3 -1
  696. data/specs/constraints/int/arithmetic.rb +3 -1
  697. data/specs/constraints/int/channel.rb +3 -1
  698. data/specs/constraints/int/linear.rb +3 -1
  699. data/specs/constraints/int/linear_properties.rb +3 -1
  700. data/specs/constraints/int_enum/arithmetic.rb +3 -1
  701. data/specs/constraints/int_enum/channel.rb +3 -1
  702. data/specs/constraints/int_enum/count.rb +3 -1
  703. data/specs/constraints/int_enum/distinct.rb +3 -1
  704. data/specs/constraints/int_enum/element.rb +3 -1
  705. data/specs/constraints/int_enum/sort.rb +3 -1
  706. data/specs/constraints/property_helper.rb +10 -10
  707. data/specs/constraints/reification_sugar.rb +3 -1
  708. data/specs/constraints/selected_set/select.rb +6 -5
  709. data/specs/constraints/selected_set/select_properties.rb +12 -10
  710. data/specs/constraints/set/channel.rb +3 -1
  711. data/specs/constraints/set/domain.rb +4 -4
  712. data/specs/constraints/set/relation.rb +4 -4
  713. data/specs/constraints/set_enum/channel.rb +3 -1
  714. data/specs/constraints/set_enum/distinct.rb +3 -1
  715. data/specs/constraints/set_enum/element.rb +77 -0
  716. data/specs/enum_wrapper.rb +1 -1
  717. data/specs/mixin.rb +78 -0
  718. data/specs/model.rb +5 -5
  719. data/specs/search.rb +20 -14
  720. data/specs/selected_set.rb +3 -3
  721. data/specs/set_elements.rb +2 -2
  722. data/tasks/distribution.rake +25 -4
  723. metadata +739 -602
  724. data/example/money.rb +0 -36
  725. data/ext/gecode-2.1.1/Makefile.dep +0 -7622
  726. data/ext/gecode-2.1.1/Makefile.in +0 -1568
  727. data/ext/gecode-2.1.1/changelog.in +0 -2459
  728. data/ext/gecode-2.1.1/configure +0 -11631
  729. data/ext/gecode-2.1.1/configure.ac +0 -249
  730. data/ext/gecode-2.1.1/configure.ac.in +0 -245
  731. data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
  732. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
  733. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
  734. data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
  735. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
  736. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
  737. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
  738. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
  739. data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
  740. data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
  741. data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
  742. data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
  743. data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
  744. data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
  745. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
  746. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
  747. data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
  748. data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
  749. data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
  750. data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
  751. data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
  752. data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
  753. data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
  754. data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
  755. data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
  756. data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
  757. data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
  758. data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
  759. data/ext/gecode-2.1.1/gecode.m4 +0 -956
  760. data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
  761. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
  762. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
  763. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
  764. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
  765. data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
  766. data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
  767. data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
  768. data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
  769. data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
  770. data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
  771. data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
  772. data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
  773. data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
  774. data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
  775. data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
  776. data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
  777. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
  778. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
  779. data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
  780. data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
  781. data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
  782. data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
  783. data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
  784. data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
  785. data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
  786. data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
  787. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
  788. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
  789. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
  790. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
  791. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
  792. data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
  793. data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
  794. data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
  795. data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
  796. data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
  797. data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
  798. data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
  799. data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
  800. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
  801. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
  802. data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
  803. data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
  804. data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
  805. data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
  806. data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
  807. data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
  808. data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
  809. data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
  810. data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
  811. data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
  812. data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
  813. data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
  814. data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
  815. data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
  816. data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
  817. data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
  818. data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
  819. data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
  820. data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
  821. data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
  822. data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
  823. data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
  824. data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
  825. data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
  826. data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
  827. data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
  828. data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
  829. data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
  830. data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
  831. data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
  832. data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
  833. data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
  834. data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
  835. data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
  836. data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
  837. data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
  838. data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
  839. data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
  840. data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
  841. data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
  842. data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
  843. data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
  844. data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
  845. data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
  846. data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
  847. data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
  848. data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
  849. data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
  850. data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
  851. data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
  852. data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
  853. data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
  854. data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
  855. data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
  856. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
  857. data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
  858. data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
  859. data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
  860. data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
  861. data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
  862. data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
  863. data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
  864. data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
  865. data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
  866. data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
  867. data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
  868. data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
  869. data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
  870. data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
  871. data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
  872. data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
  873. data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
  874. data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
  875. data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
  876. data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
  877. data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
  878. data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
  879. data/ext/gecode-2.1.1/gecode/search.hh +0 -752
  880. data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
  881. data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
  882. data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
  883. data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
  884. data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
  885. data/ext/gecode-2.1.1/gecode/set.hh +0 -970
  886. data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
  887. data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
  888. data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
  889. data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
  890. data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
  891. data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
  892. data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
  893. data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
  894. data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
  895. data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
  896. data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
  897. data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
  898. data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
  899. data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
  900. data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
  901. data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
  902. data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
  903. data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
  904. data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
  905. data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
  906. data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
  907. data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
  908. data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
  909. data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
  910. data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
  911. data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
  912. data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
  913. data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
  914. data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
  915. data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
  916. data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
  917. data/lib/gecoder/interface/model.rb +0 -453
  918. data/lib/gecoder/interface/model_sugar.rb +0 -84
  919. data/specs/constraints/set_enum/select.rb +0 -73
@@ -1,1849 +0,0 @@
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
- * Copyright:
8
- * Christian Schulte, 2002
9
- * Guido Tack, 2004
10
- *
11
- * Last modified:
12
- * $Date: 2008-03-06 10:39:58 +0100 (Thu, 06 Mar 2008) $ by $Author: tack $
13
- * $Revision: 6446 $
14
- *
15
- * This file is part of Gecode, the generic constraint
16
- * development environment:
17
- * http://www.gecode.org
18
- *
19
- * Permission is hereby granted, free of charge, to any person obtaining
20
- * a copy of this software and associated documentation files (the
21
- * "Software"), to deal in the Software without restriction, including
22
- * without limitation the rights to use, copy, modify, merge, publish,
23
- * distribute, sublicense, and/or sell copies of the Software, and to
24
- * permit persons to whom the Software is furnished to do so, subject to
25
- * the following conditions:
26
- *
27
- * The above copyright notice and this permission notice shall be
28
- * included in all copies or substantial portions of the Software.
29
- *
30
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
31
- * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
32
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
33
- * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
34
- * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
35
- * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
36
- * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
37
- *
38
- */
39
-
40
- #ifndef __GECODE_INT_LINEAR_HH__
41
- #define __GECODE_INT_LINEAR_HH__
42
-
43
- #include "gecode/int.hh"
44
-
45
- /**
46
- * \namespace Gecode::Int::Linear
47
- * \brief %Linear propagators
48
- */
49
-
50
- namespace Gecode { namespace Int { namespace Linear {
51
-
52
- /*
53
- * Binary propagators
54
- *
55
- */
56
-
57
- /**
58
- * \brief Base-class for binary linear propagators
59
- *
60
- * The type \a Val can be either \c double or \c int, defining the
61
- * numerical precision during propagation. The types \a A and \a B
62
- * give the types of the views.
63
- *
64
- * The propagation condition \a pc refers to both views.
65
- */
66
- template <class Val, class A, class B, PropCond pc>
67
- class LinBin : public Propagator {
68
- protected:
69
- /// View of type \a A
70
- A x0;
71
- /// View of type \a B
72
- B x1;
73
- /// Value of type \a Val
74
- Val c;
75
- /// Constructor for cloning \a p
76
- LinBin(Space* home, bool share, LinBin& p);
77
- /// Constructor for rewriting \a p during cloning
78
- LinBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
79
- /// Constructor for creation
80
- LinBin(Space* home, A x0, B x1, Val c);
81
- /// Return specification for this propagator given a variable map \a m
82
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
83
- const Support::Symbol& name) const;
84
- public:
85
- /// Cost function (defined as PC_BINARY_LO)
86
- virtual PropCost cost(ModEventDelta med) const;
87
- /// Delete propagator and return its size
88
- virtual size_t dispose(Space* home);
89
- };
90
-
91
- /**
92
- * \brief Base-class for reified binary linear propagators
93
- *
94
- * The type \a Val can be either \c double or \c int, defining the
95
- * numerical precision during propagation. The types \a A and \a B
96
- * give the types of the views.
97
- *
98
- * The propagation condition \a pc refers to both views.
99
- */
100
- template <class Val, class A, class B, PropCond pc, class Ctrl>
101
- class ReLinBin : public Propagator {
102
- protected:
103
- /// View of type \a A
104
- A x0;
105
- /// View of type \a B
106
- B x1;
107
- /// Value of type \a Val
108
- Val c;
109
- /// Control view for reification
110
- Ctrl b;
111
- /// Constructor for cloning \a p
112
- ReLinBin(Space* home, bool share, ReLinBin& p);
113
- /// Constructor for creation
114
- ReLinBin(Space* home, A x0, B x1, Val c, Ctrl b);
115
- /// Return specification for this propagator given a variable map \a m
116
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
117
- const Support::Symbol& name) const;
118
- public:
119
- /// Cost function (defined as PC_BINARY_LO)
120
- virtual PropCost cost(ModEventDelta med) const;
121
- /// Delete propagator and return its size
122
- virtual size_t dispose(Space* home);
123
- };
124
-
125
- /**
126
- * \brief %Propagator for bounds-consistent binary linear equality
127
- *
128
- * The type \a Val can be either \c double or \c int, defining the
129
- * numerical precision during propagation. The types \a A and \a B
130
- * give the types of the views.
131
- *
132
- * The propagation condition \a pc refers to both views.
133
- *
134
- * Requires \code #include "gecode/int/linear.hh" \endcode
135
- * \ingroup FuncIntProp
136
- */
137
- template <class Val, class A, class B>
138
- class EqBin : public LinBin<Val,A,B,PC_INT_BND> {
139
- protected:
140
- using LinBin<Val,A,B,PC_INT_BND>::x0;
141
- using LinBin<Val,A,B,PC_INT_BND>::x1;
142
- using LinBin<Val,A,B,PC_INT_BND>::c;
143
-
144
- /// Constructor for cloning \a p
145
- EqBin(Space* home, bool share, EqBin& p);
146
- /// Constructor for creation
147
- EqBin(Space* home, A x0, B x1, Val c);
148
- public:
149
- /// Constructor for rewriting \a p during cloning
150
- EqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
151
- /// Create copy during cloning
152
- virtual Actor* copy(Space* home, bool share);
153
- /// Perform propagation
154
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
155
- /// Specification for this propagator
156
- virtual Reflection::ActorSpec spec(const Space* home,
157
- Reflection::VarMap& m) const;
158
- /// Post propagator according to specification
159
- static void post(Space* home, Reflection::VarMap& vars,
160
- const Reflection::ActorSpec& spec);
161
- /// Mangled propagator name
162
- static Support::Symbol ati(void);
163
- /// Post propagator for \f$x_0+x_1 = c\f$
164
- static ExecStatus post(Space* home, A x0, B x1, Val c);
165
- };
166
-
167
- /**
168
- * \brief %Propagator for reified bounds-consistent binary linear equality
169
- *
170
- * The type \a Val can be either \c double or \c int, defining the
171
- * numerical precision during propagation. The types \a A and \a B
172
- * give the types of the views.
173
- *
174
- * The propagation condition \a pc refers to both views.
175
- *
176
- * Requires \code #include "gecode/int/linear.hh" \endcode
177
- * \ingroup FuncIntProp
178
- */
179
- template <class Val, class A, class B, class Ctrl>
180
- class ReEqBin : public ReLinBin<Val,A,B,PC_INT_BND,Ctrl> {
181
- protected:
182
- using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::x0;
183
- using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::x1;
184
- using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::c;
185
- using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::b;
186
-
187
- /// Constructor for cloning \a p
188
- ReEqBin(Space* home, bool share, ReEqBin& p);
189
- /// Constructor for creation
190
- ReEqBin(Space* home,A,B,Val,Ctrl);
191
- public:
192
- /// Create copy during cloning
193
- virtual Actor* copy(Space* home, bool share);
194
- /// Perform propagation
195
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
196
- /// Specification for this propagator
197
- virtual Reflection::ActorSpec spec(const Space* home,
198
- Reflection::VarMap& m) const;
199
- /// Post propagator according to specification
200
- static void post(Space* home, Reflection::VarMap& vars,
201
- const Reflection::ActorSpec& spec);
202
- /// Mangled propagator name
203
- static Support::Symbol ati(void);
204
- /// Post propagator for \f$(x_0+x_1 = c)\Leftrightarrow b\f$
205
- static ExecStatus post(Space* home, A x0, B x1, Val c, Ctrl b);
206
- };
207
-
208
- /**
209
- * \brief %Propagator for bounds-consistent binary linear disequality
210
- *
211
- * The type \a Val can be either \c double or \c int, defining the
212
- * numerical precision during propagation. The types \a A and \a B
213
- * give the types of the views.
214
- *
215
- * The propagation condition \a pc refers to both views.
216
- *
217
- * Requires \code #include "gecode/int/linear.hh" \endcode
218
- * \ingroup FuncIntProp
219
- */
220
- template <class Val, class A, class B>
221
- class NqBin : public LinBin<Val,A,B,PC_INT_VAL> {
222
- protected:
223
- using LinBin<Val,A,B,PC_INT_VAL>::x0;
224
- using LinBin<Val,A,B,PC_INT_VAL>::x1;
225
- using LinBin<Val,A,B,PC_INT_VAL>::c;
226
-
227
- /// Constructor for cloning \a p
228
- NqBin(Space* home, bool share, NqBin& p);
229
- /// Constructor for creation
230
- NqBin(Space* home, A x0, B x1, Val c);
231
- public:
232
- /// Constructor for rewriting \a p during cloning
233
- NqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
234
- /// Create copy during cloning
235
- virtual Actor* copy(Space* home, bool share);
236
- /// Perform propagation
237
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
238
- /// Cost function (defined as PC_UNARY_LO)
239
- virtual PropCost cost(ModEventDelta med) const;
240
- /// Specification for this propagator
241
- virtual Reflection::ActorSpec spec(const Space* home,
242
- Reflection::VarMap& m) const;
243
- /// Post propagator according to specification
244
- static void post(Space* home, Reflection::VarMap& vars,
245
- const Reflection::ActorSpec& spec);
246
- /// Mangled propagator name
247
- static Support::Symbol ati(void);
248
- /// Post propagator for \f$x_0+x_1 \neq c\f$
249
- static ExecStatus post(Space* home, A x0, B x1, Val c);
250
- };
251
-
252
- /**
253
- * \brief %Propagator for bounds-consistent binary linear less or equal
254
- *
255
- * The type \a Val can be either \c double or \c int, defining the
256
- * numerical precision during propagation. The types \a A and \a B
257
- * give the types of the views.
258
- *
259
- * The propagation condition \a pc refers to both views.
260
- *
261
- * Requires \code #include "gecode/int/linear.hh" \endcode
262
- * \ingroup FuncIntProp
263
- */
264
- template <class Val, class A, class B>
265
- class LqBin : public LinBin<Val,A,B,PC_INT_BND> {
266
- protected:
267
- using LinBin<Val,A,B,PC_INT_BND>::x0;
268
- using LinBin<Val,A,B,PC_INT_BND>::x1;
269
- using LinBin<Val,A,B,PC_INT_BND>::c;
270
-
271
- /// Constructor for cloning \a p
272
- LqBin(Space* home, bool share, LqBin& p);
273
- /// Constructor for creation
274
- LqBin(Space* home, A x0, B x1, Val c);
275
- public:
276
- /// Constructor for rewriting \a p during cloning
277
- LqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
278
- /// Create copy during cloning
279
- virtual Actor* copy(Space* home, bool share);
280
- /// Perform propagation
281
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
282
- /// Specification for this propagator
283
- virtual Reflection::ActorSpec spec(const Space* home,
284
- Reflection::VarMap& m) const;
285
- /// Post propagator according to specification
286
- static void post(Space* home, Reflection::VarMap& vars,
287
- const Reflection::ActorSpec& spec);
288
- /// Mangled propagator name
289
- static Support::Symbol ati(void);
290
- /// Post propagator for \f$x_0+x_1 \leq c\f$
291
- static ExecStatus post(Space* home, A x0, B x1, Val c);
292
- };
293
-
294
- /**
295
- * \brief %Propagator for bounds-consistent binary linear greater or equal
296
- *
297
- * The type \a Val can be either \c double or \c int, defining the
298
- * numerical precision during propagation. The types \a A and \a B
299
- * give the types of the views.
300
- *
301
- * The propagation condition \a pc refers to both views.
302
- *
303
- * Requires \code #include "gecode/int/linear.hh" \endcode
304
- * \ingroup FuncIntProp
305
- */
306
- template <class Val, class A, class B>
307
- class GqBin : public LinBin<Val,A,B,PC_INT_BND> {
308
- protected:
309
- using LinBin<Val,A,B,PC_INT_BND>::x0;
310
- using LinBin<Val,A,B,PC_INT_BND>::x1;
311
- using LinBin<Val,A,B,PC_INT_BND>::c;
312
-
313
- /// Constructor for cloning \a p
314
- GqBin(Space* home, bool share, GqBin& p);
315
- /// Constructor for creation
316
- GqBin(Space* home, A x0, B x1, Val c);
317
- public:
318
- /// Constructor for rewriting \a p during cloning
319
- GqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
320
- /// Create copy during cloning
321
- virtual Actor* copy(Space* home, bool share);
322
- /// Perform propagation
323
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
324
- /// Specification for this propagator
325
- virtual Reflection::ActorSpec spec(const Space* home,
326
- Reflection::VarMap& m) const;
327
- /// Post propagator according to specification
328
- static void post(Space* home, Reflection::VarMap& vars,
329
- const Reflection::ActorSpec& spec);
330
- /// Mangled propagator name
331
- static Support::Symbol ati(void);
332
- /// Post propagator for \f$x_0+x_1 \geq c\f$
333
- static ExecStatus post(Space* home, A x0, B x1, Val c);
334
- };
335
-
336
- /**
337
- * \brief %Propagator for reified bounds-consistent binary linear less or equal
338
- *
339
- * The type \a Val can be either \c double or \c int, defining the
340
- * numerical precision during propagation. The types \a A and \a B
341
- * give the types of the views.
342
- *
343
- * The propagation condition \a pc refers to both views.
344
- *
345
- * Requires \code #include "gecode/int/linear.hh" \endcode
346
- * \ingroup FuncIntProp
347
- */
348
- template <class Val, class A, class B>
349
- class ReLqBin : public ReLinBin<Val,A,B,PC_INT_BND,BoolView> {
350
- protected:
351
- using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::x0;
352
- using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::x1;
353
- using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::c;
354
- using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::b;
355
-
356
- /// Constructor for cloning \a p
357
- ReLqBin(Space* home, bool share, ReLqBin& p);
358
- /// Constructor for creation
359
- ReLqBin(Space* home, A x0, B x1, Val c, BoolView b);
360
- public:
361
- /// Create copy during cloning
362
- virtual Actor* copy(Space* home, bool share);
363
- /// Perform propagation
364
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
365
- /// Specification for this propagator
366
- virtual Reflection::ActorSpec spec(const Space* home,
367
- Reflection::VarMap& m) const;
368
- /// Post propagator according to specification
369
- static void post(Space* home, Reflection::VarMap& vars,
370
- const Reflection::ActorSpec& spec);
371
- /// Mangled propagator name
372
- static Support::Symbol ati(void);
373
- /// Post propagator for \f$(x_0+x_1 \leq c)\Leftrightarrow b\f$
374
- static ExecStatus post(Space* home, A x0, B x1, Val c, BoolView b);
375
- };
376
-
377
- }}}
378
-
379
- #include "gecode/int/linear/int-bin.icc"
380
-
381
- namespace Gecode { namespace Int { namespace Linear {
382
-
383
- /*
384
- * Ternary propagators
385
- *
386
- */
387
-
388
- /**
389
- * \brief Base-class for ternary linear propagators
390
- *
391
- * The type \a Val can be either \c double or \c int, defining the
392
- * numerical precision during propagation. The types \a A, \a B,
393
- * and \a C give the types of the views.
394
- *
395
- * The propagation condition \a pc refers to all three views.
396
- */
397
- template <class Val, class A, class B, class C, PropCond pc>
398
- class LinTer : public Propagator {
399
- protected:
400
- /// View of type \a A
401
- A x0;
402
- /// View of type \a B
403
- B x1;
404
- /// View of type \a C
405
- C x2;
406
- /// Value of type \a Val
407
- Val c;
408
- /// Constructor for cloning \a p
409
- LinTer(Space* home, bool share, LinTer& p);
410
- /// Constructor for creation
411
- LinTer(Space* home, A x0, B x1, C x2, Val c);
412
- /// Constructor for rewriting \a p during cloning
413
- LinTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
414
- /// Return specification for this propagator given a variable map \a m
415
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
416
- const Support::Symbol& name) const;
417
- public:
418
- /// Cost function (defined as PC_TERNARY_LO)
419
- virtual PropCost cost(ModEventDelta med) const;
420
- /// Delete propagator and return its size
421
- virtual size_t dispose(Space* home);
422
- };
423
-
424
- /**
425
- * \brief %Propagator for bounds-consistent ternary linear equality
426
- *
427
- * The type \a Val can be either \c double or \c int, defining the
428
- * numerical precision during propagation. The types \a A, \a B,
429
- * and \a C give the types of the views.
430
- *
431
- * The propagation condition \a pc refers to all three views.
432
- *
433
- * Requires \code #include "gecode/int/linear.hh" \endcode
434
- * \ingroup FuncIntProp
435
- */
436
- template <class Val, class A, class B, class C>
437
- class EqTer : public LinTer<Val,A,B,C,PC_INT_BND> {
438
- protected:
439
- using LinTer<Val,A,B,C,PC_INT_BND>::x0;
440
- using LinTer<Val,A,B,C,PC_INT_BND>::x1;
441
- using LinTer<Val,A,B,C,PC_INT_BND>::x2;
442
- using LinTer<Val,A,B,C,PC_INT_BND>::c;
443
-
444
- /// Constructor for cloning \a p
445
- EqTer(Space* home, bool share, EqTer& p);
446
- /// Constructor for creation
447
- EqTer(Space* home, A x0, B x1, C x2, Val c);
448
- public:
449
- /// Constructor for rewriting \a p during cloning
450
- EqTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
451
- /// Create copy during cloning
452
- virtual Actor* copy(Space* home, bool share);
453
- /// Perform propagation
454
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
455
- /// Specification for this propagator
456
- virtual Reflection::ActorSpec spec(const Space* home,
457
- Reflection::VarMap& m) const;
458
- /// Post propagator according to specification
459
- static void post(Space* home, Reflection::VarMap& vars,
460
- const Reflection::ActorSpec& spec);
461
- /// Mangled propagator name
462
- static Support::Symbol ati(void);
463
- /// Post propagator for \f$x_0+x_1+x_2 = c\f$
464
- static ExecStatus post(Space* home, A x0, B x1, C x2, Val c);
465
- };
466
-
467
- /**
468
- * \brief %Propagator for bounds-consistent ternary linear disquality
469
- *
470
- * The type \a Val can be either \c double or \c int, defining the
471
- * numerical precision during propagation. The types \a A, \a B,
472
- * and \a C give the types of the views.
473
- *
474
- * The propagation condition \a pc refers to all three views.
475
- *
476
- * Requires \code #include "gecode/int/linear.hh" \endcode
477
- * \ingroup FuncIntProp
478
- */
479
- template <class Val, class A, class B, class C>
480
- class NqTer : public LinTer<Val,A,B,C,PC_INT_VAL> {
481
- protected:
482
- using LinTer<Val,A,B,C,PC_INT_VAL>::x0;
483
- using LinTer<Val,A,B,C,PC_INT_VAL>::x1;
484
- using LinTer<Val,A,B,C,PC_INT_VAL>::x2;
485
- using LinTer<Val,A,B,C,PC_INT_VAL>::c;
486
-
487
- /// Constructor for cloning \a p
488
- NqTer(Space* home, bool share, NqTer& p);
489
- /// Constructor for creation
490
- NqTer(Space* home, A x0, B x1, C x2, Val c);
491
- public:
492
- /// Constructor for rewriting \a p during cloning
493
- NqTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
494
- /// Create copy during cloning
495
- virtual Actor* copy(Space* home, bool share);
496
- /// Perform propagation
497
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
498
- /// Specification for this propagator
499
- virtual Reflection::ActorSpec spec(const Space* home,
500
- Reflection::VarMap& m) const;
501
- /// Post propagator according to specification
502
- static void post(Space* home, Reflection::VarMap& vars,
503
- const Reflection::ActorSpec& spec);
504
- /// Mangled propagator name
505
- static Support::Symbol ati(void);
506
- /// Post propagator for \f$x_0+x_1+x_2 \neq c\f$
507
- static ExecStatus post(Space* home, A x0, B x1, C x2, Val c);
508
- };
509
-
510
- /**
511
- * \brief %Propagator for bounds-consistent ternary linear less or equal
512
- *
513
- * The type \a Val can be either \c double or \c int, defining the
514
- * numerical precision during propagation. The types \a A, \a B,
515
- * and \a C give the types of the views.
516
- *
517
- * The propagation condition \a pc refers to all three views.
518
- *
519
- * Requires \code #include "gecode/int/linear.hh" \endcode
520
- * \ingroup FuncIntProp
521
- */
522
- template <class Val, class A, class B, class C>
523
- class LqTer : public LinTer<Val,A,B,C,PC_INT_BND> {
524
- protected:
525
- using LinTer<Val,A,B,C,PC_INT_BND>::x0;
526
- using LinTer<Val,A,B,C,PC_INT_BND>::x1;
527
- using LinTer<Val,A,B,C,PC_INT_BND>::x2;
528
- using LinTer<Val,A,B,C,PC_INT_BND>::c;
529
-
530
- /// Constructor for cloning \a p
531
- LqTer(Space* home, bool share, LqTer& p);
532
- /// Constructor for creation
533
- LqTer(Space* home, A x0, B x1, C x2, Val c);
534
- public:
535
- /// Constructor for rewriting \a p during cloning
536
- LqTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
537
- /// Create copy during cloning
538
- virtual Actor* copy(Space* home, bool share);
539
- /// Perform propagation
540
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
541
- /// Specification for this propagator
542
- virtual Reflection::ActorSpec spec(const Space* home,
543
- Reflection::VarMap& m) const;
544
- /// Post propagator according to specification
545
- static void post(Space* home, Reflection::VarMap& vars,
546
- const Reflection::ActorSpec& spec);
547
- /// Mangled propagator name
548
- static Support::Symbol ati(void);
549
- /// Post propagator for \f$x_0+x_1+x_2 \leq c\f$
550
- static ExecStatus post(Space* home, A x0, B x1, C x2, Val c);
551
- };
552
-
553
- }}}
554
-
555
- #include "gecode/int/linear/int-ter.icc"
556
-
557
- namespace Gecode { namespace Int { namespace Linear {
558
-
559
- /*
560
- * n-ary propagators
561
- *
562
- */
563
-
564
- /**
565
- * \brief Base-class for n-ary linear propagators
566
- *
567
- * The type \a Val can be either \c double or \c int, defining the
568
- * numerical precision during propagation. Positive views are of
569
- * type \a P whereas negative views are of type \a N.
570
- *
571
- * The propagation condition \a pc refers to all views.
572
- */
573
- template <class Val, class P, class N, PropCond pc>
574
- class Lin : public Propagator {
575
- protected:
576
- /// Array of positive views
577
- ViewArray<P> x;
578
- /// Array of negative views
579
- ViewArray<N> y;
580
- /// Constant value
581
- Val c;
582
-
583
- /// Constructor for cloning \a p
584
- Lin(Space* home, bool share, Lin& p);
585
- /// Constructor for creation
586
- Lin(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
587
- /// Return specification
588
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
589
- const Support::Symbol& name) const;
590
- public:
591
- /// Cost function (defined as dynamic PC_LINEAR_LO)
592
- virtual PropCost cost(ModEventDelta med) const;
593
- /// Delete propagator and return its size
594
- virtual size_t dispose(Space* home);
595
- };
596
-
597
- /**
598
- * \brief Base-class for reified n-ary linear propagators
599
- *
600
- * The type \a Val can be either \c double or \c int, defining the
601
- * numerical precision during propagation. Positive views are of
602
- * type \a P whereas negative views are of type \a N.
603
- *
604
- * The propagation condition \a pc refers to all views.
605
- */
606
- template <class Val, class P, class N, PropCond pc, class Ctrl>
607
- class ReLin : public Lin<Val,P,N,pc> {
608
- protected:
609
- /// Control view for reification
610
- Ctrl b;
611
- /// Constructor for cloning \a p
612
- ReLin(Space* home, bool share, ReLin& p);
613
- /// Constructor for creation
614
- ReLin(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, Ctrl b);
615
- /// Return specification
616
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
617
- const Support::Symbol& name) const;
618
- public:
619
- /// Delete propagator and return its size
620
- virtual size_t dispose(Space* home);
621
- };
622
-
623
- /**
624
- * \brief Compute bounds information for positive views
625
- *
626
- * \relates Lin
627
- */
628
- template <class Val, class View>
629
- void bounds_p(ModEventDelta med, ViewArray<View>& x,
630
- Val& c, Val& sl, Val& su);
631
-
632
- /**
633
- * \brief Compute bounds information for negative views
634
- *
635
- * \relates Lin
636
- */
637
- template <class Val, class View>
638
- void bounds_n(ModEventDelta med, ViewArray<View>& y,
639
- Val& c, Val& sl, Val& su);
640
-
641
- /**
642
- * \brief %Propagator for bounds-consistent n-ary linear equality
643
- *
644
- * The type \a Val can be either \c double or \c int, defining the
645
- * numerical precision during propagation. The types \a P and \a N
646
- * give the types of the views.
647
- *
648
- * The propagation condition \a pc refers to both views.
649
- *
650
- * Requires \code #include "gecode/int/linear.hh" \endcode
651
- * \ingroup FuncIntProp
652
- */
653
- template <class Val, class P, class N>
654
- class Eq : public Lin<Val,P,N,PC_INT_BND> {
655
- protected:
656
- using Lin<Val,P,N,PC_INT_BND>::x;
657
- using Lin<Val,P,N,PC_INT_BND>::y;
658
- using Lin<Val,P,N,PC_INT_BND>::c;
659
-
660
- /// Constructor for cloning \a p
661
- Eq(Space* home, bool share, Eq& p);
662
- public:
663
- /// Constructor for creation
664
- Eq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
665
- /// Create copy during cloning
666
- virtual Actor* copy(Space* home, bool share);
667
- /// Perform propagation
668
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
669
- /// Specification for this propagator
670
- virtual Reflection::ActorSpec spec(const Space* home,
671
- Reflection::VarMap& m) const;
672
- /// Post propagator according to specification
673
- static void post(Space* home, Reflection::VarMap& vars,
674
- const Reflection::ActorSpec& spec);
675
- /// Mangled propagator name
676
- static Support::Symbol ati(void);
677
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i=c\f$
678
- static ExecStatus
679
- post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
680
- };
681
-
682
- /**
683
- * \brief %Propagator for domain-consistent n-ary linear equality
684
- *
685
- * The type \a Val can be either \c double or \c int, defining the
686
- * numerical precision during propagation. The types \a View
687
- * give the type of the view.
688
- *
689
- * Requires \code #include "gecode/int/linear.hh" \endcode
690
- * \ingroup FuncIntProp
691
- */
692
- template <class Val, class View>
693
- class DomEq
694
- : public Lin<Val,View,View,PC_INT_DOM> {
695
- protected:
696
- using Lin<Val,View,View,PC_INT_DOM>::x;
697
- using Lin<Val,View,View,PC_INT_DOM>::y;
698
- using Lin<Val,View,View,PC_INT_DOM>::c;
699
-
700
- /// Constructor for cloning \a p
701
- DomEq(Space* home, bool share, DomEq& p);
702
- public:
703
- /// Constructor for creation
704
- DomEq(Space* home, ViewArray<View>& x, ViewArray<View>& y, Val c);
705
- /// Create copy during cloning
706
- virtual Actor* copy(Space* home, bool share);
707
- /// Propagation cost
708
- virtual PropCost cost(ModEventDelta med) const;
709
- /// Perform propagation
710
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
711
- /// Specification for this propagator
712
- virtual Reflection::ActorSpec spec(const Space* home,
713
- Reflection::VarMap& m) const;
714
- /// Post propagator according to specification
715
- static void post(Space* home, Reflection::VarMap& vars,
716
- const Reflection::ActorSpec& spec);
717
- /// Mangled propagator name
718
- static Support::Symbol ati(void);
719
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i=c\f$
720
- static ExecStatus
721
- post(Space* home, ViewArray<View>& x, ViewArray<View>& y, Val c);
722
- };
723
-
724
- /**
725
- * \brief %Propagator for reified bounds-consistent n-ary linear equality
726
- *
727
- * The type \a Val can be either \c double or \c int, defining the
728
- * numerical precision during propagation. The types \a P and \a N
729
- * give the types of the views.
730
- *
731
- * The propagation condition \a pc refers to both views.
732
- *
733
- * Requires \code #include "gecode/int/linear.hh" \endcode
734
- * \ingroup FuncIntProp
735
- */
736
- template <class Val, class P, class N, class Ctrl>
737
- class ReEq : public ReLin<Val,P,N,PC_INT_BND,Ctrl> {
738
- protected:
739
- using ReLin<Val,P,N,PC_INT_BND,Ctrl>::x;
740
- using ReLin<Val,P,N,PC_INT_BND,Ctrl>::y;
741
- using ReLin<Val,P,N,PC_INT_BND,Ctrl>::c;
742
- using ReLin<Val,P,N,PC_INT_BND,Ctrl>::b;
743
-
744
- /// Constructor for cloning \a p
745
- ReEq(Space* home, bool share, ReEq& p);
746
- public:
747
- /// Constructor for creation
748
- ReEq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, Ctrl b);
749
- /// Create copy during cloning
750
- virtual Actor* copy(Space* home, bool share);
751
- /// Perform propagation
752
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
753
- /// Specification for this propagator
754
- virtual Reflection::ActorSpec spec(const Space* home,
755
- Reflection::VarMap& m) const;
756
- /// Post propagator according to specification
757
- static void post(Space* home, Reflection::VarMap& vars,
758
- const Reflection::ActorSpec& spec);
759
- /// Mangled propagator name
760
- static Support::Symbol ati(void);
761
- /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i=c\right)\Leftrightarrow b\f$
762
- static ExecStatus
763
- post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, Ctrl b);
764
- };
765
-
766
- /**
767
- * \brief %Propagator for bounds-consistent n-ary linear disequality
768
- *
769
- * The type \a Val can be either \c double or \c int, defining the
770
- * numerical precision during propagation. The types \a P and \a N
771
- * give the types of the views.
772
- *
773
- * The propagation condition \a pc refers to both views.
774
- *
775
- * Requires \code #include "gecode/int/linear.hh" \endcode
776
- * \ingroup FuncIntProp
777
- */
778
- template <class Val, class P, class N>
779
- class Nq : public Lin<Val,P,N,PC_INT_VAL> {
780
- protected:
781
- using Lin<Val,P,N,PC_INT_VAL>::x;
782
- using Lin<Val,P,N,PC_INT_VAL>::y;
783
- using Lin<Val,P,N,PC_INT_VAL>::c;
784
-
785
- /// Constructor for cloning \a p
786
- Nq(Space* home, bool share, Nq& p);
787
- public:
788
- /// Constructor for creation
789
- Nq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
790
- /// Create copy during cloning
791
- virtual Actor* copy(Space* home, bool share);
792
- /// Perform propagation
793
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
794
- /// Specification for this propagator
795
- virtual Reflection::ActorSpec spec(const Space* home,
796
- Reflection::VarMap& m) const;
797
- /// Post propagator according to specification
798
- static void post(Space* home, Reflection::VarMap& vars,
799
- const Reflection::ActorSpec& spec);
800
- /// Mangled propagator name
801
- static Support::Symbol ati(void);
802
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i\neq c\f$
803
- static ExecStatus
804
- post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
805
- };
806
-
807
- /**
808
- * \brief %Propagator for bounds-consistent n-ary linear less or equal
809
- *
810
- * The type \a Val can be either \c double or \c int, defining the
811
- * numerical precision during propagation. The types \a P and \a N
812
- * give the types of the views.
813
- *
814
- * The propagation condition \a pc refers to both views.
815
- *
816
- * Requires \code #include "gecode/int/linear.hh" \endcode
817
- * \ingroup FuncIntProp
818
- */
819
- template <class Val, class P, class N>
820
- class Lq : public Lin<Val,P,N,PC_INT_BND> {
821
- protected:
822
- using Lin<Val,P,N,PC_INT_BND>::x;
823
- using Lin<Val,P,N,PC_INT_BND>::y;
824
- using Lin<Val,P,N,PC_INT_BND>::c;
825
-
826
- /// Constructor for cloning \a p
827
- Lq(Space* home, bool share, Lq& p);
828
- public:
829
- /// Constructor for creation
830
- Lq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
831
- /// Create copy during cloning
832
- virtual Actor* copy(Space* home, bool share);
833
- /// Perform propagation
834
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
835
- /// Specification for this propagator
836
- virtual Reflection::ActorSpec spec(const Space* home,
837
- Reflection::VarMap& m) const;
838
- /// Post propagator according to specification
839
- static void post(Space* home, Reflection::VarMap& vars,
840
- const Reflection::ActorSpec& spec);
841
- /// Mangled propagator name
842
- static Support::Symbol ati(void);
843
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i\leq c\f$
844
- static ExecStatus
845
- post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
846
- };
847
-
848
- /**
849
- * \brief %Propagator for reified bounds-consistent n-ary linear less or equal
850
- *
851
- * The type \a Val can be either \c double or \c int, defining the
852
- * numerical precision during propagation. The types \a P and \a N
853
- * give the types of the views.
854
- *
855
- * The propagation condition \a pc refers to both views.
856
- *
857
- * Requires \code #include "gecode/int/linear.hh" \endcode
858
- * \ingroup FuncIntProp
859
- */
860
- template <class Val, class P, class N>
861
- class ReLq : public ReLin<Val,P,N,PC_INT_BND,BoolView> {
862
- protected:
863
- using ReLin<Val,P,N,PC_INT_BND,BoolView>::x;
864
- using ReLin<Val,P,N,PC_INT_BND,BoolView>::y;
865
- using ReLin<Val,P,N,PC_INT_BND,BoolView>::c;
866
- using ReLin<Val,P,N,PC_INT_BND,BoolView>::b;
867
-
868
- /// Constructor for cloning \a p
869
- ReLq(Space* home, bool share, ReLq& p);
870
- public:
871
- /// Constructor for creation
872
- ReLq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, BoolView b);
873
- /// Create copy during cloning
874
- virtual Actor* copy(Space* home, bool share);
875
- /// Perform propagation
876
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
877
- /// Specification for this propagator
878
- virtual Reflection::ActorSpec spec(const Space* home,
879
- Reflection::VarMap& m) const;
880
- /// Post propagator according to specification
881
- static void post(Space* home, Reflection::VarMap& vars,
882
- const Reflection::ActorSpec& spec);
883
- /// Mangled propagator name
884
- static Support::Symbol ati(void);
885
- /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i\leq c\right)\Leftrightarrow b\f$
886
- static ExecStatus
887
- post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, BoolView b);
888
- };
889
-
890
- }}}
891
-
892
- #include "gecode/int/linear/int-nary.icc"
893
- #include "gecode/int/linear/int-dom.icc"
894
-
895
- namespace Gecode { namespace Int { namespace Linear {
896
-
897
- /*
898
- * Boolean linear propagators
899
- *
900
- */
901
-
902
- /**
903
- * \brief Baseclass for integer Boolean sum using dependencies
904
- *
905
- */
906
- template <class VX>
907
- class MemoryLinBoolInt : public Propagator {
908
- protected:
909
- /// Boolean views
910
- ViewArray<VX> x;
911
- /// Views from x[0] ... x[n_s-1] have subscriptions
912
- int n_s;
913
- /// Righthandside
914
- int c;
915
- /// Constructor for cloning \a p
916
- MemoryLinBoolInt(Space* home, bool share, MemoryLinBoolInt& p);
917
- /// Constructor for creation
918
- MemoryLinBoolInt(Space* home, ViewArray<VX>& x, int n_s, int c);
919
- /// Return specification for this propagator given a variable map \a m
920
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
921
- const Support::Symbol& name) const;
922
- public:
923
- /// Cost function (defined as dynamic PC_LINEAR_LO)
924
- virtual PropCost cost(ModEventDelta med) const;
925
- /// Delete propagator and return its size
926
- virtual size_t dispose(Space* home);
927
- };
928
-
929
- /**
930
- * \brief Baseclass for integer Boolean sum using advisors
931
- *
932
- */
933
- template <class VX>
934
- class SpeedLinBoolInt : public Propagator {
935
- protected:
936
- /// Boolean views
937
- ViewArray<VX> x;
938
- /// How many views are attached to advisors
939
- int n_s;
940
- /// Righthandside
941
- int c;
942
- /// Council for managing advisors
943
- Council<ViewAdvisor<VX> > co;
944
- /// Constructor for cloning \a p
945
- SpeedLinBoolInt(Space* home, bool share, SpeedLinBoolInt& p);
946
- /// Constructor for creation
947
- SpeedLinBoolInt(Space* home, ViewArray<VX>& x, int n_s, int c);
948
- /// Return specification for this propagator given a variable map \a m
949
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
950
- const Support::Symbol& name) const;
951
- public:
952
- /// Cost function (defined as dynamic PC_UNARY_HI)
953
- virtual PropCost cost(ModEventDelta med) const;
954
- /// Delete propagator and return its size
955
- virtual size_t dispose(Space* home);
956
- };
957
-
958
- /**
959
- * \brief %Propagator for integer equal to Boolean sum (cardinality)
960
- *
961
- * Requires \code #include "gecode/int/linear.hh" \endcode
962
- * \ingroup FuncIntProp
963
- */
964
- template <class VX>
965
- class EqBoolInt {
966
- public:
967
- /// Threshold of whether to prefer speed or memory
968
- static const int threshold = 32;
969
- /// Propagator using less memory but with linear runtime
970
- class Memory : public MemoryLinBoolInt<VX> {
971
- protected:
972
- using MemoryLinBoolInt<VX>::x;
973
- using MemoryLinBoolInt<VX>::n_s;
974
- using MemoryLinBoolInt<VX>::c;
975
- public:
976
- /// Constructor for cloning \a p
977
- Memory(Space* home, bool share, Memory& p);
978
- /// Constructor for creation
979
- Memory(Space* home, ViewArray<VX>& x, int c);
980
- /// Create copy during cloning
981
- virtual Actor* copy(Space* home, bool share);
982
- /// Perform propagation
983
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
984
- /// Specification for this propagator
985
- virtual Reflection::ActorSpec spec(const Space* home,
986
- Reflection::VarMap& m) const;
987
- /// Post propagator according to specification
988
- static void post(Space* home, Reflection::VarMap& vars,
989
- const Reflection::ActorSpec& spec);
990
- /// Mangled propagator name
991
- static Support::Symbol ati(void);
992
- };
993
- /// Propagator using more memory but with constant runtime
994
- class Speed : public SpeedLinBoolInt<VX> {
995
- protected:
996
- using SpeedLinBoolInt<VX>::x;
997
- using SpeedLinBoolInt<VX>::n_s;
998
- using SpeedLinBoolInt<VX>::c;
999
- using SpeedLinBoolInt<VX>::co;
1000
- public:
1001
- /// Constructor for cloning \a p
1002
- Speed(Space* home, bool share, Speed& p);
1003
- /// Constructor for creation
1004
- Speed(Space* home, ViewArray<VX>& x, int c);
1005
- /// Create copy during cloning
1006
- virtual Actor* copy(Space* home, bool share);
1007
- /// Give advice to propagator
1008
- virtual ExecStatus advise(Space* home, Advisor* a, const Delta* d);
1009
- /// Perform propagation
1010
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1011
- /// Specification for this propagator
1012
- virtual Reflection::ActorSpec spec(const Space* home,
1013
- Reflection::VarMap& m) const;
1014
- /// Post propagator according to specification
1015
- static void post(Space* home, Reflection::VarMap& vars,
1016
- const Reflection::ActorSpec& spec);
1017
- /// Mangled propagator name
1018
- static Support::Symbol ati(void);
1019
- };
1020
-
1021
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i = c\f$
1022
- static ExecStatus post(Space* home, ViewArray<VX>& x, int c,
1023
- PropKind pk=PK_DEF);
1024
- };
1025
-
1026
- /**
1027
- * \brief %Propagator for integer less or equal to Boolean sum (cardinality)
1028
- *
1029
- * Requires \code #include "gecode/int/linear.hh" \endcode
1030
- * \ingroup FuncIntProp
1031
- */
1032
- template <class VX>
1033
- class GqBoolInt {
1034
- public:
1035
- /// Threshold of whether to prefer speed or memory
1036
- static const int threshold = 32;
1037
- /// Propagator using less memory but with linear runtime
1038
- class Memory : public MemoryLinBoolInt<VX> {
1039
- protected:
1040
- using MemoryLinBoolInt<VX>::x;
1041
- using MemoryLinBoolInt<VX>::n_s;
1042
- using MemoryLinBoolInt<VX>::c;
1043
- public:
1044
- /// Constructor for cloning \a p
1045
- Memory(Space* home, bool share, Memory& p);
1046
- /// Constructor for creation
1047
- Memory(Space* home, ViewArray<VX>& x, int c);
1048
- /// Create copy during cloning
1049
- virtual Actor* copy(Space* home, bool share);
1050
- /// Perform propagation
1051
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1052
- /// Specification for this propagator
1053
- virtual Reflection::ActorSpec spec(const Space* home,
1054
- Reflection::VarMap& m) const;
1055
- /// Post propagator according to specification
1056
- static void post(Space* home, Reflection::VarMap& vars,
1057
- const Reflection::ActorSpec& spec);
1058
- /// Mangled propagator name
1059
- static Support::Symbol ati(void);
1060
- };
1061
- /// Propagator using more memory but with constant runtime
1062
- class Speed : public SpeedLinBoolInt<VX> {
1063
- protected:
1064
- using SpeedLinBoolInt<VX>::x;
1065
- using SpeedLinBoolInt<VX>::n_s;
1066
- using SpeedLinBoolInt<VX>::c;
1067
- using SpeedLinBoolInt<VX>::co;
1068
- public:
1069
- /// Constructor for cloning \a p
1070
- Speed(Space* home, bool share, Speed& p);
1071
- /// Constructor for creation
1072
- Speed(Space* home, ViewArray<VX>& x, int c);
1073
- /// Create copy during cloning
1074
- virtual Actor* copy(Space* home, bool share);
1075
- /// Give advice to propagator
1076
- virtual ExecStatus advise(Space* home, Advisor* a, const Delta* d);
1077
- /// Perform propagation
1078
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1079
- /// Specification for this propagator
1080
- virtual Reflection::ActorSpec spec(const Space* home,
1081
- Reflection::VarMap& m) const;
1082
- /// Post propagator according to specification
1083
- static void post(Space* home, Reflection::VarMap& vars,
1084
- const Reflection::ActorSpec& spec);
1085
- /// Mangled propagator name
1086
- static Support::Symbol ati(void);
1087
- };
1088
- public:
1089
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \geq c\f$
1090
- static ExecStatus post(Space* home, ViewArray<VX>& x, int c,
1091
- PropKind pk=PK_DEF);
1092
- };
1093
-
1094
- /**
1095
- * \brief %Propagator for integer disequal to Boolean sum (cardinality)
1096
- *
1097
- * Requires \code #include "gecode/int/linear.hh" \endcode
1098
- * \ingroup FuncIntProp
1099
- */
1100
- template<class VX>
1101
- class NqBoolInt : public BinaryPropagator<VX,PC_INT_VAL> {
1102
- protected:
1103
- using BinaryPropagator<VX,PC_INT_VAL>::x0;
1104
- using BinaryPropagator<VX,PC_INT_VAL>::x1;
1105
- /// Views not yet subscribed to
1106
- ViewArray<VX> x;
1107
- /// Righthandside
1108
- int c;
1109
- /// Update subscription
1110
- bool resubscribe(Space* home, VX& y);
1111
- /// Constructor for posting
1112
- NqBoolInt(Space* home, ViewArray<VX>& b, int c);
1113
- /// Constructor for cloning \a p
1114
- NqBoolInt(Space* home, bool share, NqBoolInt<VX>& p);
1115
- public:
1116
- /// Copy propagator during cloning
1117
- virtual Actor* copy(Space* home, bool share);
1118
- /// Cost function (defined as PC_LINEAR_LO)
1119
- virtual PropCost cost(ModEventDelta med) const;
1120
- /// Perform propagation
1121
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1122
- /// Return specification for this propagator given a variable map \a m
1123
- virtual Reflection::ActorSpec spec(const Space* home,
1124
- Reflection::VarMap& m) const;
1125
- /// Post propagator according to specification
1126
- static void post(Space* home, Reflection::VarMap& vars,
1127
- const Reflection::ActorSpec& spec);
1128
- /// Mangled propagator name
1129
- static Support::Symbol ati(void);
1130
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \neq c\f$
1131
- static ExecStatus post(Space* home, ViewArray<VX>& b, int c);
1132
- };
1133
-
1134
- }}}
1135
-
1136
- #include "gecode/int/linear/bool-int.icc"
1137
-
1138
- namespace Gecode { namespace Int { namespace Linear {
1139
-
1140
- /**
1141
- * \brief Base-class for Boolean linear propagators
1142
- *
1143
- */
1144
- template <class XV, class YV>
1145
- class LinBoolView : public Propagator {
1146
- protected:
1147
- /// Boolean views
1148
- ViewArray<XV> x;
1149
- /// View to compare number of assigned Boolean views to
1150
- YV y;
1151
- /// Righthandside (constant part from Boolean views assigned to 1)
1152
- int c;
1153
- /// Constructor for cloning \a p
1154
- LinBoolView(Space* home, bool share, LinBoolView& p);
1155
- /// Constructor for creation
1156
- LinBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
1157
- /// Return specification for this propagator given a variable map \a m
1158
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
1159
- const Support::Symbol& name) const;
1160
- public:
1161
- /// Cost function (defined as dynamic PC_LINEAR_LO)
1162
- virtual PropCost cost(ModEventDelta med) const;
1163
- /// Delete propagator and return its size
1164
- virtual size_t dispose(Space* home);
1165
- };
1166
-
1167
-
1168
- /**
1169
- * \brief Base-class for reified Boolean linear propagators
1170
- *
1171
- */
1172
- template <class XV, class YV, class BV>
1173
- class ReLinBoolView : public LinBoolView<XV,YV> {
1174
- protected:
1175
- using LinBoolView<XV,YV>::x;
1176
- using LinBoolView<XV,YV>::y;
1177
- using LinBoolView<XV,YV>::c;
1178
- /// Control variable
1179
- BV b;
1180
- /// Constructor for cloning \a p
1181
- ReLinBoolView(Space* home, bool share, ReLinBoolView& p);
1182
- /// Constructor for creation
1183
- ReLinBoolView(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
1184
- /// Return specification for this propagator given a variable map \a m
1185
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
1186
- const Support::Symbol& name) const;
1187
- public:
1188
- /// Delete propagator and return its size
1189
- virtual size_t dispose(Space* home);
1190
- };
1191
-
1192
-
1193
- /**
1194
- * \brief %Propagator for equality to Boolean sum (cardinality)
1195
- *
1196
- * Requires \code #include "gecode/int/linear.hh" \endcode
1197
- * \ingroup FuncIntProp
1198
- */
1199
- template <class XV, class YV>
1200
- class EqBoolView : public LinBoolView<XV,YV> {
1201
- protected:
1202
- using LinBoolView<XV,YV>::x;
1203
- using LinBoolView<XV,YV>::y;
1204
- using LinBoolView<XV,YV>::c;
1205
-
1206
- /// Constructor for cloning \a p
1207
- EqBoolView(Space* home, bool share, EqBoolView& p);
1208
- /// Constructor for creation
1209
- EqBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
1210
- public:
1211
- /// Create copy during cloning
1212
- virtual Actor* copy(Space* home, bool share);
1213
- /// Perform propagation
1214
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1215
- /// Return specification for this propagator given a variable map \a m
1216
- virtual Reflection::ActorSpec spec(const Space* home,
1217
- Reflection::VarMap& m) const;
1218
- /// Post propagator according to specification
1219
- static void post(Space* home, Reflection::VarMap& vars,
1220
- const Reflection::ActorSpec& spec);
1221
- /// Mangled propagator name
1222
- static Support::Symbol ati(void);
1223
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i = y+c\f$
1224
- static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c);
1225
- };
1226
-
1227
- /**
1228
- * \brief %Propagator for disequality to Boolean sum (cardinality)
1229
- *
1230
- * Requires \code #include "gecode/int/linear.hh" \endcode
1231
- * \ingroup FuncIntProp
1232
- */
1233
- template <class XV, class YV>
1234
- class NqBoolView : public LinBoolView<XV,YV> {
1235
- protected:
1236
- using LinBoolView<XV,YV>::x;
1237
- using LinBoolView<XV,YV>::y;
1238
- using LinBoolView<XV,YV>::c;
1239
-
1240
- /// Constructor for cloning \a p
1241
- NqBoolView(Space* home, bool share, NqBoolView& p);
1242
- /// Constructor for creation
1243
- NqBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
1244
- public:
1245
- /// Create copy during cloning
1246
- virtual Actor* copy(Space* home, bool share);
1247
- /// Perform propagation
1248
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1249
- /// Return specification for this propagator given a variable map \a m
1250
- virtual Reflection::ActorSpec spec(const Space* home,
1251
- Reflection::VarMap& m) const;
1252
- /// Post propagator according to specification
1253
- static void post(Space* home, Reflection::VarMap& vars,
1254
- const Reflection::ActorSpec& spec);
1255
- /// Mangled propagator name
1256
- static Support::Symbol ati(void);
1257
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \neq y+c\f$
1258
- static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c);
1259
- };
1260
-
1261
- /**
1262
- * \brief %Propagator for greater or equal to Boolean sum (cardinality)
1263
- *
1264
- * Requires \code #include "gecode/int/linear.hh" \endcode
1265
- * \ingroup FuncIntProp
1266
- */
1267
- template <class XV, class YV>
1268
- class GqBoolView : public LinBoolView<XV,YV> {
1269
- protected:
1270
- using LinBoolView<XV,YV>::x;
1271
- using LinBoolView<XV,YV>::y;
1272
- using LinBoolView<XV,YV>::c;
1273
-
1274
- /// Constructor for cloning \a p
1275
- GqBoolView(Space* home, bool share, GqBoolView& p);
1276
- /// Constructor for creation
1277
- GqBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
1278
- public:
1279
- /// Create copy during cloning
1280
- virtual Actor* copy(Space* home, bool share);
1281
- /// Perform propagation
1282
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1283
- /// Return specification for this propagator given a variable map \a m
1284
- virtual Reflection::ActorSpec spec(const Space* home,
1285
- Reflection::VarMap& m) const;
1286
- /// Post propagator according to specification
1287
- static void post(Space* home, Reflection::VarMap& vars,
1288
- const Reflection::ActorSpec& spec);
1289
- /// Mangled propagator name
1290
- static Support::Symbol ati(void);
1291
- /// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \geq y+c\f$
1292
- static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c);
1293
- };
1294
-
1295
- /**
1296
- * \brief %Propagator for reified equality to Boolean sum (cardinality)
1297
- *
1298
- * Requires \code #include "gecode/int/linear.hh" \endcode
1299
- * \ingroup FuncIntProp
1300
- */
1301
- template <class XV, class YV, class BV>
1302
- class ReEqBoolView : public ReLinBoolView<XV,YV,BV> {
1303
- protected:
1304
- using ReLinBoolView<XV,YV,BV>::x;
1305
- using ReLinBoolView<XV,YV,BV>::y;
1306
- using ReLinBoolView<XV,YV,BV>::c;
1307
- using ReLinBoolView<XV,YV,BV>::b;
1308
-
1309
- /// Constructor for cloning \a p
1310
- ReEqBoolView(Space* home, bool share, ReEqBoolView& p);
1311
- /// Constructor for creation
1312
- ReEqBoolView(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
1313
- public:
1314
- /// Create copy during cloning
1315
- virtual Actor* copy(Space* home, bool share);
1316
- /// Perform propagation
1317
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1318
- /// Return specification for this propagator given a variable map \a m
1319
- virtual Reflection::ActorSpec spec(const Space* home,
1320
- Reflection::VarMap& m) const;
1321
- /// Post propagator according to specification
1322
- static void post(Space* home, Reflection::VarMap& vars,
1323
- const Reflection::ActorSpec& spec);
1324
- /// Mangled propagator name
1325
- static Support::Symbol ati(void);
1326
- /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i = y+c\right)\Leftrightarrow b\f$
1327
- static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
1328
- };
1329
-
1330
- /**
1331
- * \brief %Propagator for reified greater or equal to Boolean sum (cardinality)
1332
- *
1333
- * Requires \code #include "gecode/int/linear.hh" \endcode
1334
- * \ingroup FuncIntProp
1335
- */
1336
- template <class XV, class YV, class BV>
1337
- class ReGqBoolView : public ReLinBoolView<XV,YV,BV> {
1338
- protected:
1339
- using ReLinBoolView<XV,YV,BV>::x;
1340
- using ReLinBoolView<XV,YV,BV>::y;
1341
- using ReLinBoolView<XV,YV,BV>::c;
1342
- using ReLinBoolView<XV,YV,BV>::b;
1343
-
1344
- /// Constructor for cloning \a p
1345
- ReGqBoolView(Space* home, bool share, ReGqBoolView& p);
1346
- /// Constructor for creation
1347
- ReGqBoolView(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
1348
- public:
1349
- /// Create copy during cloning
1350
- virtual Actor* copy(Space* home, bool share);
1351
- /// Perform propagation
1352
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1353
- /// Return specification for this propagator given a variable map \a m
1354
- virtual Reflection::ActorSpec spec(const Space* home,
1355
- Reflection::VarMap& m) const;
1356
- /// Post propagator according to specification
1357
- static void post(Space* home, Reflection::VarMap& vars,
1358
- const Reflection::ActorSpec& spec);
1359
- /// Mangled propagator name
1360
- static Support::Symbol ati(void);
1361
- /// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i \geq y+c\right)\Leftrightarrow b\f$
1362
- static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
1363
- };
1364
-
1365
- }}}
1366
-
1367
- #include "gecode/int/linear/bool-view.icc"
1368
-
1369
- namespace Gecode { namespace Int { namespace Linear {
1370
-
1371
- /// Coefficient and Boolean view
1372
- class ScaleBool {
1373
- public:
1374
- /// Integer coefficient
1375
- int a;
1376
- /// Boolean view
1377
- BoolView x;
1378
- };
1379
-
1380
- /// Array of scale Boolean views
1381
- class ScaleBoolArray {
1382
- private:
1383
- /// First entry in array
1384
- ScaleBool* _fst;
1385
- /// One after last entry in array
1386
- ScaleBool* _lst;
1387
- public:
1388
- /// Default constructor
1389
- ScaleBoolArray(void);
1390
- /// Create array with \a n elements
1391
- ScaleBoolArray(Space* home, int n);
1392
- /// Subscribe propagator \a p
1393
- void subscribe(Space* home, Propagator* p);
1394
- /// Cancel propagator \a p
1395
- void cancel(Space* home, Propagator* p);
1396
- /// Update \a sba during copying
1397
- void update(Space* home, bool share, ScaleBoolArray& sba);
1398
- /// Return pointer to first element
1399
- ScaleBool* fst(void) const;
1400
- /// Return pointer after last element
1401
- ScaleBool* lst(void) const;
1402
- /// Set pointer to first element
1403
- void fst(ScaleBool* f);
1404
- /// Set pointer after last element
1405
- void lst(ScaleBool* l);
1406
- /// Test whether array is empty
1407
- bool empty(void) const;
1408
- /// Return number of elements
1409
- int size(void) const;
1410
- /// Return type of array
1411
- static Support::Symbol type(void);
1412
- /// Reflection
1413
- Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
1414
- private:
1415
- /// For sorting array in decreasing order of coefficients
1416
- class ScaleDec {
1417
- public:
1418
- bool
1419
- operator()(const ScaleBool& x, const ScaleBool& y);
1420
- };
1421
- public:
1422
- /// Sort array in decreasing order of coefficients
1423
- void sort(void);
1424
- };
1425
-
1426
-
1427
- /// Empty array of scale Boolean views
1428
- class EmptyScaleBoolArray {
1429
- public:
1430
- /// Default constructor
1431
- EmptyScaleBoolArray(void);
1432
- /// Create array with \a n elements
1433
- EmptyScaleBoolArray(Space* home, int n);
1434
- /// Subscribe propagator \a p
1435
- void subscribe(Space* home, Propagator* p);
1436
- /// Cancel propagator \a p
1437
- void cancel(Space* home, Propagator* p);
1438
- /// Update \a sba during copying
1439
- void update(Space* home, bool share, EmptyScaleBoolArray& esba);
1440
- /// Return pointer to first element
1441
- ScaleBool* fst(void) const;
1442
- /// Return pointer after last element
1443
- ScaleBool* lst(void) const;
1444
- /// Set pointer to first element
1445
- void fst(ScaleBool* f);
1446
- /// Set pointer after last element
1447
- void lst(ScaleBool* l);
1448
- /// Test whether array is empty
1449
- bool empty(void) const;
1450
- /// Return number of elements
1451
- int size(void) const;
1452
- /// Sort array in decreasing order of coefficients
1453
- void sort(void);
1454
- /// Return type of array
1455
- static Support::Symbol type(void);
1456
- };
1457
-
1458
-
1459
- /**
1460
- * \brief Base class for linear Boolean constraints with coefficients
1461
- *
1462
- */
1463
- template <class SBAP, class SBAN, class VX, PropCond pcx>
1464
- class LinBoolScale : public Propagator {
1465
- protected:
1466
- /// Positive Boolean views with coefficients on left-hand side
1467
- SBAP p;
1468
- /// Negative Boolean views with coefficients on left-hand side
1469
- SBAN n;
1470
- /// Integer view on right-hand side
1471
- VX x;
1472
- /// Integer constant on right-hand side
1473
- int c;
1474
- /// Return specification for this propagator given a variable map \a m
1475
- Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
1476
- const Support::Symbol& name) const;
1477
- public:
1478
- /// Constructor for creation
1479
- LinBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
1480
- /// Constructor for cloning \a pr
1481
- LinBoolScale(Space* home, bool share, Propagator& pr,
1482
- SBAP& p, SBAN& n, VX x, int c);
1483
- /// Cost function (defined as dynamic PC_LINEAR_LO)
1484
- virtual PropCost cost(ModEventDelta med) const;
1485
- /// Delete propagator and return its size
1486
- virtual size_t dispose(Space* home);
1487
- };
1488
-
1489
- /**
1490
- * \brief %Propagator for equality to Boolean sum with coefficients
1491
- *
1492
- * Requires \code #include "gecode/int/linear.hh" \endcode
1493
- * \ingroup FuncIntProp
1494
- */
1495
- template <class SBAP, class SBAN, class VX>
1496
- class EqBoolScale : public LinBoolScale<SBAP,SBAN,VX,PC_INT_BND> {
1497
- protected:
1498
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::p;
1499
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::n;
1500
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::x;
1501
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::c;
1502
- public:
1503
- /// Constructor for creation
1504
- EqBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
1505
- /// Constructor for cloning \a pr
1506
- EqBoolScale(Space* home, bool share, Propagator& pr,
1507
- SBAP& p, SBAN& n, VX x, int c);
1508
- /// Create copy during cloning
1509
- virtual Actor* copy(Space* home, bool share);
1510
- /// Perform propagation
1511
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1512
- /// Return specification for this propagator given a variable map \a m
1513
- virtual Reflection::ActorSpec spec(const Space* home,
1514
- Reflection::VarMap& m) const;
1515
- /// Post propagator according to specification
1516
- static void post(Space* home, Reflection::VarMap& vars,
1517
- const Reflection::ActorSpec& spec);
1518
- /// Mangled propagator name
1519
- static Support::Symbol ati(void);
1520
- /// Post propagator
1521
- static ExecStatus post(Space* home, SBAP& p, SBAN& n, VX x, int c);
1522
- };
1523
-
1524
- /**
1525
- * \brief %Propagator for inequality to Boolean sum with coefficients
1526
- *
1527
- * Requires \code #include "gecode/int/linear.hh" \endcode
1528
- * \ingroup FuncIntProp
1529
- */
1530
- template <class SBAP, class SBAN, class VX>
1531
- class LqBoolScale : public LinBoolScale<SBAP,SBAN,VX,PC_INT_BND> {
1532
- protected:
1533
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::p;
1534
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::n;
1535
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::x;
1536
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::c;
1537
- public:
1538
- /// Constructor for creation
1539
- LqBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
1540
- /// Constructor for cloning \a pr
1541
- LqBoolScale(Space* home, bool share, Propagator& pr,
1542
- SBAP& p, SBAN& n, VX x, int c);
1543
- /// Create copy during cloning
1544
- virtual Actor* copy(Space* home, bool share);
1545
- /// Perform propagation
1546
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1547
- /// Return specification for this propagator given a variable map \a m
1548
- virtual Reflection::ActorSpec spec(const Space* home,
1549
- Reflection::VarMap& m) const;
1550
- /// Post propagator according to specification
1551
- static void post(Space* home, Reflection::VarMap& vars,
1552
- const Reflection::ActorSpec& spec);
1553
- /// Mangled propagator name
1554
- static Support::Symbol ati(void);
1555
- /// Post propagator
1556
- static ExecStatus post(Space* home, SBAP& p, SBAN& n, VX x, int c);
1557
- };
1558
-
1559
- /**
1560
- * \brief %Propagator for disequality to Boolean sum with coefficients
1561
- *
1562
- * Requires \code #include "gecode/int/linear.hh" \endcode
1563
- * \ingroup FuncIntProp
1564
- */
1565
- template <class SBAP, class SBAN, class VX>
1566
- class NqBoolScale : public LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL> {
1567
- protected:
1568
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::p;
1569
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::n;
1570
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::x;
1571
- using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::c;
1572
- public:
1573
- /// Constructor for creation
1574
- NqBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
1575
- /// Constructor for cloning \a pr
1576
- NqBoolScale(Space* home, bool share, Propagator& pr,
1577
- SBAP& p, SBAN& n, VX x, int c);
1578
- /// Create copy during cloning
1579
- virtual Actor* copy(Space* home, bool share);
1580
- /// Perform propagation
1581
- virtual ExecStatus propagate(Space* home, ModEventDelta med);
1582
- /// Return specification for this propagator given a variable map \a m
1583
- virtual Reflection::ActorSpec spec(const Space* home,
1584
- Reflection::VarMap& m) const;
1585
- /// Post propagator according to specification
1586
- static void post(Space* home, Reflection::VarMap& vars,
1587
- const Reflection::ActorSpec& spec);
1588
- /// Mangled propagator name
1589
- static Support::Symbol ati(void);
1590
- /// Post propagator
1591
- static ExecStatus post(Space* home, SBAP& p, SBAN& n, VX x, int c);
1592
- };
1593
-
1594
- }}}
1595
-
1596
- #include "gecode/int/linear/bool-scale.icc"
1597
-
1598
- namespace Gecode { namespace Int { namespace Linear {
1599
-
1600
- /**
1601
- * \brief Class for describing linear term \f$a\cdot x\f$
1602
- *
1603
- */
1604
- template<class View>
1605
- class Term {
1606
- public:
1607
- /// Coefficient
1608
- int a;
1609
- /// View
1610
- View x;
1611
- };
1612
-
1613
- /** \brief Estimate lower and upper bounds
1614
- *
1615
- * Estimates the boundaries for a linear expression
1616
- * \f$\sum_{i=0}^{n-1}t_i + c\f$. If the boundaries exceed
1617
- * the limits as defined in Limits::Int, these boundaries
1618
- * are returned.
1619
- *
1620
- * \param t array of linear terms
1621
- * \param n size of array
1622
- * \param c constant
1623
- * \param l lower bound
1624
- * \param u upper bound
1625
- *
1626
- */
1627
- template<class View>
1628
- void estimate(Term<View>* t, int n, int c,
1629
- int& l, int& u);
1630
-
1631
- /** \brief Normalize linear integer constraints
1632
- *
1633
- * \param t array of linear terms
1634
- * \param n size of array
1635
- * \param t_p array of linear terms over integers with positive coefficients
1636
- * \param n_p number of postive terms
1637
- * \param t_n array of linear terms over integers with negative coefficients
1638
- * \param n_n number of negative terms
1639
- *
1640
- * Replaces all negative coefficients by positive coefficients.
1641
- *
1642
- * - Variables occuring multiply in the term array are replaced
1643
- * by a single occurence: for example, \f$ax+bx\f$ becomes
1644
- * \f$(a+b)x\f$.
1645
- * - If in the above simplification the value for \f$(a+b)\f$ (or for
1646
- * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1647
- * defined in Limits::Int, an exception of type
1648
- * Int::NumericalOverflow is thrown.
1649
- *
1650
- * Returns true, if all coefficients are unit coefficients
1651
- */
1652
- template<class View>
1653
- bool normalize(Term<View>* t, int &n,
1654
- Term<View>* &t_p, int &n_p,
1655
- Term<View>* &t_n, int &n_n);
1656
-
1657
-
1658
- /**
1659
- * \brief Post propagator for linear constraint over integers
1660
- * \param t array of linear terms over integers
1661
- * \param n size of array
1662
- * \param r type of relation
1663
- * \param c result of linear constraint
1664
- *
1665
- * All variants for linear constraints share the following properties:
1666
- * - Variables occuring multiply in the term array are replaced
1667
- * by a single occurence: for example, \f$ax+bx\f$ becomes
1668
- * \f$(a+b)x\f$.
1669
- * - If in the above simplification the value for \f$(a+b)\f$ (or for
1670
- * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1671
- * defined in Limits::Int, an exception of type
1672
- * Int::NumericalOverflow is thrown.
1673
- * - Assume linear terms for the constraint
1674
- * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1675
- * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
1676
- * for doubles as defined in Limits::Int, an exception of
1677
- * type Int::NumericalOverflow is thrown.
1678
- * - In all other cases, the created propagators are accurate (that
1679
- * is, they will not silently overflow during propagation).
1680
- *
1681
- * Requires \code #include "gecode/int/linear.hh" \endcode
1682
- * \ingroup FuncIntProp
1683
- */
1684
- GECODE_INT_EXPORT void
1685
- post(Space* home, Term<IntView>* t, int n, IntRelType r, int c,
1686
- IntConLevel=ICL_DEF, PropKind pk=PK_DEF);
1687
-
1688
- /**
1689
- * \brief Post reified propagator for linear constraint
1690
- * \param t array of linear terms
1691
- * \param n size of array
1692
- * \param r type of relation
1693
- * \param c result of linear constraint
1694
- * \param b Boolean control view
1695
- *
1696
- * All variants for linear constraints share the following properties:
1697
- * - Only bounds-consistency is supported.
1698
- * - Variables occuring multiply in the term array are replaced
1699
- * by a single occurence: for example, \f$ax+bx\f$ becomes
1700
- * \f$(a+b)x\f$.
1701
- * - If in the above simplification the value for \f$(a+b)\f$ (or for
1702
- * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1703
- * defined in Limits::Int, an exception of type
1704
- * Int::NumericalOverflow is thrown.
1705
- * - Assume linear terms for the constraint
1706
- * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1707
- * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
1708
- * for doubles as defined in Limits::Int, an exception of
1709
- * type Int::NumericalOverflow is thrown.
1710
- * - In all other cases, the created propagators are accurate (that
1711
- * is, they will not silently overflow during propagation).
1712
- *
1713
- * Requires \code #include "gecode/int/linear.hh" \endcode
1714
- * \ingroup FuncIntProp
1715
- */
1716
- GECODE_INT_EXPORT void
1717
- post(Space* home, Term<IntView>* t, int n, IntRelType r, int c, BoolView b,
1718
- IntConLevel=ICL_DEF, PropKind pk=PK_DEF);
1719
-
1720
- /**
1721
- * \brief Post propagator for linear constraint over Booleans
1722
- * \param t array of linear terms over Booleans
1723
- * \param n size of array
1724
- * \param r type of relation
1725
- * \param c result of linear constraint
1726
- *
1727
- * All variants for linear constraints share the following properties:
1728
- * - Variables occuring multiply in the term array are replaced
1729
- * by a single occurence: for example, \f$ax+bx\f$ becomes
1730
- * \f$(a+b)x\f$.
1731
- * - If in the above simplification the value for \f$(a+b)\f$ (or for
1732
- * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1733
- * defined in Limits::Int, an exception of type
1734
- * Int::NumericalOverflow is thrown.
1735
- * - Assume linear terms for the constraint
1736
- * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1737
- * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
1738
- * for integers as defined in Limits::Int, an exception of
1739
- * type Int::NumericalOverflow is thrown.
1740
- * - In all other cases, the created propagators are accurate (that
1741
- * is, they will not silently overflow during propagation).
1742
- *
1743
- * Requires \code #include "gecode/int/linear.hh" \endcode
1744
- * \ingroup FuncIntProp
1745
- */
1746
- GECODE_INT_EXPORT void
1747
- post(Space* home, Term<BoolView>* t, int n, IntRelType r, int c,
1748
- IntConLevel=ICL_DEF, PropKind=PK_DEF);
1749
-
1750
- /**
1751
- * \brief Post propagator for reified linear constraint over Booleans
1752
- * \param t array of linear terms over Booleans
1753
- * \param n size of array
1754
- * \param r type of relation
1755
- * \param c result of linear constraint
1756
- * \param b Boolean control varaible
1757
- *
1758
- * All variants for linear constraints share the following properties:
1759
- * - Variables occuring multiply in the term array are replaced
1760
- * by a single occurence: for example, \f$ax+bx\f$ becomes
1761
- * \f$(a+b)x\f$.
1762
- * - If in the above simplification the value for \f$(a+b)\f$ (or for
1763
- * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1764
- * defined in Limits::Int, an exception of type
1765
- * Int::NumericalOverflow is thrown.
1766
- * - Assume linear terms for the constraint
1767
- * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1768
- * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
1769
- * for integers as defined in Limits::Int, an exception of
1770
- * type Int::NumericalOverflow is thrown.
1771
- * - In all other cases, the created propagators are accurate (that
1772
- * is, they will not silently overflow during propagation).
1773
- *
1774
- * Requires \code #include "gecode/int/linear.hh" \endcode
1775
- * \ingroup FuncIntProp
1776
- */
1777
- GECODE_INT_EXPORT void
1778
- post(Space* home, Term<BoolView>* t, int n, IntRelType r, int c, BoolView b,
1779
- IntConLevel=ICL_DEF, PropKind=PK_DEF);
1780
-
1781
- /**
1782
- * \brief Post propagator for linear constraint over Booleans
1783
- * \param t array of linear terms over Booleans
1784
- * \param n size of array
1785
- * \param r type of relation
1786
- * \param y variable right hand side of linear constraint
1787
- * \param c constant right hand side of linear constraint
1788
- *
1789
- * All variants for linear constraints share the following properties:
1790
- * - Variables occuring multiply in the term array are replaced
1791
- * by a single occurence: for example, \f$ax+bx\f$ becomes
1792
- * \f$(a+b)x\f$.
1793
- * - If in the above simplification the value for \f$(a+b)\f$ (or for
1794
- * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1795
- * defined in Limits::Int, an exception of type
1796
- * Int::NumericalOverflow is thrown.
1797
- * - Assume linear terms for the constraint
1798
- * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1799
- * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
1800
- * for integers as defined in Limits::Int, an exception of
1801
- * type Int::NumericalOverflow is thrown.
1802
- * - In all other cases, the created propagators are accurate (that
1803
- * is, they will not silently overflow during propagation).
1804
- *
1805
- * Requires \code #include "gecode/int/linear.hh" \endcode
1806
- * \ingroup FuncIntProp
1807
- */
1808
- GECODE_INT_EXPORT void
1809
- post(Space* home, Term<BoolView>* t, int n, IntRelType r, IntView y, int c=0,
1810
- IntConLevel=ICL_DEF, PropKind=PK_DEF);
1811
-
1812
- /**
1813
- * \brief Post propagator for reified linear constraint over Booleans
1814
- * \param t array of linear terms over Booleans
1815
- * \param n size of array
1816
- * \param r type of relation
1817
- * \param y variable right hand side of linear constraint
1818
- * \param b Boolean control variable
1819
- *
1820
- * All variants for linear constraints share the following properties:
1821
- * - Variables occuring multiply in the term array are replaced
1822
- * by a single occurence: for example, \f$ax+bx\f$ becomes
1823
- * \f$(a+b)x\f$.
1824
- * - If in the above simplification the value for \f$(a+b)\f$ (or for
1825
- * \f$a\f$ and \f$b\f$) exceeds the limits for integers as
1826
- * defined in Limits::Int, an exception of type
1827
- * Int::NumericalOverflow is thrown.
1828
- * - Assume linear terms for the constraint
1829
- * \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
1830
- * If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
1831
- * for integers as defined in Limits::Int, an exception of
1832
- * type Int::NumericalOverflow is thrown.
1833
- * - In all other cases, the created propagators are accurate (that
1834
- * is, they will not silently overflow during propagation).
1835
- *
1836
- * Requires \code #include "gecode/int/linear.hh" \endcode
1837
- * \ingroup FuncIntProp
1838
- */
1839
- GECODE_INT_EXPORT void
1840
- post(Space* home, Term<BoolView>* t, int n, IntRelType r, IntView y,
1841
- BoolView b, IntConLevel=ICL_DEF, PropKind=PK_DEF);
1842
-
1843
- }}}
1844
-
1845
- #include "gecode/int/linear/post.icc"
1846
-
1847
- #endif
1848
-
1849
- // STATISTICS: int-prop