Related Functions |
(Note that these are not member functions.)
|
template<class Char , class Traits > |
std::basic_ostream< Char,
Traits > & | operator<< (std::basic_ostream< Char, Traits > &os, const BoolView &x) |
| Print Boolean view.
|
Domain status access |
|
static const int | BITS = BoolVarImp::BITS |
| How many bits does the status have.
|
static const BoolStatus | ZERO = BoolVarImp::ZERO |
| Status of domain assigned to zero.
|
static const BoolStatus | ONE = BoolVarImp::ONE |
| Status of domain assigned to one.
|
static const BoolStatus | NONE = BoolVarImp::NONE |
| Status of domain not yet assigned.
|
BoolStatus | status (void) const |
| Return current domain status.
|
Constructors and initialization |
|
| BoolView (void) |
| Default constructor.
|
| BoolView (const BoolVar &y) |
| Initialize from Boolean variable y.
|
| BoolView (BoolVarImp *y) |
| Initialize from Boolean variable implementation y.
|
Value access |
|
int | min (void) const |
| Return minimum of domain.
|
int | max (void) const |
| Return maximum of domain.
|
int | med (void) const |
| Return median of domain (greatest element not greater than the median).
|
int | val (void) const |
| Return assigned value (only if assigned).
|
unsigned int | size (void) const |
| Return size (cardinality) of domain.
|
unsigned int | width (void) const |
| Return width of domain (distance between maximum and minimum).
|
unsigned int | regret_min (void) const |
| Return regret of domain minimum (distance to next larger value).
|
unsigned int | regret_max (void) const |
| Return regret of domain maximum (distance to next smaller value).
|
Domain tests |
|
bool | range (void) const |
| Test whether domain is a range.
|
bool | in (int n) const |
| Test whether n is contained in domain.
|
bool | in (long long int n) const |
| Test whether n is contained in domain.
|
Boolean domain tests |
|
bool | zero (void) const |
| Test whether view is assigned to be zero.
|
bool | one (void) const |
| Test whether view is assigned to be one.
|
bool | none (void) const |
| Test whether view is not yet assigned.
|
Boolean assignment operations |
|
ModEvent | one (Space &home) |
| Try to assign view to one.
|
ModEvent | zero (Space &home) |
| Try to assign view to zero.
|
ModEvent | one_none (Space &home) |
| Assign not yet assigned view to one.
|
ModEvent | zero_none (Space &home) |
| Assign not yet assigned view to zero.
|
Domain update by value |
|
ModEvent | lq (Space &home, int n) |
| Restrict domain values to be less or equal than n.
|
ModEvent | lq (Space &home, long long int n) |
| Restrict domain values to be less or equal than n.
|
ModEvent | le (Space &home, int n) |
| Restrict domain values to be less than n.
|
ModEvent | le (Space &home, long long int n) |
| Restrict domain values to be less than n.
|
ModEvent | gq (Space &home, int n) |
| Restrict domain values to be greater or equal than n.
|
ModEvent | gq (Space &home, long long int n) |
| Restrict domain values to be greater or equal than n.
|
ModEvent | gr (Space &home, int n) |
| Restrict domain values to be greater than n.
|
ModEvent | gr (Space &home, long long int n) |
| Restrict domain values to be greater than n.
|
ModEvent | nq (Space &home, int n) |
| Restrict domain values to be different from n.
|
ModEvent | nq (Space &home, long long int n) |
| Restrict domain values to be different from n.
|
ModEvent | eq (Space &home, int n) |
| Restrict domain values to be equal to n.
|
ModEvent | eq (Space &home, long long int n) |
| Restrict domain values to be equal to n.
|
Domain update by iterator |
Views can be both updated by range and value iterators. Value iterators do not need to be strict in that the same value is allowed to occur more than once in the iterated sequence.
The argument depends must be true, if the iterator passed as argument depends on the view on which the operation is invoked. In this case, the view is only updated after the iterator has been consumed. Otherwise, the domain might be updated concurrently while following the iterator.
|
template<class I > |
ModEvent | narrow_r (Space &home, I &i, bool depends=true) |
| Replace domain by ranges described by i.
|
template<class I > |
ModEvent | inter_r (Space &home, I &i, bool depends=true) |
| Intersect domain with ranges described by i.
|
template<class I > |
ModEvent | minus_r (Space &home, I &i, bool depends=true) |
| Remove from domain the ranges described by i.
|
template<class I > |
ModEvent | narrow_v (Space &home, I &i, bool depends=true) |
| Replace domain by values described by i.
|
template<class I > |
ModEvent | inter_v (Space &home, I &i, bool depends=true) |
| Intersect domain with values described by i.
|
template<class I > |
ModEvent | minus_v (Space &home, I &i, bool depends=true) |
| Remove from domain the values described by i.
|
Delta information for advisors |
|
int | min (const Delta &d) const |
| Return minimum value just pruned.
|
int | max (const Delta &d) const |
| Return maximum value just pruned.
|
bool | any (const Delta &d) const |
| Test whether arbitrary values got pruned.
|
static bool | zero (const Delta &d) |
| Test whether a view has been assigned to zero.
|
static bool | one (const Delta &d) |
| Test whether a view has been assigned to one.
|
View-dependent propagator support |
|
static ModEventDelta | med (ModEvent me) |
| Translate modification event me to modification event delta for view.
|
Test sharing between Boolean and negated Boolean views |
NegBoolView
|
BoolTest | bool_test (const BoolView &b0, const BoolView &b1) |
| Test whether views b0 and b1 are the same.
|
BoolTest | bool_test (const BoolView &b0, const NegBoolView &b1) |
| Test whether views b0 and b1 are complementary.
|
BoolTest | bool_test (const NegBoolView &b0, const BoolView &b1) |
| Test whether views b0 and b1 are complementary.
|
BoolTest | bool_test (const NegBoolView &b0, const NegBoolView &b1) |
| Test whether views b0 and b1 are the same.
|
Boolean view for Boolean variables.
Provides convenient and efficient operations for Boolean views.