Continuity Constraint
Soft constraint*
* with possibility for hard constraintThe continuity constraint can be enabled to improve the continuity of selected employees
for certain shifts. This can be relevant in cases where planners want to make sure that they do not have to onboard new employees
every day (when employing temp workers), or where it is preferred for employees
to work multiple shifts in similar groups.
The constraint is configured by specifying continuityGroups
. A group consist of one or more shifts
, and can be specified to apply to the entire schedule (default) or to a certain set of days.
The solver will attempt to ensure that all shifts within one continuityGroup
are worked by the same employees
. If this is not possible, it will try to minimize the number of deviations.
Each continuity constraint can be assigned a weight
from 0 to 100 to indicate its importance. Moreover, should a planner require strict continuity for some continuityGroup
, the isStrict
property can be used.
Strict continuity
A group is considered to have strict continuity when all shifts in the group are worked by the first X entries in some ordering of all employees. The number of employees (X) may differ per shift. For instance, this is an example of assignments that would constitute strict continuity. The numbers represent employees.
Monday | [8, 3, 2]
Tuesday | [8, 3, 2, 5, 7]
Wednesday | [8, 3, 2, 5]
Thursday | [8, 3, 2, 5]
Friday | [8]
The following example shows two continuity constraint with three continuity groups in total, which have the following effects:
- It is preferred to have a similar group of people working all
shift-1
shifts during the first week. - It is preferred to have a similar group of people working all
shift-1
shifts during the second week. This may be a different group than was used in the first week. - It is required for all
shift-2
shifts to be worked by the same group of people. This applies to the entire schedule.
{
"continuityConstraints": [
{
"id": "cc-123",
"continuityGroups": [
{
"shiftIds": ["shift-1"],
"scheduleDays": {
"dayIndexes": [0, 1, 2, 3, 4]
}
},
{
"shiftIds": ["shift-1"],
"scheduleDays": {
"dayIndexes": [5, 6, 7, 8, 9]
}
}
]
},
{
"id": "cc-456",
"isStrict": true,
"continuityGroups": [
{
"shiftIds": ["shift-2"],
}
]
}
]
},
Continuity Constraint in the request payload
id required | string (constraintId) Unique identifier for the constraint. |
importance | string (importanceWithStrict) Enum: "NONE" "VERY_LOW" "LOW" "MEDIUM" "HIGH" "VERY_HIGH" "STRICT" The importance of the constraint. The higher the importance, the more the solver will take the constraint into account. Under strict importance, the constraint may never be violated. |
required | Array of objects non-empty Groupings of shifts which should preferably be handled by a low number of distinct employees. Currently, a shift can only be part of one continuityGroup per continuityConstraint. |
weight | integer (constraintWeightPositive) [ 0 .. 100 ] Deprecated DEPRECATED - Use importance instead. |
isStrict | boolean Deprecated Default: false DEPRECATED - Use importance instead. If set to true, continuity groups in this constraint must have strict continuity. A group is considered to have strict continuity when all shifts in the group are worked by the first X entries in some ordering of all employees. The number of employees (X) may differ per shift. For more information, see the Continuity Constraint documentation. If a shift impacted by this constraint cannot be filled without breaking strict continuity, it will remain unassigned. |
{- "id": "string",
- "importance": "NONE",
- "continuityGroups": [
- {
- "shiftIds": [
- "string"
], - "shiftGroupLabel": "string",
- "scheduleDays": {
- "weekDays": {
- "example_1": {
- "value": [
- 1
], - "summary": "All Mondays in the planning horizon."
}
}, - "dayIndexes": {
- "example_1": {
- "value": [
- 0,
- 1,
- 2,
- 3
], - "summary": "First four days of the planning horizon."
}
}, - "dates": {
- "example_1": {
- "value": [
- "2023-12-24",
- "2023-12-25"
], - "summary": "The 24th and 25th of December 2023."
}
}
}
}
], - "weight": {
- "example_1": {
- "value": 0,
- "summary": "The constraint is not taken into account when solving the schedule as it has weight 0."
}, - "example_2": {
- "value": 100,
- "summary": "Solver will try its best to satisfy the constraint as it has weight 100."
}
}, - "isStrict": false
}