gecoder-with-gecode 0.9.0 → 0.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (919) hide show
  1. data/CHANGES +6 -0
  2. data/README +1 -1
  3. data/THANKS +18 -0
  4. data/example/equation_system.rb +3 -1
  5. data/example/magic_sequence.rb +3 -1
  6. data/example/queens.rb +3 -1
  7. data/example/send_more_money.rb +24 -30
  8. data/example/send_most_money.rb +15 -26
  9. data/example/square_tiling.rb +3 -1
  10. data/example/sudoku-set.rb +3 -1
  11. data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
  12. data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
  13. data/ext/gecode-2.2.0/Makefile.dep +8056 -0
  14. data/ext/gecode-2.2.0/Makefile.in +1590 -0
  15. data/ext/gecode-2.2.0/changelog.in +2698 -0
  16. data/ext/gecode-2.2.0/configure +13112 -0
  17. data/ext/gecode-2.2.0/configure.ac +273 -0
  18. data/ext/gecode-2.2.0/configure.ac.in +269 -0
  19. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
  20. data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
  21. data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
  22. data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
  23. data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
  24. data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
  25. data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
  26. data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
  27. data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
  28. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
  29. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
  30. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
  31. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
  32. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
  33. data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
  34. data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
  35. data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
  36. data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
  37. data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
  38. data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
  39. data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
  40. data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
  41. data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
  42. data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
  43. data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
  44. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
  45. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
  46. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
  47. data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
  48. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
  49. data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
  50. data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
  51. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
  52. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
  53. data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
  54. data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
  55. data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
  56. data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
  57. data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
  58. data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
  59. data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
  60. data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
  61. data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
  62. data/ext/gecode-2.2.0/examples/crew.cc +286 -0
  63. data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
  64. data/ext/gecode-2.2.0/examples/domino.cc +297 -0
  65. data/ext/gecode-2.2.0/examples/donald.cc +107 -0
  66. data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
  67. data/ext/gecode-2.2.0/examples/golf.cc +297 -0
  68. data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
  69. data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
  70. data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
  71. data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
  72. data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
  73. data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
  74. data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
  75. data/ext/gecode-2.2.0/examples/knights.cc +220 -0
  76. data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
  77. data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
  78. data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
  79. data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
  80. data/ext/gecode-2.2.0/examples/money.cc +105 -0
  81. data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
  82. data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
  83. data/ext/gecode-2.2.0/examples/partition.cc +141 -0
  84. data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
  85. data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
  86. data/ext/gecode-2.2.0/examples/photo.cc +170 -0
  87. data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
  88. data/ext/gecode-2.2.0/examples/queens.cc +147 -0
  89. data/ext/gecode-2.2.0/examples/queens.js +57 -0
  90. data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
  91. data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
  92. data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
  93. data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
  94. data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
  95. data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
  96. data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
  97. data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
  98. data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
  99. data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
  100. data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
  101. data/ext/gecode-2.2.0/examples/support.hh +338 -0
  102. data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
  103. data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
  104. data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
  105. data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
  106. data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
  107. data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
  108. data/ext/gecode-2.2.0/gecode.m4 +1046 -0
  109. data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
  110. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
  111. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
  112. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
  113. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
  114. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
  115. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
  116. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
  117. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
  118. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
  119. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
  120. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
  121. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
  122. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
  123. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
  124. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
  125. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
  126. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
  127. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
  128. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
  129. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
  130. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
  131. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
  132. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
  133. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
  134. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
  135. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
  136. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
  137. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
  138. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
  139. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
  140. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
  141. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
  142. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
  143. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
  144. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
  145. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
  146. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
  147. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
  148. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
  149. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
  150. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
  151. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
  152. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
  153. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
  154. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
  155. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
  156. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
  157. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
  158. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
  159. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
  160. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
  161. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
  162. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
  163. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
  164. data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
  165. data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
  166. data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
  167. data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
  168. data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
  169. data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
  170. data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
  171. data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
  172. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
  173. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
  174. data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
  175. data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
  176. data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
  177. data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
  178. data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
  179. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
  180. data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
  181. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
  182. data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
  183. data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
  184. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
  185. data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
  186. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
  187. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
  188. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
  189. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
  190. data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
  191. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
  192. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
  193. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
  194. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
  195. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
  196. data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
  197. data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
  198. data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
  199. data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
  200. data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
  201. data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
  202. data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
  203. data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
  204. data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
  205. data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
  206. data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
  207. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
  208. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
  209. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
  210. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
  211. data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
  212. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
  213. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
  214. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
  215. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
  216. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
  217. data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
  218. data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
  219. data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
  220. data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
  221. data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
  222. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
  223. data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
  224. data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
  225. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
  226. data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
  227. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
  228. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
  229. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
  230. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
  231. data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
  232. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
  233. data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
  234. data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
  235. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
  236. data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
  237. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
  238. data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
  239. data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
  240. data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
  241. data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
  242. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
  243. data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
  244. data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
  245. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
  246. data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
  247. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
  248. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
  249. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
  250. data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
  251. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
  252. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
  253. data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
  254. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
  255. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
  256. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
  257. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
  258. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
  259. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
  260. data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
  261. data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
  262. data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
  263. data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
  264. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
  265. data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
  266. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
  267. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
  268. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
  269. data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
  270. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
  271. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
  272. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
  273. data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
  274. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
  275. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
  276. data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
  277. data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
  278. data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
  279. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
  280. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
  281. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
  282. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
  283. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
  284. data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
  285. data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
  286. data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
  287. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
  288. data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
  289. data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
  290. data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
  291. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
  292. data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
  293. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
  294. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
  295. data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
  296. data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
  297. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
  298. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
  299. data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
  300. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
  301. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
  302. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
  303. data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
  304. data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
  305. data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
  306. data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
  307. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
  308. data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
  309. data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
  310. data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
  311. data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
  312. data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
  313. data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
  314. data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
  315. data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
  316. data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
  317. data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
  318. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
  319. data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
  320. data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
  321. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
  322. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
  323. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
  324. data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
  325. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
  326. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
  327. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
  328. data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
  329. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
  330. data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
  331. data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
  332. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
  333. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
  334. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
  335. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
  336. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
  337. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
  338. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
  339. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
  340. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
  341. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
  342. data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
  343. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
  344. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
  345. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
  346. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
  347. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
  348. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
  349. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
  350. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
  351. data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
  352. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
  353. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
  354. data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
  355. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
  356. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
  357. data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
  358. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
  359. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
  360. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
  361. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
  362. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
  363. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
  364. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
  365. data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
  366. data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
  367. data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
  368. data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
  369. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
  370. data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
  371. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
  372. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
  373. data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
  374. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
  375. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
  376. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
  377. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
  378. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
  379. data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
  380. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
  381. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
  382. data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
  383. data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
  384. data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
  385. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
  386. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
  387. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
  388. data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
  389. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
  390. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
  391. data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
  392. data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
  393. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
  394. data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
  395. data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
  396. data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
  397. data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
  398. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
  399. data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
  400. data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
  401. data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
  402. data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
  403. data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
  404. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
  405. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
  406. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
  407. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
  408. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
  409. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
  410. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
  411. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
  412. data/ext/gecode-2.2.0/gecode/search.hh +759 -0
  413. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
  414. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
  415. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
  416. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
  417. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
  418. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
  419. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
  420. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
  421. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
  422. data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
  423. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
  424. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
  425. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
  426. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
  427. data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
  428. data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
  429. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
  430. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
  431. data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
  432. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
  433. data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
  434. data/ext/gecode-2.2.0/gecode/set.hh +970 -0
  435. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
  436. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
  437. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
  438. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
  439. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
  440. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
  441. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
  442. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
  443. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
  444. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
  445. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
  446. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
  447. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
  448. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
  449. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
  450. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
  451. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
  452. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
  453. data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
  454. data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
  455. data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
  456. data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
  457. data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
  458. data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
  459. data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
  460. data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
  461. data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
  462. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
  463. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
  464. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
  465. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
  466. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
  467. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
  468. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
  469. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
  470. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
  471. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
  472. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
  473. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
  474. data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
  475. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
  476. data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
  477. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
  478. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
  479. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
  480. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
  481. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
  482. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
  483. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
  484. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
  485. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
  486. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
  487. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
  488. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
  489. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
  490. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
  491. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
  492. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
  493. data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
  494. data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
  495. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
  496. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
  497. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
  498. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
  499. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
  500. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
  501. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
  502. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
  503. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
  504. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
  505. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
  506. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
  507. data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
  508. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
  509. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
  510. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
  511. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
  512. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
  513. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
  514. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
  515. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
  516. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
  517. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
  518. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
  519. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
  520. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
  521. data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
  522. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
  523. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
  524. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
  525. data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
  526. data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
  527. data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
  528. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
  529. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
  530. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
  531. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
  532. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
  533. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
  534. data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
  535. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
  536. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
  537. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
  538. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
  539. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
  540. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
  541. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
  542. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
  543. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
  544. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
  545. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
  546. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
  547. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
  548. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
  549. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
  550. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
  551. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
  552. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
  553. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
  554. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
  555. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
  556. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
  557. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
  558. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
  559. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
  560. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
  561. data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
  562. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
  563. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
  564. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
  565. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
  566. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
  567. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
  568. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
  569. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
  570. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
  571. data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
  572. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
  573. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
  574. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
  575. data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
  576. data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
  577. data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
  578. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
  579. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
  580. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
  581. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
  582. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
  583. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
  584. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
  585. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
  586. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
  587. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
  588. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
  589. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
  590. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
  591. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
  592. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
  593. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
  594. data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
  595. data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
  596. data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
  597. data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
  598. data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
  599. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
  600. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
  601. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
  602. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
  603. data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
  604. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
  605. data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
  606. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
  607. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
  608. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
  609. data/ext/gecode-2.2.0/test/assign.cc +181 -0
  610. data/ext/gecode-2.2.0/test/assign.hh +93 -0
  611. data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
  612. data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
  613. data/ext/gecode-2.2.0/test/branch.cc +563 -0
  614. data/ext/gecode-2.2.0/test/branch.hh +144 -0
  615. data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
  616. data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
  617. data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
  618. data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
  619. data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
  620. data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
  621. data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
  622. data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
  623. data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
  624. data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
  625. data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
  626. data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
  627. data/ext/gecode-2.2.0/test/int.cc +688 -0
  628. data/ext/gecode-2.2.0/test/int.hh +267 -0
  629. data/ext/gecode-2.2.0/test/int.icc +266 -0
  630. data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
  631. data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
  632. data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
  633. data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
  634. data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
  635. data/ext/gecode-2.2.0/test/int/count.cc +357 -0
  636. data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
  637. data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
  638. data/ext/gecode-2.2.0/test/int/element.cc +333 -0
  639. data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
  640. data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
  641. data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
  642. data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
  643. data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
  644. data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
  645. data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
  646. data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
  647. data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
  648. data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
  649. data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
  650. data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
  651. data/ext/gecode-2.2.0/test/search.cc +618 -0
  652. data/ext/gecode-2.2.0/test/set.cc +753 -0
  653. data/ext/gecode-2.2.0/test/set.hh +286 -0
  654. data/ext/gecode-2.2.0/test/set.icc +108 -0
  655. data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
  656. data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
  657. data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
  658. data/ext/gecode-2.2.0/test/set/int.cc +473 -0
  659. data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
  660. data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
  661. data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
  662. data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
  663. data/ext/gecode-2.2.0/test/set/select.cc +299 -0
  664. data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
  665. data/ext/gecode-2.2.0/test/test.cc +287 -0
  666. data/ext/gecode-2.2.0/test/test.hh +175 -0
  667. data/ext/gecode-2.2.0/test/test.icc +93 -0
  668. data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
  669. data/lib/gecoder/bindings.rb +7 -5
  670. data/lib/gecoder/bindings/bindings.rb +8 -8
  671. data/lib/gecoder/interface.rb +4 -2
  672. data/lib/gecoder/interface/binding_changes.rb +1 -1
  673. data/lib/gecoder/interface/branch.rb +1 -1
  674. data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
  675. data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
  676. data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
  677. data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
  678. data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
  679. data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
  680. data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
  681. data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
  682. data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
  683. data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
  684. data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
  685. data/lib/gecoder/interface/convenience.rb +99 -0
  686. data/lib/gecoder/interface/enum_wrapper.rb +1 -1
  687. data/lib/gecoder/interface/mixin.rb +486 -0
  688. data/lib/gecoder/interface/search.rb +23 -22
  689. data/lib/gecoder/version.rb +1 -1
  690. data/specs/branch.rb +5 -3
  691. data/specs/constraints/bool/boolean.rb +3 -1
  692. data/specs/constraints/bool/linear.rb +3 -1
  693. data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
  694. data/specs/constraints/bool_enum/channel.rb +3 -1
  695. data/specs/constraints/fixnum_enum/element.rb +3 -1
  696. data/specs/constraints/int/arithmetic.rb +3 -1
  697. data/specs/constraints/int/channel.rb +3 -1
  698. data/specs/constraints/int/linear.rb +3 -1
  699. data/specs/constraints/int/linear_properties.rb +3 -1
  700. data/specs/constraints/int_enum/arithmetic.rb +3 -1
  701. data/specs/constraints/int_enum/channel.rb +3 -1
  702. data/specs/constraints/int_enum/count.rb +3 -1
  703. data/specs/constraints/int_enum/distinct.rb +3 -1
  704. data/specs/constraints/int_enum/element.rb +3 -1
  705. data/specs/constraints/int_enum/sort.rb +3 -1
  706. data/specs/constraints/property_helper.rb +10 -10
  707. data/specs/constraints/reification_sugar.rb +3 -1
  708. data/specs/constraints/selected_set/select.rb +6 -5
  709. data/specs/constraints/selected_set/select_properties.rb +12 -10
  710. data/specs/constraints/set/channel.rb +3 -1
  711. data/specs/constraints/set/domain.rb +4 -4
  712. data/specs/constraints/set/relation.rb +4 -4
  713. data/specs/constraints/set_enum/channel.rb +3 -1
  714. data/specs/constraints/set_enum/distinct.rb +3 -1
  715. data/specs/constraints/set_enum/element.rb +77 -0
  716. data/specs/enum_wrapper.rb +1 -1
  717. data/specs/mixin.rb +78 -0
  718. data/specs/model.rb +5 -5
  719. data/specs/search.rb +20 -14
  720. data/specs/selected_set.rb +3 -3
  721. data/specs/set_elements.rb +2 -2
  722. data/tasks/distribution.rake +25 -4
  723. metadata +739 -602
  724. data/example/money.rb +0 -36
  725. data/ext/gecode-2.1.1/Makefile.dep +0 -7622
  726. data/ext/gecode-2.1.1/Makefile.in +0 -1568
  727. data/ext/gecode-2.1.1/changelog.in +0 -2459
  728. data/ext/gecode-2.1.1/configure +0 -11631
  729. data/ext/gecode-2.1.1/configure.ac +0 -249
  730. data/ext/gecode-2.1.1/configure.ac.in +0 -245
  731. data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
  732. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
  733. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
  734. data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
  735. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
  736. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
  737. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
  738. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
  739. data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
  740. data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
  741. data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
  742. data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
  743. data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
  744. data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
  745. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
  746. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
  747. data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
  748. data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
  749. data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
  750. data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
  751. data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
  752. data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
  753. data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
  754. data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
  755. data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
  756. data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
  757. data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
  758. data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
  759. data/ext/gecode-2.1.1/gecode.m4 +0 -956
  760. data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
  761. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
  762. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
  763. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
  764. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
  765. data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
  766. data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
  767. data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
  768. data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
  769. data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
  770. data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
  771. data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
  772. data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
  773. data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
  774. data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
  775. data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
  776. data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
  777. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
  778. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
  779. data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
  780. data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
  781. data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
  782. data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
  783. data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
  784. data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
  785. data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
  786. data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
  787. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
  788. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
  789. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
  790. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
  791. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
  792. data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
  793. data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
  794. data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
  795. data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
  796. data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
  797. data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
  798. data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
  799. data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
  800. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
  801. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
  802. data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
  803. data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
  804. data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
  805. data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
  806. data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
  807. data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
  808. data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
  809. data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
  810. data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
  811. data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
  812. data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
  813. data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
  814. data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
  815. data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
  816. data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
  817. data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
  818. data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
  819. data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
  820. data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
  821. data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
  822. data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
  823. data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
  824. data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
  825. data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
  826. data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
  827. data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
  828. data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
  829. data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
  830. data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
  831. data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
  832. data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
  833. data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
  834. data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
  835. data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
  836. data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
  837. data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
  838. data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
  839. data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
  840. data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
  841. data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
  842. data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
  843. data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
  844. data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
  845. data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
  846. data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
  847. data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
  848. data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
  849. data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
  850. data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
  851. data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
  852. data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
  853. data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
  854. data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
  855. data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
  856. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
  857. data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
  858. data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
  859. data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
  860. data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
  861. data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
  862. data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
  863. data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
  864. data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
  865. data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
  866. data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
  867. data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
  868. data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
  869. data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
  870. data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
  871. data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
  872. data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
  873. data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
  874. data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
  875. data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
  876. data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
  877. data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
  878. data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
  879. data/ext/gecode-2.1.1/gecode/search.hh +0 -752
  880. data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
  881. data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
  882. data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
  883. data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
  884. data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
  885. data/ext/gecode-2.1.1/gecode/set.hh +0 -970
  886. data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
  887. data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
  888. data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
  889. data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
  890. data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
  891. data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
  892. data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
  893. data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
  894. data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
  895. data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
  896. data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
  897. data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
  898. data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
  899. data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
  900. data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
  901. data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
  902. data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
  903. data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
  904. data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
  905. data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
  906. data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
  907. data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
  908. data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
  909. data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
  910. data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
  911. data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
  912. data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
  913. data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
  914. data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
  915. data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
  916. data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
  917. data/lib/gecoder/interface/model.rb +0 -453
  918. data/lib/gecoder/interface/model_sugar.rb +0 -84
  919. data/specs/constraints/set_enum/select.rb +0 -73
