1
0
This repository has been archived on 2025-03-06. You can view files and clone it, but cannot push or open issues or pull requests.
Jip J. Dekker fad1b07018 Squashed 'software/minizinc/' content from commit 4f10c8205
git-subtree-dir: software/minizinc
git-subtree-split: 4f10c82056ffcb1041d7ffef29d77a7eef92cf76
2021-06-16 14:06:46 +10:00

38 lines
1.4 KiB
MiniZinc

include "table_bool.mzn";
include "table_int.mzn";
include "fzn_table_int_opt.mzn";
/** @group globals.extensional
Represents the constraint \a x in \a t where we
consider each row in \a t to be a tuple and \a t as a set of tuples.
*/
predicate table(array[int] of var bool: x, array[int, int] of bool: t) =
assert (index_set_2of2(t) == index_set(x),
"The second dimension of the table must equal the number of variables "
++ "in the first argument",
table_bool(x, t)
);
/** @group globals.extensional
Represents the constraint \a x in \a t where we
consider each row in \a t to be a tuple and \a t as a set of tuples.
*/
predicate table(array[int] of var int: x, array[int, int] of int: t) =
assert (index_set_2of2(t) == index_set(x),
"The second dimension of the table must equal the number of variables "
++ "in the first argument",
table_int(x, t)
);
/** @group globals.extensional
Represents the constraint \a x in \a t if the variable \a x_i and the value
\a t_i occur where we consider each row in \a t to be a tuple and \a t as a
set of tuples.
*/
predicate table(array[int] of var opt int: x, array[int, int] of opt int: t) =
assert (index_set_2of2(t) == index_set(x),
"The second dimension of the table must equal the number of variables "
++ "in the first argument",
fzn_table_int_opt(x, t)
);