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_cumulative_opt_reif.mzn
Jip J. Dekker f2a1c4e389 Squashed 'software/mza/' content from commit f970a59b17
git-subtree-dir: software/mza
git-subtree-split: f970a59b177c13ca3dd8aaef8cc6681d83b7e813
2021-07-11 16:34:30 +10:00

17 lines
727 B
MiniZinc

predicate fzn_cumulative_opt_reif(array[int] of var opt int: s,
array[int] of var int: d,
array[int] of var int: r, var int: b, var bool: bb) =
let {
set of int: tasks =
{i | i in index_set(s) where ub(r[i]) > 0 /\ ub(d[i]) > 0 },
set of int: times =
min([ lb(s[i]) | i in tasks ]) ..
max([ ub(s[i]) + ub(d[i]) | i in tasks ])
}
in
bb <-> forall( t in times ) (
b >= sum( i in tasks ) (
bool2int( occurs(s[i]) /\ deopt(s[i]) <= t /\ t < deopt(s[i]) + d[i] ) * r[i]
)
);