3.7.18. Assignment to the same set of values
modelling: assignment to the same set of values Given several mutually disjoint finite sets of values such that , as well as a set of variables , the assignment to the same set of values subproblem consists of assigning all variables values that belong to the same set . As we will see later on, this subproblem arises naturally in many resource assignment problems where an additional constraint between variables also has to hold. The subproblem can be modelled as a conjunction of constraints of the form:
ย ย ย
where if and only if (i.e., corresponds to the index of the set that contains value ). The -th constraint expresses that variable is assigned a value in set . Since all constraints share the same third argument this forces all variables to be assigned a value within the same set. Note that this conjunction of constraints corresponds to a Berge-acyclic constraint network. Consequently, one can achieve arc-consistency on this subproblem provided that arc-consistency is enforced on each constraint.
As an example, consider the four sets of values , , , and , as well as four variables , , and that all must be assigned values that belong to the same set . This leads to the following conjunction of constraints:
The first entry of the table is set to 2 since value 1 belongs to . Similarly, the second entry of the table is set of 4 since value 2 belongs to . The same logic is used for building up the other entries of the table.
A generalisation of this subproblem consists in lifting the restriction that the sets of values are mutually disjoint. The only change to adapt the previous model is to replace within each constraint each value by a value variable (i.e., each value of a value variable represents a set containing ), where if and only if . Distinct constraints will get distinct value variables. As an example, consider the previous four sets of values where we add value 2 to and value 5 to . We now have the sets , , , and where value 2 occurs both in and , and value 5 appears both in and . This leads to the following conjunction of constraints:
The domain of the variables associated with the second entry of the tableThe table corresponds to the second argument of the constraint. of the constraints is set to 1 and 4 since value 2 belongs to and to . Similarly, the domain of variables associated with the fifth entry is set to 2 and 3 since value 5 belongs to and . Note that, since variables , , , , , , , are distinct, the corresponding constraint network is still Berge-acyclic. We now provide an alternative model where the entry of the table of the constraint corresponds to a variable for which the initial domain is the set of values that belong to . We have a conjunction of constraints of the form:
ย ย ย
where is a variable ranging from 1 to designating the selected set. This model perhaps seems more natural. However unlike the first model, when the sets are mutually disjoint, it enforces using variables instead of integers in the table of each constraint. Like the first model, it is Berge-acyclic.
Now that we have presented two dual models for the assignment to the same set of values subproblem, we introduce the resource assignment with groups pattern, which uses several instances of the subproblem. We consider a set of tasks tasks, where each task is decomposed into subtasks . All subtasks that belong to one and the same task should be assigned the same group, where groups are defined by the finite sets of values introduced early on. For this purpose an assignment variable and a group variable are respectively associated with each subtask and each task. In addition, we also have a resource constraint involving all subtasks. This resource constraint has an assignment dimension corresponding to the different resources where subtasks can potentially be assigned. To each resource corresponds a value of . Depending on the kind of resource constraint we have (e.g.,ย , , , ), each subtask has additional attributes that characterise it. For instance, if we have a constraint then, in addition to the assignment dimension that corresponds to the bin where a subtask will be assigned, we also have a weight attribute that describes how much space a subtask uses in a bin. Then the constraint expresses that the total weight of the subtasks in each bin does not exceed a given fixed capacity.
Figure 3.7.3. Illustration of the constraint network associated with the resource assignment with groups pattern
Figureย 3.7.3 illustrates the constraint network associated with the resource assignment with groups pattern. Lower circles represent the group variables associated with the different tasks (three tasks in the example), while all the other circles represent the attributes of the different subtasks (i.e., vertically aligned circles correspond to the attributes of a given subtask). All circles that are associated with the same task are coloured with the same colour. As said before, each subtask has an attribute that gives the resource to which the resource will be assigned (called assignment variables in Figureย 3.7.3) and other attributes that depend of the resource constraint we are considering (called other subtask attributes in the Figure). Each blue rounded box corresponds to a group constraint which enforces all subtasks of a given task to be assigned the same group (i.e., within this blue box, each line segment represents an constraint of the assignment to the same set of values subproblem). Finally, the pink rounded box represents the resource constraint that involves all subtasks.
Before illustrating the resource assignment with groups pattern on a particular resource constraint, we first point out a potential weakness that is inherent to this constraint network, no matter what kind of resource constraint we use. When pruning the assignment variables, the resource constraint will ignore the groups (since the resource constraint is not aware of the constraints) and will therefore miss some filtering. Consequently one may complete the constraint network by some global necessary conditions. When fixing variables it may be a good idea to fix all variables that are attached to one task before considering the next task. While fixing the variables of a task one may first assign its group variable, and second fix the variables of its subtasks; again we may prefer to fix all variables of a subtask before considering the next subtask. The idea behind this heuristics is to try to avoid the creation of infeasible subproblems during search.
Figure 3.7.4. Illustration of the resource assignment with groups pattern in the context of a resource constraint (subtasks of the same colour are assigned to the same group of bins)
Figureย 3.7.4 illustrates the resource assignment with groups pattern when the resource constraint corresponds to a constraint. As in Figureย 3.7.3, we have three tasks , and such that:
Three subtasks , and are associated with task . They have a respective weight of 2, 3 and 2 and are coloured in green in Figureย 3.7.4.
Two subtasks and of respective weight 2 and 3 are associated with task . They are coloured in yellow.
Two subtasks and of respective weight 2 and 1 are associated with task . They are coloured in orange.
We consider 9 bins that are partitioned into four groups of bins (coloured in light blue in Figureย 3.7.4), (coloured in light green), (coloured in light brown), and (coloured in light violet), and enforce that all subtasks that are associated with the same task are assigned the same group of bins. In addition, the sum of the weights of the subtasks that are assigned the same bin should not exceed the capacity of the bins, 5 in our example. Within the solution depicted by Figureย 3.7.4, all constraints are satisfied since:
For each task, all its subtasks are assigned the same group of bins (i.e., all subtasks that have the same colour are assigned bins with the same colour).
The capacity constraint of each bin is respected (i.e., the overall capacity of five is never exceeded).
The conjunction of constraints corresponding to this solution is:
ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย
ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย .
For each subtask we have one constraint expressing that all subtasks of a given task are assigned the same group of bins. Finally we have one constraint expressing the capacity condition.
We now quote two concrete examples of the resource assignment with groups pattern:
Given, (1)ย a set of jobs where each job is decomposed into a set of tasks, each of them requiring an amount of memory for its execution, as well as (2)ย a set of potential machines, each of them having a given available memory, organised into clusters, the problem is to:
Assign all tasks to machines in such a way that tasks from the same job are assigned the same cluster.
Fulfil the available memory constraint of each machine (i.e., the sum of the required memory of all tasks that are assigned a given machine does not exceed the machine available memory).
This concrete problem corresponds to the example presented in Figureย 3.7.4.
Given, (1)ย a set of maintenance activities where each maintenance activity is decomposed into a set of subactivities, each of them requiring a specific skill and a given duration, as well as (2)ย a set of technicians, each of them having its own home base location and its own working time window, the problem is to:
Assign all maintenance subactivities to technicians in such a way that subactivities from the same activity are assigned technicians that have the same home base location (i.e., each subactivity should be assigned a single technician).
Fulfil both the working time window of each technician, and the fact that subactivities that are assigned the same technician should not overlap (i.e., subactivities must be assigned a starting time and preemption is not allowed).
In this problem we replace the constraint by a constraint. To each item of the collection corresponds a subactivity, such that:
Its attribute designates the potential technicians that can take care of this subactivity.
Its attribute corresponds to the timepoint where the subactivity will actually start.
Its attribute is set to the duration of the corresponding subactivity.
Its attribute is equal to .
Its attribute is set to one.
In addition to the subactivities, we also introduce for each technician two fixed dummy tasks for preventing assigning subactivities outside its time window. To each item of the collection corresponds a technician, such that:
Its attribute is a fixed integer that uniquely identifies the technician.
Its attribute is set to one since it cannot perform more than one subactivity at any timepoint.