1517 lines
146 KiB
XML
1517 lines
146 KiB
XML
|
<?xml version='1.0' encoding='UTF-8' standalone='no'?>
|
||
|
<doxygen xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="compound.xsd" version="1.8.6">
|
||
|
<compounddef id="nroot_8hpp" kind="file">
|
||
|
<compoundname>nroot.hpp</compoundname>
|
||
|
<includes refid="int_2rel_8hh" local="no">gecode/int/rel.hh</includes>
|
||
|
<includes local="no">climits</includes>
|
||
|
<includes local="no">algorithm</includes>
|
||
|
<includedby refid="int_2arithmetic_8hh" local="no">/usr/include/gecode/int/arithmetic.hh</includedby>
|
||
|
<incdepgraph>
|
||
|
<node id="9835">
|
||
|
<label>gecode/support/cast.hpp</label>
|
||
|
<link refid="cast_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9927">
|
||
|
<label>gecode/iter/values-ranges.hpp</label>
|
||
|
<link refid="values-ranges_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9949">
|
||
|
<label>gecode/int/div.hh</label>
|
||
|
<link refid="div_8hh_source"/>
|
||
|
<childnode refid="9819" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9950" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9948">
|
||
|
<label>gecode/int/view/scale.hpp</label>
|
||
|
<link refid="int_2view_2scale_8hpp_source"/>
|
||
|
<childnode refid="9949" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9916">
|
||
|
<label>gecode/iter/ranges-rangelist.hpp</label>
|
||
|
<link refid="ranges-rangelist_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9889">
|
||
|
<label>gecode/kernel/brancher-val-sel-commit.hpp</label>
|
||
|
<link refid="brancher-val-sel-commit_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9922">
|
||
|
<label>gecode/iter/values-map.hpp</label>
|
||
|
<link refid="values-map_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9907">
|
||
|
<label>gecode/iter/ranges-negative.hpp</label>
|
||
|
<link refid="ranges-negative_8hpp_source"/>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9851">
|
||
|
<label>gecode/support/static-stack.hpp</label>
|
||
|
<link refid="static-stack_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9891">
|
||
|
<label>gecode/kernel/var-imp.hpp</label>
|
||
|
<link refid="kernel_2var-imp_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9849">
|
||
|
<label>gecode/support/random.hpp</label>
|
||
|
<link refid="random_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9972">
|
||
|
<label>gecode/int/rel/nq.hpp</label>
|
||
|
<link refid="int_2rel_2nq_8hpp_source"/>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9893">
|
||
|
<label>limits</label>
|
||
|
</node>
|
||
|
<node id="9867">
|
||
|
<label>gecode/kernel/var.hpp</label>
|
||
|
<link refid="kernel_2var_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9952">
|
||
|
<label>gecode/int/view/bool.hpp</label>
|
||
|
<link refid="int_2view_2bool_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9931">
|
||
|
<label>gecode/iter/ranges-size.hpp</label>
|
||
|
<link refid="ranges-size_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9852">
|
||
|
<label>gecode/support/thread/none.hpp</label>
|
||
|
<link refid="none_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9871">
|
||
|
<label>iterator</label>
|
||
|
</node>
|
||
|
<node id="9899">
|
||
|
<label>gecode/iter/ranges-array.hpp</label>
|
||
|
<link refid="ranges-array_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9854">
|
||
|
<label>gecode/support/timer.hpp</label>
|
||
|
<link refid="timer_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9853">
|
||
|
<label>gecode/support/thread/thread.hpp</label>
|
||
|
<link refid="thread_2thread_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9915">
|
||
|
<label>gecode/iter/ranges-singleton-append.hpp</label>
|
||
|
<link refid="ranges-singleton-append_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9909">
|
||
|
<label>gecode/iter/ranges-positive.hpp</label>
|
||
|
<link refid="ranges-positive_8hpp_source"/>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9888">
|
||
|
<label>gecode/kernel/brancher-val-commit.hpp</label>
|
||
|
<link refid="brancher-val-commit_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9940">
|
||
|
<label>gecode/int/view/iter.hpp</label>
|
||
|
<link refid="int_2view_2iter_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9818">
|
||
|
<label>gecode/int/rel.hh</label>
|
||
|
<link refid="int_2rel_8hh_source"/>
|
||
|
<childnode refid="9819" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9971" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9972" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9973" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9974" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9878">
|
||
|
<label>gecode/kernel/afc.hpp</label>
|
||
|
<link refid="kernel_2afc_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9863">
|
||
|
<label>gecode/kernel/var-type.hpp</label>
|
||
|
<link refid="var-type_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9855">
|
||
|
<label>gecode/support/hw-rnd.hpp</label>
|
||
|
<link refid="hw-rnd_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9817">
|
||
|
<label>/usr/include/gecode/int/arithmetic/nroot.hpp</label>
|
||
|
<link refid="nroot.hpp"/>
|
||
|
<childnode refid="9818" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9820" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9919">
|
||
|
<label>gecode/iter/values-bitsetoffset.hpp</label>
|
||
|
<link refid="values-bitsetoffset_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9843">
|
||
|
<label>cmath</label>
|
||
|
</node>
|
||
|
<node id="9828">
|
||
|
<label>cassert</label>
|
||
|
</node>
|
||
|
<node id="9885">
|
||
|
<label>gecode/kernel/brancher-view-sel.hpp</label>
|
||
|
<link refid="brancher-view-sel_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9892">
|
||
|
<label>gecode/kernel/allocators.hpp</label>
|
||
|
<link refid="allocators_8hpp_source"/>
|
||
|
<childnode refid="9893" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9960">
|
||
|
<label>gecode/int/int-set-2.hpp</label>
|
||
|
<link refid="int-set-2_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9870">
|
||
|
<label>cstdarg</label>
|
||
|
</node>
|
||
|
<node id="9841">
|
||
|
<label>gecode/support/bitset-base.hpp</label>
|
||
|
<link refid="bitset-base_8hpp_source"/>
|
||
|
<childnode refid="9820" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9873">
|
||
|
<label>gecode/kernel/shared-array.hpp</label>
|
||
|
<link refid="shared-array_8hpp_source"/>
|
||
|
<childnode refid="9870" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9822" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9872" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9951">
|
||
|
<label>gecode/int/view/cached.hpp</label>
|
||
|
<link refid="int_2view_2cached_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9864">
|
||
|
<label>gecode/kernel/modevent.hpp</label>
|
||
|
<link refid="modevent_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9857">
|
||
|
<label>gecode/kernel/memory-config.hpp</label>
|
||
|
<link refid="memory-config_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9969">
|
||
|
<label>gecode/int/branch/val.hpp</label>
|
||
|
<link refid="int_2branch_2val_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9840">
|
||
|
<label>gecode/support/int-type.hpp</label>
|
||
|
<link refid="int-type_8hpp_source"/>
|
||
|
<childnode refid="9820" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9926">
|
||
|
<label>gecode/iter/values-positive.hpp</label>
|
||
|
<link refid="values-positive_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9821">
|
||
|
<label>cfloat</label>
|
||
|
</node>
|
||
|
<node id="9932">
|
||
|
<label>gecode/int/exception.hpp</label>
|
||
|
<link refid="int_2exception_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9833">
|
||
|
<label>gecode/support/exception.hpp</label>
|
||
|
<link refid="support_2exception_8hpp_source"/>
|
||
|
<childnode refid="9834" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9834">
|
||
|
<label>exception</label>
|
||
|
</node>
|
||
|
<node id="9905">
|
||
|
<label>gecode/iter/ranges-map.hpp</label>
|
||
|
<link refid="ranges-map_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9866">
|
||
|
<label>gecode/kernel/region.hpp</label>
|
||
|
<link refid="region_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9839">
|
||
|
<label>gecode/support/marked-pointer.hpp</label>
|
||
|
<link refid="marked-pointer_8hpp_source"/>
|
||
|
<childnode refid="9825" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9836">
|
||
|
<label>gecode/support/thread.hpp</label>
|
||
|
<link refid="thread_8hpp_source"/>
|
||
|
<childnode refid="9825" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9824">
|
||
|
<label>gecode/kernel.hh</label>
|
||
|
<link refid="kernel_8hh_source"/>
|
||
|
<childnode refid="9825" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9826" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9827" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9828" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9829" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9831" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9856" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9857" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9858" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9859" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9860" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9861" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9862" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9864" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9865" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9866" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9867" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9868" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9869" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9873" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9874" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9876" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9877" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9878" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9879" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9880" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9881" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9882" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9883" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9884" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9885" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9886" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9887" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9888" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9889" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9890" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9891" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9892" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9934">
|
||
|
<label>gecode/int/int-set-1.hpp</label>
|
||
|
<link refid="int-set-1_8hpp_source"/>
|
||
|
<childnode refid="9872" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9879">
|
||
|
<label>gecode/kernel/branch-traits.hpp</label>
|
||
|
<link refid="branch-traits_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9945">
|
||
|
<label>gecode/int/view/zero.hpp</label>
|
||
|
<link refid="zero_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9901">
|
||
|
<label>gecode/iter/ranges-compl.hpp</label>
|
||
|
<link refid="ranges-compl_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9963">
|
||
|
<label>gecode/int/extensional/dfa.hpp</label>
|
||
|
<link refid="dfa_8hpp_source"/>
|
||
|
<childnode refid="9872" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9869">
|
||
|
<label>gecode/kernel/array.hpp</label>
|
||
|
<link refid="kernel_2array_8hpp_source"/>
|
||
|
<childnode refid="9870" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9822" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9871" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9823" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9872" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9966">
|
||
|
<label>gecode/int/branch/afc.hpp</label>
|
||
|
<link refid="int_2branch_2afc_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9883">
|
||
|
<label>gecode/kernel/branch-val.hpp</label>
|
||
|
<link refid="branch-val_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9848">
|
||
|
<label>gecode/support/dynamic-stack.hpp</label>
|
||
|
<link refid="dynamic-stack_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9910">
|
||
|
<label>gecode/iter/ranges-scale.hpp</label>
|
||
|
<link refid="ranges-scale_8hpp_source"/>
|
||
|
<childnode refid="9843" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9860">
|
||
|
<label>gecode/kernel/archive.hpp</label>
|
||
|
<link refid="archive_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9865">
|
||
|
<label>gecode/kernel/range-list.hpp</label>
|
||
|
<link refid="range-list_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9921">
|
||
|
<label>gecode/iter/values-inter.hpp</label>
|
||
|
<link refid="values-inter_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9884">
|
||
|
<label>gecode/kernel/brancher-merit.hpp</label>
|
||
|
<link refid="brancher-merit_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9830">
|
||
|
<label>gecode/support/config.hpp</label>
|
||
|
<link refid="support_2config_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9957">
|
||
|
<label>gecode/int/view/bool-test.hpp</label>
|
||
|
<link refid="bool-test_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9914">
|
||
|
<label>gecode/iter/ranges-add.hpp</label>
|
||
|
<link refid="ranges-add_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9939">
|
||
|
<label>gecode/int/view.hpp</label>
|
||
|
<link refid="int_2view_8hpp_source"/>
|
||
|
<childnode refid="9822" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9940" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9941" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9942" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9943" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9944" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9945" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9946" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9947" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9948" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9951" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9952" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9953" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9954" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9955" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9956" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9957" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9920">
|
||
|
<label>gecode/iter/values-list.hpp</label>
|
||
|
<link refid="values-list_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9923">
|
||
|
<label>gecode/iter/values-minus.hpp</label>
|
||
|
<link refid="values-minus_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9881">
|
||
|
<label>gecode/kernel/branch-var.hpp</label>
|
||
|
<link refid="branch-var_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9973">
|
||
|
<label>gecode/int/rel/lq-le.hpp</label>
|
||
|
<link refid="int_2rel_2lq-le_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9858">
|
||
|
<label>gecode/kernel/memory-manager.hpp</label>
|
||
|
<link refid="memory-manager_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9933">
|
||
|
<label>gecode/int/limits.hpp</label>
|
||
|
<link refid="int_2limits_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9847">
|
||
|
<label>gecode/support/dynamic-queue.hpp</label>
|
||
|
<link refid="dynamic-queue_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9958">
|
||
|
<label>gecode/int/propagator.hpp</label>
|
||
|
<link refid="int_2propagator_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9965">
|
||
|
<label>gecode/int/branch/traits.hpp</label>
|
||
|
<link refid="int_2branch_2traits_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9929">
|
||
|
<label>gecode/iter/values-union.hpp</label>
|
||
|
<link refid="values-union_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9859">
|
||
|
<label>gecode/kernel/macros.hpp</label>
|
||
|
<link refid="kernel_2macros_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9908">
|
||
|
<label>gecode/iter/ranges-offset.hpp</label>
|
||
|
<link refid="ranges-offset_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9875">
|
||
|
<label>ctime</label>
|
||
|
</node>
|
||
|
<node id="9947">
|
||
|
<label>gecode/int/view/offset.hpp</label>
|
||
|
<link refid="int_2view_2offset_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9917">
|
||
|
<label>gecode/iter/values-array.hpp</label>
|
||
|
<link refid="values-array_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9968">
|
||
|
<label>gecode/int/branch/var.hpp</label>
|
||
|
<link refid="int_2branch_2var_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9911">
|
||
|
<label>gecode/iter/ranges-singleton.hpp</label>
|
||
|
<link refid="ranges-singleton_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9823">
|
||
|
<label>vector</label>
|
||
|
</node>
|
||
|
<node id="9974">
|
||
|
<label>gecode/int/rel/lex.hpp</label>
|
||
|
<link refid="lex_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9954">
|
||
|
<label>gecode/int/view/print.hpp</label>
|
||
|
<link refid="int_2view_2print_8hpp_source"/>
|
||
|
<childnode refid="9872" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9877">
|
||
|
<label>gecode/kernel/advisor.hpp</label>
|
||
|
<link refid="advisor_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9964">
|
||
|
<label>gecode/int/extensional/tuple-set.hpp</label>
|
||
|
<link refid="tuple-set_8hpp_source"/>
|
||
|
<childnode refid="9872" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9890">
|
||
|
<label>gecode/kernel/brancher-view-val.hpp</label>
|
||
|
<link refid="brancher-view-val_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9943">
|
||
|
<label>gecode/int/view/int.hpp</label>
|
||
|
<link refid="int_2view_2int_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9956">
|
||
|
<label>gecode/int/view/rel-test.hpp</label>
|
||
|
<link refid="int_2view_2rel-test_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9872">
|
||
|
<label>sstream</label>
|
||
|
</node>
|
||
|
<node id="9959">
|
||
|
<label>gecode/int/array-traits.hpp</label>
|
||
|
<link refid="int_2array-traits_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9887">
|
||
|
<label>gecode/kernel/brancher-val-sel.hpp</label>
|
||
|
<link refid="brancher-val-sel_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9876">
|
||
|
<label>gecode/kernel/propagator.hpp</label>
|
||
|
<link refid="kernel_2propagator_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9845">
|
||
|
<label>gecode/support/block-allocator.hpp</label>
|
||
|
<link refid="block-allocator_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9950">
|
||
|
<label>gecode/int/div.hpp</label>
|
||
|
<link refid="int_2div_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9925">
|
||
|
<label>gecode/iter/values-offset.hpp</label>
|
||
|
<link refid="values-offset_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9961">
|
||
|
<label>gecode/int/array.hpp</label>
|
||
|
<link refid="int_2array_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9880">
|
||
|
<label>gecode/kernel/activity.hpp</label>
|
||
|
<link refid="kernel_2activity_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9819">
|
||
|
<label>gecode/int.hh</label>
|
||
|
<link refid="int_8hh_source"/>
|
||
|
<childnode refid="9820" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9821" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9822" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9823" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9824" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9894" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9831" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9932" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9933" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9934" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9935" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9939" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9958" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9959" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9960" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9961" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9962" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9963" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9964" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9965" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9966" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9967" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9968" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9969" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9970" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9826">
|
||
|
<label>cstdlib</label>
|
||
|
</node>
|
||
|
<node id="9842">
|
||
|
<label>gecode/support/bitset.hpp</label>
|
||
|
<link refid="bitset_8hpp_source"/>
|
||
|
<childnode refid="9820" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9843" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9942">
|
||
|
<label>gecode/int/var/bool.hpp</label>
|
||
|
<link refid="int_2var_2bool_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9831">
|
||
|
<label>gecode/support/auto-link.hpp</label>
|
||
|
<link refid="auto-link_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9970">
|
||
|
<label>gecode/int/branch/assign.hpp</label>
|
||
|
<link refid="int_2branch_2assign_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9822">
|
||
|
<label>iostream</label>
|
||
|
</node>
|
||
|
<node id="9856">
|
||
|
<label>gecode/kernel/exception.hpp</label>
|
||
|
<link refid="kernel_2exception_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9953">
|
||
|
<label>gecode/int/view/neg-bool.hpp</label>
|
||
|
<link refid="neg-bool_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9906">
|
||
|
<label>gecode/iter/ranges-minus.hpp</label>
|
||
|
<link refid="ranges-minus_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9924">
|
||
|
<label>gecode/iter/values-negative.hpp</label>
|
||
|
<link refid="values-negative_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9832">
|
||
|
<label>gecode/support/macros.hpp</label>
|
||
|
<link refid="support_2macros_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9868">
|
||
|
<label>gecode/kernel/view.hpp</label>
|
||
|
<link refid="kernel_2view_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9882">
|
||
|
<label>gecode/kernel/branch-tiebreak.hpp</label>
|
||
|
<link refid="branch-tiebreak_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9825">
|
||
|
<label>cstddef</label>
|
||
|
</node>
|
||
|
<node id="9820">
|
||
|
<label>climits</label>
|
||
|
</node>
|
||
|
<node id="9928">
|
||
|
<label>gecode/iter/values-singleton.hpp</label>
|
||
|
<link refid="values-singleton_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9862">
|
||
|
<label>gecode/kernel/core.hpp</label>
|
||
|
<link refid="core_8hpp_source"/>
|
||
|
<childnode refid="9822" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9863" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9904">
|
||
|
<label>gecode/iter/ranges-inter.hpp</label>
|
||
|
<link refid="ranges-inter_8hpp_source"/>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9898">
|
||
|
<label>gecode/iter/ranges-append.hpp</label>
|
||
|
<link refid="ranges-append_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9895">
|
||
|
<label>gecode/iter/ranges-operations.hpp</label>
|
||
|
<link refid="ranges-operations_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9829">
|
||
|
<label>gecode/support.hh</label>
|
||
|
<link refid="support_8hh_source"/>
|
||
|
<childnode refid="9828" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9830" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9831" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9832" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9833" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9835" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9836" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9837" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9839" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9840" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9841" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9842" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9844" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9845" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9846" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9847" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9848" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9849" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9850" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9851" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9852" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9853" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9854" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9855" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9967">
|
||
|
<label>gecode/int/branch/activity.hpp</label>
|
||
|
<link refid="int_2branch_2activity_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9937">
|
||
|
<label>gecode/int/var-imp/int.hpp</label>
|
||
|
<link refid="int_2var-imp_2int_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9935">
|
||
|
<label>gecode/int/var-imp.hpp</label>
|
||
|
<link refid="int_2var-imp_8hpp_source"/>
|
||
|
<childnode refid="9843" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9936" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9937" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9938" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9900">
|
||
|
<label>gecode/iter/ranges-cache.hpp</label>
|
||
|
<link refid="ranges-cache_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9846">
|
||
|
<label>gecode/support/dynamic-array.hpp</label>
|
||
|
<link refid="dynamic-array_8hpp_source"/>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9944">
|
||
|
<label>gecode/int/view/constint.hpp</label>
|
||
|
<link refid="constint_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9930">
|
||
|
<label>gecode/iter/values-unique.hpp</label>
|
||
|
<link refid="values-unique_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9902">
|
||
|
<label>gecode/iter/ranges-diff.hpp</label>
|
||
|
<link refid="ranges-diff_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9850">
|
||
|
<label>gecode/support/sort.hpp</label>
|
||
|
<link refid="support_2sort_8hpp_source"/>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9820" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9936">
|
||
|
<label>gecode/int/var-imp/delta.hpp</label>
|
||
|
<link refid="int_2var-imp_2delta_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9874">
|
||
|
<label>gecode/kernel/rnd.hpp</label>
|
||
|
<link refid="rnd_8hpp_source"/>
|
||
|
<childnode refid="9875" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9838">
|
||
|
<label>algorithm</label>
|
||
|
</node>
|
||
|
<node id="9886">
|
||
|
<label>gecode/kernel/brancher-view.hpp</label>
|
||
|
<link refid="brancher-view_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9971">
|
||
|
<label>gecode/int/rel/eq.hpp</label>
|
||
|
<link refid="int_2rel_2eq_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9918">
|
||
|
<label>gecode/iter/values-bitset.hpp</label>
|
||
|
<link refid="values-bitset_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9861">
|
||
|
<label>gecode/kernel/global-afc.hpp</label>
|
||
|
<link refid="global-afc_8hpp_source"/>
|
||
|
<childnode refid="9843" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9903">
|
||
|
<label>gecode/iter/ranges-empty.hpp</label>
|
||
|
<link refid="ranges-empty_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9941">
|
||
|
<label>gecode/int/var/int.hpp</label>
|
||
|
<link refid="int_2var_2int_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9894">
|
||
|
<label>gecode/iter.hh</label>
|
||
|
<link refid="iter_8hh_source"/>
|
||
|
<childnode refid="9824" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9895" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9896" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9897" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9898" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9899" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9900" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9901" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9902" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9903" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9904" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9905" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9906" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9907" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9908" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9909" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9910" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9911" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9912" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9913" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9914" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9915" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9916" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9917" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9918" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9919" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9920" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9921" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9922" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9923" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9924" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9925" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9926" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9927" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9928" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9929" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9930" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9931" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9913">
|
||
|
<label>gecode/iter/ranges-values.hpp</label>
|
||
|
<link refid="ranges-values_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9938">
|
||
|
<label>gecode/int/var-imp/bool.hpp</label>
|
||
|
<link refid="int_2var-imp_2bool_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9827">
|
||
|
<label>cstring</label>
|
||
|
</node>
|
||
|
<node id="9962">
|
||
|
<label>gecode/int/reify.hpp</label>
|
||
|
<link refid="reify_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9912">
|
||
|
<label>gecode/iter/ranges-union.hpp</label>
|
||
|
<link refid="ranges-union_8hpp_source"/>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9946">
|
||
|
<label>gecode/int/view/minus.hpp</label>
|
||
|
<link refid="int_2view_2minus_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9896">
|
||
|
<label>gecode/iter/ranges-minmax.hpp</label>
|
||
|
<link refid="ranges-minmax_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9844">
|
||
|
<label>gecode/support/bitset-offset.hpp</label>
|
||
|
<link refid="bitset-offset_8hpp_source"/>
|
||
|
<childnode refid="9820" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9843" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9822" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9837">
|
||
|
<label>gecode/support/heap.hpp</label>
|
||
|
<link refid="heap_8hpp_source"/>
|
||
|
<childnode refid="9827" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9826" relation="include">
|
||
|
</childnode>
|
||
|
<childnode refid="9838" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
<node id="9955">
|
||
|
<label>gecode/int/var/print.hpp</label>
|
||
|
<link refid="int_2var_2print_8hpp_source"/>
|
||
|
</node>
|
||
|
<node id="9897">
|
||
|
<label>gecode/iter/ranges-list.hpp</label>
|
||
|
<link refid="ranges-list_8hpp_source"/>
|
||
|
</node>
|
||
|
</incdepgraph>
|
||
|
<invincdepgraph>
|
||
|
<node id="9976">
|
||
|
<label>/usr/include/gecode/int/arithmetic.hh</label>
|
||
|
<link refid="int_2arithmetic_8hh_source"/>
|
||
|
</node>
|
||
|
<node id="9975">
|
||
|
<label>/usr/include/gecode/int/arithmetic/nroot.hpp</label>
|
||
|
<link refid="nroot.hpp"/>
|
||
|
<childnode refid="9976" relation="include">
|
||
|
</childnode>
|
||
|
</node>
|
||
|
</invincdepgraph>
|
||
|
<innerclass refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow" prot="public">Gecode::Int::Arithmetic::RangesMapPow</innerclass>
|
||
|
<innerclass refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot" prot="public">Gecode::Int::Arithmetic::RangesMapNroot</innerclass>
|
||
|
<innernamespace refid="namespaceGecode">Gecode</innernamespace>
|
||
|
<innernamespace refid="namespaceGecode_1_1Int">Gecode::Int</innernamespace>
|
||
|
<innernamespace refid="namespaceGecode_1_1Int_1_1Arithmetic">Gecode::Int::Arithmetic</innernamespace>
|
||
|
<briefdescription>
|
||
|
</briefdescription>
|
||
|
<detaileddescription>
|
||
|
</detaileddescription>
|
||
|
<programlisting>
|
||
|
<codeline lineno="1"><highlight class="comment">/*<sp/>-*-<sp/>mode:<sp/>C++;<sp/>c-basic-offset:<sp/>2;<sp/>indent-tabs-mode:<sp/>nil<sp/>-*-<sp/>*/</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="2"><highlight class="normal"></highlight><highlight class="comment">/*</highlight></codeline>
|
||
|
<codeline lineno="3"><highlight class="comment"><sp/>*<sp/><sp/>Main<sp/>authors:</highlight></codeline>
|
||
|
<codeline lineno="4"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/><sp/>Christian<sp/>Schulte<sp/><schulte@gecode.org></highlight></codeline>
|
||
|
<codeline lineno="5"><highlight class="comment"><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="6"><highlight class="comment"><sp/>*<sp/><sp/>Copyright:</highlight></codeline>
|
||
|
<codeline lineno="7"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/><sp/>Christian<sp/>Schulte,<sp/>2012</highlight></codeline>
|
||
|
<codeline lineno="8"><highlight class="comment"><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="9"><highlight class="comment"><sp/>*<sp/><sp/>Last<sp/>modified:</highlight></codeline>
|
||
|
<codeline lineno="10"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/><sp/>$Date:<sp/>2013-08-29<sp/>16:05:54<sp/>+0200<sp/>(Thu,<sp/>29<sp/>Aug<sp/>2013)<sp/>$<sp/>by<sp/>$Author:<sp/>schulte<sp/>$</highlight></codeline>
|
||
|
<codeline lineno="11"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/><sp/>$Revision:<sp/>13993<sp/>$</highlight></codeline>
|
||
|
<codeline lineno="12"><highlight class="comment"><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="13"><highlight class="comment"><sp/>*<sp/><sp/>This<sp/>file<sp/>is<sp/>part<sp/>of<sp/>Gecode,<sp/>the<sp/>generic<sp/>constraint</highlight></codeline>
|
||
|
<codeline lineno="14"><highlight class="comment"><sp/>*<sp/><sp/>development<sp/>environment:</highlight></codeline>
|
||
|
<codeline lineno="15"><highlight class="comment"><sp/>*<sp/><sp/><sp/><sp/><sp/>http://www.gecode.org</highlight></codeline>
|
||
|
<codeline lineno="16"><highlight class="comment"><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="17"><highlight class="comment"><sp/>*<sp/><sp/>Permission<sp/>is<sp/>hereby<sp/>granted,<sp/>free<sp/>of<sp/>charge,<sp/>to<sp/>any<sp/>person<sp/>obtaining</highlight></codeline>
|
||
|
<codeline lineno="18"><highlight class="comment"><sp/>*<sp/><sp/>a<sp/>copy<sp/>of<sp/>this<sp/>software<sp/>and<sp/>associated<sp/>documentation<sp/>files<sp/>(the</highlight></codeline>
|
||
|
<codeline lineno="19"><highlight class="comment"><sp/>*<sp/><sp/>"Software"),<sp/>to<sp/>deal<sp/>in<sp/>the<sp/>Software<sp/>without<sp/>restriction,<sp/>including</highlight></codeline>
|
||
|
<codeline lineno="20"><highlight class="comment"><sp/>*<sp/><sp/>without<sp/>limitation<sp/>the<sp/>rights<sp/>to<sp/>use,<sp/>copy,<sp/>modify,<sp/>merge,<sp/>publish,</highlight></codeline>
|
||
|
<codeline lineno="21"><highlight class="comment"><sp/>*<sp/><sp/>distribute,<sp/>sublicense,<sp/>and/or<sp/>sell<sp/>copies<sp/>of<sp/>the<sp/>Software,<sp/>and<sp/>to</highlight></codeline>
|
||
|
<codeline lineno="22"><highlight class="comment"><sp/>*<sp/><sp/>permit<sp/>persons<sp/>to<sp/>whom<sp/>the<sp/>Software<sp/>is<sp/>furnished<sp/>to<sp/>do<sp/>so,<sp/>subject<sp/>to</highlight></codeline>
|
||
|
<codeline lineno="23"><highlight class="comment"><sp/>*<sp/><sp/>the<sp/>following<sp/>conditions:</highlight></codeline>
|
||
|
<codeline lineno="24"><highlight class="comment"><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="25"><highlight class="comment"><sp/>*<sp/><sp/>The<sp/>above<sp/>copyright<sp/>notice<sp/>and<sp/>this<sp/>permission<sp/>notice<sp/>shall<sp/>be</highlight></codeline>
|
||
|
<codeline lineno="26"><highlight class="comment"><sp/>*<sp/><sp/>included<sp/>in<sp/>all<sp/>copies<sp/>or<sp/>substantial<sp/>portions<sp/>of<sp/>the<sp/>Software.</highlight></codeline>
|
||
|
<codeline lineno="27"><highlight class="comment"><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="28"><highlight class="comment"><sp/>*<sp/><sp/>THE<sp/>SOFTWARE<sp/>IS<sp/>PROVIDED<sp/>"AS<sp/>IS",<sp/>WITHOUT<sp/>WARRANTY<sp/>OF<sp/>ANY<sp/>KIND,</highlight></codeline>
|
||
|
<codeline lineno="29"><highlight class="comment"><sp/>*<sp/><sp/>EXPRESS<sp/>OR<sp/>IMPLIED,<sp/>INCLUDING<sp/>BUT<sp/>NOT<sp/>LIMITED<sp/>TO<sp/>THE<sp/>WARRANTIES<sp/>OF</highlight></codeline>
|
||
|
<codeline lineno="30"><highlight class="comment"><sp/>*<sp/><sp/>MERCHANTABILITY,<sp/>FITNESS<sp/>FOR<sp/>A<sp/>PARTICULAR<sp/>PURPOSE<sp/>AND</highlight></codeline>
|
||
|
<codeline lineno="31"><highlight class="comment"><sp/>*<sp/><sp/>NONINFRINGEMENT.<sp/>IN<sp/>NO<sp/>EVENT<sp/>SHALL<sp/>THE<sp/>AUTHORS<sp/>OR<sp/>COPYRIGHT<sp/>HOLDERS<sp/>BE</highlight></codeline>
|
||
|
<codeline lineno="32"><highlight class="comment"><sp/>*<sp/><sp/>LIABLE<sp/>FOR<sp/>ANY<sp/>CLAIM,<sp/>DAMAGES<sp/>OR<sp/>OTHER<sp/>LIABILITY,<sp/>WHETHER<sp/>IN<sp/>AN<sp/>ACTION</highlight></codeline>
|
||
|
<codeline lineno="33"><highlight class="comment"><sp/>*<sp/><sp/>OF<sp/>CONTRACT,<sp/>TORT<sp/>OR<sp/>OTHERWISE,<sp/>ARISING<sp/>FROM,<sp/>OUT<sp/>OF<sp/>OR<sp/>IN<sp/>CONNECTION</highlight></codeline>
|
||
|
<codeline lineno="34"><highlight class="comment"><sp/>*<sp/><sp/>WITH<sp/>THE<sp/>SOFTWARE<sp/>OR<sp/>THE<sp/>USE<sp/>OR<sp/>OTHER<sp/>DEALINGS<sp/>IN<sp/>THE<sp/>SOFTWARE.</highlight></codeline>
|
||
|
<codeline lineno="35"><highlight class="comment"><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="36"><highlight class="comment"><sp/>*/</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="37"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="38"><highlight class="normal"></highlight><highlight class="preprocessor">#include<sp/><gecode/int/rel.hh></highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="39"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="40"><highlight class="normal"></highlight><highlight class="preprocessor">#include<sp/><climits></highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="41"><highlight class="normal"></highlight><highlight class="preprocessor">#include<sp/><algorithm></highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="42"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="43"><highlight class="normal"></highlight><highlight class="keyword">namespace<sp/></highlight><highlight class="normal">Gecode<sp/>{<sp/></highlight><highlight class="keyword">namespace<sp/></highlight><highlight class="normal">Int<sp/>{<sp/></highlight><highlight class="keyword">namespace<sp/></highlight><highlight class="normal">Arithmetic<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="44"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="45"><highlight class="normal"><sp/><sp/></highlight><highlight class="comment">/*</highlight></codeline>
|
||
|
<codeline lineno="46"><highlight class="comment"><sp/><sp/><sp/>*<sp/>Positive<sp/>bounds<sp/>consistent<sp/>nth<sp/>root</highlight></codeline>
|
||
|
<codeline lineno="47"><highlight class="comment"><sp/><sp/><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="48"><highlight class="comment"><sp/><sp/><sp/>*/</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="49"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="50"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="51"><highlight class="normal"><sp/><sp/>forceinline<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="52"><highlight class="normal"><sp/><sp/>prop_nroot_plus_bnd(Space&<sp/>home,<sp/>IntView<sp/>x0,<sp/>IntView<sp/>x1,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>ops)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="53"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(minus)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="54"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/><ref refid="group__TaskModelIntArith_1ga4cd6235cdf64674a689b4d75da983394" kindref="member">mod</ref>;</highlight></codeline>
|
||
|
<codeline lineno="55"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">do</highlight><highlight class="normal"><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="56"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>=<sp/></highlight><highlight class="keyword">false</highlight><highlight class="normal">;</highlight></codeline>
|
||
|
<codeline lineno="57"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="58"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x1.gq(home,-ops.cnroot(-x0.min()));</highlight></codeline>
|
||
|
<codeline lineno="59"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="60"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="61"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="62"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="63"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x1.lq(home,-ops.cnroot(-x0.max()));</highlight></codeline>
|
||
|
<codeline lineno="64"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="65"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="66"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="67"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="68"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x0.gq(home,-ops.tpow(-x1.min()));</highlight></codeline>
|
||
|
<codeline lineno="69"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="70"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="71"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="72"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="73"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x0.lq(home,-(ops.tpow(-x1.max()-1)+1));</highlight></codeline>
|
||
|
<codeline lineno="74"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="75"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="76"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="77"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>}<sp/></highlight><highlight class="keywordflow">while</highlight><highlight class="normal"><sp/>(mod);</highlight></codeline>
|
||
|
<codeline lineno="78"><highlight class="normal"><sp/><sp/><sp/><sp/>}<sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="79"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/><ref refid="group__TaskModelIntArith_1ga4cd6235cdf64674a689b4d75da983394" kindref="member">mod</ref>;</highlight></codeline>
|
||
|
<codeline lineno="80"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">do</highlight><highlight class="normal"><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="81"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>=<sp/></highlight><highlight class="keyword">false</highlight><highlight class="normal">;</highlight></codeline>
|
||
|
<codeline lineno="82"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="83"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x1.lq(home,ops.fnroot(x0.max()));</highlight></codeline>
|
||
|
<codeline lineno="84"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="85"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="86"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="87"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="88"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x1.gq(home,ops.fnroot(x0.min()));</highlight></codeline>
|
||
|
<codeline lineno="89"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="90"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="91"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="92"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="93"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x0.le(home,ops.tpow(x1.max()+1));</highlight></codeline>
|
||
|
<codeline lineno="94"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="95"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="96"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="97"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="98"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="group__TaskVarMEPC_1gafa985ae465bd12df08e29252cdb7519b" kindref="member">ModEvent</ref><sp/>me<sp/>=<sp/>x0.gq(home,ops.tpow(x1.min()));</highlight></codeline>
|
||
|
<codeline lineno="99"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="namespaceGecode_1a93e4dea4e5e021b4f58d0ccc78ac1523" kindref="member">me_failed</ref>(me))<sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a839b40c2e7ccebb2e61e92e274833089" kindref="member">ES_FAILED</ref>;</highlight></codeline>
|
||
|
<codeline lineno="100"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>mod<sp/>|=<sp/><ref refid="namespaceGecode_1ab0c2b67fac58a0d289893450d8a9b2bd" kindref="member">me_modified</ref>(me);</highlight></codeline>
|
||
|
<codeline lineno="101"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="102"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>}<sp/></highlight><highlight class="keywordflow">while</highlight><highlight class="normal"><sp/>(mod);</highlight></codeline>
|
||
|
<codeline lineno="103"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="104"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="105"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="106"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="107"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="108"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="109" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a6f3210e23a77258890ed929e0d5b1b42" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a7951620c43e3d6ba0c1208af54b8e342" kindref="member">NrootPlusBnd<Ops,minus>::NrootPlusBnd</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/></highlight></codeline>
|
||
|
<codeline lineno="110"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>o)</highlight></codeline>
|
||
|
<codeline lineno="111"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_BND>(home,x0,x1),<sp/></highlight></codeline>
|
||
|
<codeline lineno="112"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(o)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="113"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="114"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="115"><highlight class="normal"><sp/><sp/>forceinline<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="116" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a02b74c91c8e959ca6cd1fc8e90d13ef9" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a02b74c91c8e959ca6cd1fc8e90d13ef9" kindref="member">NrootPlusBnd<Ops,minus>::post</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/>Ops<sp/>ops)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="117"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(minus)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="118"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="119"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="120"><highlight class="normal"><sp/><sp/><sp/><sp/>}<sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="121"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="122"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="123"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="124"><highlight class="normal"><sp/><sp/><sp/><sp/>(void)<sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd" kindref="compound">NrootPlusBnd<Ops,minus></ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="125"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="126"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="127"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="128"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="129"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="130" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a7951620c43e3d6ba0c1208af54b8e342" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a7951620c43e3d6ba0c1208af54b8e342" kindref="member">NrootPlusBnd<Ops,minus>::NrootPlusBnd</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share,<sp/></highlight></codeline>
|
||
|
<codeline lineno="131"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd" kindref="compound">NrootPlusBnd<Ops,minus></ref>&<sp/>p)</highlight></codeline>
|
||
|
<codeline lineno="132"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_BND>(home,share,p),<sp/></highlight></codeline>
|
||
|
<codeline lineno="133"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(p.ops)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="134"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="135"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="136"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Actor" kindref="compound">Actor</ref>*</highlight></codeline>
|
||
|
<codeline lineno="137" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1ad96c0a28824f2bc1ab26d3caef03b2a2" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1ad96c0a28824f2bc1ab26d3caef03b2a2" kindref="member">NrootPlusBnd<Ops,minus>::copy</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="138"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd" kindref="compound">NrootPlusBnd<Ops,minus></ref>(home,share,*</highlight><highlight class="keyword">this</highlight><highlight class="normal">);</highlight></codeline>
|
||
|
<codeline lineno="139"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="140"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="141"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="142"><highlight class="normal"><sp/><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="143" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1ab087e2a108e6e66b6a403d239402a6ec" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1ab087e2a108e6e66b6a403d239402a6ec" kindref="member">NrootPlusBnd<Ops,minus>::propagate</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1a129e41c1d037528010d7b6706495a560" kindref="member">ModEventDelta</ref>&)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="144"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ES_CHECK((prop_nroot_plus_bnd<Ops,minus>(home,x0,x1,ops)));</highlight></codeline>
|
||
|
<codeline lineno="145"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>x1.assigned()<sp/>?<sp/>home.<ref refid="group__TaskActorStatus_1gafc19cbf71ed90a9e0b414b875103f4c7" kindref="member">ES_SUBSUMED</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">)<sp/>:<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a13bb69056fb9293e8df98c0e347ba634" kindref="member">ES_FIX</ref>;</highlight></codeline>
|
||
|
<codeline lineno="146"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="147"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="148"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="149"><highlight class="normal"><sp/><sp/></highlight><highlight class="comment">/*</highlight></codeline>
|
||
|
<codeline lineno="150"><highlight class="comment"><sp/><sp/><sp/>*<sp/>Bounds<sp/>consistent<sp/>nth<sp/>root</highlight></codeline>
|
||
|
<codeline lineno="151"><highlight class="comment"><sp/><sp/><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="152"><highlight class="comment"><sp/><sp/><sp/>*/</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="153"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="154"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="155"><highlight class="normal"><sp/><sp/>forceinline<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="156"><highlight class="normal"><sp/><sp/>prop_nroot_bnd(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>ops)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="157"><highlight class="normal"><sp/><sp/><sp/><sp/>assert((x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/><<sp/>0)<sp/>&&<sp/>(x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/>><sp/>0));</highlight></codeline>
|
||
|
<codeline lineno="158"><highlight class="normal"><sp/><sp/><sp/><sp/>assert((x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/><<sp/>0)<sp/>&&<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/>><sp/>0));</highlight></codeline>
|
||
|
<codeline lineno="159"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight></codeline>
|
||
|
<codeline lineno="160"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,ops.fnroot(x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>())));</highlight></codeline>
|
||
|
<codeline lineno="161"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,-ops.cnroot(-x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>())));</highlight></codeline>
|
||
|
<codeline lineno="162"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ab9f0a0b85e62380f7983a8ffbad3bf46" kindref="member">le</ref>(home,ops.tpow(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()+1)));</highlight></codeline>
|
||
|
<codeline lineno="163"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,ops.tpow(x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()-1)+1));</highlight></codeline>
|
||
|
<codeline lineno="164"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="165"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="166"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="167"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="168"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="169"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="170" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1a1849275350a8d67e3bd96b62c48f4443" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1ac06ceeb035f60a801b07335a54ee4060" kindref="member">NrootBnd<Ops>::NrootBnd</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>o)</highlight></codeline>
|
||
|
<codeline lineno="171"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_BND>(home,x0,x1),<sp/></highlight></codeline>
|
||
|
<codeline lineno="172"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(o)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="173"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="174"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="175"><highlight class="normal"><sp/><sp/>forceinline<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="176" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1a26b510b10a6b6855ce80ca27b525b690" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1a26b510b10a6b6855ce80ca27b525b690" kindref="member">NrootBnd<Ops>::post</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/>Ops<sp/>ops)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="177"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(static_cast<unsigned<sp/>int>(ops.exp())<sp/>>=<sp/></highlight><highlight class="keyword">sizeof</highlight><highlight class="normal">(</highlight><highlight class="keywordtype">int</highlight><highlight class="normal">)<sp/>*<sp/>CHAR_BIT)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="178"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="comment">//<sp/>The<sp/>integer<sp/>limits<sp/>allow<sp/>only<sp/>-2,<sp/>-1,<sp/>0,<sp/>1<sp/>for<sp/>x1</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="179"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,1));</highlight></codeline>
|
||
|
<codeline lineno="180"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,-2));</highlight></codeline>
|
||
|
<codeline lineno="181"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="comment">//<sp/>Just<sp/>rewrite<sp/>to<sp/>values<sp/>that<sp/>can<sp/>be<sp/>handeled<sp/>without<sp/>overflow</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="182"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops.exp(ops.even()<sp/>?<sp/>30<sp/>:<sp/>31);</highlight></codeline>
|
||
|
<codeline lineno="183"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="184"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="185"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(ops.exp()<sp/>==<sp/>0)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="186"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a2d2e90761f5d36056dfa3fe354655f99" kindref="member">eq</ref>(home,1));</highlight></codeline>
|
||
|
<codeline lineno="187"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="188"><highlight class="normal"><sp/><sp/><sp/><sp/>}<sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(ops.exp()<sp/>==<sp/>1)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="189"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Rel_1_1EqBnd_1a6a4e15cf4b828abbaf95786b97530ca0" kindref="member">Rel::EqBnd<IntView,IntView>::post</ref>(home,x0,x1);<sp/><sp/><sp/><sp/><sp/><sp/></highlight></codeline>
|
||
|
<codeline lineno="190"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="191"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="192"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(same(x0,x1))<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="193"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>assert(ops.exp()<sp/>><sp/>1);</highlight></codeline>
|
||
|
<codeline lineno="194"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,1));</highlight></codeline>
|
||
|
<codeline lineno="195"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,ops.even()<sp/>?<sp/>0<sp/>:<sp/>-2));</highlight></codeline>
|
||
|
<codeline lineno="196"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="197"><highlight class="normal"><sp/><sp/><sp/><sp/>}<sp/></highlight></codeline>
|
||
|
<codeline lineno="198"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="199"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="comment">//<sp/>Limits<sp/>values<sp/>such<sp/>that<sp/>no<sp/>overflow<sp/>can<sp/>occur</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="200"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,ops.fnroot(<ref refid="namespaceGecode_1_1Int_1_1Limits_1ad2fea399ca2de529a8b294fefe37e177" kindref="member">Limits::max</ref>)));</highlight></codeline>
|
||
|
<codeline lineno="201"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,-ops.cnroot(-<ref refid="namespaceGecode_1_1Int_1_1Limits_1a866b451d77425f6d442aa9f114e1424c" kindref="member">Limits::min</ref>)));</highlight></codeline>
|
||
|
<codeline lineno="202"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="203"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(ops.even())<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="204"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="205"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="206"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="207"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="208"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="209"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a02b74c91c8e959ca6cd1fc8e90d13ef9" kindref="member">NrootPlusBnd<Ops,false>::post</ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="210"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="211"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="212"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd_1a02b74c91c8e959ca6cd1fc8e90d13ef9" kindref="member">NrootPlusBnd<Ops,true>::post</ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="213"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="214"><highlight class="normal"><sp/><sp/><sp/><sp/>assert((x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/><<sp/>0)<sp/>&&<sp/>(x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/>><sp/>0));</highlight></codeline>
|
||
|
<codeline lineno="215"><highlight class="normal"><sp/><sp/><sp/><sp/>assert((x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/><<sp/>0)<sp/>&&<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/>><sp/>0));</highlight></codeline>
|
||
|
<codeline lineno="216"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ES_CHECK(prop_nroot_bnd<Ops>(home,x0,x1,ops));</highlight></codeline>
|
||
|
<codeline lineno="217"><highlight class="normal"><sp/><sp/><sp/><sp/>(void)<sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd" kindref="compound">NrootBnd</ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="218"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="219"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="220"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="221"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="222"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="223" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1ac06ceeb035f60a801b07335a54ee4060" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1ac06ceeb035f60a801b07335a54ee4060" kindref="member">NrootBnd<Ops>::NrootBnd</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share,<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd" kindref="compound">NrootBnd<Ops></ref>&<sp/>p)</highlight></codeline>
|
||
|
<codeline lineno="224"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_BND>(home,share,p),<sp/></highlight></codeline>
|
||
|
<codeline lineno="225"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(p.ops)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="226"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="227"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="228"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Actor" kindref="compound">Actor</ref>*</highlight></codeline>
|
||
|
<codeline lineno="229" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1aa1168218dfbc992fa2d57d78bddba84e" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1aa1168218dfbc992fa2d57d78bddba84e" kindref="member">NrootBnd<Ops>::copy</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="230"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd" kindref="compound">NrootBnd<Ops></ref>(home,share,*</highlight><highlight class="keyword">this</highlight><highlight class="normal">);</highlight></codeline>
|
||
|
<codeline lineno="231"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="232"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="233"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="234"><highlight class="normal"><sp/><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="235" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1a1ac3a898ab282f8705b8ad59bf3ace9f" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootBnd_1a1ac3a898ab282f8705b8ad59bf3ace9f" kindref="member">NrootBnd<Ops>::propagate</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1a129e41c1d037528010d7b6706495a560" kindref="member">ModEventDelta</ref>&)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="236"><highlight class="normal"><sp/><sp/><sp/><sp/>assert(!ops.even());</highlight></codeline>
|
||
|
<codeline lineno="237"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="238"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_REWRITE(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">,(<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd" kindref="compound">NrootPlusBnd<Ops,false>::post</ref>(home,x0,x1,ops)));</highlight></codeline>
|
||
|
<codeline lineno="239"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="240"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="241"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_REWRITE(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">,(<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusBnd" kindref="compound">NrootPlusBnd<Ops,true>::post</ref>(home,x0,x1,ops)));</highlight></codeline>
|
||
|
<codeline lineno="242"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="243"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ES_CHECK(prop_nroot_bnd(home,x0,x1,ops));</highlight></codeline>
|
||
|
<codeline lineno="244"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="245"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>x0.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>&&<sp/>x1.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>?<sp/>home.<ref refid="group__TaskActorStatus_1gafc19cbf71ed90a9e0b414b875103f4c7" kindref="member">ES_SUBSUMED</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">)<sp/>:<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5ac32341b682bca52b8617a8ad004023ef" kindref="member">ES_NOFIX</ref>;</highlight></codeline>
|
||
|
<codeline lineno="246"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="247"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="248"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="249"><highlight class="normal"><sp/><sp/></highlight><highlight class="comment">/*</highlight></codeline>
|
||
|
<codeline lineno="250"><highlight class="comment"><sp/><sp/><sp/>*<sp/>Domain<sp/>consistent<sp/>nth<sp/>root</highlight></codeline>
|
||
|
<codeline lineno="251"><highlight class="comment"><sp/><sp/><sp/>*</highlight></codeline>
|
||
|
<codeline lineno="252"><highlight class="comment"><sp/><sp/><sp/>*/</highlight></codeline>
|
||
|
<codeline lineno="254"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="255" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow" refkind="compound"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">class<sp/></highlight><highlight class="normal"><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow" kindref="compound">RangesMapPow</ref><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="256"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">protected</highlight><highlight class="normal">:</highlight></codeline>
|
||
|
<codeline lineno="258" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1a6942f88343cfce8909aa41db3164d544" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>Ops<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1a6942f88343cfce8909aa41db3164d544" kindref="member">ops</ref>;</highlight></codeline>
|
||
|
<codeline lineno="259"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">public</highlight><highlight class="normal">:</highlight></codeline>
|
||
|
<codeline lineno="261" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1a97cbce73bfbca04e3b51c42baa58b785" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>forceinline<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1a97cbce73bfbca04e3b51c42baa58b785" kindref="member">RangesMapPow</ref>(</highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>o)<sp/>:<sp/>ops(o)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="263" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1a304b775c209f2e02abc60571ddaeddbf" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>forceinline<sp/></highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1a304b775c209f2e02abc60571ddaeddbf" kindref="member">min</ref>(</highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/>x)</highlight><highlight class="keyword"><sp/>const<sp/></highlight><highlight class="normal">{</highlight></codeline>
|
||
|
<codeline lineno="264"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>ops.tpow(x);</highlight></codeline>
|
||
|
<codeline lineno="265"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="267" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1ab4dbc7a0fd712df23f2606f93fec3c3f" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>forceinline<sp/></highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow_1ab4dbc7a0fd712df23f2606f93fec3c3f" kindref="member">max</ref>(</highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/>x)</highlight><highlight class="keyword"><sp/>const<sp/></highlight><highlight class="normal">{</highlight></codeline>
|
||
|
<codeline lineno="268"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>ops.tpow(x+1)-1;</highlight></codeline>
|
||
|
<codeline lineno="269"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="270"><highlight class="normal"><sp/><sp/>};</highlight></codeline>
|
||
|
<codeline lineno="271"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="273"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="274" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot" refkind="compound"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">class<sp/></highlight><highlight class="normal"><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot" kindref="compound">RangesMapNroot</ref><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="275"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">protected</highlight><highlight class="normal">:</highlight></codeline>
|
||
|
<codeline lineno="277" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a3ef7b893d0b38cc31571df2ab468032b" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>Ops<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a3ef7b893d0b38cc31571df2ab468032b" kindref="member">ops</ref>;</highlight></codeline>
|
||
|
<codeline lineno="278"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">public</highlight><highlight class="normal">:</highlight></codeline>
|
||
|
<codeline lineno="280" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a4dc0483ad440c886a3b696a8968bb35a" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>forceinline<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a4dc0483ad440c886a3b696a8968bb35a" kindref="member">RangesMapNroot</ref>(</highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>o)<sp/>:<sp/>ops(o)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="282" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a38dbb1ec7306387061071ff4b60ef414" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>forceinline<sp/></highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a38dbb1ec7306387061071ff4b60ef414" kindref="member">min</ref>(</highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/>x)</highlight><highlight class="keyword"><sp/>const<sp/></highlight><highlight class="normal">{</highlight></codeline>
|
||
|
<codeline lineno="283"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>(x<sp/><<sp/>0)<sp/>?<sp/>-ops.cnroot(-x)<sp/>:<sp/>ops.fnroot(x);</highlight></codeline>
|
||
|
<codeline lineno="284"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="286" refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a14720c23bc83e19ad8662623adaf5da0" refkind="member"><highlight class="normal"><sp/><sp/><sp/><sp/>forceinline<sp/></highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot_1a14720c23bc83e19ad8662623adaf5da0" kindref="member">max</ref>(</highlight><highlight class="keywordtype">int</highlight><highlight class="normal"><sp/>x)</highlight><highlight class="keyword"><sp/>const<sp/></highlight><highlight class="normal">{</highlight></codeline>
|
||
|
<codeline lineno="287"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>(x<sp/><<sp/>0)<sp/>?<sp/>-ops.cnroot(-x)<sp/>:<sp/>ops.fnroot(x);</highlight></codeline>
|
||
|
<codeline lineno="288"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="289"><highlight class="normal"><sp/>};</highlight></codeline>
|
||
|
<codeline lineno="290"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="291"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="292"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="293" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1aabbb2009083731c8fe06f7af5b55f29f" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a9b229c72ead442248f4743dc4150b8b8" kindref="member">NrootPlusDom<Ops,minus>::NrootPlusDom</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/></highlight></codeline>
|
||
|
<codeline lineno="294"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>o)</highlight></codeline>
|
||
|
<codeline lineno="295"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_DOM>(home,x0,x1),</highlight></codeline>
|
||
|
<codeline lineno="296"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(o)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="297"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="298"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="299"><highlight class="normal"><sp/><sp/>forceinline<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="300" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a8c661bfe322bccb1541e8f7405f3003e" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a8c661bfe322bccb1541e8f7405f3003e" kindref="member">NrootPlusDom<Ops,minus>::post</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/>Ops<sp/>ops)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="301"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(minus)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="302"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="303"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="304"><highlight class="normal"><sp/><sp/><sp/><sp/>}<sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="305"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="306"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="307"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="308"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ES_CHECK((prop_nroot_plus_bnd<Ops,minus>(home,x0,x1,ops)));</highlight></codeline>
|
||
|
<codeline lineno="309"><highlight class="normal"><sp/><sp/><sp/><sp/>(void)<sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom" kindref="compound">NrootPlusDom<Ops,minus></ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="310"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="311"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="312"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="313"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="314"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="315" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a9b229c72ead442248f4743dc4150b8b8" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a9b229c72ead442248f4743dc4150b8b8" kindref="member">NrootPlusDom<Ops,minus>::NrootPlusDom</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share,<sp/></highlight></codeline>
|
||
|
<codeline lineno="316"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom" kindref="compound">NrootPlusDom<Ops,minus></ref>&<sp/>p)</highlight></codeline>
|
||
|
<codeline lineno="317"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_DOM>(home,share,p),<sp/></highlight></codeline>
|
||
|
<codeline lineno="318"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(p.ops)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="319"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="320"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="321"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Actor" kindref="compound">Actor</ref>*</highlight></codeline>
|
||
|
<codeline lineno="322" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1ad3a545385f419448e17da2aaf27bec8a" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1ad3a545385f419448e17da2aaf27bec8a" kindref="member">NrootPlusDom<Ops,minus>::copy</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="323"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom" kindref="compound">NrootPlusDom<Ops,minus></ref>(home,share,*</highlight><highlight class="keyword">this</highlight><highlight class="normal">);</highlight></codeline>
|
||
|
<codeline lineno="324"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="325"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="326"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="327"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1PropCost" kindref="compound">PropCost</ref></highlight></codeline>
|
||
|
<codeline lineno="328" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a606a100d74537ea0aa1263321ffb562c" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a606a100d74537ea0aa1263321ffb562c" kindref="member">NrootPlusDom<Ops,minus>::cost</ref>(</highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1a129e41c1d037528010d7b6706495a560" kindref="member">ModEventDelta</ref>&<sp/>med)</highlight><highlight class="keyword"><sp/>const<sp/></highlight><highlight class="normal">{</highlight></codeline>
|
||
|
<codeline lineno="329"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="classGecode_1_1VarImpView_1a6dced43c3bf8befaf8cd27dbd53bf24c" kindref="member">IntView::me</ref>(med)<sp/>==<sp/>ME_INT_VAL)</highlight></codeline>
|
||
|
<codeline lineno="330"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1PropCost_1a6c01ce3c391f293ce6a8b27294d7ee0c" kindref="member">PropCost::unary</ref>(<ref refid="classGecode_1_1PropCost_1ad1bebae59ea373495c5bf51ffc249dcda29f70a7d7f550f3822568ddce422d861" kindref="member">PropCost::LO</ref>);</highlight></codeline>
|
||
|
<codeline lineno="331"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="classGecode_1_1VarImpView_1a6dced43c3bf8befaf8cd27dbd53bf24c" kindref="member">IntView::me</ref>(med)<sp/>==<sp/>ME_INT_DOM)</highlight></codeline>
|
||
|
<codeline lineno="332"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1PropCost_1ab1f645eea8eaf90e3bee56c6cdb3ab74" kindref="member">PropCost::binary</ref>(<ref refid="classGecode_1_1PropCost_1ad1bebae59ea373495c5bf51ffc249dcdada52d4d3b08e9888c5063df5140e12e2" kindref="member">PropCost::HI</ref>);</highlight></codeline>
|
||
|
<codeline lineno="333"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="334"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1PropCost_1ab1f645eea8eaf90e3bee56c6cdb3ab74" kindref="member">PropCost::binary</ref>(<ref refid="classGecode_1_1PropCost_1ad1bebae59ea373495c5bf51ffc249dcda29f70a7d7f550f3822568ddce422d861" kindref="member">PropCost::LO</ref>);</highlight></codeline>
|
||
|
<codeline lineno="335"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="336"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="337"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>minus></highlight></codeline>
|
||
|
<codeline lineno="338"><highlight class="normal"><sp/><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="339" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1aafb6bbcbd5ed1269593806925b10a40f" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1aafb6bbcbd5ed1269593806925b10a40f" kindref="member">NrootPlusDom<Ops,minus>::propagate</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1a129e41c1d037528010d7b6706495a560" kindref="member">ModEventDelta</ref>&<sp/>med)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="340"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="classGecode_1_1VarImpView_1a6dced43c3bf8befaf8cd27dbd53bf24c" kindref="member">IntView::me</ref>(med)<sp/>!=<sp/>ME_INT_DOM)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="341"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ES_CHECK((prop_nroot_plus_bnd<Ops,minus>(home,x0,x1,ops)));</highlight></codeline>
|
||
|
<codeline lineno="342"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>x1.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>?<sp/>home.<ref refid="group__TaskActorStatus_1gafc19cbf71ed90a9e0b414b875103f4c7" kindref="member">ES_SUBSUMED</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">)</highlight></codeline>
|
||
|
<codeline lineno="343"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>:<sp/>home.<ref refid="group__TaskActorStatus_1ga1f9059933d5d03ecfe32a1df5c8d7e36" kindref="member">ES_NOFIX_PARTIAL</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">,<ref refid="classGecode_1_1Int_1_1IntView_1a8844c2395ae6301319fdced12b920914" kindref="member">IntView::med</ref>(ME_INT_DOM));</highlight></codeline>
|
||
|
<codeline lineno="344"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="345"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="346"><highlight class="normal"><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="347"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1ViewRanges_3_01IntView_01_4" kindref="compound">ViewRanges<IntView></ref><sp/>r(x0);</highlight></codeline>
|
||
|
<codeline lineno="348"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot" kindref="compound">RangesMapNroot<Ops></ref><sp/>rmn(ops);</highlight></codeline>
|
||
|
<codeline lineno="349"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Iter_1_1Ranges_1_1Map" kindref="compound">Iter::Ranges::Map<ViewRanges<IntView></ref>,<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot" kindref="compound">RangesMapNroot<Ops></ref>,</highlight><highlight class="keyword">false</highlight><highlight class="normal">><sp/></highlight></codeline>
|
||
|
<codeline lineno="350"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>m(r,rmn);</highlight></codeline>
|
||
|
<codeline lineno="351"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a33f3549b155470451e554a52bf8df710" kindref="member">inter_r</ref>(home,m,</highlight><highlight class="keyword">false</highlight><highlight class="normal">));</highlight></codeline>
|
||
|
<codeline lineno="352"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="353"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="354"><highlight class="normal"><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="355"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1ViewRanges_3_01IntView_01_4" kindref="compound">ViewRanges<IntView></ref><sp/>r(x1);</highlight></codeline>
|
||
|
<codeline lineno="356"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow" kindref="compound">RangesMapPow<Ops></ref><sp/>rmp(ops);</highlight></codeline>
|
||
|
<codeline lineno="357"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Iter_1_1Ranges_1_1Map" kindref="compound">Iter::Ranges::Map<ViewRanges<IntView></ref>,<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow" kindref="compound">RangesMapPow<Ops></ref>,</highlight><highlight class="keyword">true</highlight><highlight class="normal">><sp/></highlight></codeline>
|
||
|
<codeline lineno="358"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>m(r,rmp);</highlight></codeline>
|
||
|
<codeline lineno="359"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1a33f3549b155470451e554a52bf8df710" kindref="member">inter_r</ref>(home,m,</highlight><highlight class="keyword">false</highlight><highlight class="normal">));</highlight></codeline>
|
||
|
<codeline lineno="360"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="361"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="362"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>x1.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>?<sp/>home.<ref refid="group__TaskActorStatus_1gafc19cbf71ed90a9e0b414b875103f4c7" kindref="member">ES_SUBSUMED</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">)<sp/>:<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a13bb69056fb9293e8df98c0e347ba634" kindref="member">ES_FIX</ref>;</highlight></codeline>
|
||
|
<codeline lineno="363"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="364"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="365"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="366"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="367"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="368"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="369" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1a4f07744123c4d8a2c089f01968a6dfd5" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1ab3f27540bdd55784164845c42230c462" kindref="member">NrootDom<Ops>::NrootDom</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/>Ops&<sp/>o)</highlight></codeline>
|
||
|
<codeline lineno="370"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_DOM>(home,x0,x1),</highlight></codeline>
|
||
|
<codeline lineno="371"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(o)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="372"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="373"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="374"><highlight class="normal"><sp/><sp/>forceinline<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="375" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1aa70109dc72e223b4b15108dfde4cf3e9" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1aa70109dc72e223b4b15108dfde4cf3e9" kindref="member">NrootDom<Ops>::post</ref>(<ref refid="classGecode_1_1Home" kindref="compound">Home</ref><sp/>home,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x0,<sp/><ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref><sp/>x1,<sp/>Ops<sp/>ops)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="376"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(static_cast<unsigned<sp/>int>(ops.exp())<sp/>>=<sp/></highlight><highlight class="keyword">sizeof</highlight><highlight class="normal">(</highlight><highlight class="keywordtype">int</highlight><highlight class="normal">)<sp/>*<sp/>CHAR_BIT)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="377"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="comment">//<sp/>The<sp/>integer<sp/>limits<sp/>allow<sp/>only<sp/>-2,<sp/>-1,<sp/>0,<sp/>1<sp/>for<sp/>x1</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="378"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,1));</highlight></codeline>
|
||
|
<codeline lineno="379"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,-2));</highlight></codeline>
|
||
|
<codeline lineno="380"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="comment">//<sp/>Just<sp/>rewrite<sp/>to<sp/>values<sp/>that<sp/>can<sp/>be<sp/>handeled<sp/>without<sp/>overflow</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="381"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops.exp(ops.even()<sp/>?<sp/>30<sp/>:<sp/>31);</highlight></codeline>
|
||
|
<codeline lineno="382"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="383"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="384"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(ops.exp()<sp/>==<sp/>0)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="385"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a2d2e90761f5d36056dfa3fe354655f99" kindref="member">eq</ref>(home,1));</highlight></codeline>
|
||
|
<codeline lineno="386"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="387"><highlight class="normal"><sp/><sp/><sp/><sp/>}<sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(ops.exp()<sp/>==<sp/>1)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="388"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Rel_1_1EqDom_1a217b2a26dc0c959f8ea73e10054fbf5b" kindref="member">Rel::EqDom<IntView,IntView>::post</ref>(home,x0,x1);<sp/><sp/><sp/><sp/><sp/><sp/></highlight></codeline>
|
||
|
<codeline lineno="389"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="390"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="391"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(same(x0,x1))<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="392"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>assert(ops.exp()<sp/>><sp/>1);</highlight></codeline>
|
||
|
<codeline lineno="393"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,1));</highlight></codeline>
|
||
|
<codeline lineno="394"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,ops.even()<sp/>?<sp/>0<sp/>:<sp/>-2));</highlight></codeline>
|
||
|
<codeline lineno="395"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="396"><highlight class="normal"><sp/><sp/><sp/><sp/>}<sp/></highlight></codeline>
|
||
|
<codeline lineno="397"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="398"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="comment">//<sp/>Limits<sp/>values<sp/>such<sp/>that<sp/>no<sp/>overflow<sp/>can<sp/>occur</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="399"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a765f7b23d8006387bfcdca16309f79fa" kindref="member">lq</ref>(home,ops.fnroot(<ref refid="namespaceGecode_1_1Int_1_1Limits_1ad2fea399ca2de529a8b294fefe37e177" kindref="member">Limits::max</ref>)));</highlight></codeline>
|
||
|
<codeline lineno="400"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,-ops.cnroot(-<ref refid="namespaceGecode_1_1Int_1_1Limits_1a866b451d77425f6d442aa9f114e1424c" kindref="member">Limits::min</ref>)));</highlight></codeline>
|
||
|
<codeline lineno="401"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="402"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(ops.even())<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="403"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="404"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1ae0caad61da923547d773198f2420b96f" kindref="member">gq</ref>(home,0));</highlight></codeline>
|
||
|
<codeline lineno="405"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="406"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="407"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="408"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a8c661bfe322bccb1541e8f7405f3003e" kindref="member">NrootPlusDom<Ops,false>::post</ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="409"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="410"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="411"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom_1a8c661bfe322bccb1541e8f7405f3003e" kindref="member">NrootPlusDom<Ops,true>::post</ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="412"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="413"><highlight class="normal"><sp/><sp/><sp/><sp/>assert((x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/><<sp/>0)<sp/>&&<sp/>(x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/>><sp/>0));</highlight></codeline>
|
||
|
<codeline lineno="414"><highlight class="normal"><sp/><sp/><sp/><sp/>assert((x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/><<sp/>0)<sp/>&&<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/>><sp/>0));</highlight></codeline>
|
||
|
<codeline lineno="415"><highlight class="normal"><sp/><sp/><sp/><sp/>GECODE_ES_CHECK(prop_nroot_bnd<Ops>(home,x0,x1,ops));</highlight></codeline>
|
||
|
<codeline lineno="416"><highlight class="normal"><sp/><sp/><sp/><sp/>(void)<sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom" kindref="compound">NrootDom</ref>(home,x0,x1,ops);</highlight></codeline>
|
||
|
<codeline lineno="417"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a01d6fb1ec70479e8e413d5ecfd63e303" kindref="member">ES_OK</ref>;</highlight></codeline>
|
||
|
<codeline lineno="418"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="419"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="420"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="421"><highlight class="normal"><sp/><sp/>forceinline</highlight></codeline>
|
||
|
<codeline lineno="422" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1ab3f27540bdd55784164845c42230c462" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1ab3f27540bdd55784164845c42230c462" kindref="member">NrootDom<Ops>::NrootDom</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share,<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom" kindref="compound">NrootDom<Ops></ref>&<sp/>p)</highlight></codeline>
|
||
|
<codeline lineno="423"><highlight class="normal"><sp/><sp/><sp/><sp/>:<sp/><ref refid="classGecode_1_1BinaryPropagator" kindref="compound">BinaryPropagator</ref><<ref refid="classGecode_1_1Int_1_1IntView" kindref="compound">IntView</ref>,PC_INT_DOM>(home,share,p),<sp/></highlight></codeline>
|
||
|
<codeline lineno="424"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>ops(p.ops)<sp/>{}</highlight></codeline>
|
||
|
<codeline lineno="425"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="426"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="427"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Actor" kindref="compound">Actor</ref>*</highlight></codeline>
|
||
|
<codeline lineno="428" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1a2ec4ada1af2994e51a4272c114225f0b" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1a2ec4ada1af2994e51a4272c114225f0b" kindref="member">NrootDom<Ops>::copy</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keywordtype">bool</highlight><highlight class="normal"><sp/>share)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="429"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/></highlight><highlight class="keyword">new</highlight><highlight class="normal"><sp/>(home)<sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom" kindref="compound">NrootDom<Ops></ref>(home,share,*</highlight><highlight class="keyword">this</highlight><highlight class="normal">);</highlight></codeline>
|
||
|
<codeline lineno="430"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="431"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="432"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="433"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1PropCost" kindref="compound">PropCost</ref></highlight></codeline>
|
||
|
<codeline lineno="434" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1a97074f499273323e803b65433c8f15d7" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1a97074f499273323e803b65433c8f15d7" kindref="member">NrootDom<Ops>::cost</ref>(</highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1a129e41c1d037528010d7b6706495a560" kindref="member">ModEventDelta</ref>&<sp/>med)</highlight><highlight class="keyword"><sp/>const<sp/></highlight><highlight class="normal">{</highlight></codeline>
|
||
|
<codeline lineno="435"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="classGecode_1_1VarImpView_1a6dced43c3bf8befaf8cd27dbd53bf24c" kindref="member">IntView::me</ref>(med)<sp/>==<sp/>ME_INT_VAL)</highlight></codeline>
|
||
|
<codeline lineno="436"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1PropCost_1a6c01ce3c391f293ce6a8b27294d7ee0c" kindref="member">PropCost::unary</ref>(<ref refid="classGecode_1_1PropCost_1ad1bebae59ea373495c5bf51ffc249dcda29f70a7d7f550f3822568ddce422d861" kindref="member">PropCost::LO</ref>);</highlight></codeline>
|
||
|
<codeline lineno="437"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="classGecode_1_1VarImpView_1a6dced43c3bf8befaf8cd27dbd53bf24c" kindref="member">IntView::me</ref>(med)<sp/>==<sp/>ME_INT_DOM)</highlight></codeline>
|
||
|
<codeline lineno="438"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1PropCost_1ab1f645eea8eaf90e3bee56c6cdb3ab74" kindref="member">PropCost::binary</ref>(<ref refid="classGecode_1_1PropCost_1ad1bebae59ea373495c5bf51ffc249dcdada52d4d3b08e9888c5063df5140e12e2" kindref="member">PropCost::HI</ref>);</highlight></codeline>
|
||
|
<codeline lineno="439"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">else</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="440"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/><ref refid="classGecode_1_1PropCost_1ab1f645eea8eaf90e3bee56c6cdb3ab74" kindref="member">PropCost::binary</ref>(<ref refid="classGecode_1_1PropCost_1ad1bebae59ea373495c5bf51ffc249dcda29f70a7d7f550f3822568ddce422d861" kindref="member">PropCost::LO</ref>);</highlight></codeline>
|
||
|
<codeline lineno="441"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="442"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="443"><highlight class="normal"><sp/><sp/></highlight><highlight class="keyword">template</highlight><highlight class="normal"><</highlight><highlight class="keyword">class</highlight><highlight class="normal"><sp/>Ops></highlight></codeline>
|
||
|
<codeline lineno="444"><highlight class="normal"><sp/><sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5" kindref="member">ExecStatus</ref></highlight></codeline>
|
||
|
<codeline lineno="445" refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1a3f17ccd23bd21c072f91b60dd2f5cd6a" refkind="member"><highlight class="normal"><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootDom_1a3f17ccd23bd21c072f91b60dd2f5cd6a" kindref="member">NrootDom<Ops>::propagate</ref>(<ref refid="classGecode_1_1Space" kindref="compound">Space</ref>&<sp/>home,<sp/></highlight><highlight class="keyword">const</highlight><highlight class="normal"><sp/><ref refid="namespaceGecode_1a129e41c1d037528010d7b6706495a560" kindref="member">ModEventDelta</ref>&<sp/>med)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="446"><highlight class="normal"><sp/><sp/><sp/><sp/>assert(!ops.even());</highlight></codeline>
|
||
|
<codeline lineno="447"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1abc9505bdc00f7a5de8aadb550bdac72a" kindref="member">min</ref>()<sp/>>=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="448"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_REWRITE(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">,(<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom" kindref="compound">NrootPlusDom<Ops,false>::post</ref>(home,x0,x1,ops)));</highlight></codeline>
|
||
|
<codeline lineno="449"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="450"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>((x0.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0)<sp/>||<sp/>(x1.<ref refid="classGecode_1_1Int_1_1IntView_1aa06f1c972492a79e90000d854134cc74" kindref="member">max</ref>()<sp/><=<sp/>0))</highlight></codeline>
|
||
|
<codeline lineno="451"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_REWRITE(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">,(<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1NrootPlusDom" kindref="compound">NrootPlusDom<Ops,true>::post</ref>(home,x0,x1,ops)));</highlight></codeline>
|
||
|
<codeline lineno="452"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="453"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">if</highlight><highlight class="normal"><sp/>(<ref refid="classGecode_1_1VarImpView_1a6dced43c3bf8befaf8cd27dbd53bf24c" kindref="member">IntView::me</ref>(med)<sp/>!=<sp/>ME_INT_DOM)<sp/>{</highlight></codeline>
|
||
|
<codeline lineno="454"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ES_CHECK(prop_nroot_bnd<Ops>(home,x0,x1,ops));</highlight></codeline>
|
||
|
<codeline lineno="455"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>x0.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>&&<sp/>x1.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>?<sp/>home.<ref refid="group__TaskActorStatus_1gafc19cbf71ed90a9e0b414b875103f4c7" kindref="member">ES_SUBSUMED</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">)</highlight></codeline>
|
||
|
<codeline lineno="456"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>:<sp/>home.<ref refid="group__TaskActorStatus_1ga1f9059933d5d03ecfe32a1df5c8d7e36" kindref="member">ES_NOFIX_PARTIAL</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">,<ref refid="classGecode_1_1Int_1_1IntView_1a8844c2395ae6301319fdced12b920914" kindref="member">IntView::med</ref>(ME_INT_DOM));</highlight></codeline>
|
||
|
<codeline lineno="457"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="458"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="459"><highlight class="normal"><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="460"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1ViewRanges_3_01IntView_01_4" kindref="compound">ViewRanges<IntView></ref><sp/>r(x0);</highlight></codeline>
|
||
|
<codeline lineno="461"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot" kindref="compound">RangesMapNroot<Ops></ref><sp/>rmn(ops);</highlight></codeline>
|
||
|
<codeline lineno="462"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Iter_1_1Ranges_1_1Map" kindref="compound">Iter::Ranges::Map<ViewRanges<IntView></ref>,<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapNroot" kindref="compound">RangesMapNroot<Ops></ref>,</highlight><highlight class="keyword">false</highlight><highlight class="normal">><sp/></highlight></codeline>
|
||
|
<codeline lineno="463"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>m(r,rmn);</highlight></codeline>
|
||
|
<codeline lineno="464"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x1.<ref refid="classGecode_1_1Int_1_1IntView_1a33f3549b155470451e554a52bf8df710" kindref="member">inter_r</ref>(home,m,</highlight><highlight class="keyword">false</highlight><highlight class="normal">));</highlight></codeline>
|
||
|
<codeline lineno="465"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="466"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="467"><highlight class="normal"><sp/><sp/><sp/><sp/>{</highlight></codeline>
|
||
|
<codeline lineno="468"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1ViewRanges_3_01IntView_01_4" kindref="compound">ViewRanges<IntView></ref><sp/>r(x1);</highlight></codeline>
|
||
|
<codeline lineno="469"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow" kindref="compound">RangesMapPow<Ops></ref><sp/>rmp(ops);</highlight></codeline>
|
||
|
<codeline lineno="470"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><ref refid="classGecode_1_1Iter_1_1Ranges_1_1Map" kindref="compound">Iter::Ranges::Map<ViewRanges<IntView></ref>,<ref refid="classGecode_1_1Int_1_1Arithmetic_1_1RangesMapPow" kindref="compound">RangesMapPow<Ops></ref>,</highlight><highlight class="keyword">true</highlight><highlight class="normal">><sp/></highlight></codeline>
|
||
|
<codeline lineno="471"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/><sp/><sp/>m(r,rmp);</highlight></codeline>
|
||
|
<codeline lineno="472"><highlight class="normal"><sp/><sp/><sp/><sp/><sp/><sp/>GECODE_ME_CHECK(x0.<ref refid="classGecode_1_1Int_1_1IntView_1a33f3549b155470451e554a52bf8df710" kindref="member">inter_r</ref>(home,m,</highlight><highlight class="keyword">false</highlight><highlight class="normal">));</highlight></codeline>
|
||
|
<codeline lineno="473"><highlight class="normal"><sp/><sp/><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="474"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="475"><highlight class="normal"><sp/><sp/><sp/><sp/></highlight><highlight class="keywordflow">return</highlight><highlight class="normal"><sp/>x0.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>&&<sp/>x1.<ref refid="classGecode_1_1VarImpView_1aeee242f0be13f77dc287449dd51e6fd2" kindref="member">assigned</ref>()<sp/>?<sp/>home.<ref refid="group__TaskActorStatus_1gafc19cbf71ed90a9e0b414b875103f4c7" kindref="member">ES_SUBSUMED</ref>(*</highlight><highlight class="keyword">this</highlight><highlight class="normal">)<sp/>:<sp/><ref refid="namespaceGecode_1ab278aee34126d2f13c5429ee3c4ed3b5a13bb69056fb9293e8df98c0e347ba634" kindref="member">ES_FIX</ref>;</highlight></codeline>
|
||
|
<codeline lineno="476"><highlight class="normal"><sp/><sp/>}</highlight></codeline>
|
||
|
<codeline lineno="477"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="478"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="479"><highlight class="normal">}}}</highlight></codeline>
|
||
|
<codeline lineno="480"><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="481"><highlight class="normal"></highlight><highlight class="comment">//<sp/>STATISTICS:<sp/>int-prop</highlight><highlight class="normal"></highlight></codeline>
|
||
|
<codeline lineno="482"><highlight class="normal"></highlight></codeline>
|
||
|
</programlisting>
|
||
|
<location file="/usr/include/gecode/int/arithmetic/nroot.hpp"/>
|
||
|
</compounddef>
|
||
|
</doxygen>
|