38 namespace Gecode {
namespace Int {
namespace Linear {
44 template<
class Val,
class A,
class B,
class C, PropCond pc>
48 x0.subscribe(home,*
this,pc);
49 x1.subscribe(home,*
this,pc);
50 x2.subscribe(home,*
this,pc);
53 template<
class Val,
class A,
class B,
class C, PropCond pc>
58 x0.update(home,share,p.
x0);
59 x1.update(home,share,p.
x1);
60 x2.update(home,share,p.
x2);
63 template<
class Val,
class A,
class B,
class C, PropCond pc>
66 A y0, B y1, C y2, Val c0)
68 x0.update(home,share,y0);
69 x1.update(home,share,y1);
70 x2.update(home,share,y2);
73 template<
class Val,
class A,
class B,
class C, PropCond pc>
76 return PropCost::ternary(PropCost::LO);
79 template<
class Val,
class A,
class B,
class C, PropCond pc>
82 x0.reschedule(home,*
this,pc);
83 x1.reschedule(home,*
this,pc);
84 x2.reschedule(home,*
this,pc);
87 template<
class Val,
class A,
class B,
class C, PropCond pc>
90 x0.cancel(home,*
this,pc);
91 x1.cancel(home,*
this,pc);
92 x2.cancel(home,*
this,pc);
93 (void) Propagator::dispose(home);
102 template<
class Val,
class A,
class B,
class C>
107 template<
class Val,
class A,
class B,
class C>
115 template<
class Val,
class A,
class B,
class C>
120 template<
class Val,
class A,
class B,
class C>
124 :
LinTer<Val,A,B,C,
PC_INT_BND>(home,share,p,x0,x1,x2,c) {}
126 template<
class Val,
class A,
class B,
class C>
143 #define GECODE_INT_PV(CASE,TELL,UPDATE) \ 145 bm -= (CASE); ModEvent me = (TELL); \ 146 if (me_failed(me)) return ES_FAILED; \ 147 if (me_modified(me)) bm |= (UPDATE); \ 150 template<
class Val,
class A,
class B,
class C>
168 return (
x0.assigned() &&
x1.assigned()) ?
181 template<
class Val,
class A,
class B,
class C>
186 template<
class Val,
class A,
class B,
class C>
194 template<
class Val,
class A,
class B,
class C>
199 template<
class Val,
class A,
class B,
class C>
205 template<
class Val,
class A,
class B,
class C>
209 :
LinTer<Val,A,B,C,
PC_INT_VAL>(home,share,p,x0,x1,x2,c) {}
212 template<
class Val,
class A,
class B,
class C>
215 if (
x0.assigned() &&
x1.assigned()) {
219 if (
x0.assigned() &&
x2.assigned()) {
223 if (
x1.assigned() &&
x2.assigned()) {
237 template<
class Val,
class A,
class B,
class C>
242 template<
class Val,
class A,
class B,
class C>
250 template<
class Val,
class A,
class B,
class C>
255 template<
class Val,
class A,
class B,
class C>
262 template<
class Val,
class A,
class B,
class C>
266 :
LinTer<Val,A,B,C,
PC_INT_BND>(home,share,p,x0,x1,x2,c) {}
268 template<
class Val,
class A,
class B,
class C>
274 return (
x0.max()+
x1.max()+
x2.max() <=
c) ?
static ExecStatus post(Home home, A x0, B x1, C x2, Val c)
Post propagator for .
virtual Actor * copy(Space &home, bool share)
Create copy during cloning.
ExecStatus ES_SUBSUMED(Propagator &p)
virtual Actor * copy(Space &home, bool share)
Create copy during cloning.
Propagator for bounds consistent ternary linear equality
Base-class for propagators.
Base-class for ternary linear propagators.
Propagation has computed fixpoint.
EqTer(Space &home, bool share, EqTer &p)
Constructor for cloning p.
LinTer(Space &home, bool share, LinTer &p)
Constructor for cloning p.
Base-class for both propagators and branchers.
Propagator for bounds consistent ternary linear less or equal
Gecode::FloatVal c(-8, 8)
int p
Number of positive literals for node type.
const Gecode::PropCond PC_INT_BND
Propagate when minimum or maximum of a view changes.
static ExecStatus post(Home home, A x0, B x1, C x2, Val c)
Post propagator for .
NqTer(Space &home, bool share, NqTer &p)
Constructor for cloning p.
TerMod
Describe which view has been modified how.
#define GECODE_ME_CHECK(me)
Check whether modification event me is failed, and forward failure.
virtual Actor * copy(Space &home, bool share)
Create copy during cloning.
virtual ExecStatus propagate(Space &home, const ModEventDelta &med)
Perform propagation.
static ExecStatus post(Home home, A x0, B x1, C x2, Val c)
Post propagator for .
virtual ExecStatus propagate(Space &home, const ModEventDelta &med)
Perform propagation.
Gecode toplevel namespace
void reschedule(Space &home, Propagator &p, IntSet &y)
Propagator for bounds consistent ternary linear disquality
int ModEventDelta
Modification event deltas.
virtual ExecStatus propagate(Space &home, const ModEventDelta &med)
Perform propagation.
Home class for posting propagators
#define GECODE_INT_PV(CASE, TELL, UPDATE)
LqTer(Space &home, bool share, LqTer &p)
Constructor for cloning p.
const Gecode::PropCond PC_INT_VAL
Propagate when a view becomes assigned (single value)