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
File without changes
|
File without changes
|
@@ -0,0 +1,433 @@
|
|
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, 2004
|
9
|
+
* Guido Tack, 2004
|
10
|
+
*
|
11
|
+
* Last modified:
|
12
|
+
* $Date: 2008-08-20 15:55:47 +0200 (Wed, 20 Aug 2008) $ by $Author: tack $
|
13
|
+
* $Revision: 7658 $
|
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
|
+
namespace Gecode {
|
41
|
+
|
42
|
+
/**
|
43
|
+
* \defgroup TaskBranchViewVal Generic branching based on view and value selection
|
44
|
+
*
|
45
|
+
* Implements view-based branching for an array of views and value.
|
46
|
+
* \ingroup TaskActor
|
47
|
+
*/
|
48
|
+
|
49
|
+
//@{
|
50
|
+
/// Status returned by member functions of view selection class
|
51
|
+
enum ViewSelStatus {
|
52
|
+
VSS_NONE, ///< Current view is not better
|
53
|
+
VSS_SELECT, ///< Current view is better
|
54
|
+
VSS_COMMIT ///< Current view is known to be a best one
|
55
|
+
};
|
56
|
+
|
57
|
+
/**
|
58
|
+
* \brief Generic branching
|
59
|
+
*
|
60
|
+
* Implements view-based branching for an array of views (of type
|
61
|
+
* \a View) and value (of type \a Val). The behaviour is defined by
|
62
|
+
* the class \a ViewSel (which view is selected for branching)
|
63
|
+
* and the class \a ValSel (which value is selected for branching).
|
64
|
+
*
|
65
|
+
* The class \a ViewSel must implement two member functions:
|
66
|
+
* - Gecode::ViewSelStatus init(const Space* \a home, \a View \a x)
|
67
|
+
* Initializes view selection with the \a View \a x. If \a x
|
68
|
+
* is known to be a best one, VSS_COMMIT should be returned.
|
69
|
+
* Otherwise, either VSS_NONE or VSS_SELECT should be returned.
|
70
|
+
* - Gecode::ViewSelStatus select(const Space* \a home, \a View \a x)
|
71
|
+
* If \a x is not better than the previously selected view,
|
72
|
+
* return VSS_NONE. If it is better, return VSS_SELECT. If
|
73
|
+
* it is a best view, return VSS_COMMIT.
|
74
|
+
*
|
75
|
+
* The class \a ValSel must implement two member functions:
|
76
|
+
* - \a Val val(const Space* \a home, View \a x) const
|
77
|
+
* returns the value (most likely determined by \a x) to branch with.
|
78
|
+
* - Gecode::ModEvent tell(Space* \a home, unsigned int \a a, \a View \a x, \a Val \a n)
|
79
|
+
* performs a tell for alternative \a a on \a x with value \a n.
|
80
|
+
*
|
81
|
+
* For examples, see \link int/branch.hh integer branchings \endlink.
|
82
|
+
*/
|
83
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
84
|
+
class ViewValBranching : public Branching {
|
85
|
+
protected:
|
86
|
+
ViewArray<View> x; ///< Views to branch on
|
87
|
+
mutable int start; ///< Unassigned views start at x[start]
|
88
|
+
/// Constructor for cloning \a b
|
89
|
+
ViewValBranching(Space* home, bool share, ViewValBranching& b);
|
90
|
+
public:
|
91
|
+
/// Constructor for creation
|
92
|
+
ViewValBranching(Space* home, ViewArray<View>& x);
|
93
|
+
/// Check status of branching, return true if alternatives left
|
94
|
+
virtual bool status(const Space* home) const;
|
95
|
+
/// Return branching description (of type Gecode::PosValDesc)
|
96
|
+
virtual const BranchingDesc* description(const Space* home) const;
|
97
|
+
/// Perform commit for branching description \a d and alternative \a a
|
98
|
+
virtual ExecStatus commit(Space* home, const BranchingDesc* d,
|
99
|
+
unsigned int a);
|
100
|
+
/// Return specification for this branching given a variable map \a m
|
101
|
+
virtual Reflection::ActorSpec spec(const Space* home,
|
102
|
+
Reflection::VarMap& m) const;
|
103
|
+
/// Return specification for a branch
|
104
|
+
virtual Reflection::BranchingSpec
|
105
|
+
branchingSpec(const Space* home,
|
106
|
+
Reflection::VarMap& m,
|
107
|
+
const BranchingDesc* d) const;
|
108
|
+
/// Actor type identifier of this branching
|
109
|
+
static Support::Symbol ati(void);
|
110
|
+
/// Post branching according to specification
|
111
|
+
static void post(Space* home, Reflection::VarMap& m,
|
112
|
+
const Reflection::ActorSpec& spec);
|
113
|
+
/// Perform cloning
|
114
|
+
virtual Actor* copy(Space* home, bool share);
|
115
|
+
};
|
116
|
+
|
117
|
+
/**
|
118
|
+
* \brief Generic assignment
|
119
|
+
*
|
120
|
+
* Implements view-based assignment for an array of views (of type
|
121
|
+
* \a View) and value (of type \a Val). The behaviour is defined by
|
122
|
+
* the class \a ValSel (which value is selected for assignment).
|
123
|
+
*
|
124
|
+
* The class \a ValSel must implement two member functions:
|
125
|
+
* - \a Val val(const Space* \a home, View \a x) const
|
126
|
+
* returns the value (most likely determined by \a x) to branch with.
|
127
|
+
* - Gecode::ModEvent tell(Space* \a home, unsigned int a, \a View \a x, \a Val \a n)
|
128
|
+
* performs a tell on \a x with value \a n (the value for \a a is
|
129
|
+
* always 0, it is present such that assignments can use the same
|
130
|
+
* value selection as branchings).
|
131
|
+
*
|
132
|
+
* For examples, see \link int/branch.hh integer branchings \endlink.
|
133
|
+
*/
|
134
|
+
template <class View, class Val, class ValSel>
|
135
|
+
class ViewValAssignment : public Branching {
|
136
|
+
protected:
|
137
|
+
ViewArray<View> x; ///< Views to branch on
|
138
|
+
mutable int start; ///< Unassigned views start at x[start]
|
139
|
+
/// Constructor for cloning \a b
|
140
|
+
ViewValAssignment(Space* home, bool share, ViewValAssignment& b);
|
141
|
+
public:
|
142
|
+
/// Constructor for creation
|
143
|
+
ViewValAssignment(Space* home, ViewArray<View>& x);
|
144
|
+
/// Check status of branching, return true if alternatives left
|
145
|
+
virtual bool status(const Space* home) const;
|
146
|
+
/// Return branching description (of type Gecode::PosValDesc)
|
147
|
+
virtual const BranchingDesc* description(const Space* home) const;
|
148
|
+
/// Perform commit for branching description \a d and alternative \a a
|
149
|
+
virtual ExecStatus commit(Space* home, const BranchingDesc* d,
|
150
|
+
unsigned int a);
|
151
|
+
/// Return specification for this assignment given a variable map \a m
|
152
|
+
virtual Reflection::ActorSpec spec(const Space* home,
|
153
|
+
Reflection::VarMap& m) const;
|
154
|
+
/// Return specification for a branch
|
155
|
+
virtual Reflection::BranchingSpec
|
156
|
+
branchingSpec(const Space* home,
|
157
|
+
Reflection::VarMap& m,
|
158
|
+
const BranchingDesc* d) const;
|
159
|
+
/// Actor type identifier of this assignment
|
160
|
+
static Support::Symbol ati(void);
|
161
|
+
/// Post assignment according to specification
|
162
|
+
static void post(Space* home, Reflection::VarMap& m,
|
163
|
+
const Reflection::ActorSpec& spec);
|
164
|
+
/// Perform cloning
|
165
|
+
virtual Actor* copy(Space* home, bool share);
|
166
|
+
};
|
167
|
+
|
168
|
+
/**
|
169
|
+
* \brief %Branching descriptions storing position and value
|
170
|
+
*
|
171
|
+
* The maximal number of alternatives is defined by \a alt.
|
172
|
+
*/
|
173
|
+
template <class Val, unsigned int alt>
|
174
|
+
class PosValDesc : public BranchingDesc {
|
175
|
+
protected:
|
176
|
+
/// Position of view
|
177
|
+
const int _pos;
|
178
|
+
/// Value to assign to
|
179
|
+
const Val _val;
|
180
|
+
public:
|
181
|
+
/** \brief Initialize description for branching \a b, position \a p, value \a n, and start position \a s.
|
182
|
+
*
|
183
|
+
* The start position can be used in the commit function to eliminate
|
184
|
+
* assigned variables from the array.
|
185
|
+
*/
|
186
|
+
PosValDesc(const Branching* b, const int p, const Val& n);
|
187
|
+
/// Return position in array
|
188
|
+
int pos(void) const;
|
189
|
+
/// Return value to branch with
|
190
|
+
Val val(void) const;
|
191
|
+
/// Report size occupied
|
192
|
+
virtual size_t size(void) const;
|
193
|
+
};
|
194
|
+
|
195
|
+
//@}
|
196
|
+
|
197
|
+
|
198
|
+
|
199
|
+
|
200
|
+
|
201
|
+
|
202
|
+
/*
|
203
|
+
* Branching descriptions with position and value
|
204
|
+
*
|
205
|
+
*/
|
206
|
+
|
207
|
+
template <class Val, unsigned int alt>
|
208
|
+
forceinline
|
209
|
+
PosValDesc<Val,alt>::PosValDesc(const Branching* b, const int p,
|
210
|
+
const Val& n)
|
211
|
+
: BranchingDesc(b,alt), _pos(p), _val(n) {}
|
212
|
+
|
213
|
+
template <class Val, unsigned int alt>
|
214
|
+
forceinline int
|
215
|
+
PosValDesc<Val,alt>::pos(void) const {
|
216
|
+
return _pos;
|
217
|
+
}
|
218
|
+
|
219
|
+
template <class Val, unsigned int alt>
|
220
|
+
forceinline Val
|
221
|
+
PosValDesc<Val,alt>::val(void) const {
|
222
|
+
return _val;
|
223
|
+
}
|
224
|
+
|
225
|
+
template <class Val, unsigned int alt>
|
226
|
+
size_t
|
227
|
+
PosValDesc<Val,alt>::size(void) const {
|
228
|
+
return sizeof(PosValDesc<Val,alt>);
|
229
|
+
}
|
230
|
+
|
231
|
+
|
232
|
+
/*
|
233
|
+
* Generic branching based on variable/value selection
|
234
|
+
*
|
235
|
+
*/
|
236
|
+
|
237
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
238
|
+
forceinline
|
239
|
+
ViewValBranching<View,Val,ViewSel,ValSel>
|
240
|
+
::ViewValBranching(Space* home, ViewArray<View>& x0)
|
241
|
+
: Branching(home), x(x0), start(0) {}
|
242
|
+
|
243
|
+
|
244
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
245
|
+
forceinline
|
246
|
+
ViewValBranching<View,Val,ViewSel,ValSel>
|
247
|
+
::ViewValBranching(Space* home, bool share, ViewValBranching& b)
|
248
|
+
: Branching(home,share,b), start(b.start) {
|
249
|
+
x.update(home,share,b.x);
|
250
|
+
}
|
251
|
+
|
252
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
253
|
+
Actor*
|
254
|
+
ViewValBranching<View,Val,ViewSel,ValSel>::copy(Space* home, bool share) {
|
255
|
+
return new (home)
|
256
|
+
ViewValBranching<View,Val,ViewSel,ValSel>(home,share,*this);
|
257
|
+
}
|
258
|
+
|
259
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
260
|
+
bool
|
261
|
+
ViewValBranching<View,Val,ViewSel,ValSel>
|
262
|
+
::status(const Space*) const {
|
263
|
+
for (int i=start; i < x.size(); i++)
|
264
|
+
if (!x[i].assigned()) {
|
265
|
+
start = i;
|
266
|
+
return true;
|
267
|
+
}
|
268
|
+
return false;
|
269
|
+
}
|
270
|
+
|
271
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
272
|
+
const BranchingDesc*
|
273
|
+
ViewValBranching<View,Val,ViewSel,ValSel>
|
274
|
+
::description(const Space* home) const {
|
275
|
+
assert(!x[start].assigned());
|
276
|
+
ViewSel vs; // For view selection
|
277
|
+
ValSel vl; // For value selection
|
278
|
+
int i = start;
|
279
|
+
int b = i++;
|
280
|
+
if (vs.init(home,x[b]) != VSS_COMMIT)
|
281
|
+
for (; i < x.size(); i++)
|
282
|
+
if (!x[i].assigned())
|
283
|
+
switch (vs.select(home,x[i])) {
|
284
|
+
case VSS_SELECT: b=i; break;
|
285
|
+
case VSS_COMMIT: b=i; goto create;
|
286
|
+
case VSS_NONE: break;
|
287
|
+
default: GECODE_NEVER;
|
288
|
+
}
|
289
|
+
create:
|
290
|
+
return new PosValDesc<Val,2>(this,b,vl.val(home,x[b]));
|
291
|
+
}
|
292
|
+
|
293
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
294
|
+
ExecStatus
|
295
|
+
ViewValBranching<View,Val,ViewSel,ValSel>
|
296
|
+
::commit(Space* home, const BranchingDesc* d, unsigned int a) {
|
297
|
+
const PosValDesc<Val,2>* pvd = static_cast<const PosValDesc<Val,2>*>(d);
|
298
|
+
ValSel vs;
|
299
|
+
return me_failed(vs.tell(home,a,x[pvd->pos()],pvd->val()))
|
300
|
+
? ES_FAILED : ES_OK;
|
301
|
+
}
|
302
|
+
|
303
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
304
|
+
Support::Symbol
|
305
|
+
ViewValBranching<View,Val,ViewSel,ValSel>::ati(void) {
|
306
|
+
return Reflection::mangle<View,Val,ViewSel,ValSel>("Gecode::ViewValBranching");
|
307
|
+
}
|
308
|
+
|
309
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
310
|
+
void
|
311
|
+
ViewValBranching<View,Val,ViewSel,ValSel>
|
312
|
+
::post(Space* home, Reflection::VarMap& vars,
|
313
|
+
const Reflection::ActorSpec& spec) {
|
314
|
+
spec.checkArity(1);
|
315
|
+
ViewArray<View> x(home, vars, spec[0]);
|
316
|
+
(void) new (home) ViewValBranching<View,Val,ViewSel,ValSel>(home, x);
|
317
|
+
}
|
318
|
+
|
319
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
320
|
+
Reflection::ActorSpec
|
321
|
+
ViewValBranching<View,Val,ViewSel,ValSel>::spec(const Space* home,
|
322
|
+
Reflection::VarMap& m) const {
|
323
|
+
Reflection::ActorSpec s(ati());
|
324
|
+
return s << x.spec(home, m);
|
325
|
+
}
|
326
|
+
|
327
|
+
template <class View, class Val, class ViewSel, class ValSel>
|
328
|
+
Reflection::BranchingSpec
|
329
|
+
ViewValBranching<View,Val,ViewSel,ValSel>::branchingSpec(const Space* home,
|
330
|
+
Reflection::VarMap& m, const BranchingDesc* d) const {
|
331
|
+
Reflection::BranchingSpec bs(d);
|
332
|
+
const PosValDesc<Val,2>* pvd = static_cast<const PosValDesc<Val,2>*>(d);
|
333
|
+
ValSel vs;
|
334
|
+
vs.branchingSpec(home, m, bs, 2, x[pvd->pos()], pvd->val());
|
335
|
+
return bs;
|
336
|
+
}
|
337
|
+
|
338
|
+
/*
|
339
|
+
* Generic assignment based on value selection
|
340
|
+
*
|
341
|
+
*/
|
342
|
+
|
343
|
+
template <class View, class Val, class ValSel>
|
344
|
+
forceinline
|
345
|
+
ViewValAssignment<View,Val,ValSel>
|
346
|
+
::ViewValAssignment(Space* home, ViewArray<View>& x0)
|
347
|
+
: Branching(home), x(x0), start(0) {}
|
348
|
+
|
349
|
+
|
350
|
+
template <class View, class Val, class ValSel>
|
351
|
+
forceinline
|
352
|
+
ViewValAssignment<View,Val,ValSel>
|
353
|
+
::ViewValAssignment(Space* home, bool share, ViewValAssignment& b)
|
354
|
+
: Branching(home,share,b), start(b.start) {
|
355
|
+
x.update(home,share,b.x);
|
356
|
+
}
|
357
|
+
|
358
|
+
template <class View, class Val, class ValSel>
|
359
|
+
Actor*
|
360
|
+
ViewValAssignment<View,Val,ValSel>::copy(Space* home, bool share) {
|
361
|
+
return new (home)
|
362
|
+
ViewValAssignment<View,Val,ValSel>(home,share,*this);
|
363
|
+
}
|
364
|
+
|
365
|
+
template <class View, class Val, class ValSel>
|
366
|
+
bool
|
367
|
+
ViewValAssignment<View,Val,ValSel>
|
368
|
+
::status(const Space*) const {
|
369
|
+
for (int i=start; i < x.size(); i++)
|
370
|
+
if (!x[i].assigned()) {
|
371
|
+
start = i;
|
372
|
+
return true;
|
373
|
+
}
|
374
|
+
return false;
|
375
|
+
}
|
376
|
+
|
377
|
+
template <class View, class Val, class ValSel>
|
378
|
+
const BranchingDesc*
|
379
|
+
ViewValAssignment<View,Val,ValSel>
|
380
|
+
::description(const Space* home) const {
|
381
|
+
assert(!x[start].assigned());
|
382
|
+
ValSel vl; // For value selection
|
383
|
+
return new PosValDesc<Val,1>(this,start,vl.val(home,x[start]));
|
384
|
+
}
|
385
|
+
|
386
|
+
template <class View, class Val, class ValSel>
|
387
|
+
ExecStatus
|
388
|
+
ViewValAssignment<View,Val,ValSel>
|
389
|
+
::commit(Space* home, const BranchingDesc* d, unsigned int) {
|
390
|
+
const PosValDesc<Val,1>* pvd = static_cast<const PosValDesc<Val,1>*>(d);
|
391
|
+
ValSel vs;
|
392
|
+
return me_failed(vs.tell(home,0,x[pvd->pos()],pvd->val()))
|
393
|
+
? ES_FAILED : ES_OK;
|
394
|
+
}
|
395
|
+
|
396
|
+
template <class View, class Val, class ValSel>
|
397
|
+
Support::Symbol
|
398
|
+
ViewValAssignment<View,Val,ValSel>::ati(void) {
|
399
|
+
return Reflection::mangle<View,Val,ValSel>("Gecode::ViewValAssignment");
|
400
|
+
}
|
401
|
+
|
402
|
+
template <class View, class Val, class ValSel>
|
403
|
+
void
|
404
|
+
ViewValAssignment<View,Val,ValSel>
|
405
|
+
::post(Space* home, Reflection::VarMap& vars,
|
406
|
+
const Reflection::ActorSpec& spec) {
|
407
|
+
spec.checkArity(1);
|
408
|
+
ViewArray<View> x(home, vars, spec[0]);
|
409
|
+
(void) new (home) ViewValAssignment<View,Val,ValSel>(home, x);
|
410
|
+
}
|
411
|
+
|
412
|
+
template <class View, class Val, class ValSel>
|
413
|
+
Reflection::ActorSpec
|
414
|
+
ViewValAssignment<View,Val,ValSel>::spec(const Space* home,
|
415
|
+
Reflection::VarMap& m) const {
|
416
|
+
Reflection::ActorSpec s(ati());
|
417
|
+
return s << x.spec(home, m);
|
418
|
+
}
|
419
|
+
|
420
|
+
template <class View, class Val, class ValSel>
|
421
|
+
Reflection::BranchingSpec
|
422
|
+
ViewValAssignment<View,Val,ValSel>::branchingSpec(const Space* home,
|
423
|
+
Reflection::VarMap& m, const BranchingDesc* d) const {
|
424
|
+
Reflection::BranchingSpec bs(d);
|
425
|
+
const PosValDesc<Val,1>* pvd = static_cast<const PosValDesc<Val,1>*>(d);
|
426
|
+
ValSel vs;
|
427
|
+
vs.branchingSpec(home, m, bs, 1, x[pvd->pos()], pvd->val());
|
428
|
+
return bs;
|
429
|
+
}
|
430
|
+
|
431
|
+
}
|
432
|
+
|
433
|
+
// STATISTICS: kernel-other
|
@@ -0,0 +1,474 @@
|
|
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, 2002
|
8
|
+
*
|
9
|
+
* Last modified:
|
10
|
+
* $Date: 2008-07-11 10:27:28 +0200 (Fri, 11 Jul 2008) $ by $Author: tack $
|
11
|
+
* $Revision: 7332 $
|
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/kernel.hh"
|
39
|
+
|
40
|
+
namespace Gecode {
|
41
|
+
|
42
|
+
/*
|
43
|
+
* Variable type disposer
|
44
|
+
*
|
45
|
+
*/
|
46
|
+
void
|
47
|
+
VarDisposerBase::dispose(Space*,VarImpBase*) {}
|
48
|
+
|
49
|
+
VarDisposerBase::~VarDisposerBase(void) {}
|
50
|
+
|
51
|
+
|
52
|
+
|
53
|
+
/*
|
54
|
+
* Actor
|
55
|
+
*
|
56
|
+
*/
|
57
|
+
Reflection::ActorSpec
|
58
|
+
Actor::spec(const Space*, Reflection::VarMap&) const {
|
59
|
+
throw Reflection::NoReflectionDefinedException();
|
60
|
+
}
|
61
|
+
|
62
|
+
size_t
|
63
|
+
Actor::allocated(void) const {
|
64
|
+
return 0;
|
65
|
+
}
|
66
|
+
|
67
|
+
#ifdef __GNUC__
|
68
|
+
/// To avoid warnings from GCC
|
69
|
+
Actor::~Actor(void) {}
|
70
|
+
#endif
|
71
|
+
|
72
|
+
|
73
|
+
|
74
|
+
/*
|
75
|
+
* Propagator
|
76
|
+
*
|
77
|
+
*/
|
78
|
+
ExecStatus
|
79
|
+
Propagator::advise(Space*, Advisor*, const Delta*) {
|
80
|
+
assert(false);
|
81
|
+
return ES_FAILED;
|
82
|
+
}
|
83
|
+
|
84
|
+
|
85
|
+
|
86
|
+
/*
|
87
|
+
* Branching
|
88
|
+
*
|
89
|
+
*/
|
90
|
+
Reflection::BranchingSpec
|
91
|
+
Branching::branchingSpec(const Space*,
|
92
|
+
Reflection::VarMap&, const BranchingDesc*) const {
|
93
|
+
throw Reflection::NoReflectionDefinedException();
|
94
|
+
}
|
95
|
+
|
96
|
+
|
97
|
+
|
98
|
+
/*
|
99
|
+
* Space: Misc
|
100
|
+
*
|
101
|
+
*/
|
102
|
+
unsigned long int Space::unused_uli;
|
103
|
+
|
104
|
+
#ifdef GECODE_HAS_VAR_DISPOSE
|
105
|
+
VarDisposerBase* Space::vd[AllVarConf::idx_d];
|
106
|
+
#endif
|
107
|
+
|
108
|
+
Space::Space(void) {
|
109
|
+
#ifdef GECODE_HAS_VAR_DISPOSE
|
110
|
+
for (int i=0; i<AllVarConf::idx_d; i++)
|
111
|
+
_vars_d[i] = NULL;
|
112
|
+
#endif
|
113
|
+
// Initialize actor and branching links
|
114
|
+
a_actors.init();
|
115
|
+
b_status = b_commit = Branching::cast(&a_actors);
|
116
|
+
// Initialize array for forced deletion to be empty
|
117
|
+
d_fst = d_cur = d_lst = NULL;
|
118
|
+
// Initialize propagator queues
|
119
|
+
pc.p.active = &pc.p.queue[0]-1;
|
120
|
+
for (int i=0; i<=PC_MAX; i++)
|
121
|
+
pc.p.queue[i].init();
|
122
|
+
pc.p.branch_id = 0;
|
123
|
+
pc.p.n_sub = 0;
|
124
|
+
}
|
125
|
+
|
126
|
+
size_t
|
127
|
+
Space::allocated(void) const {
|
128
|
+
size_t s = mm.allocated();
|
129
|
+
Actor** a = d_fst;
|
130
|
+
Actor** e = d_cur;
|
131
|
+
while (a < e) {
|
132
|
+
s += (*a)->allocated(); a++;
|
133
|
+
}
|
134
|
+
return s;
|
135
|
+
}
|
136
|
+
|
137
|
+
void
|
138
|
+
Space::d_resize(void) {
|
139
|
+
if (d_fst == NULL) {
|
140
|
+
// Create new array
|
141
|
+
d_fst = static_cast<Actor**>(alloc(4*sizeof(Actor*)));
|
142
|
+
d_cur = d_fst;
|
143
|
+
d_lst = d_fst+4;
|
144
|
+
} else {
|
145
|
+
// Resize existing array
|
146
|
+
ptrdiff_t n = d_lst - d_fst;
|
147
|
+
assert(n != 0);
|
148
|
+
Actor** a = static_cast<Actor**>(alloc(2*n*sizeof(Actor*)));
|
149
|
+
memcpy(a, d_fst, n*sizeof(Actor*));
|
150
|
+
reuse(d_fst,n*sizeof(Actor*));
|
151
|
+
d_fst = a;
|
152
|
+
d_cur = a+n;
|
153
|
+
d_lst = a+2*n;
|
154
|
+
}
|
155
|
+
}
|
156
|
+
|
157
|
+
unsigned int
|
158
|
+
Space::propagators(void) const {
|
159
|
+
unsigned int n = 0;
|
160
|
+
for (ActorLink* q = pc.p.active; q >= &pc.p.queue[0]; q--)
|
161
|
+
for (ActorLink* a = q->next(); a != q; a = a->next())
|
162
|
+
n++;
|
163
|
+
for (ActorLink* a = a_actors.next();
|
164
|
+
Branching::cast(a) != b_commit; a = a->next())
|
165
|
+
n++;
|
166
|
+
return n;
|
167
|
+
}
|
168
|
+
|
169
|
+
unsigned int
|
170
|
+
Space::branchings(void) const {
|
171
|
+
unsigned int n = 0;
|
172
|
+
for (ActorLink* a = Branching::cast(b_status);
|
173
|
+
a != &a_actors; a = a->next())
|
174
|
+
n++;
|
175
|
+
return n;
|
176
|
+
}
|
177
|
+
|
178
|
+
void
|
179
|
+
Space::getVars(Reflection::VarMap&, bool) {}
|
180
|
+
|
181
|
+
Reflection::BranchingSpec
|
182
|
+
Space::branchingSpec(Reflection::VarMap& m, const BranchingDesc* d) const {
|
183
|
+
const Branching* b = b_commit;
|
184
|
+
while ((b != Branching::cast(&a_actors)) && (d->_id != b->id))
|
185
|
+
b = Branching::cast(b->next());
|
186
|
+
if (b == Branching::cast(&a_actors))
|
187
|
+
throw SpaceNoBranching();
|
188
|
+
return b->branchingSpec(this, m, d);
|
189
|
+
}
|
190
|
+
|
191
|
+
Space::~Space(void) {
|
192
|
+
// Mark space as failed
|
193
|
+
fail();
|
194
|
+
// Delete actors that must be deleted
|
195
|
+
{
|
196
|
+
Actor** a = d_fst;
|
197
|
+
Actor** e = d_cur;
|
198
|
+
// So that d_unforce knows that deletion is in progress
|
199
|
+
d_fst = NULL;
|
200
|
+
while (a < e) {
|
201
|
+
(void) (*a)->dispose(this);
|
202
|
+
a++;
|
203
|
+
}
|
204
|
+
}
|
205
|
+
#ifdef GECODE_HAS_VAR_DISPOSE
|
206
|
+
// Delete variables that were registered for disposal
|
207
|
+
for (int i=AllVarConf::idx_d; i--;)
|
208
|
+
if (_vars_d[i] != NULL)
|
209
|
+
vd[i]->dispose(this, _vars_d[i]);
|
210
|
+
#endif
|
211
|
+
}
|
212
|
+
|
213
|
+
|
214
|
+
|
215
|
+
/*
|
216
|
+
* Space: propagation
|
217
|
+
*
|
218
|
+
*/
|
219
|
+
SpaceStatus
|
220
|
+
Space::status(unsigned long int& pn) {
|
221
|
+
if (failed())
|
222
|
+
return SS_FAILED;
|
223
|
+
if (!stable()) {
|
224
|
+
assert(pc.p.active >= &pc.p.queue[0]);
|
225
|
+
Propagator* p;
|
226
|
+
ModEventDelta med_o;
|
227
|
+
goto unstable;
|
228
|
+
execute:
|
229
|
+
pn++;
|
230
|
+
// Keep old modification event delta
|
231
|
+
med_o = p->u.med;
|
232
|
+
// Clear med but leave propagator in queue
|
233
|
+
p->u.med = 0;
|
234
|
+
switch (p->propagate(this,med_o)) {
|
235
|
+
case ES_FAILED:
|
236
|
+
fail();
|
237
|
+
return SS_FAILED;
|
238
|
+
case ES_NOFIX:
|
239
|
+
// Find next, if possible
|
240
|
+
if (p->u.med != 0) {
|
241
|
+
unstable:
|
242
|
+
// There is at least one propagator in a queue
|
243
|
+
do {
|
244
|
+
assert(pc.p.active >= &pc.p.queue[0]);
|
245
|
+
// First propagator or link back to queue
|
246
|
+
ActorLink* fst = pc.p.active->next();
|
247
|
+
if (pc.p.active != fst) {
|
248
|
+
p = Propagator::cast(fst);
|
249
|
+
goto execute;
|
250
|
+
}
|
251
|
+
pc.p.active--;
|
252
|
+
} while (true);
|
253
|
+
GECODE_NEVER;
|
254
|
+
}
|
255
|
+
// Fall through
|
256
|
+
case ES_FIX:
|
257
|
+
// Clear med and put into idle queue
|
258
|
+
p->u.med = 0; p->unlink(); a_actors.head(p);
|
259
|
+
stable_or_unstable:
|
260
|
+
// There might be a propagator in the queue
|
261
|
+
do {
|
262
|
+
assert(pc.p.active >= &pc.p.queue[0]);
|
263
|
+
// First propagator or link back to queue
|
264
|
+
ActorLink* fst = pc.p.active->next();
|
265
|
+
if (pc.p.active != fst) {
|
266
|
+
p = Propagator::cast(fst);
|
267
|
+
goto execute;
|
268
|
+
}
|
269
|
+
} while (--pc.p.active >= &pc.p.queue[0]);
|
270
|
+
assert(pc.p.active < &pc.p.queue[0]);
|
271
|
+
goto stable;
|
272
|
+
case __ES_SUBSUMED:
|
273
|
+
p->unlink(); reuse(p,p->u.size);
|
274
|
+
goto stable_or_unstable;
|
275
|
+
case __ES_PARTIAL:
|
276
|
+
// Schedule propagator with specified propagator events
|
277
|
+
assert(p->u.med != 0);
|
278
|
+
enqueue(p);
|
279
|
+
goto unstable;
|
280
|
+
default:
|
281
|
+
GECODE_NEVER;
|
282
|
+
}
|
283
|
+
}
|
284
|
+
stable:
|
285
|
+
/*
|
286
|
+
* Find the next branching that has still alternatives left
|
287
|
+
*
|
288
|
+
* It is important to note that branchings reporting to have no more
|
289
|
+
* alternatives left can not be deleted. They can not be deleted
|
290
|
+
* as there might be branching descriptions to be used in commit
|
291
|
+
* that refer to one of these branchings. This e.g. happens when
|
292
|
+
* we combine branch-and-bound search with adaptive recomputation: during
|
293
|
+
* recomputation, a copy is constrained to be better than the currently
|
294
|
+
* best solution, then the first half of the BranchingDescs is posted,
|
295
|
+
* and a fixpoint computed (for storing in the middle of the path). Then
|
296
|
+
* the remaining BranchingDescs are posted, and because of the additional
|
297
|
+
* constraints that the space must be better than the previous solution,
|
298
|
+
* the corresponding Branchings may already have no alternatives left.
|
299
|
+
*
|
300
|
+
* A branching reporting that no more alternatives exist will eventually
|
301
|
+
* be deleted in commit. It will be deleted if the first branching
|
302
|
+
* description is used in commit that does not refer to this branching.
|
303
|
+
* As we insist that branching descriptions are used in order of
|
304
|
+
* creation, all further branching descriptions cannot refer to this
|
305
|
+
* branching.
|
306
|
+
*
|
307
|
+
*/
|
308
|
+
while (b_status != Branching::cast(&a_actors)) {
|
309
|
+
if (b_status->status(this))
|
310
|
+
return SS_BRANCH;
|
311
|
+
b_status = Branching::cast(b_status->next());
|
312
|
+
}
|
313
|
+
// No branching with alternatives left, space is solved
|
314
|
+
return SS_SOLVED;
|
315
|
+
}
|
316
|
+
|
317
|
+
|
318
|
+
void
|
319
|
+
Space::commit(const BranchingDesc* d, unsigned int a) {
|
320
|
+
if (failed())
|
321
|
+
return;
|
322
|
+
/*
|
323
|
+
* This relies on the fact that branching descriptions must be
|
324
|
+
* used in the order of creation. If a branching description
|
325
|
+
* with an id different from the id of the current branching
|
326
|
+
* is used, it is clear that the current branching can be discarded
|
327
|
+
* as all of its descriptions must have been used already.
|
328
|
+
*
|
329
|
+
*/
|
330
|
+
while ((b_commit != Branching::cast(&a_actors)) &&
|
331
|
+
(d->_id != b_commit->id)) {
|
332
|
+
Branching* b = b_commit;
|
333
|
+
b_commit = Branching::cast(b_commit->next());
|
334
|
+
if (b == b_status)
|
335
|
+
b_status = b_commit;
|
336
|
+
b->unlink();
|
337
|
+
reuse(b,b->dispose(this));
|
338
|
+
}
|
339
|
+
if (b_commit == Branching::cast(&a_actors))
|
340
|
+
throw SpaceNoBranching();
|
341
|
+
if (a >= d->alternatives())
|
342
|
+
throw SpaceIllegalAlternative();
|
343
|
+
if (b_commit->commit(this,d,a) == ES_FAILED)
|
344
|
+
fail();
|
345
|
+
}
|
346
|
+
|
347
|
+
|
348
|
+
|
349
|
+
/*
|
350
|
+
* Space cloning
|
351
|
+
*
|
352
|
+
* Cloning is performed in two steps:
|
353
|
+
* - The space itself is copied by the copy constructor. This
|
354
|
+
* also copies all propagators, branchings, and variables.
|
355
|
+
* The copied variables are recorded.
|
356
|
+
* - In the second step the dependency information of the recorded
|
357
|
+
* variables is updated and their forwarding information is reset.
|
358
|
+
*
|
359
|
+
*/
|
360
|
+
Space::Space(bool share, Space& s)
|
361
|
+
: mm(s.mm,s.pc.p.n_sub*sizeof(Propagator**)) {
|
362
|
+
#ifdef GECODE_HAS_VAR_DISPOSE
|
363
|
+
for (int i=0; i<AllVarConf::idx_d; i++)
|
364
|
+
_vars_d[i] = NULL;
|
365
|
+
#endif
|
366
|
+
for (int i=0; i<AllVarConf::idx_c; i++)
|
367
|
+
pc.c.vars_u[i] = NULL;
|
368
|
+
pc.c.vars_noidx = NULL;
|
369
|
+
pc.c.shared = NULL;
|
370
|
+
// Copy all actors
|
371
|
+
{
|
372
|
+
ActorLink* p = &a_actors;
|
373
|
+
ActorLink* e = &s.a_actors;
|
374
|
+
for (ActorLink* a = e->next(); a != e; a = a->next()) {
|
375
|
+
Actor* c = Actor::cast(a)->copy(this,share);
|
376
|
+
// Link copied actor
|
377
|
+
p->next(ActorLink::cast(c)); ActorLink::cast(c)->prev(p);
|
378
|
+
// Note that forwarding is done in the constructors
|
379
|
+
p = c;
|
380
|
+
}
|
381
|
+
// Link last actor
|
382
|
+
p->next(&a_actors); a_actors.prev(p);
|
383
|
+
}
|
384
|
+
// Setup array for actor disposal
|
385
|
+
{
|
386
|
+
ptrdiff_t n = s.d_cur - s.d_fst;
|
387
|
+
if (n == 0) {
|
388
|
+
// No actors
|
389
|
+
d_fst = d_cur = d_lst = NULL;
|
390
|
+
} else {
|
391
|
+
// Leave one entry free
|
392
|
+
Actor** a = static_cast<Actor**>(alloc((n+1)*sizeof(Actor*)));
|
393
|
+
d_fst = a;
|
394
|
+
d_cur = a+n;
|
395
|
+
d_lst = a+n+1;
|
396
|
+
Actor** f = s.d_fst;
|
397
|
+
do {
|
398
|
+
n--;
|
399
|
+
a[n] = Actor::cast(f[n]->prev());
|
400
|
+
} while (n != 0);
|
401
|
+
}
|
402
|
+
}
|
403
|
+
// Setup branching pointers
|
404
|
+
if (s.b_status == &s.a_actors) {
|
405
|
+
b_status = Branching::cast(&a_actors);
|
406
|
+
} else {
|
407
|
+
b_status = Branching::cast(s.b_status->prev());
|
408
|
+
}
|
409
|
+
if (s.b_commit == &s.a_actors) {
|
410
|
+
b_commit = Branching::cast(&a_actors);
|
411
|
+
} else {
|
412
|
+
b_commit = Branching::cast(s.b_commit->prev());
|
413
|
+
}
|
414
|
+
}
|
415
|
+
|
416
|
+
Space*
|
417
|
+
Space::clone(bool share) {
|
418
|
+
if (failed())
|
419
|
+
throw SpaceFailed("Space::clone");
|
420
|
+
if (!stable())
|
421
|
+
throw SpaceNotStable("Space::clone");
|
422
|
+
|
423
|
+
// Copy all data structures (which in turn will invoke the constructor)
|
424
|
+
Space* c = copy(share);
|
425
|
+
|
426
|
+
// Update variables without indexing structure
|
427
|
+
VarImp<NoIdxVarImpConf>* x =
|
428
|
+
static_cast<VarImp<NoIdxVarImpConf>*>(c->pc.c.vars_noidx);
|
429
|
+
while (x != NULL) {
|
430
|
+
VarImp<NoIdxVarImpConf>* n = x->next();
|
431
|
+
x->idx[0] = x->idx[1] = NULL;
|
432
|
+
x = n;
|
433
|
+
}
|
434
|
+
// Update variables with indexing structure
|
435
|
+
c->update(static_cast<ActorLink**>(c->mm.subscriptions()));
|
436
|
+
|
437
|
+
// Re-establish prev links (reset forwarding information)
|
438
|
+
ActorLink* p_a = &a_actors;
|
439
|
+
ActorLink* c_a = p_a->next();
|
440
|
+
// First update propagators and check for advisors that also must be reset
|
441
|
+
while (c_a != b_commit) {
|
442
|
+
Propagator* p = Propagator::cast(c_a);
|
443
|
+
if (p->u.advisors != NULL) {
|
444
|
+
ActorLink* a = p->u.advisors;
|
445
|
+
p->u.advisors = NULL;
|
446
|
+
do {
|
447
|
+
a->prev(p); a = a->next();
|
448
|
+
} while (a != NULL);
|
449
|
+
}
|
450
|
+
c_a->prev(p_a); p_a = c_a; c_a = c_a->next();
|
451
|
+
}
|
452
|
+
// Update branchings
|
453
|
+
while (c_a != &a_actors) {
|
454
|
+
c_a->prev(p_a); p_a = c_a; c_a = c_a->next();
|
455
|
+
}
|
456
|
+
assert(c_a->prev() == p_a);
|
457
|
+
|
458
|
+
// Reset links for shared objects
|
459
|
+
for (SharedHandle::Object* s = c->pc.c.shared; s != NULL; s = s->next)
|
460
|
+
s->fwd = NULL;
|
461
|
+
|
462
|
+
// Initialize propagator queue
|
463
|
+
c->pc.p.active = &c->pc.p.queue[0]-1;
|
464
|
+
for (int i=0; i<=PC_MAX; i++)
|
465
|
+
c->pc.p.queue[i].init();
|
466
|
+
// Copy propagation only data
|
467
|
+
c->pc.p.n_sub = pc.p.n_sub;
|
468
|
+
c->pc.p.branch_id = pc.p.branch_id;
|
469
|
+
return c;
|
470
|
+
}
|
471
|
+
|
472
|
+
}
|
473
|
+
|
474
|
+
// STATISTICS: kernel-core
|