gecoder-with-gecode 0.9.0 → 0.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (919) hide show
  1. data/CHANGES +6 -0
  2. data/README +1 -1
  3. data/THANKS +18 -0
  4. data/example/equation_system.rb +3 -1
  5. data/example/magic_sequence.rb +3 -1
  6. data/example/queens.rb +3 -1
  7. data/example/send_more_money.rb +24 -30
  8. data/example/send_most_money.rb +15 -26
  9. data/example/square_tiling.rb +3 -1
  10. data/example/sudoku-set.rb +3 -1
  11. data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
  12. data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
  13. data/ext/gecode-2.2.0/Makefile.dep +8056 -0
  14. data/ext/gecode-2.2.0/Makefile.in +1590 -0
  15. data/ext/gecode-2.2.0/changelog.in +2698 -0
  16. data/ext/gecode-2.2.0/configure +13112 -0
  17. data/ext/gecode-2.2.0/configure.ac +273 -0
  18. data/ext/gecode-2.2.0/configure.ac.in +269 -0
  19. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
  20. data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
  21. data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
  22. data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
  23. data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
  24. data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
  25. data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
  26. data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
  27. data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
  28. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
  29. data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
  30. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
  31. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
  32. data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
  33. data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
  34. data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
  35. data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
  36. data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
  37. data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
  38. data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
  39. data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
  40. data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
  41. data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
  42. data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
  43. data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
  44. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
  45. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
  46. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
  47. data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
  48. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
  49. data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
  50. data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
  51. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
  52. data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
  53. data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
  54. data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
  55. data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
  56. data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
  57. data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
  58. data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
  59. data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
  60. data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
  61. data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
  62. data/ext/gecode-2.2.0/examples/crew.cc +286 -0
  63. data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
  64. data/ext/gecode-2.2.0/examples/domino.cc +297 -0
  65. data/ext/gecode-2.2.0/examples/donald.cc +107 -0
  66. data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
  67. data/ext/gecode-2.2.0/examples/golf.cc +297 -0
  68. data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
  69. data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
  70. data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
  71. data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
  72. data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
  73. data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
  74. data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
  75. data/ext/gecode-2.2.0/examples/knights.cc +220 -0
  76. data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
  77. data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
  78. data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
  79. data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
  80. data/ext/gecode-2.2.0/examples/money.cc +105 -0
  81. data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
  82. data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
  83. data/ext/gecode-2.2.0/examples/partition.cc +141 -0
  84. data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
  85. data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
  86. data/ext/gecode-2.2.0/examples/photo.cc +170 -0
  87. data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
  88. data/ext/gecode-2.2.0/examples/queens.cc +147 -0
  89. data/ext/gecode-2.2.0/examples/queens.js +57 -0
  90. data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
  91. data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
  92. data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
  93. data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
  94. data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
  95. data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
  96. data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
  97. data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
  98. data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
  99. data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
  100. data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
  101. data/ext/gecode-2.2.0/examples/support.hh +338 -0
  102. data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
  103. data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
  104. data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
  105. data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
  106. data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
  107. data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
  108. data/ext/gecode-2.2.0/gecode.m4 +1046 -0
  109. data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
  110. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
  111. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
  112. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
  113. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
  114. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
  115. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
  116. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
  117. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
  118. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
  119. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
  120. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
  121. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
  122. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
  123. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
  124. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
  125. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
  126. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
  127. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
  128. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
  129. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
  130. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
  131. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
  132. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
  133. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
  134. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
  135. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
  136. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
  137. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
  138. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
  139. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
  140. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
  141. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
  142. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
  143. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
  144. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
  145. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
  146. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
  147. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
  148. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
  149. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
  150. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
  151. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
  152. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
  153. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
  154. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
  155. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
  156. data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
  157. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
  158. data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
  159. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
  160. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
  161. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
  162. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
  163. data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
  164. data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
  165. data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
  166. data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
  167. data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
  168. data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
  169. data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
  170. data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
  171. data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
  172. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
  173. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
  174. data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
  175. data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
  176. data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
  177. data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
  178. data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
  179. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
  180. data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
  181. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
  182. data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
  183. data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
  184. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
  185. data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
  186. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
  187. data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
  188. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
  189. data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
  190. data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
  191. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
  192. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
  193. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
  194. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
  195. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
  196. data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
  197. data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
  198. data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
  199. data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
  200. data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
  201. data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
  202. data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
  203. data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
  204. data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
  205. data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
  206. data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
  207. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
  208. data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
  209. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
  210. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
  211. data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
  212. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
  213. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
  214. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
  215. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
  216. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
  217. data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
  218. data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
  219. data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
  220. data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
  221. data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
  222. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
  223. data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
  224. data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
  225. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
  226. data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
  227. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
  228. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
  229. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
  230. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
  231. data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
  232. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
  233. data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
  234. data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
  235. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
  236. data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
  237. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
  238. data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
  239. data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
  240. data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
  241. data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
  242. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
  243. data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
  244. data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
  245. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
  246. data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
  247. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
  248. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
  249. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
  250. data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
  251. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
  252. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
  253. data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
  254. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
  255. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
  256. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
  257. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
  258. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
  259. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
  260. data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
  261. data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
  262. data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
  263. data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
  264. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
  265. data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
  266. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
  267. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
  268. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
  269. data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
  270. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
  271. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
  272. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
  273. data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
  274. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
  275. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
  276. data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
  277. data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
  278. data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
  279. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
  280. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
  281. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
  282. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
  283. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
  284. data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
  285. data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
  286. data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
  287. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
  288. data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
  289. data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
  290. data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
  291. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
  292. data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
  293. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
  294. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
  295. data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
  296. data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
  297. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
  298. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
  299. data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
  300. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
  301. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
  302. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
  303. data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
  304. data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
  305. data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
  306. data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
  307. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
  308. data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
  309. data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
  310. data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
  311. data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
  312. data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
  313. data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
  314. data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
  315. data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
  316. data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
  317. data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
  318. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
  319. data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
  320. data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
  321. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
  322. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
  323. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
  324. data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
  325. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
  326. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
  327. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
  328. data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
  329. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
  330. data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
  331. data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
  332. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
  333. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
  334. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
  335. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
  336. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
  337. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
  338. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
  339. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
  340. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
  341. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
  342. data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
  343. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
  344. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
  345. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
  346. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
  347. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
  348. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
  349. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
  350. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
  351. data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
  352. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
  353. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
  354. data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
  355. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
  356. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
  357. data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
  358. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
  359. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
  360. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
  361. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
  362. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
  363. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
  364. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
  365. data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
  366. data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
  367. data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
  368. data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
  369. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
  370. data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
  371. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
  372. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
  373. data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
  374. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
  375. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
  376. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
  377. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
  378. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
  379. data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
  380. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
  381. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
  382. data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
  383. data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
  384. data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
  385. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
  386. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
  387. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
  388. data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
  389. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
  390. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
  391. data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
  392. data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
  393. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
  394. data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
  395. data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
  396. data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
  397. data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
  398. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
  399. data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
  400. data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
  401. data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
  402. data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
  403. data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
  404. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
  405. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
  406. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
  407. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
  408. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
  409. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
  410. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
  411. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
  412. data/ext/gecode-2.2.0/gecode/search.hh +759 -0
  413. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
  414. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
  415. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
  416. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
  417. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
  418. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
  419. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
  420. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
  421. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
  422. data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
  423. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
  424. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
  425. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
  426. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
  427. data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
  428. data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
  429. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
  430. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
  431. data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
  432. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
  433. data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
  434. data/ext/gecode-2.2.0/gecode/set.hh +970 -0
  435. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
  436. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
  437. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
  438. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
  439. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
  440. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
  441. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
  442. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
  443. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
  444. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
  445. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
  446. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
  447. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
  448. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
  449. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
  450. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
  451. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
  452. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
  453. data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
  454. data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
  455. data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
  456. data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
  457. data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
  458. data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
  459. data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
  460. data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
  461. data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
  462. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
  463. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
  464. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
  465. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
  466. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
  467. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
  468. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
  469. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
  470. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
  471. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
  472. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
  473. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
  474. data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
  475. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
  476. data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
  477. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
  478. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
  479. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
  480. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
  481. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
  482. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
  483. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
  484. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
  485. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
  486. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
  487. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
  488. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
  489. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
  490. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
  491. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
  492. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
  493. data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
  494. data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
  495. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
  496. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
  497. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
  498. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
  499. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
  500. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
  501. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
  502. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
  503. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
  504. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
  505. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
  506. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
  507. data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
  508. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
  509. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
  510. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
  511. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
  512. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
  513. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
  514. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
  515. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
  516. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
  517. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
  518. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
  519. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
  520. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
  521. data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
  522. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
  523. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
  524. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
  525. data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
  526. data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
  527. data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
  528. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
  529. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
  530. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
  531. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
  532. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
  533. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
  534. data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
  535. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
  536. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
  537. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
  538. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
  539. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
  540. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
  541. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
  542. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
  543. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
  544. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
  545. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
  546. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
  547. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
  548. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
  549. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
  550. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
  551. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
  552. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
  553. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
  554. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
  555. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
  556. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
  557. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
  558. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
  559. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
  560. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
  561. data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
  562. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
  563. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
  564. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
  565. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
  566. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
  567. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
  568. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
  569. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
  570. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
  571. data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
  572. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
  573. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
  574. data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
  575. data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
  576. data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
  577. data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
  578. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
  579. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
  580. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
  581. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
  582. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
  583. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
  584. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
  585. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
  586. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
  587. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
  588. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
  589. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
  590. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
  591. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
  592. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
  593. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
  594. data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
  595. data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
  596. data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
  597. data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
  598. data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
  599. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
  600. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
  601. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
  602. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
  603. data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
  604. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
  605. data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
  606. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
  607. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
  608. data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
  609. data/ext/gecode-2.2.0/test/assign.cc +181 -0
  610. data/ext/gecode-2.2.0/test/assign.hh +93 -0
  611. data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
  612. data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
  613. data/ext/gecode-2.2.0/test/branch.cc +563 -0
  614. data/ext/gecode-2.2.0/test/branch.hh +144 -0
  615. data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
  616. data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
  617. data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
  618. data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
  619. data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
  620. data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
  621. data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
  622. data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
  623. data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
  624. data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
  625. data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
  626. data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
  627. data/ext/gecode-2.2.0/test/int.cc +688 -0
  628. data/ext/gecode-2.2.0/test/int.hh +267 -0
  629. data/ext/gecode-2.2.0/test/int.icc +266 -0
  630. data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
  631. data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
  632. data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
  633. data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
  634. data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
  635. data/ext/gecode-2.2.0/test/int/count.cc +357 -0
  636. data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
  637. data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
  638. data/ext/gecode-2.2.0/test/int/element.cc +333 -0
  639. data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
  640. data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
  641. data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
  642. data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
  643. data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
  644. data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
  645. data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
  646. data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
  647. data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
  648. data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
  649. data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
  650. data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
  651. data/ext/gecode-2.2.0/test/search.cc +618 -0
  652. data/ext/gecode-2.2.0/test/set.cc +753 -0
  653. data/ext/gecode-2.2.0/test/set.hh +286 -0
  654. data/ext/gecode-2.2.0/test/set.icc +108 -0
  655. data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
  656. data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
  657. data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
  658. data/ext/gecode-2.2.0/test/set/int.cc +473 -0
  659. data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
  660. data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
  661. data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
  662. data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
  663. data/ext/gecode-2.2.0/test/set/select.cc +299 -0
  664. data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
  665. data/ext/gecode-2.2.0/test/test.cc +287 -0
  666. data/ext/gecode-2.2.0/test/test.hh +175 -0
  667. data/ext/gecode-2.2.0/test/test.icc +93 -0
  668. data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
  669. data/lib/gecoder/bindings.rb +7 -5
  670. data/lib/gecoder/bindings/bindings.rb +8 -8
  671. data/lib/gecoder/interface.rb +4 -2
  672. data/lib/gecoder/interface/binding_changes.rb +1 -1
  673. data/lib/gecoder/interface/branch.rb +1 -1
  674. data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
  675. data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
  676. data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
  677. data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
  678. data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
  679. data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
  680. data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
  681. data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
  682. data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
  683. data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
  684. data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
  685. data/lib/gecoder/interface/convenience.rb +99 -0
  686. data/lib/gecoder/interface/enum_wrapper.rb +1 -1
  687. data/lib/gecoder/interface/mixin.rb +486 -0
  688. data/lib/gecoder/interface/search.rb +23 -22
  689. data/lib/gecoder/version.rb +1 -1
  690. data/specs/branch.rb +5 -3
  691. data/specs/constraints/bool/boolean.rb +3 -1
  692. data/specs/constraints/bool/linear.rb +3 -1
  693. data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
  694. data/specs/constraints/bool_enum/channel.rb +3 -1
  695. data/specs/constraints/fixnum_enum/element.rb +3 -1
  696. data/specs/constraints/int/arithmetic.rb +3 -1
  697. data/specs/constraints/int/channel.rb +3 -1
  698. data/specs/constraints/int/linear.rb +3 -1
  699. data/specs/constraints/int/linear_properties.rb +3 -1
  700. data/specs/constraints/int_enum/arithmetic.rb +3 -1
  701. data/specs/constraints/int_enum/channel.rb +3 -1
  702. data/specs/constraints/int_enum/count.rb +3 -1
  703. data/specs/constraints/int_enum/distinct.rb +3 -1
  704. data/specs/constraints/int_enum/element.rb +3 -1
  705. data/specs/constraints/int_enum/sort.rb +3 -1
  706. data/specs/constraints/property_helper.rb +10 -10
  707. data/specs/constraints/reification_sugar.rb +3 -1
  708. data/specs/constraints/selected_set/select.rb +6 -5
  709. data/specs/constraints/selected_set/select_properties.rb +12 -10
  710. data/specs/constraints/set/channel.rb +3 -1
  711. data/specs/constraints/set/domain.rb +4 -4
  712. data/specs/constraints/set/relation.rb +4 -4
  713. data/specs/constraints/set_enum/channel.rb +3 -1
  714. data/specs/constraints/set_enum/distinct.rb +3 -1
  715. data/specs/constraints/set_enum/element.rb +77 -0
  716. data/specs/enum_wrapper.rb +1 -1
  717. data/specs/mixin.rb +78 -0
  718. data/specs/model.rb +5 -5
  719. data/specs/search.rb +20 -14
  720. data/specs/selected_set.rb +3 -3
  721. data/specs/set_elements.rb +2 -2
  722. data/tasks/distribution.rake +25 -4
  723. metadata +739 -602
  724. data/example/money.rb +0 -36
  725. data/ext/gecode-2.1.1/Makefile.dep +0 -7622
  726. data/ext/gecode-2.1.1/Makefile.in +0 -1568
  727. data/ext/gecode-2.1.1/changelog.in +0 -2459
  728. data/ext/gecode-2.1.1/configure +0 -11631
  729. data/ext/gecode-2.1.1/configure.ac +0 -249
  730. data/ext/gecode-2.1.1/configure.ac.in +0 -245
  731. data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
  732. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
  733. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
  734. data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
  735. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
  736. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
  737. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
  738. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
  739. data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
  740. data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
  741. data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
  742. data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
  743. data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
  744. data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
  745. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
  746. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
  747. data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
  748. data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
  749. data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
  750. data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
  751. data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
  752. data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
  753. data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
  754. data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
  755. data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
  756. data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
  757. data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
  758. data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
  759. data/ext/gecode-2.1.1/gecode.m4 +0 -956
  760. data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
  761. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
  762. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
  763. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
  764. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
  765. data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
  766. data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
  767. data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
  768. data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
  769. data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
  770. data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
  771. data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
  772. data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
  773. data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
  774. data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
  775. data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
  776. data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
  777. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
  778. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
  779. data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
  780. data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
  781. data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
  782. data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
  783. data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
  784. data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
  785. data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
  786. data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
  787. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
  788. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
  789. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
  790. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
  791. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
  792. data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
  793. data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
  794. data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
  795. data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
  796. data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
  797. data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
  798. data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
  799. data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
  800. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
  801. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
  802. data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
  803. data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
  804. data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
  805. data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
  806. data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
  807. data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
  808. data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
  809. data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
  810. data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
  811. data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
  812. data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
  813. data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
  814. data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
  815. data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
  816. data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
  817. data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
  818. data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
  819. data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
  820. data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
  821. data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
  822. data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
  823. data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
  824. data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
  825. data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
  826. data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
  827. data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
  828. data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
  829. data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
  830. data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
  831. data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
  832. data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
  833. data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
  834. data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
  835. data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
  836. data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
  837. data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
  838. data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
  839. data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
  840. data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
  841. data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
  842. data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
  843. data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
  844. data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
  845. data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
  846. data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
  847. data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
  848. data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
  849. data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
  850. data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
  851. data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
  852. data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
  853. data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
  854. data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
  855. data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
  856. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
  857. data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
  858. data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
  859. data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
  860. data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
  861. data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
  862. data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
  863. data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
  864. data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
  865. data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
  866. data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
  867. data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
  868. data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
  869. data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
  870. data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
  871. data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
  872. data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
  873. data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
  874. data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
  875. data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
  876. data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
  877. data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
  878. data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
  879. data/ext/gecode-2.1.1/gecode/search.hh +0 -752
  880. data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
  881. data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
  882. data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
  883. data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
  884. data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
  885. data/ext/gecode-2.1.1/gecode/set.hh +0 -970
  886. data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
  887. data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
  888. data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
  889. data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
  890. data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
  891. data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
  892. data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
  893. data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
  894. data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
  895. data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
  896. data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
  897. data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
  898. data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
  899. data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
  900. data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
  901. data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
  902. data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
  903. data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
  904. data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
  905. data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
  906. data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
  907. data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
  908. data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
  909. data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
  910. data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
  911. data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
  912. data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
  913. data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
  914. data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
  915. data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
  916. data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
  917. data/lib/gecoder/interface/model.rb +0 -453
  918. data/lib/gecoder/interface/model_sugar.rb +0 -84
  919. data/specs/constraints/set_enum/select.rb +0 -73
