Generated on Thu Mar 22 10:40:00 2012 for Gecode by doxygen 1.6.3

Gecode::Set::Int::ChannelInt< View > Class Template Reference
[Set propagators]

Propagator for channelling between variable-value-dual models More...

#include <int.hh>

List of all members.

Public Member Functions

virtual Actorcopy (Space &home, bool)
 Copy propagator during cloning.
virtual PropCost cost (const Space &home, const ModEventDelta &med) const
 Cost function (defined as PC_QUADRATIC_LO).
virtual size_t dispose (Space &home)
 Delete propagator and return its size.
virtual ExecStatus propagate (Space &home, const ModEventDelta &med)
 Perform propagation.

Static Public Member Functions

static ExecStatus post (Home home, ViewArray< Gecode::Int::CachedView< Gecode::Int::IntView > > &x, ViewArray< CachedView< View > > &y)
 Post propagator for $x_i=j \Leftrightarrow i\in y_j$.

Protected Member Functions

 ChannelInt (Space &home, bool share, ChannelInt &p)
 Constructor for cloning p.
 ChannelInt (Home home, ViewArray< Gecode::Int::CachedView< Gecode::Int::IntView > > &, ViewArray< CachedView< View > > &)
 Constructor for posting.

Protected Attributes

ViewArray
< Gecode::Int::CachedView
< Gecode::Int::IntView > > 
xs
 IntViews, $x_i$ reflects which set contains element $i$.
ViewArray< CachedView< View > > ys
 SetViews that are constrained to be disjoint.

Detailed Description

template<class View>
class Gecode::Set::Int::ChannelInt< View >

Propagator for channelling between variable-value-dual models

Implements channelling constraints between IntVars and SetVars. For IntVars $x_0,\dots,x_n$ and SetVars $y_0,\dots,y_m$ it propagates the constraint $x_i=j \Leftrightarrow i\in y_j$.

Can be used to implement the "channelling constraints" for disjoint with cardinalities from "Disjoint, Partition and Intersection Constraints for Set and Multiset Variables" Christian Bessiere, Emmanuel Hebrard, Brahim Hnich, Toby Walsh CP 2004

Requires

 #include <gecode/set/int.hh> 

Definition at line 305 of file int.hh.


Constructor & Destructor Documentation

template<class View >
Gecode::Set::Int::ChannelInt< View >::ChannelInt ( Space home,
bool  share,
ChannelInt< View > &  p 
) [inline, protected]

Constructor for cloning p.

Definition at line 63 of file channel-int.hpp.

template<class View >
Gecode::Set::Int::ChannelInt< View >::ChannelInt ( Home  home,
ViewArray< Gecode::Int::CachedView< Gecode::Int::IntView > > &  xs0,
ViewArray< CachedView< View > > &  ys0 
) [inline, protected]

Constructor for posting.

Definition at line 48 of file channel-int.hpp.


Member Function Documentation

template<class View >
Actor * Gecode::Set::Int::ChannelInt< View >::copy ( Space home,
bool  share 
) [inline, virtual]

Copy propagator during cloning.

Implements Gecode::Actor.

Definition at line 112 of file channel-int.hpp.

template<class View >
PropCost Gecode::Set::Int::ChannelInt< View >::cost ( const Space home,
const ModEventDelta med 
) const [inline, virtual]

Cost function (defined as PC_QUADRATIC_LO).

Implements Gecode::Propagator.

Definition at line 97 of file channel-int.hpp.

template<class View >
size_t Gecode::Set::Int::ChannelInt< View >::dispose ( Space home  )  [inline, virtual]

Delete propagator and return its size.

Reimplemented from Gecode::Actor.

Definition at line 103 of file channel-int.hpp.

template<class View >
ExecStatus Gecode::Set::Int::ChannelInt< View >::propagate ( Space home,
const ModEventDelta med 
) [inline, virtual]

Perform propagation.

Implements Gecode::Propagator.

Definition at line 118 of file channel-int.hpp.

template<class View >
ExecStatus Gecode::Set::Int::ChannelInt< View >::post ( Home  home,
ViewArray< Gecode::Int::CachedView< Gecode::Int::IntView > > &  x,
ViewArray< CachedView< View > > &  y 
) [inline, static]

Post propagator for $x_i=j \Leftrightarrow i\in y_j$.

Definition at line 71 of file channel-int.hpp.


Member Data Documentation

IntViews, $x_i$ reflects which set contains element $i$.

Definition at line 308 of file int.hh.

template<class View >
ViewArray<CachedView<View> > Gecode::Set::Int::ChannelInt< View >::ys [protected]

SetViews that are constrained to be disjoint.

Definition at line 310 of file int.hh.


The documentation for this class was generated from the following files: