Commit b5de2456 authored by Georgios Dagkakis's avatar Georgios Dagkakis

enumeration to stop if total delay gets increased

parent 4d53e46b
...@@ -37,7 +37,7 @@ class CapacityStationsEnumeration(Enumeration): ...@@ -37,7 +37,7 @@ class CapacityStationsEnumeration(Enumeration):
return totalDelay return totalDelay
# creates the collated scenarios, i.e. the list # creates the collated scenarios, i.e. the list
# of options collated into a dictionary for ease of referencing in ManPy # of options collated into a list for ease of referencing in ManPy
def createScenarioList(self,data): def createScenarioList(self,data):
scenarioList=[] scenarioList=[]
step=data['general'].get('thresholdStep',7) step=data['general'].get('thresholdStep',7)
...@@ -60,7 +60,18 @@ class CapacityStationsEnumeration(Enumeration): ...@@ -60,7 +60,18 @@ class CapacityStationsEnumeration(Enumeration):
scenarioData['graph']['node']['CSC']['dueDateThreshold']=scenario['threshold'] scenarioData['graph']['node']['CSC']['dueDateThreshold']=scenario['threshold']
return scenarioData return scenarioData
# checks if the algorithm should terminate. Default is set to False so that the algorithm # checks if the algorithm should terminate.
# terminates only when all scenarios are considered # in this case terminate if the total delat is increased
def checkIfShouldTerminate(self,data,scenarioList): def checkIfShouldTerminate(self,data,scenarioList):
if len(scenarioList)<2:
return False
index=0
for i in range(len(scenarioList)):
if scenarioList[i].get('score',None)==None:
index=i-1
break
if index:
if scenarioList[index]['score']>scenarioList[index-1]['score']:
scenarioList = scenarioList[:index+1]
return True
return False return False
...@@ -35,7 +35,6 @@ class Enumeration(plugin.ExecutionPlugin): ...@@ -35,7 +35,6 @@ class Enumeration(plugin.ExecutionPlugin):
def checkIfShouldTerminate(self,data,scenarioList): def checkIfShouldTerminate(self,data,scenarioList):
return False return False
def run(self, data): def run(self, data):
# distributor_url = data['general'].get('distributorURL',None) # distributor_url = data['general'].get('distributorURL',None)
# distributor = None # distributor = None
...@@ -45,18 +44,21 @@ class Enumeration(plugin.ExecutionPlugin): ...@@ -45,18 +44,21 @@ class Enumeration(plugin.ExecutionPlugin):
start = time.time() # start counting execution time start = time.time() # start counting execution time
numberOfSolutions = int(data['general'].get('numberOfSolutions',3)) numberOfSolutions = int(data['general'].get('numberOfSolutions',15))
assert numberOfSolutions >= 1 assert numberOfSolutions >= 1
scenarioList=self.createScenarioList(data) scenarioList=self.createScenarioList(data)
i=0
for scenario in scenarioList: for scenario in scenarioList:
scenario['input']=self.createScenarioData(data, scenario) scenario['input']=self.createScenarioData(data, scenario)
scenario['result'] = self.runOneScenario(scenario['input'])['result'] scenario['result'] = self.runOneScenario(scenario['input'])['result']
scenario['score'] = self.calculateScenarioScore(scenario) scenario['score'] = self.calculateScenarioScore(scenario)
if self.checkIfShouldTerminate(data, scenarioList): if self.checkIfShouldTerminate(data, scenarioList):
scenarioList = scenarioList[:i+1]
break break
i+=1
# rand the scenarios based on their score and take only the numberOfSolutions best # rank the scenarios based on their score and take only the numberOfSolutions best
scenariosToReturn = sorted(scenarioList,key=operator.itemgetter('score'))[:numberOfSolutions] scenariosToReturn = sorted(scenarioList,key=operator.itemgetter('score'))[:numberOfSolutions]
# return the number of scenarios that need to be returned # return the number of scenarios that need to be returned
......
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