gecoder-with-gecode 0.9.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGES +6 -0
- data/README +1 -1
- data/THANKS +18 -0
- data/example/equation_system.rb +3 -1
- data/example/magic_sequence.rb +3 -1
- data/example/queens.rb +3 -1
- data/example/send_more_money.rb +24 -30
- data/example/send_most_money.rb +15 -26
- data/example/square_tiling.rb +3 -1
- data/example/sudoku-set.rb +3 -1
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
- data/ext/gecode-2.2.0/Makefile.dep +8056 -0
- data/ext/gecode-2.2.0/Makefile.in +1590 -0
- data/ext/gecode-2.2.0/changelog.in +2698 -0
- data/ext/gecode-2.2.0/configure +13112 -0
- data/ext/gecode-2.2.0/configure.ac +273 -0
- data/ext/gecode-2.2.0/configure.ac.in +269 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
- data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
- data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
- data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
- data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
- data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
- data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
- data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
- data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
- data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
- data/ext/gecode-2.2.0/examples/crew.cc +286 -0
- data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
- data/ext/gecode-2.2.0/examples/domino.cc +297 -0
- data/ext/gecode-2.2.0/examples/donald.cc +107 -0
- data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
- data/ext/gecode-2.2.0/examples/golf.cc +297 -0
- data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
- data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
- data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
- data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
- data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
- data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
- data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
- data/ext/gecode-2.2.0/examples/knights.cc +220 -0
- data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
- data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
- data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
- data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
- data/ext/gecode-2.2.0/examples/money.cc +105 -0
- data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
- data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
- data/ext/gecode-2.2.0/examples/partition.cc +141 -0
- data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
- data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
- data/ext/gecode-2.2.0/examples/photo.cc +170 -0
- data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
- data/ext/gecode-2.2.0/examples/queens.cc +147 -0
- data/ext/gecode-2.2.0/examples/queens.js +57 -0
- data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
- data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
- data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
- data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
- data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
- data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
- data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
- data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
- data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
- data/ext/gecode-2.2.0/examples/support.hh +338 -0
- data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
- data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
- data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
- data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
- data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
- data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
- data/ext/gecode-2.2.0/gecode.m4 +1046 -0
- data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
- data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
- data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
- data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
- data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
- data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
- data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
- data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
- data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
- data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
- data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
- data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
- data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
- data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
- data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
- data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
- data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
- data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
- data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
- data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
- data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
- data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
- data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
- data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
- data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
- data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
- data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
- data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
- data/ext/gecode-2.2.0/gecode/search.hh +759 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
- data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
- data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
- data/ext/gecode-2.2.0/gecode/set.hh +970 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
- data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
- data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
- data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
- data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
- data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
- data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
- data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
- data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
- data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
- data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
- data/ext/gecode-2.2.0/test/assign.cc +181 -0
- data/ext/gecode-2.2.0/test/assign.hh +93 -0
- data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch.cc +563 -0
- data/ext/gecode-2.2.0/test/branch.hh +144 -0
- data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
- data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
- data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
- data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
- data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
- data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
- data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
- data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
- data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
- data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
- data/ext/gecode-2.2.0/test/int.cc +688 -0
- data/ext/gecode-2.2.0/test/int.hh +267 -0
- data/ext/gecode-2.2.0/test/int.icc +266 -0
- data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
- data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
- data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
- data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
- data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
- data/ext/gecode-2.2.0/test/int/count.cc +357 -0
- data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
- data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
- data/ext/gecode-2.2.0/test/int/element.cc +333 -0
- data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
- data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
- data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
- data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
- data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
- data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
- data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
- data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
- data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
- data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
- data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
- data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
- data/ext/gecode-2.2.0/test/search.cc +618 -0
- data/ext/gecode-2.2.0/test/set.cc +753 -0
- data/ext/gecode-2.2.0/test/set.hh +286 -0
- data/ext/gecode-2.2.0/test/set.icc +108 -0
- data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
- data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
- data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
- data/ext/gecode-2.2.0/test/set/int.cc +473 -0
- data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
- data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
- data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
- data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
- data/ext/gecode-2.2.0/test/set/select.cc +299 -0
- data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
- data/ext/gecode-2.2.0/test/test.cc +287 -0
- data/ext/gecode-2.2.0/test/test.hh +175 -0
- data/ext/gecode-2.2.0/test/test.icc +93 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
- data/lib/gecoder/bindings.rb +7 -5
- data/lib/gecoder/bindings/bindings.rb +8 -8
- data/lib/gecoder/interface.rb +4 -2
- data/lib/gecoder/interface/binding_changes.rb +1 -1
- data/lib/gecoder/interface/branch.rb +1 -1
- data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
- data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
- data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
- data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
- data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
- data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
- data/lib/gecoder/interface/convenience.rb +99 -0
- data/lib/gecoder/interface/enum_wrapper.rb +1 -1
- data/lib/gecoder/interface/mixin.rb +486 -0
- data/lib/gecoder/interface/search.rb +23 -22
- data/lib/gecoder/version.rb +1 -1
- data/specs/branch.rb +5 -3
- data/specs/constraints/bool/boolean.rb +3 -1
- data/specs/constraints/bool/linear.rb +3 -1
- data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
- data/specs/constraints/bool_enum/channel.rb +3 -1
- data/specs/constraints/fixnum_enum/element.rb +3 -1
- data/specs/constraints/int/arithmetic.rb +3 -1
- data/specs/constraints/int/channel.rb +3 -1
- data/specs/constraints/int/linear.rb +3 -1
- data/specs/constraints/int/linear_properties.rb +3 -1
- data/specs/constraints/int_enum/arithmetic.rb +3 -1
- data/specs/constraints/int_enum/channel.rb +3 -1
- data/specs/constraints/int_enum/count.rb +3 -1
- data/specs/constraints/int_enum/distinct.rb +3 -1
- data/specs/constraints/int_enum/element.rb +3 -1
- data/specs/constraints/int_enum/sort.rb +3 -1
- data/specs/constraints/property_helper.rb +10 -10
- data/specs/constraints/reification_sugar.rb +3 -1
- data/specs/constraints/selected_set/select.rb +6 -5
- data/specs/constraints/selected_set/select_properties.rb +12 -10
- data/specs/constraints/set/channel.rb +3 -1
- data/specs/constraints/set/domain.rb +4 -4
- data/specs/constraints/set/relation.rb +4 -4
- data/specs/constraints/set_enum/channel.rb +3 -1
- data/specs/constraints/set_enum/distinct.rb +3 -1
- data/specs/constraints/set_enum/element.rb +77 -0
- data/specs/enum_wrapper.rb +1 -1
- data/specs/mixin.rb +78 -0
- data/specs/model.rb +5 -5
- data/specs/search.rb +20 -14
- data/specs/selected_set.rb +3 -3
- data/specs/set_elements.rb +2 -2
- data/tasks/distribution.rake +25 -4
- metadata +739 -602
- data/example/money.rb +0 -36
- data/ext/gecode-2.1.1/Makefile.dep +0 -7622
- data/ext/gecode-2.1.1/Makefile.in +0 -1568
- data/ext/gecode-2.1.1/changelog.in +0 -2459
- data/ext/gecode-2.1.1/configure +0 -11631
- data/ext/gecode-2.1.1/configure.ac +0 -249
- data/ext/gecode-2.1.1/configure.ac.in +0 -245
- data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
- data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
- data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
- data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
- data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
- data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
- data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
- data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
- data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
- data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
- data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
- data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
- data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
- data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
- data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
- data/ext/gecode-2.1.1/gecode.m4 +0 -956
- data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
- data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
- data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
- data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
- data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
- data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
- data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
- data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
- data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
- data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
- data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
- data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
- data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
- data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
- data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
- data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
- data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
- data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
- data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
- data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
- data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
- data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
- data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
- data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
- data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
- data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
- data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
- data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
- data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
- data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
- data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
- data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
- data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
- data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
- data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
- data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
- data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
- data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
- data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
- data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
- data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
- data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
- data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
- data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
- data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
- data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
- data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
- data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
- data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
- data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
- data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
- data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
- data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
- data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
- data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
- data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
- data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
- data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
- data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
- data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
- data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
- data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
- data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
- data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
- data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
- data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
- data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
- data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
- data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
- data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
- data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
- data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
- data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
- data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
- data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
- data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
- data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
- data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
- data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
- data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
- data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
- data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
- data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
- data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
- data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
- data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
- data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
- data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
- data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
- data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
- data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
- data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
- data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
- data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
- data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
- data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
- data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
- data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
- data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
- data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
- data/ext/gecode-2.1.1/gecode/search.hh +0 -752
- data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
- data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
- data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
- data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
- data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
- data/ext/gecode-2.1.1/gecode/set.hh +0 -970
- data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
- data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
- data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
- data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
- data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
- data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
- data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
- data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
- data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
- data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
- data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
- data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
- data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
- data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
- data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
- data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
- data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
- data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
- data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
- data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
- data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
- data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
- data/lib/gecoder/interface/model.rb +0 -453
- data/lib/gecoder/interface/model_sugar.rb +0 -84
- data/specs/constraints/set_enum/select.rb +0 -73
@@ -1,179 +0,0 @@
|
|
1
|
-
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
-
/*
|
3
|
-
* Main authors:
|
4
|
-
* Christian Schulte <schulte@gecode.org>
|
5
|
-
*
|
6
|
-
* Copyright:
|
7
|
-
* Christian Schulte, 2006
|
8
|
-
*
|
9
|
-
* Last modified:
|
10
|
-
* $Date: 2008-02-21 08:37:19 +0100 (Thu, 21 Feb 2008) $ by $Author: schulte $
|
11
|
-
* $Revision: 6264 $
|
12
|
-
*
|
13
|
-
* This file is part of Gecode, the generic constraint
|
14
|
-
* development environment:
|
15
|
-
* http://www.gecode.org
|
16
|
-
*
|
17
|
-
* Permission is hereby granted, free of charge, to any person obtaining
|
18
|
-
* a copy of this software and associated documentation files (the
|
19
|
-
* "Software"), to deal in the Software without restriction, including
|
20
|
-
* without limitation the rights to use, copy, modify, merge, publish,
|
21
|
-
* distribute, sublicense, and/or sell copies of the Software, and to
|
22
|
-
* permit persons to whom the Software is furnished to do so, subject to
|
23
|
-
* the following conditions:
|
24
|
-
*
|
25
|
-
* The above copyright notice and this permission notice shall be
|
26
|
-
* included in all copies or substantial portions of the Software.
|
27
|
-
*
|
28
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
29
|
-
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
30
|
-
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
31
|
-
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
32
|
-
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
33
|
-
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
34
|
-
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
35
|
-
*
|
36
|
-
*/
|
37
|
-
|
38
|
-
#include "gecode/minimodel.hh"
|
39
|
-
|
40
|
-
#include <algorithm>
|
41
|
-
|
42
|
-
namespace Gecode {
|
43
|
-
|
44
|
-
#define GECODE_MM_RETURN_FAILED \
|
45
|
-
if (home->failed()) { \
|
46
|
-
IntVar _x(home,0,0); return _x; \
|
47
|
-
}
|
48
|
-
|
49
|
-
IntVar
|
50
|
-
abs(Space* home, IntVar x, IntConLevel icl, PropKind pk) {
|
51
|
-
GECODE_MM_RETURN_FAILED;
|
52
|
-
if ((icl == ICL_DOM) && (x.min() >= 0))
|
53
|
-
return x;
|
54
|
-
int min, max;
|
55
|
-
if (x.min() >= 0) {
|
56
|
-
min = x.min(); max = x.max();
|
57
|
-
} else if (x.max() <= 0) {
|
58
|
-
min = -x.max(); max = -x.min();
|
59
|
-
} else {
|
60
|
-
min = 0; max = std::max(-x.min(),x.max());
|
61
|
-
}
|
62
|
-
IntVar y(home, min, max);
|
63
|
-
abs(home, x, y, icl, pk);
|
64
|
-
return y;
|
65
|
-
}
|
66
|
-
|
67
|
-
IntVar
|
68
|
-
min(Space* home, IntVar x, IntVar y, IntConLevel icl, PropKind pk) {
|
69
|
-
GECODE_MM_RETURN_FAILED;
|
70
|
-
IntVar z(home,
|
71
|
-
std::min(x.min(),y.min()),
|
72
|
-
std::min(x.max(),y.max()));
|
73
|
-
min(home, x, y, z, icl, pk);
|
74
|
-
return z;
|
75
|
-
}
|
76
|
-
|
77
|
-
IntVar
|
78
|
-
min(Space* home, const IntVarArgs& x, IntConLevel icl, PropKind pk) {
|
79
|
-
GECODE_MM_RETURN_FAILED;
|
80
|
-
int min = Int::Limits::max;
|
81
|
-
int max = Int::Limits::max;
|
82
|
-
for (int i=x.size(); i--; ) {
|
83
|
-
min = std::min(min,x[i].min());
|
84
|
-
max = std::min(max,x[i].max());
|
85
|
-
}
|
86
|
-
IntVar y(home, min, max);
|
87
|
-
Gecode::min(home, x, y, icl, pk);
|
88
|
-
return y;
|
89
|
-
}
|
90
|
-
|
91
|
-
IntVar
|
92
|
-
max(Space* home, IntVar x, IntVar y, IntConLevel icl, PropKind pk) {
|
93
|
-
GECODE_MM_RETURN_FAILED;
|
94
|
-
IntVar z(home,
|
95
|
-
std::max(x.min(),y.min()),
|
96
|
-
std::max(x.max(),y.max()));
|
97
|
-
max(home, x, y, z, icl, pk);
|
98
|
-
return z;
|
99
|
-
}
|
100
|
-
|
101
|
-
IntVar
|
102
|
-
max(Space* home, const IntVarArgs& x, IntConLevel icl, PropKind pk) {
|
103
|
-
GECODE_MM_RETURN_FAILED;
|
104
|
-
int min = Int::Limits::min;
|
105
|
-
int max = Int::Limits::min;
|
106
|
-
for (int i=x.size(); i--; ) {
|
107
|
-
min = std::max(min,x[i].min());
|
108
|
-
max = std::max(max,x[i].max());
|
109
|
-
}
|
110
|
-
IntVar y(home, min, max);
|
111
|
-
Gecode::max(home, x, y, icl, pk);
|
112
|
-
return y;
|
113
|
-
}
|
114
|
-
|
115
|
-
IntVar
|
116
|
-
mult(Space* home, IntVar x, IntVar y, IntConLevel icl, PropKind pk) {
|
117
|
-
GECODE_MM_RETURN_FAILED;
|
118
|
-
IntVar z(home, Int::Limits::min, Int::Limits::max);
|
119
|
-
mult(home, x, y, z, icl, pk);
|
120
|
-
return z;
|
121
|
-
}
|
122
|
-
|
123
|
-
IntVar
|
124
|
-
sqr(Space* home, IntVar x, IntConLevel icl, PropKind pk) {
|
125
|
-
GECODE_MM_RETURN_FAILED;
|
126
|
-
IntVar y(home, 0, Int::Limits::max);
|
127
|
-
sqr(home, x, y, icl, pk);
|
128
|
-
return y;
|
129
|
-
}
|
130
|
-
|
131
|
-
IntVar
|
132
|
-
sqrt(Space* home, IntVar x, IntConLevel icl, PropKind pk) {
|
133
|
-
GECODE_MM_RETURN_FAILED;
|
134
|
-
IntVar y(home, 0, std::max(0,x.max()));
|
135
|
-
sqrt(home, x, y, icl, pk);
|
136
|
-
return y;
|
137
|
-
}
|
138
|
-
|
139
|
-
IntVar
|
140
|
-
plus(Space* home, IntVar x, IntVar y, IntConLevel icl, PropKind) {
|
141
|
-
GECODE_MM_RETURN_FAILED;
|
142
|
-
double min = static_cast<double>(x.min())+static_cast<double>(y.min());
|
143
|
-
min = std::min(static_cast<double>(Int::Limits::max),
|
144
|
-
std::max(static_cast<double>(Int::Limits::min),min));
|
145
|
-
double max = static_cast<double>(x.max())+static_cast<double>(y.max());
|
146
|
-
max = std::min(static_cast<double>(Int::Limits::max),
|
147
|
-
std::max(static_cast<double>(Int::Limits::min),max));
|
148
|
-
IntVar z(home, static_cast<int>(min), static_cast<int>(max));
|
149
|
-
Int::Linear::Term<Int::IntView> ts[3];
|
150
|
-
ts[0].a = 1; ts[0].x = x;
|
151
|
-
ts[1].a = 1; ts[1].x = y;
|
152
|
-
ts[2].a = -1; ts[2].x = z;
|
153
|
-
Int::Linear::post(home, ts, 3, IRT_EQ, 0, icl);
|
154
|
-
return z;
|
155
|
-
}
|
156
|
-
|
157
|
-
IntVar
|
158
|
-
minus(Space* home, IntVar x, IntVar y, IntConLevel icl, PropKind) {
|
159
|
-
GECODE_MM_RETURN_FAILED;
|
160
|
-
double min = static_cast<double>(x.min())-static_cast<double>(y.max());
|
161
|
-
min = std::min(static_cast<double>(Int::Limits::max),
|
162
|
-
std::max(static_cast<double>(Int::Limits::min),min));
|
163
|
-
double max = static_cast<double>(x.max())-static_cast<double>(y.min());
|
164
|
-
max = std::min(static_cast<double>(Int::Limits::max),
|
165
|
-
std::max(static_cast<double>(Int::Limits::min),max));
|
166
|
-
IntVar z(home, static_cast<int>(min), static_cast<int>(max));
|
167
|
-
Int::Linear::Term<Int::IntView> ts[3];
|
168
|
-
ts[0].a = 1; ts[0].x = x;
|
169
|
-
ts[1].a = -1; ts[1].x = y;
|
170
|
-
ts[2].a = -1; ts[2].x = z;
|
171
|
-
Int::Linear::post(home, ts, 3, IRT_EQ, 0, icl);
|
172
|
-
return z;
|
173
|
-
}
|
174
|
-
|
175
|
-
#undef GECODE_MM_RETURN_FAILED
|
176
|
-
|
177
|
-
}
|
178
|
-
|
179
|
-
// STATISTICS: minimodel-any
|
@@ -1,752 +0,0 @@
|
|
1
|
-
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
-
/*
|
3
|
-
* Main authors:
|
4
|
-
* Christian Schulte <schulte@gecode.org>
|
5
|
-
* Guido Tack <tack@gecode.org>
|
6
|
-
*
|
7
|
-
* Copyright:
|
8
|
-
* Christian Schulte, 2002
|
9
|
-
* Guido Tack, 2004
|
10
|
-
*
|
11
|
-
* Last modified:
|
12
|
-
* $Date: 2008-02-29 01:09:17 +0100 (Fri, 29 Feb 2008) $ by $Author: schulte $
|
13
|
-
* $Revision: 6355 $
|
14
|
-
*
|
15
|
-
* This file is part of Gecode, the generic constraint
|
16
|
-
* development environment:
|
17
|
-
* http://www.gecode.org
|
18
|
-
*
|
19
|
-
* Permission is hereby granted, free of charge, to any person obtaining
|
20
|
-
* a copy of this software and associated documentation files (the
|
21
|
-
* "Software"), to deal in the Software without restriction, including
|
22
|
-
* without limitation the rights to use, copy, modify, merge, publish,
|
23
|
-
* distribute, sublicense, and/or sell copies of the Software, and to
|
24
|
-
* permit persons to whom the Software is furnished to do so, subject to
|
25
|
-
* the following conditions:
|
26
|
-
*
|
27
|
-
* The above copyright notice and this permission notice shall be
|
28
|
-
* included in all copies or substantial portions of the Software.
|
29
|
-
*
|
30
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
31
|
-
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
32
|
-
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
33
|
-
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
34
|
-
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
35
|
-
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
36
|
-
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
37
|
-
*
|
38
|
-
*/
|
39
|
-
|
40
|
-
#ifndef __GECODE_SEARCH_HH__
|
41
|
-
#define __GECODE_SEARCH_HH__
|
42
|
-
|
43
|
-
#include <ctime>
|
44
|
-
|
45
|
-
#include "gecode/kernel.hh"
|
46
|
-
|
47
|
-
/*
|
48
|
-
* Configure linking
|
49
|
-
*
|
50
|
-
*/
|
51
|
-
#if !defined(GECODE_STATIC_LIBS) && \
|
52
|
-
(defined(__CYGWIN__) || defined(__MINGW32__) || defined(_MSC_VER))
|
53
|
-
|
54
|
-
#ifdef GECODE_BUILD_SEARCH
|
55
|
-
#define GECODE_SEARCH_EXPORT __declspec( dllexport )
|
56
|
-
#else
|
57
|
-
#define GECODE_SEARCH_EXPORT __declspec( dllimport )
|
58
|
-
#endif
|
59
|
-
|
60
|
-
#else
|
61
|
-
|
62
|
-
#ifdef GECODE_GCC_HAS_CLASS_VISIBILITY
|
63
|
-
#define GECODE_SEARCH_EXPORT __attribute__ ((visibility("default")))
|
64
|
-
#else
|
65
|
-
#define GECODE_SEARCH_EXPORT
|
66
|
-
#endif
|
67
|
-
|
68
|
-
#endif
|
69
|
-
|
70
|
-
namespace Gecode {
|
71
|
-
|
72
|
-
/// %Search engines
|
73
|
-
namespace Search {
|
74
|
-
|
75
|
-
/**
|
76
|
-
* \brief %Search configuration
|
77
|
-
*
|
78
|
-
* \ingroup TaskModelSearch
|
79
|
-
*/
|
80
|
-
namespace Config {
|
81
|
-
/// Create a clone after every \a c_d commits
|
82
|
-
const unsigned int c_d = 8;
|
83
|
-
/// Create a clone during recomputation if distance is greater than \a a_d
|
84
|
-
const unsigned int a_d = 2;
|
85
|
-
}
|
86
|
-
|
87
|
-
/**
|
88
|
-
* \brief %Search engine statistics
|
89
|
-
* \ingroup TaskModelSearch
|
90
|
-
*/
|
91
|
-
class Statistics {
|
92
|
-
public:
|
93
|
-
/// Number of propagation steps
|
94
|
-
unsigned long int propagate;
|
95
|
-
/// Number of failed nodes in search tree
|
96
|
-
unsigned long int fail;
|
97
|
-
/// Number of clones created
|
98
|
-
unsigned long int clone;
|
99
|
-
/// Number of commit operations performed
|
100
|
-
unsigned long int commit;
|
101
|
-
/// Peak memory allocated
|
102
|
-
size_t memory;
|
103
|
-
/// Initialize with all numbers zero
|
104
|
-
Statistics(void);
|
105
|
-
};
|
106
|
-
|
107
|
-
|
108
|
-
/**
|
109
|
-
* \defgroup TaskModelSearchStop Stop-objects for stopping search
|
110
|
-
* \ingroup TaskModelSearch
|
111
|
-
*
|
112
|
-
* Allows to specify various criteria when a search engine should
|
113
|
-
* stop exploration. Only exploration but neither recomputation
|
114
|
-
* nor propagation will be interrupted.
|
115
|
-
*
|
116
|
-
*/
|
117
|
-
|
118
|
-
/**
|
119
|
-
* \brief Base-class for %Stop-object
|
120
|
-
* \ingroup TaskModelSearchStop
|
121
|
-
*/
|
122
|
-
class GECODE_SEARCH_EXPORT Stop {
|
123
|
-
public:
|
124
|
-
/// Default constructor
|
125
|
-
Stop(void);
|
126
|
-
/// Stop search, if returns true (can be based on statistics \a s)
|
127
|
-
virtual bool stop(const Statistics& s) = 0;
|
128
|
-
/// Destructor
|
129
|
-
virtual ~Stop(void);
|
130
|
-
};
|
131
|
-
|
132
|
-
/**
|
133
|
-
* \brief %Stop-object based on memory consumption
|
134
|
-
*
|
135
|
-
* \ingroup TaskModelSearchStop
|
136
|
-
*/
|
137
|
-
class GECODE_SEARCH_EXPORT MemoryStop : public Stop {
|
138
|
-
protected:
|
139
|
-
/// Size limit
|
140
|
-
size_t l;
|
141
|
-
public:
|
142
|
-
/// Stop if memory limit \a l (in bytes) is exceeded
|
143
|
-
MemoryStop(size_t l);
|
144
|
-
/// Return current limit
|
145
|
-
size_t limit(void) const;
|
146
|
-
/// Set current limit to \a l (in bytes)
|
147
|
-
void limit(size_t l);
|
148
|
-
/// Return true if memory limit is exceeded
|
149
|
-
virtual bool stop(const Statistics& s);
|
150
|
-
};
|
151
|
-
|
152
|
-
/**
|
153
|
-
* \brief %Stop-object based on number of failures
|
154
|
-
*
|
155
|
-
* The number of failures reported (by the statistics) is the
|
156
|
-
* number since the engine started exploration. It is not the
|
157
|
-
* number since the last stop!
|
158
|
-
* \ingroup TaskModelSearchStop
|
159
|
-
*/
|
160
|
-
class GECODE_SEARCH_EXPORT FailStop : public Stop {
|
161
|
-
protected:
|
162
|
-
/// Failure limit
|
163
|
-
unsigned long int l;
|
164
|
-
public:
|
165
|
-
/// Stop if failure limit \a l is exceeded
|
166
|
-
FailStop(unsigned long int l);
|
167
|
-
/// Return current limit
|
168
|
-
unsigned long int limit(void) const;
|
169
|
-
/// Set current limit to \a l failures
|
170
|
-
void limit(unsigned long int l);
|
171
|
-
/// Return true if failure limit is exceeded
|
172
|
-
virtual bool stop(const Statistics& s);
|
173
|
-
};
|
174
|
-
|
175
|
-
/**
|
176
|
-
* \brief %Stop-object based on time
|
177
|
-
* \ingroup TaskModelSearchStop
|
178
|
-
*/
|
179
|
-
class GECODE_SEARCH_EXPORT TimeStop : public Stop {
|
180
|
-
protected:
|
181
|
-
/// Clock when execution should stop
|
182
|
-
clock_t s;
|
183
|
-
/// Current limit in milliseconds
|
184
|
-
unsigned long int l;
|
185
|
-
public:
|
186
|
-
/// Stop if search exceeds \a l milliseconds (from creation of this object)
|
187
|
-
TimeStop(unsigned long int l);
|
188
|
-
/// Return current limit in milliseconds
|
189
|
-
unsigned long int limit(void) const;
|
190
|
-
/// Set current limit to \a l milliseconds
|
191
|
-
void limit(unsigned long int l);
|
192
|
-
/// Reset time to zero
|
193
|
-
void reset(void);
|
194
|
-
/// Return true if time limit is exceeded
|
195
|
-
virtual bool stop(const Statistics& s);
|
196
|
-
};
|
197
|
-
|
198
|
-
/**
|
199
|
-
* \brief %Search engine options
|
200
|
-
*
|
201
|
-
* Defines options for search engines. Not all search engines might
|
202
|
-
* honor all option values.
|
203
|
-
*
|
204
|
-
* - \a c_d as minimal recomputation distance: this guarantees that
|
205
|
-
* a path between two nodes in the search tree for which copies are
|
206
|
-
* stored has at least length \a c_d. That is, in order to recompute
|
207
|
-
* a node in the search tree, \a c_d recomputation steps are needed.
|
208
|
-
* The minimal recomputation distance yields a guarantee on saving
|
209
|
-
* memory compared to full copying: it stores \a c_d times less nodes
|
210
|
-
* than full copying.
|
211
|
-
* - \a a_d as adaptive recomputation distance: when a node needs to be
|
212
|
-
* recomputed and the path is longer than \a a_d, an intermediate copy
|
213
|
-
* is created (approximately in the middle of the path) to speed up
|
214
|
-
* future recomputation. Note that small values of \a a_d can increase
|
215
|
-
* the memory consumption considerably.
|
216
|
-
*
|
217
|
-
* Full copying corresponds to a maximal recomputation distance
|
218
|
-
* \a c_d of 1.
|
219
|
-
*
|
220
|
-
* All recomputation performed is based on batch recomputation: batch
|
221
|
-
* recomputation performs propagation only once for an entire path
|
222
|
-
* used in recomputation.
|
223
|
-
*/
|
224
|
-
class Options {
|
225
|
-
public:
|
226
|
-
/// Create a clone after every \a c_d commits
|
227
|
-
unsigned int c_d;
|
228
|
-
/// Create a clone during recomputation if distance is greater than \a a_d
|
229
|
-
unsigned int a_d;
|
230
|
-
/// Stop object for stopping search
|
231
|
-
Stop* stop;
|
232
|
-
/// Default options
|
233
|
-
GECODE_SEARCH_EXPORT static const Options def;
|
234
|
-
/// Initialize with default values
|
235
|
-
Options(void);
|
236
|
-
};
|
237
|
-
|
238
|
-
/**
|
239
|
-
* \brief %Search engine control including memory information
|
240
|
-
*/
|
241
|
-
class EngineCtrl : public Statistics {
|
242
|
-
protected:
|
243
|
-
/// %Stop-object to be used
|
244
|
-
Stop* st;
|
245
|
-
/// Whether engine has been stopped
|
246
|
-
bool _stopped;
|
247
|
-
/// Memory required for a single space
|
248
|
-
size_t mem_space;
|
249
|
-
/// Memory for the current space (including memory for caching)
|
250
|
-
size_t mem_cur;
|
251
|
-
/// Current total memory
|
252
|
-
size_t mem_total;
|
253
|
-
public:
|
254
|
-
/// Initialize with stop-object \a st and space size \a sz
|
255
|
-
EngineCtrl(Stop* st, size_t sz);
|
256
|
-
/// Reset stop information
|
257
|
-
void start(void);
|
258
|
-
/// Check whether engine must be stopped (with additional stackspace \a sz)
|
259
|
-
bool stop(size_t sz);
|
260
|
-
/// Check whether engine has been stopped
|
261
|
-
bool stopped(void) const;
|
262
|
-
/// New space \a s and branching description \a d get pushed on stack
|
263
|
-
void push(const Space* s, const BranchingDesc* d);
|
264
|
-
/// Space \a s1 is replaced by space \a s2 due to constraining
|
265
|
-
void constrained(const Space* s1, const Space* s2);
|
266
|
-
/// New space \a s is added for adaptive recomputation
|
267
|
-
void adapt(const Space* s);
|
268
|
-
/// Space \a s and branching description \a d get popped from stack
|
269
|
-
void pop(const Space* s, const BranchingDesc* d);
|
270
|
-
/// Space \a s gets used for LAO (removed from stack)
|
271
|
-
void lao(const Space* s);
|
272
|
-
/// Space \a s becomes current space (\a s = NULL: current space deleted)
|
273
|
-
void current(const Space* s);
|
274
|
-
/// Reset statistics for space \a s
|
275
|
-
void reset(const Space* s);
|
276
|
-
/// Reset statistics for failed space
|
277
|
-
void reset(void);
|
278
|
-
};
|
279
|
-
|
280
|
-
/**
|
281
|
-
* \brief %Search tree node for recomputation
|
282
|
-
*
|
283
|
-
*/
|
284
|
-
class ReCoNode {
|
285
|
-
protected:
|
286
|
-
/// Space corresponding to this node (might be NULL)
|
287
|
-
Space* _space;
|
288
|
-
/// Current alternative
|
289
|
-
unsigned int _alt;
|
290
|
-
/// Braching description
|
291
|
-
const BranchingDesc* _desc;
|
292
|
-
public:
|
293
|
-
/// Node for space \a s with clone \a c (possibly NULL)
|
294
|
-
ReCoNode(Space* s, Space* c);
|
295
|
-
|
296
|
-
/// Return space for node
|
297
|
-
Space* space(void) const;
|
298
|
-
/// Set space to \a s
|
299
|
-
void space(Space* s);
|
300
|
-
|
301
|
-
/// Return branching description
|
302
|
-
const BranchingDesc* desc(void) const;
|
303
|
-
|
304
|
-
/// Return number for alternatives
|
305
|
-
unsigned int alt(void) const;
|
306
|
-
/// Test whether current alternative is rightmost
|
307
|
-
bool rightmost(void) const;
|
308
|
-
/// Move to next alternative
|
309
|
-
void next(void);
|
310
|
-
|
311
|
-
/// Free memory for node
|
312
|
-
void dispose(void);
|
313
|
-
};
|
314
|
-
|
315
|
-
|
316
|
-
/**
|
317
|
-
* \brief Stack of nodes supporting recomputation
|
318
|
-
*
|
319
|
-
* Maintains the invariant that it contains
|
320
|
-
* the path of the node being currently explored. This
|
321
|
-
* is required to support recomputation, of course.
|
322
|
-
*
|
323
|
-
* The stack supports adaptive recomputation controlled
|
324
|
-
* by the value of a_d: only if the recomputation
|
325
|
-
* distance is at least this large, an additional
|
326
|
-
* clone is created.
|
327
|
-
*
|
328
|
-
*/
|
329
|
-
class ReCoStack {
|
330
|
-
private:
|
331
|
-
/// Stack to store node information
|
332
|
-
Support::DynamicStack<ReCoNode> ds;
|
333
|
-
/// Adaptive recomputation distance
|
334
|
-
const unsigned int a_d;
|
335
|
-
public:
|
336
|
-
/// Initialize with adaptive recomputation distance \a a_d
|
337
|
-
ReCoStack(unsigned int a_d);
|
338
|
-
/// Push space \a c (a clone of \a s or NULL)
|
339
|
-
const BranchingDesc* push(Space* s, Space* c);
|
340
|
-
/// Generate path for next node and return whether a next node exists
|
341
|
-
bool next(EngineCtrl& s);
|
342
|
-
/// Return position on stack of last copy
|
343
|
-
int lc(Space*& s) const;
|
344
|
-
/// Unwind the stack up to position \a l (after failure)
|
345
|
-
void unwind(int l);
|
346
|
-
/// Commit space \a s as described by stack entry at position \a i
|
347
|
-
void commit(Space* s, int i) const;
|
348
|
-
/**
|
349
|
-
* \brief Recompute space according to path with copying distance \a d
|
350
|
-
*
|
351
|
-
* The template parameter \a constrained describes whether the stack
|
352
|
-
* might contain spaces not propagated (from constraining during
|
353
|
-
* branch-and-bound).
|
354
|
-
*/
|
355
|
-
template <bool constrained>
|
356
|
-
Space* recompute(unsigned int& d, EngineCtrl& s);
|
357
|
-
/// Return number of entries on stack
|
358
|
-
int entries(void) const;
|
359
|
-
/// Return stack size used
|
360
|
-
size_t stacksize(void) const;
|
361
|
-
/// Reset stack
|
362
|
-
void reset(void);
|
363
|
-
};
|
364
|
-
|
365
|
-
/**
|
366
|
-
* \brief Depth-first search engine implementation
|
367
|
-
*
|
368
|
-
*/
|
369
|
-
class DfsEngine : public EngineCtrl {
|
370
|
-
private:
|
371
|
-
/// Recomputation stack of nodes
|
372
|
-
ReCoStack rcs;
|
373
|
-
/// Current space being explored
|
374
|
-
Space* cur;
|
375
|
-
/// Copying recomputation distance
|
376
|
-
const unsigned int c_d;
|
377
|
-
/// Distance until next clone
|
378
|
-
unsigned int d;
|
379
|
-
public:
|
380
|
-
/**
|
381
|
-
* \brief Initialize engine
|
382
|
-
* \param c_d minimal recomputation distance
|
383
|
-
* \param a_d adaptive recomputation distance
|
384
|
-
* \param st %Stop-object
|
385
|
-
* \param sz size of one space
|
386
|
-
*/
|
387
|
-
DfsEngine(unsigned int c_d, unsigned int a_d, Stop* st, size_t sz);
|
388
|
-
/// Initialize engine to start at space \a s
|
389
|
-
void init(Space* s);
|
390
|
-
/// Reset engine to restart at space \a s
|
391
|
-
void reset(Space* s);
|
392
|
-
/// Reset engine to restart at failed space
|
393
|
-
void reset(void);
|
394
|
-
/// %Search for next solution
|
395
|
-
Space* explore(void);
|
396
|
-
/// Return stack size used by engine
|
397
|
-
size_t stacksize(void) const;
|
398
|
-
/// Destructor
|
399
|
-
~DfsEngine(void);
|
400
|
-
};
|
401
|
-
|
402
|
-
/**
|
403
|
-
* \brief Depth-first search engine
|
404
|
-
*
|
405
|
-
* This class implements depth-first exploration for spaces. In order to
|
406
|
-
* use depth-first search on subclasses of Space, additional
|
407
|
-
* functionality providing the necessary typecasts is available
|
408
|
-
* in Gecode::DFS.
|
409
|
-
*/
|
410
|
-
class GECODE_SEARCH_EXPORT DFS {
|
411
|
-
protected:
|
412
|
-
/// Engine used for exploration
|
413
|
-
DfsEngine e;
|
414
|
-
public:
|
415
|
-
/**
|
416
|
-
* \brief Initialize search engine
|
417
|
-
* \param s root node (subclass of Space)
|
418
|
-
* \param c_d minimal recomputation distance
|
419
|
-
* \param a_d adaptive recomputation distance
|
420
|
-
* \param st %Stop-object
|
421
|
-
* \param sz size of one space
|
422
|
-
*/
|
423
|
-
DFS(Space* s, unsigned int c_d, unsigned int a_d, Stop* st, size_t sz);
|
424
|
-
/// Return next solution (NULL, if none exists or search has been stopped)
|
425
|
-
Space* next(void);
|
426
|
-
/// Return statistics
|
427
|
-
Statistics statistics(void) const;
|
428
|
-
/// Check whether engine has been stopped
|
429
|
-
bool stopped(void) const;
|
430
|
-
};
|
431
|
-
|
432
|
-
}
|
433
|
-
|
434
|
-
/**
|
435
|
-
* \brief Depth-first search engine
|
436
|
-
*
|
437
|
-
* This class supports depth-first search for subclasses \a T of
|
438
|
-
* Space.
|
439
|
-
* \ingroup TaskModelSearch
|
440
|
-
*/
|
441
|
-
template <class T>
|
442
|
-
class DFS : public Search::DFS {
|
443
|
-
public:
|
444
|
-
/// Initialize search engine for space \a s with options \a o
|
445
|
-
DFS(T* s, const Search::Options& o=Search::Options::def);
|
446
|
-
/// Return next solution (NULL, if none exists or search has been stopped)
|
447
|
-
T* next(void);
|
448
|
-
};
|
449
|
-
|
450
|
-
/// Invoke depth-first search engine for subclass \a T of space \a s with options \a o
|
451
|
-
template <class T>
|
452
|
-
T* dfs(T* s, const Search::Options& o=Search::Options::def);
|
453
|
-
|
454
|
-
|
455
|
-
namespace Search {
|
456
|
-
|
457
|
-
/**
|
458
|
-
* \brief Probing engine for %LDS
|
459
|
-
*
|
460
|
-
*/
|
461
|
-
class ProbeEngine : public EngineCtrl {
|
462
|
-
protected:
|
463
|
-
/// %Node in the search tree for %LDS
|
464
|
-
class ProbeNode {
|
465
|
-
private:
|
466
|
-
/// %Space of current node
|
467
|
-
Space* _space;
|
468
|
-
/// Branching description
|
469
|
-
const BranchingDesc* _desc;
|
470
|
-
/// Next alternative to try
|
471
|
-
unsigned int _alt;
|
472
|
-
public:
|
473
|
-
/// Initialize with node \a s, description \a d, and alternative \a a
|
474
|
-
ProbeNode(Space* s, const BranchingDesc* d, unsigned int a);
|
475
|
-
/// Return space
|
476
|
-
Space* space(void) const;
|
477
|
-
/// Return branching description
|
478
|
-
const BranchingDesc* desc(void) const;
|
479
|
-
/// Return next alternative
|
480
|
-
unsigned int alt(void) const;
|
481
|
-
/// %Set next alternative
|
482
|
-
void next(void);
|
483
|
-
};
|
484
|
-
/// %Stack storing current path in search tree
|
485
|
-
Support::DynamicStack<ProbeNode> ds;
|
486
|
-
/// Current space
|
487
|
-
Space* cur;
|
488
|
-
/// Current discrepancy
|
489
|
-
unsigned int d;
|
490
|
-
/// Whether entire search space has been exhausted
|
491
|
-
bool exhausted;
|
492
|
-
public:
|
493
|
-
/// Initialize for spaces of size \a s
|
494
|
-
ProbeEngine(Stop* st, size_t s);
|
495
|
-
/// Initialize with space \a s and discrepancy \a d
|
496
|
-
void init(Space* s, unsigned int d);
|
497
|
-
/// Reset with space \a s and discrepancy \a d
|
498
|
-
void reset(Space* s, unsigned int d);
|
499
|
-
/// Return stack size used by engine
|
500
|
-
size_t stacksize(void) const;
|
501
|
-
/// Destructor
|
502
|
-
~ProbeEngine(void);
|
503
|
-
/// %Search for next solution
|
504
|
-
Space* explore(void);
|
505
|
-
/// Test whether probing is done
|
506
|
-
bool done(void) const;
|
507
|
-
};
|
508
|
-
|
509
|
-
/**
|
510
|
-
* \brief Limited discrepancy search engine
|
511
|
-
*/
|
512
|
-
class GECODE_SEARCH_EXPORT LDS {
|
513
|
-
protected:
|
514
|
-
Space* root; ///< Root node for problem
|
515
|
-
unsigned int d_cur; ///< Current discrepancy
|
516
|
-
unsigned int d_max; ///< Maximal discrepancy
|
517
|
-
bool no_solution; ///< Solution found for current discrepancy
|
518
|
-
ProbeEngine e; ///< The probe engine
|
519
|
-
public:
|
520
|
-
/** Initialize engine
|
521
|
-
* \param s root node
|
522
|
-
* \param d maximal discrepancy
|
523
|
-
* \param st %Stop-object
|
524
|
-
* \param sz size of space
|
525
|
-
*/
|
526
|
-
LDS(Space* s, unsigned int d, Stop* st, size_t sz);
|
527
|
-
/// Return next solution (NULL, if none exists or search has been stopped)
|
528
|
-
Space* next(void);
|
529
|
-
/// Return statistics
|
530
|
-
Statistics statistics(void) const;
|
531
|
-
/// Check whether engine has been stopped
|
532
|
-
bool stopped(void) const;
|
533
|
-
/// Destructor
|
534
|
-
~LDS(void);
|
535
|
-
};
|
536
|
-
|
537
|
-
}
|
538
|
-
|
539
|
-
/**
|
540
|
-
* \brief Limited discrepancy search engine
|
541
|
-
* \ingroup TaskModelSearch
|
542
|
-
*/
|
543
|
-
template <class T>
|
544
|
-
class LDS : public Search::LDS {
|
545
|
-
public:
|
546
|
-
/// Initialize engine with \a s as root node and maximal discrepancy \a d
|
547
|
-
LDS(T* s, unsigned int d,
|
548
|
-
const Search::Options& o=Search::Options::def);
|
549
|
-
/// Return next solution (NULL, if none exists or search has been stopped)
|
550
|
-
T* next(void);
|
551
|
-
};
|
552
|
-
|
553
|
-
/**
|
554
|
-
* \brief Invoke limited-discrepancy search for \a s as root node and maximal discrepancy \a d
|
555
|
-
* \ingroup TaskModelSearch
|
556
|
-
*/
|
557
|
-
template <class T>
|
558
|
-
T* lds(T* s, unsigned int d,
|
559
|
-
const Search::Options& o=Search::Options::def);
|
560
|
-
|
561
|
-
|
562
|
-
|
563
|
-
|
564
|
-
|
565
|
-
/*
|
566
|
-
* Best solution search engines
|
567
|
-
*
|
568
|
-
*/
|
569
|
-
|
570
|
-
namespace Search {
|
571
|
-
|
572
|
-
/**
|
573
|
-
* \brief Implementation of depth-first branch-and-bound search engines
|
574
|
-
*/
|
575
|
-
class BabEngine : public EngineCtrl {
|
576
|
-
public:
|
577
|
-
/// Status of the explore function
|
578
|
-
enum ExploreStatus {
|
579
|
-
ES_SOLUTION,
|
580
|
-
ES_CONSTRAIN
|
581
|
-
};
|
582
|
-
private:
|
583
|
-
/// Recomputation stack of nodes
|
584
|
-
ReCoStack rcs;
|
585
|
-
/// Current space being explored
|
586
|
-
Space* cur;
|
587
|
-
/// Number of entries not yet constrained to be better
|
588
|
-
int mark;
|
589
|
-
/// Record which current operation is in progress
|
590
|
-
ExploreStatus es;
|
591
|
-
/// Best solution found so far
|
592
|
-
Space* best;
|
593
|
-
/// Copying recomputation distance
|
594
|
-
const unsigned int c_d;
|
595
|
-
/// Distance until next clone
|
596
|
-
unsigned int d;
|
597
|
-
public:
|
598
|
-
/**
|
599
|
-
* \brief Initialize engine
|
600
|
-
* \param c_d minimal recomputation distance
|
601
|
-
* \param a_d adaptive recomputation distance
|
602
|
-
* \param st %Stop-object
|
603
|
-
* \param sz size of one space
|
604
|
-
*/
|
605
|
-
BabEngine(unsigned int c_d, unsigned int a_d, Stop* st, size_t sz);
|
606
|
-
/// Initialize engine to start at space \a s
|
607
|
-
void init(Space* s);
|
608
|
-
/**
|
609
|
-
* \brief %Search for next better solution
|
610
|
-
*
|
611
|
-
* If \c ES_SOLUTION is returned, a next better solution has been found.
|
612
|
-
* This solution is available from \a s1.
|
613
|
-
*
|
614
|
-
* If \c ES_CONSTRAIN is returned, the engine requires that the
|
615
|
-
* space \a s1 is constrained to be better by the so-far best
|
616
|
-
* solution \a s2.
|
617
|
-
*
|
618
|
-
*/
|
619
|
-
GECODE_SEARCH_EXPORT
|
620
|
-
ExploreStatus explore(Space*& s1, Space*& s2);
|
621
|
-
/// Return stack size used by engine
|
622
|
-
size_t stacksize(void) const;
|
623
|
-
/// Destructor
|
624
|
-
~BabEngine(void);
|
625
|
-
};
|
626
|
-
|
627
|
-
/**
|
628
|
-
* \brief Depth-first branch-and-bound search engine
|
629
|
-
*
|
630
|
-
* This class implements depth-first branch-and-bound exploration
|
631
|
-
* for spaces. In order to use it on subclasses of Space, additional
|
632
|
-
* functionality providing the necessary typecasts is available
|
633
|
-
* in Gecode::BAB:
|
634
|
-
*
|
635
|
-
*/
|
636
|
-
class GECODE_SEARCH_EXPORT BAB {
|
637
|
-
protected:
|
638
|
-
/// Engine used for exploration
|
639
|
-
BabEngine e;
|
640
|
-
public:
|
641
|
-
/**
|
642
|
-
* \brief Initialize engine
|
643
|
-
* \param s root node
|
644
|
-
* \param c_d minimal recomputation distance
|
645
|
-
* \param a_d adaptive recomputation distance
|
646
|
-
* \param st %Stop-object
|
647
|
-
* \param sz size of one space
|
648
|
-
*/
|
649
|
-
BAB(Space* s, unsigned int c_d, unsigned int a_d, Stop* st, size_t sz);
|
650
|
-
/// Check whether engine has been stopped
|
651
|
-
bool stopped(void) const;
|
652
|
-
/// Return statistics
|
653
|
-
Statistics statistics(void) const;
|
654
|
-
};
|
655
|
-
|
656
|
-
}
|
657
|
-
|
658
|
-
/**
|
659
|
-
* \brief Depth-first branch-and-bound search engine
|
660
|
-
*
|
661
|
-
* Additionally, \a s must implement a member function
|
662
|
-
* \code void constrain(T* t) \endcode
|
663
|
-
* Whenever exploration requires to add a constraint
|
664
|
-
* to the space \a c currently being explored, the engine
|
665
|
-
* executes \c c->constrain(t) where \a t is the so-far
|
666
|
-
* best solution.
|
667
|
-
* \ingroup TaskModelSearch
|
668
|
-
*/
|
669
|
-
template <class T>
|
670
|
-
class BAB : public Search::BAB {
|
671
|
-
public:
|
672
|
-
/// Initialize engine for space \a s and options \a o
|
673
|
-
BAB(T* s, const Search::Options& o=Search::Options::def);
|
674
|
-
/// Return next better solution (NULL, if none exists or search has been stopped)
|
675
|
-
T* next(void);
|
676
|
-
};
|
677
|
-
|
678
|
-
/**
|
679
|
-
* \brief Perform depth-first branch-and-bound search for subclass \a T of space \a s and options \a o
|
680
|
-
*
|
681
|
-
* Additionally, \a s must implement a member function
|
682
|
-
* \code void constrain(T* t) \endcode
|
683
|
-
* Whenever exploration requires to add a constraint
|
684
|
-
* to the space \a c currently being explored, the engine
|
685
|
-
* executes \c c->constrain(t) where \a t is the so-far
|
686
|
-
* best solution.
|
687
|
-
*
|
688
|
-
* \ingroup TaskModelSearch
|
689
|
-
*/
|
690
|
-
template <class T>
|
691
|
-
T* bab(T* s, const Search::Options& o=Search::Options::def);
|
692
|
-
|
693
|
-
|
694
|
-
|
695
|
-
/**
|
696
|
-
* \brief Depth-first restart best solution search engine
|
697
|
-
*
|
698
|
-
* Additionally, \a s must implement a member function
|
699
|
-
* \code void constrain(T* t) \endcode
|
700
|
-
* Whenever exploration requires to add a constraint
|
701
|
-
* to the space \a c currently being explored, the engine
|
702
|
-
* executes \c c->constrain(t) where \a t is the so-far
|
703
|
-
* best solution.
|
704
|
-
* \ingroup TaskModelSearch
|
705
|
-
*/
|
706
|
-
template <class T>
|
707
|
-
class Restart : public DFS<T> {
|
708
|
-
protected:
|
709
|
-
/// Root node
|
710
|
-
Space* root;
|
711
|
-
/// So-far best solution
|
712
|
-
Space* best;
|
713
|
-
public:
|
714
|
-
/// Initialize engine for space \a s and options \a o
|
715
|
-
Restart(T* s, const Search::Options& o=Search::Options::def);
|
716
|
-
/// Destructor
|
717
|
-
~Restart(void);
|
718
|
-
/// Return next better solution (NULL, if none exists or search has been stopped)
|
719
|
-
T* next(void);
|
720
|
-
};
|
721
|
-
|
722
|
-
/**
|
723
|
-
* \brief Perform depth-first restart best solution search for subclass \a T of space \a s and options \a o
|
724
|
-
*
|
725
|
-
* Additionally, \a s must implement a member function
|
726
|
-
* \code void constrain(T* t) \endcode
|
727
|
-
* Whenever exploration requires to add a constraint
|
728
|
-
* to the space \a c currently being explored, the engine
|
729
|
-
* executes \c c->constrain(t) where \a t is the so-far
|
730
|
-
* best solution.
|
731
|
-
* \ingroup TaskModelSearch
|
732
|
-
*/
|
733
|
-
template <class T>
|
734
|
-
T* restart(T* s, const Search::Options& o=Search::Options::def);
|
735
|
-
|
736
|
-
}
|
737
|
-
|
738
|
-
#include "gecode/search/statistics.icc"
|
739
|
-
#include "gecode/search/stop.icc"
|
740
|
-
#include "gecode/search/options.icc"
|
741
|
-
#include "gecode/search/engine-ctrl.icc"
|
742
|
-
|
743
|
-
#include "gecode/search/reco-stack.icc"
|
744
|
-
|
745
|
-
#include "gecode/search/dfs.icc"
|
746
|
-
#include "gecode/search/lds.icc"
|
747
|
-
#include "gecode/search/bab.icc"
|
748
|
-
#include "gecode/search/restart.icc"
|
749
|
-
|
750
|
-
#endif
|
751
|
-
|
752
|
-
// STATISTICS: search-any
|