Commit dbcc5807 authored by Georgios Dagkakis's avatar Georgios Dagkakis

results of exit to work with CIs in multiple replications

parent 6ca6125f
...@@ -13,17 +13,45 @@ class DefaultTabularExit(plugin.OutputPreparationPlugin): ...@@ -13,17 +13,45 @@ class DefaultTabularExit(plugin.OutputPreparationPlugin):
""" """
def postprocess(self, data): def postprocess(self, data):
node=data['graph']['node'] numberOfReplications=data['general']['numberOfReplications']
# create the titles of the columns confidenceLevel=data['general']['confidenceLevel']
data['result']['result_list'][0]['exit_output'] = [['Exit Id','Throughput', 'Takt Time', 'Lifespan']] if numberOfReplications==1:
# loop the results and search for elements that have 'Exit' as family # create the titles of the columns
for record in data['result']['result_list'][0]['elementList']: data['result']['result_list'][0]['exit_output'] = [['Exit Id','Throughput', 'Takt Time', 'Lifespan']]
family=record.get('family',None) # loop the results and search for elements that have 'Exit' as family
# when found, add a row with the results of the specific exit for record in data['result']['result_list'][0]['elementList']:
if family=='Exit': family=record.get('family',None)
exitId=record['id'] # when found, add a row with the results of the specific exit
throughput=record['results'].get('throughput','undefined') if family=='Exit':
taktTime=record['results'].get('takt_time','undefined') exitId=record['id']
lifespan=record['results'].get('lifespan','undefined') throughput=record['results'].get('throughput','undefined')
data['result']['result_list'][0]['exit_output'].append([exitId,throughput,taktTime,lifespan]) taktTime=record['results'].get('takt_time','undefined')
return data lifespan=record['results'].get('lifespan','undefined')
\ No newline at end of file data['result']['result_list'][0]['exit_output'].append([exitId,throughput,taktTime,lifespan])
elif numberOfReplications>1:
# create the titles of the columns
data['result']['result_list'][0]['exit_output'] = [['Exit Id','','Throughput','' , '','Takt Time','','', 'Lifespan',''],
['','LB','AVG','RB','LB','AVG','RB','LB','AVG','RB']]
for record in data['result']['result_list'][0]['elementList']:
family=record.get('family',None)
# when found, add a row with the results of the specific exit
if family=='Exit':
exitId=record['id']
throughput=self.getConfidenceInterval(record['results'].get('throughput','undefined'),confidenceLevel)
taktTime=self.getConfidenceInterval(record['results'].get('takt_time','undefined'),confidenceLevel)
lifespan=self.getConfidenceInterval(record['results'].get('lifespan','undefined'),confidenceLevel)
data['result']['result_list'][0]['exit_output'].append([exitId,
throughput['lb'],throughput['avg'],throughput['ub'],
taktTime['lb'],taktTime['avg'],taktTime['ub'],
lifespan['lb'],lifespan['avg'],lifespan['ub']])
return data
def getConfidenceInterval(self, value_list, confidenceLevel):
from dream.KnowledgeExtraction.ConfidenceIntervals import Intervals
from dream.KnowledgeExtraction.StatisticalMeasures import BasicStatisticalMeasures
BSM=BasicStatisticalMeasures()
lb, ub = Intervals().ConfidIntervals(value_list, confidenceLevel)
return {'lb': lb,
'ub': ub,
'avg': BSM.mean(value_list)
}
\ No newline at end of file
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