[ library(fd) | Reference Manual | Alphabetic Index ]
disjunction(?Start1, +Duration1, ?Start2, +Duration2, ?Flag)
Flag indicates which of the two non-overlapping tasks is scheduled as
first. Either the one with starting time Start1 and duration Duration1
(then the value of Flag is 1), or the second one with starting time Start2
and duration Duration2 (and the Flag is 2).
- ?Start1
- A finite domain variable or integer
- +Duration1
- An integer
- ?Start2
- A finite domain variable or integer
- +Duration2
- An integer
- ?Flag
- A finite domain variable or integer
Description
This constraint can be used to model two non-overlapping tasks with
known durations. Given the starting times and durations, this
constraint uses constructive disjunction to remove all inconsistent
values from the domains of Start1 and Start2. In addition to
maintaining their bounds in a consistent state, it also locally executes
both cases (first task before the second one or voce versa) and removes
all values which are not consistent with any of these two alternatives.
If Duration1 or Duration2 is not integer, it obtains a default domain.
Fail Conditions
Fails if there is no possibility to schedule given two tasks in any
order under given conditions.
Resatisfiable
No.
Examples
[eclipse 5]: [X, Y]::1..10, disjunction_choose(X, 5, Y, 7, F).
X = X[1..10]
Y = Y[1..10]
F = F[1, 2]
Delayed goals:
disjunction_choose_1(X[1..10], 5, Y[1..10], 7, F[1, 2])
yes.
[eclipse 6]: [X, Y]::1..10, disjunction(X, 5, Y, 7, F).
X = X[1..5, 8..10]
Y = Y[1..3, 6..10]
F = F
Delayed goals:
disjunction(X[1..5, 8..10], 5, Y[1..3, 6..10], 7, F)
yes.
See Also
disjunctive / 3, disjunction_choose / 5