Commit 32e0f392 authored by Georgios Dagkakis's avatar Georgios Dagkakis

correction in plugin

parent 79fabc97
...@@ -28,11 +28,11 @@ class BatchesOperatorGantt(plugin.OutputPreparationPlugin, TimeSupportMixin): ...@@ -28,11 +28,11 @@ class BatchesOperatorGantt(plugin.OutputPreparationPlugin, TimeSupportMixin):
# loop in the results to find Operators # loop in the results to find Operators
colorList=['blue','green','red', colorList=['blue','green','red',
'gold','black','white', 'gold','black','Aqua',
'DarkRed','Fuchsia','Gray', 'DarkRed','Fuchsia','Gray',
'magenta','yellow','Olive', 'magenta','yellow','Olive',
'orange','purple','pink'] 'orange','purple','pink']
# create a dictionary so that all stations have their own color # create a dictionary so that all stations have their own color
colorDict={} colorDict={}
nodes=data['graph']['node'] nodes=data['graph']['node']
...@@ -43,7 +43,9 @@ class BatchesOperatorGantt(plugin.OutputPreparationPlugin, TimeSupportMixin): ...@@ -43,7 +43,9 @@ class BatchesOperatorGantt(plugin.OutputPreparationPlugin, TimeSupportMixin):
i+=1 i+=1
if i==len(colorList): if i==len(colorList):
i=0 i=0
# set off-shift color to white
colorDict['off-shift']='white'
for element in resultElements: for element in resultElements:
if element['_class']=="Dream.Operator": if element['_class']=="Dream.Operator":
operatorId=element['id'] operatorId=element['id']
...@@ -55,23 +57,27 @@ class BatchesOperatorGantt(plugin.OutputPreparationPlugin, TimeSupportMixin): ...@@ -55,23 +57,27 @@ class BatchesOperatorGantt(plugin.OutputPreparationPlugin, TimeSupportMixin):
open=False) open=False)
schedule=copy(element['results']['schedule']) schedule=copy(element['results']['schedule'])
# in the cases the operator exits and the enters in the same station merge those records
k=0 k=0
for record in schedule: for record in schedule:
for nextRecord in schedule[k+1:]: for nextRecord in schedule[k+1:]:
if nextRecord['stationId']==record['stationId'] and not record is schedule[-1]: if nextRecord['stationId']==record['stationId']\
and nextRecord['entranceTime']==record['exitTime']\
and not record is schedule[-1]:
nextExitTime=nextRecord.get('exitTime',maxSimTime)
record['exitTime']=nextExitTime
schedule.remove(nextRecord) schedule.remove(nextRecord)
else: else:
continue continue
k+=1 k+=1
# print schedule # loop though the records
k=1 k=1
for record in schedule: for record in schedule:
entranceTime=record['entranceTime'] entranceTime=record['entranceTime']
try: exitTime=record.get('exitTime',None)
exitTime=schedule[k]['entranceTime'] if not exitTime:
except IndexError: exitTime=maxSimTime
exitTime=maxSimTime
k+=1 k+=1
task_dict[operatorId+record['stationId']+str(k)] = dict( task_dict[operatorId+record['stationId']+str(k)] = dict(
id=operatorId+record['stationId']+str(k), id=operatorId+record['stationId']+str(k),
......
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