Commit 17cc1987 authored by Ioannis Papagiannopoulos's avatar Ioannis Papagiannopoulos Committed by Georgios Dagkakis

cherry-pick from readWIPseperatelly. correction to preemptReceiver in CoreObject

parent 7fefcbb6
...@@ -284,7 +284,6 @@ class CoreObject(object): ...@@ -284,7 +284,6 @@ class CoreObject(object):
#=========================================================================== #===========================================================================
def preemptReceiver(self): def preemptReceiver(self):
activeObjectQueue=self.Res.users activeObjectQueue=self.Res.users
# find a critical order if any # find a critical order if any
critical=False critical=False
for entity in activeObjectQueue: for entity in activeObjectQueue:
...@@ -294,7 +293,9 @@ class CoreObject(object): ...@@ -294,7 +293,9 @@ class CoreObject(object):
break break
if critical: if critical:
# pick a receiver # pick a receiver
receiver=next(object for object in self.next if object.isPreemptive and object.checkIfActive()) receiver=None
if any(object for object in self.next if object.isPreemptive and object.checkIfActive()):
receiver=next(object for object in self.next if object.isPreemptive and object.checkIfActive())
# if there is any receiver that can be preempted check if it is operated # if there is any receiver that can be preempted check if it is operated
if receiver: if receiver:
receiverOperated=False # local variable to inform if the receiver is operated for Loading receiverOperated=False # local variable to inform if the receiver is operated for Loading
...@@ -311,22 +312,22 @@ class CoreObject(object): ...@@ -311,22 +312,22 @@ class CoreObject(object):
receiverOperated=True receiverOperated=True
except: except:
pass pass
# if the obtained Entity is critical and the receiver is preemptive and not operated # if the obtained Entity is critical and the receiver is preemptive and not operated
# in the case that the receiver is operated the preemption is performed by the operators # in the case that the receiver is operated the preemption is performed by the operators
# if the receiver is not Up then no preemption will be performed # if the receiver is not Up then no preemption will be performed
if not receiverOperated and len(receiver.Res.users)>0: if not receiverOperated and len(receiver.Res.users)>0:
#if the receiver does not hold an Entity that is also critical #if the receiver does not hold an Entity that is also critical
if not receiver.Res.users[0].isCritical: if not receiver.Res.users[0].isCritical:
receiver.shouldPreempt=True receiver.shouldPreempt=True
self.printTrace(self.id, preempt=receiver.id) self.printTrace(self.id, preempt=receiver.id)
receiver.preempt() receiver.preempt()
receiver.timeLastEntityEnded=self.env.now #required to count blockage correctly in the preemptied station receiver.timeLastEntityEnded=self.env.now #required to count blockage correctly in the preemptied station
# sort so that the critical entity is placed in front # sort so that the critical entity is placed in front
activeObjectQueue.sort(key=lambda x: x==activeEntity, reverse=True)
# if there is a critical entity and the possible receivers are operated then signal the Router
elif receiverOperated:
self.signalRouter(receiver)
activeObjectQueue.sort(key=lambda x: x==activeEntity, reverse=True) activeObjectQueue.sort(key=lambda x: x==activeEntity, reverse=True)
# if there is a critical entity and the possible receivers are operated then signal the Router
elif receiverOperated:
self.signalRouter(receiver)
activeObjectQueue.sort(key=lambda x: x==activeEntity, reverse=True)
# update wipStatList # update wipStatList
if self.gatherWipStat: if self.gatherWipStat:
self.wipStatList.append([self.env.now, len(activeObjectQueue)]) self.wipStatList.append([self.env.now, len(activeObjectQueue)])
...@@ -356,7 +357,7 @@ class CoreObject(object): ...@@ -356,7 +357,7 @@ class CoreObject(object):
# signal the successor that the object can dispose an entity # signal the successor that the object can dispose an entity
# ======================================================================= # =======================================================================
def signalReceiver(self): def signalReceiver(self):
possibleReceivers=self.findReceiversFor(self) possibleReceivers=self.findReceiversFor(self)
if possibleReceivers: if possibleReceivers:
receiver=self.selectReceiver(possibleReceivers) receiver=self.selectReceiver(possibleReceivers)
receiversGiver=self receiversGiver=self
......
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