git-subtree-dir: software/mza git-subtree-split: f970a59b177c13ca3dd8aaef8cc6681d83b7e813
17 lines
671 B
MiniZinc
17 lines
671 B
MiniZinc
include "fzn_global_cardinality_closed.mzn";
|
|
include "fzn_global_cardinality_closed_reif.mzn";
|
|
|
|
/** @group globals.counting
|
|
Requires that the number of occurences of \p i in \a x is \a counts[\p i].
|
|
|
|
The elements of \a x must take their values from \a cover.
|
|
*/
|
|
predicate global_cardinality_closed(array[int] of var int: x,
|
|
array[int] of int: cover,
|
|
array[int] of var int: counts) =
|
|
assert(index_set(cover) = index_set(counts),
|
|
"global_cardinality_closed: " ++
|
|
"cover and counts must have identical index sets",
|
|
fzn_global_cardinality_closed(x, cover, counts)
|
|
);
|