@@ -0,0 +1,1451 @@
1
+ /* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
2
+ /*
3
+ * Main authors:
4
+ * Guido Tack <tack@gecode.org>
5
+ *
6
+ * Contributing authors:
7
+ * Christian Schulte <schulte@gecode.org>
8
+ *
9
+ * Copyright:
10
+ * Guido Tack, 2004
11
+ * Christian Schulte, 2004
12
+ *
13
+ * Last modified:
14
+ * $Date: 2008-07-11 10:24:32 +0200 (Fri, 11 Jul 2008) $ by $Author: tack $
15
+ * $Revision: 7328 $
16
+ *
17
+ * This file is part of Gecode, the generic constraint
18
+ * development environment:
19
+ * http://www.gecode.org
20
+ *
21
+ * Permission is hereby granted, free of charge, to any person obtaining
22
+ * a copy of this software and associated documentation files (the
23
+ * "Software"), to deal in the Software without restriction, including
24
+ * without limitation the rights to use, copy, modify, merge, publish,
25
+ * distribute, sublicense, and/or sell copies of the Software, and to
26
+ * permit persons to whom the Software is furnished to do so, subject to
27
+ * the following conditions:
28
+ *
29
+ * The above copyright notice and this permission notice shall be
30
+ * included in all copies or substantial portions of the Software.
31
+ *
32
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
33
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
34
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
35
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
36
+ * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
37
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
38
+ * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
39
+ *
40
+ */
41
+
42
+ #include <iostream>
43
+
44
+ namespace Gecode {
45
+
46
+ namespace Set {
47
+
48
+ /**
49
+ * \defgroup TaskActorSetView Set views
50
+ *
51
+ * Set propagators and branchings compute with set views.
52
+ * Set views provide views on set variable implementations,
53
+ * set constants, and integer variable implementations.
54
+ * \ingroup TaskActorSet
55
+ */
56
+
57
+ /**
58
+ * \brief %Set view for set variables
59
+ * \ingroup TaskActorSetView
60
+ */
61
+
62
+ class SetView : public VarViewBase<SetVarImp> {
63
+ protected:
64
+ using VarViewBase<SetVarImp>::varimp;
65
+ public:
66
+ /// \name Constructors and initialization
67
+ //@{
68
+ /// Default constructor
69
+ SetView(void);
70
+ /// Initialize from set variable \a x
71
+ SetView(const SetVar& x);
72
+ /// Initialize from set variable \a x
73
+ SetView(SetVarImp* x);
74
+ /// Initialize from specification
75
+ SetView(Space* home, const Reflection::VarMap& vars,
76
+ Reflection::Arg* arg);
77
+ //@}
78
+
79
+ /// \name Value access
80
+ //@{
81
+
82
+ /// Return minimum cardinality
83
+ unsigned int cardMin(void) const;
84
+ /// Return maximum cardinality
85
+ unsigned int cardMax(void) const;
86
+ /// Return minimum of the least upper bound
87
+ int lubMin(void) const;
88
+ /// Return maximum of the least upper bound
89
+ int lubMax(void) const;
90
+ /// Return n-th smallest element of the least upper bound
91
+ int lubMinN(int n) const;
92
+ /// Return minimum of the greatest lower bound
93
+ int glbMin(void) const;
94
+ /// Return maximum of the greatest lower bound
95
+ int glbMax(void) const;
96
+
97
+ /// Return the number of elements in the greatest lower bound
98
+ unsigned int glbSize(void) const;
99
+ /// Return the number of elements in the least upper bound
100
+ unsigned int lubSize(void) const;
101
+ /// Return the number of unknown elements
102
+ unsigned int unknownSize(void) const;
103
+ //@}
104
+
105
+ /// \name Domain tests
106
+ //@{
107
+ /// Test whether view is assigned
108
+ bool assigned(void) const;
109
+ /// Test whether \a i is in the greatest lower bound
110
+ bool contains(int i) const;
111
+ /// Test whether \a i is not in the least upper bound
112
+ bool notContains(int i) const;
113
+ //@}
114
+
115
+
116
+ /// \name Domain update by value
117
+ //@{
118
+ /// Restrict cardinality to be greater than or equal to \a m
119
+ ModEvent cardMin(Space* home, unsigned int m);
120
+ /// Restrict cardinality to be less than or equal to \a m
121
+ ModEvent cardMax(Space* home, unsigned int m);
122
+ /**
123
+ * \brief Update greatest lower bound to include all elements
124
+ * between and including \a i and \a j
125
+ */
126
+ ModEvent include(Space* home,int i,int j);
127
+ /**
128
+ * \brief Restrict least upper bound to not contain all elements
129
+ * between and including \a i and \a j
130
+ */
131
+ ModEvent exclude(Space* home,int i,int j);
132
+ /// Update greatest lower bound to contain \a i
133
+ ModEvent include(Space* home,int i);
134
+ /// Restrict least upper bound to not contain \a i
135
+ ModEvent exclude(Space* home,int i);
136
+ /**
137
+ * \brief Update least upper bound to contain at most all elements
138
+ * between and including \a i and \a j
139
+ */
140
+ ModEvent intersect(Space* home,int i,int j);
141
+ /// Update least upper bound to contain at most the element \a i
142
+ ModEvent intersect(Space* home,int i);
143
+ //@}
144
+
145
+ /// \name Domain update by range iterator
146
+ //@{
147
+
148
+ /// Remove range sequence described by \a i from least upper bound
149
+ template <class I> ModEvent excludeI(Space* home, I& i);
150
+ /// Include range sequence described by \a i in greatest lower bound
151
+ template <class I> ModEvent includeI(Space* home, I& i);
152
+ /// Intersect least upper bound with range sequence described by \a i
153
+ template <class I> ModEvent intersectI(Space* home, I& iter);
154
+ //@}
155
+
156
+ /// \name Cloning
157
+ //@{
158
+ /// Update this view to be a clone of view \a x
159
+ void update(Space* home, bool share, SetView& x);
160
+ //@}
161
+
162
+ /// \name Reflection
163
+ //@{
164
+ /// Return specification for this view, using variable map \a m
165
+ Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
166
+ static Support::Symbol type(void);
167
+ //@}
168
+
169
+ /// \name Delta information for advisors
170
+ //@{
171
+ /// Return modification event
172
+ static ModEvent modevent(const Delta* d);
173
+ /// Return minimum value just pruned from glb
174
+ int glbMin(const Delta* d) const;
175
+ /// Return maximum value just pruned from glb
176
+ int glbMax(const Delta* d) const;
177
+ /// Test whether arbitrary values got pruned from glb
178
+ bool glbAny(const Delta* d) const;
179
+ /// Return minimum value just pruned from lub
180
+ int lubMin(const Delta* d) const;
181
+ /// Return maximum value just pruned from lub
182
+ int lubMax(const Delta* d) const;
183
+ /// Test whether arbitrary values got pruned from lub
184
+ bool lubAny(const Delta* d) const;
185
+ //@}
186
+
187
+ };
188
+
189
+ }
190
+
191
+ /**
192
+ * \brief Traits class for views and variable implementations
193
+ *
194
+ * This class specializes the ViewVarImpTraits for SetView.
195
+ * \ingroup TaskActorSetView
196
+ */
197
+ template<>
198
+ class ViewVarImpTraits<Set::SetView> {
199
+ public:
200
+ /// The variable type of a SetView
201
+ typedef Set::SetVarImp VarImp;
202
+ };
203
+
204
+
205
+ /**
206
+ * \brief Traits class mapping variables to views
207
+ *
208
+ * This class specializes the VarViewTraits for set variables.
209
+ */
210
+ template<>
211
+ class VarViewTraits<SetVar> {
212
+ public:
213
+ /// The variable type of an IntView
214
+ typedef Set::SetView View;
215
+ };
216
+
217
+ // Forward declarations for friends
218
+ namespace Set { class ConstantView; }
219
+ bool same(const Set::ConstantView&, const Set::ConstantView&);
220
+ bool before(const Set::ConstantView&, const Set::ConstantView&);
221
+
222
+ namespace Set {
223
+
224
+ /**
225
+ * \brief Constant view
226
+ *
227
+ * A constant set view \f$x\f$ for a set \f$s\f$ provides operations such
228
+ * that \f$x\f$ behaves like \f$s\f$.
229
+ * \ingroup TaskActorSetView
230
+ */
231
+ class ConstantView : public ConstViewBase {
232
+ friend class LubRanges<ConstantView>;
233
+ friend class GlbRanges<ConstantView>;
234
+ friend bool Gecode::same(const Gecode::Set::ConstantView&,
235
+ const Gecode::Set::ConstantView&);
236
+ friend bool Gecode::before(const Gecode::Set::ConstantView&,
237
+ const Gecode::Set::ConstantView&);
238
+ private:
239
+ int *ranges;
240
+ unsigned int size;
241
+ unsigned int domSize;
242
+ /// Initialize with constant \a s
243
+ void init(Space* home, const IntSet& s);
244
+ public:
245
+ /// \name Constructors and initialization
246
+ //@{
247
+ /// Default constructor
248
+ ConstantView(void);
249
+ /// Construct with \a s as the domain
250
+ ConstantView(Space* home, const IntSet& s);
251
+ /// Initialize from specification
252
+ ConstantView(Space* home, const Reflection::VarMap& vars,
253
+ Reflection::Arg* arg);
254
+ //@}
255
+
256
+ /// \name Value access
257
+ //@{
258
+ /// Return minimum cardinality
259
+ unsigned int cardMin(void) const;
260
+ /// Return maximum cardinality
261
+ unsigned int cardMax(void) const;
262
+ /// Return minimum of the least upper bound
263
+ int lubMin(void) const;
264
+ /// Return maximum of the least upper bound
265
+ int lubMax(void) const;
266
+ /// Return n-th smallest element of the least upper bound
267
+ int lubMinN(int n) const;
268
+ /// Return minimum of the greatest lower bound
269
+ int glbMin(void) const;
270
+ /// Return maximum of the greatest lower bound
271
+ int glbMax(void) const;
272
+
273
+ /// Return the number of elements in the greatest lower bound
274
+ unsigned int glbSize(void) const;
275
+ /// Return the number of elements in the least upper bound
276
+ unsigned int lubSize(void) const;
277
+ /// Return the number of unknown elements
278
+ unsigned int unknownSize(void) const;
279
+ //@}
280
+
281
+ /// \name Domain tests
282
+ //@{
283
+ /// Test whether view is assigned
284
+ bool assigned(void) const;
285
+ /// Test whether \a i is in the greatest lower bound
286
+ bool contains(int i) const;
287
+ /// Test whether \a i is not in the least upper bound
288
+ bool notContains(int i) const;
289
+ //@}
290
+
291
+
292
+ /// \name Domain update by value
293
+ //@{
294
+ /// Restrict cardinality to be greater than or equal to \a m
295
+ ModEvent cardMin(Space* home, unsigned int m);
296
+ /// Restrict cardinality to be less than or equal to \a m
297
+ ModEvent cardMax(Space* home, unsigned int m);
298
+ /**
299
+ * \brief Update greatest lower bound to include all elements
300
+ * between and including \a i and \a j
301
+ */
302
+ ModEvent include(Space* home,int i,int j);
303
+ /**
304
+ * \brief Restrict least upper bound to not contain all elements
305
+ * between and including \a i and \a j
306
+ */
307
+ ModEvent exclude(Space* home,int i,int j);
308
+ /// Update greatest lower bound to contain \a i
309
+ ModEvent include(Space* home,int i);
310
+ /// Restrict least upper bound to not contain \a i
311
+ ModEvent exclude(Space* home,int i);
312
+ /**
313
+ * \brief Update least upper bound to contain at most all elements
314
+ * between and including \a i and \a j
315
+ */
316
+ ModEvent intersect(Space* home,int i,int j);
317
+ /// Update least upper bound to contain at most the element \a i
318
+ ModEvent intersect(Space* home,int i);
319
+ //@}
320
+
321
+ /// \name Domain update by range iterator
322
+ //@{
323
+
324
+ /// Remove range sequence described by \a i from least upper bound
325
+ template <class I> ModEvent excludeI(Space* home, I& i);
326
+ /// Include range sequence described by \a i in greatest lower bound
327
+ template <class I> ModEvent includeI(Space* home, I& i);
328
+ /// Intersect least upper bound with range sequence described by \a i
329
+ template <class I> ModEvent intersectI(Space* home, I& iter);
330
+ //@}
331
+
332
+ /// \name View-dependent propagator support
333
+ //@{
334
+ /// Schedule propagator \a p with modification event \a me
335
+ static void schedule(Space* home, Propagator* p, ModEvent me);
336
+ /// Return modification event for view type in \a med
337
+ static ModEvent me(ModEventDelta med);
338
+ /// Translate modification event \a me to modification event delta for view
339
+ static ModEventDelta med(ModEvent);
340
+ //@}
341
+
342
+ /// \name Dependencies
343
+ //@{
344
+ /**
345
+ * \brief Subscribe propagator \a p with propagation condition \a pc to view
346
+ *
347
+ * In case \a process is false, the propagator is just subscribed but
348
+ * not processed for execution (this must be used when creating
349
+ * subscriptions during propagation).
350
+ */
351
+ void subscribe(Space* home, Propagator* p, PropCond pc, bool process=true);
352
+ /// Cancel subscription of propagator \a p with propagation condition \a pc to view
353
+ void cancel(Space* home, Propagator* p, PropCond pc);
354
+ /// Subscribe advisor \a a to view
355
+ void subscribe(Space* home, Advisor* a);
356
+ /// Cancel subscription of advisor \a a
357
+ void cancel(Space* home, Advisor* a);
358
+ //@}
359
+
360
+ /// \name Cloning
361
+ //@{
362
+ /// Update this view to be a clone of view \a x
363
+ void update(Space* home, bool share, ConstantView& x);
364
+ //@}
365
+
366
+ /// \name Reflection
367
+ //@{
368
+ /// Return specification for this view, using variable map \a m
369
+ Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
370
+ static Support::Symbol type(void);
371
+ //@}
372
+
373
+ /// \name Delta information for advisors
374
+ //@{
375
+ /// Return modification event
376
+ static ModEvent modevent(const Delta* d);
377
+ /// Return minimum value just pruned from glb
378
+ int glbMin(const Delta* d) const;
379
+ /// Return maximum value just pruned from glb
380
+ int glbMax(const Delta* d) const;
381
+ /// Test whether arbitrary values got pruned from glb
382
+ bool glbAny(const Delta* d) const;
383
+ /// Return minimum value just pruned from lub
384
+ int lubMin(const Delta* d) const;
385
+ /// Return maximum value just pruned from lub
386
+ int lubMax(const Delta* d) const;
387
+ /// Test whether arbitrary values got pruned from lub
388
+ bool lubAny(const Delta* d) const;
389
+ //@}
390
+
391
+ };
392
+
393
+ }
394
+
395
+ /** \name View comparison
396
+ * \relates Gecode::Set::ConstantView
397
+ */
398
+ //@{
399
+ /// Test whether views \a x and \a y are the same
400
+ bool same(const Set::ConstantView& x, const Set::ConstantView& y);
401
+ /// Test whether view \a x comes before \a y (arbitrary order)
402
+ bool before(const Set::ConstantView& x, const Set::ConstantView& y);
403
+ //@}
404
+
405
+ /**
406
+ * \brief Traits class for views and variable implementations
407
+ *
408
+ * This class specializes the ViewVarImpTraits for ConstantView.
409
+ * \ingroup TaskActorSetView
410
+ */
411
+ template<>
412
+ class ViewVarImpTraits<Set::ConstantView> {
413
+ public:
414
+ /// The variable type of a ConstantView
415
+ typedef VarImpBase VarImp;
416
+ };
417
+
418
+ namespace Set {
419
+
420
+ /**
421
+ * \brief Constant view for the empty set
422
+ *
423
+ * A constant set view \f$x\f$ for the empty set provides operations such
424
+ * that \f$x\f$ behaves like the empty set.
425
+ * \ingroup TaskActorSetView
426
+ */
427
+
428
+ class EmptyView : public ConstViewBase {
429
+ public:
430
+ /// \name Constructors and initialization
431
+ //@{
432
+ /// Default constructor
433
+ EmptyView(void);
434
+ /// Initialize from specification
435
+ EmptyView(Space* home, const Reflection::VarMap& vars,
436
+ Reflection::Arg* arg);
437
+ //@}
438
+
439
+ /// \name Value access
440
+ //@{
441
+
442
+ /// Return minimum cardinality
443
+ unsigned int cardMin(void) const;
444
+ /// Return maximum cardinality
445
+ unsigned int cardMax(void) const;
446
+ /// Return minimum of the least upper bound
447
+ int lubMin(void) const;
448
+ /// Return maximum of the least upper bound
449
+ int lubMax(void) const;
450
+ /// Return n-th smallest element of the least upper bound
451
+ int lubMinN(int n) const;
452
+ /// Return minimum of the greatest lower bound
453
+ int glbMin(void) const;
454
+ /// Return maximum of the greatest lower bound
455
+ int glbMax(void) const;
456
+
457
+ /// Return the number of elements in the greatest lower bound
458
+ unsigned int glbSize(void) const;
459
+ /// Return the number of elements in the least upper bound
460
+ unsigned int lubSize(void) const;
461
+ /// Return the number of unknown elements
462
+ unsigned int unknownSize(void) const;
463
+ //@}
464
+
465
+ /// \name Domain tests
466
+ //@{
467
+ /// Test whether view is assigned
468
+ bool assigned(void) const;
469
+ /// Test whether \a i is in the greatest lower bound
470
+ bool contains(int i) const;
471
+ /// Test whether \a i is not in the least upper bound
472
+ bool notContains(int i) const;
473
+ //@}
474
+
475
+
476
+ /// \name Domain update by value
477
+ //@{
478
+ /// Restrict cardinality to be greater than or equal to \a m
479
+ ModEvent cardMin(Space* home, unsigned int m);
480
+ /// Restrict cardinality to be less than or equal to \a m
481
+ ModEvent cardMax(Space* home, unsigned int m);
482
+ /**
483
+ * \brief Update greatest lower bound to include all elements
484
+ * between and including \a i and \a j
485
+ */
486
+ ModEvent include(Space* home,int i,int j);
487
+ /**
488
+ * \brief Restrict least upper bound to not contain all elements
489
+ * between and including \a i and \a j
490
+ */
491
+ ModEvent exclude(Space* home,int i,int j);
492
+ /// Update greatest lower bound to contain \a i
493
+ ModEvent include(Space* home,int i);
494
+ /// Restrict least upper bound to not contain \a i
495
+ ModEvent exclude(Space* home,int i);
496
+ /**
497
+ * \brief Update least upper bound to contain at most all elements
498
+ * between and including \a i and \a j
499
+ */
500
+ ModEvent intersect(Space* home,int i,int j);
501
+ /// Update least upper bound to contain at most the element \a i
502
+ ModEvent intersect(Space* home,int i);
503
+ //@}
504
+
505
+ /// \name Domain update by range iterator
506
+ //@{
507
+
508
+ /// Remove range sequence described by \a i from least upper bound
509
+ template <class I> ModEvent excludeI(Space* home, I& i);
510
+ /// Include range sequence described by \a i in greatest lower bound
511
+ template <class I> ModEvent includeI(Space* home, I& i);
512
+ /// Intersect least upper bound with range sequence described by \a i
513
+ template <class I> ModEvent intersectI(Space* home, I& iter);
514
+ //@}
515
+
516
+ /// \name View-dependent propagator support
517
+ //@{
518
+ /// Schedule propagator \a p with modification event \a me
519
+ static void schedule(Space* home, Propagator* p, ModEvent me);
520
+ /// Return modification event for view type in \a med
521
+ static ModEvent me(ModEventDelta med);
522
+ /// Translate modification event \a me to modification event delta for view
523
+ static ModEventDelta med(ModEvent);
524
+ //@}
525
+
526
+ /// \name Dependencies
527
+ //@{
528
+ /**
529
+ * \brief Subscribe propagator \a p with propagation condition \a pc to view
530
+ *
531
+ * In case \a process is false, the propagator is just subscribed but
532
+ * not processed for execution (this must be used when creating
533
+ * subscriptions during propagation).
534
+ */
535
+ void subscribe(Space* home, Propagator* p, PropCond pc, bool process=true);
536
+ /// Cancel subscription of propagator \a p with propagation condition \a pc to view
537
+ void cancel(Space* home, Propagator* p, PropCond pc);
538
+ /// Subscribe advisor \a a to view
539
+ void subscribe(Space* home, Advisor* a);
540
+ /// Cancel subscription of advisor \a a
541
+ void cancel(Space* home, Advisor* a);
542
+ //@}
543
+
544
+ /// \name Cloning
545
+ //@{
546
+ /// Update this view to be a clone of view \a x
547
+ void update(Space* home, bool share, EmptyView& x);
548
+ //@}
549
+
550
+ /// \name Reflection
551
+ //@{
552
+ /// Return specification for this view, using variable map \a m
553
+ Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
554
+ static Support::Symbol type(void);
555
+ //@}
556
+
557
+ /// \name Delta information for advisors
558
+ //@{
559
+ /// Return modification event
560
+ static ModEvent modevent(const Delta* d);
561
+ /// Return minimum value just pruned from glb
562
+ int glbMin(const Delta* d) const;
563
+ /// Return maximum value just pruned from glb
564
+ int glbMax(const Delta* d) const;
565
+ /// Test whether arbitrary values got pruned from glb
566
+ bool glbAny(const Delta* d) const;
567
+ /// Return minimum value just pruned from lub
568
+ int lubMin(const Delta* d) const;
569
+ /// Return maximum value just pruned from lub
570
+ int lubMax(const Delta* d) const;
571
+ /// Test whether arbitrary values got pruned from lub
572
+ bool lubAny(const Delta* d) const;
573
+ //@}
574
+
575
+ };
576
+
577
+ }
578
+
579
+ /** \name View comparison
580
+ * \relates Gecode::Set::EmptyView
581
+ */
582
+ //@{
583
+ /// Test whether views \a x and \a y are the same
584
+ bool same(const Set::EmptyView& x, const Set::EmptyView& y);
585
+ /// Test whether view \a x comes before \a y (arbitrary order)
586
+ bool before(const Set::EmptyView& x, const Set::EmptyView& y);
587
+ //@}
588
+
589
+ /**
590
+ * \brief Traits class for views and variable implementations
591
+ *
592
+ * This class specializes the ViewVarImpTraits for EmptyView.
593
+ * \ingroup TaskActorSetView
594
+ */
595
+ template<>
596
+ class ViewVarImpTraits<Set::EmptyView> {
597
+ public:
598
+ /// The variable type of an EmptyView
599
+ typedef VarImpBase VarImp;
600
+ };
601
+
602
+ namespace Set {
603
+
604
+
605
+ /**
606
+ * \brief Constant view for the universe
607
+ *
608
+ * A constant set view \f$x\f$ for the universe provides operations such
609
+ * that \f$x\f$ behaves like the universe.
610
+ * \ingroup TaskActorSetView
611
+ */
612
+
613
+ class UniverseView : public ConstViewBase {
614
+ public:
615
+ /// \name Constructors and initialization
616
+ //@{
617
+ /// Default constructor
618
+ UniverseView(void);
619
+ /// Initialize from specification
620
+ UniverseView(Space* home, const Reflection::VarMap& vars,
621
+ Reflection::Arg* arg);
622
+ //@}
623
+
624
+ /// \name Value access
625
+ //@{
626
+
627
+ /// Return minimum cardinality
628
+ unsigned int cardMin(void) const;
629
+ /// Return maximum cardinality
630
+ unsigned int cardMax(void) const;
631
+ /// Return minimum of the least upper bound
632
+ int lubMin(void) const;
633
+ /// Return maximum of the least upper bound
634
+ int lubMax(void) const;
635
+ /// Return n-th smallest element of the least upper bound
636
+ int lubMinN(int n) const;
637
+ /// Return minimum of the greatest lower bound
638
+ int glbMin(void) const;
639
+ /// Return maximum of the greatest lower bound
640
+ int glbMax(void) const;
641
+
642
+ /// Return the number of elements in the greatest lower bound
643
+ unsigned int glbSize(void) const;
644
+ /// Return the number of elements in the least upper bound
645
+ unsigned int lubSize(void) const;
646
+ /// Return the number of unknown elements
647
+ unsigned int unknownSize(void) const;
648
+ //@}
649
+
650
+ /// \name Domain tests
651
+ //@{
652
+ /// Test whether view is assigned
653
+ bool assigned(void) const;
654
+ /// Test whether \a i is in the greatest lower bound
655
+ bool contains(int i) const;
656
+ /// Test whether \a i is not in the least upper bound
657
+ bool notContains(int i) const;
658
+ //@}
659
+
660
+
661
+ /// \name Domain update by value
662
+ //@{
663
+ /// Restrict cardinality to be greater than or equal to \a m
664
+ ModEvent cardMin(Space* home, unsigned int m);
665
+ /// Restrict cardinality to be less than or equal to \a m
666
+ ModEvent cardMax(Space* home, unsigned int m);
667
+ /**
668
+ * \brief Update greatest lower bound to include all elements
669
+ * between and including \a i and \a j
670
+ */
671
+ ModEvent include(Space* home,int i,int j);
672
+ /**
673
+ * \brief Restrict least upper bound to not contain all elements
674
+ * between and including \a i and \a j
675
+ */
676
+ ModEvent exclude(Space* home,int i,int j);
677
+ /// Update greatest lower bound to contain \a i
678
+ ModEvent include(Space* home,int i);
679
+ /// Restrict least upper bound to not contain \a i
680
+ ModEvent exclude(Space* home,int i);
681
+ /**
682
+ * \brief Update least upper bound to contain at most all elements
683
+ * between and including \a i and \a j
684
+ */
685
+ ModEvent intersect(Space* home,int i,int j);
686
+ /// Update least upper bound to contain at most the element \a i
687
+ ModEvent intersect(Space* home,int i);
688
+ //@}
689
+
690
+ /// \name Domain update by range iterator
691
+ //@{
692
+
693
+ /// Remove range sequence described by \a i from least upper bound
694
+ template <class I> ModEvent excludeI(Space* home, I& i);
695
+ /// Include range sequence described by \a i in greatest lower bound
696
+ template <class I> ModEvent includeI(Space* home, I& i);
697
+ /// Intersect least upper bound with range sequence described by \a i
698
+ template <class I> ModEvent intersectI(Space* home, I& iter);
699
+ //@}
700
+
701
+ /// \name View-dependent propagator support
702
+ //@{
703
+ /// Schedule propagator \a p with modification event \a me
704
+ static void schedule(Space* home, Propagator* p, ModEvent me);
705
+ /// Return modification event for view type in \a med
706
+ static ModEvent me(ModEventDelta med);
707
+ /// Translate modification event \a me to modification event delta for view
708
+ static ModEventDelta med(ModEvent);
709
+ //@}
710
+
711
+ /// \name Dependencies
712
+ //@{
713
+ /**
714
+ * \brief Subscribe propagator \a p with propagation condition \a pc to view
715
+ *
716
+ * In case \a process is false, the propagator is just subscribed but
717
+ * not processed for execution (this must be used when creating
718
+ * subscriptions during propagation).
719
+ */
720
+ void subscribe(Space* home, Propagator* p, PropCond pc, bool process=true);
721
+ /// Cancel subscription of propagator \a p with propagation condition \a pc to view
722
+ void cancel(Space* home, Propagator* p, PropCond pc);
723
+ /// Subscribe advisor \a a to view
724
+ void subscribe(Space* home, Advisor* a);
725
+ /// Cancel subscription of advisor \a a
726
+ void cancel(Space* home, Advisor* a);
727
+ //@}
728
+
729
+ /// \name Cloning
730
+ //@{
731
+ /// Update this view to be a clone of view \a x
732
+ void update(Space* home, bool share, UniverseView& x);
733
+ //@}
734
+
735
+ /// \name Reflection
736
+ //@{
737
+ /// Return specification for this view, using variable map \a m
738
+ Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
739
+ static Support::Symbol type(void);
740
+ //@}
741
+
742
+ /// \name Delta information for advisors
743
+ //@{
744
+ /// Return modification event
745
+ static ModEvent modevent(const Delta* d);
746
+ /// Return minimum value just pruned from glb
747
+ int glbMin(const Delta* d) const;
748
+ /// Return maximum value just pruned from glb
749
+ int glbMax(const Delta* d) const;
750
+ /// Test whether arbitrary values got pruned from glb
751
+ bool glbAny(const Delta* d) const;
752
+ /// Return minimum value just pruned from lub
753
+ int lubMin(const Delta* d) const;
754
+ /// Return maximum value just pruned from lub
755
+ int lubMax(const Delta* d) const;
756
+ /// Test whether arbitrary values got pruned from lub
757
+ bool lubAny(const Delta* d) const;
758
+ //@}
759
+
760
+ };
761
+
762
+ }
763
+
764
+ /** \name View comparison
765
+ * \relates Gecode::Set::UniverseView
766
+ */
767
+ //@{
768
+ /// Test whether views \a x and \a y are the same
769
+ bool same(const Set::UniverseView& x, const Set::UniverseView& y);
770
+ /// Test whether view \a x comes before \a y (arbitrary order)
771
+ bool before(const Set::UniverseView& x, const Set::UniverseView& y);
772
+ //@}
773
+
774
+ /**
775
+ * \brief Traits class for views and variable implementations
776
+ *
777
+ * This class specializes the ViewVarImpTraits for UniverseView.
778
+ * \ingroup TaskActorSetView
779
+ */
780
+ template<>
781
+ class ViewVarImpTraits<Set::UniverseView> {
782
+ public:
783
+ /// The variable type of a UniverseView
784
+ typedef VarImpBase VarImp;
785
+ };
786
+
787
+ namespace Set {
788
+
789
+
790
+
791
+ /**
792
+ * \brief Singleton set view
793
+ *
794
+ * A singleton set view \f$s\f$ for an integer view \f$x\f$ provides
795
+ * operations such that \f$s\f$ behaves like the singleton set \f$\{x\}\f$.
796
+ * \ingroup TaskActorSetView
797
+ */
798
+
799
+ class SingletonView :
800
+ public DerivedViewBase<Gecode::Int::IntView> {
801
+ protected:
802
+ using DerivedViewBase<Gecode::Int::IntView>::view;
803
+
804
+ /// Convert set variable PropCond \a pc to a PropCond for integer variables
805
+ static PropCond pc_settoint(PropCond pc);
806
+ /// Convert integer variable ModEvent \a me to a ModEvent for set variables
807
+ static ModEvent me_inttoset(ModEvent me);
808
+ /// Convert set variable ModEvent \a me to a ModEvent for integer variables
809
+ static ModEvent me_settoint(ModEvent me);
810
+
811
+ public:
812
+ /// \name Constructors and initialization
813
+ //@{
814
+ /// Default constructor
815
+ SingletonView(void);
816
+ /// Initialize with integer view \a x
817
+ SingletonView(Gecode::Int::IntView& x);
818
+ /// Initialize from specification
819
+ SingletonView(Space* home, const Reflection::VarMap& vars,
820
+ Reflection::Arg* arg);
821
+ //@}
822
+
823
+ /// \name Value access
824
+ //@{
825
+
826
+ /// Return minimum cardinality
827
+ unsigned int cardMin(void) const;
828
+ /// Return maximum cardinality
829
+ unsigned int cardMax(void) const;
830
+ /// Return minimum of the least upper bound
831
+ int lubMin(void) const;
832
+ /// Return maximum of the least upper bound
833
+ int lubMax(void) const;
834
+ /// Return n-th smallest element of the least upper bound
835
+ int lubMinN(int n) const;
836
+ /// Return minimum of the greatest lower bound
837
+ int glbMin(void) const;
838
+ /// Return maximum of the greatest lower bound
839
+ int glbMax(void) const;
840
+
841
+ /// Return the number of elements in the greatest lower bound
842
+ unsigned int glbSize(void) const;
843
+ /// Return the number of elements in the least upper bound
844
+ unsigned int lubSize(void) const;
845
+ /// Return the number of unknown elements
846
+ unsigned int unknownSize(void) const;
847
+ //@}
848
+
849
+ /// \name Domain tests
850
+ //@{
851
+ /// Test whether view is assigned
852
+ bool assigned(void) const;
853
+ /// Test whether \a i is in the greatest lower bound
854
+ bool contains(int i) const;
855
+ /// Test whether \a i is not in the least upper bound
856
+ bool notContains(int i) const;
857
+ //@}
858
+
859
+
860
+ /// \name Domain update by value
861
+ //@{
862
+ /// Restrict cardinality to be greater than or equal to \a m
863
+ ModEvent cardMin(Space* home, unsigned int m);
864
+ /// Restrict cardinality to be less than or equal to \a m
865
+ ModEvent cardMax(Space* home, unsigned int m);
866
+ /**
867
+ * \brief Update greatest lower bound to include all elements
868
+ * between and including \a i and \a j
869
+ */
870
+ ModEvent include(Space* home,int i,int j);
871
+ /**
872
+ * \brief Restrict least upper bound to not contain all elements
873
+ * between and including \a i and \a j
874
+ */
875
+ ModEvent exclude(Space* home,int i,int j);
876
+ /// Update greatest lower bound to contain \a i
877
+ ModEvent include(Space* home,int i);
878
+ /// Restrict least upper bound to not contain \a i
879
+ ModEvent exclude(Space* home,int i);
880
+ /**
881
+ * \brief Update least upper bound to contain at most all elements
882
+ * between and including \a i and \a j
883
+ */
884
+ ModEvent intersect(Space* home,int i,int j);
885
+ /// Update least upper bound to contain at most the element \a i
886
+ ModEvent intersect(Space* home,int i);
887
+ //@}
888
+
889
+ /// \name Domain update by range iterator
890
+ //@{
891
+
892
+ /// Remove range sequence described by \a i from least upper bound
893
+ template <class I> ModEvent excludeI(Space* home, I& i);
894
+ /// Include range sequence described by \a i in greatest lower bound
895
+ template <class I> ModEvent includeI(Space* home, I& i);
896
+ /// Intersect least upper bound with range sequence described by \a i
897
+ template <class I> ModEvent intersectI(Space* home, I& iter);
898
+ //@}
899
+
900
+ /// \name View-dependent propagator support
901
+ //@{
902
+ /// Schedule propagator \a p with modification event \a me
903
+ static void schedule(Space* home, Propagator* p, ModEvent me);
904
+ /// Return modification event for view type in \a med
905
+ static ModEvent me(ModEventDelta med);
906
+ /// Translate modification event \a me to modification event delta for view
907
+ static ModEventDelta med(ModEvent);
908
+ //@}
909
+
910
+ /// \name Dependencies
911
+ //@{
912
+ /**
913
+ * \brief Subscribe propagator \a p with propagation condition \a pc to view
914
+ *
915
+ * In case \a process is false, the propagator is just subscribed but
916
+ * not processed for execution (this must be used when creating
917
+ * subscriptions during propagation).
918
+ */
919
+ void subscribe(Space* home, Propagator* p, PropCond pc, bool process=true);
920
+ /// Cancel subscription of propagator \a p with propagation condition \a pc to view
921
+ void cancel(Space* home, Propagator* p, PropCond pc);
922
+ /// Subscribe advisor \a a to view
923
+ void subscribe(Space* home, Advisor* a);
924
+ /// Cancel subscription of advisor \a a
925
+ void cancel(Space* home, Advisor* a);
926
+ //@}
927
+
928
+
929
+ /// \name Cloning
930
+ //@{
931
+ /// Update this view to be a clone of view \a x
932
+ void update(Space* home, bool share, SingletonView& x);
933
+ //@}
934
+
935
+ /// \name Reflection
936
+ //@{
937
+ /// Return specification for this view, using variable map \a m
938
+ Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
939
+ static Support::Symbol type(void);
940
+ //@}
941
+
942
+ /// \name Delta information for advisors
943
+ //@{
944
+ /// Return modification event
945
+ static ModEvent modevent(const Delta* d);
946
+ /// Return minimum value just pruned from glb
947
+ int glbMin(const Delta* d) const;
948
+ /// Return maximum value just pruned from glb
949
+ int glbMax(const Delta* d) const;
950
+ /// Test whether arbitrary values got pruned from glb
951
+ bool glbAny(const Delta* d) const;
952
+ /// Return minimum value just pruned from lub
953
+ int lubMin(const Delta* d) const;
954
+ /// Return maximum value just pruned from lub
955
+ int lubMax(const Delta* d) const;
956
+ /// Test whether arbitrary values got pruned from lub
957
+ bool lubAny(const Delta* d) const;
958
+ //@}
959
+
960
+ };
961
+
962
+ }
963
+
964
+ /** \name View comparison
965
+ * \relates Gecode::Set::SingletonView
966
+ */
967
+ //@{
968
+ /// Test whether views \a x and \a y are the same
969
+ bool same(const Set::SingletonView& x, const Set::SingletonView& y);
970
+ /// Test whether view \a x comes before \a y (arbitrary order)
971
+ bool before(const Set::SingletonView& x, const Set::SingletonView& y);
972
+ //@}
973
+
974
+ /**
975
+ * \brief Traits class for views and variable implementations
976
+ *
977
+ * This class specializes the ViewVarImpTraits for SingletonView.
978
+ * \ingroup TaskActorSetView
979
+ */
980
+ template<>
981
+ class ViewVarImpTraits<Set::SingletonView> {
982
+ public:
983
+ /// The variable type of a SingletonView
984
+ typedef Int::IntVarImp VarImp;
985
+ };
986
+
987
+ namespace Set {
988
+
989
+
990
+ /**
991
+ * \brief Complement set view
992
+ *
993
+ * A complement set view \f$s\f$ for a set view \f$t\f$ provides
994
+ * operations such that \f$s\f$ behaves like the complement of \f$\{t\}\f$.
995
+ * The complement is defined in terms of the set universe.
996
+ * \ingroup TaskActorSetView
997
+ */
998
+
999
+ template <class View>
1000
+ class ComplementView
1001
+ : public DerivedViewBase<View> {
1002
+ protected:
1003
+ using DerivedViewBase<View>::view;
1004
+
1005
+ public:
1006
+ /// Negate the propagation condition \a pc
1007
+ static PropCond pc_negateset(PropCond pc);
1008
+ /// Negate the modification event \a me
1009
+ static ModEvent me_negateset(ModEvent me);
1010
+
1011
+ /// \name Constructors and initialization
1012
+ //@{
1013
+ /// Default constructor
1014
+ ComplementView(void);
1015
+ /// Initialize with set view x
1016
+ ComplementView(View& x);
1017
+ /// Initialize from specification
1018
+ ComplementView(Space* home, const Reflection::VarMap& vars,
1019
+ Reflection::Arg* arg);
1020
+ //@}
1021
+
1022
+ /// \name Value access
1023
+ //@{
1024
+
1025
+ /// Return minimum cardinality
1026
+ unsigned int cardMin(void) const;
1027
+ /// Return maximum cardinality
1028
+ unsigned int cardMax(void) const;
1029
+ /// Return minimum of the least upper bound
1030
+ int lubMin(void) const;
1031
+ /// Return maximum of the least upper bound
1032
+ int lubMax(void) const;
1033
+ /// Return n-th smallest element of the least upper bound
1034
+ int lubMinN(int n) const;
1035
+ /// Return minimum of the greatest lower bound
1036
+ int glbMin(void) const;
1037
+ /// Return maximum of the greatest lower bound
1038
+ int glbMax(void) const;
1039
+
1040
+ /// Return the number of elements in the greatest lower bound
1041
+ unsigned int glbSize(void) const;
1042
+ /// Return the number of elements in the least upper bound
1043
+ unsigned int lubSize(void) const;
1044
+ /// Return the number of unknown elements
1045
+ unsigned int unknownSize(void) const;
1046
+ //@}
1047
+
1048
+ /// \name Domain tests
1049
+ //@{
1050
+ /// Test whether view is assigned
1051
+ bool assigned(void) const;
1052
+ /// Test whether \a i is in the greatest lower bound
1053
+ bool contains(int i) const;
1054
+ /// Test whether \a i is not in the least upper bound
1055
+ bool notContains(int i) const;
1056
+ //@}
1057
+
1058
+
1059
+ /// \name Domain update by value
1060
+ //@{
1061
+ /// Restrict cardinality to be greater than or equal to \a m
1062
+ ModEvent cardMin(Space* home, unsigned int m);
1063
+ /// Restrict cardinality to be less than or equal to \a m
1064
+ ModEvent cardMax(Space* home, unsigned int m);
1065
+ /**
1066
+ * \brief Update greatest lower bound to include all elements
1067
+ * between and including \a i and \a j
1068
+ */
1069
+ ModEvent include(Space* home,int i,int j);
1070
+ /**
1071
+ * \brief Restrict least upper bound to not contain all elements
1072
+ * between and including \a i and \a j
1073
+ */
1074
+ ModEvent exclude(Space* home,int i,int j);
1075
+ /// Update greatest lower bound to contain \a i
1076
+ ModEvent include(Space* home,int i);
1077
+ /// Restrict least upper bound to not contain \a i
1078
+ ModEvent exclude(Space* home,int i);
1079
+ /**
1080
+ * \brief Update least upper bound to contain at most all elements
1081
+ * between and including \a i and \a j
1082
+ */
1083
+ ModEvent intersect(Space* home,int i,int j);
1084
+ /// Update least upper bound to contain at most the element \a i
1085
+ ModEvent intersect(Space* home,int i);
1086
+ //@}
1087
+
1088
+ /// \name Domain update by range iterator
1089
+ //@{
1090
+
1091
+ /// Remove range sequence described by \a i from least upper bound
1092
+ template <class I> ModEvent excludeI(Space* home, I& i);
1093
+ /// Include range sequence described by \a i in greatest lower bound
1094
+ template <class I> ModEvent includeI(Space* home, I& i);
1095
+ /// Intersect least upper bound with range sequence described by \a i
1096
+ template <class I> ModEvent intersectI(Space* home, I& iter);
1097
+ //@}
1098
+
1099
+ /// \name View-dependent propagator support
1100
+ //@{
1101
+ /// Schedule propagator \a p with modification event \a me
1102
+ static void schedule(Space* home, Propagator* p, ModEvent me);
1103
+ /// Return modification event for view type in \a med
1104
+ static ModEvent me(ModEventDelta med);
1105
+ /// Translate modification event \a me to modification event delta for view
1106
+ static ModEventDelta med(ModEvent);
1107
+ //@}
1108
+
1109
+ /// \name Dependencies
1110
+ //@{
1111
+ /**
1112
+ * \brief Subscribe propagator \a p with propagation condition \a pc to view
1113
+ *
1114
+ * In case \a process is false, the propagator is just subscribed but
1115
+ * not processed for execution (this must be used when creating
1116
+ * subscriptions during propagation).
1117
+ */
1118
+ void subscribe(Space* home, Propagator* p, PropCond pc, bool process=true);
1119
+ /// Cancel subscription of propagator \a p with propagation condition \a pc to view
1120
+ void cancel(Space* home, Propagator* p, PropCond pc);
1121
+ /// Subscribe advisor \a a to view
1122
+ void subscribe(Space* home, Advisor* a);
1123
+ /// Cancel subscription of advisor \a a
1124
+ void cancel(Space* home, Advisor* a);
1125
+ //@}
1126
+
1127
+
1128
+ /// \name Cloning
1129
+ //@{
1130
+ /// Update this view to be a clone of view \a x
1131
+ void update(Space* home, bool share, ComplementView& x);
1132
+ //@}
1133
+
1134
+ /// \name Reflection
1135
+ //@{
1136
+ /// Return specification for this view, using variable map \a m
1137
+ Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
1138
+ static Support::Symbol type(void);
1139
+ //@}
1140
+
1141
+ /// \name Delta information for advisors
1142
+ //@{
1143
+ /// Return modification event
1144
+ static ModEvent modevent(const Delta* d);
1145
+ /// Return minimum value just pruned from glb
1146
+ int glbMin(const Delta* d) const;
1147
+ /// Return maximum value just pruned from glb
1148
+ int glbMax(const Delta* d) const;
1149
+ /// Test whether arbitrary values got pruned from glb
1150
+ bool glbAny(const Delta* d) const;
1151
+ /// Return minimum value just pruned from lub
1152
+ int lubMin(const Delta* d) const;
1153
+ /// Return maximum value just pruned from lub
1154
+ int lubMax(const Delta* d) const;
1155
+ /// Test whether arbitrary values got pruned from lub
1156
+ bool lubAny(const Delta* d) const;
1157
+ //@}
1158
+
1159
+ };
1160
+
1161
+ }
1162
+
1163
+ /** \name View comparison
1164
+ * \relates Gecode::Set::ComplementView
1165
+ */
1166
+ //@{
1167
+ /// Test whether views \a x and \a y are the same
1168
+ template <class View>
1169
+ bool same(const Set::ComplementView<View>& x,
1170
+ const Set::ComplementView<View>& y);
1171
+ /// Test whether view \a x comes before \a y (arbitrary order)
1172
+ template <class View>
1173
+ bool before(const Set::ComplementView<View>& x,
1174
+ const Set::ComplementView<View>& y);
1175
+ //@}
1176
+
1177
+
1178
+ /**
1179
+ * \brief Traits class for views and variable implementations
1180
+ *
1181
+ * This class specializes the ViewVarImpTraits for ComplementView.
1182
+ * \ingroup TaskActorSetView
1183
+ */
1184
+ template <class View>
1185
+ class ViewVarImpTraits<Set::ComplementView<View> > {
1186
+ public:
1187
+ /// The variable type of a ComplementView
1188
+ typedef typename ViewVarImpTraits<View>::VarImp VarImp;
1189
+ };
1190
+
1191
+
1192
+ namespace Set {
1193
+
1194
+
1195
+ /**
1196
+ * \brief Offset set view
1197
+ *
1198
+ * An offset set view \f$s\f$ for a set view \f$t\f$ provides
1199
+ * operations such that \f$s\f$ behaves like \f$\{i+k\ |\ i\in t\}\f$.
1200
+ * \ingroup TaskActorSetView
1201
+ */
1202
+
1203
+ template <class View>
1204
+ class OffsetSetView : public DerivedViewBase<View> {
1205
+ protected:
1206
+ using DerivedViewBase<View>::view;
1207
+ int k;
1208
+ public:
1209
+ /// \name Constructors and initialization
1210
+ //@{
1211
+ /// Default constructor
1212
+ OffsetSetView(void);
1213
+ /// Initialize with set view \a x and offset \a k0
1214
+ OffsetSetView(View& x, int k0);
1215
+ /// Initialize from specification
1216
+ OffsetSetView(Space* home, const Reflection::VarMap& vars,
1217
+ Reflection::Arg* arg);
1218
+ //@}
1219
+
1220
+ /// \name Value access
1221
+ //@{
1222
+
1223
+ /// Return minimum cardinality
1224
+ unsigned int cardMin(void) const;
1225
+ /// Return maximum cardinality
1226
+ unsigned int cardMax(void) const;
1227
+ /// Return minimum of the least upper bound
1228
+ int lubMin(void) const;
1229
+ /// Return maximum of the least upper bound
1230
+ int lubMax(void) const;
1231
+ /// Return n-th smallest element of the least upper bound
1232
+ int lubMinN(int n) const;
1233
+ /// Return minimum of the greatest lower bound
1234
+ int glbMin(void) const;
1235
+ /// Return maximum of the greatest lower bound
1236
+ int glbMax(void) const;
1237
+
1238
+ /// Return the number of elements in the greatest lower bound
1239
+ unsigned int glbSize(void) const;
1240
+ /// Return the number of elements in the least upper bound
1241
+ unsigned int lubSize(void) const;
1242
+ /// Return the number of unknown elements
1243
+ unsigned int unknownSize(void) const;
1244
+ /// Return the offset
1245
+ int offset(void) const;
1246
+ //@}
1247
+
1248
+ /// \name Domain tests
1249
+ //@{
1250
+ /// Test whether view is assigned
1251
+ bool assigned(void) const;
1252
+ /// Test whether \a i is in the greatest lower bound
1253
+ bool contains(int i) const;
1254
+ /// Test whether \a i is not in the least upper bound
1255
+ bool notContains(int i) const;
1256
+ //@}
1257
+
1258
+
1259
+ /// \name Domain update by value
1260
+ //@{
1261
+ /// Restrict cardinality to be greater than or equal to \a m
1262
+ ModEvent cardMin(Space* home, unsigned int m);
1263
+ /// Restrict cardinality to be less than or equal to \a m
1264
+ ModEvent cardMax(Space* home, unsigned int m);
1265
+ /**
1266
+ * \brief Update greatest lower bound to include all elements
1267
+ * between and including \a i and \a j
1268
+ */
1269
+ ModEvent include(Space* home,int i,int j);
1270
+ /**
1271
+ * \brief Restrict least upper bound to not contain all elements
1272
+ * between and including \a i and \a j
1273
+ */
1274
+ ModEvent exclude(Space* home,int i,int j);
1275
+ /// Update greatest lower bound to contain \a i
1276
+ ModEvent include(Space* home,int i);
1277
+ /// Restrict least upper bound to not contain \a i
1278
+ ModEvent exclude(Space* home,int i);
1279
+ /**
1280
+ * \brief Update least upper bound to contain at most all elements
1281
+ * between and including \a i and \a j
1282
+ */
1283
+ ModEvent intersect(Space* home,int i,int j);
1284
+ /// Update least upper bound to contain at most the element \a i
1285
+ ModEvent intersect(Space* home,int i);
1286
+ //@}
1287
+
1288
+ /// \name Domain update by range iterator
1289
+ //@{
1290
+
1291
+ /// Remove range sequence described by \a i from least upper bound
1292
+ template <class I> ModEvent excludeI(Space* home, I& i);
1293
+ /// Include range sequence described by \a i in greatest lower bound
1294
+ template <class I> ModEvent includeI(Space* home, I& i);
1295
+ /// Intersect least upper bound with range sequence described by \a i
1296
+ template <class I> ModEvent intersectI(Space* home, I& iter);
1297
+ //@}
1298
+
1299
+ /// \name View-dependent propagator support
1300
+ //@{
1301
+ /// Schedule propagator \a p with modification event \a me
1302
+ static void schedule(Space* home, Propagator* p, ModEvent me);
1303
+ /// Return modification event for view type in \a med
1304
+ static ModEvent me(ModEventDelta med);
1305
+ /// Translate modification event \a me to modification event delta for view
1306
+ static ModEventDelta med(ModEvent);
1307
+ //@}
1308
+
1309
+ /// \name Dependencies
1310
+ //@{
1311
+ /**
1312
+ * \brief Subscribe propagator \a p with propagation condition \a pc to view
1313
+ *
1314
+ * In case \a process is false, the propagator is just subscribed but
1315
+ * not processed for execution (this must be used when creating
1316
+ * subscriptions during propagation).
1317
+ */
1318
+ void subscribe(Space* home, Propagator* p, PropCond pc, bool process=true);
1319
+ /// Cancel subscription of propagator \a p with propagation condition \a pc to view
1320
+ void cancel(Space* home, Propagator* p, PropCond pc);
1321
+ /// Subscribe advisor \a a to view
1322
+ void subscribe(Space* home, Advisor* a);
1323
+ /// Cancel subscription of advisor \a a
1324
+ void cancel(Space* home, Advisor* a);
1325
+ //@}
1326
+
1327
+
1328
+ /// \name Cloning
1329
+ //@{
1330
+ /// Update this view to be a clone of view \a x
1331
+ void update(Space* home, bool share, OffsetSetView& x);
1332
+ //@}
1333
+
1334
+ /// \name Reflection
1335
+ //@{
1336
+ /// Return specification for this view, using variable map \a m
1337
+ Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
1338
+ static Support::Symbol type(void);
1339
+ //@}
1340
+
1341
+ /// \name Delta information for advisors
1342
+ //@{
1343
+ /// Return modification event
1344
+ static ModEvent modevent(const Delta* d);
1345
+ /// Return minimum value just pruned from glb
1346
+ int glbMin(const Delta* d) const;
1347
+ /// Return maximum value just pruned from glb
1348
+ int glbMax(const Delta* d) const;
1349
+ /// Test whether arbitrary values got pruned from glb
1350
+ bool glbAny(const Delta* d) const;
1351
+ /// Return minimum value just pruned from lub
1352
+ int lubMin(const Delta* d) const;
1353
+ /// Return maximum value just pruned from lub
1354
+ int lubMax(const Delta* d) const;
1355
+ /// Test whether arbitrary values got pruned from lub
1356
+ bool lubAny(const Delta* d) const;
1357
+ //@}
1358
+
1359
+ };
1360
+
1361
+ }
1362
+
1363
+ /** \name View comparison
1364
+ * \relates Gecode::Set::ComplementView
1365
+ */
1366
+ //@{
1367
+ /// Test whether views \a x and \a y are the same
1368
+ template <class View>
1369
+ bool same(const Set::OffsetSetView<View>& x,
1370
+ const Set::OffsetSetView<View>& y);
1371
+ /// Test whether view \a x comes before \a y (arbitrary order)
1372
+ template <class View>
1373
+ bool before(const Set::OffsetSetView<View>& x,
1374
+ const Set::OffsetSetView<View>& y);
1375
+ //@}
1376
+
1377
+
1378
+ /**
1379
+ * \brief Traits class for views and variable implementations
1380
+ *
1381
+ * This class specializes the ViewVarImpTraits for ComplementView.
1382
+ * \ingroup TaskActorSetView
1383
+ */
1384
+ template <class View>
1385
+ class ViewVarImpTraits<Set::OffsetSetView<View> > {
1386
+ public:
1387
+ /// The variable type of a ComplementView
1388
+ typedef typename ViewVarImpTraits<View>::VarImp VarImp;
1389
+ };
1390
+
1391
+
1392
+ }
1393
+
1394
+ #include "gecode/set/var/set.icc"
1395
+ #include "gecode/set/view/set.icc"
1396
+ #include "gecode/set/view/const.icc"
1397
+ #include "gecode/set/view/singleton.icc"
1398
+ #include "gecode/set/view/complement.icc"
1399
+ #include "gecode/set/view/offset.icc"
1400
+
1401
+ /**
1402
+ * \brief Print set variable view
1403
+ * \relates Gecode::Set::SetView
1404
+ */
1405
+ GECODE_SET_EXPORT std::ostream&
1406
+ operator<<(std::ostream&, const Gecode::Set::SetView&);
1407
+
1408
+
1409
+ /**
1410
+ * \brief Print empty set view
1411
+ * \relates Gecode::Set::EmptyView
1412
+ */
1413
+ GECODE_SET_EXPORT std::ostream&
1414
+ operator<<(std::ostream&, const Gecode::Set::EmptyView&);
1415
+
1416
+ /**
1417
+ * \brief Print universe set view
1418
+ * \relates Gecode::Set::UniverseView
1419
+ */
1420
+ GECODE_SET_EXPORT std::ostream&
1421
+ operator<<(std::ostream&, const Gecode::Set::UniverseView&);
1422
+
1423
+ /**
1424
+ * \brief Print set constant view
1425
+ * \relates Gecode::Set::ConstantView
1426
+ */
1427
+ GECODE_SET_EXPORT std::ostream&
1428
+ operator<<(std::ostream&, const Gecode::Set::ConstantView&);
1429
+
1430
+ /**
1431
+ * \brief Print singelton set view
1432
+ * \relates Gecode::Set::SingletonView
1433
+ */
1434
+ GECODE_SET_EXPORT std::ostream&
1435
+ operator<<(std::ostream&, const Gecode::Set::SingletonView&);
1436
+
1437
+ /**
1438
+ * \brief Print set complement view
1439
+ * \relates Gecode::Set::ComplementView
1440
+ */
1441
+ template <class View>
1442
+ std::ostream&
1443
+ operator<<(std::ostream&, const Gecode::Set::ComplementView<View>&);
1444
+
1445
+ inline std::ostream&
1446
+ operator<<(std::ostream& os, const Gecode::SetVar& x) {
1447
+ Gecode::Set::SetView vx(x);
1448
+ return os << vx;
1449
+ }
1450
+
1451
+ // STATISTICS: set-var