Commit 11b82263 authored by Ioannis Papagiannopoulos's avatar Ioannis Papagiannopoulos Committed by Georgios Dagkakis

activeQsorter of operator correction

parent 78696dec
...@@ -150,16 +150,6 @@ class Operator(ObjectResource): ...@@ -150,16 +150,6 @@ class Operator(ObjectResource):
machine.timeWaiting=self.env.now-machine.broker.timeWaitForOperatorStarted machine.timeWaiting=self.env.now-machine.broker.timeWaitForOperatorStarted
else: else:
machine.timeWaiting=self.env.now-machine.timeLastEntityLeft machine.timeWaiting=self.env.now-machine.timeLastEntityLeft
# find the stations that hold or are about to be delivered critical entities
if self in router.preemptiveOperators:
for entity in machine.getActiveObjectQueue():
if entity in router.pending and entity.isCritical:
machine.critical=True
break
for previous in machine.previous:
for entity in previous.getActiveObjectQueue():
if entity in router.pending and entity.isCritical:
machine.critical=True
# sort the stations according their timeWaiting # sort the stations according their timeWaiting
self.candidateStations.sort(key= lambda x: x.timeWaiting, reverse=True) self.candidateStations.sort(key= lambda x: x.timeWaiting, reverse=True)
...@@ -173,7 +163,6 @@ class Operator(ObjectResource): ...@@ -173,7 +163,6 @@ class Operator(ObjectResource):
self.activeQSorter(criterion=criterion) self.activeQSorter(criterion=criterion)
#else we just use the default scheduling rule #else we just use the default scheduling rule
else: else:
print self.schedulingRule
self.activeQSorter(self.schedulingRule) self.activeQSorter(self.schedulingRule)
# ======================================================================= # =======================================================================
...@@ -214,12 +203,13 @@ class Operator(ObjectResource): ...@@ -214,12 +203,13 @@ class Operator(ObjectResource):
# ======================================================================= # =======================================================================
def activeQSorter(self, criterion=None): def activeQSorter(self, criterion=None):
activeObjectQ=self.candidateEntities activeObjectQ=self.candidateEntities
if criterion==None: if criterion==None:
criterion=self.schedulingRule criterion=self.schedulingRule
#if the schedulingRule is first in first out #if the schedulingRule is first in first out
if criterion=="FIFO": if criterion=="FIFO":
# FIFO sorting has no meaning when sorting candidateEntities # FIFO sorting has no meaning when sorting candidateEntities
self.activeCandidateQSorter('WT') self.activeQSorter('WT')
#if the schedulingRule is based on a pre-defined priority #if the schedulingRule is based on a pre-defined priority
elif criterion=="Priority": elif criterion=="Priority":
...@@ -227,7 +217,12 @@ class Operator(ObjectResource): ...@@ -227,7 +217,12 @@ class Operator(ObjectResource):
#if the scheduling rule is time waiting (time waiting of machine) #if the scheduling rule is time waiting (time waiting of machine)
elif criterion=='WT': elif criterion=='WT':
activeObjectQ.sort(key=lambda x: x.schedule[-1][1]) for part in activeObjectQ:
part.factor=0
if part.schedule:
part.factor=self.env.now-part.schedule[-1][1]
activeObjectQ.sort(key=lambda x: x.factor, reverse=True)
#if the schedulingRule is earliest due date #if the schedulingRule is earliest due date
elif criterion=="EDD": elif criterion=="EDD":
......
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