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.
on-restart-benchmarks/share/minizinc/std/fzn_arg_max_bool.mzn
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

14 lines
480 B
MiniZinc

predicate fzn_maximum_arg_bool(array[int] of var bool: x, var int: z) =
% general case: min could be 0 or 1
let { int: l = min(index_set(x)) ;
int: u = max(index_set(x)) ;
int: n = u-l+1;
array[int] of var int: xs = array1d(l..u,[ n*x[j]+(u-j) | j in l..u ]);
var int: Mx = max(xs) ;
} in
forall (j in l..u) ( (z != j) = (Mx > xs[j]) );
%%% only the new decomposition from argmax paper CP2020 submission