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 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

54 lines
1.9 KiB
MiniZinc

predicate fzn_cumulative(array[int] of var int: s,
array[int] of var int: d,
array[int] of var int: r, var int: b) =
let {
set of int: Tasks =
{i | i in index_set(s) where ub(r[i]) > 0 /\ ub(d[i]) > 0 }
} in
if 0==card(Tasks) then /*true*/ 0==card(index_set(s)) \/ b>=0
else
let {
int: early = min([ lb(s[i]) | i in Tasks ]),
int: late = max([ ub(s[i]) + ub(d[i]) | i in Tasks ])
} in (
if late - early > 5000 then
fzn_cumulative_task(s, d, r, b)
else
fzn_cumulative_time(s, d, r, b)
endif
)
endif
;
predicate fzn_cumulative_time(array[int] of var int: s,
array[int] of var int: d,
array[int] of var int: r, var int: b) =
let {
set of int: Tasks =
{i | i in index_set(s) where ub(r[i]) > 0 /\ ub(d[i]) > 0 },
int: early = min([ lb(s[i]) | i in Tasks ]),
int: late = max([ ub(s[i]) + ub(d[i]) | i in Tasks ])
} in (
forall( t in early..late ) (
b >= sum( i in Tasks ) (
bool2int(s[i] <= t /\ t < s[i] + d[i]) * r[i]
)
)
);
predicate fzn_cumulative_task(array[int] of var int: s,
array[int] of var int: d,
array[int] of var int: r, var int: b) =
let {
set of int: Tasks =
{i | i in index_set(s) where ub(r[i]) > 0 /\ ub(d[i]) > 0 }
} in (
forall( j in Tasks ) (
b >= r[j] + sum( i in Tasks where i != j ) (
bool2int(s[i] <= s[j] /\ s[j] < s[i] + d[i] ) * r[i]
)
)
);