@@ -1,2459 +0,0 @@
1
- #
2
- # Main authors:
3
- # Christian Schulte <schulte@gecode.org>
4
- #
5
- # Copyright:
6
- # Christian Schulte, 2005
7
- #
8
- # Last modified:
9
- # $Date: 2008-03-06 03:54:12 +0100 (Thu, 06 Mar 2008) $ by $Author: schulte $
10
- # $Revision: 6433 $
11
- #
12
- # This file is part of Gecode, the generic constraint
13
- # development environment:
14
- # http://www.gecode.org
15
- #
16
- # Permission is hereby granted, free of charge, to any person obtaining
17
- # a copy of this software and associated documentation files (the
18
- # "Software"), to deal in the Software without restriction, including
19
- # without limitation the rights to use, copy, modify, merge, publish,
20
- # distribute, sublicense, and/or sell copies of the Software, and to
21
- # permit persons to whom the Software is furnished to do so, subject to
22
- # the following conditions:
23
- #
24
- # The above copyright notice and this permission notice shall be
25
- # included in all copies or substantial portions of the Software.
26
- #
27
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
28
- # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
29
- # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
30
- # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
31
- # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
32
- # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
33
- # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
34
- #
35
-
36
- #
37
- # This file contains entries for changelogs
38
- #
39
- # There are two kinds of entries: one marking releases and the others
40
- # being actual entries.
41
- #
42
- # All the lines for describing entries must start at the beginning.
43
- #
44
- # A release is described as follows:
45
- # [RELEASE]
46
- # Version: <version string>
47
- # Date: <when release>
48
- # [DESCRIPTION]
49
- # ... All the text up to the next [ENTRY] is included
50
- # as description
51
- #
52
- # An entry is described as follows:
53
- # [ENTRY]
54
- # Module:
55
- # kernel|search|int|set|cpltset|example|minimodel|iter|support|
56
- # test|gist|other
57
- # What: bug|documentation|performance|new|removed|change
58
- # Rank: minor|major
59
- # Bug: <optional, for number from bugzilla>
60
- # Thanks: <optional, who reported etc>
61
- # [DESCRIPTION]
62
- # ... All the text up to the next [ENTRY] or [RELEASE] is included
63
- # as description
64
- #
65
-
66
- [RELEASE]
67
- Version: 2.1.1
68
- Date: 2008-03-06
69
- [DESCRIPTION]
70
- This is a bugfix release.
71
-
72
- [ENTRY]
73
- Module: int
74
- What: bug
75
- Rank: minor
76
- [DESCRIPTION]
77
- Non-shared copying of dfa was broken (matters only for parallel execution).
78
-
79
- [ENTRY]
80
- Module: kernel
81
- What: bug
82
- Rank: major
83
- [DESCRIPTION]
84
- The generated med_updated function was incorrect, resulting in potential
85
- crashes of programs that use SetVars.
86
-
87
- [ENTRY]
88
- Module: cpltset
89
- What: documentation
90
- Rank: minor
91
- [DESCRIPTION]
92
- The CpltSet variables are now in the correct documentation group.
93
-
94
- [ENTRY]
95
- Module: gist
96
- What: bug
97
- Rank: minor
98
- [DESCRIPTION]
99
- Fixed redraw artefacts on Windows.
100
-
101
- [ENTRY]
102
- Module: other
103
- What: bug
104
- Rank: minor
105
- [DESCRIPTION]
106
- Fixed boost serialization.
107
-
108
- [ENTRY]
109
- Module: kernel
110
- What: bug
111
- Rank: minor
112
- [DESCRIPTION]
113
- Made the constructor of Reflection::Var explicit, otherwise overloading for
114
- output stream operators does not work as expected.
115
-
116
-
117
- [RELEASE]
118
- Version: 2.1.0
119
- Date: 2008-02-29
120
- [DESCRIPTION]
121
- This release makes two essential contributions: a partly
122
- reimplemented kernel that is faster, is simpler, and uses less
123
- memory and lots of small and not so small fixes. This release is
124
- the first release where really everything that we can test
125
- (rather than everything that we initially believed to matter) has
126
- been systematically tested. So, better switch now to 2.1.0!
127
-
128
- Apart from that, the value range for variables has been increased
129
- (basically, 32 bits minus three values, so that is 32 bits), the reflection
130
- API is now fully functional and no longer considered experimental, and we have
131
- the usual small additions.
132
-
133
-
134
- [ENTRY]
135
- Module: int
136
- What: new
137
- Rank: minor
138
- [DESCRIPTION]
139
- Added interface to extensional constraints defined by TupleSets with
140
- BoolVars.
141
-
142
- [ENTRY]
143
- Module: minimodel
144
- What: bug
145
- Rank: major
146
- [DESCRIPTION]
147
- Reimplemented linear expressions from scratch, they were just
148
- hopelessly screwed.
149
-
150
- [ENTRY]
151
- Module: minimodel
152
- What: bug
153
- Rank: minor
154
- [DESCRIPTION]
155
- Added work-around for compiler bug in MSVC.
156
-
157
- [ENTRY]
158
- Module: minimodel
159
- What: new
160
- Rank: minor
161
- [DESCRIPTION]
162
- Support reified linear expressions with Boolean variables.
163
-
164
- [ENTRY]
165
- Module: int
166
- What: change
167
- Rank: minor
168
- [DESCRIPTION]
169
- Throw an exception if variables occur multiply for array-based
170
- channel constraints.
171
-
172
- [ENTRY]
173
- Module: int
174
- What: bug
175
- Rank: minor
176
- [DESCRIPTION]
177
- Fixed multiplication propagator for x*y=x.
178
-
179
- [ENTRY]
180
- Module: search
181
- What: change
182
- Rank: major
183
- [DESCRIPTION]
184
- All search engines now take an option value for configuration
185
- instead of individual arguments for recomputation, stop objects,
186
- etc.
187
-
188
- [ENTRY]
189
- Module: minimodel
190
- What: removed
191
- Rank: minor
192
- [DESCRIPTION]
193
- Removed scheduling abstractions.
194
-
195
- [ENTRY]
196
- Module: int
197
- What: removed
198
- Rank: minor
199
- [DESCRIPTION]
200
- Removed extensional constraints with offset arguments.
201
-
202
- [ENTRY]
203
- Module: minimodel
204
- What: new
205
- Rank: minor
206
- [DESCRIPTION]
207
- All minimodel functionality now understands both IntConLevel and
208
- PropKind arguments.
209
-
210
- [ENTRY]
211
- Module: set
212
- What: bug
213
- Rank: major
214
- [DESCRIPTION]
215
- Fixed bugs in several set constraints:
216
- rel(Space*,SetVar,IntRelType irt,IntVar) for irt=IRT_NQ,
217
- rel(Space*,SetVar,SetOpType sot,const IntSet&,SetRelType srt,SetVar) for
218
- sot=SOT_MINUS, srt=SRT_SUP, selectDisjoint, selectUnion with constant IntSet
219
- arguments, dom with SRT_NQ.
220
-
221
- [ENTRY]
222
- Module: kernel
223
- What: bug
224
- Rank: minor
225
- [DESCRIPTION]
226
- Fixed bug in unreflection of empty VarArrays.
227
-
228
- [ENTRY]
229
- Module: linear
230
- What: bug
231
- Rank: major
232
- [DESCRIPTION]
233
- Fixed overflow checking error in linear constraints.
234
-
235
- [ENTRY]
236
- Module: minimodel
237
- What: new
238
- Rank: minor
239
- [DESCRIPTION]
240
- Added sqrt function.
241
-
242
- [ENTRY]
243
- Module: int
244
- What: new
245
- Rank: minor
246
- [DESCRIPTION]
247
- Added sqrt propagator.
248
-
249
- [ENTRY]
250
- Module: int
251
- What: new
252
- Rank: minor
253
- [DESCRIPTION]
254
- Added sqr post function.
255
-
256
- [ENTRY]
257
- Module: int
258
- What: bug
259
- Rank: minor
260
- [DESCRIPTION]
261
- The overloaded versions of dom for variable arrays could not be
262
- resolved automatically.
263
-
264
- [ENTRY]
265
- Module: int
266
- What: new
267
- Rank: minor
268
- [DESCRIPTION]
269
- Added missing branching for INT_VAR_SIZE_DEGREE_MIN and
270
- INT_VAR_SIZE_DEGREE_MAX for Boolean variables.
271
-
272
- [ENTRY]
273
- Module: minimodel
274
- What: bug
275
- Rank: major
276
- Thanks: Stanimir Dragiev
277
- [DESCRIPTION]
278
- Fixed bug in posting linear expressions.
279
-
280
- [ENTRY]
281
- Module: int
282
- What: performance
283
- Rank: minor
284
- [DESCRIPTION]
285
- IntSet have been reimplemented for efficiency.
286
-
287
- [ENTRY]
288
- Module: other
289
- What: documentation
290
- Rank: minor
291
- Thanks: Martin Mann
292
- [DESCRIPTION]
293
- Function prototypes are now highlighted in the detailed function documentation.
294
-
295
- [ENTRY]
296
- Module: int
297
- What: removed
298
- Rank: minor
299
- [DESCRIPTION]
300
- The offset arguments for element constraints have been removed, as you can
301
- simply add dummy elements to the array to achieve the same effect.
302
-
303
- [ENTRY]
304
- Module: set
305
- What: removed
306
- Rank: minor
307
- [DESCRIPTION]
308
- The offset arguments for selection constraints have been removed, as you can
309
- simply add dummy elements to the array to achieve the same effect.
310
-
311
- [ENTRY]
312
- Module: other
313
- What: new
314
- Rank: major
315
- [DESCRIPTION]
316
- The serialization library now contains a registry of all the Gecode post
317
- functions. This makes interfacing to Gecode much easier. The registry is
318
- automatically generated from the post functions defined in gecode/int.hh and
319
- gecode/set.hh.
320
-
321
- [ENTRY]
322
- Module: kernel
323
- What: change
324
- Rank: minor
325
- [DESCRIPTION]
326
- Cleaned up reflection. Unreflection is now part of the kernel instead of the
327
- serialization library. Branchings now provide a human-readable description of
328
- a BranchingDesc. The name function of a Propagator has been renamed to ati
329
- (actor type identifier). All reflection is now const where possible.
330
- Unreflection of variables now checks dynamically that the variable types
331
- match. Unreflection of propagators checks the number of arguments. A
332
- tutorial-style section on reflection has been added to the documentation.
333
-
334
- [ENTRY]
335
- Module: set
336
- What: change
337
- Rank: major
338
- [DESCRIPTION]
339
- The limits for set variables have been moved from Limits::Set to
340
- Set::Limits.
341
-
342
- The range of set variables has been adapted to the range of
343
- integer variables. For example, on a standard machine
344
- (regardless of 32 or 64 bits), a set can hold values from -2^30+2
345
- to 2^30-2, its maximum cardinality therefore is 2^31-3.
346
-
347
- [ENTRY]
348
- Module: int
349
- What: change
350
- Rank: major
351
- [DESCRIPTION]
352
- The limits for set variables have been moved from Limits::Set to
353
- Set::Limits.
354
-
355
- The range of integer variables have been extended by one bit. For
356
- example, on a standard machine (regardless of 32 or 64 bits), the
357
- largest possible integer value for an integer variable is 2^31-2,
358
- the smallest -2^31+2. With other words, only the integer values
359
- 2^31-1, -2^31, and -2^31+1 are missing from the two-complement
360
- representation (and we will never use these values for the sake
361
- of mental sanity. We promise.).
362
-
363
- [ENTRY]
364
- Module: int
365
- What: bug
366
- Rank: minor
367
- [DESCRIPTION]
368
- Distinct with integer offsets checks accurately for overflow now.
369
-
370
- [ENTRY]
371
- Module: int
372
- What: performance
373
- Rank: minor
374
- [DESCRIPTION]
375
- Boolean variables consume 20% less memory.
376
-
377
- [ENTRY]
378
- Module: kernel
379
- What: change
380
- Rank: major
381
- [DESCRIPTION]
382
- Only stable and non-failed spaces can be cloned, otherwise
383
- Space::clone raises an exception. This makes cloning and
384
- propagation fully orthogonal. To emulate the old behavior, just
385
- execute Space::status before Space::clone.
386
-
387
- [ENTRY]
388
- Module: kernel
389
- What: change
390
- Rank: minor
391
- [DESCRIPTION]
392
- The number of propagators and branchings can be accurately
393
- retrieved from both failed and non-stable spaces.
394
-
395
- [ENTRY]
396
- Module: examples
397
- What: new
398
- Rank: minor
399
- [DESCRIPTION]
400
- Added an example that interprets a JavaScript program and runs a search of the
401
- model that the program encodes. This is an example of how to use the
402
- JavaScript interpreter. A simple JavaScript model for n-Queens has been added,
403
- too.
404
-
405
- [ENTRY]
406
- Module: kernel
407
- What: new
408
- Rank: minor
409
- [DESCRIPTION]
410
- A generic variable class has been added that can be used for interfacing. It
411
- can store arbitrary Gecode variables (e.g. IntVar and SetVar), and cast them
412
- back using a run-time type check. The update, reflection, and output
413
- operations are implemented through the reflection registry.
414
-
415
- [ENTRY]
416
- Module: other
417
- What: new
418
- Rank: major
419
- [DESCRIPTION]
420
- (De-)Serialization to and from JavaScript added.
421
-
422
- [ENTRY]
423
- Module: other
424
- What: change
425
- Rank: major
426
- [DESCRIPTION]
427
- Both the cost and propagate function of a propagator take the
428
- current modification event delta as input. Likewise,
429
- retrieving the modification event for a particular View must use
430
- the static function View::me with the passed
431
- modification event delta. Again, this feature committed the kernel to a
432
- particular implementation which might not be available in the
433
- future.
434
-
435
- [ENTRY]
436
- Module: kernel
437
- What: change
438
- Rank: minor
439
- [DESCRIPTION]
440
- Views and variables do not any longer reveal whether they have
441
- been modified: this feature committed the kernel to a particular
442
- implementation which might not be available in the future.
443
-
444
- [ENTRY]
445
- Module: example
446
- What: new
447
- Rank: minor
448
- [DESCRIPTION]
449
- Simple Singleton Arc Consistency pre-processing has been added as an
450
- optional step for examples.
451
-
452
- [ENTRY]
453
- Module: kernel
454
- What: change
455
- Rank: major
456
- [DESCRIPTION]
457
- The kernel has undergone some cleanups and improvements (much of
458
- it got actually reimplemented):
459
- - Automatically generated stubs for variable implementations are directly
460
- inlined into the kernel. This improves performance, but more
461
- importantly, lifts some limits on the number of variables. Now, the
462
- only limit is that the sum of the ceiling of the logarithms of the
463
- number of modification events of all variables does not exceed 32
464
- (as an estimate, the kernel now can handle around 10 to 16 variable
465
- types). Moreover, if the need for more variable types arises this is
466
- straightforward to do.
467
- - The addition of new variable types for users has been simplified.
468
- - The main propagation loop has been entirely rewritten (much much simpler).
469
- Now, the kernel does not optimize any longer for the case that a
470
- variable is modified more than once during propagator execution.
471
- While this changes the asymptotic complexity, it reduces the propagator
472
- execution overhead by up to 30%. And a propagator is still free
473
- to make sure that a variable is modified only once (many propagators
474
- do that already).
475
- - Variable implementations became smaller by one word. Now variable
476
- implementations are optimal in the sense that no additional memory
477
- is needed for cloning or book-keeping, the memory required for
478
- propagation is sufficient.
479
- - Spaces have lost some weight as memory for datastructures only used
480
- during cloning or propagation are shared (saves some 25% of memory
481
- per space).
482
-
483
- [ENTRY]
484
- Module: kernel
485
- What: change
486
- Rank: major
487
- [DESCRIPTION]
488
- Propagator modification events have been renamed to modification event
489
- deltas (because that is what they are).
490
-
491
- [ENTRY]
492
- Module: kernel
493
- What: change
494
- Rank: minor
495
- [DESCRIPTION]
496
- To not confuse variable implementations with variables, variable
497
- implementations are now always called VarImp, and not Variable.
498
-
499
- [ENTRY]
500
- Module: gist
501
- What: new
502
- Rank: major
503
- [DESCRIPTION]
504
- The %Gecode Interactive Search Tool (Gist), a Qt-based graphical search
505
- engine, is now part of the main %Gecode distribution. It is currently included
506
- as an experimental beta preview and may not be completely stable yet.
507
-
508
-
509
- [RELEASE]
510
- Version: 2.0.1
511
- Date: 2008-02-07
512
- [DESCRIPTION]
513
- This is a bug-fix only release. Very unfortunately, it fixes
514
- three serious bugs in search (LDS, Restart, and assignment
515
- branchings). We highly encourage you to switch to Gecode 2.0.1 as
516
- soon as possible.
517
-
518
- [ENTRY]
519
- Module: test
520
- What: bug
521
- Rank: minor
522
- [DESCRIPTION]
523
- Fixed memory leak in reflection tests.
524
-
525
- [ENTRY]
526
- Module: set
527
- What: bug
528
- Rank: minor
529
- [DESCRIPTION]
530
- Fixed memory leak in set projection propagators.
531
-
532
- [ENTRY]
533
- Module: int
534
- What: bug
535
- Rank: minor
536
- [DESCRIPTION]
537
- Fixed memory leak in IntSet.
538
-
539
- [ENTRY]
540
- Module: test
541
- What: new
542
- Rank: major
543
- [DESCRIPTION]
544
- Added comprehensive tests for all search engines.
545
-
546
- [ENTRY]
547
- Module: search
548
- What: bug
549
- Rank: major
550
- [DESCRIPTION]
551
- Assignment branchings wrongly reported that they feature two alternatives
552
- rather than one.
553
-
554
- [ENTRY]
555
- Module: search
556
- What: bug
557
- Rank: major
558
- Thanks: Stefano Gualandi
559
- [DESCRIPTION]
560
- LDS had numerous quirks. It has been fixed and greatly improved:
561
- it detects when the entire search tree has been probed,
562
- independent of the maximal discrepancy.
563
-
564
- [ENTRY]
565
- Module: search
566
- What: bug
567
- Rank: major
568
- Thanks: Stefano Gualandi
569
- [DESCRIPTION]
570
- Restart was broken in case the problem failed immediately with
571
- propagation only, both when being initialized or when requesting
572
- a next solution.
573
-
574
- [ENTRY]
575
- Module: iter
576
- What: fix
577
- Rank: minor
578
- Thanks: David Barton
579
- [DESCRIPTION]
580
- Changed Ranges::Diff to make older versions of gcc happy.
581
-
582
- [ENTRY]
583
- Module: other
584
- What: fix
585
- Rank: minor
586
- Thanks: David Barton
587
- [DESCRIPTION]
588
- Fixed linking order so that static linking works again.
589
-
590
- [ENTRY]
591
- Module: int
592
- What: new
593
- Rank: minor
594
- Thanks: Mohamad Rabbath
595
- [DESCRIPTION]
596
- Re-added reified linear constraints for Boolean variables.
597
-
598
- [ENTRY]
599
- Module: int
600
- What: bug
601
- Rank: minor
602
- [DESCRIPTION]
603
- Domain-consistent abs could crash in certain (extremely rare) border cases.
604
-
605
- [ENTRY]
606
- Module: kernel
607
- What: bug
608
- Rank: major
609
- [DESCRIPTION]
610
- Static initialization order was undefined, making reflection work unreliably.
611
- In particular, linking Gecode statically did not work.
612
-
613
- [ENTRY]
614
- Module: int
615
- What: bug
616
- Rank: minor
617
- [DESCRIPTION]
618
- Initializing an IntVar with an empty IntSet did not throw the appropriate
619
- exception but crashed.
620
-
621
- [ENTRY]
622
- Module: kernel
623
- What: bug
624
- Rank: minor
625
- [DESCRIPTION]
626
- Exceptions did not have rtti information when compiled with gcc and
627
- visibility, which meant that they could not be caught.
628
-
629
- [ENTRY]
630
- Module: example
631
- What: bug
632
- Rank: minor
633
- Thanks: Helmut Simonis
634
- [DESCRIPTION]
635
- Fixed a bug and quirk in %Kakuro puzzles.
636
-
637
- [ENTRY]
638
- Module: kernel
639
- What: change
640
- Rank: minor
641
- [DESCRIPTION]
642
- The VarMapIter can now return both a specification and the actual VarBase* of
643
- the currently iterated variable.
644
-
645
- [ENTRY]
646
- Module: other
647
- What: bug
648
- Rank: minor
649
- [DESCRIPTION]
650
- Revived boost serialization. The serialization functions will be compiled if
651
- Gecode is configured with --with-boost.
652
-
653
- [ENTRY]
654
- Module: kernel
655
- What: performance
656
- Rank: minor
657
- [DESCRIPTION]
658
- Be less aggressive in increasing size of heap chunks.
659
-
660
- [ENTRY]
661
- Module: int
662
- What: documentation
663
- Rank: minor
664
- [DESCRIPTION]
665
- Fixed bug in documentation of table-based extensional constraint.
666
-
667
- [ENTRY]
668
- Module: kernel
669
- What: bug
670
- Rank: minor
671
- [DESCRIPTION]
672
- Fixed a bug in the hash function for pointers, which could return
673
- negative array indices.
674
-
675
-
676
-
677
- [RELEASE]
678
- Version: 2.0.0
679
- Date: 2007-11-14
680
- [DESCRIPTION]
681
- As witnessed by the version number change, this is a major
682
- release with too many changes, fixes, and additions to mention
683
- them all: please consult the changelog.
684
-
685
- The highlights are:
686
- - New propagators: channeling between Integer variable and array
687
- of Boolean variables, circuit, table constraint (extensional),
688
- incremental regular constraint (extensional), incremental
689
- Boolean linear constraints
690
- - Boolean variables have a dedicated implementation: twice as
691
- fast, half the memory
692
- - Advisors for incremental propagation (see: Lagerkvist,
693
- Schulte, Advisors for Incremental Propagation, CP 2007)
694
- - Many crucial performance and scalability improvements: memory
695
- management, memory footprint of propagators
696
- - Many cleanups and more documentation, many new examples
697
- - New set variables with complete domain representation
698
- (CpltSetVar) [experimental]
699
- - A reflection API to query spaces about their propagators
700
- [experimental]
701
-
702
- The features marked as experimental are all functional, but might
703
- be revised in the next releases.
704
-
705
- As %Gecode 2.0.0 is a major release, you might have to adapt your
706
- programs: \ref PageHowToChange_2 "How to Change to Gecode 2.0.0".
707
-
708
- [ENTRY]
709
- Module: int
710
- What: new
711
- Rank: major
712
- [DESCRIPTION]
713
- Added table-based extensional constraint.
714
-
715
- [ENTRY]
716
- Module: other
717
- What: new
718
- Rank: minor
719
- [DESCRIPTION]
720
- When compiling with gcc, the default visibility of symbols in the
721
- generated dynamic library is set to hidden.
722
-
723
- [ENTRY]
724
- Module: set
725
- What: removed
726
- Rank: minor
727
- [DESCRIPTION]
728
- Removed buggy distinct propagator for finite sets.
729
-
730
- [ENTRY]
731
- Module: example
732
- What: new
733
- Rank: minor
734
- Thanks: Helmut Simonis
735
- [DESCRIPTION]
736
- New example: %Kakuro puzzles.
737
-
738
- [ENTRY]
739
- Module: other
740
- What: new
741
- Rank: minor
742
- Thanks: Martin Mann
743
- [DESCRIPTION]
744
- Added dist and distdir targets for creating source distribution.
745
-
746
- [ENTRY]
747
- Module: other
748
- What: new
749
- Rank: minor
750
- Thanks: Filip Konvicka
751
- [DESCRIPTION]
752
- On windows with MSVC, always build program database files to ease
753
- debugging of applications using %Gecode (files are also included in
754
- packages).
755
-
756
- [ENTRY]
757
- Module: int
758
- What: new
759
- Rank: minor
760
- [DESCRIPTION]
761
- Added new variable selection based on largest or smallest
762
- quotient of size and degree.
763
-
764
- [ENTRY]
765
- Module: other
766
- What: new
767
- Rank: minor
768
- [DESCRIPTION]
769
- Variable arrays, view arrays, and argument arrays can directly be
770
- printed on standard output streams.
771
-
772
- [ENTRY]
773
- Module: other
774
- What: change
775
- Rank: minor
776
- [DESCRIPTION]
777
- The structure of includes has been drastically
778
- simplified. Support for iterators ("gecode/iter.hh") is
779
- automatically included with integers ("gecode/int.hh") and sets
780
- ("gecode/set.hh"). Likewise, all support functionality becomes
781
- available by including "gecode/support.hh" (one can assume that
782
- this is included in "gecode/kernel.hh").
783
-
784
- [ENTRY]
785
- Module: kernel
786
- What: change
787
- Rank: minor
788
- [DESCRIPTION]
789
- Shared arrays are now available in the kernel (where they properly
790
- belong). This entails that they are available in the Gecode
791
- namespace and not in Gecode::Support.
792
-
793
- [ENTRY]
794
- Module: int
795
- What: change
796
- Rank: minor
797
- [DESCRIPTION]
798
- The extensional constraint specified by a DFA or a regular
799
- expression (formerly known as regular) is now named "extensional"
800
- rather than "regular".
801
-
802
- [ENTRY]
803
- Module: minimodel
804
- What: bug
805
- Rank: minor
806
- [DESCRIPTION]
807
- Fixed small quirk in posting an absolute propagator via a function.
808
-
809
- [ENTRY]
810
- Module: set
811
- What: new
812
- Rank: minor
813
- [DESCRIPTION]
814
- Added channeling propagator between a SetVar and a BoolVarArray
815
- that propagates the characteristic function of the set to the
816
- Boolean variables.
817
-
818
- [ENTRY]
819
- Module: set
820
- What: performance
821
- Rank: minor
822
- [DESCRIPTION]
823
- Changed the datastructure for set variables to use singly-linked
824
- lists.
825
-
826
- [ENTRY]
827
- Module: other
828
- What: change
829
- Rank: minor
830
- [DESCRIPTION]
831
- The values (and types) for selecting how to branch have been made
832
- uniform for all variables types: they start with INT_ (or SET_ or
833
- CPLTSET_), followed by either VAL or VAR and the respective
834
- strategy.
835
-
836
- [ENTRY]
837
- Module: int
838
- What: change
839
- Rank: minor
840
- [DESCRIPTION]
841
- The interface for the global cardinality constraint has been simplified.
842
- The constraint is now called count.
843
-
844
- [ENTRY]
845
- Module: int
846
- What: change
847
- Rank: minor
848
- [DESCRIPTION]
849
- Regular expressions (REG) have been moved from the integer module to
850
- the minimodel module.
851
-
852
- [ENTRY]
853
- Module: example
854
- What: change
855
- Rank: major
856
- [DESCRIPTION]
857
- Most examples have been cleaned up.
858
-
859
- [ENTRY]
860
- Module: example
861
- What: change
862
- Rank: minor
863
- [DESCRIPTION]
864
- Parsing of commandline arguments has been completely redone and
865
- is much more extensible and flexible.
866
-
867
- [ENTRY]
868
- Module: other
869
- What: change
870
- Rank: minor
871
- [DESCRIPTION]
872
- All of %Gecode has been put under the MIT license (which the
873
- previous license was a simple rewording of).
874
-
875
- [ENTRY]
876
- Module: other
877
- What: bug
878
- Rank: minor
879
- [DESCRIPTION]
880
- Removed huge number of casts that could (only potentially)
881
- compromise portability.
882
-
883
- [ENTRY]
884
- Module: set
885
- What: new
886
- Rank: minor
887
- [DESCRIPTION]
888
- Finite set projectors can now be specified using formulas, in addition to
889
- set expressions.
890
-
891
- [ENTRY]
892
- Module: cpltset
893
- What: new
894
- Rank: major
895
- [DESCRIPTION]
896
- Finite integer set variables with complete domain representation,
897
- based on binary decision diagrams (BDDs), have been added as a
898
- new variable type.
899
-
900
- [ENTRY]
901
- Module: kernel
902
- What: new
903
- Rank: major
904
- [DESCRIPTION]
905
- A reflection API has been added, which allows querying spaces
906
- about the variables and propagators they contain.
907
-
908
- [ENTRY]
909
- Module: kernel
910
- What: bug
911
- Rank: major
912
- [DESCRIPTION]
913
- Branching ids were not properly initialized. This was a serious
914
- problem if you posted branchings in spaces other than the root
915
- space.
916
-
917
- [ENTRY]
918
- Module: int
919
- What: change
920
- Rank: major
921
- [DESCRIPTION]
922
- Iterator-based domain operations have been renamed,
923
- reimplemented, and extended. Now operations for both range and
924
- value iterators are supported and the operations can be told to
925
- perform more efficient destructive updates.
926
-
927
- [ENTRY]
928
- Module: int
929
- What: change
930
- Rank: minor
931
- [DESCRIPTION]
932
- Sortedness constraints have been renamed to sorted constraints.
933
-
934
- [ENTRY]
935
- Module: kernel
936
- What: change
937
- Rank: minor
938
- [DESCRIPTION]
939
- VarArrays can now be resized dynamically.
940
-
941
- [ENTRY]
942
- Module: int
943
- What: performance
944
- Rank: major
945
- [DESCRIPTION]
946
- Boolean linear equations and inequalities with constant
947
- right-hand sides use constant time propagators whenever
948
- appropriate (linear time with less overhead and memory for
949
- propagators with few variables).
950
-
951
- [ENTRY]
952
- Module: kernel
953
- What: new
954
- Rank: major
955
- [DESCRIPTION]
956
- Added advisors as an abstraction for incremental propagation:
957
- advisors are executed for their propagator whenever their view
958
- changes. Advisors, when not being used, add one word of overhead
959
- to each variable and slow down the system in the worst case by
960
- less than 1%. In average, no slowdown can be observed.
961
-
962
- [ENTRY]
963
- Module: int
964
- What: bug
965
- Rank: minor
966
- [DESCRIPTION]
967
- Fixed a border-case bug for n-ary Boolean conjunction and disjunction.
968
-
969
- [ENTRY]
970
- Module: kernel
971
- What: new
972
- Rank: minor
973
- [DESCRIPTION]
974
- A new propagation condition PC_GEN_NONE (and hence, PC_INT_NONE,
975
- ...) has been introduced. Propagator patterns with this
976
- propagation condition now do not create any subscriptions.
977
-
978
- [ENTRY]
979
- Module: int
980
- What: performance
981
- Rank: major
982
- [DESCRIPTION]
983
- The regular constraint has been reimplemented, the new version
984
- runs more than twice as fast.
985
-
986
- [ENTRY]
987
- Module: example
988
- What: new
989
- Rank: minor
990
- [DESCRIPTION]
991
- Added a model for the traveling salesman problem, mostly
992
- intended to exercise the new circuit constraint (as the model is not
993
- very competitive).
994
-
995
- [ENTRY]
996
- Module: kernel
997
- What: new
998
- Rank: major
999
- [DESCRIPTION]
1000
- Support for reference-counted shared objects added: they handle
1001
- both reference counting as well as non-shared copying. This fixes
1002
- some bugs with the handling of shared arrays, integer sets, and
1003
- finite automata.
1004
-
1005
-
1006
- [ENTRY]
1007
- Module: example
1008
- What: bug
1009
- Rank: minor
1010
- [DESCRIPTION]
1011
- Examples reported wrong number of propagator invocations (the
1012
- invocations for problem setup were missing).
1013
-
1014
- [ENTRY]
1015
- Module: kernel
1016
- What: new
1017
- Rank: major
1018
- [DESCRIPTION]
1019
- Added classes for shared objects and handles. Handles to shared
1020
- objects allow to either share copies among spaces when being
1021
- copied or to create a new shared copy, if requested.
1022
-
1023
- [ENTRY]
1024
- Module: int
1025
- What: new
1026
- Rank: minor
1027
- Thanks: Martin Mann
1028
- [DESCRIPTION]
1029
- Added a new version of count (and also atleast, atmost, exactly)
1030
- that counts the number of variables equal to integers in an
1031
- array.
1032
-
1033
- [ENTRY]
1034
- Module: example
1035
- What: bug
1036
- Rank: minor
1037
- Bug: 50
1038
- [DESCRIPTION]
1039
- The number of colors in graph-color was off by one.
1040
-
1041
- [ENTRY]
1042
- Module: int
1043
- What: new
1044
- Rank: major
1045
- [DESCRIPTION]
1046
- Added channel constraints that channel an integer variable to
1047
- either a single or an array of Boolean variables.
1048
-
1049
- [ENTRY]
1050
- Module: int
1051
- What: bug
1052
- Rank: minor
1053
- [DESCRIPTION]
1054
- Fixed bug in copying of n-ary or-propagator for a special boundary case.
1055
-
1056
- [ENTRY]
1057
- Module: int
1058
- What: new
1059
- Rank: minor
1060
- [DESCRIPTION]
1061
- Relaxed sharing restrictions for channel, in particular
1062
- channel(this, x, x) is allowed.
1063
-
1064
- [ENTRY]
1065
- Module: int
1066
- What: new
1067
- Rank: major
1068
- [DESCRIPTION]
1069
- Added propagators for the circuit constraint.
1070
-
1071
- [ENTRY]
1072
- Module: kernel
1073
- What: performance
1074
- Rank: minor
1075
- [DESCRIPTION]
1076
- Improved automatic memory management on Windows platforms.
1077
-
1078
- [ENTRY]
1079
- Module: int
1080
- What: performance
1081
- Rank: minor
1082
- [DESCRIPTION]
1083
- Domain consistent distinct and channel allocate memory from the
1084
- space heap now. Much simpler.
1085
-
1086
- [ENTRY]
1087
- Module: int
1088
- What: change
1089
- Rank: minor
1090
- [DESCRIPTION]
1091
- The Boolean tell operations one_none and zero_none now also
1092
- return a ModEvent and hence must be checked for failure. This is
1093
- needed for simpler advisors.
1094
-
1095
- [ENTRY]
1096
- Module: kernel
1097
- What: performance
1098
- Rank: major
1099
- [DESCRIPTION]
1100
- The memory management policies have been completely reworked. Now
1101
- memory requests are much more regular. Hence, memory is much more
1102
- likely to be returned to the operating system. Furthermore, the
1103
- flush member functions for actors have been removed (they were
1104
- unneeded) and actors and spaces now have allocated member
1105
- functions for returning how much memory is allocated by a space.
1106
-
1107
- Moreover, the memory reported by some propagators has been
1108
- ignored. Note that this flaw did not affect the benchmark figures
1109
- on the %Gecode webpage.
1110
-
1111
- [ENTRY]
1112
- Module: int
1113
- What: performance
1114
- Rank: minor
1115
- [DESCRIPTION]
1116
- The multiplication uses integer precision if possible for better
1117
- performance.
1118
-
1119
- [ENTRY]
1120
- Module: int
1121
- What: change
1122
- Rank: minor
1123
- [DESCRIPTION]
1124
- Integer and Boolean variables are now guaranteed to be
1125
- inspectable (that is, all const member functions work on them),
1126
- even though a space is failed. However, the variables might have
1127
- been modified during a tell operation that has failed.
1128
-
1129
- [ENTRY]
1130
- Module: minimodel
1131
- What: change
1132
- Rank: major
1133
- [DESCRIPTION]
1134
- Linear expressions and relations can also be created from Boolean
1135
- variables, with the restriction that Boolean relations cannot be
1136
- reified.
1137
-
1138
- [ENTRY]
1139
- Module: int
1140
- What: change
1141
- Rank: major
1142
- [DESCRIPTION]
1143
- Boolean variables (and hence Boolean views) do not any longer
1144
- share the implementation with integer variables. That has the
1145
- following consequences:
1146
- - Boolean variables are not any longer integer variables. The same
1147
- holds true for arrays of variables.
1148
- - All constraints that make sense for both Boolean and integer
1149
- variables have post functions that support both integer and
1150
- Boolean variables.
1151
- - Memory for Boolean variables is reduced by 50% and performance
1152
- increases in problems with many Boolean variables by up to 50%.
1153
-
1154
- [ENTRY]
1155
- Module: int
1156
- What: new
1157
- Rank: major
1158
- [DESCRIPTION]
1159
- Added propagators for linear constraints over Boolean variables,
1160
- in particular specialized and efficient versions for non-unit
1161
- coefficients.
1162
-
1163
- [ENTRY]
1164
- Module: int
1165
- What: change
1166
- Rank: minor
1167
- [DESCRIPTION]
1168
- The linear constraints are now more careful (that is, they will
1169
- use more efficient versions more often if it is safe) to
1170
- determine whether overflow occurs and which precision (integer or
1171
- double) should be chosen.
1172
-
1173
- [ENTRY]
1174
- Module: int
1175
- What: change
1176
- Rank: minor
1177
- [DESCRIPTION]
1178
- The element constraints now accept an additional offset argument.
1179
-
1180
- [ENTRY]
1181
- Module: set
1182
- What: new
1183
- Rank: minor
1184
- [DESCRIPTION]
1185
- Added selection and reified relation constraints with constant sets.
1186
-
1187
- [ENTRY]
1188
- Module: set
1189
- What: change
1190
- Rank: minor
1191
- [DESCRIPTION]
1192
- Slightly stronger inferences for the finite set sequence and selection
1193
- constraints.
1194
-
1195
- [ENTRY]
1196
- Module: example
1197
- What: new
1198
- Rank: minor
1199
- [DESCRIPTION]
1200
- New example: the balanced academic curriculum problem (problem 030 from
1201
- CSPlib).
1202
-
1203
- [ENTRY]
1204
- Module: set
1205
- What: bug
1206
- Rank: minor
1207
- [DESCRIPTION]
1208
- Fixed the n-ary partition propagator to handle overflow of the sum of
1209
- cardinalities correctly.
1210
-
1211
- [ENTRY]
1212
- Module: kernel
1213
- What: bug
1214
- Rank: minor
1215
- [DESCRIPTION]
1216
- Subscription to constant views now should use the propagate
1217
- member function from a variable implementation: it guarantees
1218
- execution of a propagator at least once (int and set views have
1219
- been adopted accordingly).
1220
-
1221
- [ENTRY]
1222
- Module: int
1223
- What: bug
1224
- Rank: major
1225
- Bug: 48
1226
- [DESCRIPTION]
1227
- Branching on maximum regret would always crash on non-range domains.
1228
-
1229
- [ENTRY]
1230
- Module: set
1231
- What: change
1232
- Rank: minor
1233
- [DESCRIPTION]
1234
- The finite set selection propagators accept an additional
1235
- argument that specifies where the indexing should start. It
1236
- should make some models more natural to express, and helps in
1237
- porting code from other systems, such as Prolog or Mozart. In
1238
- addition, the selectUnion propagator is now hand-written again,
1239
- resulting in better performance.
1240
-
1241
- [ENTRY]
1242
- Module: int
1243
- What: change
1244
- Rank: major
1245
- [DESCRIPTION]
1246
- All Boolean constraints got a new and regular interface. Rather
1247
- than providing different post functions for the different
1248
- constraints, the single post function rel is used: the Boolean
1249
- operation then is described by a value of type BoolOpType. In
1250
- addition, all Boolean propagators have been reimplemented for
1251
- better performance and less memory use.
1252
-
1253
- [ENTRY]
1254
- Module: test
1255
- What: new
1256
- Rank: minor
1257
- [DESCRIPTION]
1258
- Added simple testing for branchings.
1259
-
1260
- [ENTRY]
1261
- Module: kernel
1262
- What: change
1263
- Rank: major
1264
- [DESCRIPTION]
1265
- The way how propagators report subsumption and partial fixpoints
1266
- has changed. Now, a propagator must first call dispose (which
1267
- then cancels subscriptions and possibly frees external resources)
1268
- and only then can return that the propagator is subsumed. For
1269
- that purpose a new function Gecode::ES_SUBSUMED has been
1270
- defined. Likewise, ES_FIX_PARTIAL and ES_NOFIX_PARTIAL are
1271
- functions rather than member functions of Gecode::Propagator. The
1272
- benefit is that this saves memory and is more efficient.
1273
-
1274
- [ENTRY]
1275
- Module: int
1276
- What: change
1277
- Rank: minor
1278
- [DESCRIPTION]
1279
- The use of the consistency options were a little confusing, now
1280
- the rule is: the level of consistency increases from ICL_VAL to
1281
- ICL_BND to ICL_DOM.
1282
-
1283
- [ENTRY]
1284
- Module: minimodel
1285
- What: performance
1286
- Rank: minor
1287
- [DESCRIPTION]
1288
- Boolean expressions erroneously decomposed into ternary Boolean
1289
- constraints, while not incorrect rather inefficient for large
1290
- Boolean expressions.
1291
-
1292
- [ENTRY]
1293
- Module: kernel
1294
- What: change
1295
- Rank: minor
1296
- [DESCRIPTION]
1297
- Made all macros type safe.
1298
-
1299
- [ENTRY]
1300
- Module: kernel
1301
- What: new
1302
- Rank: major
1303
- [DESCRIPTION]
1304
- Added macro GECODE_REWRITE for rewriting propagators. It is strongly advised
1305
- to always use this macro!
1306
-
1307
- [ENTRY]
1308
- Module: example
1309
- What: bug
1310
- Rank: minor
1311
- Bug: 46
1312
- [DESCRIPTION]
1313
- Orientation of Sudokus now match the orientation in the specification-file.
1314
-
1315
- [ENTRY]
1316
- Module: example
1317
- What: new
1318
- Rank: minor
1319
- [DESCRIPTION]
1320
- New example: MineSweeper.
1321
-
1322
- [ENTRY]
1323
- Module: example
1324
- What: new
1325
- Rank: minor
1326
- [DESCRIPTION]
1327
- New example: Domino.
1328
-
1329
- [ENTRY]
1330
- Module: set
1331
- What: bug
1332
- Rank: minor
1333
- [DESCRIPTION]
1334
- Set projectors could subscribe with bogus propagation conditions.
1335
-
1336
- [ENTRY]
1337
- Module: set
1338
- What: performance
1339
- Rank: minor
1340
- [DESCRIPTION]
1341
- Performance of the tell operations on finite set variables was
1342
- improved. Especially the intersect operation benefits from this.
1343
-
1344
- [ENTRY]
1345
- Module: int
1346
- What: new
1347
- Rank: minor
1348
- [DESCRIPTION]
1349
- The element constraint now also supports integer values as result.
1350
-
1351
- [ENTRY]
1352
- Module: kernel
1353
- What: new
1354
- Rank: minor
1355
- [DESCRIPTION]
1356
- Add a generic class for assignments during search (similar to
1357
- generic branchings for views and values).
1358
-
1359
- [ENTRY]
1360
- Module: int
1361
- What: change
1362
- Rank: minor
1363
- [DESCRIPTION]
1364
- All branching classes for value and view selection are now
1365
- parametric.
1366
-
1367
- [ENTRY]
1368
- Module: int
1369
- What: change
1370
- Rank: minor
1371
- [DESCRIPTION]
1372
- Boolean variables cannot longer be initialized from an integer
1373
- variable. If needed, a channel propagator must be posted (added).
1374
-
1375
- [ENTRY]
1376
- Module: int
1377
- What: change
1378
- Rank: minor
1379
- [DESCRIPTION]
1380
- The equality constraints have been replaced by a variant of rel.
1381
-
1382
- [ENTRY]
1383
- Module: kernel
1384
- What: change
1385
- Rank: minor
1386
- [DESCRIPTION]
1387
- The propagator abstractions Inhom* have been renamed to Mix*.
1388
-
1389
- [ENTRY]
1390
- Module: int
1391
- What: change
1392
- Rank: minor
1393
- [DESCRIPTION]
1394
- The operations t_one, t_one_none, t_zero, t_zero_none for Boolean
1395
- views have been renamed to one, one_none, zero, zero_none.
1396
-
1397
- [ENTRY]
1398
- Module: kernel
1399
- What: performance
1400
- Rank: major
1401
- [DESCRIPTION]
1402
- Explicit disposal of actors has been reimplemented (the old
1403
- design was nothing but darn stupid). The memory overhead of
1404
- propagators is reduced by 40% for most propagators and 20% for
1405
- all. That is, a binary propagator takes 30% less memory and a
1406
- ternary propagator takes 25% less memory. Programs with many
1407
- binary or ternary propagators can run up to 20% faster.
1408
-
1409
- [ENTRY]
1410
- Module: kernel
1411
- What: change
1412
- Rank: minor
1413
- [DESCRIPTION]
1414
- Propagators and branchings that require disposal when a space is
1415
- deleted must now be explicitly registered via a force function
1416
- and explicitly deregistered by an unforce function.
1417
-
1418
- [ENTRY]
1419
- Module: int
1420
- What: bug
1421
- Rank: minor
1422
- [DESCRIPTION]
1423
- Fixed memory leak in reified dom constraint.
1424
-
1425
- [ENTRY]
1426
- Module: set
1427
- What: bug
1428
- Rank: minor
1429
- [DESCRIPTION]
1430
- Fixed memory leak in distinct constraint for sets.
1431
-
1432
- [ENTRY]
1433
- Module: example
1434
- What: new
1435
- Rank: major
1436
- [DESCRIPTION]
1437
- New example: Pentominoes. The example uses extensional
1438
- constraints specified as regular expressions to place
1439
- irregular-shaped pieces on a board.
1440
-
1441
-
1442
-
1443
- [RELEASE]
1444
- Version: 1.3.1
1445
- Date: 2006-10-25
1446
- [DESCRIPTION]
1447
- This is a minor release which fixes a major bug (the first real
1448
- serious bug). Please update as soon as possible.
1449
-
1450
- [ENTRY]
1451
- Module: kernel
1452
- What: bug
1453
- Rank: major
1454
- Thanks: Rafael Meneses
1455
- [DESCRIPTION]
1456
- Branch&Bound search with ViewValBranchings (all standard branchings) together
1457
- with batch recomputation was severely broken. The problems ranged from wrong
1458
- search trees (missing solutions) to segmentation faults. The fix changes the
1459
- way assigned variables are removed from the array in a ViewValBranching.
1460
-
1461
- [ENTRY]
1462
- Module: int
1463
- What: bug
1464
- Rank: minor
1465
- [DESCRIPTION]
1466
- Bounds-consistent distinct catches border case when an assigned variable
1467
- during bounds propagation leads to value removal for value propagation.
1468
-
1469
- [ENTRY]
1470
- Module: int
1471
- What: performance
1472
- Rank: minor
1473
- [DESCRIPTION]
1474
- Bounds-consistent distinct eliminates assigned variables more
1475
- aggressively (can save up to 10% runtime in some cases).
1476
-
1477
- [ENTRY]
1478
- Module: int
1479
- What: bug
1480
- Rank: minor
1481
- Thanks: Alejandro Arbelaez
1482
- [DESCRIPTION]
1483
- IntVar::init now also raises exceptions for illegal domain specifications.
1484
-
1485
-
1486
-
1487
-
1488
-
1489
- [RELEASE]
1490
- Version: 1.3.0
1491
- Date: 2006-09-19
1492
- [DESCRIPTION]
1493
- This release adds a compiler for finite set projectors and provides new
1494
- infrastructure making it easier to add new variable domains. In addition,
1495
- it contains recent bug fixes and minor improvements.
1496
-
1497
- [ENTRY]
1498
- Module: set
1499
- What: new
1500
- Rank: major
1501
- [DESCRIPTION]
1502
- Compiler for finite set projectors. Given a specification of a finite set
1503
- constraint as a projector set, it generates C++ code for the corresponding
1504
- propagator. Together with the dynamic propagator for finite set projectors,
1505
- this implements the backend of the technique described in the paper
1506
- "Generating Propagators for Finite Set Constraints" (Tack, Schulte,
1507
- Smolka; CP 2006.).
1508
-
1509
- [ENTRY]
1510
- Module: other
1511
- What: new
1512
- Rank: minor
1513
- Thanks: Jorge Marques Pelizzoni
1514
- [DESCRIPTION]
1515
- Also pass options for linking standard libraries for MSVC.
1516
-
1517
- [ENTRY]
1518
- Module: other
1519
- What: bug
1520
- Rank: minor
1521
- [DESCRIPTION]
1522
- The pkg-config files now contain the correct path if you configured to the
1523
- default prefix (i.e. /usr/local).
1524
-
1525
- [ENTRY]
1526
- Module: minimodel
1527
- What: new
1528
- Rank: minor
1529
- [DESCRIPTION]
1530
- Added aliases lex, atleast, atmost, and exactly for the count constraint.
1531
-
1532
- [ENTRY]
1533
- Module: int
1534
- What: change
1535
- Rank: minor
1536
- [DESCRIPTION]
1537
- Renamed lex constraint to rel (as it also supports equality and disequality).
1538
-
1539
- [ENTRY]
1540
- Module: int
1541
- What: performance
1542
- Rank: minor
1543
- [DESCRIPTION]
1544
- Make count constraints with integer number of equal occurrences
1545
- more incremental using dynamic subscriptions (gives a 20-30%
1546
- speedup).
1547
-
1548
- [ENTRY]
1549
- Module: example
1550
- What: new
1551
- Rank: minor
1552
- [DESCRIPTION]
1553
- Added an example for solving Black Hole patience games.
1554
-
1555
- [ENTRY]
1556
- Module: kernel
1557
- What: new
1558
- Rank: major
1559
- [DESCRIPTION]
1560
- Subscription to variables now features an additional and optional
1561
- Boolean argument whether the propagator is to be processed. This
1562
- allows dynamically creation of subscriptions during propagation.
1563
-
1564
- [ENTRY]
1565
- Module: other
1566
- What: new
1567
- Rank: minor
1568
- [DESCRIPTION]
1569
- New configure switches: --enable-audit to include audit code, which may
1570
- contain expensive checks of internal invariants or alternative, checked
1571
- implementations of critical parts of %Gecode. --enable-universal and
1572
- --with-sdk, to support building universal binaries on Mac OS X.
1573
-
1574
- [ENTRY]
1575
- Module: kernel
1576
- What: new
1577
- Rank: minor
1578
- [DESCRIPTION]
1579
- Variables can now be deallocated when the Space is deallocated (for example in
1580
- case of failure). This is important in case a variable implementation needs to
1581
- reference external resources. Deallocation can be switched on in the
1582
- high-level description used for generating the variable implementation.
1583
-
1584
- [ENTRY]
1585
- Module: minimodel
1586
- What: bug
1587
- Rank: minor
1588
- Thanks: Rafael Meneses
1589
- [DESCRIPTION]
1590
- Under certain conditions (posting in a failed space), the post function
1591
- returned uninitialized variables.
1592
-
1593
- [ENTRY]
1594
- Module: kernel
1595
- What: performance
1596
- Rank: major
1597
- [DESCRIPTION]
1598
- Variable implementations are now generated from a high-level
1599
- description (taking care of all aspects relating to modification
1600
- events and propagation conditions). While simplifying the
1601
- implementation of new variable domains considerably, this also can,
1602
- in lucky cases, deliver a speed-up of 5%.
1603
-
1604
- [ENTRY]
1605
- Module: kernel
1606
- What: performance
1607
- Rank: major
1608
- [DESCRIPTION]
1609
- Allocate subscriptions in separate memory area. Can speedup execution
1610
- in some (but few) cases by up to 15-20%.
1611
-
1612
- [ENTRY]
1613
- Module: int
1614
- What: documentation
1615
- Rank: minor
1616
- Bug: 43
1617
- [DESCRIPTION]
1618
- Fixed documentation problem due to doxygen...
1619
-
1620
- [ENTRY]
1621
- Module: search
1622
- What: new
1623
- Rank: major
1624
- [DESCRIPTION]
1625
- Branch-and-bound search now interleaves recomputation with adding
1626
- bounding constraints. This can prune the search tree much
1627
- earlier: instead of recomputing many nodes from the same copy
1628
- node and then adding a constraint that fails all these nodes, it
1629
- might be possible to already fail the copy node directly. In
1630
- principle, the difference can be exponential, however for
1631
- examples we tried the effect is minor.
1632
-
1633
- [ENTRY]
1634
- Module: kernel
1635
- What: bug
1636
- Rank: minor
1637
- [DESCRIPTION]
1638
- Now commits can be interleaved with adding new constraints during
1639
- batch recomputation. This also entails that commit does not raise
1640
- an exception when applied to an already failed space (it is
1641
- simply ignored). The bug could not be observed (unless you did
1642
- some very fancy search engines yourself) and one could actually
1643
- see it as an extension.
1644
-
1645
-
1646
-
1647
-
1648
- [RELEASE]
1649
- Version: 1.2.2
1650
- Date: 2006-07-25
1651
- [DESCRIPTION]
1652
- This release switches recomputation back on and removes some
1653
- experimental code that had sneaked into the system...
1654
-
1655
- [ENTRY]
1656
- Module: kernel
1657
- What: performance
1658
- Rank: major
1659
- [DESCRIPTION]
1660
- Some experimental code had sneaked into the release, slowing down
1661
- the system by more than 10%...
1662
-
1663
- [ENTRY]
1664
- Module: search
1665
- What: bug
1666
- Rank: major
1667
- [DESCRIPTION]
1668
- With the changes to search in %Gecode 1.2.1 recomputation was
1669
- actually almost switched off...
1670
-
1671
- [ENTRY]
1672
- Module: int
1673
- What: performance
1674
- Rank: minor
1675
- [DESCRIPTION]
1676
- Improve performance of domain-consistent distinct (by providing
1677
- special ternary version). Can reduce runtime by 10-20% for some
1678
- examples.
1679
-
1680
- [ENTRY]
1681
- Module: int
1682
- What: performance
1683
- Rank: minor
1684
- [DESCRIPTION]
1685
- Cut memory requirements for element (for integer arrays) by half.
1686
-
1687
- [ENTRY]
1688
- Module: example
1689
- What: new
1690
- Rank: minor
1691
- [DESCRIPTION]
1692
- Added stress test for element constraint (originally due to Neng-Fa Zhou).
1693
-
1694
- [ENTRY]
1695
- Module: example
1696
- What: new
1697
- Rank: minor
1698
- [DESCRIPTION]
1699
- Added stress test for min constraint.
1700
-
1701
- [ENTRY]
1702
- Module: example
1703
- What: new
1704
- Rank: minor
1705
- [DESCRIPTION]
1706
- Added possibility to stop the search for solutions in examples based
1707
- on the time taken, the number of fails, or both.
1708
-
1709
- [ENTRY]
1710
- Module: example
1711
- What: new
1712
- Rank: minor
1713
- [DESCRIPTION]
1714
- Added an example for solving Peacable co-existing armies of %Queens.
1715
-
1716
-
1717
-
1718
- [RELEASE]
1719
- Version: 1.2.1
1720
- Date: 2006-07-19
1721
- [DESCRIPTION]
1722
- In addition to the usual fixes and improvements, the biggest
1723
- change is that all branchings now must support branching
1724
- descriptions. This also entails straightforward changes
1725
- (simplifications) to search-related space operations and to the
1726
- implementation of search engines.
1727
-
1728
-
1729
- [ENTRY]
1730
- Module: kernel
1731
- What: new
1732
- Rank: minor
1733
- [DESCRIPTION]
1734
- Added a macro GECODE_NEVER that assert that this command is never
1735
- executed. This is preferred over assert(false) as it is used for
1736
- optimization, if supported by a compiler (for example, Microsoft
1737
- Visual C++).
1738
-
1739
- [ENTRY]
1740
- Module: int
1741
- What: bug
1742
- Rank: minor
1743
- [DESCRIPTION]
1744
- Fixed fixpoint detection bug in n-ary min and max propagators.
1745
-
1746
- [ENTRY]
1747
- Module: int
1748
- What: bug
1749
- Rank: minor
1750
- [DESCRIPTION]
1751
- Min and max propagators now correctly handle cases such as min(x,y)=x.
1752
-
1753
- [ENTRY]
1754
- Module: int
1755
- What: removed
1756
- Rank: minor
1757
- [DESCRIPTION]
1758
- Removed bounds-consistent propagation for count constraint (not worth
1759
- the trouble, just use domain-consistent).
1760
-
1761
- [ENTRY]
1762
- Module: kernel
1763
- What: change
1764
- Rank: minor
1765
- Thanks: Martin Mann
1766
- [DESCRIPTION]
1767
- The ViewValBranching class now passes the home space to all member
1768
- functions used in selecting the view and the value.
1769
-
1770
- [ENTRY]
1771
- Module: set
1772
- What: bug
1773
- Rank: minor
1774
- [DESCRIPTION]
1775
- Fixed fixpoint detection for n-ary partition propagator.
1776
-
1777
- [ENTRY]
1778
- Module: set
1779
- What: new
1780
- Rank: major
1781
- [DESCRIPTION]
1782
- Added finite set projection propagators. They allow to propagate all
1783
- finite set constraints expressible as finite set projectors, including
1784
- negated and reified constraints.
1785
-
1786
- [ENTRY]
1787
- Module: support
1788
- What: new
1789
- Rank: minor
1790
- [DESCRIPTION]
1791
- Added simple class encapsulating a linear congruential pseudo-random
1792
- number generator.
1793
-
1794
- [ENTRY]
1795
- Module: kernel
1796
- What: change
1797
- Rank: major
1798
- [DESCRIPTION]
1799
- The interface for branchings has changed considerably, reflecting
1800
- the fact now that all branchings must support branching descriptions.
1801
- This is also reflected in the Space::status operation which has its
1802
- arguments reversed and corrected const qualifiers on its arguments.
1803
- But the good news is that it is considerably simpler than before.
1804
-
1805
- [ENTRY]
1806
- Module: int
1807
- What: bug
1808
- Rank: minor
1809
- [DESCRIPTION]
1810
- Assignment branchings (that is, branchings with a single alternative)
1811
- could possibly take the wrong values for assignment during recomputation.
1812
-
1813
- [ENTRY]
1814
- Module: kernel
1815
- What: change
1816
- Rank: major
1817
- [DESCRIPTION]
1818
- The status operation does not any longer accept an argument for
1819
- the number of alternatives. The number of alternatives is now
1820
- available from a branching description (where it is passed upon
1821
- creation of the description). This reflects the fact that
1822
- branching descriptions are mandatory now.
1823
-
1824
- [ENTRY]
1825
- Module: search
1826
- What: bug
1827
- Rank: major
1828
- [DESCRIPTION]
1829
- Fixed a serious bug where during recomputation the search stack
1830
- was always inspected behind the last element: the reason why
1831
- recomputation never crashed has been that stacks always keep one
1832
- element extra for optimization. So, serious bug but looks as if
1833
- no one stumbled over this...
1834
-
1835
- [ENTRY]
1836
- Module: kernel
1837
- What: bug
1838
- Rank: minor
1839
- [DESCRIPTION]
1840
- As Boolean variables can be derived from integer variables, the
1841
- assumption that a not yet assigned Boolean variable can not be
1842
- modified is wrong.
1843
-
1844
- [ENTRY]
1845
- Module: other
1846
- What: documentation
1847
- Rank: minor
1848
- [DESCRIPTION]
1849
- Generate one page per version released in changelog.
1850
-
1851
- [ENTRY]
1852
- Module: kernel
1853
- What: change
1854
- Rank: minor
1855
- Bug: 41
1856
- [DESCRIPTION]
1857
- Change exceptions thrown by %Gecode to be compliant with C++
1858
- exceptions.
1859
-
1860
- [ENTRY]
1861
- Module: other
1862
- What: bug
1863
- Rank: minor
1864
- Bug: 42
1865
- [DESCRIPTION]
1866
- Renamed macros so as to avoid nameclashes (all macros start with
1867
- GECODE_).
1868
-
1869
- [ENTRY]
1870
- Module: search
1871
- What: bug
1872
- Rank: minor
1873
- [DESCRIPTION]
1874
- Search engines now correctly count the number of propagation
1875
- steps including propagation that occurs when adaptive
1876
- recomputation creates additional clones.
1877
-
1878
- [ENTRY]
1879
- Module: search
1880
- What: change
1881
- Rank: major
1882
- [DESCRIPTION]
1883
- Branchings now must return branching descriptions and commit
1884
- operations also insist on being provided with branching
1885
- descriptions. This change reflects that batch recomputation is
1886
- of vital importance for efficiency in %Gecode.
1887
-
1888
- [ENTRY]
1889
- Module: int
1890
- What: performance
1891
- Rank: major
1892
- [DESCRIPTION]
1893
- Make Boolean linear constraints with constant right hand sides
1894
- more incremental using dynamic subscriptions (gives a 20-30% speedup).
1895
-
1896
- [ENTRY]
1897
- Module: minimodel
1898
- What: performance
1899
- Rank: minor
1900
- [DESCRIPTION]
1901
- Take advantage of specialized Boolean propagators in Boolean
1902
- expressions and relations.
1903
-
1904
- [ENTRY]
1905
- Module: int
1906
- What: performance
1907
- Rank: minor
1908
- [DESCRIPTION]
1909
- Made n-ary Boolean conjunction and disjunction more incremental by
1910
- using dynamic subscriptions.
1911
-
1912
- [ENTRY]
1913
- Module: int
1914
- What: performance
1915
- Rank: minor
1916
- [DESCRIPTION]
1917
- Provide special versions of Boolean propagators optimizing cases
1918
- where n-ary disjunctions are true.
1919
-
1920
- [ENTRY]
1921
- Module: int
1922
- What: performance
1923
- Rank: minor
1924
- [DESCRIPTION]
1925
- Change implementation of Boolean propagators from conjunction
1926
- to disjunction so that disjunction can be used as special case
1927
- for Boolean sum with inequalities.
1928
-
1929
-
1930
- [RELEASE]
1931
- Version: 1.2.0
1932
- Date: 2006-06-20
1933
- [DESCRIPTION]
1934
- This release makes quite some drastic changes to how propagators
1935
- and branchings are deleted: instead of using destructors they use
1936
- a dispose method that allows passing a home space during deletion
1937
- (we will use this infrastructure measure to speed up cloning
1938
- considerably a little later). Moreover the directory structure
1939
- has changed on popular request so that all include files are to
1940
- be found in a gecode subdirectory. Apart from that, some small
1941
- fixes and extensions due to requests.
1942
-
1943
- [ENTRY]
1944
- Module: set
1945
- What: bug
1946
- Rank: minor
1947
- Thanks: Luis Otero
1948
- [DESCRIPTION]
1949
- Fixed memory leak in finite set distinct propagator.
1950
-
1951
- [ENTRY]
1952
- Module: int
1953
- What: bug
1954
- Rank: minor
1955
- [DESCRIPTION]
1956
- Fixed memory leak in global cardinality constraint.
1957
-
1958
- [ENTRY]
1959
- Module: int
1960
- What: bug
1961
- Rank: minor
1962
- Thanks: Martin Mann
1963
- [DESCRIPTION]
1964
- Fixed bug in equality tests that could lead to reified (dis)equality
1965
- propagators not achieving domain consistency.
1966
-
1967
- [ENTRY]
1968
- Module: test
1969
- What: new
1970
- Rank: minor
1971
- [DESCRIPTION]
1972
- Added --enable-leak-debug configure option. This option causes the test suite
1973
- to call mtrace() under Linux, which can be used to test for memory leaks.
1974
-
1975
- [ENTRY]
1976
- Module: kernel
1977
- What: performance
1978
- Rank: minor
1979
- [DESCRIPTION]
1980
- More aggressive inlining for canceling subscriptions.
1981
-
1982
- [ENTRY]
1983
- Module: search
1984
- What: bug
1985
- Rank: minor
1986
- Bug: 39
1987
- [DESCRIPTION]
1988
- Fixed linkage of BAB destructor under Cygwin.
1989
-
1990
- [ENTRY]
1991
- Module: kernel
1992
- What: change
1993
- Rank: minor
1994
- [DESCRIPTION]
1995
- The branch member function for branchings now also takes a home space
1996
- as argument.
1997
-
1998
- [ENTRY]
1999
- Module: kernel
2000
- What: change
2001
- Rank: major
2002
- [DESCRIPTION]
2003
- Canceling subscriptions on views and variable implementations now
2004
- require also a home space (this has become possible due to not using
2005
- destructors but ordinary "dispose" member functions).
2006
-
2007
- [ENTRY]
2008
- Module: kernel
2009
- What: change
2010
- Rank: major
2011
- [DESCRIPTION]
2012
- Actors (propagators and branchings) do not any longer use destructors
2013
- but a "dispose" member function that takes a home space as argument
2014
- and must return the size of the actor.
2015
- Important: this requires that dispose member functions from super-classes
2016
- and class members are called explicitly!
2017
-
2018
- [ENTRY]
2019
- Module: kernel
2020
- What: new
2021
- Rank: minor
2022
- [DESCRIPTION]
2023
- Spaces can be queried for number of propagators and branchings.
2024
-
2025
- [ENTRY]
2026
- Module: search
2027
- What: new
2028
- Rank: minor
2029
- [DESCRIPTION]
2030
- Search engines can now be checked whether they have been stopped.
2031
-
2032
- [ENTRY]
2033
- Module: int
2034
- What: documentation
2035
- Rank: minor
2036
- Thanks: Martin Mann
2037
- [DESCRIPTION]
2038
- Fixed bug in description of PC_INT_DOM.
2039
-
2040
- [ENTRY]
2041
- Module: other
2042
- What: change
2043
- Rank: major
2044
- Thanks: Martin Mann
2045
- [DESCRIPTION]
2046
- Moved library source code into gecode subdirectory. Facilitates cleaner
2047
- installation. Programs compiling against %Gecode now need to include
2048
- e.g. "gecode/int.hh".
2049
-
2050
- [ENTRY]
2051
- Module: example
2052
- What: change
2053
- Rank: minor
2054
- [DESCRIPTION]
2055
- Sudoku example generalized to arbitrarily sized Sudokus.
2056
-
2057
- [RELEASE]
2058
- Version: 1.1.0
2059
- Date: 2006-04-10
2060
- [DESCRIPTION]
2061
- This minor release adds some new constraints (see below), adds support
2062
- for stopping search engines based on definable criteria, and some other
2063
- small fixes. Most notably, the test infrastructure has been extended to
2064
- also check whether propagators correctly claim that they have computed
2065
- a fixpoint (now all invariants a propagator must obey in %Gecode are covered
2066
- by the test infrastructure). This has lead to many small fixes.
2067
-
2068
- [ENTRY]
2069
- Module: other
2070
- What: bug
2071
- Bug: 37
2072
- Rank: minor
2073
- Thanks: Kari Pahula
2074
- [DESCRIPTION]
2075
- Added a configure switch --enable-doc-dot. If enabled, this checks for
2076
- presence of the dot tool (used for generating graphs in the documentation)
2077
-
2078
- [ENTRY]
2079
- Module: example
2080
- What: new
2081
- Rank: minor
2082
- [DESCRIPTION]
2083
- Added all-interval series using distinct.
2084
-
2085
- [ENTRY]
2086
- Module: minimodel
2087
- What: new
2088
- Rank: minor
2089
- [DESCRIPTION]
2090
- Added functions returning variables for arithmetic
2091
- (min, max, abs, mult, plus, minus).
2092
-
2093
- [ENTRY]
2094
- Module: int
2095
- What: change
2096
- Rank: minor
2097
- [DESCRIPTION]
2098
- Support for shared views has been removed in
2099
- sortedness propagator and in the propagator
2100
- for global cardinality with fixed cardinalities.
2101
-
2102
- [ENTRY]
2103
- Module: int
2104
- What: bug
2105
- Rank: minor
2106
- [DESCRIPTION]
2107
- Fixed bug in fixpoint detection of sortedness and
2108
- global cardinality propagator.
2109
-
2110
- [ENTRY]
2111
- Module: set
2112
- What: bug
2113
- Rank: minor
2114
- Bug: 36
2115
- Thanks: Javier Mena
2116
- [DESCRIPTION]
2117
- A non-debug version of %Gecode could not be linked to a program compiled with
2118
- assertions switched on, as BndSet::isConsistent was missing from the library.
2119
-
2120
- [ENTRY]
2121
- Module: int
2122
- What: change
2123
- Rank: minor
2124
- [DESCRIPTION]
2125
- Staged propagation for domain-consistent absolute value propagator
2126
-
2127
- [ENTRY]
2128
- Module: int
2129
- What: change
2130
- Rank: minor
2131
- [DESCRIPTION]
2132
- EqBnd and EqDom now take two template parameters for their view types. This
2133
- supports using different views, e.g. to express x0=-x1 using a MinusView.
2134
-
2135
- [ENTRY]
2136
- Module: search
2137
- What: new
2138
- Rank: major
2139
- Thanks: Rafael Meneses
2140
- [DESCRIPTION]
2141
- Added functionality to interrupt search engines (introduced
2142
- a Search::Stop class).
2143
-
2144
- [ENTRY]
2145
- Module: search
2146
- What: change
2147
- Rank: major
2148
- [DESCRIPTION]
2149
- Removed search engines optimizing for copying only (after
2150
- all, one should always use some recomputation).
2151
-
2152
- [ENTRY]
2153
- Module: int
2154
- What: bug
2155
- Rank: minor
2156
- [DESCRIPTION]
2157
- Fixed bug in fixpoint detection of n-ary maximum/minimum
2158
- propagator.
2159
-
2160
- [ENTRY]
2161
- Module: kernel
2162
- What: change
2163
- Rank: minor
2164
- [DESCRIPTION]
2165
- The status member function now also allows the first
2166
- argument to be optional.
2167
-
2168
- [ENTRY]
2169
- Module: set
2170
- What: bug
2171
- Rank: minor
2172
- [DESCRIPTION]
2173
- Fixed bugs in fixpoint detection of several set propagators (match,
2174
- convexity, sequence, n-ary (disjoint) union).
2175
-
2176
- [ENTRY]
2177
- Module: int
2178
- What: bug
2179
- Rank: minor
2180
- [DESCRIPTION]
2181
- Fixed bug in fixpoint detection of bounds-consistent
2182
- element for variables propagator.
2183
-
2184
- [ENTRY]
2185
- Module: int
2186
- What: bug
2187
- Rank: minor
2188
- [DESCRIPTION]
2189
- Fixed bug in fixpoint detection of bounds-consistent squaring
2190
- propagator (mult with the same variable twice).
2191
-
2192
- [ENTRY]
2193
- Module: int
2194
- What: bug
2195
- Rank: minor
2196
- [DESCRIPTION]
2197
- Fixed bug in fixpoint detection of bounds-consistent abs
2198
- propagator.
2199
-
2200
- [ENTRY]
2201
- Module: int
2202
- What: performance
2203
- Rank: minor
2204
- [DESCRIPTION]
2205
- Rewrite n-ary linear, min/max, and Boolean propagators to binary/ternary
2206
- variants during cloning if possible (saves memory).
2207
-
2208
- [ENTRY]
2209
- Module: int
2210
- What: bug
2211
- Rank: minor
2212
- Thanks: Stefano Gualandi
2213
- [DESCRIPTION]
2214
- Fixed wrong assertion in gcc-bnd propagator.
2215
-
2216
- [ENTRY]
2217
- Module: int
2218
- What: bug
2219
- Rank: major
2220
- Thanks: Jean-Christophe Godart
2221
- [DESCRIPTION]
2222
- Fixed indexing bug in SupportSet (part of the domain consistent linear
2223
- equation propagator).
2224
-
2225
- [ENTRY]
2226
- Module: int
2227
- What: new
2228
- Rank: major
2229
- [DESCRIPTION]
2230
- Added new constraint channel for variable/value channeling
2231
- between two variable arrays.
2232
-
2233
- [ENTRY]
2234
- Module: int
2235
- What: change
2236
- Rank: minor
2237
- [DESCRIPTION]
2238
- All distinct propagators raise an exception if a variable occurs
2239
- multiply in its arguments.
2240
-
2241
- [ENTRY]
2242
- Module: set
2243
- What: change
2244
- Rank: major
2245
- [DESCRIPTION]
2246
- Renamed the set propagators minElement to min, maxElement to max,
2247
- and channelVarVal to channel.
2248
-
2249
- [ENTRY]
2250
- Module: int
2251
- What: performance
2252
- Rank: major
2253
- [DESCRIPTION]
2254
- Improved initialization of domain-consistent distinct propagator,
2255
- in common cases for distinct this can save up to 10% runtime.
2256
-
2257
- [ENTRY]
2258
- Module: set
2259
- What: bug
2260
- Rank: minor
2261
- Thanks: Patrick Pekczynski
2262
- [DESCRIPTION]
2263
- Fixed off-by-one bug in SetVarImp::lubMinN and SetVarImp::lubMaxN.
2264
-
2265
- [ENTRY]
2266
- Module: minimodel
2267
- What: bug
2268
- Rank: minor
2269
- Thanks: Olof Sivertsson
2270
- [DESCRIPTION]
2271
- (In-)Equations were still not correct with respect to the sign.
2272
-
2273
- [ENTRY]
2274
- Module: minimodel
2275
- What: bug
2276
- Rank: minor
2277
- Bug: 33
2278
- Thanks: Olof Sivertsson
2279
- [DESCRIPTION]
2280
- Slice-operation now returns elements in right order.
2281
-
2282
- [ENTRY]
2283
- Module: minimodel
2284
- What: bug
2285
- Rank: minor
2286
- Bug: 32
2287
- Thanks: Olof Sivertsson
2288
- [DESCRIPTION]
2289
- Possible array-out-of bounds access fixed for MiniModel::Matrix.
2290
-
2291
- [ENTRY]
2292
- Module: example
2293
- What: performance
2294
- Rank: minor
2295
- [DESCRIPTION]
2296
- Added redundant constraint to social golfers example.
2297
-
2298
-
2299
-
2300
-
2301
- [RELEASE]
2302
- Version: 1.0.1
2303
- Date: 2006-03-01
2304
- [DESCRIPTION]
2305
- Maintenance release including some additions of domain-consistent
2306
- propagators and a fix for a serious bug in reified linear
2307
- inequalities.
2308
-
2309
- [ENTRY]
2310
- Module: search
2311
- What: change
2312
- Rank: minor
2313
- [DESCRIPTION]
2314
- Changed default copying recomputation distance to 8.
2315
-
2316
- [ENTRY]
2317
- Module: minimodel
2318
- What: bug
2319
- Rank: minor
2320
- Thanks: Olof Sivertsson
2321
- [DESCRIPTION]
2322
- (In-)Equations with an int on the left hand side (like 9==x) were
2323
- translated with a wrong sign (as -9==x).
2324
-
2325
- [ENTRY]
2326
- Module: other
2327
- What: bug
2328
- Rank: minor
2329
- Bug: 31
2330
- [DESCRIPTION]
2331
- The preprocessor macro NDEBUG for disabling assertions is no longer
2332
- put into config.icc. Without this fix, user programs could not use
2333
- assert if %Gecode was compiled with NDEBUG.
2334
-
2335
- [ENTRY]
2336
- Module: minimodel
2337
- What: new
2338
- Rank: minor
2339
- [DESCRIPTION]
2340
- The post functions for linear expressions and relations also take
2341
- an integer consistency level as optional argument.
2342
-
2343
- [ENTRY]
2344
- Module: int
2345
- What: new
2346
- Rank: major
2347
- [DESCRIPTION]
2348
- Added domain-consistent linear equalities.
2349
-
2350
- [ENTRY]
2351
- Module: int
2352
- What: bug
2353
- Rank: minor
2354
- Bug: 30
2355
- [DESCRIPTION]
2356
- Fixed fixpoint detection for ternary min and max.
2357
-
2358
- [ENTRY]
2359
- Module: int
2360
- What: bug
2361
- Rank: minor
2362
- [DESCRIPTION]
2363
- Fixed subsumption detection for regular with multiple variable occurences.
2364
-
2365
- [ENTRY]
2366
- Module: int
2367
- What: change
2368
- Rank: minor
2369
- [DESCRIPTION]
2370
- Cost computation for sortedness has been changed from static to
2371
- dynamic (taking into account the variable reduction the
2372
- propagator can perform).
2373
-
2374
- [ENTRY]
2375
- Module: int
2376
- What: change
2377
- Rank: major
2378
- [DESCRIPTION]
2379
- Global cardinality changed to non-staged version. Further
2380
- inference for cardinality variables added. Parts of the graph
2381
- structure for the domain-consistent propagator have been revised
2382
- so as to avoid unnecessary propagation in case of fixed
2383
- cardinalities and to allow better staging for the
2384
- propagator. Revision of propagation for fixed cardinalities has
2385
- also been applied to bounds-consistent propagator.
2386
-
2387
- [ENTRY]
2388
- Module: int
2389
- What: new
2390
- Rank: major
2391
- [DESCRIPTION]
2392
- Added domain-consistent version of the absolute value propagator.
2393
-
2394
- [ENTRY]
2395
- Module: other
2396
- What: performance
2397
- Rank: major
2398
- [DESCRIPTION]
2399
- Switch assertions off in optimized builds with Microsoft's C++ compiler.
2400
-
2401
- [ENTRY]
2402
- Module: int
2403
- What: bug
2404
- Rank: major
2405
- Bug: 29
2406
- Thanks: Dominik Brill
2407
- [DESCRIPTION]
2408
- Fixed a very serious bug in the reified linear inequality propagator.
2409
-
2410
- [ENTRY]
2411
- Module: other
2412
- What: bug
2413
- Rank: minor
2414
- Thanks: Filip Konvicka
2415
- [DESCRIPTION]
2416
- Removed some compiler warnings for the Microsoft compiler with -W3.
2417
-
2418
- [ENTRY]
2419
- Module: int
2420
- What: bug
2421
- Rank: major
2422
- Bug: 27
2423
- [DESCRIPTION]
2424
- The strongly connected components represented by the permutation
2425
- variables in the extended version of Sortedness has been fixed
2426
- restoring bounds consistency on the permutation variables.
2427
-
2428
- [ENTRY]
2429
- Module: other
2430
- What: change
2431
- Rank: minor
2432
- Bug: 24
2433
- [DESCRIPTION]
2434
- The soname for libraries on Linux is now set properly, as well as the
2435
- version information on Darwin (Mac OS).
2436
-
2437
- [ENTRY]
2438
- Module: other
2439
- What: change
2440
- Rank: minor
2441
- Bug: 25
2442
- [DESCRIPTION]
2443
- The build system has been updated to support building both static and
2444
- shared libraries at the same time on Unix-like systems.
2445
-
2446
- [ENTRY]
2447
- Module: example
2448
- What: change
2449
- Rank: minor
2450
- [DESCRIPTION]
2451
- Examples now use per default the recomputation settings as
2452
- defined in the search module.
2453
-
2454
- [RELEASE]
2455
- Version: 1.0.0
2456
- Date: 2005-12-06
2457
- [DESCRIPTION]
2458
- Initial release.
2459
-