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
@@ -0,0 +1,970 @@
|
|
1
|
+
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
+
/*
|
3
|
+
* Main authors:
|
4
|
+
* Guido Tack <tack@gecode.org>
|
5
|
+
* Christian Schulte <schulte@gecode.org>
|
6
|
+
*
|
7
|
+
* Contributing authors:
|
8
|
+
* Gabor Szokoli <szokoli@gecode.org>
|
9
|
+
*
|
10
|
+
* Copyright:
|
11
|
+
* Guido Tack, 2004
|
12
|
+
* Christian Schulte, 2004
|
13
|
+
* Gabor Szokoli, 2004
|
14
|
+
*
|
15
|
+
* Last modified:
|
16
|
+
* $Date: 2008-07-11 10:35:42 +0200 (Fri, 11 Jul 2008) $ by $Author: tack $
|
17
|
+
* $Revision: 7339 $
|
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_SET_HH__
|
45
|
+
#define __GECODE_SET_HH__
|
46
|
+
|
47
|
+
#include "gecode/kernel.hh"
|
48
|
+
#include "gecode/int.hh"
|
49
|
+
#include "gecode/iter.hh"
|
50
|
+
|
51
|
+
/*
|
52
|
+
* Configure linking
|
53
|
+
*
|
54
|
+
*/
|
55
|
+
#if !defined(GECODE_STATIC_LIBS) && \
|
56
|
+
(defined(__CYGWIN__) || defined(__MINGW32__) || defined(_MSC_VER))
|
57
|
+
|
58
|
+
#ifdef GECODE_BUILD_SET
|
59
|
+
#define GECODE_SET_EXPORT __declspec( dllexport )
|
60
|
+
#else
|
61
|
+
#define GECODE_SET_EXPORT __declspec( dllimport )
|
62
|
+
#endif
|
63
|
+
|
64
|
+
#else
|
65
|
+
|
66
|
+
#ifdef GECODE_GCC_HAS_CLASS_VISIBILITY
|
67
|
+
#define GECODE_SET_EXPORT __attribute__ ((visibility("default")))
|
68
|
+
#else
|
69
|
+
#define GECODE_SET_EXPORT
|
70
|
+
#endif
|
71
|
+
|
72
|
+
#endif
|
73
|
+
|
74
|
+
/**
|
75
|
+
* \namespace Gecode::Set
|
76
|
+
* \brief Finite integer sets
|
77
|
+
*
|
78
|
+
* The Gecode::Set namespace contains all functionality required
|
79
|
+
* to program propagators and branchings for finite integer sets.
|
80
|
+
* In addition, all propagators and branchings for finite integer
|
81
|
+
* sets provided by %Gecode are contained as nested namespaces.
|
82
|
+
*
|
83
|
+
*/
|
84
|
+
|
85
|
+
#include "gecode/set/exception.icc"
|
86
|
+
|
87
|
+
namespace Gecode { namespace Set {
|
88
|
+
|
89
|
+
/// Numerical limits for set variables
|
90
|
+
namespace Limits {
|
91
|
+
/// Largest allowed integer in integer set
|
92
|
+
const int max = (Gecode::Int::Limits::max / 2) - 1;
|
93
|
+
/// Smallest allowed integer in integer set
|
94
|
+
const int min = -max;
|
95
|
+
/// Maximum cardinality of an integer set
|
96
|
+
const unsigned int card = max-min+1;
|
97
|
+
/// Check whether integer \a n is in range, otherwise throw overflow exception with information \a l
|
98
|
+
void check(int n, const char* l);
|
99
|
+
/// Check whether unsigned int \a n is in range for cardinality, otherwise throw overflow exception with information \a l
|
100
|
+
void check(unsigned int n, const char* l);
|
101
|
+
/// Check whether minimum and maximum of IntSet \a s is in range, otherwise throw overflow exception with information \a l
|
102
|
+
void check(const IntSet& s, const char* l);
|
103
|
+
}
|
104
|
+
|
105
|
+
}}
|
106
|
+
|
107
|
+
#include "gecode/set/limits.icc"
|
108
|
+
|
109
|
+
#include "gecode/set/var-imp.icc"
|
110
|
+
|
111
|
+
namespace Gecode {
|
112
|
+
|
113
|
+
namespace Set {
|
114
|
+
class SetView;
|
115
|
+
}
|
116
|
+
|
117
|
+
/**
|
118
|
+
* \brief %Set variables
|
119
|
+
*
|
120
|
+
* \ingroup TaskModelSetVars
|
121
|
+
*/
|
122
|
+
class SetVar : public VarBase<Set::SetVarImp> {
|
123
|
+
friend class SetVarArray;
|
124
|
+
private:
|
125
|
+
using VarBase<Set::SetVarImp>::varimp;
|
126
|
+
/// Initialize variable with empty greatest lower and full least upper bound
|
127
|
+
void init(Space* home);
|
128
|
+
/**
|
129
|
+
* \brief Initialize variable with given bounds and cardinality
|
130
|
+
*
|
131
|
+
* The variable is created with
|
132
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
133
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
134
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
135
|
+
*/
|
136
|
+
void init(Space* home,int glbMin,int glbMax,int lubMin,int lubMax,
|
137
|
+
unsigned int cardMin = 0,
|
138
|
+
unsigned int cardMax = Set::Limits::card);
|
139
|
+
/**
|
140
|
+
* \brief Initialize variable with given bounds and cardinality
|
141
|
+
*
|
142
|
+
* The variable is created with
|
143
|
+
* greatest lower bound \a glbD,
|
144
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
145
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
146
|
+
*/
|
147
|
+
void init(Space* home,const IntSet& glbD,int lubMin,int lubMax,
|
148
|
+
unsigned int cardMin = 0,
|
149
|
+
unsigned int cardMax = Set::Limits::card);
|
150
|
+
/**
|
151
|
+
* \brief Initialize variable with given bounds and cardinality
|
152
|
+
*
|
153
|
+
* The variable is created with
|
154
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
155
|
+
* least upper bound \a lubD, and
|
156
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
157
|
+
*/
|
158
|
+
void init(Space* home,int glbMin,int glbMax,const IntSet& lubD,
|
159
|
+
unsigned int cardMin = 0,
|
160
|
+
unsigned int cardMax = Set::Limits::card);
|
161
|
+
/**
|
162
|
+
* \brief Initialize variable with given bounds and cardinality
|
163
|
+
*
|
164
|
+
* The variable is created with
|
165
|
+
* greatest lower bound \a glbD,
|
166
|
+
* least upper bound \a lubD, and
|
167
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
168
|
+
*/
|
169
|
+
void init(Space* home,const IntSet& glbD,const IntSet& lubD,
|
170
|
+
unsigned int cardMin = 0,
|
171
|
+
unsigned int cardMax = Set::Limits::card);
|
172
|
+
public:
|
173
|
+
/// \name Constructors and initialization
|
174
|
+
//@{
|
175
|
+
/// Default constructor
|
176
|
+
SetVar(void);
|
177
|
+
/// Initialize from set variable \a x0
|
178
|
+
SetVar(const SetVar& x0);
|
179
|
+
/// Initialize from set view \a x0
|
180
|
+
SetVar(const Set::SetView& x0);
|
181
|
+
/// Initialize from reflection variable \a x0
|
182
|
+
SetVar(const Reflection::Var& x0);
|
183
|
+
|
184
|
+
/// Initialize variable with empty greatest lower and full least upper bound
|
185
|
+
GECODE_SET_EXPORT SetVar(Space* home);
|
186
|
+
|
187
|
+
/**
|
188
|
+
* \brief Initialize variable with given bounds and cardinality
|
189
|
+
*
|
190
|
+
* The variable is created with
|
191
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
192
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
193
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
194
|
+
* The following exceptions might be thrown:
|
195
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
196
|
+
* and Set::Limits::max), an exception of type
|
197
|
+
* Gecode::Set::OutOfLimits is thrown.
|
198
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
199
|
+
* exception of type Gecode::Set::OutOfLimits is
|
200
|
+
* thrown.
|
201
|
+
* - If \a minCard > \a maxCard, an exception of type
|
202
|
+
* Gecode::Set::VariableEmptyDomain is thrown.
|
203
|
+
*/
|
204
|
+
GECODE_SET_EXPORT
|
205
|
+
SetVar(Space* home,int glbMin,int glbMax,int lubMin,int lubMax,
|
206
|
+
unsigned int cardMin = 0,
|
207
|
+
unsigned int cardMax = Set::Limits::card);
|
208
|
+
|
209
|
+
/**
|
210
|
+
* \brief Initialize variable with given bounds and cardinality
|
211
|
+
*
|
212
|
+
* The variable is created with
|
213
|
+
* greatest lower bound \a glbD,
|
214
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
215
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
216
|
+
* The following exceptions might be thrown:
|
217
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
218
|
+
* and Set::Limits::max), an exception of type
|
219
|
+
* Gecode::Set::OutOfLimits is thrown.
|
220
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
221
|
+
* exception of type Gecode::Set::OutOfLimits is
|
222
|
+
* thrown.
|
223
|
+
* - If \a minCard > \a maxCard, an exception of type
|
224
|
+
* Gecode::Set::VariableEmptyDomain is thrown.
|
225
|
+
*/
|
226
|
+
GECODE_SET_EXPORT
|
227
|
+
SetVar(Space* home,const IntSet& glbD,int lubMin,int lubMax,
|
228
|
+
unsigned int cardMin = 0,
|
229
|
+
unsigned int cardMax = Set::Limits::card);
|
230
|
+
|
231
|
+
/**
|
232
|
+
* \brief Initialize variable with given bounds and cardinality
|
233
|
+
*
|
234
|
+
* The variable is created with
|
235
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
236
|
+
* least upper bound \a lubD, and
|
237
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
238
|
+
* The following exceptions might be thrown:
|
239
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
240
|
+
* and Set::Limits::max), an exception of type
|
241
|
+
* Gecode::Set::OutOfLimits is thrown.
|
242
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
243
|
+
* exception of type Gecode::Set::OutOfLimits is
|
244
|
+
* thrown.
|
245
|
+
* - If \a minCard > \a maxCard, an exception of type
|
246
|
+
* Gecode::Set::VariableEmptyDomain is thrown.
|
247
|
+
*/
|
248
|
+
GECODE_SET_EXPORT
|
249
|
+
SetVar(Space* home,int glbMin,int glbMax,const IntSet& lubD,
|
250
|
+
unsigned int cardMin = 0,
|
251
|
+
unsigned int cardMax = Set::Limits::card);
|
252
|
+
|
253
|
+
/**
|
254
|
+
* \brief Initialize variable with given bounds and cardinality
|
255
|
+
*
|
256
|
+
* The variable is created with
|
257
|
+
* greatest lower bound \a glbD,
|
258
|
+
* least upper bound \a lubD, and
|
259
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
260
|
+
* The following exceptions might be thrown:
|
261
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
262
|
+
* and Set::Limits::max), an exception of type
|
263
|
+
* Gecode::Set::OutOfLimits is thrown.
|
264
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
265
|
+
* exception of type Gecode::Set::OutOfLimits is
|
266
|
+
* thrown.
|
267
|
+
* - If \a minCard > \a maxCard, an exception of type
|
268
|
+
* Gecode::Set::VariableEmptyDomain is thrown.
|
269
|
+
*/
|
270
|
+
GECODE_SET_EXPORT
|
271
|
+
SetVar(Space* home,const IntSet& glbD,const IntSet& lubD,
|
272
|
+
unsigned int cardMin = 0,
|
273
|
+
unsigned int cardMax = Set::Limits::card);
|
274
|
+
//@}
|
275
|
+
|
276
|
+
/// \name Value access
|
277
|
+
//@{
|
278
|
+
/// Return number of elements in the greatest lower bound
|
279
|
+
unsigned int glbSize(void) const;
|
280
|
+
/// Return number of elements in the least upper bound
|
281
|
+
unsigned int lubSize(void) const;
|
282
|
+
/// Return number of unknown elements (elements in lub but not in glb)
|
283
|
+
unsigned int unknownSize(void) const;
|
284
|
+
/// Return cardinality minimum
|
285
|
+
unsigned int cardMin(void) const;
|
286
|
+
/// Return cardinality maximum
|
287
|
+
unsigned int cardMax(void) const;
|
288
|
+
/// Return minimum element of least upper bound
|
289
|
+
int lubMin(void) const;
|
290
|
+
/// Return maximum element of least upper bound
|
291
|
+
int lubMax(void) const;
|
292
|
+
/// Return minimum element of greatest lower bound
|
293
|
+
int glbMin(void) const;
|
294
|
+
/// Return maximum of greatest lower bound
|
295
|
+
int glbMax(void) const;
|
296
|
+
//@}
|
297
|
+
|
298
|
+
/// \name Domain tests
|
299
|
+
//@{
|
300
|
+
/// Test whether \a i is in greatest lower bound
|
301
|
+
bool contains(int i) const;
|
302
|
+
/// Test whether \a i is not in the least upper bound
|
303
|
+
bool notContains(int i) const;
|
304
|
+
/// Test whether this variable is assigned
|
305
|
+
bool assigned(void) const;
|
306
|
+
|
307
|
+
/// \name Cloning
|
308
|
+
//@{
|
309
|
+
/// Update this variable to be a clone of variable \a x
|
310
|
+
void update(Space* home, bool, SetVar& x);
|
311
|
+
//@}
|
312
|
+
};
|
313
|
+
|
314
|
+
/**
|
315
|
+
* \defgroup TaskModelSetIter Range and value iterators for set variables
|
316
|
+
* \ingroup TaskModelSet
|
317
|
+
*/
|
318
|
+
//@{
|
319
|
+
|
320
|
+
/// Iterator for the greatest lower bound ranges of a set variable
|
321
|
+
class SetVarGlbRanges {
|
322
|
+
private:
|
323
|
+
Set::GlbRanges<Set::SetVarImp*> iter;
|
324
|
+
public:
|
325
|
+
/// \name Constructors and initialization
|
326
|
+
//@{
|
327
|
+
/// Default constructor
|
328
|
+
SetVarGlbRanges(void);
|
329
|
+
/// Initialize to iterate ranges of variable \a x
|
330
|
+
SetVarGlbRanges(const SetVar& x);
|
331
|
+
//@}
|
332
|
+
|
333
|
+
/// \name Iteration control
|
334
|
+
//@{
|
335
|
+
/// Test whether iterator is still at a range or done
|
336
|
+
bool operator()(void) const;
|
337
|
+
/// Move iterator to next range (if possible)
|
338
|
+
void operator++(void);
|
339
|
+
//@}
|
340
|
+
|
341
|
+
/// \name Range access
|
342
|
+
//@{
|
343
|
+
/// Return smallest value of range
|
344
|
+
int min(void) const;
|
345
|
+
/// Return largest value of range
|
346
|
+
int max(void) const;
|
347
|
+
/// Return width of range (distance between minimum and maximum)
|
348
|
+
unsigned int width(void) const;
|
349
|
+
//@}
|
350
|
+
};
|
351
|
+
|
352
|
+
/// Iterator for the least upper bound ranges of a set variable
|
353
|
+
class SetVarLubRanges {
|
354
|
+
private:
|
355
|
+
Set::LubRanges<Set::SetVarImp*> iter;
|
356
|
+
public:
|
357
|
+
/// \name Constructors and initialization
|
358
|
+
//@{
|
359
|
+
/// Default constructor
|
360
|
+
SetVarLubRanges(void);
|
361
|
+
/// Initialize to iterate ranges of variable \a x
|
362
|
+
SetVarLubRanges(const SetVar& x);
|
363
|
+
//@}
|
364
|
+
|
365
|
+
/// \name Iteration control
|
366
|
+
//@{
|
367
|
+
/// Test whether iterator is still at a range or done
|
368
|
+
bool operator()(void) const;
|
369
|
+
/// Move iterator to next range (if possible)
|
370
|
+
void operator++(void);
|
371
|
+
//@}
|
372
|
+
|
373
|
+
/// \name Range access
|
374
|
+
//@{
|
375
|
+
/// Return smallest value of range
|
376
|
+
int min(void) const;
|
377
|
+
/// Return largest value of range
|
378
|
+
int max(void) const;
|
379
|
+
/// Return width of range (distance between minimum and maximum)
|
380
|
+
unsigned int width(void) const;
|
381
|
+
//@}
|
382
|
+
};
|
383
|
+
|
384
|
+
/// Iterator for the unknown ranges of a set variable
|
385
|
+
class SetVarUnknownRanges {
|
386
|
+
private:
|
387
|
+
Set::UnknownRanges<Set::SetVarImp*> iter;
|
388
|
+
public:
|
389
|
+
/// \name Constructors and initialization
|
390
|
+
//@{
|
391
|
+
/// Default constructor
|
392
|
+
SetVarUnknownRanges(void);
|
393
|
+
/// Initialize to iterate ranges of variable \a x
|
394
|
+
SetVarUnknownRanges(const SetVar& x);
|
395
|
+
//@}
|
396
|
+
|
397
|
+
/// \name Iteration control
|
398
|
+
//@{
|
399
|
+
/// Test whether iterator is still at a range or done
|
400
|
+
bool operator()(void) const;
|
401
|
+
/// Move iterator to next range (if possible)
|
402
|
+
void operator++(void);
|
403
|
+
//@}
|
404
|
+
|
405
|
+
/// \name Range access
|
406
|
+
//@{
|
407
|
+
/// Return smallest value of range
|
408
|
+
int min(void) const;
|
409
|
+
/// Return largest value of range
|
410
|
+
int max(void) const;
|
411
|
+
/// Return width of range (distance between minimum and maximum)
|
412
|
+
unsigned int width(void) const;
|
413
|
+
//@}
|
414
|
+
};
|
415
|
+
|
416
|
+
/// Iterator for the values in the greatest lower bound of a set variable
|
417
|
+
class SetVarGlbValues {
|
418
|
+
private:
|
419
|
+
Iter::Ranges::ToValues<SetVarGlbRanges> iter;
|
420
|
+
public:
|
421
|
+
/// \name Constructors and initialization
|
422
|
+
//@{
|
423
|
+
/// Default constructor
|
424
|
+
SetVarGlbValues(void);
|
425
|
+
/// Initialize to iterate values of variable \a x
|
426
|
+
SetVarGlbValues(const SetVar& x);
|
427
|
+
//@}
|
428
|
+
|
429
|
+
/// \name Iteration control
|
430
|
+
//@{
|
431
|
+
/// Test whether iterator is still at a value or done
|
432
|
+
bool operator()(void) const;
|
433
|
+
/// Move iterator to next value (if possible)
|
434
|
+
void operator++(void);
|
435
|
+
//@}
|
436
|
+
|
437
|
+
/// \name Value access
|
438
|
+
//@{
|
439
|
+
/// Return current value
|
440
|
+
int val(void) const;
|
441
|
+
//@}
|
442
|
+
};
|
443
|
+
|
444
|
+
/// Iterator for the values in the least upper bound of a set variable
|
445
|
+
class SetVarLubValues {
|
446
|
+
private:
|
447
|
+
Iter::Ranges::ToValues<SetVarLubRanges> iter;
|
448
|
+
public:
|
449
|
+
/// \name Constructors and initialization
|
450
|
+
//@{
|
451
|
+
/// Default constructor
|
452
|
+
SetVarLubValues(void);
|
453
|
+
/// Initialize to iterate values of variable \a x
|
454
|
+
SetVarLubValues(const SetVar& x);
|
455
|
+
//@}
|
456
|
+
|
457
|
+
/// \name Iteration control
|
458
|
+
//@{
|
459
|
+
/// Test whether iterator is still at a value or done
|
460
|
+
bool operator()(void) const;
|
461
|
+
/// Move iterator to next value (if possible)
|
462
|
+
void operator++(void);
|
463
|
+
//@}
|
464
|
+
|
465
|
+
/// \name Value access
|
466
|
+
//@{
|
467
|
+
/// Return current value
|
468
|
+
int val(void) const;
|
469
|
+
//@}
|
470
|
+
};
|
471
|
+
|
472
|
+
/// Iterator for the values in the unknown set of a set variable
|
473
|
+
class SetVarUnknownValues {
|
474
|
+
private:
|
475
|
+
Iter::Ranges::ToValues<SetVarUnknownRanges> iter;
|
476
|
+
public:
|
477
|
+
/// \name Constructors and initialization
|
478
|
+
//@{
|
479
|
+
/// Default constructor
|
480
|
+
SetVarUnknownValues(void);
|
481
|
+
/// Initialize to iterate values of variable \a x
|
482
|
+
SetVarUnknownValues(const SetVar& x);
|
483
|
+
//@}
|
484
|
+
|
485
|
+
/// \name Iteration control
|
486
|
+
//@{
|
487
|
+
/// Test whether iterator is still at a value or done
|
488
|
+
bool operator()(void) const;
|
489
|
+
/// Move iterator to next value (if possible)
|
490
|
+
void operator++(void);
|
491
|
+
//@}
|
492
|
+
|
493
|
+
/// \name Value access
|
494
|
+
//@{
|
495
|
+
/// Return current value
|
496
|
+
int val(void) const;
|
497
|
+
//@}
|
498
|
+
};
|
499
|
+
|
500
|
+
//@}
|
501
|
+
|
502
|
+
}
|
503
|
+
|
504
|
+
/**
|
505
|
+
* \brief Print set variable \a x
|
506
|
+
* \relates Gecode::SetVar
|
507
|
+
*/
|
508
|
+
GECODE_SET_EXPORT std::ostream&
|
509
|
+
operator<<(std::ostream&, const Gecode::SetVar& x);
|
510
|
+
|
511
|
+
#include "gecode/set/view.icc"
|
512
|
+
#include "gecode/set/propagator.icc"
|
513
|
+
|
514
|
+
namespace Gecode {
|
515
|
+
/**
|
516
|
+
* \defgroup TaskModelSetArgs Argument arrays
|
517
|
+
*
|
518
|
+
* Argument arrays are just good enough for passing arguments
|
519
|
+
* with automatic memory management.
|
520
|
+
* \ingroup TaskModelSet
|
521
|
+
*/
|
522
|
+
|
523
|
+
//@{
|
524
|
+
/// Passing set arguments
|
525
|
+
typedef PrimArgArray<IntSet> IntSetArgs;
|
526
|
+
/// Passing set variables
|
527
|
+
typedef VarArgArray<SetVar> SetVarArgs;
|
528
|
+
//@}
|
529
|
+
|
530
|
+
/**
|
531
|
+
* \defgroup TaskModelSetVarArrays Variable arrays
|
532
|
+
*
|
533
|
+
* Variable arrays can store variables. They are typically used
|
534
|
+
* for storing the variables being part of a solution. However,
|
535
|
+
* they can also be used for temporary purposes (even though
|
536
|
+
* memory is not reclaimed until the space it is created for
|
537
|
+
* is deleted).
|
538
|
+
* \ingroup TaskModelSet
|
539
|
+
*/
|
540
|
+
|
541
|
+
/**
|
542
|
+
* \brief %Set variable array
|
543
|
+
* \ingroup TaskModelSetVarArrays
|
544
|
+
*/
|
545
|
+
class SetVarArray : public VarArray<SetVar> {
|
546
|
+
public:
|
547
|
+
SetVarArray(void);
|
548
|
+
SetVarArray(const SetVarArray&);
|
549
|
+
/// Create an uninitialized array of size \a n
|
550
|
+
GECODE_SET_EXPORT SetVarArray(Space* home,int n);
|
551
|
+
/**
|
552
|
+
* \brief Create an array of size \a n.
|
553
|
+
*
|
554
|
+
* Each variable is initialized with the bounds and cardinality as
|
555
|
+
* given by the arguments.
|
556
|
+
*/
|
557
|
+
GECODE_SET_EXPORT
|
558
|
+
SetVarArray(Space* home,int n,int glbMin,int glbMax,int lubMin,int lubMax,
|
559
|
+
unsigned int minCard = 0,
|
560
|
+
unsigned int maxCard = Set::Limits::card);
|
561
|
+
/**
|
562
|
+
* \brief Create an array of size \a n.
|
563
|
+
*
|
564
|
+
* Each variable is initialized with the bounds and cardinality as
|
565
|
+
* given by the arguments.
|
566
|
+
*/
|
567
|
+
GECODE_SET_EXPORT
|
568
|
+
SetVarArray(Space* home,int n,const IntSet& glb, int lubMin, int lubMax,
|
569
|
+
unsigned int minCard = 0,
|
570
|
+
unsigned int maxCard = Set::Limits::card);
|
571
|
+
/**
|
572
|
+
* \brief Create an array of size \a n.
|
573
|
+
*
|
574
|
+
* Each variable is initialized with the bounds and cardinality as
|
575
|
+
* given by the arguments.
|
576
|
+
*/
|
577
|
+
GECODE_SET_EXPORT
|
578
|
+
SetVarArray(Space* home,int n,int glbMin,int glbMax,const IntSet& lub,
|
579
|
+
unsigned int minCard = 0,
|
580
|
+
unsigned int maxCard = Set::Limits::card);
|
581
|
+
/**
|
582
|
+
* \brief Create an array of size \a n.
|
583
|
+
*
|
584
|
+
* Each variable is initialized with the bounds and cardinality as
|
585
|
+
* given by the arguments.
|
586
|
+
*/
|
587
|
+
GECODE_SET_EXPORT
|
588
|
+
SetVarArray(Space* home,int n,
|
589
|
+
const IntSet& glb,const IntSet& lub,
|
590
|
+
unsigned int minCard = 0,
|
591
|
+
unsigned int maxCard = Set::Limits::card);
|
592
|
+
};
|
593
|
+
|
594
|
+
}
|
595
|
+
|
596
|
+
#include "gecode/set/array.icc"
|
597
|
+
|
598
|
+
namespace Gecode {
|
599
|
+
|
600
|
+
/**
|
601
|
+
* \brief Common relation types for sets
|
602
|
+
* \ingroup TaskModelSet
|
603
|
+
*/
|
604
|
+
enum SetRelType {
|
605
|
+
SRT_EQ, ///< Equality (\f$=\f$)
|
606
|
+
SRT_NQ, ///< Disequality (\f$\neq\f$)
|
607
|
+
SRT_SUB, ///< Subset (\f$\subseteq\f$)
|
608
|
+
SRT_SUP, ///< Superset (\f$\supseteq\f$)
|
609
|
+
SRT_DISJ, ///< Disjoint (\f$\parallel\f$)
|
610
|
+
SRT_CMPL ///< Complement
|
611
|
+
};
|
612
|
+
|
613
|
+
/**
|
614
|
+
* \brief Common operations for sets
|
615
|
+
* \ingroup TaskModelSet
|
616
|
+
*/
|
617
|
+
enum SetOpType {
|
618
|
+
SOT_UNION, ///< Union
|
619
|
+
SOT_DUNION, ///< Disjoint union
|
620
|
+
SOT_INTER, ///< %Intersection
|
621
|
+
SOT_MINUS ///< Difference
|
622
|
+
};
|
623
|
+
|
624
|
+
/**
|
625
|
+
* \defgroup TaskModelSetDom Domain constraints
|
626
|
+
* \ingroup TaskModelSet
|
627
|
+
*
|
628
|
+
*/
|
629
|
+
|
630
|
+
//@{
|
631
|
+
|
632
|
+
/// Propagates \f$ x \sim_r \{i\}\f$
|
633
|
+
GECODE_SET_EXPORT void
|
634
|
+
dom(Space* home, SetVar x, SetRelType r, int i);
|
635
|
+
|
636
|
+
/// Propagates \f$ x \sim_r \{i,\dots,j\}\f$
|
637
|
+
GECODE_SET_EXPORT void
|
638
|
+
dom(Space* home, SetVar x, SetRelType r, int i, int j);
|
639
|
+
|
640
|
+
/// Propagates \f$ x \sim_r s\f$
|
641
|
+
GECODE_SET_EXPORT void
|
642
|
+
dom(Space* home, SetVar x, SetRelType r, const IntSet& s);
|
643
|
+
|
644
|
+
/// Post propagator for \f$ (x \sim_r \{i\}) \Leftrightarrow b \f$
|
645
|
+
GECODE_SET_EXPORT void
|
646
|
+
dom(Space* home, SetVar x, SetRelType r, int i, BoolVar b);
|
647
|
+
|
648
|
+
/// Post propagator for \f$ (x \sim_r \{i,\dots,j\}) \Leftrightarrow b \f$
|
649
|
+
GECODE_SET_EXPORT void
|
650
|
+
dom(Space* home, SetVar x, SetRelType r, int i, int j, BoolVar b);
|
651
|
+
|
652
|
+
/// Post propagator for \f$ (x \sim_r s) \Leftrightarrow b \f$
|
653
|
+
GECODE_SET_EXPORT void
|
654
|
+
dom(Space* home, SetVar x, SetRelType r, const IntSet& s, BoolVar b);
|
655
|
+
|
656
|
+
/// Propagates \f$ i \leq |s| \leq j \f$
|
657
|
+
GECODE_SET_EXPORT void
|
658
|
+
cardinality(Space* home, SetVar x, unsigned int i, unsigned int j);
|
659
|
+
|
660
|
+
//@}
|
661
|
+
|
662
|
+
|
663
|
+
/**
|
664
|
+
* \defgroup TaskModelSetRel Relation constraints
|
665
|
+
* \ingroup TaskModelSet
|
666
|
+
*
|
667
|
+
*/
|
668
|
+
|
669
|
+
//@{
|
670
|
+
|
671
|
+
/// Post propagator for \f$ x \sim_r y\f$
|
672
|
+
GECODE_SET_EXPORT void
|
673
|
+
rel(Space* home, SetVar x, SetRelType r, SetVar y);
|
674
|
+
|
675
|
+
/// Post propagator for \f$ (x \sim_r y) \Leftrightarrow b \f$
|
676
|
+
GECODE_SET_EXPORT void
|
677
|
+
rel(Space* home, SetVar x, SetRelType r, SetVar y, BoolVar b);
|
678
|
+
|
679
|
+
/// Post propagator for \f$ s \sim_r \{x\}\f$
|
680
|
+
GECODE_SET_EXPORT void
|
681
|
+
rel(Space* home, SetVar s, SetRelType r, IntVar x);
|
682
|
+
|
683
|
+
/// Post propagator for \f$ \{x\} \sim_r s\f$
|
684
|
+
GECODE_SET_EXPORT void
|
685
|
+
rel(Space* home, IntVar x, SetRelType r, SetVar s);
|
686
|
+
|
687
|
+
/// Post propagator for \f$ (s \sim_r \{x\}) \Leftrightarrow b \f$
|
688
|
+
GECODE_SET_EXPORT void
|
689
|
+
rel(Space* home, SetVar s, SetRelType r, IntVar x, BoolVar b);
|
690
|
+
|
691
|
+
/// Post propagator for \f$ (\{x\} \sim_r s) \Leftrightarrow b \f$
|
692
|
+
GECODE_SET_EXPORT void
|
693
|
+
rel(Space* home, IntVar x, SetRelType r, SetVar s, BoolVar b);
|
694
|
+
|
695
|
+
/// Post propagator for \f$|s|\geq 1 \land \forall i\in s:\ i \sim_r x\f$
|
696
|
+
GECODE_SET_EXPORT void
|
697
|
+
rel(Space* home, SetVar s, IntRelType r, IntVar x);
|
698
|
+
|
699
|
+
/// Post propagator for \f$|s|\geq 1 \land \forall i\in s:\ x \sim_r i\f$
|
700
|
+
GECODE_SET_EXPORT void
|
701
|
+
rel(Space* home, IntVar x, IntRelType r, SetVar s);
|
702
|
+
|
703
|
+
//@}
|
704
|
+
|
705
|
+
/**
|
706
|
+
* \defgroup TaskModelSetRelOp Set operation/relation constraints
|
707
|
+
* \ingroup TaskModelSet
|
708
|
+
*
|
709
|
+
*/
|
710
|
+
|
711
|
+
//@{
|
712
|
+
|
713
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{op}} y) \sim_r z \f$
|
714
|
+
GECODE_SET_EXPORT void
|
715
|
+
rel(Space* home, SetVar x, SetOpType op, SetVar y, SetRelType r, SetVar z);
|
716
|
+
|
717
|
+
/// Post propagator for \f$ y = \diamond_{\mathit{op}} x\f$
|
718
|
+
GECODE_SET_EXPORT void
|
719
|
+
rel(Space* home, SetOpType op, const SetVarArgs& x, SetVar y);
|
720
|
+
|
721
|
+
/// Post propagator for \f$ y = \diamond_{\mathit{op}} x \diamond_{\mathit{op}} z\f$
|
722
|
+
GECODE_SET_EXPORT void
|
723
|
+
rel(Space* home, SetOpType op, const SetVarArgs& x, const IntSet& z, SetVar y);
|
724
|
+
|
725
|
+
/// Post propagator for \f$ y = \diamond_{\mathit{op}} x \diamond_{\mathit{op}} z\f$
|
726
|
+
GECODE_SET_EXPORT void
|
727
|
+
rel(Space* home, SetOpType op, const IntVarArgs& x, const IntSet& z, SetVar y);
|
728
|
+
|
729
|
+
/// Post propagator for \f$ y = \diamond_{\mathit{op}} x\f$
|
730
|
+
GECODE_SET_EXPORT void
|
731
|
+
rel(Space* home, SetOpType op, const IntVarArgs& x, SetVar y);
|
732
|
+
|
733
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{op}} y) \sim_r z \f$
|
734
|
+
GECODE_SET_EXPORT void
|
735
|
+
rel(Space* home, const IntSet& x, SetOpType op, SetVar y,
|
736
|
+
SetRelType r, SetVar z);
|
737
|
+
|
738
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{op}} y) \sim_r z \f$
|
739
|
+
GECODE_SET_EXPORT void
|
740
|
+
rel(Space* home, SetVar x, SetOpType op, const IntSet& y,
|
741
|
+
SetRelType r, SetVar z);
|
742
|
+
|
743
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{op}} y) \sim_r z \f$
|
744
|
+
GECODE_SET_EXPORT void
|
745
|
+
rel(Space* home, SetVar x, SetOpType op, SetVar y,
|
746
|
+
SetRelType r, const IntSet& z);
|
747
|
+
|
748
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{op}} y) \sim_r z \f$
|
749
|
+
GECODE_SET_EXPORT void
|
750
|
+
rel(Space* home, const IntSet& x, SetOpType op, SetVar y, SetRelType r,
|
751
|
+
const IntSet& z);
|
752
|
+
|
753
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{op}} y) \sim_r z \f$
|
754
|
+
GECODE_SET_EXPORT void
|
755
|
+
rel(Space* home, SetVar x, SetOpType op, const IntSet& y, SetRelType r,
|
756
|
+
const IntSet& z);
|
757
|
+
|
758
|
+
//@}
|
759
|
+
|
760
|
+
|
761
|
+
/**
|
762
|
+
* \defgroup TaskModelSetConvex Convexity constraints
|
763
|
+
* \ingroup TaskModelSet
|
764
|
+
*
|
765
|
+
*/
|
766
|
+
//@{
|
767
|
+
|
768
|
+
/// Post propagator that propagates that \a x is convex
|
769
|
+
GECODE_SET_EXPORT void
|
770
|
+
convex(Space* home, SetVar x);
|
771
|
+
|
772
|
+
/// Post propagator that propagates that \a y is the convex hull of \a x
|
773
|
+
GECODE_SET_EXPORT void
|
774
|
+
convexHull(Space* home, SetVar x, SetVar y);
|
775
|
+
|
776
|
+
//@}
|
777
|
+
|
778
|
+
/**
|
779
|
+
* \defgroup TaskModelSetSequence Sequence constraints
|
780
|
+
* \ingroup TaskModelSet
|
781
|
+
*
|
782
|
+
*/
|
783
|
+
//@{
|
784
|
+
|
785
|
+
/// Post propagator for \f$\forall 0\leq i< |x|-1 : \max(x_i)<\min(x_{i+1})\f$
|
786
|
+
GECODE_SET_EXPORT void
|
787
|
+
sequence(Space* home, const SetVarArgs& x);
|
788
|
+
|
789
|
+
/// Post propagator for \f$\forall 0\leq i< |x|-1 : \max(x_i)<\min(x_{i+1})\f$ and \f$ x = \bigcup_{i\in\{0,\dots,n-1\}} y_i \f$
|
790
|
+
GECODE_SET_EXPORT void
|
791
|
+
sequentialUnion(Space* home, const SetVarArgs& y, SetVar x);
|
792
|
+
|
793
|
+
//@}
|
794
|
+
|
795
|
+
/**
|
796
|
+
* \defgroup TaskModelSetDistinct Distinctness constraints
|
797
|
+
* \ingroup TaskModelSet
|
798
|
+
*
|
799
|
+
*/
|
800
|
+
//@{
|
801
|
+
|
802
|
+
|
803
|
+
/// Post propagator for \f$\forall 0\leq i\leq |x| : |x_i|=c\f$ and \f$\forall 0\leq i<j\leq |x| : |x_i\cap x_j|\leq 1\f$
|
804
|
+
GECODE_SET_EXPORT void
|
805
|
+
atmostOne(Space* home, const SetVarArgs& x, unsigned int c);
|
806
|
+
|
807
|
+
//@}
|
808
|
+
|
809
|
+
/**
|
810
|
+
* \defgroup TaskModelSetConnect Connection constraints to finite domain variables
|
811
|
+
* \ingroup TaskModelSet
|
812
|
+
*
|
813
|
+
*/
|
814
|
+
|
815
|
+
//@{
|
816
|
+
|
817
|
+
/** \brief Post propagator that propagates that \a x is the
|
818
|
+
* minimal element of \a s, and that \a s is not empty */
|
819
|
+
GECODE_SET_EXPORT void
|
820
|
+
min(Space* home, SetVar s, IntVar x);
|
821
|
+
|
822
|
+
/** \brief Post propagator that propagates that \a x is the
|
823
|
+
* maximal element of \a s, and that \a s is not empty */
|
824
|
+
GECODE_SET_EXPORT void
|
825
|
+
max(Space* home, SetVar s, IntVar x);
|
826
|
+
|
827
|
+
/// Post propagator that propagates that \a s contains the \f$x_i\f$, which are sorted in non-descending order
|
828
|
+
GECODE_SET_EXPORT void
|
829
|
+
match(Space* home, SetVar s, const IntVarArgs& x);
|
830
|
+
|
831
|
+
/// Post propagator for \f$x_i=j \Leftrightarrow i\in y_j\f$
|
832
|
+
GECODE_SET_EXPORT void
|
833
|
+
channel(Space* home, const IntVarArgs& x,const SetVarArgs& y);
|
834
|
+
|
835
|
+
/// Post propagator for \f$x_i=1 \Leftrightarrow i\in y\f$
|
836
|
+
GECODE_SET_EXPORT void
|
837
|
+
channel(Space* home, const BoolVarArgs& x, SetVar y);
|
838
|
+
|
839
|
+
/// Post propagator for \f$ |s|=x \f$
|
840
|
+
GECODE_SET_EXPORT void
|
841
|
+
cardinality(Space* home, SetVar s, IntVar x);
|
842
|
+
|
843
|
+
|
844
|
+
/**
|
845
|
+
* \brief Post propagator for \f$y = \mathrm{weight}(x)\f$
|
846
|
+
*
|
847
|
+
* The weights are given as pairs of elements and their weight:
|
848
|
+
* \f$\mathrm{weight}(\mathrm{elements}_i) = \mathrm{weights}_i\f$
|
849
|
+
*
|
850
|
+
* The upper bound of \a x is constrained to contain only elements from
|
851
|
+
* \a elements. The weight of a set is the sum of the weights of its
|
852
|
+
* elements.
|
853
|
+
*/
|
854
|
+
GECODE_SET_EXPORT void
|
855
|
+
weights(Space* home, const IntArgs& elements, const IntArgs& weights,
|
856
|
+
SetVar x, IntVar y);
|
857
|
+
|
858
|
+
//@}
|
859
|
+
|
860
|
+
/**
|
861
|
+
* \defgroup TaskModelSetElement Element constraints
|
862
|
+
* \ingroup TaskModelSet
|
863
|
+
*
|
864
|
+
* An element constraint selects zero, one or more elements out of a
|
865
|
+
* sequence. We write \f$ \langle x_0,\dots, x_{n-1} \rangle \f$ for the
|
866
|
+
* sequence, and \f$ [y] \f$ for the index variable.
|
867
|
+
*
|
868
|
+
* Set element constraints are closely related to the ::element constraint
|
869
|
+
* on finite domain variables.
|
870
|
+
*/
|
871
|
+
|
872
|
+
//@{
|
873
|
+
|
874
|
+
/**
|
875
|
+
* \brief Post propagator for \f$ z=\bigcup\langle x_0,\dots,x_{n-1}\rangle[y] \f$
|
876
|
+
*
|
877
|
+
* If \a y is the empty set, \a z will also be constrained to be empty
|
878
|
+
* (as an empty union is empty).
|
879
|
+
* The indices for \a s start at 0.
|
880
|
+
*/
|
881
|
+
GECODE_SET_EXPORT void
|
882
|
+
elementsUnion(Space* home, const SetVarArgs& x, SetVar y, SetVar z);
|
883
|
+
|
884
|
+
/**
|
885
|
+
* \brief Post propagator for \f$ z=\bigcup\langle s_0,\dots,s_{n-1}\rangle[y] \f$
|
886
|
+
*
|
887
|
+
* If \a y is the empty set, \a z will also be constrained to be empty
|
888
|
+
* (as an empty union is empty).
|
889
|
+
* The indices for \a s start at 0.
|
890
|
+
*/
|
891
|
+
GECODE_SET_EXPORT void
|
892
|
+
elementsUnion(Space* home, const IntSetArgs& s, SetVar y, SetVar z);
|
893
|
+
|
894
|
+
/**
|
895
|
+
* \brief Post propagator for \f$ z=\bigcap\langle x_0,\dots,x_{n-1}\rangle[y] \f$ using \f$ \mathcal{U} \f$ as universe
|
896
|
+
*
|
897
|
+
* If \a y is empty, \a z will be constrained to be the universe
|
898
|
+
* \f$ \mathcal{U} \f$ (as an empty intersection is the universe).
|
899
|
+
* The indices for \a s start at 0.
|
900
|
+
*/
|
901
|
+
GECODE_SET_EXPORT void
|
902
|
+
elementsInter(Space* home, const SetVarArgs& x, SetVar y, SetVar z);
|
903
|
+
|
904
|
+
/**
|
905
|
+
* \brief Post propagator for \f$ z=\bigcap\langle x_0,\dots,x_{n-1}\rangle[y] \f$ using \a u as universe
|
906
|
+
*
|
907
|
+
* If \a y is empty, \a z will be constrained to be the given universe
|
908
|
+
* \a u (as an empty intersection is the universe).
|
909
|
+
* The indices for \a s start at 0.
|
910
|
+
*/
|
911
|
+
GECODE_SET_EXPORT void
|
912
|
+
elementsInter(Space* home, const SetVarArgs& x, SetVar y, SetVar z,
|
913
|
+
const IntSet& u);
|
914
|
+
|
915
|
+
/// Post propagator for \f$ \parallel\langle x_0,\dots,x_{n-1}\rangle[y] \f$
|
916
|
+
GECODE_SET_EXPORT void
|
917
|
+
elementsDisjoint(Space* home, const SetVarArgs& x, SetVar y);
|
918
|
+
|
919
|
+
/**
|
920
|
+
* \brief Post propagator for \f$ z=\langle x_0,\dots,x_{n-1}\rangle[y] \f$
|
921
|
+
*
|
922
|
+
* The indices for \a s start at 0.
|
923
|
+
*/
|
924
|
+
GECODE_SET_EXPORT void
|
925
|
+
element(Space* home, const SetVarArgs& x, IntVar y, SetVar z);
|
926
|
+
|
927
|
+
/**
|
928
|
+
* \brief Post propagator for \f$ z=\langle s_0,\dots,s_{n-1}\rangle[y] \f$
|
929
|
+
*
|
930
|
+
* The indices for \a s start at 0.
|
931
|
+
*/
|
932
|
+
GECODE_SET_EXPORT void
|
933
|
+
element(Space* home, const IntSetArgs& s, IntVar y, SetVar z);
|
934
|
+
|
935
|
+
//@}
|
936
|
+
|
937
|
+
/**
|
938
|
+
* \defgroup TaskModelSetBranch Branching
|
939
|
+
* \ingroup TaskModelSet
|
940
|
+
*/
|
941
|
+
|
942
|
+
//@{
|
943
|
+
|
944
|
+
/// Which variable to select for branching
|
945
|
+
enum SetVarBranch {
|
946
|
+
SET_VAR_NONE, ///< First unassigned
|
947
|
+
SET_VAR_MIN_CARD, ///< With smallest unknown set
|
948
|
+
SET_VAR_MAX_CARD, ///< With largest unknown set
|
949
|
+
SET_VAR_MIN_UNKNOWN_ELEM, ///< With smallest unknown element
|
950
|
+
SET_VAR_MAX_UNKNOWN_ELEM ///< With largest unknown element
|
951
|
+
};
|
952
|
+
|
953
|
+
/// Which values to select first for branching
|
954
|
+
enum SetValBranch {
|
955
|
+
SET_VAL_MIN, ///< Select smallest value in unknown set
|
956
|
+
SET_VAL_MAX ///< Select largest value in unknown set
|
957
|
+
};
|
958
|
+
|
959
|
+
/// Branch over \a x with variable selection \a vars and value selection \a vals
|
960
|
+
GECODE_SET_EXPORT void
|
961
|
+
branch(Space* home, const SetVarArgs& x,
|
962
|
+
SetVarBranch vars, SetValBranch vals);
|
963
|
+
//@}
|
964
|
+
|
965
|
+
}
|
966
|
+
|
967
|
+
#endif
|
968
|
+
|
969
|
+
// IFDEF: GECODE_HAS_SET_VARS
|
970
|
+
// STATISTICS: set-post
|