gecoder-with-gecode 0.9.0 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGES +6 -0
- data/README +1 -1
- data/THANKS +18 -0
- data/example/equation_system.rb +3 -1
- data/example/magic_sequence.rb +3 -1
- data/example/queens.rb +3 -1
- data/example/send_more_money.rb +24 -30
- data/example/send_most_money.rb +15 -26
- data/example/square_tiling.rb +3 -1
- data/example/sudoku-set.rb +3 -1
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/LICENSE +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/Makefile.contribs +0 -0
- data/ext/gecode-2.2.0/Makefile.dep +8056 -0
- data/ext/gecode-2.2.0/Makefile.in +1590 -0
- data/ext/gecode-2.2.0/changelog.in +2698 -0
- data/ext/gecode-2.2.0/configure +13112 -0
- data/ext/gecode-2.2.0/configure.ac +273 -0
- data/ext/gecode-2.2.0/configure.ac.in +269 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/README +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/Doxyfile +263 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.cc +267 -0
- data/ext/gecode-2.2.0/contribs/qecode/Implicative.hh +164 -0
- data/ext/gecode-2.2.0/contribs/qecode/Makefile.in.in +163 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.cc +82 -0
- data/ext/gecode-2.2.0/contribs/qecode/OptVar.hh +123 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.cc +131 -0
- data/ext/gecode-2.2.0/contribs/qecode/Strategy.hh +91 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.cc +62 -0
- data/ext/gecode-2.2.0/contribs/qecode/StrategyNode.hh +47 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/output.0 +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/requests +115 -0
- data/ext/gecode-2.2.0/contribs/qecode/autom4te.cache/traces.0 +57 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.log +147 -0
- data/ext/gecode-2.2.0/contribs/qecode/config.status +817 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure +2264 -0
- data/ext/gecode-2.2.0/contribs/qecode/configure.ac +23 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/COMPILING +13 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/MatrixGame.cpp +140 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/NimFibo.cpp +73 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/connect-5-3-3-3.cpp +842 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/network-pricing.cc +146 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/optim2.cc +149 -0
- data/ext/gecode-2.2.0/contribs/qecode/examples/stress_test.cpp +240 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/heap.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myDom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/myspace.cc +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/myspace.hh +68 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/qecode.hh +0 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.cc +268 -0
- data/ext/gecode-2.2.0/contribs/qecode/qsolver.hh +46 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/shortdesc.ac +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/contribs/qecode/vartype.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/doxygen/doxygen.conf.in +0 -0
- data/ext/gecode-2.2.0/doxygen/doxygen.hh.in +1112 -0
- data/ext/gecode-2.2.0/doxygen/reflection.hh +417 -0
- data/ext/gecode-2.2.0/examples/all-interval.cc +133 -0
- data/ext/gecode-2.2.0/examples/alpha.cc +137 -0
- data/ext/gecode-2.2.0/examples/bacp.cc +521 -0
- data/ext/gecode-2.2.0/examples/baseline.cc +87 -0
- data/ext/gecode-2.2.0/examples/bibd.cc +203 -0
- data/ext/gecode-2.2.0/examples/black-hole.cc +389 -0
- data/ext/gecode-2.2.0/examples/crew.cc +286 -0
- data/ext/gecode-2.2.0/examples/crowded-chess.cc +424 -0
- data/ext/gecode-2.2.0/examples/domino.cc +297 -0
- data/ext/gecode-2.2.0/examples/donald.cc +107 -0
- data/ext/gecode-2.2.0/examples/eq20.cc +125 -0
- data/ext/gecode-2.2.0/examples/golf.cc +297 -0
- data/ext/gecode-2.2.0/examples/golomb-ruler.cc +199 -0
- data/ext/gecode-2.2.0/examples/graph-color.cc +407 -0
- data/ext/gecode-2.2.0/examples/grocery.cc +113 -0
- data/ext/gecode-2.2.0/examples/hamming.cc +129 -0
- data/ext/gecode-2.2.0/examples/ind-set.cc +143 -0
- data/ext/gecode-2.2.0/examples/javascript.cc +163 -0
- data/ext/gecode-2.2.0/examples/kakuro.cc +686 -0
- data/ext/gecode-2.2.0/examples/knights.cc +220 -0
- data/ext/gecode-2.2.0/examples/langford-number.cc +225 -0
- data/ext/gecode-2.2.0/examples/magic-sequence.cc +146 -0
- data/ext/gecode-2.2.0/examples/magic-square.cc +138 -0
- data/ext/gecode-2.2.0/examples/minesweeper.cc +304 -0
- data/ext/gecode-2.2.0/examples/money.cc +105 -0
- data/ext/gecode-2.2.0/examples/nonogram.cc +492 -0
- data/ext/gecode-2.2.0/examples/ortho-latin.cc +172 -0
- data/ext/gecode-2.2.0/examples/partition.cc +141 -0
- data/ext/gecode-2.2.0/examples/pentominoes.cc +949 -0
- data/ext/gecode-2.2.0/examples/perfect-square.cc +311 -0
- data/ext/gecode-2.2.0/examples/photo.cc +170 -0
- data/ext/gecode-2.2.0/examples/queen-armies.cc +284 -0
- data/ext/gecode-2.2.0/examples/queens.cc +147 -0
- data/ext/gecode-2.2.0/examples/queens.js +57 -0
- data/ext/gecode-2.2.0/examples/sports-league.cc +342 -0
- data/ext/gecode-2.2.0/examples/steiner.cc +192 -0
- data/ext/gecode-2.2.0/examples/stress-distinct.cc +90 -0
- data/ext/gecode-2.2.0/examples/stress-domain.cc +99 -0
- data/ext/gecode-2.2.0/examples/stress-element.cc +112 -0
- data/ext/gecode-2.2.0/examples/stress-exec.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-extensional.cc +134 -0
- data/ext/gecode-2.2.0/examples/stress-linear-bool.cc +97 -0
- data/ext/gecode-2.2.0/examples/stress-min.cc +98 -0
- data/ext/gecode-2.2.0/examples/stress-search.cc +88 -0
- data/ext/gecode-2.2.0/examples/sudoku.cc +2341 -0
- data/ext/gecode-2.2.0/examples/support.hh +338 -0
- data/ext/gecode-2.2.0/examples/support/example.cc +64 -0
- data/ext/gecode-2.2.0/examples/support/example.icc +321 -0
- data/ext/gecode-2.2.0/examples/support/options.cc +226 -0
- data/ext/gecode-2.2.0/examples/support/options.icc +276 -0
- data/ext/gecode-2.2.0/examples/tsp.cc +317 -0
- data/ext/gecode-2.2.0/examples/warehouses.cc +191 -0
- data/ext/gecode-2.2.0/gecode.m4 +1046 -0
- data/ext/gecode-2.2.0/gecode/cpltset.hh +797 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/bddmanager.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/atmost.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/partition.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rangeroots.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/select.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/constraints/singleton.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/binary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/naryone.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/narytwo.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/propagators/unary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/support.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var-imp/cpltset.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/var/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/cpltset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/cpltset/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addchild.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/addvisualisationdialog.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/better.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/config.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.cc +281 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.hh +103 -0
- data/ext/gecode-2.2.0/gecode/gist/drawingcursor.icc +70 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.cc +672 -0
- data/ext/gecode-2.2.0/gecode/gist/gecodelogo.hh +64 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/gist.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.cc +115 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/layoutcursor.icc +48 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.cc +274 -0
- data/ext/gecode-2.2.0/gecode/gist/mainwindow.hh +86 -0
- data/ext/gecode-2.2.0/gecode/gist/node.cc +148 -0
- data/ext/gecode-2.2.0/gecode/gist/node.hh +117 -0
- data/ext/gecode-2.2.0/gecode/gist/node.icc +99 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.cc +123 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.hh +147 -0
- data/ext/gecode-2.2.0/gecode/gist/nodecursor.icc +122 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/nodevisitor.icc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.cc +120 -0
- data/ext/gecode-2.2.0/gecode/gist/preferences.hh +79 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.cc +468 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.hh +227 -0
- data/ext/gecode-2.2.0/gecode/gist/spacenode.icc +170 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/test.cc +0 -0
- data/ext/gecode-2.2.0/gecode/gist/textoutput.cc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/textoutput.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.cc +1343 -0
- data/ext/gecode-2.2.0/gecode/gist/treecanvas.hh +361 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/ui_addchild.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/ui_addvisualisationdialog.hh +165 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.cc +192 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/intvaritem.hh +75 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.cc +235 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/setvaritem.hh +77 -0
- data/ext/gecode-2.2.0/gecode/gist/visualisation/vararrayitem.hh +125 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayview.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/vararrayviewt.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/gist/visualisation/varitem.hh +0 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.cc +474 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.hh +226 -0
- data/ext/gecode-2.2.0/gecode/gist/visualnode.icc +198 -0
- data/ext/gecode-2.2.0/gecode/gist/zoomToFitIcon.icc +113 -0
- data/ext/gecode-2.2.0/gecode/int.hh +2116 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.cc +237 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic.hh +827 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/abs.icc +278 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/divmod.icc +496 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/max.icc +474 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/mult.icc +858 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqr.icc +464 -0
- data/ext/gecode-2.2.0/gecode/int/arithmetic/sqrt.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool.cc +734 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/eqv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/bool/lq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/bool/or.icc +1000 -0
- data/ext/gecode-2.2.0/gecode/int/branch.cc +167 -0
- data/ext/gecode-2.2.0/gecode/int/branch.hh +587 -0
- data/ext/gecode-2.2.0/gecode/int/branch/create-branch.icc +190 -0
- data/ext/gecode-2.2.0/gecode/int/branch/select-val.icc +340 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/branch/select-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel.cc +165 -0
- data/ext/gecode-2.2.0/gecode/int/channel.hh +259 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/base.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/dom.icc +348 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-multi.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/channel/link-single.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/channel/val.icc +278 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit.hh +175 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/base.icc +266 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/circuit/dom.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/circuit/val.icc +126 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/count.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/count.hh +487 -0
- data/ext/gecode-2.2.0/gecode/int/count/int.icc +620 -0
- data/ext/gecode-2.2.0/gecode/int/count/rel.icc +144 -0
- data/ext/gecode-2.2.0/gecode/int/count/view.icc +449 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/cumulatives.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives.hh +138 -0
- data/ext/gecode-2.2.0/gecode/int/cumulatives/val.icc +455 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct.hh +341 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bilink.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/bnd.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/combptr.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/dom.icc +752 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/edge.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/node.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/distinct/ter-dom.icc +136 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/distinct/val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/range.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/dom/spec.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/element.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/element.hh +239 -0
- data/ext/gecode-2.2.0/gecode/int/element/int.icc +444 -0
- data/ext/gecode-2.2.0/gecode/int/element/view.icc +584 -0
- data/ext/gecode-2.2.0/gecode/int/exception.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional.hh +415 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/base.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/basic.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/bitset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/dfa.cc +565 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/dfa.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/incremental.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/layered-graph.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/extensional/tuple-set.cc +285 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/extensional/tuple-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc.hh +329 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/bnd.icc +660 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/dom.icc +531 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/gccbndsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/graphsup.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/lbc.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/occur.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/gcc/ubc.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/gcc/val.icc +400 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.cc +157 -0
- data/ext/gecode-2.2.0/gecode/int/int-set.icc +195 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/limits.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear-bool.cc +235 -0
- data/ext/gecode-2.2.0/gecode/int/linear-int.cc +272 -0
- data/ext/gecode-2.2.0/gecode/int/linear.hh +1849 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-int.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/bool-post.cc +433 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/bool-view.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-bin.icc +605 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-dom.icc +539 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-noview.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/linear/int-post.cc +493 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/int-ter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/linear/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel.cc +420 -0
- data/ext/gecode-2.2.0/gecode/int/rel.hh +627 -0
- data/ext/gecode-2.2.0/gecode/int/rel/eq.icc +885 -0
- data/ext/gecode-2.2.0/gecode/int/rel/lex.icc +275 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/rel/lq-le.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/rel/nq.icc +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.cc +81 -0
- data/ext/gecode-2.2.0/gecode/int/sorted.hh +118 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/matching.icc +173 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/narrowing.icc +249 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/order.icc +212 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/propagate.icc +702 -0
- data/ext/gecode-2.2.0/gecode/int/sorted/sortsup.icc +563 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.hh +158 -0
- data/ext/gecode-2.2.0/gecode/int/support-values.icc +203 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/unshare.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp.icc +745 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/bool.cc +105 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/bool.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/delta.icc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var-imp/int.cc +408 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var-imp/int.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/bool.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/bool.icc +128 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/var/int.cc +0 -0
- data/ext/gecode-2.2.0/gecode/int/var/int.icc +153 -0
- data/ext/gecode-2.2.0/gecode/int/view.icc +1918 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/constint.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/iter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/minus.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/rtest.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/int/view/zero.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter.hh +98 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-add.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-cache.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-diff.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-empty.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-inter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-map.icc +260 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-minus.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-negative.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-operations.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/ranges-positive.icc +139 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-scale.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton-append.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-size.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/ranges-values.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-inter.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-map.icc +136 -0
- data/ext/gecode-2.2.0/gecode/iter/values-minus.icc +130 -0
- data/ext/gecode-2.2.0/gecode/iter/values-negative.icc +116 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-offset.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-positive.icc +123 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-ranges.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-singleton.icc +0 -0
- data/ext/gecode-2.2.0/gecode/iter/values-union.icc +137 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/values-unique.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-compl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-inter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges-union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/iter/virtual-ranges.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel.hh +188 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/advisor.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/branching.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.cc +474 -0
- data/ext/gecode-2.2.0/gecode/kernel/core.icc +2311 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/memory-manager.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/memory-manager.icc +454 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/modevent.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/propagator.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.cc +951 -0
- data/ext/gecode-2.2.0/gecode/kernel/reflection.icc +1213 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/shared-array.icc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-imp.icc +433 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.cc +269 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-map.icc +230 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-traits.icc +79 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/kernel/var-type.cc +0 -0
- data/ext/gecode-2.2.0/gecode/kernel/var-type.icc +915 -0
- data/ext/gecode-2.2.0/gecode/kernel/var.icc +114 -0
- data/ext/gecode-2.2.0/gecode/kernel/view.icc +413 -0
- data/ext/gecode-2.2.0/gecode/minimodel.hh +1206 -0
- data/ext/gecode-2.2.0/gecode/minimodel/arithmetic.icc +118 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/bool-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/lin-rel.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/matrix.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/minimodel/reg.cc +0 -0
- data/ext/gecode-2.2.0/gecode/search.hh +759 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/bab.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/dfs.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/engine-ctrl.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/lds.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/options.icc +0 -0
- data/ext/gecode-2.2.0/gecode/search/reco-stack.icc +277 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/restart.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/statistics.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/search/stop.icc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization.hh +149 -0
- data/ext/gecode-2.2.0/gecode/serialization/boost.cc +78 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/boost.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/flatzinc.cc +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/javascript.cc +343 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/serialization/javascript.hh +0 -0
- data/ext/gecode-2.2.0/gecode/serialization/register.cc +8498 -0
- data/ext/gecode-2.2.0/gecode/set.hh +970 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-val.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/branch/select-view.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/cardinality.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/conv.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/convex/hull.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/distinct/atmostOne.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/dom.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/element.cc +135 -0
- data/ext/gecode-2.2.0/gecode/set/element.hh +233 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.cc +308 -0
- data/ext/gecode-2.2.0/gecode/set/element/disjoint.icc +75 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.hh +113 -0
- data/ext/gecode-2.2.0/gecode/set/element/idxarray.icc +155 -0
- data/ext/gecode-2.2.0/gecode/set/element/inter.icc +348 -0
- data/ext/gecode-2.2.0/gecode/set/element/union.icc +371 -0
- data/ext/gecode-2.2.0/gecode/set/element/unionConst.icc +334 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-bool.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/channel-int.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/match.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/minmax.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/int/weights.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/limits.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors-compiler.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors.hh +438 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/compiler.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/projectors/formula.cc +312 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/formula.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector-set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/projector.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/card.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/propagator/re-nary.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/projectors/set-expr.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/propagator.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op-const.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op.hh +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/common.icc +613 -0
- data/ext/gecode-2.2.0/gecode/set/rel-op/inter.icc +452 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/partition.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/post.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/subofunion.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/superofinter.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel-op/union.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/eq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nosubset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/nq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/re-eq.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/rel/re-subset.icc +174 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/rel/subset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence.hh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/common.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq-u.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/sequence/seq.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/delta.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/integerset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/iter.icc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var-imp/set.cc +215 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var-imp/set.vis +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/var/set.cc +0 -0
- data/ext/gecode-2.2.0/gecode/set/var/set.icc +303 -0
- data/ext/gecode-2.2.0/gecode/set/view.icc +1451 -0
- data/ext/gecode-2.2.0/gecode/set/view/complement.icc +614 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/const.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/offset.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/print.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/set.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/set/view/singleton.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support.hh +0 -0
- data/ext/gecode-2.2.0/gecode/support/block-allocator.icc +159 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/AUTHORS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/ChangeLog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/NEWS +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/README +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddio.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddop.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bddtree.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/bvec.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cache.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/config.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/cppext.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/fdd.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/imatrix.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/kernel.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/pairs.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/prime.h +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/reorder.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/buddy/tree.c +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/cast.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/config.icc.in +83 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-array.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/dynamic-stack.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.cc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/exception.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/macros.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/map.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/marked-pointer.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/memory.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/random.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/sentinel-stack.icc +138 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/sort.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-pqueue.icc +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/gecode/support/static-stack.icc +0 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.cc +241 -0
- data/ext/gecode-2.2.0/gecode/support/symbol.icc +134 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/install-sh +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/AppleHelpbookInfo.plist +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/allexamples.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/Makefile.am +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/changelog +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/control +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/copyright +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.info +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.install +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/gecode.spec +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/debian/rules +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/back.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/footer.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/gecode-logo-100.png +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/header.html +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/doxygen/stylesheet.css +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/fixproperties.sh +0 -0
- data/ext/gecode-2.2.0/misc/gecode-gist.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-minimodel.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-search.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode-serialization.pc.in +45 -0
- data/ext/gecode-2.2.0/misc/gecode.pc.in +45 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genchangelog.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlcovmakefile.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genlicense.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/genregistry.perl +0 -0
- data/ext/gecode-2.2.0/misc/genstatistics.perl +179 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/gentxtchangelog.perl +0 -0
- data/ext/gecode-2.2.0/misc/genvariables.perl +905 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/getrevision.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/makedepend.perl +0 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/misc/svn-ignore.txt +0 -0
- data/ext/gecode-2.2.0/test/assign.cc +181 -0
- data/ext/gecode-2.2.0/test/assign.hh +93 -0
- data/ext/gecode-2.2.0/test/assign/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/assign/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch.cc +563 -0
- data/ext/gecode-2.2.0/test/branch.hh +144 -0
- data/ext/gecode-2.2.0/test/branch/bool.cc +61 -0
- data/ext/gecode-2.2.0/test/branch/cpltset.cc +71 -0
- data/ext/gecode-2.2.0/test/branch/int.cc +70 -0
- data/ext/gecode-2.2.0/test/branch/set.cc +74 -0
- data/ext/gecode-2.2.0/test/cpltset.cc +568 -0
- data/ext/gecode-2.2.0/test/cpltset.hh +125 -0
- data/ext/gecode-2.2.0/test/cpltset/atmost.cc +155 -0
- data/ext/gecode-2.2.0/test/cpltset/cardinality.cc +138 -0
- data/ext/gecode-2.2.0/test/cpltset/dom.cc +137 -0
- data/ext/gecode-2.2.0/test/cpltset/partition.cc +210 -0
- data/ext/gecode-2.2.0/test/cpltset/rel.cc +158 -0
- data/ext/gecode-2.2.0/test/cpltset/select.cc +216 -0
- data/ext/gecode-2.2.0/test/int.cc +688 -0
- data/ext/gecode-2.2.0/test/int.hh +267 -0
- data/ext/gecode-2.2.0/test/int.icc +266 -0
- data/ext/gecode-2.2.0/test/int/arithmetic.cc +766 -0
- data/ext/gecode-2.2.0/test/int/basic.cc +77 -0
- data/ext/gecode-2.2.0/test/int/bool.cc +340 -0
- data/ext/gecode-2.2.0/test/int/channel.cc +238 -0
- data/ext/gecode-2.2.0/test/int/circuit.cc +100 -0
- data/ext/gecode-2.2.0/test/int/count.cc +357 -0
- data/ext/gecode-2.2.0/test/int/distinct.cc +248 -0
- data/ext/gecode-2.2.0/test/int/dom.cc +123 -0
- data/ext/gecode-2.2.0/test/int/element.cc +333 -0
- data/ext/gecode-2.2.0/test/int/extensional.cc +475 -0
- data/ext/gecode-2.2.0/test/int/gcc.cc +293 -0
- data/ext/gecode-2.2.0/test/int/linear.cc +383 -0
- data/ext/gecode-2.2.0/test/int/mm-arithmetic.cc +302 -0
- data/ext/gecode-2.2.0/test/int/mm-bool.cc +4342 -0
- data/ext/gecode-2.2.0/test/int/mm-count.cc +295 -0
- data/ext/gecode-2.2.0/test/int/mm-lin.cc +2035 -0
- data/ext/gecode-2.2.0/test/int/mm-rel.cc +136 -0
- data/ext/gecode-2.2.0/test/int/rel.cc +416 -0
- data/ext/gecode-2.2.0/test/int/scheduling.cc +276 -0
- data/ext/gecode-2.2.0/test/int/sorted.cc +165 -0
- data/ext/gecode-2.2.0/test/int/unshare.cc +109 -0
- data/ext/gecode-2.2.0/test/search.cc +618 -0
- data/ext/gecode-2.2.0/test/set.cc +753 -0
- data/ext/gecode-2.2.0/test/set.hh +286 -0
- data/ext/gecode-2.2.0/test/set.icc +108 -0
- data/ext/gecode-2.2.0/test/set/convex.cc +139 -0
- data/ext/gecode-2.2.0/test/set/distinct.cc +116 -0
- data/ext/gecode-2.2.0/test/set/dom.cc +292 -0
- data/ext/gecode-2.2.0/test/set/int.cc +473 -0
- data/ext/gecode-2.2.0/test/set/projection.cc +436 -0
- data/ext/gecode-2.2.0/test/set/rel-op-const.cc +368 -0
- data/ext/gecode-2.2.0/test/set/rel-op.cc +465 -0
- data/ext/gecode-2.2.0/test/set/rel.cc +125 -0
- data/ext/gecode-2.2.0/test/set/select.cc +299 -0
- data/ext/gecode-2.2.0/test/set/sequence.cc +125 -0
- data/ext/gecode-2.2.0/test/test.cc +287 -0
- data/ext/gecode-2.2.0/test/test.hh +175 -0
- data/ext/gecode-2.2.0/test/test.icc +93 -0
- data/ext/{gecode-2.1.1 → gecode-2.2.0}/variables.vsl +0 -0
- data/lib/gecoder/bindings.rb +7 -5
- data/lib/gecoder/bindings/bindings.rb +8 -8
- data/lib/gecoder/interface.rb +4 -2
- data/lib/gecoder/interface/binding_changes.rb +1 -1
- data/lib/gecoder/interface/branch.rb +1 -1
- data/lib/gecoder/interface/constraints/bool_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/bool_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/extensional_regexp.rb +1 -1
- data/lib/gecoder/interface/constraints/fixnum_enum_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/int_enum/extensional.rb +5 -5
- data/lib/gecoder/interface/constraints/int_enum_constraints.rb +4 -4
- data/lib/gecoder/interface/constraints/int_var_constraints.rb +2 -2
- data/lib/gecoder/interface/constraints/selected_set/select.rb +8 -8
- data/lib/gecoder/interface/constraints/set_enum/element.rb +79 -0
- data/lib/gecoder/interface/constraints/set_enum_constraints.rb +5 -5
- data/lib/gecoder/interface/constraints/set_var_constraints.rb +2 -2
- data/lib/gecoder/interface/convenience.rb +99 -0
- data/lib/gecoder/interface/enum_wrapper.rb +1 -1
- data/lib/gecoder/interface/mixin.rb +486 -0
- data/lib/gecoder/interface/search.rb +23 -22
- data/lib/gecoder/version.rb +1 -1
- data/specs/branch.rb +5 -3
- data/specs/constraints/bool/boolean.rb +3 -1
- data/specs/constraints/bool/linear.rb +3 -1
- data/specs/constraints/bool_enum/bool_enum_relation.rb +3 -1
- data/specs/constraints/bool_enum/channel.rb +3 -1
- data/specs/constraints/fixnum_enum/element.rb +3 -1
- data/specs/constraints/int/arithmetic.rb +3 -1
- data/specs/constraints/int/channel.rb +3 -1
- data/specs/constraints/int/linear.rb +3 -1
- data/specs/constraints/int/linear_properties.rb +3 -1
- data/specs/constraints/int_enum/arithmetic.rb +3 -1
- data/specs/constraints/int_enum/channel.rb +3 -1
- data/specs/constraints/int_enum/count.rb +3 -1
- data/specs/constraints/int_enum/distinct.rb +3 -1
- data/specs/constraints/int_enum/element.rb +3 -1
- data/specs/constraints/int_enum/sort.rb +3 -1
- data/specs/constraints/property_helper.rb +10 -10
- data/specs/constraints/reification_sugar.rb +3 -1
- data/specs/constraints/selected_set/select.rb +6 -5
- data/specs/constraints/selected_set/select_properties.rb +12 -10
- data/specs/constraints/set/channel.rb +3 -1
- data/specs/constraints/set/domain.rb +4 -4
- data/specs/constraints/set/relation.rb +4 -4
- data/specs/constraints/set_enum/channel.rb +3 -1
- data/specs/constraints/set_enum/distinct.rb +3 -1
- data/specs/constraints/set_enum/element.rb +77 -0
- data/specs/enum_wrapper.rb +1 -1
- data/specs/mixin.rb +78 -0
- data/specs/model.rb +5 -5
- data/specs/search.rb +20 -14
- data/specs/selected_set.rb +3 -3
- data/specs/set_elements.rb +2 -2
- data/tasks/distribution.rake +25 -4
- metadata +739 -602
- data/example/money.rb +0 -36
- data/ext/gecode-2.1.1/Makefile.dep +0 -7622
- data/ext/gecode-2.1.1/Makefile.in +0 -1568
- data/ext/gecode-2.1.1/changelog.in +0 -2459
- data/ext/gecode-2.1.1/configure +0 -11631
- data/ext/gecode-2.1.1/configure.ac +0 -249
- data/ext/gecode-2.1.1/configure.ac.in +0 -245
- data/ext/gecode-2.1.1/contribs/qecode/Doxyfile +0 -263
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.cc +0 -82
- data/ext/gecode-2.1.1/contribs/qecode/FirstFailValueHeuristic.hh +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/Makefile.in.in +0 -162
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.cc +0 -172
- data/ext/gecode-2.1.1/contribs/qecode/NaiveValueHeuristics.hh +0 -63
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.cc +0 -37
- data/ext/gecode-2.1.1/contribs/qecode/SDFVariableHeuristic.hh +0 -35
- data/ext/gecode-2.1.1/contribs/qecode/configure +0 -2264
- data/ext/gecode-2.1.1/contribs/qecode/configure.ac +0 -23
- data/ext/gecode-2.1.1/contribs/qecode/examples/COMPILING +0 -13
- data/ext/gecode-2.1.1/contribs/qecode/examples/MatrixGame.cpp +0 -144
- data/ext/gecode-2.1.1/contribs/qecode/examples/NimFibo.cpp +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/examples/stress_test.cpp +0 -179
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.cc +0 -34
- data/ext/gecode-2.1.1/contribs/qecode/extensivecomparator.hh +0 -46
- data/ext/gecode-2.1.1/contribs/qecode/implicative.cc +0 -595
- data/ext/gecode-2.1.1/contribs/qecode/implicative.hh +0 -184
- data/ext/gecode-2.1.1/contribs/qecode/myspace.hh +0 -69
- data/ext/gecode-2.1.1/contribs/qecode/qecore.cc +0 -145
- data/ext/gecode-2.1.1/contribs/qecode/qecore.hh +0 -247
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.cc +0 -168
- data/ext/gecode-2.1.1/contribs/qecode/qsolver.hh +0 -73
- data/ext/gecode-2.1.1/contribs/qecode/valueHeuristic.hh +0 -91
- data/ext/gecode-2.1.1/contribs/qecode/warner.cc +0 -101
- data/ext/gecode-2.1.1/contribs/qecode/warner.hh +0 -83
- data/ext/gecode-2.1.1/doxygen/doxygen.hh.in +0 -1111
- data/ext/gecode-2.1.1/doxygen/reflection.hh +0 -417
- data/ext/gecode-2.1.1/gecode.m4 +0 -956
- data/ext/gecode-2.1.1/gecode/cpltset.hh +0 -797
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.cc +0 -115
- data/ext/gecode-2.1.1/gecode/gist/analysiscursor.hh +0 -77
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.cc +0 -245
- data/ext/gecode-2.1.1/gecode/gist/drawingcursor.hh +0 -101
- data/ext/gecode-2.1.1/gecode/gist/gecodelogo.icc +0 -522
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.cc +0 -254
- data/ext/gecode-2.1.1/gecode/gist/mainwindow.hh +0 -86
- data/ext/gecode-2.1.1/gecode/gist/node.cc +0 -100
- data/ext/gecode-2.1.1/gecode/gist/node.hh +0 -89
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.cc +0 -124
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.hh +0 -122
- data/ext/gecode-2.1.1/gecode/gist/nodecursor.icc +0 -79
- data/ext/gecode-2.1.1/gecode/gist/postscript.cc +0 -543
- data/ext/gecode-2.1.1/gecode/gist/postscript.hh +0 -56
- data/ext/gecode-2.1.1/gecode/gist/preferences.cc +0 -110
- data/ext/gecode-2.1.1/gecode/gist/preferences.hh +0 -76
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.cc +0 -55
- data/ext/gecode-2.1.1/gecode/gist/reflectionhelpers.hh +0 -58
- data/ext/gecode-2.1.1/gecode/gist/shapelist.cc +0 -331
- data/ext/gecode-2.1.1/gecode/gist/shapelist.hh +0 -140
- data/ext/gecode-2.1.1/gecode/gist/spacenode.cc +0 -531
- data/ext/gecode-2.1.1/gecode/gist/spacenode.hh +0 -224
- data/ext/gecode-2.1.1/gecode/gist/textoutput.cc +0 -114
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.cc +0 -1140
- data/ext/gecode-2.1.1/gecode/gist/treecanvas.hh +0 -324
- data/ext/gecode-2.1.1/gecode/gist/ui_addvisualisationdialog.hh +0 -163
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.cc +0 -175
- data/ext/gecode-2.1.1/gecode/gist/visualisation/intvaritem.hh +0 -71
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.cc +0 -219
- data/ext/gecode-2.1.1/gecode/gist/visualisation/setvaritem.hh +0 -73
- data/ext/gecode-2.1.1/gecode/gist/visualisation/vararrayitem.hh +0 -123
- data/ext/gecode-2.1.1/gecode/gist/visualnode.cc +0 -303
- data/ext/gecode-2.1.1/gecode/gist/visualnode.hh +0 -166
- data/ext/gecode-2.1.1/gecode/int.hh +0 -2035
- data/ext/gecode-2.1.1/gecode/int/arithmetic.cc +0 -136
- data/ext/gecode-2.1.1/gecode/int/arithmetic.hh +0 -440
- data/ext/gecode-2.1.1/gecode/int/arithmetic/abs.icc +0 -279
- data/ext/gecode-2.1.1/gecode/int/arithmetic/max.icc +0 -253
- data/ext/gecode-2.1.1/gecode/int/arithmetic/mult.icc +0 -522
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqr.icc +0 -218
- data/ext/gecode-2.1.1/gecode/int/arithmetic/sqrt.icc +0 -138
- data/ext/gecode-2.1.1/gecode/int/bool.cc +0 -642
- data/ext/gecode-2.1.1/gecode/int/bool/or.icc +0 -1000
- data/ext/gecode-2.1.1/gecode/int/branch.cc +0 -301
- data/ext/gecode-2.1.1/gecode/int/branch.hh +0 -576
- data/ext/gecode-2.1.1/gecode/int/branch/select-val.icc +0 -338
- data/ext/gecode-2.1.1/gecode/int/channel.cc +0 -114
- data/ext/gecode-2.1.1/gecode/int/channel.hh +0 -259
- data/ext/gecode-2.1.1/gecode/int/channel/dom.icc +0 -347
- data/ext/gecode-2.1.1/gecode/int/channel/val.icc +0 -276
- data/ext/gecode-2.1.1/gecode/int/circuit.hh +0 -175
- data/ext/gecode-2.1.1/gecode/int/circuit/base.icc +0 -271
- data/ext/gecode-2.1.1/gecode/int/circuit/val.icc +0 -122
- data/ext/gecode-2.1.1/gecode/int/count.hh +0 -487
- data/ext/gecode-2.1.1/gecode/int/count/int.icc +0 -619
- data/ext/gecode-2.1.1/gecode/int/count/rel.icc +0 -144
- data/ext/gecode-2.1.1/gecode/int/count/view.icc +0 -449
- data/ext/gecode-2.1.1/gecode/int/cumulatives.hh +0 -141
- data/ext/gecode-2.1.1/gecode/int/cumulatives/val.icc +0 -429
- data/ext/gecode-2.1.1/gecode/int/distinct.hh +0 -341
- data/ext/gecode-2.1.1/gecode/int/distinct/dom.icc +0 -750
- data/ext/gecode-2.1.1/gecode/int/distinct/ter-dom.icc +0 -136
- data/ext/gecode-2.1.1/gecode/int/element.hh +0 -239
- data/ext/gecode-2.1.1/gecode/int/element/int.icc +0 -441
- data/ext/gecode-2.1.1/gecode/int/element/view.icc +0 -584
- data/ext/gecode-2.1.1/gecode/int/exception.icc +0 -163
- data/ext/gecode-2.1.1/gecode/int/extensional.hh +0 -415
- data/ext/gecode-2.1.1/gecode/int/extensional/dfa.cc +0 -565
- data/ext/gecode-2.1.1/gecode/int/extensional/tuple-set.cc +0 -311
- data/ext/gecode-2.1.1/gecode/int/gcc.hh +0 -329
- data/ext/gecode-2.1.1/gecode/int/gcc/bnd.icc +0 -660
- data/ext/gecode-2.1.1/gecode/int/gcc/dom.icc +0 -531
- data/ext/gecode-2.1.1/gecode/int/gcc/val.icc +0 -400
- data/ext/gecode-2.1.1/gecode/int/int-set.cc +0 -153
- data/ext/gecode-2.1.1/gecode/int/int-set.icc +0 -191
- data/ext/gecode-2.1.1/gecode/int/linear-bool.cc +0 -220
- data/ext/gecode-2.1.1/gecode/int/linear-int.cc +0 -240
- data/ext/gecode-2.1.1/gecode/int/linear.hh +0 -1849
- data/ext/gecode-2.1.1/gecode/int/linear/bool-post.cc +0 -433
- data/ext/gecode-2.1.1/gecode/int/linear/int-bin.icc +0 -605
- data/ext/gecode-2.1.1/gecode/int/linear/int-dom.icc +0 -539
- data/ext/gecode-2.1.1/gecode/int/linear/int-post.cc +0 -493
- data/ext/gecode-2.1.1/gecode/int/rel.cc +0 -431
- data/ext/gecode-2.1.1/gecode/int/rel.hh +0 -657
- data/ext/gecode-2.1.1/gecode/int/rel/eq.icc +0 -848
- data/ext/gecode-2.1.1/gecode/int/rel/lex.icc +0 -248
- data/ext/gecode-2.1.1/gecode/int/rel/nq.icc +0 -269
- data/ext/gecode-2.1.1/gecode/int/sorted.cc +0 -91
- data/ext/gecode-2.1.1/gecode/int/sorted.hh +0 -117
- data/ext/gecode-2.1.1/gecode/int/sorted/matching.icc +0 -182
- data/ext/gecode-2.1.1/gecode/int/sorted/narrowing.icc +0 -257
- data/ext/gecode-2.1.1/gecode/int/sorted/order.icc +0 -208
- data/ext/gecode-2.1.1/gecode/int/sorted/propagate.icc +0 -669
- data/ext/gecode-2.1.1/gecode/int/sorted/sortsup.icc +0 -596
- data/ext/gecode-2.1.1/gecode/int/var-imp.icc +0 -745
- data/ext/gecode-2.1.1/gecode/int/var-imp/bool.cc +0 -104
- data/ext/gecode-2.1.1/gecode/int/var-imp/int.cc +0 -407
- data/ext/gecode-2.1.1/gecode/int/var/bool.icc +0 -126
- data/ext/gecode-2.1.1/gecode/int/var/int.icc +0 -151
- data/ext/gecode-2.1.1/gecode/int/view.icc +0 -1894
- data/ext/gecode-2.1.1/gecode/iter.hh +0 -90
- data/ext/gecode-2.1.1/gecode/iter/values-minus.icc +0 -130
- data/ext/gecode-2.1.1/gecode/kernel.hh +0 -182
- data/ext/gecode-2.1.1/gecode/kernel/branching.icc +0 -447
- data/ext/gecode-2.1.1/gecode/kernel/core.cc +0 -473
- data/ext/gecode-2.1.1/gecode/kernel/core.icc +0 -2295
- data/ext/gecode-2.1.1/gecode/kernel/memory-manager.icc +0 -458
- data/ext/gecode-2.1.1/gecode/kernel/reflection.cc +0 -921
- data/ext/gecode-2.1.1/gecode/kernel/reflection.icc +0 -1012
- data/ext/gecode-2.1.1/gecode/kernel/var-imp.icc +0 -433
- data/ext/gecode-2.1.1/gecode/kernel/var-map.cc +0 -269
- data/ext/gecode-2.1.1/gecode/kernel/var-map.icc +0 -227
- data/ext/gecode-2.1.1/gecode/kernel/var-traits.icc +0 -72
- data/ext/gecode-2.1.1/gecode/kernel/var-type.icc +0 -915
- data/ext/gecode-2.1.1/gecode/kernel/var.icc +0 -120
- data/ext/gecode-2.1.1/gecode/kernel/view.icc +0 -611
- data/ext/gecode-2.1.1/gecode/minimodel.hh +0 -1165
- data/ext/gecode-2.1.1/gecode/minimodel/arithmetic.cc +0 -179
- data/ext/gecode-2.1.1/gecode/search.hh +0 -752
- data/ext/gecode-2.1.1/gecode/search/reco-stack.icc +0 -237
- data/ext/gecode-2.1.1/gecode/serialization.hh +0 -149
- data/ext/gecode-2.1.1/gecode/serialization/boost.cc +0 -78
- data/ext/gecode-2.1.1/gecode/serialization/javascript.cc +0 -340
- data/ext/gecode-2.1.1/gecode/serialization/register.cc +0 -8142
- data/ext/gecode-2.1.1/gecode/set.hh +0 -970
- data/ext/gecode-2.1.1/gecode/set/projectors.hh +0 -438
- data/ext/gecode-2.1.1/gecode/set/projectors/formula.cc +0 -312
- data/ext/gecode-2.1.1/gecode/set/rel-op/common.icc +0 -557
- data/ext/gecode-2.1.1/gecode/set/rel-op/inter.icc +0 -409
- data/ext/gecode-2.1.1/gecode/set/rel/re-subset.icc +0 -172
- data/ext/gecode-2.1.1/gecode/set/select.cc +0 -135
- data/ext/gecode-2.1.1/gecode/set/select.hh +0 -233
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.cc +0 -308
- data/ext/gecode-2.1.1/gecode/set/select/disjoint.icc +0 -75
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.hh +0 -113
- data/ext/gecode-2.1.1/gecode/set/select/idxarray.icc +0 -155
- data/ext/gecode-2.1.1/gecode/set/select/inter.icc +0 -349
- data/ext/gecode-2.1.1/gecode/set/select/union.icc +0 -371
- data/ext/gecode-2.1.1/gecode/set/select/unionConst.icc +0 -334
- data/ext/gecode-2.1.1/gecode/set/var-imp/set.cc +0 -214
- data/ext/gecode-2.1.1/gecode/set/var/set.icc +0 -303
- data/ext/gecode-2.1.1/gecode/set/view.icc +0 -1503
- data/ext/gecode-2.1.1/gecode/set/view/complement.icc +0 -629
- data/ext/gecode-2.1.1/gecode/support/block-allocator.icc +0 -158
- data/ext/gecode-2.1.1/gecode/support/config.icc.in +0 -80
- data/ext/gecode-2.1.1/gecode/support/sentinel-stack.icc +0 -122
- data/ext/gecode-2.1.1/gecode/support/symbol.cc +0 -226
- data/ext/gecode-2.1.1/gecode/support/symbol.icc +0 -130
- data/ext/gecode-2.1.1/misc/gecode-gist.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-minimodel.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-search.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode-serialization.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/gecode.pc.in +0 -45
- data/ext/gecode-2.1.1/misc/genstatistics.perl +0 -178
- data/ext/gecode-2.1.1/misc/genvariables.perl +0 -905
- data/lib/gecoder/interface/constraints/set_enum/select.rb +0 -79
- data/lib/gecoder/interface/model.rb +0 -453
- data/lib/gecoder/interface/model_sugar.rb +0 -84
- data/specs/constraints/set_enum/select.rb +0 -73
@@ -1,1849 +0,0 @@
|
|
1
|
-
/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
|
2
|
-
/*
|
3
|
-
* Main authors:
|
4
|
-
* Christian Schulte <schulte@gecode.org>
|
5
|
-
* Guido Tack <tack@gecode.org>
|
6
|
-
*
|
7
|
-
* Copyright:
|
8
|
-
* Christian Schulte, 2002
|
9
|
-
* Guido Tack, 2004
|
10
|
-
*
|
11
|
-
* Last modified:
|
12
|
-
* $Date: 2008-03-06 10:39:58 +0100 (Thu, 06 Mar 2008) $ by $Author: tack $
|
13
|
-
* $Revision: 6446 $
|
14
|
-
*
|
15
|
-
* This file is part of Gecode, the generic constraint
|
16
|
-
* development environment:
|
17
|
-
* http://www.gecode.org
|
18
|
-
*
|
19
|
-
* Permission is hereby granted, free of charge, to any person obtaining
|
20
|
-
* a copy of this software and associated documentation files (the
|
21
|
-
* "Software"), to deal in the Software without restriction, including
|
22
|
-
* without limitation the rights to use, copy, modify, merge, publish,
|
23
|
-
* distribute, sublicense, and/or sell copies of the Software, and to
|
24
|
-
* permit persons to whom the Software is furnished to do so, subject to
|
25
|
-
* the following conditions:
|
26
|
-
*
|
27
|
-
* The above copyright notice and this permission notice shall be
|
28
|
-
* included in all copies or substantial portions of the Software.
|
29
|
-
*
|
30
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
31
|
-
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
32
|
-
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
33
|
-
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
34
|
-
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
35
|
-
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
36
|
-
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
37
|
-
*
|
38
|
-
*/
|
39
|
-
|
40
|
-
#ifndef __GECODE_INT_LINEAR_HH__
|
41
|
-
#define __GECODE_INT_LINEAR_HH__
|
42
|
-
|
43
|
-
#include "gecode/int.hh"
|
44
|
-
|
45
|
-
/**
|
46
|
-
* \namespace Gecode::Int::Linear
|
47
|
-
* \brief %Linear propagators
|
48
|
-
*/
|
49
|
-
|
50
|
-
namespace Gecode { namespace Int { namespace Linear {
|
51
|
-
|
52
|
-
/*
|
53
|
-
* Binary propagators
|
54
|
-
*
|
55
|
-
*/
|
56
|
-
|
57
|
-
/**
|
58
|
-
* \brief Base-class for binary linear propagators
|
59
|
-
*
|
60
|
-
* The type \a Val can be either \c double or \c int, defining the
|
61
|
-
* numerical precision during propagation. The types \a A and \a B
|
62
|
-
* give the types of the views.
|
63
|
-
*
|
64
|
-
* The propagation condition \a pc refers to both views.
|
65
|
-
*/
|
66
|
-
template <class Val, class A, class B, PropCond pc>
|
67
|
-
class LinBin : public Propagator {
|
68
|
-
protected:
|
69
|
-
/// View of type \a A
|
70
|
-
A x0;
|
71
|
-
/// View of type \a B
|
72
|
-
B x1;
|
73
|
-
/// Value of type \a Val
|
74
|
-
Val c;
|
75
|
-
/// Constructor for cloning \a p
|
76
|
-
LinBin(Space* home, bool share, LinBin& p);
|
77
|
-
/// Constructor for rewriting \a p during cloning
|
78
|
-
LinBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
|
79
|
-
/// Constructor for creation
|
80
|
-
LinBin(Space* home, A x0, B x1, Val c);
|
81
|
-
/// Return specification for this propagator given a variable map \a m
|
82
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
83
|
-
const Support::Symbol& name) const;
|
84
|
-
public:
|
85
|
-
/// Cost function (defined as PC_BINARY_LO)
|
86
|
-
virtual PropCost cost(ModEventDelta med) const;
|
87
|
-
/// Delete propagator and return its size
|
88
|
-
virtual size_t dispose(Space* home);
|
89
|
-
};
|
90
|
-
|
91
|
-
/**
|
92
|
-
* \brief Base-class for reified binary linear propagators
|
93
|
-
*
|
94
|
-
* The type \a Val can be either \c double or \c int, defining the
|
95
|
-
* numerical precision during propagation. The types \a A and \a B
|
96
|
-
* give the types of the views.
|
97
|
-
*
|
98
|
-
* The propagation condition \a pc refers to both views.
|
99
|
-
*/
|
100
|
-
template <class Val, class A, class B, PropCond pc, class Ctrl>
|
101
|
-
class ReLinBin : public Propagator {
|
102
|
-
protected:
|
103
|
-
/// View of type \a A
|
104
|
-
A x0;
|
105
|
-
/// View of type \a B
|
106
|
-
B x1;
|
107
|
-
/// Value of type \a Val
|
108
|
-
Val c;
|
109
|
-
/// Control view for reification
|
110
|
-
Ctrl b;
|
111
|
-
/// Constructor for cloning \a p
|
112
|
-
ReLinBin(Space* home, bool share, ReLinBin& p);
|
113
|
-
/// Constructor for creation
|
114
|
-
ReLinBin(Space* home, A x0, B x1, Val c, Ctrl b);
|
115
|
-
/// Return specification for this propagator given a variable map \a m
|
116
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
117
|
-
const Support::Symbol& name) const;
|
118
|
-
public:
|
119
|
-
/// Cost function (defined as PC_BINARY_LO)
|
120
|
-
virtual PropCost cost(ModEventDelta med) const;
|
121
|
-
/// Delete propagator and return its size
|
122
|
-
virtual size_t dispose(Space* home);
|
123
|
-
};
|
124
|
-
|
125
|
-
/**
|
126
|
-
* \brief %Propagator for bounds-consistent binary linear equality
|
127
|
-
*
|
128
|
-
* The type \a Val can be either \c double or \c int, defining the
|
129
|
-
* numerical precision during propagation. The types \a A and \a B
|
130
|
-
* give the types of the views.
|
131
|
-
*
|
132
|
-
* The propagation condition \a pc refers to both views.
|
133
|
-
*
|
134
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
135
|
-
* \ingroup FuncIntProp
|
136
|
-
*/
|
137
|
-
template <class Val, class A, class B>
|
138
|
-
class EqBin : public LinBin<Val,A,B,PC_INT_BND> {
|
139
|
-
protected:
|
140
|
-
using LinBin<Val,A,B,PC_INT_BND>::x0;
|
141
|
-
using LinBin<Val,A,B,PC_INT_BND>::x1;
|
142
|
-
using LinBin<Val,A,B,PC_INT_BND>::c;
|
143
|
-
|
144
|
-
/// Constructor for cloning \a p
|
145
|
-
EqBin(Space* home, bool share, EqBin& p);
|
146
|
-
/// Constructor for creation
|
147
|
-
EqBin(Space* home, A x0, B x1, Val c);
|
148
|
-
public:
|
149
|
-
/// Constructor for rewriting \a p during cloning
|
150
|
-
EqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
|
151
|
-
/// Create copy during cloning
|
152
|
-
virtual Actor* copy(Space* home, bool share);
|
153
|
-
/// Perform propagation
|
154
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
155
|
-
/// Specification for this propagator
|
156
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
157
|
-
Reflection::VarMap& m) const;
|
158
|
-
/// Post propagator according to specification
|
159
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
160
|
-
const Reflection::ActorSpec& spec);
|
161
|
-
/// Mangled propagator name
|
162
|
-
static Support::Symbol ati(void);
|
163
|
-
/// Post propagator for \f$x_0+x_1 = c\f$
|
164
|
-
static ExecStatus post(Space* home, A x0, B x1, Val c);
|
165
|
-
};
|
166
|
-
|
167
|
-
/**
|
168
|
-
* \brief %Propagator for reified bounds-consistent binary linear equality
|
169
|
-
*
|
170
|
-
* The type \a Val can be either \c double or \c int, defining the
|
171
|
-
* numerical precision during propagation. The types \a A and \a B
|
172
|
-
* give the types of the views.
|
173
|
-
*
|
174
|
-
* The propagation condition \a pc refers to both views.
|
175
|
-
*
|
176
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
177
|
-
* \ingroup FuncIntProp
|
178
|
-
*/
|
179
|
-
template <class Val, class A, class B, class Ctrl>
|
180
|
-
class ReEqBin : public ReLinBin<Val,A,B,PC_INT_BND,Ctrl> {
|
181
|
-
protected:
|
182
|
-
using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::x0;
|
183
|
-
using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::x1;
|
184
|
-
using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::c;
|
185
|
-
using ReLinBin<Val,A,B,PC_INT_BND,Ctrl>::b;
|
186
|
-
|
187
|
-
/// Constructor for cloning \a p
|
188
|
-
ReEqBin(Space* home, bool share, ReEqBin& p);
|
189
|
-
/// Constructor for creation
|
190
|
-
ReEqBin(Space* home,A,B,Val,Ctrl);
|
191
|
-
public:
|
192
|
-
/// Create copy during cloning
|
193
|
-
virtual Actor* copy(Space* home, bool share);
|
194
|
-
/// Perform propagation
|
195
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
196
|
-
/// Specification for this propagator
|
197
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
198
|
-
Reflection::VarMap& m) const;
|
199
|
-
/// Post propagator according to specification
|
200
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
201
|
-
const Reflection::ActorSpec& spec);
|
202
|
-
/// Mangled propagator name
|
203
|
-
static Support::Symbol ati(void);
|
204
|
-
/// Post propagator for \f$(x_0+x_1 = c)\Leftrightarrow b\f$
|
205
|
-
static ExecStatus post(Space* home, A x0, B x1, Val c, Ctrl b);
|
206
|
-
};
|
207
|
-
|
208
|
-
/**
|
209
|
-
* \brief %Propagator for bounds-consistent binary linear disequality
|
210
|
-
*
|
211
|
-
* The type \a Val can be either \c double or \c int, defining the
|
212
|
-
* numerical precision during propagation. The types \a A and \a B
|
213
|
-
* give the types of the views.
|
214
|
-
*
|
215
|
-
* The propagation condition \a pc refers to both views.
|
216
|
-
*
|
217
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
218
|
-
* \ingroup FuncIntProp
|
219
|
-
*/
|
220
|
-
template <class Val, class A, class B>
|
221
|
-
class NqBin : public LinBin<Val,A,B,PC_INT_VAL> {
|
222
|
-
protected:
|
223
|
-
using LinBin<Val,A,B,PC_INT_VAL>::x0;
|
224
|
-
using LinBin<Val,A,B,PC_INT_VAL>::x1;
|
225
|
-
using LinBin<Val,A,B,PC_INT_VAL>::c;
|
226
|
-
|
227
|
-
/// Constructor for cloning \a p
|
228
|
-
NqBin(Space* home, bool share, NqBin& p);
|
229
|
-
/// Constructor for creation
|
230
|
-
NqBin(Space* home, A x0, B x1, Val c);
|
231
|
-
public:
|
232
|
-
/// Constructor for rewriting \a p during cloning
|
233
|
-
NqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
|
234
|
-
/// Create copy during cloning
|
235
|
-
virtual Actor* copy(Space* home, bool share);
|
236
|
-
/// Perform propagation
|
237
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
238
|
-
/// Cost function (defined as PC_UNARY_LO)
|
239
|
-
virtual PropCost cost(ModEventDelta med) const;
|
240
|
-
/// Specification for this propagator
|
241
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
242
|
-
Reflection::VarMap& m) const;
|
243
|
-
/// Post propagator according to specification
|
244
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
245
|
-
const Reflection::ActorSpec& spec);
|
246
|
-
/// Mangled propagator name
|
247
|
-
static Support::Symbol ati(void);
|
248
|
-
/// Post propagator for \f$x_0+x_1 \neq c\f$
|
249
|
-
static ExecStatus post(Space* home, A x0, B x1, Val c);
|
250
|
-
};
|
251
|
-
|
252
|
-
/**
|
253
|
-
* \brief %Propagator for bounds-consistent binary linear less or equal
|
254
|
-
*
|
255
|
-
* The type \a Val can be either \c double or \c int, defining the
|
256
|
-
* numerical precision during propagation. The types \a A and \a B
|
257
|
-
* give the types of the views.
|
258
|
-
*
|
259
|
-
* The propagation condition \a pc refers to both views.
|
260
|
-
*
|
261
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
262
|
-
* \ingroup FuncIntProp
|
263
|
-
*/
|
264
|
-
template <class Val, class A, class B>
|
265
|
-
class LqBin : public LinBin<Val,A,B,PC_INT_BND> {
|
266
|
-
protected:
|
267
|
-
using LinBin<Val,A,B,PC_INT_BND>::x0;
|
268
|
-
using LinBin<Val,A,B,PC_INT_BND>::x1;
|
269
|
-
using LinBin<Val,A,B,PC_INT_BND>::c;
|
270
|
-
|
271
|
-
/// Constructor for cloning \a p
|
272
|
-
LqBin(Space* home, bool share, LqBin& p);
|
273
|
-
/// Constructor for creation
|
274
|
-
LqBin(Space* home, A x0, B x1, Val c);
|
275
|
-
public:
|
276
|
-
/// Constructor for rewriting \a p during cloning
|
277
|
-
LqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
|
278
|
-
/// Create copy during cloning
|
279
|
-
virtual Actor* copy(Space* home, bool share);
|
280
|
-
/// Perform propagation
|
281
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
282
|
-
/// Specification for this propagator
|
283
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
284
|
-
Reflection::VarMap& m) const;
|
285
|
-
/// Post propagator according to specification
|
286
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
287
|
-
const Reflection::ActorSpec& spec);
|
288
|
-
/// Mangled propagator name
|
289
|
-
static Support::Symbol ati(void);
|
290
|
-
/// Post propagator for \f$x_0+x_1 \leq c\f$
|
291
|
-
static ExecStatus post(Space* home, A x0, B x1, Val c);
|
292
|
-
};
|
293
|
-
|
294
|
-
/**
|
295
|
-
* \brief %Propagator for bounds-consistent binary linear greater or equal
|
296
|
-
*
|
297
|
-
* The type \a Val can be either \c double or \c int, defining the
|
298
|
-
* numerical precision during propagation. The types \a A and \a B
|
299
|
-
* give the types of the views.
|
300
|
-
*
|
301
|
-
* The propagation condition \a pc refers to both views.
|
302
|
-
*
|
303
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
304
|
-
* \ingroup FuncIntProp
|
305
|
-
*/
|
306
|
-
template <class Val, class A, class B>
|
307
|
-
class GqBin : public LinBin<Val,A,B,PC_INT_BND> {
|
308
|
-
protected:
|
309
|
-
using LinBin<Val,A,B,PC_INT_BND>::x0;
|
310
|
-
using LinBin<Val,A,B,PC_INT_BND>::x1;
|
311
|
-
using LinBin<Val,A,B,PC_INT_BND>::c;
|
312
|
-
|
313
|
-
/// Constructor for cloning \a p
|
314
|
-
GqBin(Space* home, bool share, GqBin& p);
|
315
|
-
/// Constructor for creation
|
316
|
-
GqBin(Space* home, A x0, B x1, Val c);
|
317
|
-
public:
|
318
|
-
/// Constructor for rewriting \a p during cloning
|
319
|
-
GqBin(Space* home, bool share, Propagator& p, A x0, B x1, Val c);
|
320
|
-
/// Create copy during cloning
|
321
|
-
virtual Actor* copy(Space* home, bool share);
|
322
|
-
/// Perform propagation
|
323
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
324
|
-
/// Specification for this propagator
|
325
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
326
|
-
Reflection::VarMap& m) const;
|
327
|
-
/// Post propagator according to specification
|
328
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
329
|
-
const Reflection::ActorSpec& spec);
|
330
|
-
/// Mangled propagator name
|
331
|
-
static Support::Symbol ati(void);
|
332
|
-
/// Post propagator for \f$x_0+x_1 \geq c\f$
|
333
|
-
static ExecStatus post(Space* home, A x0, B x1, Val c);
|
334
|
-
};
|
335
|
-
|
336
|
-
/**
|
337
|
-
* \brief %Propagator for reified bounds-consistent binary linear less or equal
|
338
|
-
*
|
339
|
-
* The type \a Val can be either \c double or \c int, defining the
|
340
|
-
* numerical precision during propagation. The types \a A and \a B
|
341
|
-
* give the types of the views.
|
342
|
-
*
|
343
|
-
* The propagation condition \a pc refers to both views.
|
344
|
-
*
|
345
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
346
|
-
* \ingroup FuncIntProp
|
347
|
-
*/
|
348
|
-
template <class Val, class A, class B>
|
349
|
-
class ReLqBin : public ReLinBin<Val,A,B,PC_INT_BND,BoolView> {
|
350
|
-
protected:
|
351
|
-
using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::x0;
|
352
|
-
using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::x1;
|
353
|
-
using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::c;
|
354
|
-
using ReLinBin<Val,A,B,PC_INT_BND,BoolView>::b;
|
355
|
-
|
356
|
-
/// Constructor for cloning \a p
|
357
|
-
ReLqBin(Space* home, bool share, ReLqBin& p);
|
358
|
-
/// Constructor for creation
|
359
|
-
ReLqBin(Space* home, A x0, B x1, Val c, BoolView b);
|
360
|
-
public:
|
361
|
-
/// Create copy during cloning
|
362
|
-
virtual Actor* copy(Space* home, bool share);
|
363
|
-
/// Perform propagation
|
364
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
365
|
-
/// Specification for this propagator
|
366
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
367
|
-
Reflection::VarMap& m) const;
|
368
|
-
/// Post propagator according to specification
|
369
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
370
|
-
const Reflection::ActorSpec& spec);
|
371
|
-
/// Mangled propagator name
|
372
|
-
static Support::Symbol ati(void);
|
373
|
-
/// Post propagator for \f$(x_0+x_1 \leq c)\Leftrightarrow b\f$
|
374
|
-
static ExecStatus post(Space* home, A x0, B x1, Val c, BoolView b);
|
375
|
-
};
|
376
|
-
|
377
|
-
}}}
|
378
|
-
|
379
|
-
#include "gecode/int/linear/int-bin.icc"
|
380
|
-
|
381
|
-
namespace Gecode { namespace Int { namespace Linear {
|
382
|
-
|
383
|
-
/*
|
384
|
-
* Ternary propagators
|
385
|
-
*
|
386
|
-
*/
|
387
|
-
|
388
|
-
/**
|
389
|
-
* \brief Base-class for ternary linear propagators
|
390
|
-
*
|
391
|
-
* The type \a Val can be either \c double or \c int, defining the
|
392
|
-
* numerical precision during propagation. The types \a A, \a B,
|
393
|
-
* and \a C give the types of the views.
|
394
|
-
*
|
395
|
-
* The propagation condition \a pc refers to all three views.
|
396
|
-
*/
|
397
|
-
template <class Val, class A, class B, class C, PropCond pc>
|
398
|
-
class LinTer : public Propagator {
|
399
|
-
protected:
|
400
|
-
/// View of type \a A
|
401
|
-
A x0;
|
402
|
-
/// View of type \a B
|
403
|
-
B x1;
|
404
|
-
/// View of type \a C
|
405
|
-
C x2;
|
406
|
-
/// Value of type \a Val
|
407
|
-
Val c;
|
408
|
-
/// Constructor for cloning \a p
|
409
|
-
LinTer(Space* home, bool share, LinTer& p);
|
410
|
-
/// Constructor for creation
|
411
|
-
LinTer(Space* home, A x0, B x1, C x2, Val c);
|
412
|
-
/// Constructor for rewriting \a p during cloning
|
413
|
-
LinTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
|
414
|
-
/// Return specification for this propagator given a variable map \a m
|
415
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
416
|
-
const Support::Symbol& name) const;
|
417
|
-
public:
|
418
|
-
/// Cost function (defined as PC_TERNARY_LO)
|
419
|
-
virtual PropCost cost(ModEventDelta med) const;
|
420
|
-
/// Delete propagator and return its size
|
421
|
-
virtual size_t dispose(Space* home);
|
422
|
-
};
|
423
|
-
|
424
|
-
/**
|
425
|
-
* \brief %Propagator for bounds-consistent ternary linear equality
|
426
|
-
*
|
427
|
-
* The type \a Val can be either \c double or \c int, defining the
|
428
|
-
* numerical precision during propagation. The types \a A, \a B,
|
429
|
-
* and \a C give the types of the views.
|
430
|
-
*
|
431
|
-
* The propagation condition \a pc refers to all three views.
|
432
|
-
*
|
433
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
434
|
-
* \ingroup FuncIntProp
|
435
|
-
*/
|
436
|
-
template <class Val, class A, class B, class C>
|
437
|
-
class EqTer : public LinTer<Val,A,B,C,PC_INT_BND> {
|
438
|
-
protected:
|
439
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::x0;
|
440
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::x1;
|
441
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::x2;
|
442
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::c;
|
443
|
-
|
444
|
-
/// Constructor for cloning \a p
|
445
|
-
EqTer(Space* home, bool share, EqTer& p);
|
446
|
-
/// Constructor for creation
|
447
|
-
EqTer(Space* home, A x0, B x1, C x2, Val c);
|
448
|
-
public:
|
449
|
-
/// Constructor for rewriting \a p during cloning
|
450
|
-
EqTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
|
451
|
-
/// Create copy during cloning
|
452
|
-
virtual Actor* copy(Space* home, bool share);
|
453
|
-
/// Perform propagation
|
454
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
455
|
-
/// Specification for this propagator
|
456
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
457
|
-
Reflection::VarMap& m) const;
|
458
|
-
/// Post propagator according to specification
|
459
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
460
|
-
const Reflection::ActorSpec& spec);
|
461
|
-
/// Mangled propagator name
|
462
|
-
static Support::Symbol ati(void);
|
463
|
-
/// Post propagator for \f$x_0+x_1+x_2 = c\f$
|
464
|
-
static ExecStatus post(Space* home, A x0, B x1, C x2, Val c);
|
465
|
-
};
|
466
|
-
|
467
|
-
/**
|
468
|
-
* \brief %Propagator for bounds-consistent ternary linear disquality
|
469
|
-
*
|
470
|
-
* The type \a Val can be either \c double or \c int, defining the
|
471
|
-
* numerical precision during propagation. The types \a A, \a B,
|
472
|
-
* and \a C give the types of the views.
|
473
|
-
*
|
474
|
-
* The propagation condition \a pc refers to all three views.
|
475
|
-
*
|
476
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
477
|
-
* \ingroup FuncIntProp
|
478
|
-
*/
|
479
|
-
template <class Val, class A, class B, class C>
|
480
|
-
class NqTer : public LinTer<Val,A,B,C,PC_INT_VAL> {
|
481
|
-
protected:
|
482
|
-
using LinTer<Val,A,B,C,PC_INT_VAL>::x0;
|
483
|
-
using LinTer<Val,A,B,C,PC_INT_VAL>::x1;
|
484
|
-
using LinTer<Val,A,B,C,PC_INT_VAL>::x2;
|
485
|
-
using LinTer<Val,A,B,C,PC_INT_VAL>::c;
|
486
|
-
|
487
|
-
/// Constructor for cloning \a p
|
488
|
-
NqTer(Space* home, bool share, NqTer& p);
|
489
|
-
/// Constructor for creation
|
490
|
-
NqTer(Space* home, A x0, B x1, C x2, Val c);
|
491
|
-
public:
|
492
|
-
/// Constructor for rewriting \a p during cloning
|
493
|
-
NqTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
|
494
|
-
/// Create copy during cloning
|
495
|
-
virtual Actor* copy(Space* home, bool share);
|
496
|
-
/// Perform propagation
|
497
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
498
|
-
/// Specification for this propagator
|
499
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
500
|
-
Reflection::VarMap& m) const;
|
501
|
-
/// Post propagator according to specification
|
502
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
503
|
-
const Reflection::ActorSpec& spec);
|
504
|
-
/// Mangled propagator name
|
505
|
-
static Support::Symbol ati(void);
|
506
|
-
/// Post propagator for \f$x_0+x_1+x_2 \neq c\f$
|
507
|
-
static ExecStatus post(Space* home, A x0, B x1, C x2, Val c);
|
508
|
-
};
|
509
|
-
|
510
|
-
/**
|
511
|
-
* \brief %Propagator for bounds-consistent ternary linear less or equal
|
512
|
-
*
|
513
|
-
* The type \a Val can be either \c double or \c int, defining the
|
514
|
-
* numerical precision during propagation. The types \a A, \a B,
|
515
|
-
* and \a C give the types of the views.
|
516
|
-
*
|
517
|
-
* The propagation condition \a pc refers to all three views.
|
518
|
-
*
|
519
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
520
|
-
* \ingroup FuncIntProp
|
521
|
-
*/
|
522
|
-
template <class Val, class A, class B, class C>
|
523
|
-
class LqTer : public LinTer<Val,A,B,C,PC_INT_BND> {
|
524
|
-
protected:
|
525
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::x0;
|
526
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::x1;
|
527
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::x2;
|
528
|
-
using LinTer<Val,A,B,C,PC_INT_BND>::c;
|
529
|
-
|
530
|
-
/// Constructor for cloning \a p
|
531
|
-
LqTer(Space* home, bool share, LqTer& p);
|
532
|
-
/// Constructor for creation
|
533
|
-
LqTer(Space* home, A x0, B x1, C x2, Val c);
|
534
|
-
public:
|
535
|
-
/// Constructor for rewriting \a p during cloning
|
536
|
-
LqTer(Space* home, bool share, Propagator& p, A x0, B x1, C x2, Val c);
|
537
|
-
/// Create copy during cloning
|
538
|
-
virtual Actor* copy(Space* home, bool share);
|
539
|
-
/// Perform propagation
|
540
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
541
|
-
/// Specification for this propagator
|
542
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
543
|
-
Reflection::VarMap& m) const;
|
544
|
-
/// Post propagator according to specification
|
545
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
546
|
-
const Reflection::ActorSpec& spec);
|
547
|
-
/// Mangled propagator name
|
548
|
-
static Support::Symbol ati(void);
|
549
|
-
/// Post propagator for \f$x_0+x_1+x_2 \leq c\f$
|
550
|
-
static ExecStatus post(Space* home, A x0, B x1, C x2, Val c);
|
551
|
-
};
|
552
|
-
|
553
|
-
}}}
|
554
|
-
|
555
|
-
#include "gecode/int/linear/int-ter.icc"
|
556
|
-
|
557
|
-
namespace Gecode { namespace Int { namespace Linear {
|
558
|
-
|
559
|
-
/*
|
560
|
-
* n-ary propagators
|
561
|
-
*
|
562
|
-
*/
|
563
|
-
|
564
|
-
/**
|
565
|
-
* \brief Base-class for n-ary linear propagators
|
566
|
-
*
|
567
|
-
* The type \a Val can be either \c double or \c int, defining the
|
568
|
-
* numerical precision during propagation. Positive views are of
|
569
|
-
* type \a P whereas negative views are of type \a N.
|
570
|
-
*
|
571
|
-
* The propagation condition \a pc refers to all views.
|
572
|
-
*/
|
573
|
-
template <class Val, class P, class N, PropCond pc>
|
574
|
-
class Lin : public Propagator {
|
575
|
-
protected:
|
576
|
-
/// Array of positive views
|
577
|
-
ViewArray<P> x;
|
578
|
-
/// Array of negative views
|
579
|
-
ViewArray<N> y;
|
580
|
-
/// Constant value
|
581
|
-
Val c;
|
582
|
-
|
583
|
-
/// Constructor for cloning \a p
|
584
|
-
Lin(Space* home, bool share, Lin& p);
|
585
|
-
/// Constructor for creation
|
586
|
-
Lin(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
|
587
|
-
/// Return specification
|
588
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
589
|
-
const Support::Symbol& name) const;
|
590
|
-
public:
|
591
|
-
/// Cost function (defined as dynamic PC_LINEAR_LO)
|
592
|
-
virtual PropCost cost(ModEventDelta med) const;
|
593
|
-
/// Delete propagator and return its size
|
594
|
-
virtual size_t dispose(Space* home);
|
595
|
-
};
|
596
|
-
|
597
|
-
/**
|
598
|
-
* \brief Base-class for reified n-ary linear propagators
|
599
|
-
*
|
600
|
-
* The type \a Val can be either \c double or \c int, defining the
|
601
|
-
* numerical precision during propagation. Positive views are of
|
602
|
-
* type \a P whereas negative views are of type \a N.
|
603
|
-
*
|
604
|
-
* The propagation condition \a pc refers to all views.
|
605
|
-
*/
|
606
|
-
template <class Val, class P, class N, PropCond pc, class Ctrl>
|
607
|
-
class ReLin : public Lin<Val,P,N,pc> {
|
608
|
-
protected:
|
609
|
-
/// Control view for reification
|
610
|
-
Ctrl b;
|
611
|
-
/// Constructor for cloning \a p
|
612
|
-
ReLin(Space* home, bool share, ReLin& p);
|
613
|
-
/// Constructor for creation
|
614
|
-
ReLin(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, Ctrl b);
|
615
|
-
/// Return specification
|
616
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
617
|
-
const Support::Symbol& name) const;
|
618
|
-
public:
|
619
|
-
/// Delete propagator and return its size
|
620
|
-
virtual size_t dispose(Space* home);
|
621
|
-
};
|
622
|
-
|
623
|
-
/**
|
624
|
-
* \brief Compute bounds information for positive views
|
625
|
-
*
|
626
|
-
* \relates Lin
|
627
|
-
*/
|
628
|
-
template <class Val, class View>
|
629
|
-
void bounds_p(ModEventDelta med, ViewArray<View>& x,
|
630
|
-
Val& c, Val& sl, Val& su);
|
631
|
-
|
632
|
-
/**
|
633
|
-
* \brief Compute bounds information for negative views
|
634
|
-
*
|
635
|
-
* \relates Lin
|
636
|
-
*/
|
637
|
-
template <class Val, class View>
|
638
|
-
void bounds_n(ModEventDelta med, ViewArray<View>& y,
|
639
|
-
Val& c, Val& sl, Val& su);
|
640
|
-
|
641
|
-
/**
|
642
|
-
* \brief %Propagator for bounds-consistent n-ary linear equality
|
643
|
-
*
|
644
|
-
* The type \a Val can be either \c double or \c int, defining the
|
645
|
-
* numerical precision during propagation. The types \a P and \a N
|
646
|
-
* give the types of the views.
|
647
|
-
*
|
648
|
-
* The propagation condition \a pc refers to both views.
|
649
|
-
*
|
650
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
651
|
-
* \ingroup FuncIntProp
|
652
|
-
*/
|
653
|
-
template <class Val, class P, class N>
|
654
|
-
class Eq : public Lin<Val,P,N,PC_INT_BND> {
|
655
|
-
protected:
|
656
|
-
using Lin<Val,P,N,PC_INT_BND>::x;
|
657
|
-
using Lin<Val,P,N,PC_INT_BND>::y;
|
658
|
-
using Lin<Val,P,N,PC_INT_BND>::c;
|
659
|
-
|
660
|
-
/// Constructor for cloning \a p
|
661
|
-
Eq(Space* home, bool share, Eq& p);
|
662
|
-
public:
|
663
|
-
/// Constructor for creation
|
664
|
-
Eq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
|
665
|
-
/// Create copy during cloning
|
666
|
-
virtual Actor* copy(Space* home, bool share);
|
667
|
-
/// Perform propagation
|
668
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
669
|
-
/// Specification for this propagator
|
670
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
671
|
-
Reflection::VarMap& m) const;
|
672
|
-
/// Post propagator according to specification
|
673
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
674
|
-
const Reflection::ActorSpec& spec);
|
675
|
-
/// Mangled propagator name
|
676
|
-
static Support::Symbol ati(void);
|
677
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i=c\f$
|
678
|
-
static ExecStatus
|
679
|
-
post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
|
680
|
-
};
|
681
|
-
|
682
|
-
/**
|
683
|
-
* \brief %Propagator for domain-consistent n-ary linear equality
|
684
|
-
*
|
685
|
-
* The type \a Val can be either \c double or \c int, defining the
|
686
|
-
* numerical precision during propagation. The types \a View
|
687
|
-
* give the type of the view.
|
688
|
-
*
|
689
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
690
|
-
* \ingroup FuncIntProp
|
691
|
-
*/
|
692
|
-
template <class Val, class View>
|
693
|
-
class DomEq
|
694
|
-
: public Lin<Val,View,View,PC_INT_DOM> {
|
695
|
-
protected:
|
696
|
-
using Lin<Val,View,View,PC_INT_DOM>::x;
|
697
|
-
using Lin<Val,View,View,PC_INT_DOM>::y;
|
698
|
-
using Lin<Val,View,View,PC_INT_DOM>::c;
|
699
|
-
|
700
|
-
/// Constructor for cloning \a p
|
701
|
-
DomEq(Space* home, bool share, DomEq& p);
|
702
|
-
public:
|
703
|
-
/// Constructor for creation
|
704
|
-
DomEq(Space* home, ViewArray<View>& x, ViewArray<View>& y, Val c);
|
705
|
-
/// Create copy during cloning
|
706
|
-
virtual Actor* copy(Space* home, bool share);
|
707
|
-
/// Propagation cost
|
708
|
-
virtual PropCost cost(ModEventDelta med) const;
|
709
|
-
/// Perform propagation
|
710
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
711
|
-
/// Specification for this propagator
|
712
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
713
|
-
Reflection::VarMap& m) const;
|
714
|
-
/// Post propagator according to specification
|
715
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
716
|
-
const Reflection::ActorSpec& spec);
|
717
|
-
/// Mangled propagator name
|
718
|
-
static Support::Symbol ati(void);
|
719
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i=c\f$
|
720
|
-
static ExecStatus
|
721
|
-
post(Space* home, ViewArray<View>& x, ViewArray<View>& y, Val c);
|
722
|
-
};
|
723
|
-
|
724
|
-
/**
|
725
|
-
* \brief %Propagator for reified bounds-consistent n-ary linear equality
|
726
|
-
*
|
727
|
-
* The type \a Val can be either \c double or \c int, defining the
|
728
|
-
* numerical precision during propagation. The types \a P and \a N
|
729
|
-
* give the types of the views.
|
730
|
-
*
|
731
|
-
* The propagation condition \a pc refers to both views.
|
732
|
-
*
|
733
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
734
|
-
* \ingroup FuncIntProp
|
735
|
-
*/
|
736
|
-
template <class Val, class P, class N, class Ctrl>
|
737
|
-
class ReEq : public ReLin<Val,P,N,PC_INT_BND,Ctrl> {
|
738
|
-
protected:
|
739
|
-
using ReLin<Val,P,N,PC_INT_BND,Ctrl>::x;
|
740
|
-
using ReLin<Val,P,N,PC_INT_BND,Ctrl>::y;
|
741
|
-
using ReLin<Val,P,N,PC_INT_BND,Ctrl>::c;
|
742
|
-
using ReLin<Val,P,N,PC_INT_BND,Ctrl>::b;
|
743
|
-
|
744
|
-
/// Constructor for cloning \a p
|
745
|
-
ReEq(Space* home, bool share, ReEq& p);
|
746
|
-
public:
|
747
|
-
/// Constructor for creation
|
748
|
-
ReEq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, Ctrl b);
|
749
|
-
/// Create copy during cloning
|
750
|
-
virtual Actor* copy(Space* home, bool share);
|
751
|
-
/// Perform propagation
|
752
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
753
|
-
/// Specification for this propagator
|
754
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
755
|
-
Reflection::VarMap& m) const;
|
756
|
-
/// Post propagator according to specification
|
757
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
758
|
-
const Reflection::ActorSpec& spec);
|
759
|
-
/// Mangled propagator name
|
760
|
-
static Support::Symbol ati(void);
|
761
|
-
/// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i=c\right)\Leftrightarrow b\f$
|
762
|
-
static ExecStatus
|
763
|
-
post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, Ctrl b);
|
764
|
-
};
|
765
|
-
|
766
|
-
/**
|
767
|
-
* \brief %Propagator for bounds-consistent n-ary linear disequality
|
768
|
-
*
|
769
|
-
* The type \a Val can be either \c double or \c int, defining the
|
770
|
-
* numerical precision during propagation. The types \a P and \a N
|
771
|
-
* give the types of the views.
|
772
|
-
*
|
773
|
-
* The propagation condition \a pc refers to both views.
|
774
|
-
*
|
775
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
776
|
-
* \ingroup FuncIntProp
|
777
|
-
*/
|
778
|
-
template <class Val, class P, class N>
|
779
|
-
class Nq : public Lin<Val,P,N,PC_INT_VAL> {
|
780
|
-
protected:
|
781
|
-
using Lin<Val,P,N,PC_INT_VAL>::x;
|
782
|
-
using Lin<Val,P,N,PC_INT_VAL>::y;
|
783
|
-
using Lin<Val,P,N,PC_INT_VAL>::c;
|
784
|
-
|
785
|
-
/// Constructor for cloning \a p
|
786
|
-
Nq(Space* home, bool share, Nq& p);
|
787
|
-
public:
|
788
|
-
/// Constructor for creation
|
789
|
-
Nq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
|
790
|
-
/// Create copy during cloning
|
791
|
-
virtual Actor* copy(Space* home, bool share);
|
792
|
-
/// Perform propagation
|
793
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
794
|
-
/// Specification for this propagator
|
795
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
796
|
-
Reflection::VarMap& m) const;
|
797
|
-
/// Post propagator according to specification
|
798
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
799
|
-
const Reflection::ActorSpec& spec);
|
800
|
-
/// Mangled propagator name
|
801
|
-
static Support::Symbol ati(void);
|
802
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i\neq c\f$
|
803
|
-
static ExecStatus
|
804
|
-
post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
|
805
|
-
};
|
806
|
-
|
807
|
-
/**
|
808
|
-
* \brief %Propagator for bounds-consistent n-ary linear less or equal
|
809
|
-
*
|
810
|
-
* The type \a Val can be either \c double or \c int, defining the
|
811
|
-
* numerical precision during propagation. The types \a P and \a N
|
812
|
-
* give the types of the views.
|
813
|
-
*
|
814
|
-
* The propagation condition \a pc refers to both views.
|
815
|
-
*
|
816
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
817
|
-
* \ingroup FuncIntProp
|
818
|
-
*/
|
819
|
-
template <class Val, class P, class N>
|
820
|
-
class Lq : public Lin<Val,P,N,PC_INT_BND> {
|
821
|
-
protected:
|
822
|
-
using Lin<Val,P,N,PC_INT_BND>::x;
|
823
|
-
using Lin<Val,P,N,PC_INT_BND>::y;
|
824
|
-
using Lin<Val,P,N,PC_INT_BND>::c;
|
825
|
-
|
826
|
-
/// Constructor for cloning \a p
|
827
|
-
Lq(Space* home, bool share, Lq& p);
|
828
|
-
public:
|
829
|
-
/// Constructor for creation
|
830
|
-
Lq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
|
831
|
-
/// Create copy during cloning
|
832
|
-
virtual Actor* copy(Space* home, bool share);
|
833
|
-
/// Perform propagation
|
834
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
835
|
-
/// Specification for this propagator
|
836
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
837
|
-
Reflection::VarMap& m) const;
|
838
|
-
/// Post propagator according to specification
|
839
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
840
|
-
const Reflection::ActorSpec& spec);
|
841
|
-
/// Mangled propagator name
|
842
|
-
static Support::Symbol ati(void);
|
843
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i\leq c\f$
|
844
|
-
static ExecStatus
|
845
|
-
post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c);
|
846
|
-
};
|
847
|
-
|
848
|
-
/**
|
849
|
-
* \brief %Propagator for reified bounds-consistent n-ary linear less or equal
|
850
|
-
*
|
851
|
-
* The type \a Val can be either \c double or \c int, defining the
|
852
|
-
* numerical precision during propagation. The types \a P and \a N
|
853
|
-
* give the types of the views.
|
854
|
-
*
|
855
|
-
* The propagation condition \a pc refers to both views.
|
856
|
-
*
|
857
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
858
|
-
* \ingroup FuncIntProp
|
859
|
-
*/
|
860
|
-
template <class Val, class P, class N>
|
861
|
-
class ReLq : public ReLin<Val,P,N,PC_INT_BND,BoolView> {
|
862
|
-
protected:
|
863
|
-
using ReLin<Val,P,N,PC_INT_BND,BoolView>::x;
|
864
|
-
using ReLin<Val,P,N,PC_INT_BND,BoolView>::y;
|
865
|
-
using ReLin<Val,P,N,PC_INT_BND,BoolView>::c;
|
866
|
-
using ReLin<Val,P,N,PC_INT_BND,BoolView>::b;
|
867
|
-
|
868
|
-
/// Constructor for cloning \a p
|
869
|
-
ReLq(Space* home, bool share, ReLq& p);
|
870
|
-
public:
|
871
|
-
/// Constructor for creation
|
872
|
-
ReLq(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, BoolView b);
|
873
|
-
/// Create copy during cloning
|
874
|
-
virtual Actor* copy(Space* home, bool share);
|
875
|
-
/// Perform propagation
|
876
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
877
|
-
/// Specification for this propagator
|
878
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
879
|
-
Reflection::VarMap& m) const;
|
880
|
-
/// Post propagator according to specification
|
881
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
882
|
-
const Reflection::ActorSpec& spec);
|
883
|
-
/// Mangled propagator name
|
884
|
-
static Support::Symbol ati(void);
|
885
|
-
/// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i-\sum_{i=0}^{|y|-1}y_i\leq c\right)\Leftrightarrow b\f$
|
886
|
-
static ExecStatus
|
887
|
-
post(Space* home, ViewArray<P>& x, ViewArray<N>& y, Val c, BoolView b);
|
888
|
-
};
|
889
|
-
|
890
|
-
}}}
|
891
|
-
|
892
|
-
#include "gecode/int/linear/int-nary.icc"
|
893
|
-
#include "gecode/int/linear/int-dom.icc"
|
894
|
-
|
895
|
-
namespace Gecode { namespace Int { namespace Linear {
|
896
|
-
|
897
|
-
/*
|
898
|
-
* Boolean linear propagators
|
899
|
-
*
|
900
|
-
*/
|
901
|
-
|
902
|
-
/**
|
903
|
-
* \brief Baseclass for integer Boolean sum using dependencies
|
904
|
-
*
|
905
|
-
*/
|
906
|
-
template <class VX>
|
907
|
-
class MemoryLinBoolInt : public Propagator {
|
908
|
-
protected:
|
909
|
-
/// Boolean views
|
910
|
-
ViewArray<VX> x;
|
911
|
-
/// Views from x[0] ... x[n_s-1] have subscriptions
|
912
|
-
int n_s;
|
913
|
-
/// Righthandside
|
914
|
-
int c;
|
915
|
-
/// Constructor for cloning \a p
|
916
|
-
MemoryLinBoolInt(Space* home, bool share, MemoryLinBoolInt& p);
|
917
|
-
/// Constructor for creation
|
918
|
-
MemoryLinBoolInt(Space* home, ViewArray<VX>& x, int n_s, int c);
|
919
|
-
/// Return specification for this propagator given a variable map \a m
|
920
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
921
|
-
const Support::Symbol& name) const;
|
922
|
-
public:
|
923
|
-
/// Cost function (defined as dynamic PC_LINEAR_LO)
|
924
|
-
virtual PropCost cost(ModEventDelta med) const;
|
925
|
-
/// Delete propagator and return its size
|
926
|
-
virtual size_t dispose(Space* home);
|
927
|
-
};
|
928
|
-
|
929
|
-
/**
|
930
|
-
* \brief Baseclass for integer Boolean sum using advisors
|
931
|
-
*
|
932
|
-
*/
|
933
|
-
template <class VX>
|
934
|
-
class SpeedLinBoolInt : public Propagator {
|
935
|
-
protected:
|
936
|
-
/// Boolean views
|
937
|
-
ViewArray<VX> x;
|
938
|
-
/// How many views are attached to advisors
|
939
|
-
int n_s;
|
940
|
-
/// Righthandside
|
941
|
-
int c;
|
942
|
-
/// Council for managing advisors
|
943
|
-
Council<ViewAdvisor<VX> > co;
|
944
|
-
/// Constructor for cloning \a p
|
945
|
-
SpeedLinBoolInt(Space* home, bool share, SpeedLinBoolInt& p);
|
946
|
-
/// Constructor for creation
|
947
|
-
SpeedLinBoolInt(Space* home, ViewArray<VX>& x, int n_s, int c);
|
948
|
-
/// Return specification for this propagator given a variable map \a m
|
949
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
950
|
-
const Support::Symbol& name) const;
|
951
|
-
public:
|
952
|
-
/// Cost function (defined as dynamic PC_UNARY_HI)
|
953
|
-
virtual PropCost cost(ModEventDelta med) const;
|
954
|
-
/// Delete propagator and return its size
|
955
|
-
virtual size_t dispose(Space* home);
|
956
|
-
};
|
957
|
-
|
958
|
-
/**
|
959
|
-
* \brief %Propagator for integer equal to Boolean sum (cardinality)
|
960
|
-
*
|
961
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
962
|
-
* \ingroup FuncIntProp
|
963
|
-
*/
|
964
|
-
template <class VX>
|
965
|
-
class EqBoolInt {
|
966
|
-
public:
|
967
|
-
/// Threshold of whether to prefer speed or memory
|
968
|
-
static const int threshold = 32;
|
969
|
-
/// Propagator using less memory but with linear runtime
|
970
|
-
class Memory : public MemoryLinBoolInt<VX> {
|
971
|
-
protected:
|
972
|
-
using MemoryLinBoolInt<VX>::x;
|
973
|
-
using MemoryLinBoolInt<VX>::n_s;
|
974
|
-
using MemoryLinBoolInt<VX>::c;
|
975
|
-
public:
|
976
|
-
/// Constructor for cloning \a p
|
977
|
-
Memory(Space* home, bool share, Memory& p);
|
978
|
-
/// Constructor for creation
|
979
|
-
Memory(Space* home, ViewArray<VX>& x, int c);
|
980
|
-
/// Create copy during cloning
|
981
|
-
virtual Actor* copy(Space* home, bool share);
|
982
|
-
/// Perform propagation
|
983
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
984
|
-
/// Specification for this propagator
|
985
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
986
|
-
Reflection::VarMap& m) const;
|
987
|
-
/// Post propagator according to specification
|
988
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
989
|
-
const Reflection::ActorSpec& spec);
|
990
|
-
/// Mangled propagator name
|
991
|
-
static Support::Symbol ati(void);
|
992
|
-
};
|
993
|
-
/// Propagator using more memory but with constant runtime
|
994
|
-
class Speed : public SpeedLinBoolInt<VX> {
|
995
|
-
protected:
|
996
|
-
using SpeedLinBoolInt<VX>::x;
|
997
|
-
using SpeedLinBoolInt<VX>::n_s;
|
998
|
-
using SpeedLinBoolInt<VX>::c;
|
999
|
-
using SpeedLinBoolInt<VX>::co;
|
1000
|
-
public:
|
1001
|
-
/// Constructor for cloning \a p
|
1002
|
-
Speed(Space* home, bool share, Speed& p);
|
1003
|
-
/// Constructor for creation
|
1004
|
-
Speed(Space* home, ViewArray<VX>& x, int c);
|
1005
|
-
/// Create copy during cloning
|
1006
|
-
virtual Actor* copy(Space* home, bool share);
|
1007
|
-
/// Give advice to propagator
|
1008
|
-
virtual ExecStatus advise(Space* home, Advisor* a, const Delta* d);
|
1009
|
-
/// Perform propagation
|
1010
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1011
|
-
/// Specification for this propagator
|
1012
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1013
|
-
Reflection::VarMap& m) const;
|
1014
|
-
/// Post propagator according to specification
|
1015
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1016
|
-
const Reflection::ActorSpec& spec);
|
1017
|
-
/// Mangled propagator name
|
1018
|
-
static Support::Symbol ati(void);
|
1019
|
-
};
|
1020
|
-
|
1021
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i = c\f$
|
1022
|
-
static ExecStatus post(Space* home, ViewArray<VX>& x, int c,
|
1023
|
-
PropKind pk=PK_DEF);
|
1024
|
-
};
|
1025
|
-
|
1026
|
-
/**
|
1027
|
-
* \brief %Propagator for integer less or equal to Boolean sum (cardinality)
|
1028
|
-
*
|
1029
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1030
|
-
* \ingroup FuncIntProp
|
1031
|
-
*/
|
1032
|
-
template <class VX>
|
1033
|
-
class GqBoolInt {
|
1034
|
-
public:
|
1035
|
-
/// Threshold of whether to prefer speed or memory
|
1036
|
-
static const int threshold = 32;
|
1037
|
-
/// Propagator using less memory but with linear runtime
|
1038
|
-
class Memory : public MemoryLinBoolInt<VX> {
|
1039
|
-
protected:
|
1040
|
-
using MemoryLinBoolInt<VX>::x;
|
1041
|
-
using MemoryLinBoolInt<VX>::n_s;
|
1042
|
-
using MemoryLinBoolInt<VX>::c;
|
1043
|
-
public:
|
1044
|
-
/// Constructor for cloning \a p
|
1045
|
-
Memory(Space* home, bool share, Memory& p);
|
1046
|
-
/// Constructor for creation
|
1047
|
-
Memory(Space* home, ViewArray<VX>& x, int c);
|
1048
|
-
/// Create copy during cloning
|
1049
|
-
virtual Actor* copy(Space* home, bool share);
|
1050
|
-
/// Perform propagation
|
1051
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1052
|
-
/// Specification for this propagator
|
1053
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1054
|
-
Reflection::VarMap& m) const;
|
1055
|
-
/// Post propagator according to specification
|
1056
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1057
|
-
const Reflection::ActorSpec& spec);
|
1058
|
-
/// Mangled propagator name
|
1059
|
-
static Support::Symbol ati(void);
|
1060
|
-
};
|
1061
|
-
/// Propagator using more memory but with constant runtime
|
1062
|
-
class Speed : public SpeedLinBoolInt<VX> {
|
1063
|
-
protected:
|
1064
|
-
using SpeedLinBoolInt<VX>::x;
|
1065
|
-
using SpeedLinBoolInt<VX>::n_s;
|
1066
|
-
using SpeedLinBoolInt<VX>::c;
|
1067
|
-
using SpeedLinBoolInt<VX>::co;
|
1068
|
-
public:
|
1069
|
-
/// Constructor for cloning \a p
|
1070
|
-
Speed(Space* home, bool share, Speed& p);
|
1071
|
-
/// Constructor for creation
|
1072
|
-
Speed(Space* home, ViewArray<VX>& x, int c);
|
1073
|
-
/// Create copy during cloning
|
1074
|
-
virtual Actor* copy(Space* home, bool share);
|
1075
|
-
/// Give advice to propagator
|
1076
|
-
virtual ExecStatus advise(Space* home, Advisor* a, const Delta* d);
|
1077
|
-
/// Perform propagation
|
1078
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1079
|
-
/// Specification for this propagator
|
1080
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1081
|
-
Reflection::VarMap& m) const;
|
1082
|
-
/// Post propagator according to specification
|
1083
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1084
|
-
const Reflection::ActorSpec& spec);
|
1085
|
-
/// Mangled propagator name
|
1086
|
-
static Support::Symbol ati(void);
|
1087
|
-
};
|
1088
|
-
public:
|
1089
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \geq c\f$
|
1090
|
-
static ExecStatus post(Space* home, ViewArray<VX>& x, int c,
|
1091
|
-
PropKind pk=PK_DEF);
|
1092
|
-
};
|
1093
|
-
|
1094
|
-
/**
|
1095
|
-
* \brief %Propagator for integer disequal to Boolean sum (cardinality)
|
1096
|
-
*
|
1097
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1098
|
-
* \ingroup FuncIntProp
|
1099
|
-
*/
|
1100
|
-
template<class VX>
|
1101
|
-
class NqBoolInt : public BinaryPropagator<VX,PC_INT_VAL> {
|
1102
|
-
protected:
|
1103
|
-
using BinaryPropagator<VX,PC_INT_VAL>::x0;
|
1104
|
-
using BinaryPropagator<VX,PC_INT_VAL>::x1;
|
1105
|
-
/// Views not yet subscribed to
|
1106
|
-
ViewArray<VX> x;
|
1107
|
-
/// Righthandside
|
1108
|
-
int c;
|
1109
|
-
/// Update subscription
|
1110
|
-
bool resubscribe(Space* home, VX& y);
|
1111
|
-
/// Constructor for posting
|
1112
|
-
NqBoolInt(Space* home, ViewArray<VX>& b, int c);
|
1113
|
-
/// Constructor for cloning \a p
|
1114
|
-
NqBoolInt(Space* home, bool share, NqBoolInt<VX>& p);
|
1115
|
-
public:
|
1116
|
-
/// Copy propagator during cloning
|
1117
|
-
virtual Actor* copy(Space* home, bool share);
|
1118
|
-
/// Cost function (defined as PC_LINEAR_LO)
|
1119
|
-
virtual PropCost cost(ModEventDelta med) const;
|
1120
|
-
/// Perform propagation
|
1121
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1122
|
-
/// Return specification for this propagator given a variable map \a m
|
1123
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1124
|
-
Reflection::VarMap& m) const;
|
1125
|
-
/// Post propagator according to specification
|
1126
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1127
|
-
const Reflection::ActorSpec& spec);
|
1128
|
-
/// Mangled propagator name
|
1129
|
-
static Support::Symbol ati(void);
|
1130
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \neq c\f$
|
1131
|
-
static ExecStatus post(Space* home, ViewArray<VX>& b, int c);
|
1132
|
-
};
|
1133
|
-
|
1134
|
-
}}}
|
1135
|
-
|
1136
|
-
#include "gecode/int/linear/bool-int.icc"
|
1137
|
-
|
1138
|
-
namespace Gecode { namespace Int { namespace Linear {
|
1139
|
-
|
1140
|
-
/**
|
1141
|
-
* \brief Base-class for Boolean linear propagators
|
1142
|
-
*
|
1143
|
-
*/
|
1144
|
-
template <class XV, class YV>
|
1145
|
-
class LinBoolView : public Propagator {
|
1146
|
-
protected:
|
1147
|
-
/// Boolean views
|
1148
|
-
ViewArray<XV> x;
|
1149
|
-
/// View to compare number of assigned Boolean views to
|
1150
|
-
YV y;
|
1151
|
-
/// Righthandside (constant part from Boolean views assigned to 1)
|
1152
|
-
int c;
|
1153
|
-
/// Constructor for cloning \a p
|
1154
|
-
LinBoolView(Space* home, bool share, LinBoolView& p);
|
1155
|
-
/// Constructor for creation
|
1156
|
-
LinBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
|
1157
|
-
/// Return specification for this propagator given a variable map \a m
|
1158
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
1159
|
-
const Support::Symbol& name) const;
|
1160
|
-
public:
|
1161
|
-
/// Cost function (defined as dynamic PC_LINEAR_LO)
|
1162
|
-
virtual PropCost cost(ModEventDelta med) const;
|
1163
|
-
/// Delete propagator and return its size
|
1164
|
-
virtual size_t dispose(Space* home);
|
1165
|
-
};
|
1166
|
-
|
1167
|
-
|
1168
|
-
/**
|
1169
|
-
* \brief Base-class for reified Boolean linear propagators
|
1170
|
-
*
|
1171
|
-
*/
|
1172
|
-
template <class XV, class YV, class BV>
|
1173
|
-
class ReLinBoolView : public LinBoolView<XV,YV> {
|
1174
|
-
protected:
|
1175
|
-
using LinBoolView<XV,YV>::x;
|
1176
|
-
using LinBoolView<XV,YV>::y;
|
1177
|
-
using LinBoolView<XV,YV>::c;
|
1178
|
-
/// Control variable
|
1179
|
-
BV b;
|
1180
|
-
/// Constructor for cloning \a p
|
1181
|
-
ReLinBoolView(Space* home, bool share, ReLinBoolView& p);
|
1182
|
-
/// Constructor for creation
|
1183
|
-
ReLinBoolView(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
|
1184
|
-
/// Return specification for this propagator given a variable map \a m
|
1185
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
1186
|
-
const Support::Symbol& name) const;
|
1187
|
-
public:
|
1188
|
-
/// Delete propagator and return its size
|
1189
|
-
virtual size_t dispose(Space* home);
|
1190
|
-
};
|
1191
|
-
|
1192
|
-
|
1193
|
-
/**
|
1194
|
-
* \brief %Propagator for equality to Boolean sum (cardinality)
|
1195
|
-
*
|
1196
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1197
|
-
* \ingroup FuncIntProp
|
1198
|
-
*/
|
1199
|
-
template <class XV, class YV>
|
1200
|
-
class EqBoolView : public LinBoolView<XV,YV> {
|
1201
|
-
protected:
|
1202
|
-
using LinBoolView<XV,YV>::x;
|
1203
|
-
using LinBoolView<XV,YV>::y;
|
1204
|
-
using LinBoolView<XV,YV>::c;
|
1205
|
-
|
1206
|
-
/// Constructor for cloning \a p
|
1207
|
-
EqBoolView(Space* home, bool share, EqBoolView& p);
|
1208
|
-
/// Constructor for creation
|
1209
|
-
EqBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
|
1210
|
-
public:
|
1211
|
-
/// Create copy during cloning
|
1212
|
-
virtual Actor* copy(Space* home, bool share);
|
1213
|
-
/// Perform propagation
|
1214
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1215
|
-
/// Return specification for this propagator given a variable map \a m
|
1216
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1217
|
-
Reflection::VarMap& m) const;
|
1218
|
-
/// Post propagator according to specification
|
1219
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1220
|
-
const Reflection::ActorSpec& spec);
|
1221
|
-
/// Mangled propagator name
|
1222
|
-
static Support::Symbol ati(void);
|
1223
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i = y+c\f$
|
1224
|
-
static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c);
|
1225
|
-
};
|
1226
|
-
|
1227
|
-
/**
|
1228
|
-
* \brief %Propagator for disequality to Boolean sum (cardinality)
|
1229
|
-
*
|
1230
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1231
|
-
* \ingroup FuncIntProp
|
1232
|
-
*/
|
1233
|
-
template <class XV, class YV>
|
1234
|
-
class NqBoolView : public LinBoolView<XV,YV> {
|
1235
|
-
protected:
|
1236
|
-
using LinBoolView<XV,YV>::x;
|
1237
|
-
using LinBoolView<XV,YV>::y;
|
1238
|
-
using LinBoolView<XV,YV>::c;
|
1239
|
-
|
1240
|
-
/// Constructor for cloning \a p
|
1241
|
-
NqBoolView(Space* home, bool share, NqBoolView& p);
|
1242
|
-
/// Constructor for creation
|
1243
|
-
NqBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
|
1244
|
-
public:
|
1245
|
-
/// Create copy during cloning
|
1246
|
-
virtual Actor* copy(Space* home, bool share);
|
1247
|
-
/// Perform propagation
|
1248
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1249
|
-
/// Return specification for this propagator given a variable map \a m
|
1250
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1251
|
-
Reflection::VarMap& m) const;
|
1252
|
-
/// Post propagator according to specification
|
1253
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1254
|
-
const Reflection::ActorSpec& spec);
|
1255
|
-
/// Mangled propagator name
|
1256
|
-
static Support::Symbol ati(void);
|
1257
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \neq y+c\f$
|
1258
|
-
static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c);
|
1259
|
-
};
|
1260
|
-
|
1261
|
-
/**
|
1262
|
-
* \brief %Propagator for greater or equal to Boolean sum (cardinality)
|
1263
|
-
*
|
1264
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1265
|
-
* \ingroup FuncIntProp
|
1266
|
-
*/
|
1267
|
-
template <class XV, class YV>
|
1268
|
-
class GqBoolView : public LinBoolView<XV,YV> {
|
1269
|
-
protected:
|
1270
|
-
using LinBoolView<XV,YV>::x;
|
1271
|
-
using LinBoolView<XV,YV>::y;
|
1272
|
-
using LinBoolView<XV,YV>::c;
|
1273
|
-
|
1274
|
-
/// Constructor for cloning \a p
|
1275
|
-
GqBoolView(Space* home, bool share, GqBoolView& p);
|
1276
|
-
/// Constructor for creation
|
1277
|
-
GqBoolView(Space* home, ViewArray<XV>& x, YV y, int c);
|
1278
|
-
public:
|
1279
|
-
/// Create copy during cloning
|
1280
|
-
virtual Actor* copy(Space* home, bool share);
|
1281
|
-
/// Perform propagation
|
1282
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1283
|
-
/// Return specification for this propagator given a variable map \a m
|
1284
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1285
|
-
Reflection::VarMap& m) const;
|
1286
|
-
/// Post propagator according to specification
|
1287
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1288
|
-
const Reflection::ActorSpec& spec);
|
1289
|
-
/// Mangled propagator name
|
1290
|
-
static Support::Symbol ati(void);
|
1291
|
-
/// Post propagator for \f$\sum_{i=0}^{|x|-1}x_i \geq y+c\f$
|
1292
|
-
static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c);
|
1293
|
-
};
|
1294
|
-
|
1295
|
-
/**
|
1296
|
-
* \brief %Propagator for reified equality to Boolean sum (cardinality)
|
1297
|
-
*
|
1298
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1299
|
-
* \ingroup FuncIntProp
|
1300
|
-
*/
|
1301
|
-
template <class XV, class YV, class BV>
|
1302
|
-
class ReEqBoolView : public ReLinBoolView<XV,YV,BV> {
|
1303
|
-
protected:
|
1304
|
-
using ReLinBoolView<XV,YV,BV>::x;
|
1305
|
-
using ReLinBoolView<XV,YV,BV>::y;
|
1306
|
-
using ReLinBoolView<XV,YV,BV>::c;
|
1307
|
-
using ReLinBoolView<XV,YV,BV>::b;
|
1308
|
-
|
1309
|
-
/// Constructor for cloning \a p
|
1310
|
-
ReEqBoolView(Space* home, bool share, ReEqBoolView& p);
|
1311
|
-
/// Constructor for creation
|
1312
|
-
ReEqBoolView(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
|
1313
|
-
public:
|
1314
|
-
/// Create copy during cloning
|
1315
|
-
virtual Actor* copy(Space* home, bool share);
|
1316
|
-
/// Perform propagation
|
1317
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1318
|
-
/// Return specification for this propagator given a variable map \a m
|
1319
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1320
|
-
Reflection::VarMap& m) const;
|
1321
|
-
/// Post propagator according to specification
|
1322
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1323
|
-
const Reflection::ActorSpec& spec);
|
1324
|
-
/// Mangled propagator name
|
1325
|
-
static Support::Symbol ati(void);
|
1326
|
-
/// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i = y+c\right)\Leftrightarrow b\f$
|
1327
|
-
static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
|
1328
|
-
};
|
1329
|
-
|
1330
|
-
/**
|
1331
|
-
* \brief %Propagator for reified greater or equal to Boolean sum (cardinality)
|
1332
|
-
*
|
1333
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1334
|
-
* \ingroup FuncIntProp
|
1335
|
-
*/
|
1336
|
-
template <class XV, class YV, class BV>
|
1337
|
-
class ReGqBoolView : public ReLinBoolView<XV,YV,BV> {
|
1338
|
-
protected:
|
1339
|
-
using ReLinBoolView<XV,YV,BV>::x;
|
1340
|
-
using ReLinBoolView<XV,YV,BV>::y;
|
1341
|
-
using ReLinBoolView<XV,YV,BV>::c;
|
1342
|
-
using ReLinBoolView<XV,YV,BV>::b;
|
1343
|
-
|
1344
|
-
/// Constructor for cloning \a p
|
1345
|
-
ReGqBoolView(Space* home, bool share, ReGqBoolView& p);
|
1346
|
-
/// Constructor for creation
|
1347
|
-
ReGqBoolView(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
|
1348
|
-
public:
|
1349
|
-
/// Create copy during cloning
|
1350
|
-
virtual Actor* copy(Space* home, bool share);
|
1351
|
-
/// Perform propagation
|
1352
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1353
|
-
/// Return specification for this propagator given a variable map \a m
|
1354
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1355
|
-
Reflection::VarMap& m) const;
|
1356
|
-
/// Post propagator according to specification
|
1357
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1358
|
-
const Reflection::ActorSpec& spec);
|
1359
|
-
/// Mangled propagator name
|
1360
|
-
static Support::Symbol ati(void);
|
1361
|
-
/// Post propagator for \f$\left(\sum_{i=0}^{|x|-1}x_i \geq y+c\right)\Leftrightarrow b\f$
|
1362
|
-
static ExecStatus post(Space* home, ViewArray<XV>& x, YV y, int c, BV b);
|
1363
|
-
};
|
1364
|
-
|
1365
|
-
}}}
|
1366
|
-
|
1367
|
-
#include "gecode/int/linear/bool-view.icc"
|
1368
|
-
|
1369
|
-
namespace Gecode { namespace Int { namespace Linear {
|
1370
|
-
|
1371
|
-
/// Coefficient and Boolean view
|
1372
|
-
class ScaleBool {
|
1373
|
-
public:
|
1374
|
-
/// Integer coefficient
|
1375
|
-
int a;
|
1376
|
-
/// Boolean view
|
1377
|
-
BoolView x;
|
1378
|
-
};
|
1379
|
-
|
1380
|
-
/// Array of scale Boolean views
|
1381
|
-
class ScaleBoolArray {
|
1382
|
-
private:
|
1383
|
-
/// First entry in array
|
1384
|
-
ScaleBool* _fst;
|
1385
|
-
/// One after last entry in array
|
1386
|
-
ScaleBool* _lst;
|
1387
|
-
public:
|
1388
|
-
/// Default constructor
|
1389
|
-
ScaleBoolArray(void);
|
1390
|
-
/// Create array with \a n elements
|
1391
|
-
ScaleBoolArray(Space* home, int n);
|
1392
|
-
/// Subscribe propagator \a p
|
1393
|
-
void subscribe(Space* home, Propagator* p);
|
1394
|
-
/// Cancel propagator \a p
|
1395
|
-
void cancel(Space* home, Propagator* p);
|
1396
|
-
/// Update \a sba during copying
|
1397
|
-
void update(Space* home, bool share, ScaleBoolArray& sba);
|
1398
|
-
/// Return pointer to first element
|
1399
|
-
ScaleBool* fst(void) const;
|
1400
|
-
/// Return pointer after last element
|
1401
|
-
ScaleBool* lst(void) const;
|
1402
|
-
/// Set pointer to first element
|
1403
|
-
void fst(ScaleBool* f);
|
1404
|
-
/// Set pointer after last element
|
1405
|
-
void lst(ScaleBool* l);
|
1406
|
-
/// Test whether array is empty
|
1407
|
-
bool empty(void) const;
|
1408
|
-
/// Return number of elements
|
1409
|
-
int size(void) const;
|
1410
|
-
/// Return type of array
|
1411
|
-
static Support::Symbol type(void);
|
1412
|
-
/// Reflection
|
1413
|
-
Reflection::Arg* spec(const Space* home, Reflection::VarMap& m) const;
|
1414
|
-
private:
|
1415
|
-
/// For sorting array in decreasing order of coefficients
|
1416
|
-
class ScaleDec {
|
1417
|
-
public:
|
1418
|
-
bool
|
1419
|
-
operator()(const ScaleBool& x, const ScaleBool& y);
|
1420
|
-
};
|
1421
|
-
public:
|
1422
|
-
/// Sort array in decreasing order of coefficients
|
1423
|
-
void sort(void);
|
1424
|
-
};
|
1425
|
-
|
1426
|
-
|
1427
|
-
/// Empty array of scale Boolean views
|
1428
|
-
class EmptyScaleBoolArray {
|
1429
|
-
public:
|
1430
|
-
/// Default constructor
|
1431
|
-
EmptyScaleBoolArray(void);
|
1432
|
-
/// Create array with \a n elements
|
1433
|
-
EmptyScaleBoolArray(Space* home, int n);
|
1434
|
-
/// Subscribe propagator \a p
|
1435
|
-
void subscribe(Space* home, Propagator* p);
|
1436
|
-
/// Cancel propagator \a p
|
1437
|
-
void cancel(Space* home, Propagator* p);
|
1438
|
-
/// Update \a sba during copying
|
1439
|
-
void update(Space* home, bool share, EmptyScaleBoolArray& esba);
|
1440
|
-
/// Return pointer to first element
|
1441
|
-
ScaleBool* fst(void) const;
|
1442
|
-
/// Return pointer after last element
|
1443
|
-
ScaleBool* lst(void) const;
|
1444
|
-
/// Set pointer to first element
|
1445
|
-
void fst(ScaleBool* f);
|
1446
|
-
/// Set pointer after last element
|
1447
|
-
void lst(ScaleBool* l);
|
1448
|
-
/// Test whether array is empty
|
1449
|
-
bool empty(void) const;
|
1450
|
-
/// Return number of elements
|
1451
|
-
int size(void) const;
|
1452
|
-
/// Sort array in decreasing order of coefficients
|
1453
|
-
void sort(void);
|
1454
|
-
/// Return type of array
|
1455
|
-
static Support::Symbol type(void);
|
1456
|
-
};
|
1457
|
-
|
1458
|
-
|
1459
|
-
/**
|
1460
|
-
* \brief Base class for linear Boolean constraints with coefficients
|
1461
|
-
*
|
1462
|
-
*/
|
1463
|
-
template <class SBAP, class SBAN, class VX, PropCond pcx>
|
1464
|
-
class LinBoolScale : public Propagator {
|
1465
|
-
protected:
|
1466
|
-
/// Positive Boolean views with coefficients on left-hand side
|
1467
|
-
SBAP p;
|
1468
|
-
/// Negative Boolean views with coefficients on left-hand side
|
1469
|
-
SBAN n;
|
1470
|
-
/// Integer view on right-hand side
|
1471
|
-
VX x;
|
1472
|
-
/// Integer constant on right-hand side
|
1473
|
-
int c;
|
1474
|
-
/// Return specification for this propagator given a variable map \a m
|
1475
|
-
Reflection::ActorSpec spec(const Space* home, Reflection::VarMap& m,
|
1476
|
-
const Support::Symbol& name) const;
|
1477
|
-
public:
|
1478
|
-
/// Constructor for creation
|
1479
|
-
LinBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
|
1480
|
-
/// Constructor for cloning \a pr
|
1481
|
-
LinBoolScale(Space* home, bool share, Propagator& pr,
|
1482
|
-
SBAP& p, SBAN& n, VX x, int c);
|
1483
|
-
/// Cost function (defined as dynamic PC_LINEAR_LO)
|
1484
|
-
virtual PropCost cost(ModEventDelta med) const;
|
1485
|
-
/// Delete propagator and return its size
|
1486
|
-
virtual size_t dispose(Space* home);
|
1487
|
-
};
|
1488
|
-
|
1489
|
-
/**
|
1490
|
-
* \brief %Propagator for equality to Boolean sum with coefficients
|
1491
|
-
*
|
1492
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1493
|
-
* \ingroup FuncIntProp
|
1494
|
-
*/
|
1495
|
-
template <class SBAP, class SBAN, class VX>
|
1496
|
-
class EqBoolScale : public LinBoolScale<SBAP,SBAN,VX,PC_INT_BND> {
|
1497
|
-
protected:
|
1498
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::p;
|
1499
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::n;
|
1500
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::x;
|
1501
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::c;
|
1502
|
-
public:
|
1503
|
-
/// Constructor for creation
|
1504
|
-
EqBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
|
1505
|
-
/// Constructor for cloning \a pr
|
1506
|
-
EqBoolScale(Space* home, bool share, Propagator& pr,
|
1507
|
-
SBAP& p, SBAN& n, VX x, int c);
|
1508
|
-
/// Create copy during cloning
|
1509
|
-
virtual Actor* copy(Space* home, bool share);
|
1510
|
-
/// Perform propagation
|
1511
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1512
|
-
/// Return specification for this propagator given a variable map \a m
|
1513
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1514
|
-
Reflection::VarMap& m) const;
|
1515
|
-
/// Post propagator according to specification
|
1516
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1517
|
-
const Reflection::ActorSpec& spec);
|
1518
|
-
/// Mangled propagator name
|
1519
|
-
static Support::Symbol ati(void);
|
1520
|
-
/// Post propagator
|
1521
|
-
static ExecStatus post(Space* home, SBAP& p, SBAN& n, VX x, int c);
|
1522
|
-
};
|
1523
|
-
|
1524
|
-
/**
|
1525
|
-
* \brief %Propagator for inequality to Boolean sum with coefficients
|
1526
|
-
*
|
1527
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1528
|
-
* \ingroup FuncIntProp
|
1529
|
-
*/
|
1530
|
-
template <class SBAP, class SBAN, class VX>
|
1531
|
-
class LqBoolScale : public LinBoolScale<SBAP,SBAN,VX,PC_INT_BND> {
|
1532
|
-
protected:
|
1533
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::p;
|
1534
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::n;
|
1535
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::x;
|
1536
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_BND>::c;
|
1537
|
-
public:
|
1538
|
-
/// Constructor for creation
|
1539
|
-
LqBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
|
1540
|
-
/// Constructor for cloning \a pr
|
1541
|
-
LqBoolScale(Space* home, bool share, Propagator& pr,
|
1542
|
-
SBAP& p, SBAN& n, VX x, int c);
|
1543
|
-
/// Create copy during cloning
|
1544
|
-
virtual Actor* copy(Space* home, bool share);
|
1545
|
-
/// Perform propagation
|
1546
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1547
|
-
/// Return specification for this propagator given a variable map \a m
|
1548
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1549
|
-
Reflection::VarMap& m) const;
|
1550
|
-
/// Post propagator according to specification
|
1551
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1552
|
-
const Reflection::ActorSpec& spec);
|
1553
|
-
/// Mangled propagator name
|
1554
|
-
static Support::Symbol ati(void);
|
1555
|
-
/// Post propagator
|
1556
|
-
static ExecStatus post(Space* home, SBAP& p, SBAN& n, VX x, int c);
|
1557
|
-
};
|
1558
|
-
|
1559
|
-
/**
|
1560
|
-
* \brief %Propagator for disequality to Boolean sum with coefficients
|
1561
|
-
*
|
1562
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1563
|
-
* \ingroup FuncIntProp
|
1564
|
-
*/
|
1565
|
-
template <class SBAP, class SBAN, class VX>
|
1566
|
-
class NqBoolScale : public LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL> {
|
1567
|
-
protected:
|
1568
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::p;
|
1569
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::n;
|
1570
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::x;
|
1571
|
-
using LinBoolScale<SBAP,SBAN,VX,PC_INT_VAL>::c;
|
1572
|
-
public:
|
1573
|
-
/// Constructor for creation
|
1574
|
-
NqBoolScale(Space* home, SBAP& p, SBAN& n, VX x, int c);
|
1575
|
-
/// Constructor for cloning \a pr
|
1576
|
-
NqBoolScale(Space* home, bool share, Propagator& pr,
|
1577
|
-
SBAP& p, SBAN& n, VX x, int c);
|
1578
|
-
/// Create copy during cloning
|
1579
|
-
virtual Actor* copy(Space* home, bool share);
|
1580
|
-
/// Perform propagation
|
1581
|
-
virtual ExecStatus propagate(Space* home, ModEventDelta med);
|
1582
|
-
/// Return specification for this propagator given a variable map \a m
|
1583
|
-
virtual Reflection::ActorSpec spec(const Space* home,
|
1584
|
-
Reflection::VarMap& m) const;
|
1585
|
-
/// Post propagator according to specification
|
1586
|
-
static void post(Space* home, Reflection::VarMap& vars,
|
1587
|
-
const Reflection::ActorSpec& spec);
|
1588
|
-
/// Mangled propagator name
|
1589
|
-
static Support::Symbol ati(void);
|
1590
|
-
/// Post propagator
|
1591
|
-
static ExecStatus post(Space* home, SBAP& p, SBAN& n, VX x, int c);
|
1592
|
-
};
|
1593
|
-
|
1594
|
-
}}}
|
1595
|
-
|
1596
|
-
#include "gecode/int/linear/bool-scale.icc"
|
1597
|
-
|
1598
|
-
namespace Gecode { namespace Int { namespace Linear {
|
1599
|
-
|
1600
|
-
/**
|
1601
|
-
* \brief Class for describing linear term \f$a\cdot x\f$
|
1602
|
-
*
|
1603
|
-
*/
|
1604
|
-
template<class View>
|
1605
|
-
class Term {
|
1606
|
-
public:
|
1607
|
-
/// Coefficient
|
1608
|
-
int a;
|
1609
|
-
/// View
|
1610
|
-
View x;
|
1611
|
-
};
|
1612
|
-
|
1613
|
-
/** \brief Estimate lower and upper bounds
|
1614
|
-
*
|
1615
|
-
* Estimates the boundaries for a linear expression
|
1616
|
-
* \f$\sum_{i=0}^{n-1}t_i + c\f$. If the boundaries exceed
|
1617
|
-
* the limits as defined in Limits::Int, these boundaries
|
1618
|
-
* are returned.
|
1619
|
-
*
|
1620
|
-
* \param t array of linear terms
|
1621
|
-
* \param n size of array
|
1622
|
-
* \param c constant
|
1623
|
-
* \param l lower bound
|
1624
|
-
* \param u upper bound
|
1625
|
-
*
|
1626
|
-
*/
|
1627
|
-
template<class View>
|
1628
|
-
void estimate(Term<View>* t, int n, int c,
|
1629
|
-
int& l, int& u);
|
1630
|
-
|
1631
|
-
/** \brief Normalize linear integer constraints
|
1632
|
-
*
|
1633
|
-
* \param t array of linear terms
|
1634
|
-
* \param n size of array
|
1635
|
-
* \param t_p array of linear terms over integers with positive coefficients
|
1636
|
-
* \param n_p number of postive terms
|
1637
|
-
* \param t_n array of linear terms over integers with negative coefficients
|
1638
|
-
* \param n_n number of negative terms
|
1639
|
-
*
|
1640
|
-
* Replaces all negative coefficients by positive coefficients.
|
1641
|
-
*
|
1642
|
-
* - Variables occuring multiply in the term array are replaced
|
1643
|
-
* by a single occurence: for example, \f$ax+bx\f$ becomes
|
1644
|
-
* \f$(a+b)x\f$.
|
1645
|
-
* - If in the above simplification the value for \f$(a+b)\f$ (or for
|
1646
|
-
* \f$a\f$ and \f$b\f$) exceeds the limits for integers as
|
1647
|
-
* defined in Limits::Int, an exception of type
|
1648
|
-
* Int::NumericalOverflow is thrown.
|
1649
|
-
*
|
1650
|
-
* Returns true, if all coefficients are unit coefficients
|
1651
|
-
*/
|
1652
|
-
template<class View>
|
1653
|
-
bool normalize(Term<View>* t, int &n,
|
1654
|
-
Term<View>* &t_p, int &n_p,
|
1655
|
-
Term<View>* &t_n, int &n_n);
|
1656
|
-
|
1657
|
-
|
1658
|
-
/**
|
1659
|
-
* \brief Post propagator for linear constraint over integers
|
1660
|
-
* \param t array of linear terms over integers
|
1661
|
-
* \param n size of array
|
1662
|
-
* \param r type of relation
|
1663
|
-
* \param c result of linear constraint
|
1664
|
-
*
|
1665
|
-
* All variants for linear constraints share the following properties:
|
1666
|
-
* - Variables occuring multiply in the term array are replaced
|
1667
|
-
* by a single occurence: for example, \f$ax+bx\f$ becomes
|
1668
|
-
* \f$(a+b)x\f$.
|
1669
|
-
* - If in the above simplification the value for \f$(a+b)\f$ (or for
|
1670
|
-
* \f$a\f$ and \f$b\f$) exceeds the limits for integers as
|
1671
|
-
* defined in Limits::Int, an exception of type
|
1672
|
-
* Int::NumericalOverflow is thrown.
|
1673
|
-
* - Assume linear terms for the constraint
|
1674
|
-
* \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
|
1675
|
-
* If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
|
1676
|
-
* for doubles as defined in Limits::Int, an exception of
|
1677
|
-
* type Int::NumericalOverflow is thrown.
|
1678
|
-
* - In all other cases, the created propagators are accurate (that
|
1679
|
-
* is, they will not silently overflow during propagation).
|
1680
|
-
*
|
1681
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1682
|
-
* \ingroup FuncIntProp
|
1683
|
-
*/
|
1684
|
-
GECODE_INT_EXPORT void
|
1685
|
-
post(Space* home, Term<IntView>* t, int n, IntRelType r, int c,
|
1686
|
-
IntConLevel=ICL_DEF, PropKind pk=PK_DEF);
|
1687
|
-
|
1688
|
-
/**
|
1689
|
-
* \brief Post reified propagator for linear constraint
|
1690
|
-
* \param t array of linear terms
|
1691
|
-
* \param n size of array
|
1692
|
-
* \param r type of relation
|
1693
|
-
* \param c result of linear constraint
|
1694
|
-
* \param b Boolean control view
|
1695
|
-
*
|
1696
|
-
* All variants for linear constraints share the following properties:
|
1697
|
-
* - Only bounds-consistency is supported.
|
1698
|
-
* - Variables occuring multiply in the term array are replaced
|
1699
|
-
* by a single occurence: for example, \f$ax+bx\f$ becomes
|
1700
|
-
* \f$(a+b)x\f$.
|
1701
|
-
* - If in the above simplification the value for \f$(a+b)\f$ (or for
|
1702
|
-
* \f$a\f$ and \f$b\f$) exceeds the limits for integers as
|
1703
|
-
* defined in Limits::Int, an exception of type
|
1704
|
-
* Int::NumericalOverflow is thrown.
|
1705
|
-
* - Assume linear terms for the constraint
|
1706
|
-
* \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
|
1707
|
-
* If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
|
1708
|
-
* for doubles as defined in Limits::Int, an exception of
|
1709
|
-
* type Int::NumericalOverflow is thrown.
|
1710
|
-
* - In all other cases, the created propagators are accurate (that
|
1711
|
-
* is, they will not silently overflow during propagation).
|
1712
|
-
*
|
1713
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1714
|
-
* \ingroup FuncIntProp
|
1715
|
-
*/
|
1716
|
-
GECODE_INT_EXPORT void
|
1717
|
-
post(Space* home, Term<IntView>* t, int n, IntRelType r, int c, BoolView b,
|
1718
|
-
IntConLevel=ICL_DEF, PropKind pk=PK_DEF);
|
1719
|
-
|
1720
|
-
/**
|
1721
|
-
* \brief Post propagator for linear constraint over Booleans
|
1722
|
-
* \param t array of linear terms over Booleans
|
1723
|
-
* \param n size of array
|
1724
|
-
* \param r type of relation
|
1725
|
-
* \param c result of linear constraint
|
1726
|
-
*
|
1727
|
-
* All variants for linear constraints share the following properties:
|
1728
|
-
* - Variables occuring multiply in the term array are replaced
|
1729
|
-
* by a single occurence: for example, \f$ax+bx\f$ becomes
|
1730
|
-
* \f$(a+b)x\f$.
|
1731
|
-
* - If in the above simplification the value for \f$(a+b)\f$ (or for
|
1732
|
-
* \f$a\f$ and \f$b\f$) exceeds the limits for integers as
|
1733
|
-
* defined in Limits::Int, an exception of type
|
1734
|
-
* Int::NumericalOverflow is thrown.
|
1735
|
-
* - Assume linear terms for the constraint
|
1736
|
-
* \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
|
1737
|
-
* If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
|
1738
|
-
* for integers as defined in Limits::Int, an exception of
|
1739
|
-
* type Int::NumericalOverflow is thrown.
|
1740
|
-
* - In all other cases, the created propagators are accurate (that
|
1741
|
-
* is, they will not silently overflow during propagation).
|
1742
|
-
*
|
1743
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1744
|
-
* \ingroup FuncIntProp
|
1745
|
-
*/
|
1746
|
-
GECODE_INT_EXPORT void
|
1747
|
-
post(Space* home, Term<BoolView>* t, int n, IntRelType r, int c,
|
1748
|
-
IntConLevel=ICL_DEF, PropKind=PK_DEF);
|
1749
|
-
|
1750
|
-
/**
|
1751
|
-
* \brief Post propagator for reified linear constraint over Booleans
|
1752
|
-
* \param t array of linear terms over Booleans
|
1753
|
-
* \param n size of array
|
1754
|
-
* \param r type of relation
|
1755
|
-
* \param c result of linear constraint
|
1756
|
-
* \param b Boolean control varaible
|
1757
|
-
*
|
1758
|
-
* All variants for linear constraints share the following properties:
|
1759
|
-
* - Variables occuring multiply in the term array are replaced
|
1760
|
-
* by a single occurence: for example, \f$ax+bx\f$ becomes
|
1761
|
-
* \f$(a+b)x\f$.
|
1762
|
-
* - If in the above simplification the value for \f$(a+b)\f$ (or for
|
1763
|
-
* \f$a\f$ and \f$b\f$) exceeds the limits for integers as
|
1764
|
-
* defined in Limits::Int, an exception of type
|
1765
|
-
* Int::NumericalOverflow is thrown.
|
1766
|
-
* - Assume linear terms for the constraint
|
1767
|
-
* \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
|
1768
|
-
* If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
|
1769
|
-
* for integers as defined in Limits::Int, an exception of
|
1770
|
-
* type Int::NumericalOverflow is thrown.
|
1771
|
-
* - In all other cases, the created propagators are accurate (that
|
1772
|
-
* is, they will not silently overflow during propagation).
|
1773
|
-
*
|
1774
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1775
|
-
* \ingroup FuncIntProp
|
1776
|
-
*/
|
1777
|
-
GECODE_INT_EXPORT void
|
1778
|
-
post(Space* home, Term<BoolView>* t, int n, IntRelType r, int c, BoolView b,
|
1779
|
-
IntConLevel=ICL_DEF, PropKind=PK_DEF);
|
1780
|
-
|
1781
|
-
/**
|
1782
|
-
* \brief Post propagator for linear constraint over Booleans
|
1783
|
-
* \param t array of linear terms over Booleans
|
1784
|
-
* \param n size of array
|
1785
|
-
* \param r type of relation
|
1786
|
-
* \param y variable right hand side of linear constraint
|
1787
|
-
* \param c constant right hand side of linear constraint
|
1788
|
-
*
|
1789
|
-
* All variants for linear constraints share the following properties:
|
1790
|
-
* - Variables occuring multiply in the term array are replaced
|
1791
|
-
* by a single occurence: for example, \f$ax+bx\f$ becomes
|
1792
|
-
* \f$(a+b)x\f$.
|
1793
|
-
* - If in the above simplification the value for \f$(a+b)\f$ (or for
|
1794
|
-
* \f$a\f$ and \f$b\f$) exceeds the limits for integers as
|
1795
|
-
* defined in Limits::Int, an exception of type
|
1796
|
-
* Int::NumericalOverflow is thrown.
|
1797
|
-
* - Assume linear terms for the constraint
|
1798
|
-
* \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
|
1799
|
-
* If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
|
1800
|
-
* for integers as defined in Limits::Int, an exception of
|
1801
|
-
* type Int::NumericalOverflow is thrown.
|
1802
|
-
* - In all other cases, the created propagators are accurate (that
|
1803
|
-
* is, they will not silently overflow during propagation).
|
1804
|
-
*
|
1805
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1806
|
-
* \ingroup FuncIntProp
|
1807
|
-
*/
|
1808
|
-
GECODE_INT_EXPORT void
|
1809
|
-
post(Space* home, Term<BoolView>* t, int n, IntRelType r, IntView y, int c=0,
|
1810
|
-
IntConLevel=ICL_DEF, PropKind=PK_DEF);
|
1811
|
-
|
1812
|
-
/**
|
1813
|
-
* \brief Post propagator for reified linear constraint over Booleans
|
1814
|
-
* \param t array of linear terms over Booleans
|
1815
|
-
* \param n size of array
|
1816
|
-
* \param r type of relation
|
1817
|
-
* \param y variable right hand side of linear constraint
|
1818
|
-
* \param b Boolean control variable
|
1819
|
-
*
|
1820
|
-
* All variants for linear constraints share the following properties:
|
1821
|
-
* - Variables occuring multiply in the term array are replaced
|
1822
|
-
* by a single occurence: for example, \f$ax+bx\f$ becomes
|
1823
|
-
* \f$(a+b)x\f$.
|
1824
|
-
* - If in the above simplification the value for \f$(a+b)\f$ (or for
|
1825
|
-
* \f$a\f$ and \f$b\f$) exceeds the limits for integers as
|
1826
|
-
* defined in Limits::Int, an exception of type
|
1827
|
-
* Int::NumericalOverflow is thrown.
|
1828
|
-
* - Assume linear terms for the constraint
|
1829
|
-
* \f$\sum_{i=0}^{|x|-1}a_i\cdot x_i\sim_r c\f$.
|
1830
|
-
* If \f$|c|+\sum_{i=0}^{|x|-1}a_i\cdot x_i\f$ exceeds the limits
|
1831
|
-
* for integers as defined in Limits::Int, an exception of
|
1832
|
-
* type Int::NumericalOverflow is thrown.
|
1833
|
-
* - In all other cases, the created propagators are accurate (that
|
1834
|
-
* is, they will not silently overflow during propagation).
|
1835
|
-
*
|
1836
|
-
* Requires \code #include "gecode/int/linear.hh" \endcode
|
1837
|
-
* \ingroup FuncIntProp
|
1838
|
-
*/
|
1839
|
-
GECODE_INT_EXPORT void
|
1840
|
-
post(Space* home, Term<BoolView>* t, int n, IntRelType r, IntView y,
|
1841
|
-
BoolView b, IntConLevel=ICL_DEF, PropKind=PK_DEF);
|
1842
|
-
|
1843
|
-
}}}
|
1844
|
-
|
1845
|
-
#include "gecode/int/linear/post.icc"
|
1846
|
-
|
1847
|
-
#endif
|
1848
|
-
|
1849
|
-
// STATISTICS: int-prop
|