findCandidateReceivers method of Router updated. minor corrections

parent 0f5f3aef
...@@ -625,7 +625,25 @@ class Router(ObjectInterruption): ...@@ -625,7 +625,25 @@ class Router(ObjectInterruption):
#local method that finds a candidate entity for an operator #local method that finds a candidate entity for an operator
def findCandidateEntity(): def findCandidateEntity():
candidateEntity=next(x for x in operator.candidateEntities if not x in entitiesWithOccupiedReceivers) # local recursive method that searches for entities with available receivers
def findAvailableEntity():
# if the candidateEntities and the entitiesWithOccupiedReceivers lists are identical then return None
if len(set(operator.candidateEntities).intersection(entitiesWithOccupiedReceivers))==len(operator.candidateEntities):
return None
availableEntity=next(x for x in operator.candidateEntities if not x in entitiesWithOccupiedReceivers)
receiverAvailability=False
if availableEntity:
for receiver in availableEntity.candidateReceivers:
if not receiver in occupiedReceivers:
receiverAvailability=True
break
# if there are no available receivers for the entity
if not receiverAvailability:
entitiesWithOccupiedReceivers.append(availableEntity)
return findAvailableEntity()
return availableEntity
# pick a candidateEntity
candidateEntity=findAvailableEntity()
if not self.sorting: if not self.sorting:
if not candidateEntity: if not candidateEntity:
candidateEntity=next(x for x in operator.candidateEntities) candidateEntity=next(x for x in operator.candidateEntities)
...@@ -682,7 +700,7 @@ class Router(ObjectInterruption): ...@@ -682,7 +700,7 @@ class Router(ObjectInterruption):
for operator in self.candidateOperators: for operator in self.candidateOperators:
if operator.candidateEntity in conflictingEntities: if operator.candidateEntity in conflictingEntities:
conflictingOperators.append(operator) conflictingOperators.append(operator)
elif operator.candidateEntity.candidateReceiver in [x.candidateReceiver for x in conflinctingEntities]: elif operator.candidateEntity.candidateReceiver in [x.candidateReceiver for x in conflictingEntities]:
conflictingOperators.append(operator) conflictingOperators.append(operator)
self.conflictingOperators=conflictingOperators self.conflictingOperators=conflictingOperators
# keep the sorting provided by the queues if there is conflict between operators # keep the sorting provided by the queues if there is conflict between operators
...@@ -701,7 +719,7 @@ class Router(ObjectInterruption): ...@@ -701,7 +719,7 @@ class Router(ObjectInterruption):
# the operator that can proceed is the manager of the entity as sorted by the queue that holds them # the operator that can proceed is the manager of the entity as sorted by the queue that holds them
conflictingGroup.sort(key=lambda x: x.ind) conflictingGroup.sort(key=lambda x: x.ind)
# the operators that are not first in the list cannot proceed # the operators that are not first in the list cannot proceed
for operator in conflitingGroup: for operator in conflictingGroup:
if conflictingGroup.index(operator)!=0: if conflictingGroup.index(operator)!=0:
self.candidateOperators.remove(operator) self.candidateOperators.remove(operator)
self.calledOperators.remove(operator) self.calledOperators.remove(operator)
......
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