Gecode::Int::GCC::Dom< View, Card, isView > Class Template Reference
[Integer propagators]
Domain consistent global cardinality propagator.
More...
#include <gcc.hh>
Public Member Functions | |
| virtual size_t | dispose (Space &home) |
| Destructor including deallocation of variable-value graph. | |
| virtual size_t | allocated (void) const |
| Return how much extra memory is allocated by the propagator. | |
| virtual Actor * | copy (Space &home, bool share) |
| Copy propagator during cloning. | |
| virtual PropCost | cost (const Space &home, const ModEventDelta &med) const |
| Cost function. | |
| virtual ExecStatus | propagate (Space &home, const ModEventDelta &med) |
| Perform propagation. | |
Static Public Member Functions | |
| static ExecStatus | post (Space &home, ViewArray< View > &x, ViewArray< Card > &k) |
| Post propagator for views x and cardinalities k. | |
Protected Member Functions | |
| Dom (Space &home, bool share, Dom< View, Card, isView > &p) | |
| Constructor for cloning p. | |
| Dom (Space &home, ViewArray< View > &, ViewArray< Card > &, bool) | |
| Constructor for posting. | |
Protected Attributes | |
| ViewArray< View > | x |
| Views on which to perform domain-propagation. | |
| ViewArray< View > | y |
Views used to channel information between x and k ( ). | |
| ViewArray< Card > | k |
| Array containing either fixed cardinalities or CardViews. | |
| VarValGraph< View, Card, isView > * | vvg |
| Propagation is performed on a variable-value graph (used as cache). | |
| bool | card_fixed |
| Stores whether cardinalities are all assigned. | |
Detailed Description
template<class View, class Card, bool isView>
class Gecode::Int::GCC::Dom< View, Card, isView >
Domain consistent global cardinality propagator.
- [Reference]
- The algorithm is taken from:
@PROCEEDINGS{improvedgcc, title = {Improved Algorithms for the Global Cardinality Constraint}, year = {2004}, volume = {3528}, address = {Toronto, Canada}, month = {September}, author = {Claude-Guy Quimper and Peter van Beek and Alejandro López-Ortiz and Alexander Golynski}, booktitle = {Proceedings of the 10th International Conference on Principles and Practice of Constraint Programming}, url = {http://ai.uwaterloo.ca/~vanbeek/publications}, }
#include <gecode/int/gcc.hh>
Definition at line 199 of file gcc.hh.
Constructor & Destructor Documentation
template<class View , class Card , bool isView>
| Gecode::Int::GCC::Dom< View, Card, isView >::Dom | ( | Space & | home, | |
| bool | share, | |||
| Dom< View, Card, isView > & | p | |||
| ) | [inline, protected] |
template<class View , class Card , bool isView>
| Gecode::Int::GCC::Dom< View, Card, isView >::Dom | ( | Space & | home, | |
| ViewArray< View > & | x0, | |||
| ViewArray< Card > & | k0, | |||
| bool | cf | |||
| ) | [inline, protected] |
Member Function Documentation
template<class View , class Card , bool isView>
| size_t Gecode::Int::GCC::Dom< View, Card, isView >::dispose | ( | Space & | home | ) | [inline, virtual] |
template<class View , class Card , bool isView>
| size_t Gecode::Int::GCC::Dom< View, Card, isView >::allocated | ( | void | ) | const [inline, virtual] |
template<class View , class Card , bool isView>
| Actor * Gecode::Int::GCC::Dom< View, Card, isView >::copy | ( | Space & | home, | |
| bool | share | |||
| ) | [inline, virtual] |
template<class View , class Card , bool isView>
| PropCost Gecode::Int::GCC::Dom< View, Card, isView >::cost | ( | const Space & | home, | |
| const ModEventDelta & | med | |||
| ) | const [inline, virtual] |
Cost function.
As the propagation strongly depends on the domain size of the views on which propagation is performed, the propagation costs are computed as follows, where d denotes the size of the largest domain of a view in x:
- low linear (
) - high linear (
) - low quadratic (
) - high cubic (
)
Implements Gecode::Propagator.
template<class View , class Card , bool isView>
| ExecStatus Gecode::Int::GCC::Dom< View, Card, isView >::propagate | ( | Space & | home, | |
| const ModEventDelta & | med | |||
| ) | [inline, virtual] |
template<class View , class Card , bool isView>
| ExecStatus Gecode::Int::GCC::Dom< View, Card, isView >::post | ( | Space & | home, | |
| ViewArray< View > & | x, | |||
| ViewArray< Card > & | k | |||
| ) | [inline, static] |
Member Data Documentation
template<class View, class Card, bool isView>
ViewArray<View> Gecode::Int::GCC::Dom< View, Card, isView >::x [protected] |
template<class View, class Card, bool isView>
ViewArray<View> Gecode::Int::GCC::Dom< View, Card, isView >::y [protected] |
template<class View, class Card, bool isView>
ViewArray<Card> Gecode::Int::GCC::Dom< View, Card, isView >::k [protected] |
template<class View, class Card, bool isView>
VarValGraph<View, Card, isView>* Gecode::Int::GCC::Dom< View, Card, isView >::vvg [protected] |
template<class View, class Card, bool isView>
bool Gecode::Int::GCC::Dom< View, Card, isView >::card_fixed [protected] |
The documentation for this class was generated from the following files:
- gecode/int/gcc.hh (Revision: 8139)
- gecode/int/gcc/dom.hpp (Revision: 8129)

).