gecoder-with-gecode 0.9.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGES +6 -0
- data/README +1 -1
- data/THANKS +18 -0
- data/example/equation_system.rb +3 -1
- data/example/magic_sequence.rb +3 -1
- data/example/queens.rb +3 -1
- data/example/send_more_money.rb +24 -30
- data/example/send_most_money.rb +15 -26
- data/example/square_tiling.rb +3 -1
- data/example/sudoku-set.rb +3 -1
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
- data/ext/gecode-2.2.0/Makefile.dep +8056 -0
- data/ext/gecode-2.2.0/Makefile.in +1590 -0
- data/ext/gecode-2.2.0/changelog.in +2698 -0
- data/ext/gecode-2.2.0/configure +13112 -0
- data/ext/gecode-2.2.0/configure.ac +273 -0
- data/ext/gecode-2.2.0/configure.ac.in +269 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
- data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
- data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
- data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
- data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
- data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
- data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
- data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
- data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
- data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
- data/ext/gecode-2.2.0/examples/crew.cc +286 -0
- data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
- data/ext/gecode-2.2.0/examples/domino.cc +297 -0
- data/ext/gecode-2.2.0/examples/donald.cc +107 -0
- data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
- data/ext/gecode-2.2.0/examples/golf.cc +297 -0
- data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
- data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
- data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
- data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
- data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
- data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
- data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
- data/ext/gecode-2.2.0/examples/knights.cc +220 -0
- data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
- data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
- data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
- data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
- data/ext/gecode-2.2.0/examples/money.cc +105 -0
- data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
- data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
- data/ext/gecode-2.2.0/examples/partition.cc +141 -0
- data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
- data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
- data/ext/gecode-2.2.0/examples/photo.cc +170 -0
- data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
- data/ext/gecode-2.2.0/examples/queens.cc +147 -0
- data/ext/gecode-2.2.0/examples/queens.js +57 -0
- data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
- data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
- data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
- data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
- data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
- data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
- data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
- data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
- data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
- data/ext/gecode-2.2.0/examples/support.hh +338 -0
- data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
- data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
- data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
- data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
- data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
- data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
- data/ext/gecode-2.2.0/gecode.m4 +1046 -0
- data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
- data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
- data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
- data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
- data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
- data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
- data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
- data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
- data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
- data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
- data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
- data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
- data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
- data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
- data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
- data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
- data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
- data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
- data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
- data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
- data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
- data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
- data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
- data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
- data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
- data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
- data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
- data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
- data/ext/gecode-2.2.0/gecode/search.hh +759 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
- data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
- data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
- data/ext/gecode-2.2.0/gecode/set.hh +970 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
- data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
- data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
- data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
- data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
- data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
- data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
- data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
- data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
- data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
- data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
- data/ext/gecode-2.2.0/test/assign.cc +181 -0
- data/ext/gecode-2.2.0/test/assign.hh +93 -0
- data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch.cc +563 -0
- data/ext/gecode-2.2.0/test/branch.hh +144 -0
- data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
- data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
- data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
- data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
- data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
- data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
- data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
- data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
- data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
- data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
- data/ext/gecode-2.2.0/test/int.cc +688 -0
- data/ext/gecode-2.2.0/test/int.hh +267 -0
- data/ext/gecode-2.2.0/test/int.icc +266 -0
- data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
- data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
- data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
- data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
- data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
- data/ext/gecode-2.2.0/test/int/count.cc +357 -0
- data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
- data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
- data/ext/gecode-2.2.0/test/int/element.cc +333 -0
- data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
- data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
- data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
- data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
- data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
- data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
- data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
- data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
- data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
- data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
- data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
- data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
- data/ext/gecode-2.2.0/test/search.cc +618 -0
- data/ext/gecode-2.2.0/test/set.cc +753 -0
- data/ext/gecode-2.2.0/test/set.hh +286 -0
- data/ext/gecode-2.2.0/test/set.icc +108 -0
- data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
- data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
- data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
- data/ext/gecode-2.2.0/test/set/int.cc +473 -0
- data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
- data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
- data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
- data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
- data/ext/gecode-2.2.0/test/set/select.cc +299 -0
- data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
- data/ext/gecode-2.2.0/test/test.cc +287 -0
- data/ext/gecode-2.2.0/test/test.hh +175 -0
- data/ext/gecode-2.2.0/test/test.icc +93 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
- data/lib/gecoder/bindings.rb +7 -5
- data/lib/gecoder/bindings/bindings.rb +8 -8
- data/lib/gecoder/interface.rb +4 -2
- data/lib/gecoder/interface/binding_changes.rb +1 -1
- data/lib/gecoder/interface/branch.rb +1 -1
- data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
- data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
- data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
- data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
- data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
- data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
- data/lib/gecoder/interface/convenience.rb +99 -0
- data/lib/gecoder/interface/enum_wrapper.rb +1 -1
- data/lib/gecoder/interface/mixin.rb +486 -0
- data/lib/gecoder/interface/search.rb +23 -22
- data/lib/gecoder/version.rb +1 -1
- data/specs/branch.rb +5 -3
- data/specs/constraints/bool/boolean.rb +3 -1
- data/specs/constraints/bool/linear.rb +3 -1
- data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
- data/specs/constraints/bool_enum/channel.rb +3 -1
- data/specs/constraints/fixnum_enum/element.rb +3 -1
- data/specs/constraints/int/arithmetic.rb +3 -1
- data/specs/constraints/int/channel.rb +3 -1
- data/specs/constraints/int/linear.rb +3 -1
- data/specs/constraints/int/linear_properties.rb +3 -1
- data/specs/constraints/int_enum/arithmetic.rb +3 -1
- data/specs/constraints/int_enum/channel.rb +3 -1
- data/specs/constraints/int_enum/count.rb +3 -1
- data/specs/constraints/int_enum/distinct.rb +3 -1
- data/specs/constraints/int_enum/element.rb +3 -1
- data/specs/constraints/int_enum/sort.rb +3 -1
- data/specs/constraints/property_helper.rb +10 -10
- data/specs/constraints/reification_sugar.rb +3 -1
- data/specs/constraints/selected_set/select.rb +6 -5
- data/specs/constraints/selected_set/select_properties.rb +12 -10
- data/specs/constraints/set/channel.rb +3 -1
- data/specs/constraints/set/domain.rb +4 -4
- data/specs/constraints/set/relation.rb +4 -4
- data/specs/constraints/set_enum/channel.rb +3 -1
- data/specs/constraints/set_enum/distinct.rb +3 -1
- data/specs/constraints/set_enum/element.rb +77 -0
- data/specs/enum_wrapper.rb +1 -1
- data/specs/mixin.rb +78 -0
- data/specs/model.rb +5 -5
- data/specs/search.rb +20 -14
- data/specs/selected_set.rb +3 -3
- data/specs/set_elements.rb +2 -2
- data/tasks/distribution.rake +25 -4
- metadata +739 -602
- data/example/money.rb +0 -36
- data/ext/gecode-2.1.1/Makefile.dep +0 -7622
- data/ext/gecode-2.1.1/Makefile.in +0 -1568
- data/ext/gecode-2.1.1/changelog.in +0 -2459
- data/ext/gecode-2.1.1/configure +0 -11631
- data/ext/gecode-2.1.1/configure.ac +0 -249
- data/ext/gecode-2.1.1/configure.ac.in +0 -245
- data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
- data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
- data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
- data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
- data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
- data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
- data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
- data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
- data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
- data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
- data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
- data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
- data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
- data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
- data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
- data/ext/gecode-2.1.1/gecode.m4 +0 -956
- data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
- data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
- data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
- data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
- data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
- data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
- data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
- data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
- data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
- data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
- data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
- data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
- data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
- data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
- data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
- data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
- data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
- data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
- data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
- data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
- data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
- data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
- data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
- data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
- data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
- data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
- data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
- data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
- data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
- data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
- data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
- data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
- data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
- data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
- data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
- data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
- data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
- data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
- data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
- data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
- data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
- data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
- data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
- data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
- data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
- data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
- data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
- data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
- data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
- data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
- data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
- data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
- data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
- data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
- data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
- data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
- data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
- data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
- data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
- data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
- data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
- data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
- data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
- data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
- data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
- data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
- data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
- data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
- data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
- data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
- data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
- data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
- data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
- data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
- data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
- data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
- data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
- data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
- data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
- data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
- data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
- data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
- data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
- data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
- data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
- data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
- data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
- data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
- data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
- data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
- data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
- data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
- data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
- data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
- data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
- data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
- data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
- data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
- data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
- data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
- data/ext/gecode-2.1.1/gecode/search.hh +0 -752
- data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
- data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
- data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
- data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
- data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
- data/ext/gecode-2.1.1/gecode/set.hh +0 -970
- data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
- data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
- data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
- data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
- data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
- data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
- data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
- data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
- data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
- data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
- data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
- data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
- data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
- data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
- data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
- data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
- data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
- data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
- data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
- data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
- data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
- data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
- data/lib/gecoder/interface/model.rb +0 -453
- data/lib/gecoder/interface/model_sugar.rb +0 -84
- data/specs/constraints/set_enum/select.rb +0 -73
@@ -1,341 +0,0 @@
|
|
1
|
-
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
-
/*
|
3
|
-
* Main authors:
|
4
|
-
* Christian Schulte <schulte@gecode.org>
|
5
|
-
* Guido Tack <tack@gecode.org>
|
6
|
-
*
|
7
|
-
* Contributing authors:
|
8
|
-
* Gabor Szokoli <szokoli@gecode.org>
|
9
|
-
*
|
10
|
-
* Copyright:
|
11
|
-
* Christian Schulte, 2002
|
12
|
-
* Guido Tack, 2004
|
13
|
-
* Gabor Szokoli, 2003
|
14
|
-
*
|
15
|
-
* Last modified:
|
16
|
-
* $Date: 2008-01-29 13:37:51 +0100 (Tue, 29 Jan 2008) $ by $Author: tack $
|
17
|
-
* $Revision: 5993 $
|
18
|
-
*
|
19
|
-
* This file is part of Gecode, the generic constraint
|
20
|
-
* development environment:
|
21
|
-
* http://www.gecode.org
|
22
|
-
*
|
23
|
-
* Permission is hereby granted, free of charge, to any person obtaining
|
24
|
-
* a copy of this software and associated documentation files (the
|
25
|
-
* "Software"), to deal in the Software without restriction, including
|
26
|
-
* without limitation the rights to use, copy, modify, merge, publish,
|
27
|
-
* distribute, sublicense, and/or sell copies of the Software, and to
|
28
|
-
* permit persons to whom the Software is furnished to do so, subject to
|
29
|
-
* the following conditions:
|
30
|
-
*
|
31
|
-
* The above copyright notice and this permission notice shall be
|
32
|
-
* included in all copies or substantial portions of the Software.
|
33
|
-
*
|
34
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
35
|
-
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
36
|
-
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
37
|
-
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
38
|
-
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
39
|
-
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
40
|
-
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
41
|
-
*
|
42
|
-
*/
|
43
|
-
|
44
|
-
#ifndef __GECODE_INT_DISTINCT_HH__
|
45
|
-
#define __GECODE_INT_DISTINCT_HH__
|
46
|
-
|
47
|
-
#include "gecode/int.hh"
|
48
|
-
|
49
|
-
#include "gecode/int/rel.hh"
|
50
|
-
|
51
|
-
/**
|
52
|
-
* \namespace Gecode::Int::Distinct
|
53
|
-
* \brief %Distinct propagators
|
54
|
-
*/
|
55
|
-
|
56
|
-
namespace Gecode { namespace Int { namespace Distinct {
|
57
|
-
|
58
|
-
/**
|
59
|
-
* \brief Naive value distinct propagator
|
60
|
-
*
|
61
|
-
* Eliminates values of assigned views of type \a View.
|
62
|
-
*
|
63
|
-
* Requires \code #include "gecode/int/distinct.hh" \endcode
|
64
|
-
* \ingroup FuncIntProp
|
65
|
-
*/
|
66
|
-
template <class View>
|
67
|
-
class Val : public NaryPropagator<View,PC_INT_VAL> {
|
68
|
-
protected:
|
69
|
-
using NaryPropagator<View,PC_INT_VAL>::x;
|
70
|
-
|
71
|
-
/// Constructor for posting
|
72
|
-
Val(Space* home, ViewArray<View>& x);
|
73
|
-
/// Constructor for cloning \a p
|
74
|
-
Val(Space* home, bool share, Val<View>& p);
|
75
|
-
public:
|
76
|
-
/// Copy propagator during cloning
|
77
|
-
virtual Actor* copy(Space* home, bool share);
|
78
|
-
/// Perform propagation
|
79
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
80
|
-
/// Specification for this propagator
|
81
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
82
|
-
Reflection::VarMap& m) const;
|
83
|
-
/// Name of this propagator
|
84
|
-
static Support::Symbol ati(void);
|
85
|
-
/// Post propagator for specification
|
86
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
87
|
-
const Reflection::ActorSpec& spec);
|
88
|
-
/// Post propagator for view array \a x
|
89
|
-
static ExecStatus post(Space* home, ViewArray<View>& x);
|
90
|
-
};
|
91
|
-
|
92
|
-
/**
|
93
|
-
* \brief Eliminate singletons by naive value propagation
|
94
|
-
*
|
95
|
-
* This is actually the propagation algorithm for Distinct::Val.
|
96
|
-
* It is available as separate function as it is reused for
|
97
|
-
* both bounds-consistent and domain-consistent distinct
|
98
|
-
* propagators.
|
99
|
-
*
|
100
|
-
* If \a complete is true, computes fixpoint, otherwise might not
|
101
|
-
* compute fixpoint. This can be helpful when used together with
|
102
|
-
* bounds or domain propagation to protect from pathological cases
|
103
|
-
* which can be handled more efficiently with bounds propagation.
|
104
|
-
*/
|
105
|
-
template <class View, bool complete>
|
106
|
-
ExecStatus prop_val(Space* home, ViewArray<View>&);
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
/**
|
111
|
-
* \brief Bounds-consistent distinct propagator
|
112
|
-
*
|
113
|
-
* The propagator uses staging: first it uses naive value-based
|
114
|
-
* propagation and only then uses bounds-consistent propagation.
|
115
|
-
* Due to using naive value-based propagation, the propagator
|
116
|
-
* might actually achieve stronger consistency than just
|
117
|
-
* bounds-consistency.
|
118
|
-
*
|
119
|
-
* The algorithm is taken from:
|
120
|
-
* A. Lopez-Ortiz, C.-G. Quimper, J. Tromp, and P. van Beek.
|
121
|
-
* A fast and simple algorithm for bounds consistency of the
|
122
|
-
* alldifferent constraint. IJCAI-2003.
|
123
|
-
*
|
124
|
-
* This implementation uses the code that is provided by
|
125
|
-
* Peter Van Beek:
|
126
|
-
* http://ai.uwaterloo.ca/~vanbeek/software/software.html
|
127
|
-
* The code (originally by John Tromp) here has only been slightly modified
|
128
|
-
* to fit %Gecode (taking idempotent/non-idempotent propagation into account)
|
129
|
-
* and uses a more efficient layout of datastructures (keeping the number
|
130
|
-
* of different arrays small).
|
131
|
-
*
|
132
|
-
* Requires \code #include "gecode/int/distinct.hh" \endcode
|
133
|
-
* \ingroup FuncIntProp
|
134
|
-
*/
|
135
|
-
template <class View>
|
136
|
-
class Bnd : public Propagator {
|
137
|
-
protected:
|
138
|
-
/// Views on which to perform bounds-propagation
|
139
|
-
ViewArray<View> x;
|
140
|
-
/// Views on which to perform value-propagation (subset of \c x)
|
141
|
-
ViewArray<View> y;
|
142
|
-
/// Constructor for posting
|
143
|
-
Bnd(Space* home, ViewArray<View>& x);
|
144
|
-
/// Constructor for cloning \a p
|
145
|
-
Bnd(Space* home, bool share, Bnd<View>& p);
|
146
|
-
public:
|
147
|
-
/// Post propagator for view array \a x
|
148
|
-
static ExecStatus post(Space* home, ViewArray<View>& x);
|
149
|
-
/// Post propagator for specification
|
150
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
151
|
-
const Reflection::ActorSpec& spec);
|
152
|
-
/// Perform propagation
|
153
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
154
|
-
/**
|
155
|
-
* \brief Cost function
|
156
|
-
*
|
157
|
-
* If in stage for naive value propagation, the cost is dynamic
|
158
|
-
* PC_LINEAR_LO. Otherwise it is dynamic PC_LINEAR_HI.
|
159
|
-
*/
|
160
|
-
virtual PropCost cost(ModEventDelta med) const;
|
161
|
-
/// Copy propagator during cloning
|
162
|
-
virtual Actor* copy(Space* home, bool share);
|
163
|
-
/// Destructor
|
164
|
-
virtual size_t dispose(Space* home);
|
165
|
-
/// Specification for this propagator
|
166
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
167
|
-
Reflection::VarMap& m) const;
|
168
|
-
/// Name of this propagator
|
169
|
-
static Support::Symbol ati(void);
|
170
|
-
};
|
171
|
-
|
172
|
-
/**
|
173
|
-
* \brief Perform bounds-consistent distinct propagation
|
174
|
-
*
|
175
|
-
* This is actually the propagation algorithm for Distinct::Bnd.
|
176
|
-
* It is available as separate function as it is reused for
|
177
|
-
* both bounds-consistent and domain-consistent distinct
|
178
|
-
* propagators.
|
179
|
-
*/
|
180
|
-
template <class View>
|
181
|
-
ExecStatus prop_bnd(Space* home, ViewArray<View>& x, int m);
|
182
|
-
|
183
|
-
template <class View> class ViewNode;
|
184
|
-
template <class View> class ValNode;
|
185
|
-
|
186
|
-
/**
|
187
|
-
* \brief Propagation controller for domain-consistent distinct
|
188
|
-
*
|
189
|
-
* The propagation controller provides convenient access to
|
190
|
-
* performing incremental domain-consistent distinct propagation
|
191
|
-
* so that the routines can be reused easily.
|
192
|
-
*
|
193
|
-
* Requires \code #include "gecode/int/distinct.hh" \endcode
|
194
|
-
* \ingroup FuncIntProp
|
195
|
-
*/
|
196
|
-
template <class View>
|
197
|
-
class DomCtrl {
|
198
|
-
protected:
|
199
|
-
/// View-value graph for propagation
|
200
|
-
class ViewValGraph {
|
201
|
-
public:
|
202
|
-
/// Array of view nodes
|
203
|
-
ViewNode<View>** view;
|
204
|
-
/// Number of view nodes
|
205
|
-
int n_view;
|
206
|
-
/// Array of value nodes
|
207
|
-
ValNode<View>* val;
|
208
|
-
/// Number of value nodes
|
209
|
-
int n_val;
|
210
|
-
/// Marking counter
|
211
|
-
unsigned int count;
|
212
|
-
public:
|
213
|
-
/// Construct graph as not yet initialized
|
214
|
-
ViewValGraph(void);
|
215
|
-
/// Test whether graph has been initialized
|
216
|
-
bool initialized(void) const;
|
217
|
-
/// Initialize graph
|
218
|
-
ExecStatus init(Space* home, int n, View* x);
|
219
|
-
/// Mark edges in graph
|
220
|
-
void mark(void);
|
221
|
-
/// Prune unmarked edges, \a assigned is true if a view got assigned
|
222
|
-
ExecStatus tell(Space* home, bool& assigned);
|
223
|
-
/// Purge graph if necessary
|
224
|
-
void purge(void);
|
225
|
-
/// Synchronize graph with new view domains
|
226
|
-
bool sync(void);
|
227
|
-
public:
|
228
|
-
/// Stack used during matching
|
229
|
-
typedef Support::SentinelStack<ViewNode<View>*> MatchStack;
|
230
|
-
/// Find a matching for node \a x
|
231
|
-
bool match(MatchStack& m, ViewNode<View>* x);
|
232
|
-
};
|
233
|
-
/// Propagation is performed on a view-value graph
|
234
|
-
ViewValGraph vvg;
|
235
|
-
public:
|
236
|
-
/// Initialize with non-initialized view-value graph
|
237
|
-
DomCtrl(void);
|
238
|
-
/// Check whether a view-value graph is available
|
239
|
-
bool available(void);
|
240
|
-
/// Initialize view-value graph for views \a x
|
241
|
-
ExecStatus init(Space* home, int n, View* x);
|
242
|
-
/// Synchronize available view-value graph
|
243
|
-
ExecStatus sync(void);
|
244
|
-
/// Perform propagation, \a assigned is true if a view gets assigned
|
245
|
-
ExecStatus propagate(Space* home, bool& assigned);
|
246
|
-
};
|
247
|
-
|
248
|
-
/**
|
249
|
-
* \brief Domain-consistent distinct propagator
|
250
|
-
*
|
251
|
-
* The propagator uses staging: first it uses naive value-based
|
252
|
-
* propagation and only then uses domain-consistent propagation.
|
253
|
-
*
|
254
|
-
* The algorithm is taken from:
|
255
|
-
* Jean-Charles R�gin, A filtering algorithm for constraints
|
256
|
-
* of difference in CSPs, Proceedings of the Twelfth National
|
257
|
-
* Conference on Artificial Intelligence, pages 362--367.
|
258
|
-
* Seattle, WA, USA, 1994.
|
259
|
-
*
|
260
|
-
* Requires \code #include "gecode/int/distinct.hh" \endcode
|
261
|
-
* \ingroup FuncIntProp
|
262
|
-
*/
|
263
|
-
template <class View>
|
264
|
-
class Dom : public NaryPropagator<View,PC_INT_DOM> {
|
265
|
-
protected:
|
266
|
-
using NaryPropagator<View,PC_INT_DOM>::x;
|
267
|
-
/// Propagation controller
|
268
|
-
DomCtrl<View> dc;
|
269
|
-
/// Constructor for cloning \a p
|
270
|
-
Dom(Space* home, bool share, Dom<View>& p);
|
271
|
-
/// Constructor for posting
|
272
|
-
Dom(Space* home, ViewArray<View>& x);
|
273
|
-
public:
|
274
|
-
/// Perform propagation
|
275
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
276
|
-
/**
|
277
|
-
* \brief Cost function
|
278
|
-
*
|
279
|
-
* If in stage for naive value propagation, the cost is dynamic
|
280
|
-
* PC_LINEAR_LO. Otherwise it is dynamic PC_CUBIC_LO.
|
281
|
-
*/
|
282
|
-
virtual PropCost cost(ModEventDelta med) const;
|
283
|
-
/// Copy propagator during cloning
|
284
|
-
virtual Actor* copy(Space* home, bool share);
|
285
|
-
/// Specification for this propagator
|
286
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
287
|
-
Reflection::VarMap& m) const;
|
288
|
-
/// Name of this propagator
|
289
|
-
static Support::Symbol ati(void);
|
290
|
-
/// Post propagator for views \a x
|
291
|
-
static ExecStatus post(Space* home, ViewArray<View>& x);
|
292
|
-
/// Post propagator for specification
|
293
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
294
|
-
const Reflection::ActorSpec& spec);
|
295
|
-
};
|
296
|
-
|
297
|
-
/**
|
298
|
-
* \brief Ternary domain-consistent distinct propagator
|
299
|
-
*
|
300
|
-
* Requires \code #include "gecode/int/distinct.hh" \endcode
|
301
|
-
* \ingroup FuncIntProp
|
302
|
-
*/
|
303
|
-
template <class View>
|
304
|
-
class TerDom : public TernaryPropagator<View,PC_INT_DOM> {
|
305
|
-
protected:
|
306
|
-
using TernaryPropagator<View,PC_INT_DOM>::x0;
|
307
|
-
using TernaryPropagator<View,PC_INT_DOM>::x1;
|
308
|
-
using TernaryPropagator<View,PC_INT_DOM>::x2;
|
309
|
-
|
310
|
-
/// Constructor for cloning \a p
|
311
|
-
TerDom(Space* home, bool share, TerDom<View>& p);
|
312
|
-
/// Constructor for posting
|
313
|
-
TerDom(Space* home, View x0, View x1, View x2);
|
314
|
-
public:
|
315
|
-
/// Perform propagation
|
316
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
317
|
-
/// Copy propagator during cloning
|
318
|
-
virtual Actor* copy(Space* home, bool share);
|
319
|
-
/// Specification for this propagator
|
320
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
321
|
-
Reflection::VarMap& m) const;
|
322
|
-
/// Name of this propagator
|
323
|
-
static Support::Symbol ati(void);
|
324
|
-
/// Post propagator for views \a x
|
325
|
-
static ExecStatus post(Space* home, View x0, View x1, View x2);
|
326
|
-
/// Post propagator for specification
|
327
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
328
|
-
const Reflection::ActorSpec& spec);
|
329
|
-
};
|
330
|
-
|
331
|
-
}}}
|
332
|
-
|
333
|
-
#include "gecode/int/distinct/val.icc"
|
334
|
-
#include "gecode/int/distinct/bnd.icc"
|
335
|
-
#include "gecode/int/distinct/ter-dom.icc"
|
336
|
-
#include "gecode/int/distinct/dom.icc"
|
337
|
-
|
338
|
-
#endif
|
339
|
-
|
340
|
-
// STATISTICS: int-prop
|
341
|
-
|
@@ -1,750 +0,0 @@
|
|
1
|
-
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
-
/*
|
3
|
-
* Main authors:
|
4
|
-
* Christian Schulte <schulte@gecode.org>
|
5
|
-
*
|
6
|
-
* Copyright:
|
7
|
-
* Christian Schulte, 2003
|
8
|
-
*
|
9
|
-
* Last modified:
|
10
|
-
* $Date: 2008-01-31 18:29:16 +0100 (Thu, 31 Jan 2008) $ by $Author: tack $
|
11
|
-
* $Revision: 6017 $
|
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 <climits>
|
39
|
-
|
40
|
-
namespace Gecode { namespace Int { namespace Distinct {
|
41
|
-
|
42
|
-
/**
|
43
|
-
* \brief Class for combining two pointers with a flag
|
44
|
-
*
|
45
|
-
* When one pointer is given, this other can be retrieved.
|
46
|
-
*
|
47
|
-
*/
|
48
|
-
|
49
|
-
template <class T>
|
50
|
-
class CombPtrFlag {
|
51
|
-
private:
|
52
|
-
/// Store pointer and flag
|
53
|
-
ptrdiff_t cpf;
|
54
|
-
public:
|
55
|
-
/// Initialize with pointer \a p1 and \a p2
|
56
|
-
CombPtrFlag(T* p1, T* p2);
|
57
|
-
/// Initialize with pointer \a p1 and \a p2
|
58
|
-
void init(T* p1, T* p2);
|
59
|
-
/// Return the other pointer when \a p is given
|
60
|
-
T* ptr(T* p) const;
|
61
|
-
/// Check whether flag is set
|
62
|
-
int is_set(void) const;
|
63
|
-
/// Set flag
|
64
|
-
void set(void);
|
65
|
-
/// Clear flag
|
66
|
-
void unset(void);
|
67
|
-
};
|
68
|
-
|
69
|
-
/**
|
70
|
-
* \brief Bidirectional links for both edges and anchors in nodes of view-value graph
|
71
|
-
*
|
72
|
-
*/
|
73
|
-
class BiLink {
|
74
|
-
private:
|
75
|
-
BiLink* _prev; BiLink* _next;
|
76
|
-
public:
|
77
|
-
BiLink(void);
|
78
|
-
|
79
|
-
BiLink* prev(void) const; void prev(BiLink*);
|
80
|
-
BiLink* next(void) const; void next(BiLink*);
|
81
|
-
|
82
|
-
void add(BiLink*);
|
83
|
-
void unlink(void);
|
84
|
-
|
85
|
-
void mark(void);
|
86
|
-
bool marked(void) const;
|
87
|
-
|
88
|
-
bool empty(void) const;
|
89
|
-
};
|
90
|
-
|
91
|
-
template <class View> class Edge;
|
92
|
-
|
93
|
-
/**
|
94
|
-
* \brief Base-class for nodes (both view and value nodes)
|
95
|
-
*
|
96
|
-
* Note: the obvious ill-design to have also nodes and edges
|
97
|
-
* parametric wrt View is because the right design (having template
|
98
|
-
* function members) gets miscompiled (and actually not even compiled
|
99
|
-
* with some C++ compilers). Duh!
|
100
|
-
*
|
101
|
-
*/
|
102
|
-
template <class View>
|
103
|
-
class Node : public BiLink {
|
104
|
-
public:
|
105
|
-
unsigned int low, min, comp;
|
106
|
-
Edge<View>* iter;
|
107
|
-
|
108
|
-
Node(void);
|
109
|
-
|
110
|
-
Edge<View>* edge_fst(void) const;
|
111
|
-
Edge<View>* edge_lst(void) const;
|
112
|
-
|
113
|
-
static void operator delete(void*, size_t);
|
114
|
-
static void operator delete(void*,Space*);
|
115
|
-
static void* operator new(size_t, Space*);
|
116
|
-
};
|
117
|
-
|
118
|
-
/**
|
119
|
-
* \brief Value nodes in view-value graph
|
120
|
-
*
|
121
|
-
*/
|
122
|
-
template <class View>
|
123
|
-
class ValNode : public Node<View> {
|
124
|
-
protected:
|
125
|
-
/// The value of the node
|
126
|
-
const int _val;
|
127
|
-
/// The matching edge
|
128
|
-
Edge<View>* _matching;
|
129
|
-
/// The next value node
|
130
|
-
ValNode<View>* _next_val;
|
131
|
-
public:
|
132
|
-
/// Initialize with value \a v
|
133
|
-
ValNode(int v);
|
134
|
-
/// Initialize with value \a v and successor \a n
|
135
|
-
ValNode(int v, ValNode<View>* n);
|
136
|
-
/// Return value of node
|
137
|
-
int val(void) const;
|
138
|
-
/// Set matching edge to \a m
|
139
|
-
void matching(Edge<View>* m);
|
140
|
-
/// Return matching edge (NULL if unmatched)
|
141
|
-
Edge<View>* matching(void) const;
|
142
|
-
/// Return pointer to next value node fields
|
143
|
-
ValNode<View>** next_val_ref(void);
|
144
|
-
/// Return next value node
|
145
|
-
ValNode<View>* next_val(void) const;
|
146
|
-
/// Set next value node to \a v
|
147
|
-
void next_val(ValNode<View>* v);
|
148
|
-
};
|
149
|
-
|
150
|
-
/**
|
151
|
-
* \brief View nodes in view-value graph
|
152
|
-
*
|
153
|
-
*/
|
154
|
-
template <class View>
|
155
|
-
class ViewNode : public Node<View> {
|
156
|
-
protected:
|
157
|
-
/// The node's view
|
158
|
-
View _view;
|
159
|
-
/// The first value edge
|
160
|
-
Edge<View>* _val_edges;
|
161
|
-
public:
|
162
|
-
/// Initialize new node for view \a x
|
163
|
-
ViewNode(View x);
|
164
|
-
/// Return first edge of all value edges
|
165
|
-
Edge<View>* val_edges(void) const;
|
166
|
-
/// Return pointer to first edge fields of all value edges
|
167
|
-
Edge<View>** val_edges_ref(void);
|
168
|
-
/// Return view
|
169
|
-
View view(void) const;
|
170
|
-
};
|
171
|
-
|
172
|
-
/**
|
173
|
-
* \brief Edges in view-value graph
|
174
|
-
*
|
175
|
-
*/
|
176
|
-
template <class View>
|
177
|
-
class Edge : public BiLink {
|
178
|
-
protected:
|
179
|
-
/// Next edge in chain of value edges
|
180
|
-
Edge<View>* _next_edge;
|
181
|
-
/// Combine source and destination node anf flag
|
182
|
-
CombPtrFlag<Node<View> > sd;
|
183
|
-
public:
|
184
|
-
/// Construct new edge between \a x and \a v
|
185
|
-
Edge(ValNode<View>* v, ViewNode<View>* x);
|
186
|
-
/// Return destination of edge when source \a s is given
|
187
|
-
Node<View>* dst(Node<View>* s) const;
|
188
|
-
|
189
|
-
/// Return view node when value node \a v is given
|
190
|
-
ViewNode<View>* view(ValNode<View>* v) const;
|
191
|
-
/// Return value node when view node \a x is given
|
192
|
-
ValNode<View>* val(ViewNode<View>* x) const;
|
193
|
-
|
194
|
-
bool used(Node<View>*) const;
|
195
|
-
void use(void);
|
196
|
-
void free(void);
|
197
|
-
|
198
|
-
void revert(Node<View>*);
|
199
|
-
|
200
|
-
Edge<View>* next_edge(void) const;
|
201
|
-
Edge<View>** next_edge_ref(void);
|
202
|
-
|
203
|
-
Edge<View>* next(void) const;
|
204
|
-
|
205
|
-
static void operator delete(void*, size_t);
|
206
|
-
static void operator delete(void*,Space*);
|
207
|
-
static void* operator new(size_t, Space*);
|
208
|
-
};
|
209
|
-
|
210
|
-
}}}
|
211
|
-
|
212
|
-
#include "gecode/int/distinct/combptr.icc"
|
213
|
-
#include "gecode/int/distinct/bilink.icc"
|
214
|
-
#include "gecode/int/distinct/edge.icc"
|
215
|
-
#include "gecode/int/distinct/node.icc"
|
216
|
-
|
217
|
-
namespace Gecode { namespace Int { namespace Distinct {
|
218
|
-
|
219
|
-
|
220
|
-
template <class View>
|
221
|
-
forceinline
|
222
|
-
DomCtrl<View>::ViewValGraph::ViewValGraph(void)
|
223
|
-
: view(NULL), val(NULL), count(1) {}
|
224
|
-
|
225
|
-
template <class View>
|
226
|
-
forceinline bool
|
227
|
-
DomCtrl<View>::ViewValGraph::initialized(void) const {
|
228
|
-
return view != NULL;
|
229
|
-
}
|
230
|
-
|
231
|
-
template <class View>
|
232
|
-
forceinline bool
|
233
|
-
DomCtrl<View>::ViewValGraph::match(MatchStack& m, ViewNode<View>* x) {
|
234
|
-
count++;
|
235
|
-
start:
|
236
|
-
// Try to find matching edge cheaply: is there a free edge around?
|
237
|
-
{
|
238
|
-
Edge<View>* e = x->val_edges();
|
239
|
-
// This holds true as domains are never empty
|
240
|
-
assert(e != NULL);
|
241
|
-
do {
|
242
|
-
if (!e->val(x)->matching()) {
|
243
|
-
e->revert(x); e->val(x)->matching(e);
|
244
|
-
// Found a matching, revert all edges on stack
|
245
|
-
while (!m.empty()) {
|
246
|
-
x = m.pop(); e = x->iter;
|
247
|
-
e->val(x)->matching()->revert(e->val(x));
|
248
|
-
e->revert(x); e->val(x)->matching(e);
|
249
|
-
}
|
250
|
-
return true;
|
251
|
-
}
|
252
|
-
e = e->next_edge();
|
253
|
-
} while (e != NULL);
|
254
|
-
}
|
255
|
-
// No, find matching edge by augmenting path method
|
256
|
-
Edge<View>* e = x->val_edges();
|
257
|
-
do {
|
258
|
-
if (e->val(x)->matching()->view(e->val(x))->min < count) {
|
259
|
-
e->val(x)->matching()->view(e->val(x))->min = count;
|
260
|
-
m.push(x); x->iter = e;
|
261
|
-
x = e->val(x)->matching()->view(e->val(x));
|
262
|
-
goto start;
|
263
|
-
}
|
264
|
-
next:
|
265
|
-
e = e->next_edge();
|
266
|
-
} while (e != NULL);
|
267
|
-
if (!m.empty()) {
|
268
|
-
x = m.pop(); e = x->iter; goto next;
|
269
|
-
}
|
270
|
-
// All nodes and edges unsuccessfully tried
|
271
|
-
return false;
|
272
|
-
}
|
273
|
-
|
274
|
-
template <class View>
|
275
|
-
ExecStatus
|
276
|
-
DomCtrl<View>::ViewValGraph::init(Space* home, int n, View* x) {
|
277
|
-
n_view = n;
|
278
|
-
view = static_cast<ViewNode<View>**>
|
279
|
-
(home->alloc(n_view*sizeof(ViewNode<View>*)));
|
280
|
-
|
281
|
-
// Find value information for construction of view value graph
|
282
|
-
int min = x[n_view-1].min();
|
283
|
-
int max = x[n_view-1].max();
|
284
|
-
for (int i=n_view-1; i--; ) {
|
285
|
-
min = std::min(min,x[i].min());
|
286
|
-
max = std::max(max,x[i].max());
|
287
|
-
}
|
288
|
-
|
289
|
-
unsigned int width = max-min+1;
|
290
|
-
|
291
|
-
// Definitly not enough values
|
292
|
-
if (width < static_cast<unsigned int>(n_view))
|
293
|
-
return ES_FAILED;
|
294
|
-
|
295
|
-
n_val = 0;
|
296
|
-
val = NULL;
|
297
|
-
|
298
|
-
if (static_cast<unsigned int>(n_view)*4 >= width) {
|
299
|
-
// Values are dense: use a mapping
|
300
|
-
GECODE_AUTOARRAY(ValNode<View>*,val2node,width);
|
301
|
-
|
302
|
-
for (unsigned int i=width; i--; )
|
303
|
-
val2node[i]=NULL;
|
304
|
-
|
305
|
-
for (int i=n; i--; ) {
|
306
|
-
view[i] = new (home) ViewNode<View>(x[i]);
|
307
|
-
Edge<View>** edge_p = view[i]->val_edges_ref();
|
308
|
-
ViewValues<View> xi(x[i]);
|
309
|
-
while (xi()) {
|
310
|
-
if (val2node[xi.val()-min] == NULL)
|
311
|
-
val2node[xi.val()-min] = new (home) ValNode<View>(xi.val());
|
312
|
-
*edge_p = new (home) Edge<View>(val2node[xi.val()-min],view[i]);
|
313
|
-
edge_p = (*edge_p)->next_edge_ref();
|
314
|
-
++xi;
|
315
|
-
}
|
316
|
-
*edge_p = NULL;
|
317
|
-
}
|
318
|
-
|
319
|
-
for (unsigned int i=width; i--; )
|
320
|
-
if (val2node[i] != NULL) {
|
321
|
-
val2node[i]->next_val(val);
|
322
|
-
val = val2node[i];
|
323
|
-
n_val++;
|
324
|
-
}
|
325
|
-
|
326
|
-
} else {
|
327
|
-
// Values are sparse
|
328
|
-
for (int i=n; i--; ) {
|
329
|
-
view[i] = new (home) ViewNode<View>(x[i]);
|
330
|
-
Edge<View>** edge_p = view[i]->val_edges_ref();
|
331
|
-
ViewValues<View> xi(x[i]);
|
332
|
-
ValNode<View>** v = &val;
|
333
|
-
while (xi() && (*v != NULL)) {
|
334
|
-
if ((*v)->val() == xi.val()) {
|
335
|
-
// Value node does already exist, create new edge
|
336
|
-
*edge_p = new (home) Edge<View>(*v,view[i]);
|
337
|
-
edge_p = (*edge_p)->next_edge_ref();
|
338
|
-
v = (*v)->next_val_ref();
|
339
|
-
++xi;
|
340
|
-
} else if ((*v)->val() < xi.val()) {
|
341
|
-
// Skip to next value node
|
342
|
-
v = (*v)->next_val_ref();
|
343
|
-
} else {
|
344
|
-
// Value node does not yet exist, create and link it
|
345
|
-
ValNode<View>* nv = new (home) ValNode<View>(xi.val(),*v);
|
346
|
-
*v = nv; v = nv->next_val_ref();
|
347
|
-
*edge_p = new (home) Edge<View>(nv,view[i]);
|
348
|
-
edge_p = (*edge_p)->next_edge_ref();
|
349
|
-
++xi; n_val++;
|
350
|
-
}
|
351
|
-
}
|
352
|
-
// Create missing value nodes
|
353
|
-
while (xi()) {
|
354
|
-
ValNode<View>* nv = new (home) ValNode<View>(xi.val(),*v);
|
355
|
-
*v = nv; v = nv->next_val_ref();
|
356
|
-
*edge_p = new (home) Edge<View>(nv,view[i]);
|
357
|
-
edge_p = (*edge_p)->next_edge_ref();
|
358
|
-
++xi; n_val++;
|
359
|
-
}
|
360
|
-
*edge_p = NULL;
|
361
|
-
}
|
362
|
-
}
|
363
|
-
|
364
|
-
GECODE_AUTOSTACK(ViewNode<View>*,NULL,m,n_view);
|
365
|
-
for (int i = n_view; i--; )
|
366
|
-
if (!match(m,view[i]))
|
367
|
-
return ES_FAILED;
|
368
|
-
return ES_OK;
|
369
|
-
}
|
370
|
-
|
371
|
-
template <class View>
|
372
|
-
forceinline void
|
373
|
-
DomCtrl<View>::ViewValGraph::mark(void) {
|
374
|
-
{
|
375
|
-
// Marks all edges as used that are on simple paths in the graph
|
376
|
-
// that start from a free (unmatched node) by depth-first-search
|
377
|
-
GECODE_AUTOSTACK(ValNode<View>*,NULL,visit,n_val);
|
378
|
-
|
379
|
-
// Insert all free nodes: they can be only value nodes as we
|
380
|
-
// have a maximum matching covering all view nodes
|
381
|
-
count++;
|
382
|
-
{
|
383
|
-
ValNode<View>** v = &val;
|
384
|
-
while (*v != NULL)
|
385
|
-
if (!(*v)->matching()) {
|
386
|
-
if ((*v)->empty()) {
|
387
|
-
*v = (*v)->next_val();
|
388
|
-
n_val--;
|
389
|
-
} else {
|
390
|
-
(*v)->min = count;
|
391
|
-
visit.push(*v);
|
392
|
-
v = (*v)->next_val_ref();
|
393
|
-
}
|
394
|
-
} else {
|
395
|
-
v = (*v)->next_val_ref();
|
396
|
-
}
|
397
|
-
}
|
398
|
-
|
399
|
-
// Invariant: only value nodes are on the stack!
|
400
|
-
while (!visit.empty()) {
|
401
|
-
ValNode<View>* n = visit.pop();
|
402
|
-
for (Edge<View>* e = n->edge_fst(); e != n->edge_lst(); e=e->next()) {
|
403
|
-
// Get the value node
|
404
|
-
e->use();
|
405
|
-
ViewNode<View>* x = e->view(n);
|
406
|
-
if (x->min < count) {
|
407
|
-
x->min = count;
|
408
|
-
assert(x->edge_fst()->next() == x->edge_lst());
|
409
|
-
ValNode<View>* m = x->edge_fst()->val(x);
|
410
|
-
x->edge_fst()->use();
|
411
|
-
if (m->min < count) {
|
412
|
-
m->min = count;
|
413
|
-
visit.push(m);
|
414
|
-
}
|
415
|
-
}
|
416
|
-
}
|
417
|
-
}
|
418
|
-
}
|
419
|
-
|
420
|
-
{
|
421
|
-
GECODE_AUTOSTACK(Node<View>*,NULL,scc,n_val+n_view);
|
422
|
-
GECODE_AUTOSTACK(Node<View>*,NULL,visit,n_val+n_view);
|
423
|
-
|
424
|
-
count++;
|
425
|
-
unsigned int cnt0 = count;
|
426
|
-
unsigned int cnt1 = count;
|
427
|
-
|
428
|
-
for (int i = n_view; i--; )
|
429
|
-
if (view[i]->min < count) {
|
430
|
-
Node<View>* w = view[i];
|
431
|
-
start:
|
432
|
-
w->low = w->min = cnt0++;
|
433
|
-
scc.push(w);
|
434
|
-
Edge<View>* e = w->edge_fst();
|
435
|
-
while (e != w->edge_lst()) {
|
436
|
-
if (e->dst(w)->min < count) {
|
437
|
-
visit.push(w); w->iter = e;
|
438
|
-
w=e->dst(w);
|
439
|
-
goto start;
|
440
|
-
}
|
441
|
-
next:
|
442
|
-
if (e->dst(w)->low < w->min)
|
443
|
-
w->min = e->dst(w)->low;
|
444
|
-
e = e->next();
|
445
|
-
}
|
446
|
-
if (w->min < w->low) {
|
447
|
-
w->low = w->min;
|
448
|
-
} else {
|
449
|
-
Node<View>* v;
|
450
|
-
do {
|
451
|
-
v = scc.pop();
|
452
|
-
v->comp = cnt1;
|
453
|
-
v->low = UINT_MAX;
|
454
|
-
} while (v != w);
|
455
|
-
cnt1++;
|
456
|
-
}
|
457
|
-
if (!visit.empty()) {
|
458
|
-
w=visit.pop(); e=w->iter; goto next;
|
459
|
-
}
|
460
|
-
}
|
461
|
-
count = cnt0+1;
|
462
|
-
}
|
463
|
-
}
|
464
|
-
|
465
|
-
/// Prunes the values read from a view node
|
466
|
-
template <class View>
|
467
|
-
class PruneVal {
|
468
|
-
protected:
|
469
|
-
/// View node
|
470
|
-
ViewNode<View>* x;
|
471
|
-
/// Current value edge
|
472
|
-
Edge<View>* e;
|
473
|
-
public:
|
474
|
-
/// \name Constructors and initialization
|
475
|
-
//@{
|
476
|
-
/// Initialize with edges for view node \a y
|
477
|
-
PruneVal(ViewNode<View>* y);
|
478
|
-
//@}
|
479
|
-
|
480
|
-
/// \name Iteration control
|
481
|
-
//@{
|
482
|
-
/// Test whether iterator is still at a value or done
|
483
|
-
bool operator()(void) const;
|
484
|
-
/// Move iterator to next value (if possible)
|
485
|
-
void operator++(void);
|
486
|
-
//@}
|
487
|
-
|
488
|
-
/// \name Value access
|
489
|
-
//@{
|
490
|
-
/// Return current value
|
491
|
-
int val(void) const;
|
492
|
-
//@}
|
493
|
-
};
|
494
|
-
|
495
|
-
template <class View>
|
496
|
-
forceinline
|
497
|
-
PruneVal<View>::PruneVal(ViewNode<View>* y)
|
498
|
-
: x(y), e(y->val_edges()) {
|
499
|
-
while ((e != NULL) && e->used(x))
|
500
|
-
e = e->next_edge();
|
501
|
-
}
|
502
|
-
template <class View>
|
503
|
-
forceinline bool
|
504
|
-
PruneVal<View>::operator()(void) const {
|
505
|
-
return e != NULL;
|
506
|
-
}
|
507
|
-
template <class View>
|
508
|
-
forceinline void
|
509
|
-
PruneVal<View>::operator++(void) {
|
510
|
-
do {
|
511
|
-
e = e->next_edge();
|
512
|
-
} while ((e != NULL) && e->used(x));
|
513
|
-
}
|
514
|
-
template <class View>
|
515
|
-
forceinline int
|
516
|
-
PruneVal<View>::val(void) const {
|
517
|
-
assert(!e->used(x));
|
518
|
-
return e->val(x)->val();
|
519
|
-
}
|
520
|
-
|
521
|
-
template <class View>
|
522
|
-
forceinline ExecStatus
|
523
|
-
DomCtrl<View>::ViewValGraph::tell(Space* home, bool& assigned) {
|
524
|
-
assigned = false;
|
525
|
-
// Tell constraints and also eliminate nodes and edges
|
526
|
-
for (int i = n_view; i--; ) {
|
527
|
-
ViewNode<View>* x = view[i];
|
528
|
-
if (!x->edge_fst()->used(x)) {
|
529
|
-
GECODE_ME_CHECK(x->view().eq(home,x->edge_fst()->val(x)->val()));
|
530
|
-
x->edge_fst()->val(x)->matching(NULL);
|
531
|
-
view[i] = view[--n_view];
|
532
|
-
assigned = true;
|
533
|
-
} else {
|
534
|
-
PruneVal<View> pv(view[i]);
|
535
|
-
GECODE_ME_CHECK(view[i]->view().minus_v(home,pv,false));
|
536
|
-
}
|
537
|
-
}
|
538
|
-
return ES_OK;
|
539
|
-
}
|
540
|
-
|
541
|
-
template <class View>
|
542
|
-
forceinline void
|
543
|
-
DomCtrl<View>::ViewValGraph::purge(void) {
|
544
|
-
if (count > (UINT_MAX >> 1)) {
|
545
|
-
count = 1;
|
546
|
-
for (int i=n_view; i--; )
|
547
|
-
view[i]->min = 0;
|
548
|
-
for (ValNode<View>* v = val; v != NULL; v = v->next_val())
|
549
|
-
v->min = 0;
|
550
|
-
}
|
551
|
-
}
|
552
|
-
|
553
|
-
template <class View>
|
554
|
-
bool
|
555
|
-
DomCtrl<View>::ViewValGraph::sync(void) {
|
556
|
-
// Stack for view nodes to be rematched
|
557
|
-
GECODE_AUTOSTACK(ViewNode<View>*,NULL,re,n_view);
|
558
|
-
// Synchronize nodes
|
559
|
-
for (int i = n_view; i--; ) {
|
560
|
-
ViewNode<View>* x = view[i];
|
561
|
-
if (x->view().assigned()) {
|
562
|
-
x->edge_fst()->val(x)->matching(NULL);
|
563
|
-
for (Edge<View>* e = x->val_edges(); e != NULL; e = e->next_edge())
|
564
|
-
e->unlink();
|
565
|
-
view[i] = view[--n_view];
|
566
|
-
} else {
|
567
|
-
ViewRanges<View> r(x->view());
|
568
|
-
Edge<View>* m = x->edge_fst(); // Matching edge
|
569
|
-
Edge<View>** p = x->val_edges_ref();
|
570
|
-
Edge<View>* e = *p;
|
571
|
-
do {
|
572
|
-
while (e->val(x)->val() < r.min()) {
|
573
|
-
// Skip edge
|
574
|
-
e->unlink(); e->mark();
|
575
|
-
e = e->next_edge();
|
576
|
-
}
|
577
|
-
*p = e;
|
578
|
-
assert(r.min() == e->val(x)->val());
|
579
|
-
// This edges must be kept
|
580
|
-
for (unsigned int i=r.width(); i--; ) {
|
581
|
-
e->free();
|
582
|
-
p = e->next_edge_ref();
|
583
|
-
e = e->next_edge();
|
584
|
-
}
|
585
|
-
++r;
|
586
|
-
} while (r());
|
587
|
-
*p = NULL;
|
588
|
-
while (e != NULL) {
|
589
|
-
e->unlink(); e->mark();
|
590
|
-
e = e->next_edge();
|
591
|
-
}
|
592
|
-
if (m->marked()) {
|
593
|
-
// Matching has been deleted!
|
594
|
-
m->val(x)->matching(NULL);
|
595
|
-
re.push(x);
|
596
|
-
}
|
597
|
-
}
|
598
|
-
}
|
599
|
-
GECODE_AUTOSTACK(ViewNode<View>*,NULL,m,n_view);
|
600
|
-
while (!re.empty())
|
601
|
-
if (!match(m,re.pop()))
|
602
|
-
return false;
|
603
|
-
return true;
|
604
|
-
}
|
605
|
-
|
606
|
-
|
607
|
-
|
608
|
-
/*
|
609
|
-
* The propagation controller
|
610
|
-
*
|
611
|
-
*/
|
612
|
-
|
613
|
-
template <class View>
|
614
|
-
forceinline
|
615
|
-
DomCtrl<View>::DomCtrl(void) {}
|
616
|
-
|
617
|
-
template <class View>
|
618
|
-
forceinline bool
|
619
|
-
DomCtrl<View>::available(void) {
|
620
|
-
return vvg.initialized();
|
621
|
-
}
|
622
|
-
|
623
|
-
template <class View>
|
624
|
-
forceinline ExecStatus
|
625
|
-
DomCtrl<View>::init(Space* home, int n, View* x) {
|
626
|
-
return vvg.init(home,n,x);
|
627
|
-
}
|
628
|
-
|
629
|
-
template <class View>
|
630
|
-
forceinline ExecStatus
|
631
|
-
DomCtrl<View>::sync(void) {
|
632
|
-
vvg.purge();
|
633
|
-
return vvg.sync() ? ES_OK : ES_FAILED;
|
634
|
-
}
|
635
|
-
|
636
|
-
template <class View>
|
637
|
-
forceinline ExecStatus
|
638
|
-
DomCtrl<View>::propagate(Space* home, bool& assigned) {
|
639
|
-
vvg.mark();
|
640
|
-
return vvg.tell(home,assigned);
|
641
|
-
}
|
642
|
-
|
643
|
-
|
644
|
-
/*
|
645
|
-
* The propagator proper
|
646
|
-
*
|
647
|
-
*/
|
648
|
-
|
649
|
-
template <class View>
|
650
|
-
forceinline
|
651
|
-
Dom<View>::Dom(Space* home, ViewArray<View>& x)
|
652
|
-
: NaryPropagator<View,PC_INT_DOM>(home,x) {}
|
653
|
-
|
654
|
-
template <class View>
|
655
|
-
ExecStatus
|
656
|
-
Dom<View>::post(Space* home, ViewArray<View>& x) {
|
657
|
-
if (x.size() == 2)
|
658
|
-
return Rel::Nq<View>::post(home,x[0],x[1]);
|
659
|
-
if (x.size() == 3)
|
660
|
-
return TerDom<View>::post(home,x[0],x[1],x[2]);
|
661
|
-
if (x.size() > 3) {
|
662
|
-
// Do bounds propagation to make view-value graph smaller
|
663
|
-
GECODE_ES_CHECK(prop_bnd<View>(home,x))
|
664
|
-
(void) new (home) Dom<View>(home,x);
|
665
|
-
}
|
666
|
-
return ES_OK;
|
667
|
-
}
|
668
|
-
|
669
|
-
template <class View>
|
670
|
-
void
|
671
|
-
Dom<View>::post(Space* home, Reflection::VarMap& vars,
|
672
|
-
const Reflection::ActorSpec& spec) {
|
673
|
-
spec.checkArity(1);
|
674
|
-
ViewArray<View> x(home, vars, spec[0]);
|
675
|
-
(void) new (home) Dom<View>(home, x);
|
676
|
-
}
|
677
|
-
|
678
|
-
template <class View>
|
679
|
-
forceinline
|
680
|
-
Dom<View>::Dom(Space* home, bool share, Dom<View>& p)
|
681
|
-
: NaryPropagator<View,PC_INT_DOM>(home,share,p) {}
|
682
|
-
|
683
|
-
template <class View>
|
684
|
-
PropCost
|
685
|
-
Dom<View>::cost(ModEventDelta med) const {
|
686
|
-
return cost_lo(x.size(),
|
687
|
-
(View::me(med) == ME_INT_VAL)
|
688
|
-
? PC_LINEAR_LO : PC_CUBIC_LO);
|
689
|
-
}
|
690
|
-
|
691
|
-
template <class View>
|
692
|
-
Support::Symbol
|
693
|
-
Dom<View>::ati(void) {
|
694
|
-
return Reflection::mangle<View>("Gecode::Int::Distinct::Dom");
|
695
|
-
}
|
696
|
-
|
697
|
-
template <class View>
|
698
|
-
Reflection::ActorSpec
|
699
|
-
Dom<View>::spec(const Space* home, Reflection::VarMap& m) const {
|
700
|
-
return NaryPropagator<View,PC_INT_DOM>::spec(home, m, ati());
|
701
|
-
}
|
702
|
-
|
703
|
-
template <class View>
|
704
|
-
Actor*
|
705
|
-
Dom<View>::copy(Space* home, bool share) {
|
706
|
-
return new (home) Dom<View>(home,share,*this);
|
707
|
-
}
|
708
|
-
|
709
|
-
template <class View>
|
710
|
-
ExecStatus
|
711
|
-
Dom<View>::propagate(Space* home, ModEventDelta med) {
|
712
|
-
if (View::me(med) == ME_INT_VAL) {
|
713
|
-
ExecStatus es = prop_val<View,false>(home,x);
|
714
|
-
GECODE_ES_CHECK(es);
|
715
|
-
if (x.size() < 2)
|
716
|
-
return ES_SUBSUMED(this,home);
|
717
|
-
if (es == ES_FIX)
|
718
|
-
return ES_FIX_PARTIAL(this,View::med(ME_INT_DOM));
|
719
|
-
es = prop_bnd<View>(home,x);
|
720
|
-
if (x.size() < 2)
|
721
|
-
return ES_SUBSUMED(this,home);
|
722
|
-
GECODE_ES_CHECK(es);
|
723
|
-
es = prop_val<View,true>(home,x);
|
724
|
-
if (x.size() < 2)
|
725
|
-
return ES_SUBSUMED(this,home);
|
726
|
-
GECODE_ES_CHECK(es);
|
727
|
-
return ES_FIX_PARTIAL(this,View::med(ME_INT_DOM));
|
728
|
-
}
|
729
|
-
|
730
|
-
if (x.size() == 2)
|
731
|
-
GECODE_REWRITE(this,Rel::Nq<View>::post(home,x[0],x[1]));
|
732
|
-
if (x.size() == 3)
|
733
|
-
GECODE_REWRITE(this,TerDom<View>::post(home,x[0],x[1],x[2]));
|
734
|
-
|
735
|
-
if (dc.available()) {
|
736
|
-
GECODE_ES_CHECK(dc.sync());
|
737
|
-
} else {
|
738
|
-
GECODE_ES_CHECK(dc.init(home,x.size(),&x[0]));
|
739
|
-
}
|
740
|
-
|
741
|
-
bool assigned;
|
742
|
-
GECODE_ES_CHECK(dc.propagate(home,assigned));
|
743
|
-
|
744
|
-
return ES_FIX;
|
745
|
-
}
|
746
|
-
|
747
|
-
}}}
|
748
|
-
|
749
|
-
// STATISTICS: int-prop
|
750
|
-
|