2.5 MODELLING MANUFACTURING SYSTEMS WITH DIOIDS
2.5.2 M ODELLING T IME W INDOW C ONSTRAINTS
Example 2.22 (Manufacturing systems with time window constraints)
Consider a (part of a) manufacturing system which, similar to the system in Example 2.21, com- bines two intermediate products to a final product. However, once intermediate product 1 has been finished, it has to rest for at least 3 but not more than 5 time units before it can be further processed. Similarly, intermediate product 2 has to rest for at least 1 but not more than 4 time units after it has been finished. Thus, there are time windows for the resting periods of both intermediate products. The corresponding part of the TEG is given in Figure 2.11. In this figure, the brackets at the places represent the time window with its lower and upper bound. For this
[1,4]
[3,5]
x1
x2
x3
FIGURE 2.11 Part of a TEG with time window constraints.
TEG, it is quite simple to determine the dependencies inMaxin[[γ,δ]]. The lower bounds of the time window are modelled as for standard TEG, that is,
x3δ3x1, x3δx2.
This means that x3can fire as soon as 3 time units have passed after the firing of x1and 1 time unit needs to have passed after the firing of x2. Consequently the two dependencies can be merged to
x3δ3x1⊕δx2. (2.44)
The upper bounds of the time window are modelled similarly. Transition x3has to fire at the latest 5 time units after the firing of x1and not later than 4 time units after the firing of x2. InMaxin[[γ,δ]]
this can be written as
x3δ5x1, x3δ4x2. These two constraints can be merged to
x3δ5x1∧δ4x2. (2.45)
Note that the dependencies of the lower bounds are merged by⊕into their greatest lower bounds and the upper bounds are merged into their least upper bound. Equations 2.44 and 2.45 can be written in matrix–vector form:
x
⎡
⎣ ε ε ε ε ε ε δ3 δ ε
⎤
⎦⊗x, (2.46)
x
⎡
⎣ δ5 δ4
⎤
⎦x. (2.47)
It is important to note that the dependencies of the upper time window constraints are written in terms of the dual multiplication (see Definition 2.21 for details) and that the zero element of this
operation is.
In the previous example, there are two different kinds of constraints on the system, and it is not possible to determine a linear ad hoc model inMaxin[[γ,δ]]. In the following, we will show how (under some conditions) such a linear model can be achieved. Our approach is based on the method introduced in [23–25].
Formally, the internal behaviour of the system is defined by two types of constraints, that is,
xA⊗x, (2.48)
xAx, (2.49)
where the entries of A represent the lower time bounds imposed by a standard TEG and the entries of A represent the upper bounds of the time windows and the minimal number of tokens between two transitions. According to Lemmas 2.1 and 2.5, any solution of the previous inequalities also satisfies
x=A∗⊗x, x=A∗x.
The aim is to find an x that fulfils both constraints, which means that we have to guarantee that x is in the image of LA∗ and in the image ofA∗(see Remarks 2.11 and 2.13). Formally,
A∗⊗x=x=A∗x⇔x∈ImLA∗∩ImA∗. (2.50)
It can be shown [5] that, if every entry of A∗ is eitherε oror admits a multiplicative inverse, the map P : x →
A∗•\A∗∗
◦\x is a projector in ImLA∗∩ImA∗. Hence, if this condition holds, x∈ImLA∗∩ImA∗is equivalent to x=
A∗•\A∗∗
◦\x. This, according to Lemma 2.1, is equivalent to
x=( A∗•\A∗)∗
A∗
⊗x.
Consequently, if the invertibility condition for the entries of A∗holds, the matrix A∗captures the constraints (2.48) and (2.49) and therefore represents time window constraints.
Example 2.23 (Simple manufacturing system with time window constraints)
Reconsider the simple manufacturing system of Example 2.21 with an additional time window constraint between transitions x4and x5, such that x5has to fire at the latest 2 time units after x4has fired. The corresponding (extended) TEG is given in Figure 2.12. As nothing has changed except for the upper bound for the time between the firings of x4 and x5, the matrix A∗ given in Example 2.21 is equivalent to matrix A∗of the system with time window constraints given in Figure 2.12. The only additional constraint is
x5δ2x4,
that is, transition x5shall fire (for the kth time) at the latest two time units after transition x4has fired for the kth time. Consequently, matrix A has a single entry not equal to, that is,
A
54=δ2. The resulting A∗capturing all constraints is
x2
x4
x5 x6 y
0 3
4
0 u1
x1 10
0
x3 u3
u2
1
[1,2]
FIGURE 2.12 Simple manufacturing system with time window constraints.
A∗=(A∗•\A∗)∗
=
⎡
⎢⎢
⎢⎢
⎢⎢
⎣
γ2δ10∗
γ2 γ2δ10∗
ε ε ε
δ10
γ2δ10∗ γ2δ10∗
ε ε ε
γδ9⊕γ2δ13 γ2δ10∗
γδ−1⊕γ2δ3 γ2δ10∗ γδ4∗
γ
γδ4∗
γδ−2 γδ4∗ δ9⊕γδ13 γ2δ10∗
δ−1⊕γδ3 γ2δ10∗ δ4
γδ4∗ γδ4∗
δ−2 γδ4∗ δ11⊕γδ14 γ2δ10∗
δ⊕γδ4 γ2δ10∗ δ5
γδ4∗ δ
γδ4∗ δ14⊕γδ17 γ2δ10∗
δ4⊕γδ7 γ2δ10∗ δ8
γδ4∗ δ4
γδ4∗ δ3⊕
γδ6 γδ4∗ ε
ε
γ2δ−2 γδ4∗ γδ−2
γδ4∗ γ⊕
γ2δ3 γδ4∗ e⊕γδ3⊕
γ2δ6 γδ4∗
⎤
⎥⎥
⎥⎥
⎥⎥
⎦ .
Then the system state x can be computed by x=A∗Bu
=
⎡
⎢⎢
⎢⎢
⎢⎢
⎣
γ2δ10∗
ε ε
δ10 γ2δ10∗
ε ε
γδ9⊕γ2δ13 γ2δ10∗ γδ4∗
γδ−2 γδ4∗ δ9⊕γδ13 γ2δ10∗
δ4 γδ4∗
δ−2 γδ4∗ δ11⊕γδ14 γ2δ10∗
δ5 γδ4∗
e⊕
γδ3 γδ4∗
δ14⊕γδ17 γ2δ10∗
δ8 γδ4∗
δ3⊕
γδ6 γδ4∗
⎤
⎥⎥
⎥⎥
⎥⎥
⎦ u,
which is not causal with respect to Definition 2.34. The corresponding causal projection of the transfer relation is
x=Prcaus(A∗B)u
=
⎡
⎢⎢
⎢⎢
⎢⎢
⎣
γ2δ10∗
ε ε
δ10 γ2δ10∗
ε ε
γδ9⊕γ2δ13 γ2δ10∗ γδ4∗
γ2δ2 γδ4∗ δ9⊕γδ13 γ2δ10∗
δ4 γδ4∗
γδ2 γδ4∗ δ11⊕γδ14 γ2δ10∗
δ5 γδ4∗
e⊕
γδ3 γδ4∗ δ14⊕γδ17 γ2δ10∗
δ8 γδ4∗
δ3⊕
γδ6 γδ4∗
⎤
⎥⎥
⎥⎥
⎥⎥
⎦ u,
and the earliest possible firing of all internal transitions is x=Prcaus(A∗B)e
=
⎡
⎢⎢
⎢⎢
⎢⎢
⎣
γ2δ10∗
δ10 γ2δ10∗
γδ9⊕γ2δ13 γ2δ10∗
δ9⊕γδ13 γ2δ10∗
δ11⊕γδ14 γ2δ10∗
δ14⊕γδ17 γ2δ10∗
⎤
⎥⎥
⎥⎥
⎥⎥
⎦ .
Looking at the earliest possible firings of internal transitions, it becomes clear that the time window constraint affects the operation of resource RB(represented by transitions x3and x4). Since the start of processing part C may not be more than 2 time units after part B is finished, the production of Bis slowed down to the production rate of resource RC, which is constrained by the throughput of resource RA, the bottleneck of the system. Consequently, the earliest possible and admissible
firing of every transition has the same throughput of 2 parts every 10 time units. Furthermore, the transfer relation of the system also changes, that is,
y=CA∗Bu
=
δ14⊕γδ17 γ2δ10∗
δ8 γδ4∗
δ3⊕
γδ6 γδ4∗ u.
While the firing of internal transitions and the transfer relation change due to the additional time window constraint, the fastest throughput of the overall system remains the same, that is,
y=CA∗Be
=
δ14⊕γδ17 γ2δ10∗ .
This is due to the fact that the introduced time window does not affect the overall throughput of the system but rather imposes an addition constraint on its internal behaviour.
2.5.3 MODELLINGREENTRANTOPERATIONS
The previous example described a system with time window constraints. In the following example, a system is described in which a minimal number of tokens are required in certain places, for example, to increase the throughput of the system.
Example 2.24 (Nested schedules in manufacturing systems)
Consider a simple manufacturing system which consists of a single resource with a capacity of 1.
However, this resource has to perform two processing steps on every part. The minimal times for these two processing steps, also called activities, are 2 time units and 1 time unit, respectively. In between these two activities, the part is moved to a buffer of appropriate size and has to rest there for at least 2 time units. Using this setup, parts should be produced in an efficient way. A rather naive approach would be to start producing one part after the other. The corresponding TEG of this approach is given in Figure 2.13. In this figure, the input represents the provision with raw material, the output y refers to the finishing of a part and x1and x2(resp., x3and x4) model the start and finish events of activity one (resp., activity two). The activities are indicated by dashed boxes and the buffer is represented by the place in between the two activities. The capacity of the single resource is modelled by the three initial tokens shown in Figure 2.13. Since the resource has a single capacity, act1cannot start earlier than the same activity of the previous part has been finished. Likewise, act2cannot start until the preceding act2has been finished, and act1can only start if the previous part has been finished processing in act2. In other words, at any time, there is at most one part processed in act1, there is also at most one part processed in act2, and finally, at any time, there is at most one part processed in the system. In fact, modelling the ‘capacity’ of an activity is not necessary in this setting; however, later on (in a different setting, i.e., in operations
x1 x2 x3 x4 y
act1 act1
u 2
0
0
0 1 0 0 2
FIGURE 2.13 TEG of the simple manufacturing system (Example 2.24).
with nested schedules), this may be crucial for the correct modelling of the system’s behaviour.
The linear representation of the TEG given in Figure 2.13 inMaxin[[γ,δ]]results in
x=
⎡
⎢⎢
⎣
ε γ ε γ δ2 ε ε ε ε δ2 ε γ ε ε δ ε
⎤
⎥⎥
⎦
A
x⊕
⎡
⎢⎢
⎣ e ε ε ε
⎤
⎥⎥
⎦
B
u,
y=
ε ε ε e
C
x.
The smallest solution of the implicit equation is x=A∗Bu
=
⎡
⎢⎢
⎣ γδ5∗
γδ3 γδ5∗
γδ γδ5∗
γ γδ5∗ δ2
γδ5∗ γδ5∗
γδ3 γδ5∗
γδ2 γδ5∗
δ4 γδ5∗
δ2
γδ5∗ γδ5∗
γδ4 γδ5∗
δ5 γδ5∗
δ3 γδ5∗
δ
γδ5∗ γδ5∗
⎤
⎥⎥
⎦
⎡
⎢⎢
⎣ e ε ε ε
⎤
⎥⎥
⎦u
=
⎡
⎢⎢
⎣ γδ5∗
δ2 γδ5∗
δ4 γδ5∗
δ5 γδ5∗
⎤
⎥⎥
⎦u,
and the corresponding input–output behaviour of the system is y=Cx=CA∗Bu
=δ5 γδ5∗
u.
Looking at the transfer relation, one can easily see that 5 time units after the input has fired for the first time, the first part is finished. Furthermore, the maximal throughput of the system is 1 part every 5 time units. Often the operation of a manufacturing system is visualized by a so-called Gantt chart. The Gantt chart of this example is given in Figure 2.14a. Looking at the Gantt chart of the example, it is obvious that the capacity utilization of the single resource R1is rather low.
k k+1 k+2
(a) part R1
act1 act2 act1 act2 act1 act2
time
k
part k– 1 k+ 1 k+ 2 k+ 3 k+ 4
R1
act2 act1
act2 act1
act2 act1
act2 act1
act2 act1
time
(b)
FIGURE 2.14 Gantt chart of possible schedules of the manufacturing system. (a) Gantt chart of a simple schedule. (b) Gantt chart of a nested schedule.
More precisely, between the execution of act1and act2of a part, the resource is idle. To increase the efficiency of the manufacturing system, the user may want to try to reduce this idle time by choosing a different schedule. For example, the idle time of the resource when producing part k may be used to execute act1of the next part, that is, part k+1, and consequently, act2of part k will be executed between act1and act2of part k+1. Such a schedule is said to be nested as (at least) one activity of a future part (e.g., part k+1) is executed in between activities of part k. In our example, however, this is only possible if the resting time between act1and act2is extended by 1 time unit (to be able to squeeze in the additional activities), which is of course possible as the two-time-unit resting time represents a minimal time. The corresponding Gantt chart of this nested schedule is given in Figure 2.14b. From this, it can be seen that the total processing time of a single part is elongated from 5 to 6 time units, but the throughput of the system is increased to 1 part every 3 time units. To study this formally, the nested schedule is modelled as a TEG and represented as a linear system in the dioidMaxin[[γ,δ]]. To do this, one has to find the dependencies for the firing of transitions in the system. First of all, it is clear that the (minimal) timing information for the production of a single part remains unchanged, that is,
x2δ2x1 processing time of act1,
x3δ2x2 resting time between act1and act2, x4δx3 processing time of act2.
Furthermore, as the capacity of the resource does not change, an activity for part k can still only start if the same activity for part k−1 has been finished, that is, one gets
x1γx2, x3γx4.
Thus, to this point, nothing has changed with respect to the dependencies of the simple schedule.
What changes is the number of parts present in the system at the same time. Even though resource R1 is still of single capacity, there are always two parts in the system (one being processed in act1or act2and the other one resting). Thus, the dependencies of different activities executed on different parts to be processed change. Looking at the Gantt chart of the nested schedule, one can easily determine that act1of part k has to be finished before act2of part k−1 can start. Similarly, act1of part k+1 cannot start until act2of part k−1 has been finished. Formally, this means
x2γ1x3, (2.51)
x1γ2x4. (2.52)
The first of these two inequalities warrants particular attention as it is the only constraint where the time of the occurrence of an event for a part is less or equal to the time of the occurrence of an event related to a previous part. With respect to TEGs, this means that at any time, the number of firings of transition x2should be at least one more than the number of firings of x3, that is, there should always be a minimum of one token in the place between x2and x3, if the number of initial
tokens is zero.
Remark 2.27 Note that the requirement x2 γ1x3 could of course also be written as x3 γ−1x2. This, however, would lead to an acausal system model inMaxin[[γ,δ]], as at least one entry in the system matrices would have a negative exponent inγ.
Clearly, the constraints (2.51) and (2.52) are very similar to the constraints of a time window. In fact, with respect to the event variableγ, the constraints on the minimal and maximal number of tokens can be handled analogously to the constraints onδof time window constraints.
Example 2.25 (Nested schedules in manufacturing systems [cont.])
Reconsider the manufacturing system with a nested schedule from Example 2.24. Similar to time window constraints, it is possible to model this system inMaxin[[γ,δ]]by
xA⊗x, xAx, where the matrices A and A are
A=
⎡
⎢⎢
⎣
ε γ ε γ2 δ2 ε ε ε
ε δ2 ε γ
ε ε δ ε
⎤
⎥⎥
⎦, A=
⎡
⎢⎢
⎣
γ
⎤
⎥⎥
⎦.
As
A∗=
⎡
⎢⎢
⎣
e
e γ
e
e
⎤
⎥⎥
⎦
contains only monomials, that is, elements that are eitherε, oror have a multiplicative inverse, the resulting matrix A∗capturing all constraints is
A∗=(A∗•\A∗)∗
=
⎡
⎢⎢
⎣
(γδ3)∗ γδ(γδ3)∗ γ2δ(γδ3)∗ γ2(γδ3)∗ δ2(γδ3)∗ (γδ3)∗ γ2δ3(γδ3)∗ γ2δ2(γδ3)∗ γ−1δ2(γδ3)∗ γ−1(γδ3)∗ (γδ3)∗ γδ2(γδ3)∗ γ−1δ3(γδ3)∗ γ−1δ(γδ3)∗ δ(γδ3)∗ (γδ3)∗
⎤
⎥⎥
⎦.
Then, the complete system representation (with input and output elements) results in x=A∗x⊕Bu=
A∗ ∗
Bu=A∗Bu
=
⎡
⎢⎢
⎣ (γδ3)∗ δ2(γδ3)∗ γ−1δ2(γδ3)∗ γ−1δ3(γδ3)∗
⎤
⎥⎥
⎦u,
y=Cx=CA∗Bu
=γ−1δ3(γδ3)∗u.
Obviously, the obtained transfer relation is not causal. Applying the causal projection Prcaus
results in
y=δ6(γδ3)∗u,
which is equivalent to the system behaviour given in the Gantt chart of the nested schedule
(Figure 2.14b) of Example 2.24.
Obviously, by considering constraints on the minimal number of tokens in places, it is possible to model nested schedules of manufacturing systems. Such nested schedules may have a higher throughput and, therefore, may be more efficient than simple schedules which can be modelled without additional constraints in standard dioids.
[t, t] xj xi
FIGURE 2.15 Simple TEG with unfeasible time window constraints, that is, t>t.
2.5.4 CHECKINGCONSTRAINTFEASIBILITY
One remaining question is, what happens when the user makes a mistake and models an unfeasible constraint, for example, when the upper bound of a time window constraint is smaller than the lower bound. Formally, this would mean that there are two constraints:
xjδtxi, xjδtxi,
with t>t. The corresponding TEG is given in Figure 2.15. The resulting system model of this small TEG with unfeasible time window constraints is
A∗=(A∗•\A∗)∗
=
e δt e
•\
e ε δt e
∗
with x= [xi xj]T. According to Lemma 2.4, the elements of matrix A=(A∗•\A∗)can be computed by A
ij= n
k=1
A∗−1
ki ⊗
A∗
kj
.
Thus,
A
11=e⊗e⊕δ−t⊗δt
=δ(t−t), A
12=e⊗ε⊕δ−t⊗e
=δ−t, A
21=ε⊗e⊕e⊗δt
=δt, A
22=ε⊗ε⊕e⊗e
=e.
Finally, the Kleene star of matrix A has to be determined, for example, by the algorithm given in Remark 2.10. One central element in this algorithm is the term(a21a∗11a12⊕a22)∗, which for matrix
A=
δ(t−t) δ−t δt e
=
a11 a12
a21 a22
can be computed as
(a21a∗11a12⊕a22)∗=
δt(δ(t−t))∗δ−t⊕e ∗
. Since t−t>0, the term(δ(t−t))∗=δ∞. Consequently, one obtains
(a21a∗11a12⊕a22)∗=
δtδ∞δt⊕e∗
=
δ(t+∞−t)⊕e ∗
=(δ∞⊕e)∗
=(δ∞)∗
=δ∞.
Using this result to compute the elements of matrix A∗, one obtains A∗=
δ∞ δ∞ δ∞ δ∞
.
This result means the only way to guarantee that the time window constraints are not violated is to never start the system, that is, all events fire the first time at the earliest at time t= ∞.
Hence, if the user makes a mistake and asks for unfeasible constraints, the resulting linear model inMaxin[[γ,δ]]will tell the user to check his or her constraints once more.
Remark 2.28 (Unfeasible constraints with respect to the number of tokens) A similar effect can be observed if the user asks for unfeasible constraints with respect to the number of tokens. If the user models, for example,
xiγkδτxj, xiγkxj,
that is, at any time t transition xi may fire at most k times more often than xj has fired at time t−τand xishall fire at least k times more often than xjat time t. The corresponding system matrix A=A∗•\A∗is
A=
e γkδτ γ−k γ(k−k)δτ
,
and with k−k<0 andτ>0 and applying the Kleene star, one obtains A∗=
γ−∞δ∞ γ−∞δ∞ γ−∞δ∞ γ−∞δ∞
=
which again means that the constraints can only be met, if the system never starts at all.
Remark 2.29 Of course, a TEG may have time window constraints as well as constraints on the number of tokens. However, it is not possible to have a time window constraint as well as a constraint
on the minimal and maximal number of tokens for the simple TEG shown in Figure 2.15. Consider, for example, the time window constraints
xjδtxi, (2.53)
xjδtxi, (2.54)
with t≤t, and the constraints on the number of firings, for example,
xiγkδτxj, (2.55)
xiγkxj, (2.56)
with k ≥ k and τ > 0. Clearly, the constraints (2.53) and (2.54) by themselves as well as the constraints (2.55) and (2.56) by themselves are feasible; combining these constraints, however, results in matrix
A=A∗•\A∗
=
.
Consequently, our approach cannot be applied as the resulting matrix A indicates that the constraints can only be met if the system is prevented to fire at all.