gecoder-with-gecode 0.7.1 → 0.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1063) hide show
  1. data/CHANGES +7 -0
  2. data/README +10 -1
  3. data/ext/extconf.rb +24 -7
  4. data/ext/gecode-2.1.1/LICENSE +25 -0
  5. data/ext/gecode-2.1.1/Makefile.contribs +86 -0
  6. data/ext/gecode-2.1.1/Makefile.dep +7622 -0
  7. data/ext/gecode-2.1.1/Makefile.in +1568 -0
  8. data/ext/gecode-2.1.1/changelog.in +2459 -0
  9. data/ext/gecode-2.1.1/configure +11631 -0
  10. data/ext/gecode-2.1.1/configure.ac +249 -0
  11. data/ext/gecode-2.1.1/configure.ac.in +245 -0
  12. data/ext/{gecode-1.3.1 → gecode-2.1.1}/contribs/README +0 -0
  13. data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +263 -0
  14. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +82 -0
  15. data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +37 -0
  16. data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +162 -0
  17. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +172 -0
  18. data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +63 -0
  19. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +37 -0
  20. data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +35 -0
  21. data/ext/gecode-2.1.1/contribs/qecode/configure +2264 -0
  22. data/ext/gecode-2.1.1/contribs/qecode/configure.ac +23 -0
  23. data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +13 -0
  24. data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +144 -0
  25. data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +73 -0
  26. data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +179 -0
  27. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +34 -0
  28. data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +46 -0
  29. data/ext/gecode-2.1.1/contribs/qecode/heap.cc +151 -0
  30. data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +595 -0
  31. data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +184 -0
  32. data/ext/gecode-2.1.1/contribs/qecode/myDom.cc +39 -0
  33. data/ext/gecode-2.1.1/contribs/qecode/myspace.cc +69 -0
  34. data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +69 -0
  35. data/ext/gecode-2.1.1/contribs/qecode/qecode.hh +56 -0
  36. data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +145 -0
  37. data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +247 -0
  38. data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +168 -0
  39. data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +73 -0
  40. data/ext/gecode-2.1.1/contribs/qecode/shortdesc.ac +1 -0
  41. data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +91 -0
  42. data/ext/gecode-2.1.1/contribs/qecode/vartype.hh +31 -0
  43. data/ext/gecode-2.1.1/contribs/qecode/warner.cc +101 -0
  44. data/ext/gecode-2.1.1/contribs/qecode/warner.hh +83 -0
  45. data/ext/gecode-2.1.1/doxygen/doxygen.conf.in +1270 -0
  46. data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +1111 -0
  47. data/ext/gecode-2.1.1/doxygen/reflection.hh +417 -0
  48. data/ext/gecode-2.1.1/gecode.m4 +956 -0
  49. data/ext/gecode-2.1.1/gecode/cpltset.hh +797 -0
  50. data/ext/gecode-2.1.1/gecode/cpltset/array.cc +121 -0
  51. data/ext/gecode-2.1.1/gecode/cpltset/array.icc +81 -0
  52. data/ext/gecode-2.1.1/gecode/cpltset/bddmanager.cc +59 -0
  53. data/ext/gecode-2.1.1/gecode/cpltset/bddmanager.icc +448 -0
  54. data/ext/gecode-2.1.1/gecode/cpltset/branch.cc +68 -0
  55. data/ext/gecode-2.1.1/gecode/cpltset/branch.hh +208 -0
  56. data/ext/gecode-2.1.1/gecode/cpltset/branch/select-val.icc +167 -0
  57. data/ext/gecode-2.1.1/gecode/cpltset/branch/select-view.icc +143 -0
  58. data/ext/gecode-2.1.1/gecode/cpltset/constraints/atmost.cc +472 -0
  59. data/ext/gecode-2.1.1/gecode/cpltset/constraints/cardinality.cc +69 -0
  60. data/ext/gecode-2.1.1/gecode/cpltset/constraints/distinct.cc +83 -0
  61. data/ext/gecode-2.1.1/gecode/cpltset/constraints/dom.cc +147 -0
  62. data/ext/gecode-2.1.1/gecode/cpltset/constraints/partition.cc +383 -0
  63. data/ext/gecode-2.1.1/gecode/cpltset/constraints/rangeroots.cc +466 -0
  64. data/ext/gecode-2.1.1/gecode/cpltset/constraints/rel.cc +530 -0
  65. data/ext/gecode-2.1.1/gecode/cpltset/constraints/select.cc +126 -0
  66. data/ext/gecode-2.1.1/gecode/cpltset/constraints/singleton.cc +55 -0
  67. data/ext/gecode-2.1.1/gecode/cpltset/exception.icc +172 -0
  68. data/ext/gecode-2.1.1/gecode/cpltset/propagators.hh +335 -0
  69. data/ext/gecode-2.1.1/gecode/cpltset/propagators/binary.icc +260 -0
  70. data/ext/gecode-2.1.1/gecode/cpltset/propagators/nary.icc +210 -0
  71. data/ext/gecode-2.1.1/gecode/cpltset/propagators/naryone.icc +165 -0
  72. data/ext/gecode-2.1.1/gecode/cpltset/propagators/narytwo.icc +191 -0
  73. data/ext/gecode-2.1.1/gecode/cpltset/propagators/singleton.icc +130 -0
  74. data/ext/gecode-2.1.1/gecode/cpltset/propagators/unary.icc +132 -0
  75. data/ext/gecode-2.1.1/gecode/cpltset/support.cc +673 -0
  76. data/ext/gecode-2.1.1/gecode/cpltset/support.icc +696 -0
  77. data/ext/gecode-2.1.1/gecode/cpltset/var-imp.icc +487 -0
  78. data/ext/gecode-2.1.1/gecode/cpltset/var-imp/cpltset.cc +926 -0
  79. data/ext/gecode-2.1.1/gecode/cpltset/var-imp/cpltset.icc +687 -0
  80. data/ext/gecode-2.1.1/gecode/cpltset/var-imp/cpltset.vis +86 -0
  81. data/ext/gecode-2.1.1/gecode/cpltset/var/cpltset.cc +101 -0
  82. data/ext/gecode-2.1.1/gecode/cpltset/var/cpltset.icc +219 -0
  83. data/ext/gecode-2.1.1/gecode/cpltset/view.icc +231 -0
  84. data/ext/gecode-2.1.1/gecode/cpltset/view/cpltset.icc +420 -0
  85. data/ext/gecode-2.1.1/gecode/cpltset/view/print.cc +166 -0
  86. data/ext/gecode-2.1.1/gecode/gist.hh +162 -0
  87. data/ext/gecode-2.1.1/gecode/gist/addchild.cc +191 -0
  88. data/ext/gecode-2.1.1/gecode/gist/addchild.hh +76 -0
  89. data/ext/gecode-2.1.1/gecode/gist/addvisualisationdialog.cc +139 -0
  90. data/ext/gecode-2.1.1/gecode/gist/addvisualisationdialog.hh +78 -0
  91. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +115 -0
  92. data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +77 -0
  93. data/ext/gecode-2.1.1/gecode/gist/better.hh +59 -0
  94. data/ext/gecode-2.1.1/gecode/gist/config.cc +61 -0
  95. data/ext/gecode-2.1.1/gecode/gist/config.hh +62 -0
  96. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +245 -0
  97. data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +101 -0
  98. data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +522 -0
  99. data/ext/gecode-2.1.1/gecode/gist/gist.cc +129 -0
  100. data/ext/gecode-2.1.1/gecode/gist/gist.icc +76 -0
  101. data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +254 -0
  102. data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +86 -0
  103. data/ext/gecode-2.1.1/gecode/gist/node.cc +100 -0
  104. data/ext/gecode-2.1.1/gecode/gist/node.hh +89 -0
  105. data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +124 -0
  106. data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +122 -0
  107. data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +79 -0
  108. data/ext/gecode-2.1.1/gecode/gist/nodevisitor.hh +91 -0
  109. data/ext/gecode-2.1.1/gecode/gist/nodevisitor.icc +112 -0
  110. data/ext/gecode-2.1.1/gecode/gist/postscript.cc +543 -0
  111. data/ext/gecode-2.1.1/gecode/gist/postscript.hh +56 -0
  112. data/ext/gecode-2.1.1/gecode/gist/preferences.cc +110 -0
  113. data/ext/gecode-2.1.1/gecode/gist/preferences.hh +76 -0
  114. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +55 -0
  115. data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +58 -0
  116. data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +331 -0
  117. data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +140 -0
  118. data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +531 -0
  119. data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +224 -0
  120. data/ext/gecode-2.1.1/gecode/gist/test.cc +78 -0
  121. data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +114 -0
  122. data/ext/gecode-2.1.1/gecode/gist/textoutput.hh +67 -0
  123. data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +1140 -0
  124. data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +324 -0
  125. data/ext/gecode-2.1.1/gecode/gist/ui_addchild.hh +163 -0
  126. data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +163 -0
  127. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +175 -0
  128. data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +71 -0
  129. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +219 -0
  130. data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +73 -0
  131. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +123 -0
  132. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayview.cc +146 -0
  133. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayview.hh +96 -0
  134. data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayviewt.hh +105 -0
  135. data/ext/gecode-2.1.1/gecode/gist/visualisation/varitem.cc +68 -0
  136. data/ext/gecode-2.1.1/gecode/gist/visualisation/varitem.hh +67 -0
  137. data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +303 -0
  138. data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +166 -0
  139. data/ext/gecode-2.1.1/gecode/int.hh +2035 -0
  140. data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +136 -0
  141. data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +440 -0
  142. data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +279 -0
  143. data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +253 -0
  144. data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +522 -0
  145. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +218 -0
  146. data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +138 -0
  147. data/ext/gecode-2.1.1/gecode/int/array.cc +74 -0
  148. data/ext/gecode-2.1.1/gecode/int/array.icc +115 -0
  149. data/ext/gecode-2.1.1/gecode/int/bool.cc +642 -0
  150. data/ext/gecode-2.1.1/gecode/int/bool.hh +487 -0
  151. data/ext/gecode-2.1.1/gecode/int/bool/base.icc +156 -0
  152. data/ext/gecode-2.1.1/gecode/int/bool/eq.icc +239 -0
  153. data/ext/gecode-2.1.1/gecode/int/bool/eqv.icc +179 -0
  154. data/ext/gecode-2.1.1/gecode/int/bool/lq.icc +147 -0
  155. data/ext/gecode-2.1.1/gecode/int/bool/or.icc +1000 -0
  156. data/ext/gecode-2.1.1/gecode/int/branch.cc +301 -0
  157. data/ext/gecode-2.1.1/gecode/int/branch.hh +576 -0
  158. data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +338 -0
  159. data/ext/gecode-2.1.1/gecode/int/branch/select-view.icc +421 -0
  160. data/ext/gecode-2.1.1/gecode/int/channel.cc +114 -0
  161. data/ext/gecode-2.1.1/gecode/int/channel.hh +259 -0
  162. data/ext/gecode-2.1.1/gecode/int/channel/base.icc +86 -0
  163. data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +347 -0
  164. data/ext/gecode-2.1.1/gecode/int/channel/link-multi.cc +231 -0
  165. data/ext/gecode-2.1.1/gecode/int/channel/link-multi.icc +70 -0
  166. data/ext/gecode-2.1.1/gecode/int/channel/link-single.cc +97 -0
  167. data/ext/gecode-2.1.1/gecode/int/channel/link-single.icc +71 -0
  168. data/ext/gecode-2.1.1/gecode/int/channel/val.icc +276 -0
  169. data/ext/gecode-2.1.1/gecode/int/circuit.cc +63 -0
  170. data/ext/gecode-2.1.1/gecode/int/circuit.hh +175 -0
  171. data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +271 -0
  172. data/ext/gecode-2.1.1/gecode/int/circuit/dom.icc +146 -0
  173. data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +122 -0
  174. data/ext/gecode-2.1.1/gecode/int/count.cc +310 -0
  175. data/ext/gecode-2.1.1/gecode/int/count.hh +487 -0
  176. data/ext/gecode-2.1.1/gecode/int/count/int.icc +619 -0
  177. data/ext/gecode-2.1.1/gecode/int/count/rel.icc +144 -0
  178. data/ext/gecode-2.1.1/gecode/int/count/view.icc +449 -0
  179. data/ext/gecode-2.1.1/gecode/int/cumulatives.cc +226 -0
  180. data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +141 -0
  181. data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +429 -0
  182. data/ext/gecode-2.1.1/gecode/int/distinct.cc +108 -0
  183. data/ext/gecode-2.1.1/gecode/int/distinct.hh +341 -0
  184. data/ext/gecode-2.1.1/gecode/int/distinct/bilink.icc +89 -0
  185. data/ext/gecode-2.1.1/gecode/int/distinct/bnd.icc +378 -0
  186. data/ext/gecode-2.1.1/gecode/int/distinct/combptr.icc +78 -0
  187. data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +750 -0
  188. data/ext/gecode-2.1.1/gecode/int/distinct/edge.icc +118 -0
  189. data/ext/gecode-2.1.1/gecode/int/distinct/node.icc +147 -0
  190. data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +136 -0
  191. data/ext/gecode-2.1.1/gecode/int/distinct/val.icc +209 -0
  192. data/ext/gecode-2.1.1/gecode/int/dom.cc +116 -0
  193. data/ext/gecode-2.1.1/gecode/int/dom.hh +134 -0
  194. data/ext/gecode-2.1.1/gecode/int/dom/range.icc +129 -0
  195. data/ext/gecode-2.1.1/gecode/int/dom/spec.icc +151 -0
  196. data/ext/gecode-2.1.1/gecode/int/element.cc +156 -0
  197. data/ext/gecode-2.1.1/gecode/int/element.hh +239 -0
  198. data/ext/gecode-2.1.1/gecode/int/element/int.icc +441 -0
  199. data/ext/gecode-2.1.1/gecode/int/element/view.icc +584 -0
  200. data/ext/gecode-2.1.1/gecode/int/exception.icc +163 -0
  201. data/ext/gecode-2.1.1/gecode/int/extensional.cc +138 -0
  202. data/ext/gecode-2.1.1/gecode/int/extensional.hh +415 -0
  203. data/ext/gecode-2.1.1/gecode/int/extensional/base.icc +160 -0
  204. data/ext/gecode-2.1.1/gecode/int/extensional/basic.icc +166 -0
  205. data/ext/gecode-2.1.1/gecode/int/extensional/bitset.icc +113 -0
  206. data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +565 -0
  207. data/ext/gecode-2.1.1/gecode/int/extensional/dfa.icc +241 -0
  208. data/ext/gecode-2.1.1/gecode/int/extensional/incremental.icc +393 -0
  209. data/ext/gecode-2.1.1/gecode/int/extensional/layered-graph.icc +604 -0
  210. data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +311 -0
  211. data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.icc +207 -0
  212. data/ext/gecode-2.1.1/gecode/int/gcc.cc +374 -0
  213. data/ext/gecode-2.1.1/gecode/int/gcc.hh +329 -0
  214. data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +660 -0
  215. data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +531 -0
  216. data/ext/gecode-2.1.1/gecode/int/gcc/gccbndsup.icc +780 -0
  217. data/ext/gecode-2.1.1/gecode/int/gcc/graphsup.icc +2422 -0
  218. data/ext/gecode-2.1.1/gecode/int/gcc/lbc.icc +391 -0
  219. data/ext/gecode-2.1.1/gecode/int/gcc/occur.icc +829 -0
  220. data/ext/gecode-2.1.1/gecode/int/gcc/ubc.icc +255 -0
  221. data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +400 -0
  222. data/ext/gecode-2.1.1/gecode/int/int-set.cc +153 -0
  223. data/ext/gecode-2.1.1/gecode/int/int-set.icc +191 -0
  224. data/ext/gecode-2.1.1/gecode/int/limits.icc +54 -0
  225. data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +220 -0
  226. data/ext/gecode-2.1.1/gecode/int/linear-int.cc +240 -0
  227. data/ext/gecode-2.1.1/gecode/int/linear.hh +1849 -0
  228. data/ext/gecode-2.1.1/gecode/int/linear/bool-int.icc +791 -0
  229. data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +433 -0
  230. data/ext/gecode-2.1.1/gecode/int/linear/bool-scale.icc +854 -0
  231. data/ext/gecode-2.1.1/gecode/int/linear/bool-view.icc +399 -0
  232. data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +605 -0
  233. data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +539 -0
  234. data/ext/gecode-2.1.1/gecode/int/linear/int-nary.icc +1004 -0
  235. data/ext/gecode-2.1.1/gecode/int/linear/int-noview.icc +385 -0
  236. data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +493 -0
  237. data/ext/gecode-2.1.1/gecode/int/linear/int-ter.icc +357 -0
  238. data/ext/gecode-2.1.1/gecode/int/linear/post.icc +146 -0
  239. data/ext/gecode-2.1.1/gecode/int/propagator.icc +240 -0
  240. data/ext/gecode-2.1.1/gecode/int/rel.cc +431 -0
  241. data/ext/gecode-2.1.1/gecode/int/rel.hh +657 -0
  242. data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +848 -0
  243. data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +248 -0
  244. data/ext/gecode-2.1.1/gecode/int/rel/lq-le.icc +352 -0
  245. data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +269 -0
  246. data/ext/gecode-2.1.1/gecode/int/sorted.cc +91 -0
  247. data/ext/gecode-2.1.1/gecode/int/sorted.hh +117 -0
  248. data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +182 -0
  249. data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +257 -0
  250. data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +208 -0
  251. data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +669 -0
  252. data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +596 -0
  253. data/ext/gecode-2.1.1/gecode/int/unshare.cc +148 -0
  254. data/ext/gecode-2.1.1/gecode/int/var-imp.icc +745 -0
  255. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +104 -0
  256. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.icc +423 -0
  257. data/ext/gecode-2.1.1/gecode/int/var-imp/bool.vis +69 -0
  258. data/ext/gecode-2.1.1/gecode/int/var-imp/delta.icc +64 -0
  259. data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +407 -0
  260. data/ext/gecode-2.1.1/gecode/int/var-imp/int.icc +1004 -0
  261. data/ext/gecode-2.1.1/gecode/int/var-imp/int.vis +195 -0
  262. data/ext/gecode-2.1.1/gecode/int/var/bool.cc +72 -0
  263. data/ext/gecode-2.1.1/gecode/int/var/bool.icc +126 -0
  264. data/ext/gecode-2.1.1/gecode/int/var/int.cc +79 -0
  265. data/ext/gecode-2.1.1/gecode/int/var/int.icc +151 -0
  266. data/ext/gecode-2.1.1/gecode/int/view.icc +1894 -0
  267. data/ext/gecode-2.1.1/gecode/int/view/bool.icc +598 -0
  268. data/ext/gecode-2.1.1/gecode/int/view/constint.icc +392 -0
  269. data/ext/gecode-2.1.1/gecode/int/view/int.icc +301 -0
  270. data/ext/gecode-2.1.1/gecode/int/view/iter.icc +65 -0
  271. data/ext/gecode-2.1.1/gecode/int/view/minus.icc +372 -0
  272. data/ext/gecode-2.1.1/gecode/int/view/offset.icc +362 -0
  273. data/ext/gecode-2.1.1/gecode/int/view/print.cc +133 -0
  274. data/ext/gecode-2.1.1/gecode/int/view/rtest.icc +231 -0
  275. data/ext/gecode-2.1.1/gecode/int/view/scale.icc +456 -0
  276. data/ext/gecode-2.1.1/gecode/int/view/zero.icc +384 -0
  277. data/ext/gecode-2.1.1/gecode/iter.hh +90 -0
  278. data/ext/gecode-2.1.1/gecode/iter/ranges-add.icc +144 -0
  279. data/ext/gecode-2.1.1/gecode/iter/ranges-append.icc +222 -0
  280. data/ext/gecode-2.1.1/gecode/iter/ranges-array.icc +138 -0
  281. data/ext/gecode-2.1.1/gecode/iter/ranges-cache.icc +337 -0
  282. data/ext/gecode-2.1.1/gecode/iter/ranges-compl.icc +220 -0
  283. data/ext/gecode-2.1.1/gecode/iter/ranges-diff.icc +142 -0
  284. data/ext/gecode-2.1.1/gecode/iter/ranges-empty.icc +111 -0
  285. data/ext/gecode-2.1.1/gecode/iter/ranges-inter.icc +216 -0
  286. data/ext/gecode-2.1.1/gecode/iter/ranges-minmax.icc +118 -0
  287. data/ext/gecode-2.1.1/gecode/iter/ranges-minus.icc +150 -0
  288. data/ext/gecode-2.1.1/gecode/iter/ranges-offset.icc +127 -0
  289. data/ext/gecode-2.1.1/gecode/iter/ranges-operations.icc +157 -0
  290. data/ext/gecode-2.1.1/gecode/iter/ranges-scale.icc +238 -0
  291. data/ext/gecode-2.1.1/gecode/iter/ranges-singleton-append.icc +111 -0
  292. data/ext/gecode-2.1.1/gecode/iter/ranges-singleton.icc +86 -0
  293. data/ext/gecode-2.1.1/gecode/iter/ranges-size.icc +146 -0
  294. data/ext/gecode-2.1.1/gecode/iter/ranges-union.icc +224 -0
  295. data/ext/gecode-2.1.1/gecode/iter/ranges-values.icc +140 -0
  296. data/ext/gecode-2.1.1/gecode/iter/values-array.icc +119 -0
  297. data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +130 -0
  298. data/ext/gecode-2.1.1/gecode/iter/values-offset.icc +113 -0
  299. data/ext/gecode-2.1.1/gecode/iter/values-ranges.icc +106 -0
  300. data/ext/gecode-2.1.1/gecode/iter/values-singleton.icc +109 -0
  301. data/ext/gecode-2.1.1/gecode/iter/values-unique.icc +118 -0
  302. data/ext/gecode-2.1.1/gecode/iter/virtual-ranges-compl.icc +261 -0
  303. data/ext/gecode-2.1.1/gecode/iter/virtual-ranges-inter.icc +241 -0
  304. data/ext/gecode-2.1.1/gecode/iter/virtual-ranges-union.icc +249 -0
  305. data/ext/gecode-2.1.1/gecode/iter/virtual-ranges.icc +140 -0
  306. data/ext/gecode-2.1.1/gecode/kernel.hh +182 -0
  307. data/ext/gecode-2.1.1/gecode/kernel/advisor.icc +104 -0
  308. data/ext/gecode-2.1.1/gecode/kernel/array.icc +1232 -0
  309. data/ext/gecode-2.1.1/gecode/kernel/branching.icc +447 -0
  310. data/ext/gecode-2.1.1/gecode/kernel/core.cc +473 -0
  311. data/ext/gecode-2.1.1/gecode/kernel/core.icc +2295 -0
  312. data/ext/gecode-2.1.1/gecode/kernel/exception.icc +101 -0
  313. data/ext/gecode-2.1.1/gecode/kernel/macros.icc +117 -0
  314. data/ext/gecode-2.1.1/gecode/kernel/memory-manager.cc +57 -0
  315. data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +458 -0
  316. data/ext/gecode-2.1.1/gecode/kernel/modevent.icc +69 -0
  317. data/ext/gecode-2.1.1/gecode/kernel/propagator.icc +845 -0
  318. data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +921 -0
  319. data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +1012 -0
  320. data/ext/gecode-2.1.1/gecode/kernel/shared-array.icc +286 -0
  321. data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +433 -0
  322. data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +269 -0
  323. data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +227 -0
  324. data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +72 -0
  325. data/ext/gecode-2.1.1/gecode/kernel/var-type.cc +68 -0
  326. data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +915 -0
  327. data/ext/gecode-2.1.1/gecode/kernel/var.icc +120 -0
  328. data/ext/gecode-2.1.1/gecode/kernel/view.icc +611 -0
  329. data/ext/gecode-2.1.1/gecode/minimodel.hh +1165 -0
  330. data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +179 -0
  331. data/ext/gecode-2.1.1/gecode/minimodel/bool-expr.cc +327 -0
  332. data/ext/gecode-2.1.1/gecode/minimodel/bool-expr.icc +131 -0
  333. data/ext/gecode-2.1.1/gecode/minimodel/bool-rel.icc +83 -0
  334. data/ext/gecode-2.1.1/gecode/minimodel/exception.icc +84 -0
  335. data/ext/gecode-2.1.1/gecode/minimodel/lin-expr.icc +374 -0
  336. data/ext/gecode-2.1.1/gecode/minimodel/lin-rel.icc +324 -0
  337. data/ext/gecode-2.1.1/gecode/minimodel/matrix.icc +144 -0
  338. data/ext/gecode-2.1.1/gecode/minimodel/reg.cc +823 -0
  339. data/ext/gecode-2.1.1/gecode/search.hh +752 -0
  340. data/ext/gecode-2.1.1/gecode/search/bab.cc +169 -0
  341. data/ext/gecode-2.1.1/gecode/search/bab.icc +117 -0
  342. data/ext/gecode-2.1.1/gecode/search/dfs.cc +79 -0
  343. data/ext/gecode-2.1.1/gecode/search/dfs.icc +169 -0
  344. data/ext/gecode-2.1.1/gecode/search/engine-ctrl.icc +131 -0
  345. data/ext/gecode-2.1.1/gecode/search/lds.cc +265 -0
  346. data/ext/gecode-2.1.1/gecode/search/lds.icc +73 -0
  347. data/ext/gecode-2.1.1/gecode/search/options.cc +46 -0
  348. data/ext/gecode-2.1.1/gecode/search/options.icc +46 -0
  349. data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +237 -0
  350. data/ext/gecode-2.1.1/gecode/search/restart.icc +99 -0
  351. data/ext/gecode-2.1.1/gecode/search/statistics.icc +46 -0
  352. data/ext/gecode-2.1.1/gecode/search/stop.cc +74 -0
  353. data/ext/gecode-2.1.1/gecode/search/stop.icc +116 -0
  354. data/ext/gecode-2.1.1/gecode/serialization.hh +149 -0
  355. data/ext/gecode-2.1.1/gecode/serialization/boost.cc +78 -0
  356. data/ext/gecode-2.1.1/gecode/serialization/boost.icc +381 -0
  357. data/ext/gecode-2.1.1/gecode/serialization/flatzinc.cc +372 -0
  358. data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +340 -0
  359. data/ext/gecode-2.1.1/gecode/serialization/javascript.hh +69 -0
  360. data/ext/gecode-2.1.1/gecode/serialization/register.cc +8142 -0
  361. data/ext/gecode-2.1.1/gecode/set.hh +970 -0
  362. data/ext/gecode-2.1.1/gecode/set/array.cc +114 -0
  363. data/ext/gecode-2.1.1/gecode/set/array.icc +77 -0
  364. data/ext/gecode-2.1.1/gecode/set/branch.cc +78 -0
  365. data/ext/gecode-2.1.1/gecode/set/branch.hh +213 -0
  366. data/ext/gecode-2.1.1/gecode/set/branch/select-val.icc +132 -0
  367. data/ext/gecode-2.1.1/gecode/set/branch/select-view.icc +148 -0
  368. data/ext/gecode-2.1.1/gecode/set/cardinality.cc +65 -0
  369. data/ext/gecode-2.1.1/gecode/set/convex.cc +59 -0
  370. data/ext/gecode-2.1.1/gecode/set/convex.hh +126 -0
  371. data/ext/gecode-2.1.1/gecode/set/convex/conv.cc +118 -0
  372. data/ext/gecode-2.1.1/gecode/set/convex/conv.icc +67 -0
  373. data/ext/gecode-2.1.1/gecode/set/convex/hull.cc +140 -0
  374. data/ext/gecode-2.1.1/gecode/set/convex/hull.icc +68 -0
  375. data/ext/gecode-2.1.1/gecode/set/distinct.cc +56 -0
  376. data/ext/gecode-2.1.1/gecode/set/distinct.hh +90 -0
  377. data/ext/gecode-2.1.1/gecode/set/distinct/atmostOne.cc +192 -0
  378. data/ext/gecode-2.1.1/gecode/set/distinct/atmostOne.icc +66 -0
  379. data/ext/gecode-2.1.1/gecode/set/dom.cc +232 -0
  380. data/ext/gecode-2.1.1/gecode/set/exception.icc +135 -0
  381. data/ext/gecode-2.1.1/gecode/set/int.cc +177 -0
  382. data/ext/gecode-2.1.1/gecode/set/int.hh +391 -0
  383. data/ext/gecode-2.1.1/gecode/set/int/card.icc +116 -0
  384. data/ext/gecode-2.1.1/gecode/set/int/channel-bool.icc +303 -0
  385. data/ext/gecode-2.1.1/gecode/set/int/channel-int.icc +174 -0
  386. data/ext/gecode-2.1.1/gecode/set/int/match.icc +224 -0
  387. data/ext/gecode-2.1.1/gecode/set/int/minmax.icc +228 -0
  388. data/ext/gecode-2.1.1/gecode/set/int/weights.icc +370 -0
  389. data/ext/gecode-2.1.1/gecode/set/limits.icc +62 -0
  390. data/ext/gecode-2.1.1/gecode/set/projectors-compiler.hh +164 -0
  391. data/ext/gecode-2.1.1/gecode/set/projectors.cc +143 -0
  392. data/ext/gecode-2.1.1/gecode/set/projectors.hh +438 -0
  393. data/ext/gecode-2.1.1/gecode/set/projectors/compiler.cc +859 -0
  394. data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +312 -0
  395. data/ext/gecode-2.1.1/gecode/set/projectors/formula.icc +66 -0
  396. data/ext/gecode-2.1.1/gecode/set/projectors/projector-set.cc +91 -0
  397. data/ext/gecode-2.1.1/gecode/set/projectors/projector-set.icc +85 -0
  398. data/ext/gecode-2.1.1/gecode/set/projectors/projector.cc +147 -0
  399. data/ext/gecode-2.1.1/gecode/set/projectors/projector.icc +98 -0
  400. data/ext/gecode-2.1.1/gecode/set/projectors/propagator.hh +168 -0
  401. data/ext/gecode-2.1.1/gecode/set/projectors/propagator/card.icc +128 -0
  402. data/ext/gecode-2.1.1/gecode/set/projectors/propagator/nary.icc +144 -0
  403. data/ext/gecode-2.1.1/gecode/set/projectors/propagator/re-nary.cc +100 -0
  404. data/ext/gecode-2.1.1/gecode/set/projectors/propagator/re-nary.icc +71 -0
  405. data/ext/gecode-2.1.1/gecode/set/projectors/set-expr.cc +339 -0
  406. data/ext/gecode-2.1.1/gecode/set/projectors/set-expr.icc +237 -0
  407. data/ext/gecode-2.1.1/gecode/set/propagator.icc +125 -0
  408. data/ext/gecode-2.1.1/gecode/set/rel-op-const.cc +332 -0
  409. data/ext/gecode-2.1.1/gecode/set/rel-op.cc +197 -0
  410. data/ext/gecode-2.1.1/gecode/set/rel-op.hh +353 -0
  411. data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +557 -0
  412. data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +409 -0
  413. data/ext/gecode-2.1.1/gecode/set/rel-op/partition.icc +202 -0
  414. data/ext/gecode-2.1.1/gecode/set/rel-op/post.icc +223 -0
  415. data/ext/gecode-2.1.1/gecode/set/rel-op/subofunion.icc +192 -0
  416. data/ext/gecode-2.1.1/gecode/set/rel-op/superofinter.icc +193 -0
  417. data/ext/gecode-2.1.1/gecode/set/rel-op/union.icc +383 -0
  418. data/ext/gecode-2.1.1/gecode/set/rel.cc +258 -0
  419. data/ext/gecode-2.1.1/gecode/set/rel.hh +321 -0
  420. data/ext/gecode-2.1.1/gecode/set/rel/common.icc +125 -0
  421. data/ext/gecode-2.1.1/gecode/set/rel/eq.icc +139 -0
  422. data/ext/gecode-2.1.1/gecode/set/rel/nosubset.icc +128 -0
  423. data/ext/gecode-2.1.1/gecode/set/rel/nq.icc +208 -0
  424. data/ext/gecode-2.1.1/gecode/set/rel/re-eq.icc +179 -0
  425. data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +172 -0
  426. data/ext/gecode-2.1.1/gecode/set/rel/subset.icc +119 -0
  427. data/ext/gecode-2.1.1/gecode/set/select.cc +135 -0
  428. data/ext/gecode-2.1.1/gecode/set/select.hh +233 -0
  429. data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +308 -0
  430. data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +75 -0
  431. data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +113 -0
  432. data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +155 -0
  433. data/ext/gecode-2.1.1/gecode/set/select/inter.icc +349 -0
  434. data/ext/gecode-2.1.1/gecode/set/select/union.icc +371 -0
  435. data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +334 -0
  436. data/ext/gecode-2.1.1/gecode/set/sequence.cc +69 -0
  437. data/ext/gecode-2.1.1/gecode/set/sequence.hh +134 -0
  438. data/ext/gecode-2.1.1/gecode/set/sequence/common.icc +99 -0
  439. data/ext/gecode-2.1.1/gecode/set/sequence/seq-u.cc +176 -0
  440. data/ext/gecode-2.1.1/gecode/set/sequence/seq-u.icc +79 -0
  441. data/ext/gecode-2.1.1/gecode/set/sequence/seq.cc +94 -0
  442. data/ext/gecode-2.1.1/gecode/set/sequence/seq.icc +69 -0
  443. data/ext/gecode-2.1.1/gecode/set/var-imp.icc +737 -0
  444. data/ext/gecode-2.1.1/gecode/set/var-imp/delta.icc +78 -0
  445. data/ext/gecode-2.1.1/gecode/set/var-imp/integerset.cc +349 -0
  446. data/ext/gecode-2.1.1/gecode/set/var-imp/integerset.icc +484 -0
  447. data/ext/gecode-2.1.1/gecode/set/var-imp/iter.icc +63 -0
  448. data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +214 -0
  449. data/ext/gecode-2.1.1/gecode/set/var-imp/set.icc +532 -0
  450. data/ext/gecode-2.1.1/gecode/set/var-imp/set.vis +190 -0
  451. data/ext/gecode-2.1.1/gecode/set/var/set.cc +105 -0
  452. data/ext/gecode-2.1.1/gecode/set/var/set.icc +303 -0
  453. data/ext/gecode-2.1.1/gecode/set/view.icc +1503 -0
  454. data/ext/gecode-2.1.1/gecode/set/view/complement.icc +629 -0
  455. data/ext/gecode-2.1.1/gecode/set/view/const.icc +907 -0
  456. data/ext/gecode-2.1.1/gecode/set/view/offset.icc +497 -0
  457. data/ext/gecode-2.1.1/gecode/set/view/print.cc +141 -0
  458. data/ext/gecode-2.1.1/gecode/set/view/set.icc +275 -0
  459. data/ext/gecode-2.1.1/gecode/set/view/singleton.icc +438 -0
  460. data/ext/gecode-2.1.1/gecode/support.hh +110 -0
  461. data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +158 -0
  462. data/ext/gecode-2.1.1/gecode/support/buddy/AUTHORS +11 -0
  463. data/ext/gecode-2.1.1/gecode/support/buddy/ChangeLog +218 -0
  464. data/ext/gecode-2.1.1/gecode/support/buddy/NEWS +200 -0
  465. data/ext/gecode-2.1.1/gecode/support/buddy/README +128 -0
  466. data/ext/gecode-2.1.1/gecode/support/buddy/bdd.h +939 -0
  467. data/ext/gecode-2.1.1/gecode/support/buddy/bddio.c +596 -0
  468. data/ext/gecode-2.1.1/gecode/support/buddy/bddop.c +2848 -0
  469. data/ext/gecode-2.1.1/gecode/support/buddy/bddtree.h +62 -0
  470. data/ext/gecode-2.1.1/gecode/support/buddy/bvec.c +1354 -0
  471. data/ext/gecode-2.1.1/gecode/support/buddy/bvec.h +298 -0
  472. data/ext/gecode-2.1.1/gecode/support/buddy/cache.c +104 -0
  473. data/ext/gecode-2.1.1/gecode/support/buddy/cache.h +72 -0
  474. data/ext/gecode-2.1.1/gecode/support/buddy/config.h +20 -0
  475. data/ext/gecode-2.1.1/gecode/support/buddy/cppext.cc +626 -0
  476. data/ext/gecode-2.1.1/gecode/support/buddy/fdd.c +1079 -0
  477. data/ext/gecode-2.1.1/gecode/support/buddy/fdd.h +175 -0
  478. data/ext/gecode-2.1.1/gecode/support/buddy/imatrix.c +151 -0
  479. data/ext/gecode-2.1.1/gecode/support/buddy/imatrix.h +61 -0
  480. data/ext/gecode-2.1.1/gecode/support/buddy/kernel.c +1555 -0
  481. data/ext/gecode-2.1.1/gecode/support/buddy/kernel.h +244 -0
  482. data/ext/gecode-2.1.1/gecode/support/buddy/pairs.c +336 -0
  483. data/ext/gecode-2.1.1/gecode/support/buddy/prime.c +322 -0
  484. data/ext/gecode-2.1.1/gecode/support/buddy/prime.h +50 -0
  485. data/ext/gecode-2.1.1/gecode/support/buddy/reorder.c +2345 -0
  486. data/ext/gecode-2.1.1/gecode/support/buddy/tree.c +224 -0
  487. data/ext/gecode-2.1.1/gecode/support/cast.icc +52 -0
  488. data/ext/gecode-2.1.1/gecode/support/config.icc.in +80 -0
  489. data/ext/gecode-2.1.1/gecode/support/dynamic-array.icc +138 -0
  490. data/ext/gecode-2.1.1/gecode/support/dynamic-stack.icc +167 -0
  491. data/ext/gecode-2.1.1/gecode/support/exception.cc +65 -0
  492. data/ext/gecode-2.1.1/gecode/support/exception.icc +82 -0
  493. data/ext/gecode-2.1.1/gecode/support/macros.icc +103 -0
  494. data/ext/gecode-2.1.1/gecode/support/map.icc +207 -0
  495. data/ext/gecode-2.1.1/gecode/support/marked-pointer.icc +66 -0
  496. data/ext/gecode-2.1.1/gecode/support/memory.icc +220 -0
  497. data/ext/gecode-2.1.1/gecode/support/random.icc +121 -0
  498. data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +122 -0
  499. data/ext/gecode-2.1.1/gecode/support/sort.icc +210 -0
  500. data/ext/gecode-2.1.1/gecode/support/static-pqueue.icc +242 -0
  501. data/ext/gecode-2.1.1/gecode/support/static-stack.icc +125 -0
  502. data/ext/gecode-2.1.1/gecode/support/symbol.cc +226 -0
  503. data/ext/gecode-2.1.1/gecode/support/symbol.icc +130 -0
  504. data/ext/{gecode-1.3.1 → gecode-2.1.1}/install-sh +0 -0
  505. data/ext/gecode-2.1.1/misc/AppleHelpbookInfo.plist +26 -0
  506. data/ext/gecode-2.1.1/misc/allexamples.perl +60 -0
  507. data/ext/gecode-2.1.1/misc/debian/Makefile.am +44 -0
  508. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/debian/changelog +0 -0
  509. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/debian/control +0 -0
  510. data/ext/gecode-2.1.1/misc/debian/copyright +30 -0
  511. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/debian/gecode.info +0 -0
  512. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/debian/gecode.install +0 -0
  513. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/debian/gecode.spec +0 -0
  514. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/debian/rules +0 -0
  515. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/doxygen/back.png +0 -0
  516. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/doxygen/footer.html +0 -0
  517. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/doxygen/gecode-logo-100.png +0 -0
  518. data/ext/{gecode-1.3.1 → gecode-2.1.1}/misc/doxygen/header.html +0 -0
  519. data/ext/gecode-2.1.1/misc/doxygen/stylesheet.css +464 -0
  520. data/ext/gecode-2.1.1/misc/fixproperties.sh +77 -0
  521. data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +45 -0
  522. data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +45 -0
  523. data/ext/gecode-2.1.1/misc/gecode-search.pc.in +45 -0
  524. data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +45 -0
  525. data/ext/gecode-2.1.1/misc/gecode.pc.in +45 -0
  526. data/ext/gecode-2.1.1/misc/genchangelog.perl +208 -0
  527. data/ext/gecode-2.1.1/misc/genlcovmakefile.perl +148 -0
  528. data/ext/gecode-2.1.1/misc/genlicense.perl +121 -0
  529. data/ext/gecode-2.1.1/misc/genregistry.perl +468 -0
  530. data/ext/gecode-2.1.1/misc/genstatistics.perl +178 -0
  531. data/ext/gecode-2.1.1/misc/gentxtchangelog.perl +192 -0
  532. data/ext/gecode-2.1.1/misc/genvariables.perl +905 -0
  533. data/ext/gecode-2.1.1/misc/getrevision.perl +47 -0
  534. data/ext/gecode-2.1.1/misc/makedepend.perl +85 -0
  535. data/ext/gecode-2.1.1/misc/svn-ignore.txt +15 -0
  536. data/ext/gecode-2.1.1/variables.vsl +50 -0
  537. data/ext/missing.cpp +1 -1
  538. data/ext/missing.h +1 -1
  539. data/ext/vararray.h +4 -4
  540. data/lib/gecoder/bindings.rb +21 -1
  541. data/lib/gecoder/bindings/bindings.rb +408 -731
  542. data/lib/gecoder/interface/binding_changes.rb +1 -1
  543. data/lib/gecoder/interface/branch.rb +25 -25
  544. data/lib/gecoder/interface/constraints.rb +47 -4
  545. data/lib/gecoder/interface/constraints/bool/boolean.rb +18 -16
  546. data/lib/gecoder/interface/constraints/bool_enum/boolean.rb +13 -11
  547. data/lib/gecoder/interface/constraints/int/arithmetic.rb +5 -4
  548. data/lib/gecoder/interface/constraints/int/domain.rb +8 -9
  549. data/lib/gecoder/interface/constraints/int/linear.rb +10 -8
  550. data/lib/gecoder/interface/constraints/int_enum/arithmetic.rb +4 -4
  551. data/lib/gecoder/interface/constraints/int_enum/channel.rb +2 -2
  552. data/lib/gecoder/interface/constraints/int_enum/count.rb +4 -5
  553. data/lib/gecoder/interface/constraints/int_enum/distinct.rb +7 -2
  554. data/lib/gecoder/interface/constraints/int_enum/element.rb +2 -2
  555. data/lib/gecoder/interface/constraints/int_enum/equality.rb +6 -3
  556. data/lib/gecoder/interface/constraints/int_enum/sort.rb +17 -5
  557. data/lib/gecoder/interface/constraints/set_enum/distinct.rb +0 -36
  558. data/lib/gecoder/interface/constraints/set_var_constraints.rb +5 -0
  559. data/lib/gecoder/interface/model.rb +3 -3
  560. data/lib/gecoder/interface/search.rb +5 -4
  561. data/lib/gecoder/version.rb +1 -1
  562. data/specs/branch.rb +27 -27
  563. data/specs/constraints/arithmetic.rb +48 -30
  564. data/specs/constraints/bool_enum.rb +39 -19
  565. data/specs/constraints/boolean.rb +10 -10
  566. data/specs/constraints/cardinality.rb +12 -9
  567. data/specs/constraints/channel.rb +6 -6
  568. data/specs/constraints/connection.rb +22 -26
  569. data/specs/constraints/constraint_helper.rb +125 -41
  570. data/specs/constraints/count.rb +22 -15
  571. data/specs/constraints/distinct.rb +10 -64
  572. data/specs/constraints/element.rb +14 -12
  573. data/specs/constraints/equality.rb +4 -4
  574. data/specs/constraints/int_domain.rb +8 -7
  575. data/specs/constraints/int_relation.rb +12 -8
  576. data/specs/constraints/linear.rb +4 -4
  577. data/specs/constraints/reification_sugar.rb +22 -4
  578. data/specs/constraints/selection.rb +2 -2
  579. data/specs/constraints/set_domain.rb +7 -3
  580. data/specs/constraints/set_operation.rb +2 -2
  581. data/specs/constraints/set_relation.rb +2 -6
  582. data/specs/constraints/sort.rb +20 -16
  583. data/specs/distribution.rb +14 -0
  584. data/specs/model.rb +4 -4
  585. data/tasks/dependencies.txt +21 -0
  586. data/tasks/distribution.rake +49 -14
  587. data/vendor/rust/include/rust_checks.hh +2 -1
  588. data/vendor/rust/include/rust_conversions.hh +2 -2
  589. data/vendor/rust/rust/attribute.rb +2 -2
  590. data/vendor/rust/rust/class.rb +2 -2
  591. data/vendor/rust/rust/cxxclass.rb +0 -2
  592. data/vendor/rust/rust/function.rb +2 -2
  593. data/vendor/rust/rust/templates/AttributeDefinition.rusttpl +1 -1
  594. data/vendor/rust/rust/templates/StandaloneClassDeclarations.rusttpl +1 -1
  595. data/vendor/rust/rust/templates/VariableFunctionCall.rusttpl +1 -1
  596. data/vendor/rust/rust/type.rb +1 -1
  597. metadata +599 -542
  598. data/ext/gecode-1.3.1/LICENSE +0 -34
  599. data/ext/gecode-1.3.1/Makefile.contribs +0 -71
  600. data/ext/gecode-1.3.1/Makefile.dep +0 -3928
  601. data/ext/gecode-1.3.1/Makefile.in +0 -966
  602. data/ext/gecode-1.3.1/changelog.in +0 -1065
  603. data/ext/gecode-1.3.1/configure +0 -8590
  604. data/ext/gecode-1.3.1/configure.ac +0 -179
  605. data/ext/gecode-1.3.1/configure.ac.in +0 -175
  606. data/ext/gecode-1.3.1/contribs/graph/INSTALL +0 -53
  607. data/ext/gecode-1.3.1/contribs/graph/LICENSE +0 -11
  608. data/ext/gecode-1.3.1/contribs/graph/Makefile +0 -167
  609. data/ext/gecode-1.3.1/contribs/graph/Makefile.in.in +0 -169
  610. data/ext/gecode-1.3.1/contribs/graph/TODO +0 -28
  611. data/ext/gecode-1.3.1/contribs/graph/binarysimple.hh +0 -82
  612. data/ext/gecode-1.3.1/contribs/graph/binarysimple.icc +0 -186
  613. data/ext/gecode-1.3.1/contribs/graph/branch/branch.icc +0 -257
  614. data/ext/gecode-1.3.1/contribs/graph/configure +0 -2160
  615. data/ext/gecode-1.3.1/contribs/graph/configure.ac +0 -33
  616. data/ext/gecode-1.3.1/contribs/graph/doxygen.conf +0 -1226
  617. data/ext/gecode-1.3.1/contribs/graph/doxygen.hh +0 -132
  618. data/ext/gecode-1.3.1/contribs/graph/examples/cpgraph-basic.cc +0 -94
  619. data/ext/gecode-1.3.1/contribs/graph/examples/cpgraph-complement.cc +0 -104
  620. data/ext/gecode-1.3.1/contribs/graph/examples/cpgraph-instUB.cc +0 -105
  621. data/ext/gecode-1.3.1/contribs/graph/examples/cpgraph-path.cc +0 -92
  622. data/ext/gecode-1.3.1/contribs/graph/examples/cpgraph-path2.cc +0 -273
  623. data/ext/gecode-1.3.1/contribs/graph/examples/cpgraph-pathcost.cc +0 -311
  624. data/ext/gecode-1.3.1/contribs/graph/examples/g1.txt +0 -1
  625. data/ext/gecode-1.3.1/contribs/graph/examples/g2.txt +0 -1
  626. data/ext/gecode-1.3.1/contribs/graph/graph.hh +0 -51
  627. data/ext/gecode-1.3.1/contribs/graph/graphutils.h +0 -46
  628. data/ext/gecode-1.3.1/contribs/graph/graphutils.icc +0 -140
  629. data/ext/gecode-1.3.1/contribs/graph/misc/doxygen/footer.html +0 -1
  630. data/ext/gecode-1.3.1/contribs/graph/path.hh +0 -116
  631. data/ext/gecode-1.3.1/contribs/graph/path.icc +0 -64
  632. data/ext/gecode-1.3.1/contribs/graph/path/path.icc +0 -139
  633. data/ext/gecode-1.3.1/contribs/graph/path/pathdegree.icc +0 -133
  634. data/ext/gecode-1.3.1/contribs/graph/path/pathgraphs.icc +0 -341
  635. data/ext/gecode-1.3.1/contribs/graph/shortdesc.ac +0 -1
  636. data/ext/gecode-1.3.1/contribs/graph/stlutility.icc +0 -105
  637. data/ext/gecode-1.3.1/contribs/graph/var.icc +0 -106
  638. data/ext/gecode-1.3.1/contribs/graph/view.icc +0 -373
  639. data/ext/gecode-1.3.1/contribs/graph/view/arcnode.cc +0 -162
  640. data/ext/gecode-1.3.1/contribs/graph/view/arcnode.hh +0 -78
  641. data/ext/gecode-1.3.1/contribs/graph/view/boundsgraphs.icc +0 -349
  642. data/ext/gecode-1.3.1/contribs/graph/view/constant.icc +0 -148
  643. data/ext/gecode-1.3.1/contribs/graph/view/iter.icc +0 -337
  644. data/ext/gecode-1.3.1/contribs/graph/view/nodearcsets.icc +0 -493
  645. data/ext/gecode-1.3.1/contribs/graph/view/nodeset.icc +0 -60
  646. data/ext/gecode-1.3.1/contribs/graph/view/outadjsets.icc +0 -600
  647. data/ext/gecode-1.3.1/contribs/graph/view/prop.icc +0 -135
  648. data/ext/gecode-1.3.1/contribs/map/COMPILING +0 -68
  649. data/ext/gecode-1.3.1/contribs/map/LICENSE +0 -11
  650. data/ext/gecode-1.3.1/contribs/map/Makefile.in.in +0 -173
  651. data/ext/gecode-1.3.1/contribs/map/configure +0 -2285
  652. data/ext/gecode-1.3.1/contribs/map/configure.ac +0 -32
  653. data/ext/gecode-1.3.1/contribs/map/constraints.hh +0 -46
  654. data/ext/gecode-1.3.1/contribs/map/constraints.icc +0 -84
  655. data/ext/gecode-1.3.1/contribs/map/doxygen.conf +0 -1229
  656. data/ext/gecode-1.3.1/contribs/map/doxygen.hh +0 -33
  657. data/ext/gecode-1.3.1/contribs/map/examples/approximateMatching.cc +0 -199
  658. data/ext/gecode-1.3.1/contribs/map/examples/g1.txt +0 -1
  659. data/ext/gecode-1.3.1/contribs/map/examples/g2.txt +0 -1
  660. data/ext/gecode-1.3.1/contribs/map/examples/graph-examples.tgz +0 -0
  661. data/ext/gecode-1.3.1/contribs/map/examples/isomorphism.cc +0 -148
  662. data/ext/gecode-1.3.1/contribs/map/examples/map +0 -0
  663. data/ext/gecode-1.3.1/contribs/map/examples/map.cc +0 -80
  664. data/ext/gecode-1.3.1/contribs/map/examples/subgraphmonomorphism.cc +0 -155
  665. data/ext/gecode-1.3.1/contribs/map/map.hh +0 -65
  666. data/ext/gecode-1.3.1/contribs/map/matching/mono.hh +0 -235
  667. data/ext/gecode-1.3.1/contribs/map/matching/mono.icc +0 -771
  668. data/ext/gecode-1.3.1/contribs/map/shortdesc.ac +0 -2
  669. data/ext/gecode-1.3.1/contribs/map/var.icc +0 -346
  670. data/ext/gecode-1.3.1/contribs/map/var/imp.cc +0 -42
  671. data/ext/gecode-1.3.1/contribs/map/var/imp.icc +0 -436
  672. data/ext/gecode-1.3.1/doxygen.conf.in +0 -1225
  673. data/ext/gecode-1.3.1/doxygen.hh.in +0 -877
  674. data/ext/gecode-1.3.1/examples/all-interval-sort.cc +0 -201
  675. data/ext/gecode-1.3.1/examples/all-interval.cc +0 -114
  676. data/ext/gecode-1.3.1/examples/alpha.cc +0 -112
  677. data/ext/gecode-1.3.1/examples/baseline.cc +0 -71
  678. data/ext/gecode-1.3.1/examples/bibd.cc +0 -173
  679. data/ext/gecode-1.3.1/examples/black-hole.cc +0 -281
  680. data/ext/gecode-1.3.1/examples/cars.cc +0 -165
  681. data/ext/gecode-1.3.1/examples/crew.cc +0 -220
  682. data/ext/gecode-1.3.1/examples/crowded-chess.cc +0 -312
  683. data/ext/gecode-1.3.1/examples/donald.cc +0 -93
  684. data/ext/gecode-1.3.1/examples/eq20.cc +0 -111
  685. data/ext/gecode-1.3.1/examples/golf.cc +0 -242
  686. data/ext/gecode-1.3.1/examples/golomb.cc +0 -141
  687. data/ext/gecode-1.3.1/examples/graph-color.cc +0 -371
  688. data/ext/gecode-1.3.1/examples/grocery.cc +0 -107
  689. data/ext/gecode-1.3.1/examples/hamming.cc +0 -107
  690. data/ext/gecode-1.3.1/examples/ind-set.cc +0 -130
  691. data/ext/gecode-1.3.1/examples/knights.cc +0 -146
  692. data/ext/gecode-1.3.1/examples/langfordnum.cc +0 -244
  693. data/ext/gecode-1.3.1/examples/magic-sequence-gcc.cc +0 -93
  694. data/ext/gecode-1.3.1/examples/magic-sequence.cc +0 -108
  695. data/ext/gecode-1.3.1/examples/magic-square.cc +0 -120
  696. data/ext/gecode-1.3.1/examples/money.cc +0 -92
  697. data/ext/gecode-1.3.1/examples/ortho-latin.cc +0 -156
  698. data/ext/gecode-1.3.1/examples/packing.cc +0 -211
  699. data/ext/gecode-1.3.1/examples/partition.cc +0 -126
  700. data/ext/gecode-1.3.1/examples/photo.cc +0 -155
  701. data/ext/gecode-1.3.1/examples/picture-puzzle.cc +0 -481
  702. data/ext/gecode-1.3.1/examples/queen-armies.cc +0 -240
  703. data/ext/gecode-1.3.1/examples/queens.cc +0 -99
  704. data/ext/gecode-1.3.1/examples/sports-league.cc +0 -454
  705. data/ext/gecode-1.3.1/examples/steiner.cc +0 -148
  706. data/ext/gecode-1.3.1/examples/stress-domain.cc +0 -86
  707. data/ext/gecode-1.3.1/examples/stress-element.cc +0 -95
  708. data/ext/gecode-1.3.1/examples/stress-exec.cc +0 -74
  709. data/ext/gecode-1.3.1/examples/stress-min.cc +0 -84
  710. data/ext/gecode-1.3.1/examples/stress-search.cc +0 -72
  711. data/ext/gecode-1.3.1/examples/sudoku-mixed.cc +0 -282
  712. data/ext/gecode-1.3.1/examples/sudoku-set.cc +0 -162
  713. data/ext/gecode-1.3.1/examples/sudoku.cc +0 -188
  714. data/ext/gecode-1.3.1/examples/sudoku.icc +0 -703
  715. data/ext/gecode-1.3.1/examples/support.cc +0 -160
  716. data/ext/gecode-1.3.1/examples/support.hh +0 -98
  717. data/ext/gecode-1.3.1/examples/support.icc +0 -187
  718. data/ext/gecode-1.3.1/examples/timer.cc +0 -47
  719. data/ext/gecode-1.3.1/examples/timer.hh +0 -72
  720. data/ext/gecode-1.3.1/examples/warehouses.cc +0 -176
  721. data/ext/gecode-1.3.1/extconf.rb +0 -8
  722. data/ext/gecode-1.3.1/gecode.m4 +0 -736
  723. data/ext/gecode-1.3.1/gecode/config.icc.in +0 -50
  724. data/ext/gecode-1.3.1/gecode/int.hh +0 -1426
  725. data/ext/gecode-1.3.1/gecode/int/arithmetic.cc +0 -87
  726. data/ext/gecode-1.3.1/gecode/int/arithmetic.hh +0 -292
  727. data/ext/gecode-1.3.1/gecode/int/arithmetic/abs.icc +0 -213
  728. data/ext/gecode-1.3.1/gecode/int/arithmetic/max.icc +0 -196
  729. data/ext/gecode-1.3.1/gecode/int/arithmetic/mult.icc +0 -478
  730. data/ext/gecode-1.3.1/gecode/int/array.cc +0 -61
  731. data/ext/gecode-1.3.1/gecode/int/array.icc +0 -264
  732. data/ext/gecode-1.3.1/gecode/int/bool.cc +0 -187
  733. data/ext/gecode-1.3.1/gecode/int/bool.hh +0 -255
  734. data/ext/gecode-1.3.1/gecode/int/bool/base.icc +0 -123
  735. data/ext/gecode-1.3.1/gecode/int/bool/eq.icc +0 -89
  736. data/ext/gecode-1.3.1/gecode/int/bool/eqv.icc +0 -132
  737. data/ext/gecode-1.3.1/gecode/int/bool/or.icc +0 -380
  738. data/ext/gecode-1.3.1/gecode/int/branch.cc +0 -81
  739. data/ext/gecode-1.3.1/gecode/int/branch.hh +0 -444
  740. data/ext/gecode-1.3.1/gecode/int/branch/assign.cc +0 -83
  741. data/ext/gecode-1.3.1/gecode/int/branch/assign.icc +0 -76
  742. data/ext/gecode-1.3.1/gecode/int/branch/select-val.icc +0 -104
  743. data/ext/gecode-1.3.1/gecode/int/branch/select-view.icc +0 -219
  744. data/ext/gecode-1.3.1/gecode/int/channel.cc +0 -62
  745. data/ext/gecode-1.3.1/gecode/int/channel.hh +0 -144
  746. data/ext/gecode-1.3.1/gecode/int/channel/base.icc +0 -60
  747. data/ext/gecode-1.3.1/gecode/int/channel/dom.icc +0 -313
  748. data/ext/gecode-1.3.1/gecode/int/channel/stack.icc +0 -59
  749. data/ext/gecode-1.3.1/gecode/int/channel/val.icc +0 -239
  750. data/ext/gecode-1.3.1/gecode/int/count.cc +0 -174
  751. data/ext/gecode-1.3.1/gecode/int/count.hh +0 -401
  752. data/ext/gecode-1.3.1/gecode/int/count/int.icc +0 -495
  753. data/ext/gecode-1.3.1/gecode/int/count/rel.icc +0 -100
  754. data/ext/gecode-1.3.1/gecode/int/count/view.icc +0 -332
  755. data/ext/gecode-1.3.1/gecode/int/cumulatives.cc +0 -210
  756. data/ext/gecode-1.3.1/gecode/int/cumulatives.hh +0 -118
  757. data/ext/gecode-1.3.1/gecode/int/cumulatives/val.icc +0 -377
  758. data/ext/gecode-1.3.1/gecode/int/distinct.cc +0 -77
  759. data/ext/gecode-1.3.1/gecode/int/distinct.hh +0 -272
  760. data/ext/gecode-1.3.1/gecode/int/distinct/bilink.icc +0 -73
  761. data/ext/gecode-1.3.1/gecode/int/distinct/bnd.icc +0 -335
  762. data/ext/gecode-1.3.1/gecode/int/distinct/combptr.icc +0 -62
  763. data/ext/gecode-1.3.1/gecode/int/distinct/dom.icc +0 -740
  764. data/ext/gecode-1.3.1/gecode/int/distinct/edge.icc +0 -96
  765. data/ext/gecode-1.3.1/gecode/int/distinct/node.icc +0 -107
  766. data/ext/gecode-1.3.1/gecode/int/distinct/ter-dom.icc +0 -97
  767. data/ext/gecode-1.3.1/gecode/int/distinct/val.icc +0 -171
  768. data/ext/gecode-1.3.1/gecode/int/dom.cc +0 -81
  769. data/ext/gecode-1.3.1/gecode/int/dom.hh +0 -101
  770. data/ext/gecode-1.3.1/gecode/int/dom/range.icc +0 -85
  771. data/ext/gecode-1.3.1/gecode/int/dom/spec.icc +0 -85
  772. data/ext/gecode-1.3.1/gecode/int/element.cc +0 -58
  773. data/ext/gecode-1.3.1/gecode/int/element.hh +0 -203
  774. data/ext/gecode-1.3.1/gecode/int/element/int.icc +0 -396
  775. data/ext/gecode-1.3.1/gecode/int/element/view.icc +0 -443
  776. data/ext/gecode-1.3.1/gecode/int/exception.icc +0 -137
  777. data/ext/gecode-1.3.1/gecode/int/gcc.cc +0 -708
  778. data/ext/gecode-1.3.1/gecode/int/gcc.hh +0 -338
  779. data/ext/gecode-1.3.1/gecode/int/gcc/bnd.icc +0 -629
  780. data/ext/gecode-1.3.1/gecode/int/gcc/dom.icc +0 -504
  781. data/ext/gecode-1.3.1/gecode/int/gcc/gccbndsup.icc +0 -760
  782. data/ext/gecode-1.3.1/gecode/int/gcc/graphsup.icc +0 -2375
  783. data/ext/gecode-1.3.1/gecode/int/gcc/lbc.icc +0 -375
  784. data/ext/gecode-1.3.1/gecode/int/gcc/occur.icc +0 -687
  785. data/ext/gecode-1.3.1/gecode/int/gcc/ubc.icc +0 -236
  786. data/ext/gecode-1.3.1/gecode/int/gcc/val.icc +0 -373
  787. data/ext/gecode-1.3.1/gecode/int/int-set.cc +0 -115
  788. data/ext/gecode-1.3.1/gecode/int/int-set.icc +0 -151
  789. data/ext/gecode-1.3.1/gecode/int/linear.cc +0 -247
  790. data/ext/gecode-1.3.1/gecode/int/linear.hh +0 -1056
  791. data/ext/gecode-1.3.1/gecode/int/linear/binary.icc +0 -439
  792. data/ext/gecode-1.3.1/gecode/int/linear/bool-int.icc +0 -422
  793. data/ext/gecode-1.3.1/gecode/int/linear/bool-view.icc +0 -311
  794. data/ext/gecode-1.3.1/gecode/int/linear/dom.icc +0 -503
  795. data/ext/gecode-1.3.1/gecode/int/linear/nary.icc +0 -857
  796. data/ext/gecode-1.3.1/gecode/int/linear/noview.icc +0 -264
  797. data/ext/gecode-1.3.1/gecode/int/linear/post.cc +0 -542
  798. data/ext/gecode-1.3.1/gecode/int/linear/ternary.icc +0 -255
  799. data/ext/gecode-1.3.1/gecode/int/propagator.icc +0 -194
  800. data/ext/gecode-1.3.1/gecode/int/regular.cc +0 -40
  801. data/ext/gecode-1.3.1/gecode/int/regular.hh +0 -83
  802. data/ext/gecode-1.3.1/gecode/int/regular/dfa.cc +0 -466
  803. data/ext/gecode-1.3.1/gecode/int/regular/dfa.icc +0 -172
  804. data/ext/gecode-1.3.1/gecode/int/regular/dom.icc +0 -480
  805. data/ext/gecode-1.3.1/gecode/int/regular/reg.cc +0 -738
  806. data/ext/gecode-1.3.1/gecode/int/rel.cc +0 -293
  807. data/ext/gecode-1.3.1/gecode/int/rel.hh +0 -526
  808. data/ext/gecode-1.3.1/gecode/int/rel/eq.icc +0 -640
  809. data/ext/gecode-1.3.1/gecode/int/rel/lex.icc +0 -212
  810. data/ext/gecode-1.3.1/gecode/int/rel/lq-le.icc +0 -246
  811. data/ext/gecode-1.3.1/gecode/int/rel/nq.icc +0 -188
  812. data/ext/gecode-1.3.1/gecode/int/sortedness.cc +0 -124
  813. data/ext/gecode-1.3.1/gecode/int/sortedness.hh +0 -108
  814. data/ext/gecode-1.3.1/gecode/int/sortedness/matching.icc +0 -177
  815. data/ext/gecode-1.3.1/gecode/int/sortedness/narrowing.icc +0 -243
  816. data/ext/gecode-1.3.1/gecode/int/sortedness/order.icc +0 -232
  817. data/ext/gecode-1.3.1/gecode/int/sortedness/sortedness.icc +0 -727
  818. data/ext/gecode-1.3.1/gecode/int/sortedness/sortsup.icc +0 -666
  819. data/ext/gecode-1.3.1/gecode/int/var-imp.vis +0 -198
  820. data/ext/gecode-1.3.1/gecode/int/var.icc +0 -590
  821. data/ext/gecode-1.3.1/gecode/int/var/bool.icc +0 -52
  822. data/ext/gecode-1.3.1/gecode/int/var/imp-body.icc +0 -65
  823. data/ext/gecode-1.3.1/gecode/int/var/imp-hdr.icc +0 -191
  824. data/ext/gecode-1.3.1/gecode/int/var/imp.cc +0 -361
  825. data/ext/gecode-1.3.1/gecode/int/var/imp.icc +0 -579
  826. data/ext/gecode-1.3.1/gecode/int/var/int.cc +0 -63
  827. data/ext/gecode-1.3.1/gecode/int/var/int.icc +0 -135
  828. data/ext/gecode-1.3.1/gecode/int/view.icc +0 -1219
  829. data/ext/gecode-1.3.1/gecode/int/view/bool.icc +0 -270
  830. data/ext/gecode-1.3.1/gecode/int/view/constint.icc +0 -306
  831. data/ext/gecode-1.3.1/gecode/int/view/int.icc +0 -221
  832. data/ext/gecode-1.3.1/gecode/int/view/iter.icc +0 -49
  833. data/ext/gecode-1.3.1/gecode/int/view/minus.icc +0 -285
  834. data/ext/gecode-1.3.1/gecode/int/view/offset.icc +0 -274
  835. data/ext/gecode-1.3.1/gecode/int/view/print.cc +0 -109
  836. data/ext/gecode-1.3.1/gecode/int/view/rtest.icc +0 -215
  837. data/ext/gecode-1.3.1/gecode/int/view/scale.icc +0 -373
  838. data/ext/gecode-1.3.1/gecode/iter.hh +0 -65
  839. data/ext/gecode-1.3.1/gecode/iter/ranges-add.icc +0 -130
  840. data/ext/gecode-1.3.1/gecode/iter/ranges-append.icc +0 -208
  841. data/ext/gecode-1.3.1/gecode/iter/ranges-array.icc +0 -123
  842. data/ext/gecode-1.3.1/gecode/iter/ranges-cache.icc +0 -143
  843. data/ext/gecode-1.3.1/gecode/iter/ranges-compl.icc +0 -206
  844. data/ext/gecode-1.3.1/gecode/iter/ranges-diff.icc +0 -127
  845. data/ext/gecode-1.3.1/gecode/iter/ranges-empty.icc +0 -96
  846. data/ext/gecode-1.3.1/gecode/iter/ranges-inter.icc +0 -202
  847. data/ext/gecode-1.3.1/gecode/iter/ranges-minmax.icc +0 -103
  848. data/ext/gecode-1.3.1/gecode/iter/ranges-minus.icc +0 -138
  849. data/ext/gecode-1.3.1/gecode/iter/ranges-offset.icc +0 -112
  850. data/ext/gecode-1.3.1/gecode/iter/ranges-operations.icc +0 -142
  851. data/ext/gecode-1.3.1/gecode/iter/ranges-scale.icc +0 -224
  852. data/ext/gecode-1.3.1/gecode/iter/ranges-singleton.icc +0 -71
  853. data/ext/gecode-1.3.1/gecode/iter/ranges-size.icc +0 -131
  854. data/ext/gecode-1.3.1/gecode/iter/ranges-union.icc +0 -211
  855. data/ext/gecode-1.3.1/gecode/iter/ranges-values.icc +0 -125
  856. data/ext/gecode-1.3.1/gecode/iter/values-ranges.icc +0 -91
  857. data/ext/gecode-1.3.1/gecode/iter/virtual-ranges-compl.icc +0 -247
  858. data/ext/gecode-1.3.1/gecode/iter/virtual-ranges-inter.icc +0 -227
  859. data/ext/gecode-1.3.1/gecode/iter/virtual-ranges-union.icc +0 -236
  860. data/ext/gecode-1.3.1/gecode/iter/virtual-ranges.icc +0 -126
  861. data/ext/gecode-1.3.1/gecode/kernel.hh +0 -141
  862. data/ext/gecode-1.3.1/gecode/kernel/array.icc +0 -954
  863. data/ext/gecode-1.3.1/gecode/kernel/branching.icc +0 -233
  864. data/ext/gecode-1.3.1/gecode/kernel/core.cc +0 -417
  865. data/ext/gecode-1.3.1/gecode/kernel/core.icc +0 -1681
  866. data/ext/gecode-1.3.1/gecode/kernel/exception.cc +0 -49
  867. data/ext/gecode-1.3.1/gecode/kernel/exception.icc +0 -104
  868. data/ext/gecode-1.3.1/gecode/kernel/macros.icc +0 -98
  869. data/ext/gecode-1.3.1/gecode/kernel/memory-manager.cc +0 -41
  870. data/ext/gecode-1.3.1/gecode/kernel/memory-manager.icc +0 -438
  871. data/ext/gecode-1.3.1/gecode/kernel/memory.icc +0 -205
  872. data/ext/gecode-1.3.1/gecode/kernel/modevent.icc +0 -53
  873. data/ext/gecode-1.3.1/gecode/kernel/propagator.icc +0 -680
  874. data/ext/gecode-1.3.1/gecode/kernel/view.icc +0 -583
  875. data/ext/gecode-1.3.1/gecode/limits.hh +0 -87
  876. data/ext/gecode-1.3.1/gecode/minimodel.hh +0 -942
  877. data/ext/gecode-1.3.1/gecode/minimodel/arithmetic.cc +0 -137
  878. data/ext/gecode-1.3.1/gecode/minimodel/bool-expr.cc +0 -207
  879. data/ext/gecode-1.3.1/gecode/minimodel/bool-expr.icc +0 -191
  880. data/ext/gecode-1.3.1/gecode/minimodel/bool-rel.icc +0 -66
  881. data/ext/gecode-1.3.1/gecode/minimodel/exception.icc +0 -59
  882. data/ext/gecode-1.3.1/gecode/minimodel/lin-expr.cc +0 -103
  883. data/ext/gecode-1.3.1/gecode/minimodel/lin-expr.icc +0 -192
  884. data/ext/gecode-1.3.1/gecode/minimodel/lin-rel.icc +0 -200
  885. data/ext/gecode-1.3.1/gecode/minimodel/matrix.icc +0 -118
  886. data/ext/gecode-1.3.1/gecode/minimodel/scheduling.cc +0 -241
  887. data/ext/gecode-1.3.1/gecode/search.hh +0 -745
  888. data/ext/gecode-1.3.1/gecode/search/bab.cc +0 -153
  889. data/ext/gecode-1.3.1/gecode/search/bab.icc +0 -101
  890. data/ext/gecode-1.3.1/gecode/search/dfs.cc +0 -63
  891. data/ext/gecode-1.3.1/gecode/search/dfs.icc +0 -144
  892. data/ext/gecode-1.3.1/gecode/search/engine-ctrl.icc +0 -109
  893. data/ext/gecode-1.3.1/gecode/search/lds.cc +0 -237
  894. data/ext/gecode-1.3.1/gecode/search/lds.icc +0 -57
  895. data/ext/gecode-1.3.1/gecode/search/reco-stack.icc +0 -219
  896. data/ext/gecode-1.3.1/gecode/search/restart.icc +0 -76
  897. data/ext/gecode-1.3.1/gecode/search/statistics.icc +0 -30
  898. data/ext/gecode-1.3.1/gecode/search/stop.cc +0 -58
  899. data/ext/gecode-1.3.1/gecode/search/stop.icc +0 -100
  900. data/ext/gecode-1.3.1/gecode/set.hh +0 -419
  901. data/ext/gecode-1.3.1/gecode/set/array.cc +0 -114
  902. data/ext/gecode-1.3.1/gecode/set/array.icc +0 -134
  903. data/ext/gecode-1.3.1/gecode/set/branch.cc +0 -57
  904. data/ext/gecode-1.3.1/gecode/set/branch.hh +0 -176
  905. data/ext/gecode-1.3.1/gecode/set/branch/select-val.icc +0 -72
  906. data/ext/gecode-1.3.1/gecode/set/branch/select-view.icc +0 -112
  907. data/ext/gecode-1.3.1/gecode/set/cardinality.cc +0 -49
  908. data/ext/gecode-1.3.1/gecode/set/convex.cc +0 -43
  909. data/ext/gecode-1.3.1/gecode/set/convex.hh +0 -92
  910. data/ext/gecode-1.3.1/gecode/set/convex/conv.cc +0 -81
  911. data/ext/gecode-1.3.1/gecode/set/convex/conv.icc +0 -51
  912. data/ext/gecode-1.3.1/gecode/set/convex/hull.cc +0 -100
  913. data/ext/gecode-1.3.1/gecode/set/convex/hull.icc +0 -52
  914. data/ext/gecode-1.3.1/gecode/set/distinct.cc +0 -48
  915. data/ext/gecode-1.3.1/gecode/set/distinct.hh +0 -97
  916. data/ext/gecode-1.3.1/gecode/set/distinct/atmostOne.cc +0 -151
  917. data/ext/gecode-1.3.1/gecode/set/distinct/atmostOne.icc +0 -50
  918. data/ext/gecode-1.3.1/gecode/set/distinct/binomial.cc +0 -46
  919. data/ext/gecode-1.3.1/gecode/set/distinct/binomial.icc +0 -157
  920. data/ext/gecode-1.3.1/gecode/set/distinct/distinct.cc +0 -124
  921. data/ext/gecode-1.3.1/gecode/set/distinct/distinct.icc +0 -58
  922. data/ext/gecode-1.3.1/gecode/set/dom.cc +0 -224
  923. data/ext/gecode-1.3.1/gecode/set/exception.icc +0 -132
  924. data/ext/gecode-1.3.1/gecode/set/int.cc +0 -139
  925. data/ext/gecode-1.3.1/gecode/set/int.hh +0 -226
  926. data/ext/gecode-1.3.1/gecode/set/int/card.cc +0 -61
  927. data/ext/gecode-1.3.1/gecode/set/int/card.icc +0 -54
  928. data/ext/gecode-1.3.1/gecode/set/int/channel.cc +0 -100
  929. data/ext/gecode-1.3.1/gecode/set/int/channel.icc +0 -75
  930. data/ext/gecode-1.3.1/gecode/set/int/match.cc +0 -148
  931. data/ext/gecode-1.3.1/gecode/set/int/match.icc +0 -67
  932. data/ext/gecode-1.3.1/gecode/set/int/minmax.cc +0 -109
  933. data/ext/gecode-1.3.1/gecode/set/int/minmax.icc +0 -63
  934. data/ext/gecode-1.3.1/gecode/set/int/weights.cc +0 -182
  935. data/ext/gecode-1.3.1/gecode/set/int/weights.icc +0 -174
  936. data/ext/gecode-1.3.1/gecode/set/projectors-compiler.hh +0 -148
  937. data/ext/gecode-1.3.1/gecode/set/projectors.cc +0 -109
  938. data/ext/gecode-1.3.1/gecode/set/projectors.hh +0 -319
  939. data/ext/gecode-1.3.1/gecode/set/projectors/compiler.cc +0 -841
  940. data/ext/gecode-1.3.1/gecode/set/projectors/projector-set.cc +0 -69
  941. data/ext/gecode-1.3.1/gecode/set/projectors/projector-set.icc +0 -66
  942. data/ext/gecode-1.3.1/gecode/set/projectors/projector.cc +0 -125
  943. data/ext/gecode-1.3.1/gecode/set/projectors/projector.icc +0 -79
  944. data/ext/gecode-1.3.1/gecode/set/projectors/propagator.hh +0 -127
  945. data/ext/gecode-1.3.1/gecode/set/projectors/propagator/card.icc +0 -96
  946. data/ext/gecode-1.3.1/gecode/set/projectors/propagator/nary.icc +0 -106
  947. data/ext/gecode-1.3.1/gecode/set/projectors/propagator/re-nary.cc +0 -76
  948. data/ext/gecode-1.3.1/gecode/set/projectors/propagator/re-nary.icc +0 -53
  949. data/ext/gecode-1.3.1/gecode/set/projectors/set-expr.cc +0 -306
  950. data/ext/gecode-1.3.1/gecode/set/projectors/set-expr.icc +0 -192
  951. data/ext/gecode-1.3.1/gecode/set/propagator.icc +0 -96
  952. data/ext/gecode-1.3.1/gecode/set/rel-op-const.cc +0 -233
  953. data/ext/gecode-1.3.1/gecode/set/rel-op.cc +0 -96
  954. data/ext/gecode-1.3.1/gecode/set/rel-op.hh +0 -267
  955. data/ext/gecode-1.3.1/gecode/set/rel-op/common.icc +0 -528
  956. data/ext/gecode-1.3.1/gecode/set/rel-op/inter.icc +0 -312
  957. data/ext/gecode-1.3.1/gecode/set/rel-op/partition.icc +0 -131
  958. data/ext/gecode-1.3.1/gecode/set/rel-op/post.icc +0 -198
  959. data/ext/gecode-1.3.1/gecode/set/rel-op/subofunion.icc +0 -150
  960. data/ext/gecode-1.3.1/gecode/set/rel-op/superofinter.icc +0 -151
  961. data/ext/gecode-1.3.1/gecode/set/rel-op/union.icc +0 -292
  962. data/ext/gecode-1.3.1/gecode/set/rel.cc +0 -201
  963. data/ext/gecode-1.3.1/gecode/set/rel.hh +0 -250
  964. data/ext/gecode-1.3.1/gecode/set/rel/common.icc +0 -109
  965. data/ext/gecode-1.3.1/gecode/set/rel/eq.icc +0 -101
  966. data/ext/gecode-1.3.1/gecode/set/rel/nosubset.icc +0 -88
  967. data/ext/gecode-1.3.1/gecode/set/rel/nq.icc +0 -132
  968. data/ext/gecode-1.3.1/gecode/set/rel/re-eq.icc +0 -142
  969. data/ext/gecode-1.3.1/gecode/set/rel/re-subset.icc +0 -121
  970. data/ext/gecode-1.3.1/gecode/set/rel/subset.icc +0 -80
  971. data/ext/gecode-1.3.1/gecode/set/select.cc +0 -88
  972. data/ext/gecode-1.3.1/gecode/set/select.hh +0 -113
  973. data/ext/gecode-1.3.1/gecode/set/select/disjoint.cc +0 -267
  974. data/ext/gecode-1.3.1/gecode/set/select/disjoint.icc +0 -59
  975. data/ext/gecode-1.3.1/gecode/set/select/idxarray.hh +0 -91
  976. data/ext/gecode-1.3.1/gecode/set/select/idxarray.icc +0 -112
  977. data/ext/gecode-1.3.1/gecode/set/select/inter.icc +0 -300
  978. data/ext/gecode-1.3.1/gecode/set/sequence.cc +0 -48
  979. data/ext/gecode-1.3.1/gecode/set/sequence.hh +0 -97
  980. data/ext/gecode-1.3.1/gecode/set/sequence/common.icc +0 -79
  981. data/ext/gecode-1.3.1/gecode/set/sequence/seq-u.cc +0 -83
  982. data/ext/gecode-1.3.1/gecode/set/sequence/seq-u.icc +0 -63
  983. data/ext/gecode-1.3.1/gecode/set/sequence/seq.cc +0 -61
  984. data/ext/gecode-1.3.1/gecode/set/sequence/seq.icc +0 -53
  985. data/ext/gecode-1.3.1/gecode/set/var-imp.vis +0 -205
  986. data/ext/gecode-1.3.1/gecode/set/var.icc +0 -1090
  987. data/ext/gecode-1.3.1/gecode/set/var/imp-body.icc +0 -192
  988. data/ext/gecode-1.3.1/gecode/set/var/imp-hdr.icc +0 -235
  989. data/ext/gecode-1.3.1/gecode/set/var/imp.cc +0 -127
  990. data/ext/gecode-1.3.1/gecode/set/var/imp.icc +0 -356
  991. data/ext/gecode-1.3.1/gecode/set/var/integerset.cc +0 -256
  992. data/ext/gecode-1.3.1/gecode/set/var/integerset.icc +0 -512
  993. data/ext/gecode-1.3.1/gecode/set/var/iter.icc +0 -47
  994. data/ext/gecode-1.3.1/gecode/set/var/set.cc +0 -99
  995. data/ext/gecode-1.3.1/gecode/set/var/set.icc +0 -282
  996. data/ext/gecode-1.3.1/gecode/set/view.icc +0 -1075
  997. data/ext/gecode-1.3.1/gecode/set/view/complement.icc +0 -525
  998. data/ext/gecode-1.3.1/gecode/set/view/const.icc +0 -651
  999. data/ext/gecode-1.3.1/gecode/set/view/print.cc +0 -120
  1000. data/ext/gecode-1.3.1/gecode/set/view/set.icc +0 -217
  1001. data/ext/gecode-1.3.1/gecode/set/view/singleton.icc +0 -348
  1002. data/ext/gecode-1.3.1/gecode/support/block-allocator.hh +0 -152
  1003. data/ext/gecode-1.3.1/gecode/support/dynamic-array.hh +0 -131
  1004. data/ext/gecode-1.3.1/gecode/support/dynamic-stack.hh +0 -157
  1005. data/ext/gecode-1.3.1/gecode/support/random.hh +0 -100
  1006. data/ext/gecode-1.3.1/gecode/support/shared-array.hh +0 -255
  1007. data/ext/gecode-1.3.1/gecode/support/sort.hh +0 -193
  1008. data/ext/gecode-1.3.1/gecode/support/static-pqueue.hh +0 -240
  1009. data/ext/gecode-1.3.1/gecode/support/static-stack.hh +0 -117
  1010. data/ext/gecode-1.3.1/misc/debian/Makefile.am +0 -8
  1011. data/ext/gecode-1.3.1/misc/debian/copyright +0 -44
  1012. data/ext/gecode-1.3.1/misc/doxygen/stylesheet.css +0 -460
  1013. data/ext/gecode-1.3.1/misc/fixproperties.sh +0 -32
  1014. data/ext/gecode-1.3.1/misc/gecode-minimodel.pc.in +0 -12
  1015. data/ext/gecode-1.3.1/misc/gecode-search.pc.in +0 -12
  1016. data/ext/gecode-1.3.1/misc/gecode.pc.in +0 -12
  1017. data/ext/gecode-1.3.1/misc/genchangelog.perl +0 -190
  1018. data/ext/gecode-1.3.1/misc/genlicense.perl +0 -113
  1019. data/ext/gecode-1.3.1/misc/genstatistics.perl +0 -155
  1020. data/ext/gecode-1.3.1/misc/gentxtchangelog.perl +0 -170
  1021. data/ext/gecode-1.3.1/misc/genvarimp.perl +0 -666
  1022. data/ext/gecode-1.3.1/misc/getrevision.perl +0 -32
  1023. data/ext/gecode-1.3.1/misc/makedepend.perl +0 -66
  1024. data/ext/gecode-1.3.1/test/int.cc +0 -497
  1025. data/ext/gecode-1.3.1/test/int.hh +0 -119
  1026. data/ext/gecode-1.3.1/test/int/arithmetic.cc +0 -262
  1027. data/ext/gecode-1.3.1/test/int/basic.cc +0 -42
  1028. data/ext/gecode-1.3.1/test/int/bool.cc +0 -189
  1029. data/ext/gecode-1.3.1/test/int/channel.cc +0 -79
  1030. data/ext/gecode-1.3.1/test/int/count.cc +0 -264
  1031. data/ext/gecode-1.3.1/test/int/distinct.cc +0 -121
  1032. data/ext/gecode-1.3.1/test/int/dom.cc +0 -69
  1033. data/ext/gecode-1.3.1/test/int/element.cc +0 -132
  1034. data/ext/gecode-1.3.1/test/int/gcc.cc +0 -592
  1035. data/ext/gecode-1.3.1/test/int/linear.cc +0 -315
  1036. data/ext/gecode-1.3.1/test/int/minimodel.cc +0 -451
  1037. data/ext/gecode-1.3.1/test/int/regular.cc +0 -105
  1038. data/ext/gecode-1.3.1/test/int/rel.cc +0 -283
  1039. data/ext/gecode-1.3.1/test/int/scheduling.cc +0 -259
  1040. data/ext/gecode-1.3.1/test/int/sortedness.cc +0 -272
  1041. data/ext/gecode-1.3.1/test/intset.cc +0 -40
  1042. data/ext/gecode-1.3.1/test/log.cc +0 -515
  1043. data/ext/gecode-1.3.1/test/log.hh +0 -68
  1044. data/ext/gecode-1.3.1/test/set.cc +0 -542
  1045. data/ext/gecode-1.3.1/test/set.hh +0 -152
  1046. data/ext/gecode-1.3.1/test/set/convex.cc +0 -94
  1047. data/ext/gecode-1.3.1/test/set/distinct.cc +0 -148
  1048. data/ext/gecode-1.3.1/test/set/dom.cc +0 -67
  1049. data/ext/gecode-1.3.1/test/set/int.cc +0 -249
  1050. data/ext/gecode-1.3.1/test/set/projection.cc +0 -333
  1051. data/ext/gecode-1.3.1/test/set/rel-op.cc +0 -662
  1052. data/ext/gecode-1.3.1/test/set/rel.cc +0 -198
  1053. data/ext/gecode-1.3.1/test/set/select.cc +0 -108
  1054. data/ext/gecode-1.3.1/test/set/sequence.cc +0 -83
  1055. data/ext/gecode-1.3.1/test/stress.cc +0 -93
  1056. data/ext/gecode-1.3.1/test/stress.hh +0 -74
  1057. data/ext/gecode-1.3.1/test/stress/distinct.cc +0 -70
  1058. data/ext/gecode-1.3.1/test/stress/domain.cc +0 -69
  1059. data/ext/gecode-1.3.1/test/stress/exec.cc +0 -60
  1060. data/ext/gecode-1.3.1/test/stress/minsort.cc +0 -63
  1061. data/ext/gecode-1.3.1/test/stress/regular.cc +0 -112
  1062. data/ext/gecode-1.3.1/test/test.cc +0 -215
  1063. data/ext/gecode-1.3.1/test/test.hh +0 -107
@@ -0,0 +1,2459 @@
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
+