Commit ebe3737c authored by Georgios Dagkakis's avatar Georgios Dagkakis Committed by Jérome Perrin

pred/successorIndex removed also from BatchDecomposition and BatchReassembly

parent c3dfe7ff
...@@ -162,14 +162,12 @@ class BatchDecomposition(CoreObject): ...@@ -162,14 +162,12 @@ class BatchDecomposition(CoreObject):
#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
i=0 # loop through the object in the successor list
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.successorIndex=i # and update the successorIndex to the index of this object self.receiver=object # and update the successorIndex to the index of this object
i+=1
#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()
...@@ -191,7 +189,6 @@ class BatchDecomposition(CoreObject): ...@@ -191,7 +189,6 @@ class BatchDecomposition(CoreObject):
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
i=0 # 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
...@@ -202,7 +199,6 @@ class BatchDecomposition(CoreObject): ...@@ -202,7 +199,6 @@ class BatchDecomposition(CoreObject):
#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.predecessorIndex=i activeObject.giver=object
maxTimeWaiting=timeWaiting maxTimeWaiting=timeWaiting
i+=1 # pick the predecessor waiting the more
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
...@@ -162,21 +162,19 @@ class BatchReassembly(CoreObject): ...@@ -162,21 +162,19 @@ 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 successor 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
i=0 # loop through the object in the successor list
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.successorIndex=i # and update the successorIndex to the index of this object self.receiver=object # and update the successorIndex to the index of this object
i+=1
#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)==1\ return len(self.getActiveObjectueue)==1\
and (thecaller is receiverObject)\ and (thecaller is receiverObject)\
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
...@@ -200,8 +198,7 @@ class BatchReassembly(CoreObject): ...@@ -200,8 +198,7 @@ class BatchReassembly(CoreObject):
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 # loop through all the predecessors
i=0 # 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
...@@ -212,9 +209,8 @@ class BatchReassembly(CoreObject): ...@@ -212,9 +209,8 @@ class BatchReassembly(CoreObject):
#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.predecessorIndex=i activeObject.giver=object
maxTimeWaiting=timeWaiting maxTimeWaiting=timeWaiting
i+=1 # pick the predecessor waiting the more
return isRequested\ return isRequested\
and activeObject.Up\ and activeObject.Up\
and len(activeObjectQueue<self.numberOfSubBatches)\ and len(activeObjectQueue<self.numberOfSubBatches)\
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment