102 for (
int i=x.
size();
i--; )
128 for (
int i=x.
size();
i--; ) {
129 ix[
i].idx=
i; ix[
i].view=x[
i];
133 ::
post(home,ix,yv)));
136 ::
post(home,ix,yv)));
155 for (
int i=x.
size();
i--; ) {
156 ix[
i].idx=
i; ix[
i].view=x[
i];
160 ::
post(home,ix,yv)));
163 ::
post(home,ix,yv)));
181 for (
int i=x.
size();
i--; ) {
186 ::
post(home,ix,yv)));
189 ::
post(home,ix,yv)));
208 for (
int i=x.
size();
i--; ) {
213 ::
post(home,ix,yv)));
216 ::
post(home,ix,yv)));
242 t[0].
a = 1; t[0].
x = prod;
243 t[1].
a = 1; t[1].
x = x3;
249 t[2].
a=-1; t[2].
x=x0;
251 if (home.
failed())
return;
272 divmod(home, x0, x1, _div, x2, ipl);
282 ::
post(home,x0,x1,ops));
285 ::
post(home,x0,x1,ops));
296 ::
post(home,x0,x1,ops));
299 ::
post(home,x0,x1,ops));
309 sqr(home, x0, x1, ipl);
315 ::
post(home,x0,x1,ops));
318 ::
post(home,x0,x1,ops));
328 sqrt(home, x0, x1, ipl);
334 ::
post(home,x0,x1,ops));
337 ::
post(home,x0,x1,ops));
void mod(Home home, IntVar x0, IntVar x1, IntVar x2, IntPropLevel ipl)
Post propagator for .
IntPropLevel vbd(IntPropLevel ipl)
Extract value, bounds, or domain propagation from propagation level.
Integer division/modulo propagator.
void mult(Home home, FloatVar x0, FloatVar x1, FloatVar x2)
Post propagator for .
int size(void) const
Return size of array (number of elements)
Domain consistent ternary maximum propagator.
Domain consistent n-th root propagator.
Domain consistent n-ary maximum propagator.
void max(Home home, FloatVar x0, FloatVar x1, FloatVar x2)
Post propagator for .
void abs(Home home, FloatVar x0, FloatVar x1)
Post propagator for .
void nroot(Home home, FloatVar x0, int n, FloatVar x1)
Post propagator for for $n 0$.
void pow(Home home, FloatVar x0, int n, FloatVar x1)
Post propagator for for $n 0$.
Exception: Too few arguments available in argument array
void nonnegative(int n, const char *l)
Check whether n is in range and nonnegative, otherwise throw out of limits with information l...
void argmin(Home home, const IntVarArgs &x, IntVar y, bool tiebreak, IntPropLevel)
Post propagator for .
Bounds consistent power propagator.
static ExecStatus post(Home home, IntView x0, IntView x1, IntView x2)
Post propagator .
const int max
Largest allowed integer value.
const int min
Smallest allowed integer value.
Bounds consistent absolute value propagator.
ModEvent le(Space &home, int n)
Restrict domain values to be less than n.
ModEvent le(Space &home, int n)
Restrict domain values to be less than n.
Gecode::IntArgs i(4, 1, 2, 3, 4)
bool same(void) const
Test whether array contains same variable multiply.
int n
Number of negative literals for node type.
ModEvent gq(Space &home, int n)
Restrict domain values to be greater or equal than n.
void divmod(Home home, IntVar x0, IntVar x1, IntVar x2, IntVar x3, IntPropLevel)
Post propagator for .
Domain consistent absolute value propagator.
ModEvent lq(Space &home, int n)
Restrict domain values to be less or equal than n.
void sqr(Home home, FloatVar x0, FloatVar x1)
Post propagator for .
void sqrt(Home home, FloatVar x0, FloatVar x1)
Post propagator for .
bool failed(void) const
Check whether corresponding space is failed.
Operations for square and square-root propagators.
void argmax(Home home, const IntVarArgs &x, IntVar y, bool tiebreak, IntPropLevel)
Post propagator for .
Bounds consistent n-ary maximum propagator.
Argument maximum propagator.
Passing integer variables.
Bounds consistent division propagator.
Domain consistent power propagator.
void min(Home home, FloatVar x0, FloatVar x1, FloatVar x2)
Post propagator for .
TieBreak< VarBranch > tiebreak(VarBranch a, VarBranch b)
Combine variable selection criteria a and b for tie-breaking.
IntPropLevel
Propagation levels for integer propagators.
Integer view for integer variables.
Post propagator for SetVar SetOpType SetVar y
void div(Home home, FloatVar x0, FloatVar x1, FloatVar x2)
Post propagator for .
static ExecStatus post(Home home, IntView x0, IntView x1, IntView x2)
Post propagator .
Operations for power and nroot propagators.
Bounds consistent ternary maximum propagator.
Exception: Arguments contain same variable multiply
void estimate(Term< View > *t, int n, int c, int &l, int &u)
Estimate lower and upper bounds.
Domain propagation Options: basic versus advanced propagation.
ModEvent gq(Space &home, int n)
Restrict domain values to be greater or equal than n.
Post propagator for SetVar x
#define GECODE_ME_FAIL(me)
Check whether modification event me is failed, and fail space home.
An array of IdxView pairs.
Class for describing linear term .
Gecode toplevel namespace
void post(Home home, Term< BoolView > *t, int n, IntRelType irt, IntView x, int c, IntPropLevel)
Post propagator for linear constraint over Booleans.
#define GECODE_POST
Check for failure in a constraint post function.
Home class for posting propagators
#define GECODE_ES_FAIL(es)
Check whether execution status es is failed, and fail space home.
Bounds consistent n-th root propagator.
void positive(int n, const char *l)
Check whether n is in range and strictly positive, otherwise throw out of limits with information l...
TFE post(PropagatorGroup g)
Only post functions (but not propagators) from g are considered.