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,797 @@
|
|
1
|
+
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
+
/*
|
3
|
+
* Main authors:
|
4
|
+
* Patrick Pekczynski <pekczynski@ps.uni-sb.de>
|
5
|
+
*
|
6
|
+
* Copyright:
|
7
|
+
* Patrick Pekczynski, 2006
|
8
|
+
*
|
9
|
+
* Last modified:
|
10
|
+
* $Date: 2008-08-06 10:39:34 +0200 (Wed, 06 Aug 2008) $ by $Author: raphael $
|
11
|
+
* $Revision: 7494 $
|
12
|
+
*
|
13
|
+
* This file is part of Gecode, the generic constraint
|
14
|
+
* development environment:
|
15
|
+
* http://www.gecode.org
|
16
|
+
*
|
17
|
+
* Permission is hereby granted, free of charge, to any person obtaining
|
18
|
+
* a copy of this software and associated documentation files (the
|
19
|
+
* "Software"), to deal in the Software without restriction, including
|
20
|
+
* without limitation the rights to use, copy, modify, merge, publish,
|
21
|
+
* distribute, sublicense, and/or sell copies of the Software, and to
|
22
|
+
* permit persons to whom the Software is furnished to do so, subject to
|
23
|
+
* the following conditions:
|
24
|
+
*
|
25
|
+
* The above copyright notice and this permission notice shall be
|
26
|
+
* included in all copies or substantial portions of the Software.
|
27
|
+
*
|
28
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
29
|
+
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
30
|
+
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
31
|
+
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
32
|
+
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
33
|
+
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
34
|
+
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
35
|
+
*
|
36
|
+
*/
|
37
|
+
|
38
|
+
#ifndef __GECODE_CPLTSET_HH__
|
39
|
+
#define __GECODE_CPLTSET_HH__
|
40
|
+
|
41
|
+
#include "gecode/kernel.hh"
|
42
|
+
#include "gecode/iter.hh"
|
43
|
+
#include "gecode/int.hh"
|
44
|
+
#include "gecode/set.hh"
|
45
|
+
|
46
|
+
/*
|
47
|
+
* Configure linking
|
48
|
+
*
|
49
|
+
*/
|
50
|
+
#if !defined(GECODE_STATIC_LIBS) && \
|
51
|
+
(defined(__CYGWIN__) || defined(__MINGW32__) || defined(_MSC_VER))
|
52
|
+
|
53
|
+
#ifdef GECODE_BUILD_CPLTSET
|
54
|
+
#define GECODE_CPLTSET_EXPORT __declspec( dllexport )
|
55
|
+
#else
|
56
|
+
#define GECODE_CPLTSET_EXPORT __declspec( dllimport )
|
57
|
+
#endif
|
58
|
+
|
59
|
+
#else
|
60
|
+
|
61
|
+
#ifdef GECODE_GCC_HAS_CLASS_VISIBILITY
|
62
|
+
#define GECODE_CPLTSET_EXPORT __attribute__ ((visibility("default")))
|
63
|
+
#else
|
64
|
+
#define GECODE_CPLTSET_EXPORT
|
65
|
+
#endif
|
66
|
+
|
67
|
+
#endif
|
68
|
+
|
69
|
+
#include "gecode/cpltset/exception.icc"
|
70
|
+
|
71
|
+
/**
|
72
|
+
* \namespace Gecode::CpltSet
|
73
|
+
* \brief Complete representation of finite integer sets using ROBDD's
|
74
|
+
*
|
75
|
+
* The Gecode::CpltSet namespace contains all functionality required
|
76
|
+
* to program propagators and branchings for finite integer set variables,
|
77
|
+
* where the variables' domains are represented completely (without
|
78
|
+
* approximation) using reduced ordered binary decision diagrams (ROBDDs).
|
79
|
+
*
|
80
|
+
* In addition, all propagators and branchings for these variables
|
81
|
+
* provided by %Gecode are contained as nested namespaces.
|
82
|
+
*
|
83
|
+
*/
|
84
|
+
|
85
|
+
#include "gecode/cpltset/bddmanager.icc"
|
86
|
+
|
87
|
+
#include "gecode/cpltset/support.icc"
|
88
|
+
#include "gecode/cpltset/var-imp.icc"
|
89
|
+
|
90
|
+
namespace Gecode {
|
91
|
+
/**
|
92
|
+
* \brief Finite set variable with complete domain representation
|
93
|
+
*
|
94
|
+
* \ingroup TaskModelCpltSetVars
|
95
|
+
*
|
96
|
+
*/
|
97
|
+
class CpltSetVar : public VarBase<CpltSet::CpltSetVarImp> {
|
98
|
+
private:
|
99
|
+
using VarBase<CpltSet::CpltSetVarImp>::varimp;
|
100
|
+
public:
|
101
|
+
/// Default constructor
|
102
|
+
CpltSetVar(void);
|
103
|
+
|
104
|
+
/// Deallocate memory
|
105
|
+
void dispose(Space* home);
|
106
|
+
|
107
|
+
/**
|
108
|
+
* \brief Initialize variable with given bounds and cardinality
|
109
|
+
*
|
110
|
+
* The variable is created with
|
111
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
112
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
113
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
114
|
+
* The following exceptions might be thrown:
|
115
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
116
|
+
* and Set::Limits::max), an exception of type
|
117
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
118
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
119
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
120
|
+
* thrown.
|
121
|
+
* - If \a minCard > \a maxCard, an exception of type
|
122
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
123
|
+
*/
|
124
|
+
GECODE_CPLTSET_EXPORT
|
125
|
+
CpltSetVar(Space* home,
|
126
|
+
int glbMin,int glbMax,int lubMin,int lubMax,
|
127
|
+
unsigned int cardMin = 0,
|
128
|
+
unsigned int cardMax = Set::Limits::card);
|
129
|
+
/**
|
130
|
+
* \brief Initialize variable with given bounds and cardinality
|
131
|
+
*
|
132
|
+
* The variable is created with
|
133
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
134
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
135
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
136
|
+
* The following exceptions might be thrown:
|
137
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
138
|
+
* and Set::Limits::max), an exception of type
|
139
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
140
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
141
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
142
|
+
* thrown.
|
143
|
+
* - If \a minCard > \a maxCard, an exception of type
|
144
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
145
|
+
*/
|
146
|
+
void init(Space* home,
|
147
|
+
int glbMin,int glbMax,int lubMin,int lubMax,
|
148
|
+
unsigned int cardMin = 0,
|
149
|
+
unsigned int cardMax = Set::Limits::card);
|
150
|
+
|
151
|
+
/**
|
152
|
+
* \brief Initialize variable with given bounds and cardinality
|
153
|
+
*
|
154
|
+
* The variable is created with
|
155
|
+
* greatest lower bound \a glbD,
|
156
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
157
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
158
|
+
* The following exceptions might be thrown:
|
159
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
160
|
+
* and Set::Limits::max), an exception of type
|
161
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
162
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
163
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
164
|
+
* thrown.
|
165
|
+
* - If \a minCard > \a maxCard, an exception of type
|
166
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
167
|
+
*/
|
168
|
+
GECODE_CPLTSET_EXPORT
|
169
|
+
CpltSetVar(Space* home,
|
170
|
+
const IntSet& glbD,int lubMin,int lubMax,
|
171
|
+
unsigned int cardMin = 0,
|
172
|
+
unsigned int cardMax = Set::Limits::card);
|
173
|
+
/**
|
174
|
+
* \brief Initialize variable with given bounds and cardinality
|
175
|
+
*
|
176
|
+
* The variable is created with
|
177
|
+
* greatest lower bound \a glbD,
|
178
|
+
* least upper bound \f$\{\mathit{lubMin},\dots,\mathit{lubMax}\}\f$, and
|
179
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
180
|
+
* The following exceptions might be thrown:
|
181
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
182
|
+
* and Set::Limits::max), an exception of type
|
183
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
184
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
185
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
186
|
+
* thrown.
|
187
|
+
* - If \a minCard > \a maxCard, an exception of type
|
188
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
189
|
+
*/
|
190
|
+
void init(Space* home,
|
191
|
+
const IntSet& glbD,int lubMin,int lubMax,
|
192
|
+
unsigned int cardMin = 0,
|
193
|
+
unsigned int cardMax = Set::Limits::card);
|
194
|
+
|
195
|
+
/**
|
196
|
+
* \brief Initialize variable with given bounds and cardinality
|
197
|
+
*
|
198
|
+
* The variable is created with
|
199
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
200
|
+
* least upper bound \a lubD, and
|
201
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
202
|
+
* The following exceptions might be thrown:
|
203
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
204
|
+
* and Set::Limits::max), an exception of type
|
205
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
206
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
207
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
208
|
+
* thrown.
|
209
|
+
* - If \a minCard > \a maxCard, an exception of type
|
210
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
211
|
+
*/
|
212
|
+
GECODE_CPLTSET_EXPORT
|
213
|
+
CpltSetVar(Space* home,
|
214
|
+
int glbMin,int glbMax,const IntSet& lubD,
|
215
|
+
unsigned int cardMin = 0,
|
216
|
+
unsigned int cardMax = Set::Limits::card);
|
217
|
+
/**
|
218
|
+
* \brief Initialize variable with given bounds and cardinality
|
219
|
+
*
|
220
|
+
* The variable is created with
|
221
|
+
* greatest lower bound \f$\{\mathit{glbMin},\dots,\mathit{glbMax}\}\f$,
|
222
|
+
* least upper bound \a lubD, and
|
223
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
224
|
+
* The following exceptions might be thrown:
|
225
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
226
|
+
* and Set::Limits::max), an exception of type
|
227
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
228
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
229
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
230
|
+
* thrown.
|
231
|
+
* - If \a minCard > \a maxCard, an exception of type
|
232
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
233
|
+
*/
|
234
|
+
void init(Space* home,
|
235
|
+
int glbMin,int glbMax,const IntSet& lubD,
|
236
|
+
unsigned int cardMin = 0,
|
237
|
+
unsigned int cardMax = Set::Limits::card);
|
238
|
+
|
239
|
+
/**
|
240
|
+
* \brief Initialize variable with given bounds and cardinality
|
241
|
+
*
|
242
|
+
* The variable is created with
|
243
|
+
* greatest lower bound \a glbD,
|
244
|
+
* least upper bound \a lubD, and
|
245
|
+
* cardinality minimum \a cardMin and maximum \a cardMax.
|
246
|
+
* The following exceptions might be thrown:
|
247
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
248
|
+
* and Set::Limits::max), an exception of type
|
249
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
250
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
251
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
252
|
+
* thrown.
|
253
|
+
* - If \a minCard > \a maxCard, an exception of type
|
254
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
255
|
+
*/
|
256
|
+
GECODE_CPLTSET_EXPORT
|
257
|
+
CpltSetVar(Space* home,
|
258
|
+
const IntSet& glbD,const IntSet& lubD,
|
259
|
+
unsigned int cardMin = 0,
|
260
|
+
unsigned int cardMax = Set::Limits::card);
|
261
|
+
/**
|
262
|
+
* \brief Initialize variable with given bounds and cardinality
|
263
|
+
*
|
264
|
+
* The variable is created with greatest lower bound \a glbD,
|
265
|
+
* least upper bound \a lubD, and cardinality minimum \a cardMin
|
266
|
+
* and maximum \a cardMax.
|
267
|
+
* The following exceptions might be thrown:
|
268
|
+
* - If the bounds are no legal set bounds (between Set::Limits::min
|
269
|
+
* and Set::Limits::max), an exception of type
|
270
|
+
* Gecode::Set::VariableOutOfRangeDomain is thrown.
|
271
|
+
* - If the cardinality is greater than Set::Limits::max_set_size, an
|
272
|
+
* exception of type Gecode::Set::VariableOutOfRangeCardinality is
|
273
|
+
* thrown.
|
274
|
+
* - If \a minCard > \a maxCard, an exception of type
|
275
|
+
* Gecode::Set::VariableFailedDomain is thrown.
|
276
|
+
*/
|
277
|
+
void init(Space* home,
|
278
|
+
const IntSet& glbD,const IntSet& lubD,
|
279
|
+
unsigned int cardMin = 0,
|
280
|
+
unsigned int cardMax = Set::Limits::card);
|
281
|
+
//@}
|
282
|
+
|
283
|
+
/// \name Value access
|
284
|
+
//@{
|
285
|
+
/// Return the size of the greatest lower bound
|
286
|
+
unsigned int glbSize(void) const;
|
287
|
+
/// Return the size of the least upper bound
|
288
|
+
unsigned int lubSize(void) const;
|
289
|
+
/// Return the size of lub-glb
|
290
|
+
unsigned int unknownSize(void) const;
|
291
|
+
/// Return current cardinality minimum
|
292
|
+
unsigned int cardMin(void) const;
|
293
|
+
/// Return current cardinality maximum
|
294
|
+
unsigned int cardMax(void) const;
|
295
|
+
/// Return minimum of the least upper bound
|
296
|
+
int lubMin(void) const;
|
297
|
+
/// Return maximum of the least upper bound
|
298
|
+
int lubMax(void) const;
|
299
|
+
/// Return minimum of the greatest lower bound
|
300
|
+
int glbMin(void) const;
|
301
|
+
/// Return maximum of the greatest lower bound
|
302
|
+
int glbMax(void) const;
|
303
|
+
//@}
|
304
|
+
|
305
|
+
/// \name Domain tests
|
306
|
+
//@{
|
307
|
+
/// Test whether \a i is in greatest lower bound
|
308
|
+
bool contains(int i) const;
|
309
|
+
/// Test whether \a i is not in the least upper bound
|
310
|
+
bool notContains(int i) const;
|
311
|
+
/// Test whether this variable is assigned
|
312
|
+
bool assigned(void) const;
|
313
|
+
//@}
|
314
|
+
|
315
|
+
/// \name Cloning
|
316
|
+
//@{
|
317
|
+
/// Update this variable to be a clone of variable \a x
|
318
|
+
void update(Space* home, bool share, CpltSetVar& x);
|
319
|
+
//@}
|
320
|
+
|
321
|
+
};
|
322
|
+
|
323
|
+
/**
|
324
|
+
* \brief Range iterator for the greatest lower bound of a bdd variable
|
325
|
+
*
|
326
|
+
* \ingroup TaskModelCpltSetVars
|
327
|
+
*/
|
328
|
+
class CpltSetVarGlbRanges {
|
329
|
+
private:
|
330
|
+
Set::GlbRanges<CpltSet::CpltSetVarImp*> iter;
|
331
|
+
public:
|
332
|
+
CpltSetVarGlbRanges(void);
|
333
|
+
CpltSetVarGlbRanges(const CpltSetVar& x);
|
334
|
+
bool operator()(void) const;
|
335
|
+
void operator++(void);
|
336
|
+
int min(void) const;
|
337
|
+
int max(void) const;
|
338
|
+
};
|
339
|
+
|
340
|
+
/**
|
341
|
+
* \brief Value iterator for the greatest lower bound of a bdd variable
|
342
|
+
*
|
343
|
+
* \ingroup TaskModelCpltSetVars
|
344
|
+
*/
|
345
|
+
class CpltSetVarGlbValues {
|
346
|
+
private:
|
347
|
+
CpltSet::GlbValues<CpltSet::CpltSetVarImp*> iter;
|
348
|
+
public:
|
349
|
+
CpltSetVarGlbValues(void);
|
350
|
+
CpltSetVarGlbValues(const CpltSetVar& x);
|
351
|
+
bool operator()(void) const;
|
352
|
+
void operator++(void);
|
353
|
+
int val(void) const;
|
354
|
+
};
|
355
|
+
|
356
|
+
/**
|
357
|
+
* \brief Range iterator for the least upper bound of a bdd variable
|
358
|
+
*
|
359
|
+
* \ingroup TaskModelCpltSetVars
|
360
|
+
*/
|
361
|
+
class CpltSetVarLubRanges {
|
362
|
+
private:
|
363
|
+
Set::LubRanges<CpltSet::CpltSetVarImp*> iter;
|
364
|
+
public:
|
365
|
+
CpltSetVarLubRanges(void);
|
366
|
+
CpltSetVarLubRanges(const CpltSetVar& x);
|
367
|
+
bool operator()(void) const;
|
368
|
+
void operator++(void);
|
369
|
+
int min(void) const;
|
370
|
+
int max(void) const;
|
371
|
+
};
|
372
|
+
|
373
|
+
/**
|
374
|
+
* \brief Value iterator for the least upper bound of a bdd variable
|
375
|
+
*
|
376
|
+
* \ingroup TaskModelCpltSetVars
|
377
|
+
*/
|
378
|
+
class CpltSetVarLubValues {
|
379
|
+
private:
|
380
|
+
CpltSet::LubValues<CpltSet::CpltSetVarImp*> iter;
|
381
|
+
public:
|
382
|
+
CpltSetVarLubValues(void);
|
383
|
+
CpltSetVarLubValues(const CpltSetVar& x);
|
384
|
+
bool operator()(void) const;
|
385
|
+
void operator++(void);
|
386
|
+
int val(void) const;
|
387
|
+
};
|
388
|
+
|
389
|
+
/**
|
390
|
+
* \brief Range iterator for the unknown set of a bdd variable
|
391
|
+
*
|
392
|
+
* \ingroup TaskModelCpltSetVars
|
393
|
+
*/
|
394
|
+
class CpltSetVarUnknownRanges {
|
395
|
+
private:
|
396
|
+
Set::UnknownRanges<CpltSet::CpltSetVarImp*> iter;
|
397
|
+
public:
|
398
|
+
CpltSetVarUnknownRanges(void);
|
399
|
+
CpltSetVarUnknownRanges(const CpltSetVar& x);
|
400
|
+
bool operator()(void) const;
|
401
|
+
void operator++(void);
|
402
|
+
int min(void) const;
|
403
|
+
int max(void) const;
|
404
|
+
};
|
405
|
+
|
406
|
+
}
|
407
|
+
|
408
|
+
/**
|
409
|
+
* \brief Print bdd variable \a x
|
410
|
+
* \relates Gecode::CpltSetVar
|
411
|
+
*/
|
412
|
+
GECODE_CPLTSET_EXPORT std::ostream&
|
413
|
+
operator<<(std::ostream&, const Gecode::CpltSetVar& x);
|
414
|
+
|
415
|
+
#include "gecode/cpltset/view.icc"
|
416
|
+
|
417
|
+
namespace Gecode {
|
418
|
+
/**
|
419
|
+
* \defgroup TaskModelCpltSetArgs Argument arrays
|
420
|
+
*
|
421
|
+
* Argument arrays are just good enough for passing arguments
|
422
|
+
* with automatic memory management.
|
423
|
+
* \ingroup TaskModelCpltSet
|
424
|
+
*/
|
425
|
+
|
426
|
+
//@{
|
427
|
+
/// Passing set variables
|
428
|
+
typedef VarArgArray<CpltSetVar> CpltSetVarArgs;
|
429
|
+
//@}
|
430
|
+
|
431
|
+
/**
|
432
|
+
* \defgroup TaskModelCpltSetVarArrays Variable arrays
|
433
|
+
*
|
434
|
+
* Variable arrays can store variables. They are typically used
|
435
|
+
* for storing the variables being part of a solution. However,
|
436
|
+
* they can also be used for temporary purposes (even though
|
437
|
+
* memory is not reclaimed until the space it is created for
|
438
|
+
* is deleted).
|
439
|
+
* \ingroup TaskModelCpltSet
|
440
|
+
*/
|
441
|
+
|
442
|
+
/**
|
443
|
+
* \brief %CpltSet variable array
|
444
|
+
* \ingroup TaskModelCpltSetVarArrays
|
445
|
+
*/
|
446
|
+
class CpltSetVarArray : public VarArray<CpltSetVar> {
|
447
|
+
public:
|
448
|
+
CpltSetVarArray(void);
|
449
|
+
CpltSetVarArray(const CpltSetVarArray&);
|
450
|
+
/// Create an uninitialized array of size \a n
|
451
|
+
GECODE_CPLTSET_EXPORT CpltSetVarArray(Space* home, int n);
|
452
|
+
/**
|
453
|
+
* \brief Create an array of size \a n.
|
454
|
+
*
|
455
|
+
* Each variable is initialized with the bounds and cardinality as
|
456
|
+
* given by the arguments.
|
457
|
+
*/
|
458
|
+
GECODE_CPLTSET_EXPORT
|
459
|
+
CpltSetVarArray(Space* home,
|
460
|
+
int n,int glbMin,int glbMax,int lubMin,int lubMax,
|
461
|
+
unsigned int minCard = 0,
|
462
|
+
unsigned int maxCard = Set::Limits::card);
|
463
|
+
/**
|
464
|
+
* \brief Create an array of size \a n.
|
465
|
+
*
|
466
|
+
* Each variable is initialized with the bounds and cardinality as
|
467
|
+
* given by the arguments.
|
468
|
+
*/
|
469
|
+
GECODE_CPLTSET_EXPORT
|
470
|
+
CpltSetVarArray(Space* home,
|
471
|
+
int n,const IntSet& glb, int lubMin, int lubMax,
|
472
|
+
unsigned int minCard = 0,
|
473
|
+
unsigned int maxCard = Set::Limits::card);
|
474
|
+
/**
|
475
|
+
* \brief Create an array of size \a n.
|
476
|
+
*
|
477
|
+
* Each variable is initialized with the bounds and cardinality as
|
478
|
+
* given by the arguments.
|
479
|
+
*/
|
480
|
+
GECODE_CPLTSET_EXPORT
|
481
|
+
CpltSetVarArray(Space* home,
|
482
|
+
int n,int glbMin,int glbMax,const IntSet& lub,
|
483
|
+
unsigned int minCard = 0,
|
484
|
+
unsigned int maxCard = Set::Limits::card);
|
485
|
+
/**
|
486
|
+
* \brief Create an array of size \a n.
|
487
|
+
*
|
488
|
+
* Each variable is initialized with the bounds and cardinality as
|
489
|
+
* given by the arguments.
|
490
|
+
*/
|
491
|
+
GECODE_CPLTSET_EXPORT
|
492
|
+
CpltSetVarArray(Space* home, int n,
|
493
|
+
const IntSet& glb,const IntSet& lub,
|
494
|
+
unsigned int minCard = 0,
|
495
|
+
unsigned int maxCard = Set::Limits::card);
|
496
|
+
};
|
497
|
+
}
|
498
|
+
|
499
|
+
#include "gecode/cpltset/array.icc"
|
500
|
+
|
501
|
+
|
502
|
+
namespace Gecode {
|
503
|
+
|
504
|
+
/**
|
505
|
+
* \brief Common relation types for sets
|
506
|
+
* \ingroup TaskModelCpltSet
|
507
|
+
*/
|
508
|
+
enum CpltSetRelType {
|
509
|
+
/// Lexicographically less than on bitstring(\f$\prec_{lex}\f$)
|
510
|
+
SRT_LE,
|
511
|
+
/// Lexicographically less than on bitstring(\f$\prec_{lex}\f$)
|
512
|
+
SRT_GR,
|
513
|
+
/// Lexicographically less than or equal (\f$\preceq_{lex}\f$)
|
514
|
+
SRT_LQ,
|
515
|
+
/// Lexicographically greater than or equal (\f$\preceq_{lex}\f$)
|
516
|
+
SRT_GQ,
|
517
|
+
/// Lexicographically less than on reversed bitstring(\f$\prec_{lex}\f$)
|
518
|
+
SRT_LE_REV,
|
519
|
+
/// Lexicographically greater than on reversed bitstring (\f$\succ_{lex}\f$)
|
520
|
+
SRT_GR_REV,
|
521
|
+
/// Lexicographically reversed less than or equal (\f$\preceq_{lex}\f$)
|
522
|
+
SRT_LQ_REV,
|
523
|
+
/// Lexicographically reversed greater than or equal (\f$\preceq_{lex}\f$)
|
524
|
+
SRT_GQ_REV
|
525
|
+
};
|
526
|
+
|
527
|
+
/**
|
528
|
+
* \brief Common operations for sets
|
529
|
+
* \ingroup TaskModelCpltSet
|
530
|
+
*/
|
531
|
+
enum CpltSetOpType {
|
532
|
+
SOT_SYMDIFF, ///< Symmetric Difference
|
533
|
+
};
|
534
|
+
|
535
|
+
/**
|
536
|
+
* \defgroup TaskModelCpltSetDom Domain constraints
|
537
|
+
* \ingroup TaskModelCpltSet
|
538
|
+
*
|
539
|
+
*/
|
540
|
+
//@{
|
541
|
+
|
542
|
+
/// Propagates \f$ x \sim_r \{i\}\f$
|
543
|
+
GECODE_CPLTSET_EXPORT void
|
544
|
+
dom(Space* home, CpltSetVar x, SetRelType r, int i);
|
545
|
+
|
546
|
+
/// Propagates \f$ x \sim_r \{i,\dots,j\}\f$
|
547
|
+
GECODE_CPLTSET_EXPORT void
|
548
|
+
dom(Space* home, CpltSetVar x, SetRelType r, int i, int j);
|
549
|
+
|
550
|
+
/// Propagates \f$ x \sim_r s\f$
|
551
|
+
GECODE_CPLTSET_EXPORT void
|
552
|
+
dom(Space* home, CpltSetVar x, SetRelType r, const IntSet& s);
|
553
|
+
|
554
|
+
/// Post propagator for \f$ l \leq |x| \leq u \f$
|
555
|
+
GECODE_CPLTSET_EXPORT void
|
556
|
+
cardinality(Space* home, CpltSetVar x, unsigned int l, unsigned int u);
|
557
|
+
|
558
|
+
/// Post propagator for \f$ l |x| = c \f$
|
559
|
+
GECODE_CPLTSET_EXPORT void
|
560
|
+
cardinality(Space* home, CpltSetVar x, unsigned int c);
|
561
|
+
|
562
|
+
//@}
|
563
|
+
|
564
|
+
/**
|
565
|
+
* \defgroup TaskModelCpltSetRel Relation constraints
|
566
|
+
* \ingroup TaskModelCpltSet
|
567
|
+
*
|
568
|
+
*/
|
569
|
+
|
570
|
+
//@{
|
571
|
+
|
572
|
+
/// Post propagator for \f$ x \sim_r y\f$
|
573
|
+
GECODE_CPLTSET_EXPORT void
|
574
|
+
rel(Space* home, CpltSetVar x, CpltSetRelType r, CpltSetVar y);
|
575
|
+
|
576
|
+
/// Post propagator for \f$ x \sim_r y\f$
|
577
|
+
GECODE_CPLTSET_EXPORT void
|
578
|
+
rel(Space* home, CpltSetVar x, SetRelType r, CpltSetVar y);
|
579
|
+
|
580
|
+
//@}
|
581
|
+
|
582
|
+
/**
|
583
|
+
* \defgroup TaskModelCpltSetRelOp CpltSet operation/relation constraints
|
584
|
+
* \ingroup TaskModelCpltSet
|
585
|
+
*
|
586
|
+
*/
|
587
|
+
|
588
|
+
//@{
|
589
|
+
|
590
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{o}} y) \sim_r z \f$
|
591
|
+
GECODE_CPLTSET_EXPORT void
|
592
|
+
rel(Space* home, CpltSetVar x, CpltSetOpType o, CpltSetVar y,
|
593
|
+
CpltSetRelType r, CpltSetVar z);
|
594
|
+
|
595
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{o}} y) \sim_r z \f$
|
596
|
+
GECODE_CPLTSET_EXPORT void
|
597
|
+
rel(Space* home, CpltSetVar x, CpltSetOpType o, CpltSetVar y,
|
598
|
+
SetRelType r, CpltSetVar z);
|
599
|
+
|
600
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{o}} y) \sim_r z \f$
|
601
|
+
GECODE_CPLTSET_EXPORT void
|
602
|
+
rel(Space* home, CpltSetVar x, SetOpType o, CpltSetVar y,
|
603
|
+
CpltSetRelType r, CpltSetVar z);
|
604
|
+
|
605
|
+
/// Post propagator for \f$ (x \diamond_{\mathit{o}} y) \sim_r z \f$
|
606
|
+
GECODE_CPLTSET_EXPORT void
|
607
|
+
rel(Space* home, CpltSetVar x, SetOpType o, CpltSetVar y,
|
608
|
+
SetRelType r, CpltSetVar z);
|
609
|
+
|
610
|
+
//@}
|
611
|
+
|
612
|
+
/**
|
613
|
+
* \defgroup TaskModelCpltSetConnect Connection constraints to finite domain variables
|
614
|
+
* \ingroup TaskModelCpltSet
|
615
|
+
*
|
616
|
+
*/
|
617
|
+
|
618
|
+
//@{
|
619
|
+
|
620
|
+
/// Post propagator for \f$ s = \{x\} \f$
|
621
|
+
GECODE_CPLTSET_EXPORT void
|
622
|
+
singleton(Space* home, IntVar x, CpltSetVar s);
|
623
|
+
|
624
|
+
//@}
|
625
|
+
|
626
|
+
/**
|
627
|
+
* \defgroup TaskModelCpltSetInter Intersection and partition constraints
|
628
|
+
* \ingroup TaskModelCpltSet
|
629
|
+
*
|
630
|
+
*/
|
631
|
+
|
632
|
+
//@{
|
633
|
+
|
634
|
+
/// Post propagator for \f$ |x \cap is| = c \f$
|
635
|
+
GECODE_CPLTSET_EXPORT void
|
636
|
+
exactly(Space* home, CpltSetVar x, IntSet& is, unsigned int c);
|
637
|
+
|
638
|
+
/// Post propagator for \f$ 0 \leq |x \cap is| \leq c \f$
|
639
|
+
GECODE_CPLTSET_EXPORT void
|
640
|
+
atmost(Space* home, CpltSetVar x, IntSet& is, unsigned int c);
|
641
|
+
|
642
|
+
/// Post propagator for \f$ 0 \leq |x \cap y| \leq c \f$
|
643
|
+
GECODE_CPLTSET_EXPORT void
|
644
|
+
atmost(Space* home, CpltSetVar x, CpltSetVar y, unsigned int c);
|
645
|
+
|
646
|
+
/// Post propagator for \f$ 0 \leq |x \cap y| \leq c \wedge x \sim_{lex} y\f$
|
647
|
+
GECODE_CPLTSET_EXPORT void
|
648
|
+
atmostLex(Space* home, CpltSetVar x, CpltSetVar y, unsigned int c,
|
649
|
+
CpltSetRelType lex);
|
650
|
+
|
651
|
+
/**
|
652
|
+
* \brief Post propagator for \f$ 0 \leq |x \cap y| \leq c
|
653
|
+
* \wedge x \sim_{lex} y \wedge |x| = |y| = d\f$
|
654
|
+
*/
|
655
|
+
GECODE_CPLTSET_EXPORT void
|
656
|
+
atmostLexCard(Space* home, CpltSetVar x, CpltSetVar y, int c,
|
657
|
+
CpltSetRelType lex, int d);
|
658
|
+
|
659
|
+
/// Post propagator for \f$ 0 \leq |x \cap y| \leq c \wedge |x| = |y| = d\f$
|
660
|
+
GECODE_CPLTSET_EXPORT void
|
661
|
+
atmostCard(Space* home, CpltSetVar x, CpltSetVar y, int c, int d);
|
662
|
+
|
663
|
+
/// Post propagator for \f$ x \cap y = z \wedge 0 \leq |z| \leq c \f$
|
664
|
+
GECODE_CPLTSET_EXPORT void
|
665
|
+
atmost(Space* home, CpltSetVar x, CpltSetVar y, CpltSetVar z, int c);
|
666
|
+
|
667
|
+
/** \brief Post propagator for \f$ |x_i \cap x_j| \leq 1 \f$ for all \f$0\leq i\neq j<|x|
|
668
|
+
* \wedge \forall i \in \{0, \dots, |x|-1\}: |x_i| = c \f$
|
669
|
+
* \note The bdd for this constraint becomes exponential with increasing universe
|
670
|
+
* and increasing |x|
|
671
|
+
*/
|
672
|
+
GECODE_CPLTSET_EXPORT void
|
673
|
+
atmostOne(Space* home, const CpltSetVarArgs& x, int c);
|
674
|
+
|
675
|
+
/// Post propagator for \f$ |\bigcup_{i=0}^{n-1} x_i = U \f$
|
676
|
+
GECODE_CPLTSET_EXPORT void
|
677
|
+
partition(Space* home, const CpltSetVarArgs& x);
|
678
|
+
|
679
|
+
/// Post propagator for \f$ |\bigcup_{i=0}^{n-1} x_i = U \f$
|
680
|
+
GECODE_CPLTSET_EXPORT void
|
681
|
+
partition(Space* home, const CpltSetVarArgs& x, const CpltSetVar& y);
|
682
|
+
|
683
|
+
/**
|
684
|
+
* \brief Post propagator for \f$ |\bigcup_{i=0}^{n-1} x_i = U \wedge
|
685
|
+
* \forall i,j\in \{0, \dots, n-1\}, i\neq j:
|
686
|
+
* x_i \sim_{lex} x_j\f$
|
687
|
+
*
|
688
|
+
*/
|
689
|
+
GECODE_CPLTSET_EXPORT void
|
690
|
+
partitionLex(Space* home, const CpltSetVarArgs& x, CpltSetRelType lex);
|
691
|
+
/**
|
692
|
+
* \brief Post propagator for \f$ |\bigcup_{i=0}^{n-1} x_i = U \wedge
|
693
|
+
* \forall i,j\in \{0, \dots, n-1\}, i\neq j:
|
694
|
+
* x_i \sim_{lex} x_j \wedge
|
695
|
+
* \forall i \in \{0, \dots, n-1\}: |x_i| = c \f$
|
696
|
+
*/
|
697
|
+
GECODE_CPLTSET_EXPORT void
|
698
|
+
partitionLexCard(Space* home, const CpltSetVarArgs& x, CpltSetRelType lex,
|
699
|
+
unsigned int c);
|
700
|
+
|
701
|
+
/**
|
702
|
+
* \brief Post propagator for \f$ |\bigcup_{i=0}^{n-1} x_i = U \wedge
|
703
|
+
* \forall i \in \{0, \dots, n-1\}: |x_i| = c \f$
|
704
|
+
*/
|
705
|
+
GECODE_CPLTSET_EXPORT void
|
706
|
+
partitionCard(Space* home, const CpltSetVarArgs& x, unsigned int c);
|
707
|
+
|
708
|
+
//@}
|
709
|
+
|
710
|
+
/**
|
711
|
+
* \defgroup TaskModelCpltSetSelect Selection constraints
|
712
|
+
* \ingroup TaskModelCpltSet
|
713
|
+
*
|
714
|
+
*/
|
715
|
+
|
716
|
+
//@{
|
717
|
+
|
718
|
+
/// Post propagator for \f$ t = \bigcup_{i\in s} x_i \f$
|
719
|
+
GECODE_CPLTSET_EXPORT void
|
720
|
+
selectUnion(Space* home, const CpltSetVarArgs& x, CpltSetVar s,
|
721
|
+
CpltSetVar t);
|
722
|
+
|
723
|
+
/// Post propagator for \f$ s = \bigcup_{(x_i \subseteq t) \wedge x_i \neq \emptyset } i \f$
|
724
|
+
GECODE_CPLTSET_EXPORT void
|
725
|
+
selectNonEmptySub(Space* home, const CpltSetVarArgs& x,
|
726
|
+
CpltSetVar s, CpltSetVar t);
|
727
|
+
|
728
|
+
/// Post propagator for \f$ t = \bigcup_{i\subseteq s} x_i \f$
|
729
|
+
GECODE_CPLTSET_EXPORT void
|
730
|
+
range(Space* home, const CpltSetVarArgs& x, CpltSetVar s, CpltSetVar t);
|
731
|
+
|
732
|
+
/// Post propagator for \f$ s = \bigcup_{x_i \subseteq t} i \f$
|
733
|
+
GECODE_CPLTSET_EXPORT void
|
734
|
+
roots(Space* home, const CpltSetVarArgs& x, CpltSetVar s, CpltSetVar t,
|
735
|
+
const CpltSetVarArgs& allvars);
|
736
|
+
|
737
|
+
/** \brief Post propagator for \f$ x_i\neq x_j\f$ for all \f$0\leq i\neq j<|x|
|
738
|
+
* \wedge t = \bigcup_{i\subseteq s} x_i \f$
|
739
|
+
*/
|
740
|
+
GECODE_CPLTSET_EXPORT void
|
741
|
+
alldifferent(Space* home, const CpltSetVarArgs& x, CpltSetVar s,
|
742
|
+
CpltSetVar t, const CpltSetVarArgs& allvars);
|
743
|
+
|
744
|
+
/** \brief Post propagator for \f$ |\displaystyle\bigcup_{i = 0}^{|x| - 1} x_i| = n
|
745
|
+
* \wedge t = \bigcup_{i\subseteq s} x_i \f$
|
746
|
+
*
|
747
|
+
*/
|
748
|
+
GECODE_CPLTSET_EXPORT void
|
749
|
+
nvalue(Space* home, const CpltSetVarArgs& x, CpltSetVar s, CpltSetVar t,
|
750
|
+
unsigned int n, const CpltSetVarArgs& allvars);
|
751
|
+
|
752
|
+
/** \brief Post propagator for \f$ t = \bigcup_{i\in s} x_i \wedge v = \bigcup_{i\in u} y_i
|
753
|
+
* \wedge v \subseteq t \f$
|
754
|
+
*
|
755
|
+
* |x| and |y| may be different
|
756
|
+
*/
|
757
|
+
GECODE_CPLTSET_EXPORT void
|
758
|
+
uses(Space* home, const IntVarArgs& x, CpltSetVar s, CpltSetVar t,
|
759
|
+
const CpltSetVarArgs& y, CpltSetVar u, CpltSetVar v);
|
760
|
+
//@}
|
761
|
+
|
762
|
+
|
763
|
+
/**
|
764
|
+
* \defgroup TaskModelCpltSetBranch Branching
|
765
|
+
* \ingroup TaskModelCpltSet
|
766
|
+
*/
|
767
|
+
//@{
|
768
|
+
|
769
|
+
/// Which variable to select for branching
|
770
|
+
enum CpltSetVarBranch {
|
771
|
+
CPLTSET_VAR_NONE, ///< First unassigned
|
772
|
+
CPLTSET_VAR_MIN_CARD, ///< With smallest unknown set
|
773
|
+
CPLTSET_VAR_MAX_CARD, ///< With largest unknown set
|
774
|
+
CPLTSET_VAR_MIN_UNKNOWN_ELEM, ///< With smallest unknown element
|
775
|
+
CPLTSET_VAR_MAX_UNKNOWN_ELEM ///< With largest unknown element
|
776
|
+
};
|
777
|
+
|
778
|
+
/// Which values to select first for branching
|
779
|
+
enum CpltSetValBranch {
|
780
|
+
CPLTSET_VAL_MIN_UNKNOWN, ///< Select smallest element in unknown set and try to include it
|
781
|
+
CPLTSET_VAL_MAX_UNKNOWN, ///< Select largest element in unknown set and try to include it
|
782
|
+
CPLTSET_VAL_MIN_UNKNOWN_EX_FIRST, ///< Select smallest element in unknown set and try to exclude it
|
783
|
+
CPLTSET_VAL_MAX_UNKNOWN_EX_FIRST ///< Select largest element in unknown set and try to exclude it
|
784
|
+
};
|
785
|
+
|
786
|
+
/// Branch on \a x with variable selection \a vars and value selection \a vals
|
787
|
+
GECODE_CPLTSET_EXPORT void
|
788
|
+
branch(Space* home, const CpltSetVarArgs& x,
|
789
|
+
CpltSetVarBranch vars, CpltSetValBranch vals);
|
790
|
+
//@}
|
791
|
+
|
792
|
+
}
|
793
|
+
|
794
|
+
#endif
|
795
|
+
|
796
|
+
// IFDEF: GECODE_HAS_CPLTSET_VARS
|
797
|
+
// STATISTICS: set-post
|