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,1206 @@
|
|
1
|
+
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
+
/*
|
3
|
+
* Main authors:
|
4
|
+
* Christian Schulte <schulte@gecode.org>
|
5
|
+
* Guido Tack <tack@gecode.org>
|
6
|
+
* Mikael Lagerkvist <lagerkvist@gecode.org>
|
7
|
+
*
|
8
|
+
* Copyright:
|
9
|
+
* Christian Schulte, 2004
|
10
|
+
* Guido Tack, 2004
|
11
|
+
* Mikael Lagerkvist, 2005
|
12
|
+
*
|
13
|
+
* Last modified:
|
14
|
+
* $Date: 2008-07-11 10:54:36 +0200 (Fri, 11 Jul 2008) $ by $Author: tack $
|
15
|
+
* $Revision: 7354 $
|
16
|
+
*
|
17
|
+
* This file is part of Gecode, the generic constraint
|
18
|
+
* development environment:
|
19
|
+
* http://www.gecode.org
|
20
|
+
*
|
21
|
+
* Permission is hereby granted, free of charge, to any person obtaining
|
22
|
+
* a copy of this software and associated documentation files (the
|
23
|
+
* "Software"), to deal in the Software without restriction, including
|
24
|
+
* without limitation the rights to use, copy, modify, merge, publish,
|
25
|
+
* distribute, sublicense, and/or sell copies of the Software, and to
|
26
|
+
* permit persons to whom the Software is furnished to do so, subject to
|
27
|
+
* the following conditions:
|
28
|
+
*
|
29
|
+
* The above copyright notice and this permission notice shall be
|
30
|
+
* included in all copies or substantial portions of the Software.
|
31
|
+
*
|
32
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
33
|
+
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
34
|
+
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
35
|
+
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
36
|
+
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
37
|
+
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
38
|
+
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
39
|
+
*
|
40
|
+
*/
|
41
|
+
|
42
|
+
#ifndef __GECODE_MINIMODEL_HH__
|
43
|
+
#define __GECODE_MINIMODEL_HH__
|
44
|
+
|
45
|
+
#include "gecode/kernel.hh"
|
46
|
+
#include "gecode/int.hh"
|
47
|
+
#include "gecode/int/linear.hh"
|
48
|
+
|
49
|
+
#include "gecode/minimodel/exception.icc"
|
50
|
+
|
51
|
+
#include <iostream>
|
52
|
+
|
53
|
+
/*
|
54
|
+
* Support for DLLs under Windows
|
55
|
+
*
|
56
|
+
*/
|
57
|
+
|
58
|
+
#if !defined(GECODE_STATIC_LIBS) && \
|
59
|
+
(defined(__CYGWIN__) || defined(__MINGW32__) || defined(_MSC_VER))
|
60
|
+
|
61
|
+
#ifdef GECODE_BUILD_MINIMODEL
|
62
|
+
#define GECODE_MINIMODEL_EXPORT __declspec( dllexport )
|
63
|
+
#else
|
64
|
+
#define GECODE_MINIMODEL_EXPORT __declspec( dllimport )
|
65
|
+
#endif
|
66
|
+
|
67
|
+
#else
|
68
|
+
|
69
|
+
#ifdef GECODE_GCC_HAS_CLASS_VISIBILITY
|
70
|
+
|
71
|
+
#define GECODE_MINIMODEL_EXPORT __attribute__ ((visibility("default")))
|
72
|
+
|
73
|
+
#else
|
74
|
+
|
75
|
+
#define GECODE_MINIMODEL_EXPORT
|
76
|
+
|
77
|
+
#endif
|
78
|
+
#endif
|
79
|
+
|
80
|
+
namespace Gecode {
|
81
|
+
|
82
|
+
/// Minimal modelling support
|
83
|
+
namespace MiniModel {
|
84
|
+
|
85
|
+
/// Linear expressions
|
86
|
+
template <class Var>
|
87
|
+
class LinExpr {
|
88
|
+
public:
|
89
|
+
/// Type of linear expression
|
90
|
+
enum NodeType {
|
91
|
+
NT_VAR, ///< Linear term with variable
|
92
|
+
NT_ADD, ///< Addition of linear terms
|
93
|
+
NT_SUB, ///< Subtraction of linear terms
|
94
|
+
NT_MUL ///< Multiplication by coefficient
|
95
|
+
};
|
96
|
+
private:
|
97
|
+
typedef typename VarViewTraits<Var>::View View;
|
98
|
+
/// Nodes for linear expressions
|
99
|
+
class Node {
|
100
|
+
public:
|
101
|
+
/// Nodes are reference counted
|
102
|
+
unsigned int use;
|
103
|
+
/// Variables in tree
|
104
|
+
unsigned int n;
|
105
|
+
/// Type of expression
|
106
|
+
NodeType t;
|
107
|
+
/// Subexpressions
|
108
|
+
Node *l, *r;
|
109
|
+
/// Coefficient and offset
|
110
|
+
int a, c;
|
111
|
+
/// Variable (potentially)
|
112
|
+
Var x;
|
113
|
+
/// Default constructor
|
114
|
+
Node(void);
|
115
|
+
/// Generate linear terms from expression
|
116
|
+
int fill(Int::Linear::Term<View> t[], int i, int m,
|
117
|
+
int c_i, int& c_o) const;
|
118
|
+
/// Decrement reference count and possibly free memory
|
119
|
+
bool decrement(void);
|
120
|
+
/// Memory management
|
121
|
+
static void* operator new(size_t size);
|
122
|
+
/// Memory management
|
123
|
+
static void operator delete(void* p,size_t size);
|
124
|
+
};
|
125
|
+
Node* n;
|
126
|
+
public:
|
127
|
+
/// Default constructor
|
128
|
+
LinExpr(void);
|
129
|
+
/// Create expression
|
130
|
+
LinExpr(const Var& x, int a=1);
|
131
|
+
/// Copy constructor
|
132
|
+
LinExpr(const LinExpr& e);
|
133
|
+
/// Create expression for type and subexpressions
|
134
|
+
LinExpr(const LinExpr& e0, NodeType t, const LinExpr& e1);
|
135
|
+
/// Create expression for type and subexpression
|
136
|
+
LinExpr(const LinExpr& e0, NodeType t, int c);
|
137
|
+
/// Create expression for multiplication
|
138
|
+
LinExpr(int a, const LinExpr& e);
|
139
|
+
/// Assignment operator
|
140
|
+
const LinExpr& operator=(const LinExpr& e);
|
141
|
+
/// Post propagator
|
142
|
+
void post(Space* home, IntRelType irt,
|
143
|
+
IntConLevel icl, PropKind pk) const;
|
144
|
+
/// Post reified propagator
|
145
|
+
void post(Space* home, IntRelType irt, const BoolVar& b,
|
146
|
+
IntConLevel icl, PropKind pk) const;
|
147
|
+
/// Post propagator and return variable for value
|
148
|
+
IntVar post(Space* home,
|
149
|
+
IntConLevel icl, PropKind pk) const;
|
150
|
+
/// Destructor
|
151
|
+
~LinExpr(void);
|
152
|
+
};
|
153
|
+
|
154
|
+
/// Linear relations
|
155
|
+
template<class Var>
|
156
|
+
class LinRel {
|
157
|
+
private:
|
158
|
+
/// Linear expression describing the entire relation
|
159
|
+
LinExpr<Var> e;
|
160
|
+
/// Which relation
|
161
|
+
IntRelType irt;
|
162
|
+
/// Negate relation type
|
163
|
+
static IntRelType neg(IntRelType irt);
|
164
|
+
public:
|
165
|
+
/// Default constructor
|
166
|
+
LinRel(void);
|
167
|
+
/// Create linear relation for expressions \a l and \a r
|
168
|
+
LinRel(const LinExpr<Var>& l, IntRelType irt, const LinExpr<Var>& r);
|
169
|
+
/// Create linear relation for expression \a l and integer \a r
|
170
|
+
LinRel(const LinExpr<Var>& l, IntRelType irt, int r);
|
171
|
+
/// Create linear relation for integer \a l and expression \a r
|
172
|
+
LinRel(int l, IntRelType irt, const LinExpr<Var>& r);
|
173
|
+
/// Post propagator for relation (if \a t is false for negated relation)
|
174
|
+
void post(Space* home, bool t,
|
175
|
+
IntConLevel icl, PropKind pk) const;
|
176
|
+
/// Post reified propagator for relation
|
177
|
+
void post(Space* home, const BoolVar& b,
|
178
|
+
IntConLevel icl, PropKind pk) const;
|
179
|
+
};
|
180
|
+
|
181
|
+
}
|
182
|
+
|
183
|
+
}
|
184
|
+
|
185
|
+
/**
|
186
|
+
* \defgroup TaskModelMiniModelLin Linear expressions and relations
|
187
|
+
*
|
188
|
+
* Linear expressions can be freely composed of sums and differences of
|
189
|
+
* integer variables (Gecode::IntVar) or Boolean variables (Gecode::BoolVar)
|
190
|
+
* possibly with integer coefficients and integer constants.
|
191
|
+
*
|
192
|
+
* Note that both integer and Boolean variables are automatically available
|
193
|
+
* as linear expressions.
|
194
|
+
*
|
195
|
+
* Linear relations are obtained from linear expressions with the normal
|
196
|
+
* relation operators.
|
197
|
+
*
|
198
|
+
* \ingroup TaskModelMiniModel
|
199
|
+
*/
|
200
|
+
|
201
|
+
//@{
|
202
|
+
|
203
|
+
/// Construct linear expression as sum of linear expression and integer
|
204
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
205
|
+
operator+(int,
|
206
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>&);
|
207
|
+
/// Construct linear expression as sum of integer and linear expression
|
208
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
209
|
+
operator+(const Gecode::MiniModel::LinExpr<Gecode::IntVar>&,
|
210
|
+
int);
|
211
|
+
/// Construct linear expression as sum of linear expressions
|
212
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
213
|
+
operator+(const Gecode::MiniModel::LinExpr<Gecode::IntVar>&,
|
214
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>&);
|
215
|
+
/// Construct linear expression as difference of linear expression and integer
|
216
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
217
|
+
operator-(int,
|
218
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>&);
|
219
|
+
/// Construct linear expression as difference of integer and linear expression
|
220
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
221
|
+
operator-(const Gecode::MiniModel::LinExpr<Gecode::IntVar>&,
|
222
|
+
int);
|
223
|
+
/// Construct linear expression as difference of linear expressions
|
224
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
225
|
+
operator-(const Gecode::MiniModel::LinExpr<Gecode::IntVar>&,
|
226
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>&);
|
227
|
+
/// Construct linear expression as negative of linear expression
|
228
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
229
|
+
operator-(const Gecode::MiniModel::LinExpr<Gecode::IntVar>&);
|
230
|
+
|
231
|
+
/// Construct linear expression as product of integer coefficient and integer variable
|
232
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
233
|
+
operator*(int, const Gecode::IntVar&);
|
234
|
+
/// Construct linear expression as product of integer coefficient and integer variable
|
235
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
236
|
+
operator*(const Gecode::IntVar&, int);
|
237
|
+
/// Construct linear expression as product of integer coefficient and linear expression
|
238
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
239
|
+
operator*(const Gecode::MiniModel::LinExpr<Gecode::IntVar>&, int);
|
240
|
+
/// Construct linear expression as product of integer coefficient and linear expression
|
241
|
+
Gecode::MiniModel::LinExpr<Gecode::IntVar>
|
242
|
+
operator*(int, const Gecode::MiniModel::LinExpr<Gecode::IntVar>&);
|
243
|
+
|
244
|
+
|
245
|
+
/// Construct linear expression as sum of linear expression and integer
|
246
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
247
|
+
operator+(int,
|
248
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&);
|
249
|
+
/// Construct linear expression as sum of integer and linear expression
|
250
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
251
|
+
operator+(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&,
|
252
|
+
int);
|
253
|
+
/// Construct linear expression as sum of linear expressions
|
254
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
255
|
+
operator+(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&,
|
256
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&);
|
257
|
+
/// Construct linear expression as difference of linear expression and integer
|
258
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
259
|
+
operator-(int,
|
260
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&);
|
261
|
+
/// Construct linear expression as difference of integer and linear expression
|
262
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
263
|
+
operator-(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&,
|
264
|
+
int);
|
265
|
+
/// Construct linear expression as difference of linear expressions
|
266
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
267
|
+
operator-(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&,
|
268
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&);
|
269
|
+
/// Construct linear expression as negative of linear expression
|
270
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
271
|
+
operator-(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&);
|
272
|
+
|
273
|
+
/// Construct linear expression as product of integer coefficient and integer variable
|
274
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
275
|
+
operator*(int, const Gecode::BoolVar&);
|
276
|
+
/// Construct linear expression as product of integer coefficient and integer variable
|
277
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
278
|
+
operator*(const Gecode::BoolVar&, int);
|
279
|
+
/// Construct linear expression as product of integer coefficient and linear expression
|
280
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
281
|
+
operator*(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&, int);
|
282
|
+
/// Construct linear expression as product of integer coefficient and linear expression
|
283
|
+
Gecode::MiniModel::LinExpr<Gecode::BoolVar>
|
284
|
+
operator*(int, const Gecode::MiniModel::LinExpr<Gecode::BoolVar>&);
|
285
|
+
|
286
|
+
|
287
|
+
/// Construct linear equality relation
|
288
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
289
|
+
operator==(int l,
|
290
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
291
|
+
/// Construct linear equality relation
|
292
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
293
|
+
operator==(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
294
|
+
int r);
|
295
|
+
/// Construct linear equality relation
|
296
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
297
|
+
operator==(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
298
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
299
|
+
|
300
|
+
/// Construct linear disequality relation
|
301
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
302
|
+
operator!=(int l,
|
303
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
304
|
+
/// Construct linear disequality relation
|
305
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
306
|
+
operator!=(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
307
|
+
int r);
|
308
|
+
/// Construct linear disequality relation
|
309
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
310
|
+
operator!=(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
311
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
312
|
+
|
313
|
+
/// Construct linear inequality relation
|
314
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
315
|
+
operator<(int l,
|
316
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
317
|
+
/// Construct linear inequality relation
|
318
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
319
|
+
operator<(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
320
|
+
int r);
|
321
|
+
/// Construct linear inequality relation
|
322
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
323
|
+
operator<(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
324
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
325
|
+
|
326
|
+
/// Construct linear inequality relation
|
327
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
328
|
+
operator<=(int l,
|
329
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
330
|
+
/// Construct linear inequality relation
|
331
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
332
|
+
operator<=(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
333
|
+
int r);
|
334
|
+
/// Construct linear inequality relation
|
335
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
336
|
+
operator<=(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
337
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
338
|
+
|
339
|
+
/// Construct linear inequality relation
|
340
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
341
|
+
operator>(int l,
|
342
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
343
|
+
/// Construct linear inequality relation
|
344
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
345
|
+
operator>(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
346
|
+
int r);
|
347
|
+
/// Construct linear inequality relation
|
348
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
349
|
+
operator>(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
350
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
351
|
+
|
352
|
+
/// Construct linear inequality relation
|
353
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
354
|
+
operator>=(int l,
|
355
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
356
|
+
/// Construct linear inequality relation
|
357
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
358
|
+
operator>=(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
359
|
+
int r);
|
360
|
+
/// Construct linear inequality relation
|
361
|
+
Gecode::MiniModel::LinRel<Gecode::IntVar>
|
362
|
+
operator>=(const Gecode::MiniModel::LinExpr<Gecode::IntVar>& l,
|
363
|
+
const Gecode::MiniModel::LinExpr<Gecode::IntVar>& r);
|
364
|
+
|
365
|
+
|
366
|
+
/// Construct linear equality relation
|
367
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
368
|
+
operator==(int l,
|
369
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
370
|
+
/// Construct linear equality relation
|
371
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
372
|
+
operator==(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
373
|
+
int r);
|
374
|
+
/// Construct linear equality relation
|
375
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
376
|
+
operator==(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
377
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
378
|
+
|
379
|
+
/// Construct linear disequality relation
|
380
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
381
|
+
operator!=(int l,
|
382
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
383
|
+
/// Construct linear disequality relation
|
384
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
385
|
+
operator!=(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
386
|
+
int r);
|
387
|
+
/// Construct linear disequality relation
|
388
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
389
|
+
operator!=(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
390
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
391
|
+
|
392
|
+
/// Construct linear inequality relation
|
393
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
394
|
+
operator<(int l,
|
395
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
396
|
+
/// Construct linear inequality relation
|
397
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
398
|
+
operator<(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
399
|
+
int r);
|
400
|
+
/// Construct linear inequality relation
|
401
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
402
|
+
operator<(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
403
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
404
|
+
|
405
|
+
/// Construct linear inequality relation
|
406
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
407
|
+
operator<=(int l,
|
408
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
409
|
+
/// Construct linear inequality relation
|
410
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
411
|
+
operator<=(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
412
|
+
int r);
|
413
|
+
/// Construct linear inequality relation
|
414
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
415
|
+
operator<=(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
416
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
417
|
+
|
418
|
+
/// Construct linear inequality relation
|
419
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
420
|
+
operator>(int l,
|
421
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
422
|
+
/// Construct linear inequality relation
|
423
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
424
|
+
operator>(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
425
|
+
int r);
|
426
|
+
/// Construct linear inequality relation
|
427
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
428
|
+
operator>(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
429
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
430
|
+
|
431
|
+
/// Construct linear inequality relation
|
432
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
433
|
+
operator>=(int l,
|
434
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
435
|
+
/// Construct linear inequality relation
|
436
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
437
|
+
operator>=(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
438
|
+
int r);
|
439
|
+
/// Construct linear inequality relation
|
440
|
+
Gecode::MiniModel::LinRel<Gecode::BoolVar>
|
441
|
+
operator>=(const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& l,
|
442
|
+
const Gecode::MiniModel::LinExpr<Gecode::BoolVar>& r);
|
443
|
+
|
444
|
+
//@}
|
445
|
+
|
446
|
+
namespace Gecode {
|
447
|
+
|
448
|
+
namespace MiniModel {
|
449
|
+
|
450
|
+
/// Boolean expressions
|
451
|
+
class BoolExpr {
|
452
|
+
public:
|
453
|
+
/// Type of Boolean expression
|
454
|
+
enum NodeType {
|
455
|
+
NT_VAR, ///< Variable
|
456
|
+
NT_NOT, ///< Negation
|
457
|
+
NT_AND, ///< Conjunction
|
458
|
+
NT_OR, ///< Disjunction
|
459
|
+
NT_IMP, ///< Implication
|
460
|
+
NT_XOR, ///< Exclusive or
|
461
|
+
NT_EQV, ///< Equivalence
|
462
|
+
NT_RLIN_INT, ///< Reified linear relation (integer variables)
|
463
|
+
NT_RLIN_BOOL ///< Reified linear relation (Boolean variables)
|
464
|
+
};
|
465
|
+
/// Node for Boolean expression
|
466
|
+
class Node {
|
467
|
+
public:
|
468
|
+
/// Nodes are reference counted
|
469
|
+
unsigned int use;
|
470
|
+
/// Number of variables in subtree with same type (for AND and OR)
|
471
|
+
unsigned int same;
|
472
|
+
/// Type of expression
|
473
|
+
NodeType t;
|
474
|
+
/// Subexpressions
|
475
|
+
Node *l, *r;
|
476
|
+
/// Possibly a variable
|
477
|
+
BoolVar x;
|
478
|
+
/// Possibly a reified linear relation over integer variables
|
479
|
+
LinRel<IntVar> rl_int;
|
480
|
+
/// Possibly a reified linear relation over Boolean variables
|
481
|
+
LinRel<BoolVar> rl_bool;
|
482
|
+
|
483
|
+
/// Default constructor
|
484
|
+
Node(void);
|
485
|
+
/// Decrement reference count and possibly free memory
|
486
|
+
GECODE_MINIMODEL_EXPORT
|
487
|
+
bool decrement(void);
|
488
|
+
/// Post propagators for nested conjunctive and disjunctive expression
|
489
|
+
GECODE_MINIMODEL_EXPORT
|
490
|
+
int post(Space* home, NodeType t, BoolVarArgs& b, int i,
|
491
|
+
IntConLevel icl, PropKind pk) const;
|
492
|
+
/// Post propagators for expression
|
493
|
+
GECODE_MINIMODEL_EXPORT
|
494
|
+
void post(Space* home, BoolVar b,
|
495
|
+
IntConLevel icl, PropKind pk) const;
|
496
|
+
/// Post propagators for expression
|
497
|
+
GECODE_MINIMODEL_EXPORT
|
498
|
+
BoolVar post(Space* home,
|
499
|
+
IntConLevel icl, PropKind pk) const;
|
500
|
+
/// Post propagators for relation
|
501
|
+
GECODE_MINIMODEL_EXPORT
|
502
|
+
void post(Space* home, bool t,
|
503
|
+
IntConLevel icl, PropKind pk) const;
|
504
|
+
|
505
|
+
/// Memory management
|
506
|
+
static void* operator new(size_t size);
|
507
|
+
/// Memory management
|
508
|
+
static void operator delete(void* p,size_t size);
|
509
|
+
};
|
510
|
+
private:
|
511
|
+
/// Pointer to node for expression
|
512
|
+
Node* n;
|
513
|
+
public:
|
514
|
+
/// Copy constructor
|
515
|
+
BoolExpr(const BoolExpr& e);
|
516
|
+
/// Construct expression for type and subexpresssions
|
517
|
+
GECODE_MINIMODEL_EXPORT
|
518
|
+
BoolExpr(const BoolExpr& l, NodeType t, const BoolExpr& r);
|
519
|
+
/// Construct expression for variable
|
520
|
+
GECODE_MINIMODEL_EXPORT
|
521
|
+
BoolExpr(const BoolVar& x);
|
522
|
+
/// Construct expression for negation
|
523
|
+
GECODE_MINIMODEL_EXPORT
|
524
|
+
BoolExpr(const BoolExpr& e, NodeType t);
|
525
|
+
/// Construct expression for reified linear relation
|
526
|
+
GECODE_MINIMODEL_EXPORT
|
527
|
+
BoolExpr(const LinRel<IntVar>& rl);
|
528
|
+
/// Construct expression for reified linear relation
|
529
|
+
GECODE_MINIMODEL_EXPORT
|
530
|
+
BoolExpr(const LinRel<BoolVar>& rl);
|
531
|
+
/// Post propagators for expression
|
532
|
+
BoolVar post(Space* home, IntConLevel icl, PropKind pk) const;
|
533
|
+
/// Post propagators for relation
|
534
|
+
void post(Space* home, bool t, IntConLevel icl, PropKind pk) const;
|
535
|
+
|
536
|
+
/// Assignment operator
|
537
|
+
GECODE_MINIMODEL_EXPORT
|
538
|
+
const BoolExpr& operator=(const BoolExpr& e);
|
539
|
+
/// Destructor
|
540
|
+
GECODE_MINIMODEL_EXPORT
|
541
|
+
~BoolExpr(void);
|
542
|
+
};
|
543
|
+
|
544
|
+
/// Boolean relations
|
545
|
+
class BoolRel {
|
546
|
+
private:
|
547
|
+
/// Expression
|
548
|
+
BoolExpr e;
|
549
|
+
/// Whether expression is true or false
|
550
|
+
bool t;
|
551
|
+
public:
|
552
|
+
/// Constructor
|
553
|
+
BoolRel(const BoolExpr& e, bool t);
|
554
|
+
/// Post propagators for relation
|
555
|
+
void post(Space* home, IntConLevel icl, PropKind pk) const;
|
556
|
+
};
|
557
|
+
}
|
558
|
+
|
559
|
+
}
|
560
|
+
|
561
|
+
/**
|
562
|
+
* \defgroup TaskModelMiniModelBool Boolean expressions and relations
|
563
|
+
*
|
564
|
+
* Boolean expressions can be freely composed of variables with
|
565
|
+
* the usual connectives and reified linear expressions.
|
566
|
+
*
|
567
|
+
* Boolean relations are obtained from Boolean expressions with
|
568
|
+
* functions \a tt (stating that the expression must be true)
|
569
|
+
* and \a ff (stating that the expression must be false).
|
570
|
+
*
|
571
|
+
* \ingroup TaskModelMiniModel
|
572
|
+
*/
|
573
|
+
|
574
|
+
//@{
|
575
|
+
|
576
|
+
/// Negated Boolean expression
|
577
|
+
Gecode::MiniModel::BoolExpr
|
578
|
+
operator!(const Gecode::MiniModel::BoolExpr&);
|
579
|
+
|
580
|
+
/// Conjunction of Boolean expressions
|
581
|
+
Gecode::MiniModel::BoolExpr
|
582
|
+
operator&&(const Gecode::MiniModel::BoolExpr&,
|
583
|
+
const Gecode::MiniModel::BoolExpr&);
|
584
|
+
|
585
|
+
/// Disjunction of Boolean expressions
|
586
|
+
Gecode::MiniModel::BoolExpr
|
587
|
+
operator||(const Gecode::MiniModel::BoolExpr&,
|
588
|
+
const Gecode::MiniModel::BoolExpr&);
|
589
|
+
|
590
|
+
/// Exclusive-or of Boolean expressions
|
591
|
+
Gecode::MiniModel::BoolExpr
|
592
|
+
operator^(const Gecode::MiniModel::BoolExpr&,
|
593
|
+
const Gecode::MiniModel::BoolExpr&);
|
594
|
+
|
595
|
+
/// Reification of linear relations
|
596
|
+
template <class Var>
|
597
|
+
Gecode::MiniModel::BoolExpr
|
598
|
+
operator~(const Gecode::MiniModel::LinRel<Var>&);
|
599
|
+
|
600
|
+
namespace Gecode {
|
601
|
+
|
602
|
+
/// Equivalence of Boolean expressions
|
603
|
+
MiniModel::BoolExpr
|
604
|
+
eqv(const MiniModel::BoolExpr&,
|
605
|
+
const MiniModel::BoolExpr&);
|
606
|
+
/// Implication of Boolean expressions
|
607
|
+
MiniModel::BoolExpr
|
608
|
+
imp(const MiniModel::BoolExpr&,
|
609
|
+
const MiniModel::BoolExpr&);
|
610
|
+
|
611
|
+
/// State that Boolean expression must be true
|
612
|
+
MiniModel::BoolRel
|
613
|
+
tt(const MiniModel::BoolExpr&);
|
614
|
+
|
615
|
+
/// State that Boolean expression must be false
|
616
|
+
MiniModel::BoolRel
|
617
|
+
ff(const MiniModel::BoolExpr&);
|
618
|
+
|
619
|
+
}
|
620
|
+
|
621
|
+
//@}
|
622
|
+
|
623
|
+
namespace Gecode {
|
624
|
+
|
625
|
+
/**
|
626
|
+
* \defgroup TaskModelMiniModelPost Posting of expressions and relations
|
627
|
+
*
|
628
|
+
* \ingroup TaskModelMiniModel
|
629
|
+
*/
|
630
|
+
//@{
|
631
|
+
/// Post linear expression and return its value
|
632
|
+
template <class Var>
|
633
|
+
IntVar post(Space* home, const MiniModel::LinExpr<Var>& e,
|
634
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
635
|
+
/// Post linear expression (special case for integer variable) and return its value
|
636
|
+
IntVar post(Space* home, const IntVar& x,
|
637
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
638
|
+
/// Post linear expression (special case for constant) and return its value
|
639
|
+
IntVar post(Space* home, int n,
|
640
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
641
|
+
|
642
|
+
/// Post linear relation
|
643
|
+
template <class Var>
|
644
|
+
void post(Space* home, const MiniModel::LinRel<Var>& r,
|
645
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
646
|
+
/// Make it work for special integer only-case
|
647
|
+
void post(Space* home, bool r,
|
648
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
649
|
+
|
650
|
+
/// Post Boolean expression and return its value
|
651
|
+
BoolVar post(Space* home, const MiniModel::BoolExpr& e,
|
652
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
653
|
+
/// Post Boolean expression (special case for variable) and return its value
|
654
|
+
BoolVar post(Space* home, const BoolVar& b,
|
655
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
656
|
+
/// Post Boolean relation
|
657
|
+
void post(Space* home, const MiniModel::BoolRel& r,
|
658
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
659
|
+
//@}
|
660
|
+
|
661
|
+
}
|
662
|
+
|
663
|
+
#include "gecode/minimodel/lin-expr.icc"
|
664
|
+
#include "gecode/minimodel/lin-rel.icc"
|
665
|
+
#include "gecode/minimodel/bool-expr.icc"
|
666
|
+
#include "gecode/minimodel/bool-rel.icc"
|
667
|
+
|
668
|
+
namespace Gecode {
|
669
|
+
|
670
|
+
/**
|
671
|
+
* \brief Regular expressions over integer values
|
672
|
+
*
|
673
|
+
* \ingroup TaskModelMiniModel
|
674
|
+
*/
|
675
|
+
class GECODE_MINIMODEL_EXPORT REG {
|
676
|
+
private:
|
677
|
+
/// Implementation of the actual expression tree
|
678
|
+
class Exp;
|
679
|
+
/// The expression tree
|
680
|
+
Exp* e;
|
681
|
+
/// Initialize with given expression tree \a
|
682
|
+
REG(Exp* e);
|
683
|
+
public:
|
684
|
+
/// Initialize as empty sequence (epsilon)
|
685
|
+
REG(void);
|
686
|
+
/// Initialize as single integer \a s
|
687
|
+
REG(int s);
|
688
|
+
/**
|
689
|
+
* \brief Initialize as alternative of integers
|
690
|
+
*
|
691
|
+
* Throws an exception of type MiniModel::TooFewArguments if \a x
|
692
|
+
* is empty.
|
693
|
+
*/
|
694
|
+
REG(const IntArgs& x);
|
695
|
+
|
696
|
+
/// Initialize from regular expression \a r
|
697
|
+
REG(const REG& r);
|
698
|
+
/// Assign to regular expression \a r
|
699
|
+
const REG& operator=(const REG& r);
|
700
|
+
|
701
|
+
/// Return expression for: this expression followed by \a r
|
702
|
+
REG operator+(const REG& r);
|
703
|
+
/// This expression is followed by \a r
|
704
|
+
REG& operator+=(const REG& r);
|
705
|
+
/// Return expression for: this expression or \a r
|
706
|
+
REG operator|(const REG& r);
|
707
|
+
/// This expression or \a r
|
708
|
+
REG& operator|=(const REG& r);
|
709
|
+
/// Return expression for: this expression arbitrarily often (Kleene star)
|
710
|
+
REG operator*(void);
|
711
|
+
/// Return expression for: this expression at least once
|
712
|
+
REG operator+(void);
|
713
|
+
/// Return expression for: this expression at least \a n and at most \a m times
|
714
|
+
REG operator()(unsigned int n, unsigned int m);
|
715
|
+
/// Return expression for: this expression at least \a n times
|
716
|
+
REG operator()(unsigned int n);
|
717
|
+
/// Print expression
|
718
|
+
std::ostream& print(std::ostream&) const;
|
719
|
+
/// Return DFA for regular expression
|
720
|
+
operator DFA(void);
|
721
|
+
/// Destructor
|
722
|
+
~REG(void);
|
723
|
+
};
|
724
|
+
|
725
|
+
}
|
726
|
+
|
727
|
+
/** \relates Gecode::REG
|
728
|
+
* Print regular expression \a r
|
729
|
+
*/
|
730
|
+
GECODE_MINIMODEL_EXPORT std::ostream&
|
731
|
+
operator<<(std::ostream&, const Gecode::REG& r);
|
732
|
+
|
733
|
+
|
734
|
+
namespace Gecode {
|
735
|
+
|
736
|
+
/**
|
737
|
+
* \defgroup TaskModelMiniModelArith Arithmetic functions
|
738
|
+
*
|
739
|
+
* \ingroup TaskModelMiniModel
|
740
|
+
*/
|
741
|
+
//@{
|
742
|
+
/** \brief Return variable constrained to \f$|x|\f$
|
743
|
+
*
|
744
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
745
|
+
* and domain consistency (\a icl = ICL_DOM).
|
746
|
+
*/
|
747
|
+
IntVar
|
748
|
+
abs(Space* home, IntVar x,
|
749
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
750
|
+
/** \brief Return variable constrained to \f$\min(x,y)\f$
|
751
|
+
*
|
752
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
753
|
+
* and domain consistency (\a icl = ICL_DOM).
|
754
|
+
*/
|
755
|
+
IntVar
|
756
|
+
min(Space* home, IntVar x, IntVar y,
|
757
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
758
|
+
/** \brief Return variable constrained to \f$\min(x)\f$
|
759
|
+
*
|
760
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
761
|
+
* and domain consistency (\a icl = ICL_DOM).
|
762
|
+
*/
|
763
|
+
IntVar
|
764
|
+
min(Space* home, const IntVarArgs& x,
|
765
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
766
|
+
/** \brief Return variable constrained to \f$\max(x,y)\f$
|
767
|
+
*
|
768
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
769
|
+
* and domain consistency (\a icl = ICL_DOM).
|
770
|
+
*/
|
771
|
+
IntVar
|
772
|
+
max(Space* home, IntVar x, IntVar y,
|
773
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
774
|
+
/** \brief Return variable constrained to \f$\max(x)\f$
|
775
|
+
*
|
776
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
777
|
+
* and domain consistency (\a icl = ICL_DOM).
|
778
|
+
*/
|
779
|
+
IntVar
|
780
|
+
max(Space* home, const IntVarArgs& x,
|
781
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
782
|
+
/** \brief Return variable constrained to \f$x\cdot y\f$
|
783
|
+
*
|
784
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
785
|
+
* and domain consistency (\a icl = ICL_DOM).
|
786
|
+
*/
|
787
|
+
IntVar
|
788
|
+
mult(Space* home, IntVar x, IntVar y,
|
789
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
790
|
+
/** \brief Return variable constrained to \f$x^2\f$
|
791
|
+
*
|
792
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
793
|
+
* and domain consistency (\a icl = ICL_DOM).
|
794
|
+
*/
|
795
|
+
IntVar
|
796
|
+
sqr(Space* home, IntVar x,
|
797
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
798
|
+
/** \brief Return variable constrained to \f$\lfloor\sqrt{x}\rfloor\f$
|
799
|
+
*
|
800
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
801
|
+
* and domain consistency (\a icl = ICL_DOM).
|
802
|
+
*/
|
803
|
+
IntVar
|
804
|
+
sqrt(Space* home, IntVar x,
|
805
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
806
|
+
/** \brief Return variable constrained to \f$x+y\f$
|
807
|
+
*
|
808
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
809
|
+
* and domain consistency (\a icl = ICL_DOM).
|
810
|
+
*/
|
811
|
+
IntVar
|
812
|
+
plus(Space* home, IntVar x, IntVar y,
|
813
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
814
|
+
/** Return variable constrained to \f$x-y\f$
|
815
|
+
*
|
816
|
+
* Supports both bounds consistency (\a icl = ICL_BND, default)
|
817
|
+
* and domain consistency (\a icl = ICL_DOM).
|
818
|
+
*/
|
819
|
+
IntVar
|
820
|
+
minus(Space* home, IntVar x, IntVar y,
|
821
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF);
|
822
|
+
//@}
|
823
|
+
}
|
824
|
+
|
825
|
+
#include "gecode/minimodel/arithmetic.icc"
|
826
|
+
|
827
|
+
namespace Gecode {
|
828
|
+
|
829
|
+
/**
|
830
|
+
* \defgroup TaskModelMiniModelChannel Channel functions
|
831
|
+
*
|
832
|
+
* \ingroup TaskModelMiniModel
|
833
|
+
*/
|
834
|
+
//@{
|
835
|
+
/// Return Boolean variable equal to \f$x\f$
|
836
|
+
inline BoolVar
|
837
|
+
channel(Space* home, IntVar x,
|
838
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
839
|
+
(void) icl; (void) pk;
|
840
|
+
BoolVar b(home,0,1); channel(home,b,x);
|
841
|
+
return b;
|
842
|
+
}
|
843
|
+
/// Return integer variable equal to \f$b\f$
|
844
|
+
inline IntVar
|
845
|
+
channel(Space* home, BoolVar b,
|
846
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
847
|
+
(void) icl; (void) pk;
|
848
|
+
IntVar x(home,0,1); channel(home,b,x);
|
849
|
+
return x;
|
850
|
+
}
|
851
|
+
//@}
|
852
|
+
|
853
|
+
}
|
854
|
+
|
855
|
+
namespace Gecode {
|
856
|
+
|
857
|
+
/**
|
858
|
+
* \defgroup TaskModelMiniModelIntAlias Aliases for integer constraints
|
859
|
+
*
|
860
|
+
* Contains definitions of common constraints which have different
|
861
|
+
* names in Gecode.
|
862
|
+
*
|
863
|
+
* \ingroup TaskModelMiniModel
|
864
|
+
*/
|
865
|
+
|
866
|
+
//@{
|
867
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}\leq m\f$
|
868
|
+
*
|
869
|
+
* Supports domain consistent propagation only.
|
870
|
+
*/
|
871
|
+
inline void
|
872
|
+
atmost(Space* home, const IntVarArgs& x, int n, int m,
|
873
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
874
|
+
count(home,x,n,IRT_LQ,m,icl,pk);
|
875
|
+
}
|
876
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}\leq m\f$
|
877
|
+
*
|
878
|
+
* Supports domain consistent propagation only.
|
879
|
+
*/
|
880
|
+
inline void
|
881
|
+
atmost(Space* home, const IntVarArgs& x, IntVar y, int m,
|
882
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
883
|
+
count(home,x,y,IRT_LQ,m,icl,pk);
|
884
|
+
}
|
885
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}\leq m\f$
|
886
|
+
*
|
887
|
+
* Supports domain consistent propagation only.
|
888
|
+
*
|
889
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
890
|
+
* \a x and \a y are of different size.
|
891
|
+
*/
|
892
|
+
inline void
|
893
|
+
atmost(Space* home, const IntVarArgs& x, const IntArgs& y, int m,
|
894
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
895
|
+
count(home,x,y,IRT_LQ,m,icl,pk);
|
896
|
+
}
|
897
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}\leq z\f$
|
898
|
+
*
|
899
|
+
* Supports domain consistent propagation only.
|
900
|
+
*/
|
901
|
+
inline void
|
902
|
+
atmost(Space* home, const IntVarArgs& x, int n, IntVar z,
|
903
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
904
|
+
count(home,x,n,IRT_LQ,z,icl,pk);
|
905
|
+
}
|
906
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}\leq z\f$
|
907
|
+
*
|
908
|
+
* Supports domain consistent propagation only.
|
909
|
+
*/
|
910
|
+
inline void
|
911
|
+
atmost(Space* home, const IntVarArgs& x, IntVar y, IntVar z,
|
912
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
913
|
+
count(home,x,y,IRT_LQ,z,icl,pk);
|
914
|
+
}
|
915
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}\leq z\f$
|
916
|
+
*
|
917
|
+
* Supports domain consistent propagation only.
|
918
|
+
*
|
919
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
920
|
+
* \a x and \a y are of different size.
|
921
|
+
*/
|
922
|
+
inline void
|
923
|
+
atmost(Space* home, const IntVarArgs& x, const IntArgs& y, IntVar z,
|
924
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
925
|
+
count(home,x,y,IRT_LQ,z,icl,pk);
|
926
|
+
}
|
927
|
+
|
928
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}\geq m\f$
|
929
|
+
*
|
930
|
+
* Supports domain consistent propagation only.
|
931
|
+
*/
|
932
|
+
inline void
|
933
|
+
atleast(Space* home, const IntVarArgs& x, int n, int m,
|
934
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
935
|
+
count(home,x,n,IRT_GQ,m,icl,pk);
|
936
|
+
}
|
937
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}\geq m\f$
|
938
|
+
*
|
939
|
+
* Supports domain consistent propagation only.
|
940
|
+
*/
|
941
|
+
inline void
|
942
|
+
atleast(Space* home, const IntVarArgs& x, IntVar y, int m,
|
943
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
944
|
+
count(home,x,y,IRT_GQ,m,icl,pk);
|
945
|
+
}
|
946
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}\geq m\f$
|
947
|
+
*
|
948
|
+
* Supports domain consistent propagation only.
|
949
|
+
*
|
950
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
951
|
+
* \a x and \a y are of different size.
|
952
|
+
*/
|
953
|
+
inline void
|
954
|
+
atleast(Space* home, const IntVarArgs& x, const IntArgs& y, int m,
|
955
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
956
|
+
count(home,x,y,IRT_GQ,m,icl,pk);
|
957
|
+
}
|
958
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}\geq z\f$
|
959
|
+
*
|
960
|
+
* Supports domain consistent propagation only.
|
961
|
+
*/
|
962
|
+
inline void
|
963
|
+
atleast(Space* home, const IntVarArgs& x, int n, IntVar z,
|
964
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
965
|
+
count(home,x,n,IRT_GQ,z,icl,pk);
|
966
|
+
}
|
967
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}\geq z\f$
|
968
|
+
*
|
969
|
+
* Supports domain consistent propagation only.
|
970
|
+
*/
|
971
|
+
inline void
|
972
|
+
atleast(Space* home, const IntVarArgs& x, IntVar y, IntVar z,
|
973
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
974
|
+
count(home,x,y,IRT_GQ,z,icl,pk);
|
975
|
+
}
|
976
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}\geq z\f$
|
977
|
+
*
|
978
|
+
* Supports domain consistent propagation only.
|
979
|
+
*
|
980
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
981
|
+
* \a x and \a y are of different size.
|
982
|
+
*/
|
983
|
+
inline void
|
984
|
+
atleast(Space* home, const IntVarArgs& x, const IntArgs& y, IntVar z,
|
985
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
986
|
+
count(home,x,y,IRT_GQ,z,icl,pk);
|
987
|
+
}
|
988
|
+
|
989
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}=m\f$
|
990
|
+
*
|
991
|
+
* Supports domain consistent propagation only.
|
992
|
+
*/
|
993
|
+
inline void
|
994
|
+
exactly(Space* home, const IntVarArgs& x, int n, int m,
|
995
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
996
|
+
count(home,x,n,IRT_EQ,m,icl,pk);
|
997
|
+
}
|
998
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}=m\f$
|
999
|
+
*
|
1000
|
+
* Supports domain consistent propagation only.
|
1001
|
+
*/
|
1002
|
+
inline void
|
1003
|
+
exactly(Space* home, const IntVarArgs& x, IntVar y, int m,
|
1004
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
1005
|
+
count(home,x,y,IRT_EQ,m,icl,pk);
|
1006
|
+
}
|
1007
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}=m\f$
|
1008
|
+
*
|
1009
|
+
* Supports domain consistent propagation only.
|
1010
|
+
*
|
1011
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
1012
|
+
* \a x and \a y are of different size.
|
1013
|
+
*/
|
1014
|
+
inline void
|
1015
|
+
exactly(Space* home, const IntVarArgs& x, const IntArgs& y, int m,
|
1016
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
1017
|
+
count(home,x,y,IRT_EQ,m,icl,pk);
|
1018
|
+
}
|
1019
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=n\}=z\f$
|
1020
|
+
*
|
1021
|
+
* Supports domain consistent propagation only.
|
1022
|
+
*/
|
1023
|
+
inline void
|
1024
|
+
exactly(Space* home, const IntVarArgs& x, int n, IntVar z,
|
1025
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
1026
|
+
count(home,x,n,IRT_EQ,z,icl,pk);
|
1027
|
+
}
|
1028
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y\}=z\f$
|
1029
|
+
*
|
1030
|
+
* Supports domain consistent propagation only.
|
1031
|
+
*/
|
1032
|
+
inline void
|
1033
|
+
exactly(Space* home, const IntVarArgs& x, IntVar y, IntVar z,
|
1034
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
1035
|
+
count(home,x,y,IRT_EQ,z,icl,pk);
|
1036
|
+
}
|
1037
|
+
/** \brief Post propagator for \f$\#\{i\in\{0,\ldots,|x|-1\}\;|\;x_i=y_i\}=z\f$
|
1038
|
+
*
|
1039
|
+
* Supports domain consistent propagation only.
|
1040
|
+
*
|
1041
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
1042
|
+
* \a x and \a y are of different size.
|
1043
|
+
*/
|
1044
|
+
inline void
|
1045
|
+
exactly(Space* home, const IntVarArgs& x, const IntArgs& y, IntVar z,
|
1046
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
1047
|
+
count(home,x,y,IRT_EQ,z,icl,pk);
|
1048
|
+
}
|
1049
|
+
/** \brief Post propagator for lexical order between \a x and \a y.
|
1050
|
+
*
|
1051
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
1052
|
+
* \a x and \a y are of different size.
|
1053
|
+
*/
|
1054
|
+
inline void
|
1055
|
+
lex(Space* home, const IntVarArgs& x, IntRelType r, const IntVarArgs& y,
|
1056
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
1057
|
+
rel(home,x,r,y,icl,pk);
|
1058
|
+
}
|
1059
|
+
/** \brief Post propagator for lexical order between \a x and \a y.
|
1060
|
+
*
|
1061
|
+
* Throws an exception of type Int::ArgumentSizeMismatch, if
|
1062
|
+
* \a x and \a y are of different size.
|
1063
|
+
*/
|
1064
|
+
inline void
|
1065
|
+
lex(Space* home, const BoolVarArgs& x, IntRelType r, const BoolVarArgs& y,
|
1066
|
+
IntConLevel icl=ICL_DEF, PropKind pk=PK_DEF) {
|
1067
|
+
rel(home,x,r,y,icl,pk);
|
1068
|
+
}
|
1069
|
+
|
1070
|
+
//@}
|
1071
|
+
|
1072
|
+
}
|
1073
|
+
|
1074
|
+
/**
|
1075
|
+
* \addtogroup TaskModelMiniModelMatrix Matrix interface for arrays
|
1076
|
+
*
|
1077
|
+
* Wrapper for arrays to act as a two-dimensional matrix.
|
1078
|
+
*
|
1079
|
+
* \ingroup TaskModelMiniModel
|
1080
|
+
*/
|
1081
|
+
//@{
|
1082
|
+
namespace Gecode { namespace MiniModel {
|
1083
|
+
|
1084
|
+
/** \brief Matrix-interface for arrays
|
1085
|
+
*
|
1086
|
+
* This class allows for wrapping some array and accessing it as a
|
1087
|
+
* matrix.
|
1088
|
+
*
|
1089
|
+
* \note This is a light-weight wrapper, and is not intended for
|
1090
|
+
* storing variables directly instead of in an array.
|
1091
|
+
*
|
1092
|
+
* \ingroup TaskModelMiniModelMatrix
|
1093
|
+
*/
|
1094
|
+
template <class A>
|
1095
|
+
class Matrix {
|
1096
|
+
public:
|
1097
|
+
/// The type of elements of this array
|
1098
|
+
typedef typename ArrayTraits<A>::value_type value_type;
|
1099
|
+
/// The type of the Args-array type for value_type values.
|
1100
|
+
typedef typename ArrayTraits<A>::args_type args_type;
|
1101
|
+
|
1102
|
+
/** \brief A slice of a matrix.
|
1103
|
+
*
|
1104
|
+
* This class represents a slice of the matrix. It is used to get
|
1105
|
+
* context-dependent behaviour. The slice will be automatically
|
1106
|
+
* converted to an args_type Args-array or to a Matrix<args_type>
|
1107
|
+
* depending on the context where it is used.
|
1108
|
+
*/
|
1109
|
+
class Slice {
|
1110
|
+
args_type _r; ///< The elements of the slice
|
1111
|
+
unsigned int _fc, ///< From column
|
1112
|
+
_tc, ///< To column
|
1113
|
+
_fr, ///< From row
|
1114
|
+
_tr; ///< To row
|
1115
|
+
public:
|
1116
|
+
Slice(Matrix<A>& a,
|
1117
|
+
unsigned int fc, unsigned int tc,
|
1118
|
+
unsigned int fr, unsigned int tr);
|
1119
|
+
|
1120
|
+
/** \brief Reverses the contents of the slice, and returns a
|
1121
|
+
* reference to it.
|
1122
|
+
*/
|
1123
|
+
Slice& reverse(void);
|
1124
|
+
|
1125
|
+
operator args_type(void);
|
1126
|
+
operator Matrix<args_type>(void);
|
1127
|
+
};
|
1128
|
+
|
1129
|
+
private:
|
1130
|
+
/// The type of storage for this array
|
1131
|
+
typedef typename ArrayTraits<A>::storage_type storage_type;
|
1132
|
+
storage_type _a; ///< The array wrapped
|
1133
|
+
unsigned int _w, ///< The width of the matrix
|
1134
|
+
_h; ///< The height of the matrix
|
1135
|
+
|
1136
|
+
public:
|
1137
|
+
/** \brief Basic constructor
|
1138
|
+
*
|
1139
|
+
* Constructs a Matrix from the array \a a, using \a w and \a h as
|
1140
|
+
* the width and height of the matrix.
|
1141
|
+
*
|
1142
|
+
* The elements in the wrapped array \a a are accessed in
|
1143
|
+
* row-major order.
|
1144
|
+
*
|
1145
|
+
* \exception MiniModel::ArgumentSizeMismatch Raised if the
|
1146
|
+
* parameters \a w and \a h doesn't match the size
|
1147
|
+
* of the array \a a.
|
1148
|
+
*/
|
1149
|
+
Matrix(A a, unsigned int w, unsigned int h);
|
1150
|
+
|
1151
|
+
/** \brief Basic constructor
|
1152
|
+
*
|
1153
|
+
* Constructs a square Matrix from the array \a a, using \a n as
|
1154
|
+
* the length of the sides.
|
1155
|
+
*
|
1156
|
+
* The elements in the wrapped array \a a are accessed in
|
1157
|
+
* row-major order.
|
1158
|
+
*
|
1159
|
+
* \exception MiniModel::ArgumentSizeMismatch Raised if the
|
1160
|
+
* parameter \a n doesn't match the size
|
1161
|
+
* of the array \a a.
|
1162
|
+
*/
|
1163
|
+
Matrix(A a, unsigned int n);
|
1164
|
+
|
1165
|
+
/// Return the width of the matrix
|
1166
|
+
unsigned int width(void) const;
|
1167
|
+
/// Return the height of the matrix
|
1168
|
+
unsigned int height(void) const;
|
1169
|
+
/// Return an Args-array of the contents of the matrix
|
1170
|
+
args_type const get_array(void);
|
1171
|
+
|
1172
|
+
/** \brief Access element (\a c, \a r) of the matrix
|
1173
|
+
*
|
1174
|
+
* \exception MiniModel::ArgumentOutOfRange Raised if \a c or \a r
|
1175
|
+
* are out of range.
|
1176
|
+
*/
|
1177
|
+
value_type& operator()(unsigned int c, unsigned int r);
|
1178
|
+
|
1179
|
+
/** \brief Access slice of the matrix
|
1180
|
+
*
|
1181
|
+
* This function allows accessing a slice of the matrix, located at
|
1182
|
+
* columns \f$[fc,tc)\f$ and rows \f$[fr,tr)\f$. The result of this
|
1183
|
+
* function is an object that can be converted into either a
|
1184
|
+
* Matrix<args_type> or into args_type.
|
1185
|
+
*
|
1186
|
+
* For further information, see Slice.
|
1187
|
+
*/
|
1188
|
+
Slice slice(unsigned int fc, unsigned int tc,
|
1189
|
+
unsigned int fr, unsigned int tr);
|
1190
|
+
|
1191
|
+
/// Access row \a r.
|
1192
|
+
Slice row(int r);
|
1193
|
+
|
1194
|
+
/// Access column \a c.
|
1195
|
+
Slice col(int c);
|
1196
|
+
};
|
1197
|
+
}}
|
1198
|
+
//@}
|
1199
|
+
|
1200
|
+
#include "gecode/minimodel/matrix.icc"
|
1201
|
+
|
1202
|
+
#endif
|
1203
|
+
|
1204
|
+
// IFDEF: GECODE_HAS_INT_VARS
|
1205
|
+
// STATISTICS: minimodel-any
|
1206
|
+
|