Operator inherits directly from ObjectResource

parent 27ae92ec
...@@ -59,10 +59,10 @@ class Operator(ObjectResource): ...@@ -59,10 +59,10 @@ class Operator(ObjectResource):
self.multipleCriterionList=SRlist # hold the criteria list in the property multipleCriterionList self.multipleCriterionList=SRlist # hold the criteria list in the property multipleCriterionList
for scheduling_rule in SRlist: for scheduling_rule in SRlist:
if scheduling_rule not in ("FIFO", "Priority","WT", "EDD", "EOD", if scheduling_rule not in self.getSupportedSchedulingRules():
"NumStages", "RPC", "LPT", "SPT", "MS", "WINQ"):
raise ValueError("Unknown scheduling rule %s for %s" % raise ValueError("Unknown scheduling rule %s for %s" %
(scheduling_rule, id)) (scheduling_rule, id))
# the station that the operator is assigned to # the station that the operator is assigned to
self.operatorAssignedTo=None self.operatorAssignedTo=None
...@@ -70,28 +70,33 @@ class Operator(ObjectResource): ...@@ -70,28 +70,33 @@ class Operator(ObjectResource):
self.candidateEntities=[] # list of the entities requesting the operator at a certain simulation Time self.candidateEntities=[] # list of the entities requesting the operator at a certain simulation Time
self.candidateEntity=None # the entity that will be chosen for processing self.candidateEntity=None # the entity that will be chosen for processing
@staticmethod
def getSupportedSchedulingRules():
return ("FIFO", "Priority", "WT", "EDD", "EOD",
"NumStages", "RPC", "LPT", "SPT", "MS", "WINQ")
# ======================================================================= # =======================================================================
# sorts the candidateEntities of the Operator according to the scheduling rule # sorts the candidateEntities of the Operator according to the scheduling rule
# TODO: clean the comments
# TODO: maybe the argument is not needed. the candidate entities is a variable of the object
# ======================================================================= # =======================================================================
def sortCandidateEntities(self): def sortCandidateEntities(self):
# TODO: have to consider what happens in case of a critical order
#if we have sorting according to multiple criteria we have to call the sorter many times
if self.schedulingRule=="MC":
for criterion in reversed(self.multipleCriterionList):
self.activeCandidateQSorter(criterion=criterion)
#else we just use the default scheduling rule
else:
self.activeCandidateQSorter(self.schedulingRule)
# =======================================================================
# sorts the Entities of the Queue according to the scheduling rule
# =======================================================================
def activeCandidateQSorter(self, criterion=None):
pass pass
# # TODO: have to consider what happens in case of a critical order
# # FIFO sorting has no meaning when sorting candidateEntities
# if self.schedulingRule=="FIFO":
# self.activeCandidateQSorter('WT', candidateEntities=candidateEntities)
# #if we have sorting according to multiple criteria we have to call the sorter many times
# elif self.schedulingRule=="MC":
# for criterion in reversed(self.multipleCriterionList):
# self.activeCandidateQSorter(criterion=criterion, candidateEntities=candidateEntities)
# #else we just use the default scheduling rule
# else:
# self.activeCandidateQSorter(self.schedulingRule, candidateEntities=candidateEntities)
# ======================================================================= # =======================================================================
# sorts the activeCallerrs of the Operator according to the scheduling rule # sorts the activeCallerrs of the Operator according to the scheduling rule
# TODO: change the name of the class (they are not entities)
# ======================================================================= # =======================================================================
def sortActiveCallers(self): def sortActiveCallers(self):
#if we have sorting according to multiple criteria we have to call the sorter many times #if we have sorting according to multiple criteria we have to call the sorter many times
......
...@@ -67,19 +67,19 @@ class OperatorManagedJob(Operator): ...@@ -67,19 +67,19 @@ class OperatorManagedJob(Operator):
# return False # return False
return len(self.Res.activeQ)<self.capacity return len(self.Res.activeQ)<self.capacity
# ======================================================================= # # =======================================================================
# sorts the candidateEntities of the Operator according to the scheduling rule # # sorts the candidateEntities of the Operator according to the scheduling rule
# TODO: maybe the argument is not needed. the candidate entities is a variable of the object # # TODO: maybe the argument is not needed. the candidate entities is a variable of the object
# ======================================================================= # # =======================================================================
def sortCandidateEntities(self): # def sortCandidateEntities(self):
# TODO: have to consider what happens in case of a critical order # # TODO: have to consider what happens in case of a critical order
#if we have sorting according to multiple criteria we have to call the sorter many times # #if we have sorting according to multiple criteria we have to call the sorter many times
if self.schedulingRule=="MC": # if self.schedulingRule=="MC":
for criterion in reversed(self.multipleCriterionList): # for criterion in reversed(self.multipleCriterionList):
self.activeCandidateQSorter(criterion=criterion) # self.activeCandidateQSorter(criterion=criterion)
#else we just use the default scheduling rule # #else we just use the default scheduling rule
else: # else:
self.activeCandidateQSorter(self.schedulingRule) # self.activeCandidateQSorter(self.schedulingRule)
# ======================================================================= # =======================================================================
# sorts the Entities of the Queue according to the scheduling rule # sorts the Entities of the Queue according to the scheduling rule
......
...@@ -40,6 +40,8 @@ class Router(ObjectInterruption): ...@@ -40,6 +40,8 @@ class Router(ObjectInterruption):
# according to this implementation one machine per broker is allowed # according to this implementation one machine per broker is allowed
# The Broker is initiated within the Machine and considered as # The Broker is initiated within the Machine and considered as
# black box for the ManPy end Developer # black box for the ManPy end Developer
# TODO: we should maybe define a global schedulingRule criterion that will be
# chosen in case of multiple criteria for different Operators
# ======================================================================= # =======================================================================
def __init__(self): def __init__(self):
ObjectInterruption.__init__(self) ObjectInterruption.__init__(self)
...@@ -83,119 +85,45 @@ class Router(ObjectInterruption): ...@@ -83,119 +85,45 @@ class Router(ObjectInterruption):
# wait until the router is called # wait until the router is called
yield waitevent, self, self.startCycle yield waitevent, self, self.startCycle
self.victim=findObjectById(self.startCycle.signalparam) self.victim=findObjectById(self.startCycle.signalparam)
# yield waituntil,self,self.isCalled # yield waituntil,self,self.isCalled
# when the router is called for the first time wait till all the entities # when the router is called for the first time wait till all the entities
# finished all their moves in stations of non-Machine-type # finished all their moves in stations of non-Machine-type
# before they can enter again a type-Machine object # before they can enter again a type-Machine object
yield waituntil, self,self.entitiesFinishedMoving yield waituntil, self,self.entitiesFinishedMoving
# update the objects to be served list (pendingObjects) # update the objects to be served list (pendingObjects)
self.pendingObjects=[object for object in G.MachineList if object.inPositionToGet] self.pendingObjects=[object for object in G.MachineList if object.inPositionToGet]
#===================================================================
# # TESTING
# print now(), '================================================================================'
# print ' the pending objects are ', [str(object.id) for object in self.pendingObjects]
#===================================================================
# update the calledOperators list # update the calledOperators list
self.calledOperators=[operator for operator in G.OperatorsList if len(operator.activeCallersList)] self.calledOperators=[operator for operator in G.OperatorsList if len(operator.activeCallersList)]
#===================================================================
# # TESTING
# print ' (calledOperators, activeCallers, callerEntities): ', [(str(operator.id),\
# [str(x.id) for x in operator.activeCallersList],\
# [str(x.giver.getActiveObjectQueue()[0].id)for x in operator.activeCallersList])\
# for operator in self.calledOperators]
#===================================================================
# find the operators that can start working now even if they are not called # find the operators that can start working now even if they are not called
self.findCandidateOperators() self.findCandidateOperators()
#===================================================================
# # TESTING
# print ' {} the candidateOperators ',
# print [str(op.id) for op in self.candidateOperators]
# print [str(entity.id) for entity in G.pendingEntities]
#===================================================================
# sort the pendingEntities list # sort the pendingEntities list
self.sortPendingEntities() self.sortPendingEntities()
#===================================================================
# # TESTING
# print [str(entity.id) for entity in G.pendingEntities]
# if G.pendingEntities:
# print ' {} the pending entities that can proceed are: ',
# print [str(entity.id) for entity in G.pendingEntities if entity.canProceed]
#===================================================================
# find the operators candidateEntities # find the operators candidateEntities
self.findCandidateEntities() self.findCandidateEntities()
#===================================================================
# # TESTING
# print ' {} candidate entities for each candidateOperator ',
# print [(str(operator.id),[str(candidateEntity.id) for candidateEntity in operator.candidateEntities],)\
# for operator in self.candidateOperators]
#===================================================================
# find the entity that will occupy the resource, and the station that will receive it (if any available) # find the entity that will occupy the resource, and the station that will receive it (if any available)
self.findCandidateReceivers() self.findCandidateReceivers()
#===================================================================
# # TESTING
# print ' {} (candidateOperator, candidateEntity, candidateReceiver) ',
# print [(str(op.id), str(op.candidateEntity.id), str(op.candidateEntity.candidateReceiver.id))\
# for op in self.candidateOperators if op.candidateEntity.candidateReceiver]
#===================================================================
# sort the givers for the operators that will process the entities # sort the givers for the operators that will process the entities
self.sortGiverQueue() self.sortGiverQueue()
# for all the operators that are requested # for all the operators that are requested
for operator in self.calledOperators: for operator in self.calledOperators:
priorityObject=None priorityObject=None
# check if the candidateReceivers are inPositionToGet and if they are already called # check if the candidateReceivers are inPositionToGet and if they are already called
try: try:
receiverIsActive=(operator.candidateEntity.candidateReceiver in operator.activeCallersList\ receiverIsActive=(operator.candidateEntity.candidateReceiver in operator.activeCallersList\
and operator.candidateEntity.candidateReceiver in self.pendingObjects ) and operator.candidateEntity.candidateReceiver in self.pendingObjects )
except: except:
receiverIsActive=True receiverIsActive=True
#===============================================================
# # TESTING
# print ' calledOperator', operator.id,
# print 'will receive?',operator.checkIfResourceIsAvailable() and receiverIsActive
#===============================================================
# check if the candidateOperators are available, if the are requested and reside in the pendingObjects list # check if the candidateOperators are available, if the are requested and reside in the pendingObjects list
if operator.checkIfResourceIsAvailable() and \ if operator.checkIfResourceIsAvailable() and \
receiverIsActive: receiverIsActive:
# sort the activeCallersList of the operator # sort the activeCallersList of the operator
operator.sortActiveCallers() operator.sortActiveCallers()
# find the activeCaller that has priority # find the activeCaller that has priority
priorityObject=next(x for x in operator.activeCallersList if x in self.pendingObjects) priorityObject=next(x for x in operator.activeCallersList if x in self.pendingObjects)
#===========================================================
# # TESTING
# print [str(caller.id) for caller in operator.activeCallersList]
# print ' the PRIORITY object is', priorityObject.id
#===========================================================
# and if the priorityObject is indeed pending # and if the priorityObject is indeed pending
if priorityObject in self.pendingObjects: if priorityObject in self.pendingObjects:
# assign an operator to the priorityObject # assign an operator to the priorityObject
operator.operatorAssignedTo=priorityObject operator.operatorAssignedTo=priorityObject
#=======================================================
# # TESTING
# print operator.id, 'got assigned to', priorityObject.id
#=======================================================
# and let it proceed withGetEntity # and let it proceed withGetEntity
priorityObject.canProceedWithGetEntity=True priorityObject.canProceedWithGetEntity=True
priorityObject.inPositionToGet=False priorityObject.inPositionToGet=False
...@@ -206,12 +134,6 @@ class Router(ObjectInterruption): ...@@ -206,12 +134,6 @@ class Router(ObjectInterruption):
for object in self.pendingObjects: for object in self.pendingObjects:
if not object.canProceedWithGetEntity: if not object.canProceedWithGetEntity:
object.giver.unAssignExit() object.giver.unAssignExit()
#===================================================================
# # TESTING
# print ' these objects will proceed with getting entities',
# print [str(object.id) for object in self.pendingObjects if object.canProceedWithGetEntity]
#===================================================================
self.exit() self.exit()
#=========================================================================== #===========================================================================
......
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