Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
dream
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
1
Issues
1
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
dream
Commits
74f11f24
Commit
74f11f24
authored
Apr 14, 2014
by
Ioannis Papagiannopoulos
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
draft BatchDecomposition/Reassembly towards signaling. BatchDecomposition working in Topology21
parent
5c035718
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
206 additions
and
107 deletions
+206
-107
dream/simulation/BatchDecomposition.py
dream/simulation/BatchDecomposition.py
+111
-46
dream/simulation/BatchReassembly.py
dream/simulation/BatchReassembly.py
+95
-61
No files found.
dream/simulation/BatchDecomposition.py
View file @
74f11f24
...
@@ -27,7 +27,7 @@ BatchDecomposition is a Core Object that takes a batch and decomposes to sub-bat
...
@@ -27,7 +27,7 @@ BatchDecomposition is a Core Object that takes a batch and decomposes to sub-bat
from
SimPy.Simulation
import
Process
,
Resource
from
SimPy.Simulation
import
Process
,
Resource
from
SimPy.Simulation
import
waituntil
,
now
,
hold
from
SimPy.Simulation
import
waituntil
,
now
,
hold
,
waitevent
from
Globals
import
G
from
Globals
import
G
from
CoreObject
import
CoreObject
from
CoreObject
import
CoreObject
...
@@ -75,18 +75,69 @@ class BatchDecomposition(CoreObject):
...
@@ -75,18 +75,69 @@ class BatchDecomposition(CoreObject):
# the run method of the BatchDecomposition
# the run method of the BatchDecomposition
# =======================================================================
# =======================================================================
def
run
(
self
):
def
run
(
self
):
while
1
:
while
1
:
yield
waituntil
,
self
,
self
.
canAcceptAndIsRequested
#wait until the Queue can accept an entity
while
1
:
#and one predecessor requests it
yield
waitevent
,
self
,
[
self
.
isRequested
,
self
.
interruptionStart
]
self
.
getEntity
()
if
self
.
interruptionStart
.
signalparam
==
now
():
yield
waitevent
,
self
,
self
.
interruptionEnd
assert
self
==
self
.
interruptionEnd
.
signalparam
,
'the victim of the failure is not the object that received the interruptionEnd event'
if
self
.
signalGiver
():
break
else
:
break
requestingObject
=
self
.
isRequested
.
signalparam
assert
requestingObject
==
self
.
giver
,
'the giver is not the requestingObject'
# self.operatorWaitTimeCurrentEntity = 0
# self.loadOperatorWaitTimeCurrentEntity = 0
# self.loadTimeCurrentEntity = 0
# self.setupTimeCurrentEntity = 0
# yield waituntil, self, self.canAcceptAndIsRequested #wait until the Queue can accept an entity
# #and one predecessor requests it
self
.
currentEntity
=
self
.
getEntity
()
# print '$'*40
# set the currentEntity as the Entity just received and initialize the timer timeLastEntityEntered
# set the currentEntity as the Entity just received and initialize the timer timeLastEntityEntered
self
.
currentEntity
=
self
.
getActiveObjectQueue
()[
0
]
# entity is the current entity processed in Machine
self
.
nameLastEntityEntered
=
self
.
currentEntity
.
name
# this holds the name of the last entity that got into Machine
self
.
nameLastEntityEntered
=
self
.
currentEntity
.
name
# this holds the name of the last entity that got into Machine
self
.
timeLastEntityEntered
=
now
()
#this holds the last time that an entity got into Machine
self
.
timeLastEntityEntered
=
now
()
#this holds the last time that an entity got into Machine
self
.
totalProcessingTimeInCurrentEntity
=
self
.
calculateProcessingTime
()
self
.
totalProcessingTimeInCurrentEntity
=
self
.
calculateProcessingTime
()
# self.tinM=self.totalProcessingTimeInCurrentEntity # timer to hold the processing time left
yield
hold
,
self
,
self
.
totalProcessingTimeInCurrentEntity
yield
hold
,
self
,
self
.
totalProcessingTimeInCurrentEntity
# print self.currentEntity.name, 'of type', self.currentEntity.type
self
.
decompose
()
self
.
decompose
()
for
i
in
range
(
self
.
numberOfSubBatches
):
# print ' ', i
if
not
self
.
getActiveObjectQueue
():
break
if
i
==
0
:
signaling
=
self
.
signalReceiver
()
if
not
signaling
:
while
1
:
yield
waitevent
,
self
,
self
.
canDispose
if
self
.
signalReceiver
():
break
else
:
yield
waitevent
,
self
,
self
.
canDispose
signaling
=
self
.
signalReceiver
()
if
not
signaling
:
while
1
:
yield
waitevent
,
self
,
self
.
canDispose
if
self
.
signalReceiver
():
break
# if not self.signalReceiver():
# while 1:
# event=yield waitevent, self, [self.canDispose, self.interruptionStart]
# if self.interruptionStart.signalparam==now():
# yield waitevent, self, self.interruptionEnd
# assert self==self.interruptionEnd.signalparam
# if self.signalReceiver():
# break
# =======================================================================
# =======================================================================
# method that decomposes the activeEntity into subBatches
# method that decomposes the activeEntity into subBatches
...
@@ -107,6 +158,7 @@ class BatchDecomposition(CoreObject):
...
@@ -107,6 +158,7 @@ class BatchDecomposition(CoreObject):
#for example:
#for example:
#if the total is 99 and we have 4 sub-batches it should be [25,25,25,24]
#if the total is 99 and we have 4 sub-batches it should be [25,25,25,24]
#if the total is 94 and we have 4 sub-batches it should be [24,24,24,22]
#if the total is 94 and we have 4 sub-batches it should be [24,24,24,22]
# print now(), '*'*10
for
i
in
range
(
self
.
numberOfSubBatches
):
for
i
in
range
(
self
.
numberOfSubBatches
):
if
i
==
self
.
numberOfSubBatches
-
1
:
if
i
==
self
.
numberOfSubBatches
-
1
:
numberOfSubBatchUnits
=
batchNumberOfUnits
-
alreadyAllocatedUnits
numberOfSubBatchUnits
=
batchNumberOfUnits
-
alreadyAllocatedUnits
...
@@ -119,6 +171,10 @@ class BatchDecomposition(CoreObject):
...
@@ -119,6 +171,10 @@ class BatchDecomposition(CoreObject):
+
str
(
i
),
numberOfUnits
=
numberOfSubBatchUnits
,
+
str
(
i
),
numberOfUnits
=
numberOfSubBatchUnits
,
parentBatch
=
activeEntity
)
#create the sub-batch
parentBatch
=
activeEntity
)
#create the sub-batch
self
.
outputTrace
(
subBatch
.
name
,
'was created from '
+
activeEntity
.
name
)
self
.
outputTrace
(
subBatch
.
name
,
'was created from '
+
activeEntity
.
name
)
#===================================================================
# TESTING
# print now(), subBatch.name,'was created from '+ activeEntity.name
#===================================================================
G
.
EntityList
.
append
(
subBatch
)
G
.
EntityList
.
append
(
subBatch
)
activeObjectQueue
.
append
(
subBatch
)
#append the sub-batch to the active object Queue
activeObjectQueue
.
append
(
subBatch
)
#append the sub-batch to the active object Queue
activeEntity
.
subBatchList
.
append
(
subBatch
)
activeEntity
.
subBatchList
.
append
(
subBatch
)
...
@@ -129,7 +185,8 @@ class BatchDecomposition(CoreObject):
...
@@ -129,7 +185,8 @@ class BatchDecomposition(CoreObject):
if
activeEntity
in
G
.
pendingEntities
:
if
activeEntity
in
G
.
pendingEntities
:
G
.
pendingEntities
.
append
(
subBatch
)
G
.
pendingEntities
.
append
(
subBatch
)
G
.
pendingEntities
.
remove
(
activeEntity
)
G
.
pendingEntities
.
remove
(
activeEntity
)
activeEntity
.
numberOfSubBatches
=
self
.
numberOfSubBatches
# print now(),'*'*10
activeEntity
.
numberOfSubBatches
=
self
.
numberOfSubBatches
self
.
timeLastEntityEnded
=
now
()
self
.
timeLastEntityEnded
=
now
()
# =======================================================================
# =======================================================================
...
@@ -138,13 +195,13 @@ class BatchDecomposition(CoreObject):
...
@@ -138,13 +195,13 @@ class BatchDecomposition(CoreObject):
def
canAccept
(
self
,
callerObject
=
None
):
def
canAccept
(
self
,
callerObject
=
None
):
activeObject
=
self
.
getActiveObject
()
activeObject
=
self
.
getActiveObject
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
giverObject
=
self
.
getGiverObject
()
#
giverObject=self.getGiverObject()
if
(
len
(
activeObject
.
previous
)
==
1
or
callerObject
==
None
):
if
(
len
(
activeObject
.
previous
)
==
1
or
callerObject
==
None
):
return
activeObject
.
Up
and
len
(
activeObjectQueue
)
==
0
return
activeObject
.
Up
and
len
(
activeObjectQueue
)
==
0
thecaller
=
callerObject
thecaller
=
callerObject
# return True ONLY if the length of the activeOjbectQue is smaller than
# return True ONLY if the length of the activeOjbectQue is smaller than
# the object capacity, and the callerObject is not None but the giverObject
# the object capacity, and the callerObject is not None but the giverObject
return
len
(
activeObjectQueue
)
==
0
and
(
thecaller
is
giverObject
)
return
activeObject
.
Up
and
len
(
activeObjectQueue
)
==
0
and
(
thecaller
in
activeObject
.
previous
)
# =======================================================================
# =======================================================================
# haveToDispose logic
# haveToDispose logic
...
@@ -153,27 +210,34 @@ class BatchDecomposition(CoreObject):
...
@@ -153,27 +210,34 @@ class BatchDecomposition(CoreObject):
# get active and the receiver object
# get active and the receiver object
activeObject
=
self
.
getActiveObject
()
activeObject
=
self
.
getActiveObject
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
receiverObject
=
activeObject
.
getReceiverObject
()
#
receiverObject=activeObject.getReceiverObject()
#if we have only one successor just check if object waits to dispose and also is up
#if we have only one successor just check if object waits to dispose and also is up
# this is done to achieve better (cpu) processing time
# this is done to achieve better (cpu) processing time
if
(
len
(
activeObject
.
next
)
==
1
or
callerObject
==
None
):
if
(
len
(
activeObject
.
next
)
==
1
or
callerObject
==
None
):
return
len
(
activeObjectQueue
)
>
0
and
activeObjectQueue
[
0
].
type
!=
"Batch"
# #===================================================================
# # TESTING
# print now(), self.id,
# print ' ', len(activeObjectQueue)
# if activeObjectQueue:
# print ' ', activeObjectQueue[0].type
# #===================================================================
return
len
(
activeObjectQueue
)
>
0
and
activeObjectQueue
[
0
].
type
!=
"Batch"
and
activeObject
.
Up
thecaller
=
callerObject
thecaller
=
callerObject
#give the entity to the successor that is waiting for the most time.
#
#give the entity to the successor that is waiting for the most time.
#plant does not do this in every occasion!
#
#plant does not do this in every occasion!
maxTimeWaiting
=
0
#
maxTimeWaiting=0
for
object
in
activeObject
.
next
:
#
for object in activeObject.next:
if
(
object
.
canAccept
()):
# if the object can accept
#
if(object.canAccept()): # if the object can accept
timeWaiting
=
now
()
-
object
.
timeLastEntityLeft
# compare the time that it has been waiting
#
timeWaiting=now()-object.timeLastEntityLeft # compare the time that it has been waiting
if
(
timeWaiting
>
maxTimeWaiting
or
maxTimeWaiting
==
0
):
# with the others'
#
if(timeWaiting>maxTimeWaiting or maxTimeWaiting==0):# with the others'
maxTimeWaiting
=
timeWaiting
#
maxTimeWaiting=timeWaiting
self
.
receiver
=
object
# and update the successorIndex to the index of this object
#
self.receiver=object # and update the successorIndex to the index of this object
#
#return true only to the predecessor from which the queue will take
#
#return true only to the predecessor from which the queue will take
receiverObject
=
activeObject
.
getReceiverObject
()
#
receiverObject=activeObject.getReceiverObject()
return
len
(
self
.
Res
.
activeQ
)
==
self
.
numberOfSubBatches
and
\
return
len
(
activeObjectQueue
)
==
self
.
numberOfSubBatches
and
\
(
thecaller
i
s
receiverObject
)
and
activeObjectQueue
[
0
].
type
!=
"Batch"
(
thecaller
i
n
activeObject
.
next
)
and
activeObjectQueue
[
0
].
type
!=
"Batch"
and
activeObject
.
Up
# =======================================================================
# =======================================================================
# canAcceptAndIsRequested logc
# canAcceptAndIsRequested logc
...
@@ -184,24 +248,25 @@ class BatchDecomposition(CoreObject):
...
@@ -184,24 +248,25 @@ class BatchDecomposition(CoreObject):
activeObjectQueue
=
self
.
getActiveObjectQueue
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
giverObject
=
self
.
getGiverObject
()
giverObject
=
self
.
getGiverObject
()
#if we have only one predecessor just check if there is a place available and the predecessor has an entity to dispose
# #if we have only one predecessor just check if there is a place available and the predecessor has an entity to dispose
if
(
len
(
activeObject
.
previous
)
==
1
):
# if(len(activeObject.previous)==1):
return
self
.
canAccept
()
and
giverObject
.
haveToDispose
(
activeObject
)
# return self.canAccept() and giverObject.haveToDispose(activeObject)
#
isRequested
=
False
# dummy boolean variable to check if any predecessor has something to hand in
# isRequested=False # dummy boolean variable to check if any predecessor has something to hand in
maxTimeWaiting
=
0
# dummy timer to check which predecessor has been waiting the most
# maxTimeWaiting=0 # dummy timer to check which predecessor has been waiting the most
#
#loop through the predecessors to see which have to dispose and which is the one blocked for longer
# #loop through the predecessors to see which have to dispose and which is the one blocked for longer
for
object
in
activeObject
.
previous
:
# for object in activeObject.previous:
if
(
object
.
haveToDispose
(
activeObject
)):
# if they have something to dispose off
# if(object.haveToDispose(activeObject)): # if they have something to dispose off
isRequested
=
True
# then the Queue is requested to handle the entity
# isRequested=True # then the Queue is requested to handle the entity
if
(
object
.
downTimeInTryingToReleaseCurrentEntity
>
0
):
# if the predecessor has failed wile waiting
# if(object.downTimeInTryingToReleaseCurrentEntity>0):# if the predecessor has failed wile waiting
timeWaiting
=
now
()
-
object
.
timeLastFailureEnded
# then update according the timeWaiting to be compared with the ones
# timeWaiting=now()-object.timeLastFailureEnded # then update according the timeWaiting to be compared with the ones
else
:
# of the other machines
# else: # of the other machines
timeWaiting
=
now
()
-
object
.
timeLastEntityEnded
# timeWaiting=now()-object.timeLastEntityEnded
#
#if more than one predecessor have to dispose take the part from the one that is blocked longer
# #if more than one predecessor have to dispose take the part from the one that is blocked longer
if
(
timeWaiting
>=
maxTimeWaiting
):
# if(timeWaiting>=maxTimeWaiting):
activeObject
.
giver
=
object
# activeObject.giver=object
maxTimeWaiting
=
timeWaiting
# maxTimeWaiting=timeWaiting
return
self
.
canAccept
(
self
)
and
isRequested
# return true when the Queue is not fully occupied and a predecessor is requesting it
# return self.canAccept(self) and isRequested # return true when the Queue is not fully occupied and a predecessor is requesting it
return
activeObject
.
Up
and
len
(
activeObjectQueue
)
==
0
and
giverObject
.
haveToDispose
(
activeObject
)
dream/simulation/BatchReassembly.py
View file @
74f11f24
...
@@ -26,7 +26,7 @@ BatchReassembly is a Core Object that takes a number of subBatches and reassembl
...
@@ -26,7 +26,7 @@ BatchReassembly is a Core Object that takes a number of subBatches and reassembl
'''
'''
from
SimPy.Simulation
import
Process
,
Resource
from
SimPy.Simulation
import
Process
,
Resource
from
SimPy.Simulation
import
activate
,
waituntil
,
now
,
hold
from
SimPy.Simulation
import
activate
,
waituntil
,
now
,
hold
,
waitevent
from
Globals
import
G
from
Globals
import
G
...
@@ -66,8 +66,8 @@ class BatchReassembly(CoreObject):
...
@@ -66,8 +66,8 @@ class BatchReassembly(CoreObject):
# for routing purposes
# for routing purposes
self
.
next
=
[]
#list with the next objects in the flow
self
.
next
=
[]
#list with the next objects in the flow
self
.
previous
=
[]
#list with the previous objects in the flow
self
.
previous
=
[]
#list with the previous objects in the flow
self
.
nextIds
=
[]
#list with the ids of the next objects in the flow
#
self.nextIds=[] #list with the ids of the next objects in the flow
self
.
previousIds
=
[]
#list with the ids of the previous objects in the flow
#
self.previousIds=[] #list with the ids of the previous objects in the flow
# =======================================================================
# =======================================================================
# initialize the internal resource of the object
# initialize the internal resource of the object
...
@@ -82,21 +82,49 @@ class BatchReassembly(CoreObject):
...
@@ -82,21 +82,49 @@ class BatchReassembly(CoreObject):
def
run
(
self
):
def
run
(
self
):
activeObjectQueue
=
self
.
getActiveObjectQueue
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
while
1
:
while
1
:
yield
waituntil
,
self
,
self
.
canAcceptAndIsRequested
#wait until the Queue can accept an entity
while
1
:
#and one predecessor requests it
yield
waitevent
,
self
,
[
self
.
isRequested
,
self
.
interruptionStart
]
self
.
getEntity
()
if
self
.
interruptionStart
.
signalparam
==
now
():
yield
waitevent
,
self
,
self
.
interruptionEnd
assert
self
==
self
.
interruptionEnd
.
signalparam
,
'the victim of the failure is not the object that received the interruptionEnd event'
if
self
.
signalGiver
():
break
else
:
break
requestingObject
=
self
.
isRequested
.
signalparam
assert
requestingObject
==
self
.
giver
,
'the giver is not the requestingObject'
# self.operatorWaitTimeCurrentEntity = 0
# self.loadOperatorWaitTimeCurrentEntity = 0
# self.loadTimeCurrentEntity = 0
# self.setupTimeCurrentEntity = 0
# yield waituntil, self, self.canAcceptAndIsRequested #wait until the Queue can accept an entity
# #and one predecessor requests it
self
.
currentEntity
=
self
.
getEntity
()
# self.outputTrace("got into "+self.objName)
# self.outputTrace("got into "+self.objName)
# set the currentEntity as the Entity just received and initialize the timer timeLastEntityEntered
# set the currentEntity as the Entity just received and initialize the timer timeLastEntityEntered
self
.
currentEntity
=
self
.
getActiveObjectQueue
()[
0
]
# entity is the current entity processed in object
#
self.currentEntity=self.getActiveObjectQueue()[0] # entity is the current entity processed in object
self
.
nameLastEntityEntered
=
self
.
currentEntity
.
name
# this holds the name of the last entity that got into Machine
self
.
nameLastEntityEntered
=
self
.
currentEntity
.
name
# this holds the name of the last entity that got into Machine
self
.
timeLastEntityEntered
=
now
()
#this holds the last time that an entity got into Machine
self
.
timeLastEntityEntered
=
now
()
#this holds the last time that an entity got into Machine
# self.tinM=self.totalProcessingTimeInCurrentEntity # timer to hold the processing time left
if
len
(
self
.
getActiveObjectQueue
())
==
self
.
numberOfSubBatches
and
self
.
currentEntity
.
type
!=
'Batch'
:
if
len
(
self
.
getActiveObjectQueue
())
==
self
.
numberOfSubBatches
and
self
.
currentEntity
.
type
!=
'Batch'
:
yield
hold
,
self
,
self
.
calculateProcessingTime
()
yield
hold
,
self
,
self
.
calculateProcessingTime
()
self
.
reassemble
()
self
.
reassemble
()
if
not
self
.
signalReceiver
():
while
1
:
event
=
yield
waitevent
,
self
,
[
self
.
canDispose
,
self
.
interruptiontStart
]
if
self
.
interruptionStart
.
signalparam
==
now
():
yield
waitevent
,
self
,
self
.
interruptionEnd
assert
self
==
self
.
interruptionEnd
.
signalparam
if
self
.
signalReceiver
():
break
# =======================================================================
# =======================================================================
# reassemble method that assembles the subBatches back together to a Batch
# reassemble method that assembles the subBatches back together to a Batch
...
@@ -143,27 +171,29 @@ class BatchReassembly(CoreObject):
...
@@ -143,27 +171,29 @@ class BatchReassembly(CoreObject):
def
canAccept
(
self
,
callerObject
=
None
):
def
canAccept
(
self
,
callerObject
=
None
):
activeObject
=
self
.
getActiveObject
()
activeObject
=
self
.
getActiveObject
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
giverObject
=
self
.
getGiverObject
()
# giverObject=self.getGiverObject()
giverObjectQueue
=
self
.
getGiverObjectQueue
()
# giverObjectQueue = self.getGiverObjectQueue()
if
len
(
activeObject
.
previous
)
!=
1
:
assert
callerObject
!=
None
,
'the callerObject cannot be None for canAccept of BatchReassembly'
if
(
len
(
activeObject
.
previous
)
==
1
or
callerObject
==
None
):
if
(
len
(
activeObject
.
previous
)
==
1
):
if
len
(
activeObjectQueue
)
==
0
:
if
len
(
activeObjectQueue
)
==
0
:
return
activeObject
.
Up
return
activeObject
.
Up
elif
len
(
giverObjectQueue
)
==
0
:
elif
len
(
activeObject
.
previous
[
0
].
getActiveObjectQueue
()
)
==
0
:
return
False
return
False
else
:
else
:
return
activeObject
.
Up
\
return
activeObject
.
Up
\
and
activeObjectQueue
[
0
].
type
!=
'Batch'
\
and
activeObjectQueue
[
0
].
type
!=
'Batch'
\
and
len
(
activeObjectQueue
)
<
self
.
numberOfSubBatches
\
and
len
(
activeObjectQueue
)
<
self
.
numberOfSubBatches
\
and
giverObjectQueue
[
0
].
batchId
==
activeObjectQueue
[
0
].
batchId
and
activeObject
.
previous
[
0
].
getActiveObjectQueue
()
[
0
].
batchId
==
activeObjectQueue
[
0
].
batchId
thecaller
=
callerObject
thecaller
=
callerObject
# return True ONLY if the length of the activeOjbectQueue is smaller than
# return True ONLY if the length of the activeOjbectQueue is smaller than
# the object capacity, and the callerObject is not None but the giverObject
# the object capacity, and the callerObject is not None but the giverObject
return
len
(
activeObjectQueue
)
<
self
.
numberOfSubBatches
\
return
len
(
activeObjectQueue
)
<
self
.
numberOfSubBatches
\
and
(
thecaller
i
s
giverObject
)
\
and
(
thecaller
i
n
activeObject
.
previous
)
\
and
activeObjectQueue
[
0
].
type
!=
'Batch'
\
and
activeObjectQueue
[
0
].
type
!=
'Batch'
\
and
giverObjectQueue
[
0
].
batchId
==
activeObjectQueue
[
0
].
batchId
and
thecaller
.
getActiveObjectQueue
()
[
0
].
batchId
==
activeObjectQueue
[
0
].
batchId
# =======================================================================
# =======================================================================
# returns True if it holds an entity of type Batch
# returns True if it holds an entity of type Batch
...
@@ -172,7 +202,7 @@ class BatchReassembly(CoreObject):
...
@@ -172,7 +202,7 @@ class BatchReassembly(CoreObject):
# get active and the receiver object
# get active and the receiver object
activeObject
=
self
.
getActiveObject
()
activeObject
=
self
.
getActiveObject
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
receiverObject
=
activeObject
.
getReceiverObject
()
# receiverObject=activeObject.getReceiverObject()
#if we have only one successor just check if object waits to dispose and also is up
#if we have only one successor just check if object waits to dispose and also is up
# this is done to achieve better (cpu) processing time
# this is done to achieve better (cpu) processing time
if
(
len
(
activeObject
.
next
)
==
1
or
callerObject
==
None
):
if
(
len
(
activeObject
.
next
)
==
1
or
callerObject
==
None
):
...
@@ -180,20 +210,20 @@ class BatchReassembly(CoreObject):
...
@@ -180,20 +210,20 @@ class BatchReassembly(CoreObject):
and
activeObjectQueue
[
0
].
type
==
"Batch"
# the control of the length of the queue is not needed
and
activeObjectQueue
[
0
].
type
==
"Batch"
# the control of the length of the queue is not needed
thecaller
=
callerObject
thecaller
=
callerObject
#give the entity to the receiver that is waiting for the most time.
#
#give the entity to the receiver that is waiting for the most time.
#plant does not do this in every occasion!
#
#plant does not do this in every occasion!
maxTimeWaiting
=
0
#
maxTimeWaiting=0
for
object
in
activeObject
.
next
:
#
for object in activeObject.next:
if
(
object
.
canAccept
()):
# if the object can accept
#
if(object.canAccept()): # if the object can accept
timeWaiting
=
now
()
-
object
.
timeLastEntityLeft
# compare the time that it has been waiting
#
timeWaiting=now()-object.timeLastEntityLeft # compare the time that it has been waiting
if
(
timeWaiting
>
maxTimeWaiting
or
maxTimeWaiting
==
0
):
# with the others'
#
if(timeWaiting>maxTimeWaiting or maxTimeWaiting==0):# with the others'
maxTimeWaiting
=
timeWaiting
#
maxTimeWaiting=timeWaiting
self
.
receiver
=
object
# and update the successorIndex to the index of this object
#
self.receiver=object # and update the successorIndex to the index of this object
#
#return true only to the predecessor from which the queue will take
#
#return true only to the predecessor from which the queue will take
receiverObject
=
activeObject
.
getReceiverObject
()
#
receiverObject=activeObject.getReceiverObject()
return
len
(
self
.
getActiveObject
ueue
)
==
1
\
return
len
(
activeObjectQ
ueue
)
==
1
\
and
(
thecaller
i
s
receiverObjec
t
)
\
and
(
thecaller
i
n
activeObject
.
nex
t
)
\
and
activeObjectQueue
[
0
].
type
!=
"Batch"
# the control of the length of the queue is not needed
and
activeObjectQueue
[
0
].
type
!=
"Batch"
# the control of the length of the queue is not needed
# =======================================================================
# =======================================================================
...
@@ -207,35 +237,39 @@ class BatchReassembly(CoreObject):
...
@@ -207,35 +237,39 @@ class BatchReassembly(CoreObject):
activeObjectQueue
=
self
.
getActiveObjectQueue
()
activeObjectQueue
=
self
.
getActiveObjectQueue
()
giverObject
=
self
.
getGiverObject
()
giverObject
=
self
.
getGiverObject
()
giverObjectQueue
=
self
.
getGiverObjectQueue
()
giverObjectQueue
=
self
.
getGiverObjectQueue
()
#if we have only one predecessor just check if there is a place available and the predecessor has an entity to dispose
#
#if we have only one predecessor just check if there is a place available and the predecessor has an entity to dispose
if
(
len
(
activeObject
.
previous
)
==
1
):
#
if(len(activeObject.previous)==1):
if
len
(
activeObjectQueue
)
==
0
:
#
if len(activeObjectQueue)==0:
return
activeObject
.
Up
and
giverObject
.
haveToDispose
(
activeObject
)
#
return activeObject.Up and giverObject.haveToDispose(activeObject)
else
:
#
else:
return
activeObject
.
Up
and
giverObject
.
haveToDispose
(
activeObject
)
\
#
return activeObject.Up and giverObject.haveToDispose(activeObject)\
and
activeObjectQueue
[
0
].
type
!=
'Batch'
\
#
and activeObjectQueue[0].type!='Batch'\
and
len
(
activeObjectQueue
)
<
self
.
numberOfSubBatches
\
#
and len(activeObjectQueue)<self.numberOfSubBatches\
and
giverObjectQueue
[
0
].
batchId
==
activeObjectQueue
[
0
].
batchId
#
and giverObjectQueue[0].batchId==activeObjectQueue[0].batchId
#
isRequested
=
False
# dummy boolean variable to check if any predecessor has something to hand in
#
isRequested=False # dummy boolean variable to check if any predecessor has something to hand in
maxTimeWaiting
=
0
# dummy timer to check which predecessor has been waiting the most
#
maxTimeWaiting=0 # dummy timer to check which predecessor has been waiting the most
#
#loop through the predecessors to see which have to dispose and which is the one blocked for longer # loop through all the predecessors
#
#loop through the predecessors to see which have to dispose and which is the one blocked for longer # loop through all the predecessors
for
object
in
activeObject
.
previous
:
#
for object in activeObject.previous:
if
(
object
.
haveToDispose
(
activeObject
)):
# if they have something to dispose off
#
if(object.haveToDispose(activeObject)): # if they have something to dispose off
isRequested
=
True
# then the Queue is requested to handle the entity
#
isRequested=True # then the Queue is requested to handle the entity
if
(
object
.
downTimeInTryingToReleaseCurrentEntity
>
0
):
# if the predecessor has failed wile waiting
#
if(object.downTimeInTryingToReleaseCurrentEntity>0):# if the predecessor has failed wile waiting
timeWaiting
=
now
()
-
object
.
timeLastFailureEnded
# then update according the timeWaiting to be compared with the ones
#
timeWaiting=now()-object.timeLastFailureEnded # then update according the timeWaiting to be compared with the ones
else
:
# of the other machines
#
else: # of the other machines
timeWaiting
=
now
()
-
object
.
timeLastEntityEnded
#
timeWaiting=now()-object.timeLastEntityEnded
#
#if more than one predecessor have to dispose take the part from the one that is blocked longer
#
#if more than one predecessor have to dispose take the part from the one that is blocked longer
if
(
timeWaiting
>=
maxTimeWaiting
):
# if(timeWaiting>=maxTimeWaiting):
activeObject
.
giver
=
object
# activeObject.giver=object
maxTimeWaiting
=
timeWaiting
# maxTimeWaiting=timeWaiting
return
isRequested
\
#
return isRequested\
and
activeObject
.
Up
\
#
and activeObject.Up\
and
len
(
activeObjectQueue
<
self
.
numberOfSubBatches
)
\
# and len(activeObjectQueue)<self.numberOfSubBatches
\
and
(
len
(
activeObjectQueue
)
==
0
or
activeObjectQueue
[
0
].
type
!=
'Batch'
)
\
#
and (len(activeObjectQueue)==0 or activeObjectQueue[0].type!='Batch')\
and
activeObject
.
getGiverObjectQueue
()[
0
].
batchId
==
activeObjectQueue
[
0
].
batchId
#
and activeObject.getGiverObjectQueue()[0].batchId==activeObjectQueue[0].batchId
# return true when the Queue is not fully occupied and a predecessor is requesting it
# return true when the Queue is not fully occupied and a predecessor is requesting it
return
activeObject
.
Up
and
giverObject
.
haveToDispose
(
activeObject
)
\
and
len
(
activeObjectQueue
)
<
activeObject
.
numberOfSubBatches
\
and
(
len
(
activeObjectQueue
)
==
0
or
activeObjectQueue
[
0
].
type
!=
'Batch'
)
\
and
giverObjectQueue
[
0
].
batchId
==
activeObjectQueue
[
0
].
batchId
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment