Commit c148a1f1 authored by Ioannis Papagiannopoulos's avatar Ioannis Papagiannopoulos Committed by Jérome Perrin

further clean-up in Machine and OperatorRouter

parent a6e5ed93
...@@ -1110,19 +1110,6 @@ class Machine(CoreObject): ...@@ -1110,19 +1110,6 @@ class Machine(CoreObject):
def calculateLoadTime(self): def calculateLoadTime(self):
return self.loadRng.generateNumber() return self.loadRng.generateNumber()
# #===========================================================================
# # find candidate operators within the free operators
# #===========================================================================
# def findCandidateOperator(self):
# # TODO: this way no sorting is performed
# # find an available operator
# candidateOperator=self.operatorPool.findAvailableOperator()
# # append the station into its candidateStations
# if candidateOperator: # if there was an operator found append the Machine on his candidateStations
# candidateOperator.candidateStations.append(self)
# return candidateOperator
#=========================================================================== #===========================================================================
# checks whether the entity can proceed to a successor object # checks whether the entity can proceed to a successor object
#=========================================================================== #===========================================================================
......
...@@ -38,8 +38,6 @@ class Router(ObjectInterruption): ...@@ -38,8 +38,6 @@ 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,sorting=False): def __init__(self,sorting=False):
ObjectInterruption.__init__(self) ObjectInterruption.__init__(self)
...@@ -72,11 +70,9 @@ class Router(ObjectInterruption): ...@@ -72,11 +70,9 @@ class Router(ObjectInterruption):
ObjectInterruption.initialize(self) ObjectInterruption.initialize(self)
# signal used to initiate the generator of the Router # signal used to initiate the generator of the Router
self.isCalled=self.env.event() self.isCalled=self.env.event()
# list that holds all the objects that can receive # lists that hold all the objects that can receive
# self.pendingObjects=[]
self.pendingMachines=[] self.pendingMachines=[]
self.pendingQueues=[] self.pendingQueues=[]
# self.calledOperator=[]
# list of the operators that may handle a machine at the current simulation time # list of the operators that may handle a machine at the current simulation time
self.candidateOperators=[] self.candidateOperators=[]
# flag used to check if the Router is initialised # flag used to check if the Router is initialised
...@@ -106,7 +102,6 @@ class Router(ObjectInterruption): ...@@ -106,7 +102,6 @@ class Router(ObjectInterruption):
def run(self): def run(self):
while 1: while 1:
# wait until the router is called # wait until the router is called
self.expectedSignals['isCalled']=1 self.expectedSignals['isCalled']=1
yield self.isCalled yield self.isCalled
...@@ -139,6 +134,9 @@ class Router(ObjectInterruption): ...@@ -139,6 +134,9 @@ class Router(ObjectInterruption):
# exit actions # exit actions
self.exit() self.exit()
#===========================================================================
# routing performed to define the candidate operators the pending entities and how the operators should be allocated
#===========================================================================
def allocateOperators(self): def allocateOperators(self):
# find the pending objects # find the pending objects
self.findPending() self.findPending()
...@@ -149,12 +147,6 @@ class Router(ObjectInterruption): ...@@ -149,12 +147,6 @@ class Router(ObjectInterruption):
# find working stations for the candidate operators # find working stations for the candidate operators
self.findStationsForOperators() self.findStationsForOperators()
# # find the operators candidateEntities
# self.sortCandidateEntities()
# # find the entity that will occupy the resource, and the station that will receive it (if any available)
# # entities that are already in stations have already a receiver
# self.findCandidateReceivers()
#=========================================================================== #===========================================================================
# unassigns exits of queues that are not to be signalled # unassigns exits of queues that are not to be signalled
#=========================================================================== #===========================================================================
...@@ -215,7 +207,6 @@ class Router(ObjectInterruption): ...@@ -215,7 +207,6 @@ class Router(ObjectInterruption):
operator.candidateEntities=[] operator.candidateEntities=[]
operator.candidateStations=[] operator.candidateStations=[]
operator.candidateStation=None operator.candidateStation=None
# operator.candidateEntity=None
for entity in G.pendingEntities: for entity in G.pendingEntities:
entity.proceed=False entity.proceed=False
entity.candidateReceivers=[] entity.candidateReceivers=[]
...@@ -319,8 +310,6 @@ class Router(ObjectInterruption): ...@@ -319,8 +310,6 @@ class Router(ObjectInterruption):
for candidateOperator in candidateOperators: for candidateOperator in candidateOperators:
if not station in candidateOperator.candidateStations: if not station in candidateOperator.candidateStations:
candidateOperator.candidateStations.append(station) candidateOperator.candidateStations.append(station)
# if there is candidateOperator that is not already in self.candidateOperators add him
# TODO: this way no sorting is performed
if not candidateOperator in self.candidateOperators: if not candidateOperator in self.candidateOperators:
self.candidateOperators.append(candidateOperator) self.candidateOperators.append(candidateOperator)
# if there are critical pending entities then populate the candidateOperators list with preemptiveOperators # if there are critical pending entities then populate the candidateOperators list with preemptiveOperators
......
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