From ba11f8f16f1b72b02eee6eada1b970e525ee50f3 Mon Sep 17 00:00:00 2001 From: gay Date: Fri, 3 Nov 2023 15:18:23 +0100 Subject: [PATCH] solving bug for start=none --- .../power_measure/experiment.py | 26 +++++++++++++------ 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/deep_learning_power_measure/power_measure/experiment.py b/deep_learning_power_measure/power_measure/experiment.py index 5fab6ce..44b8cbf 100644 --- a/deep_learning_power_measure/power_measure/experiment.py +++ b/deep_learning_power_measure/power_measure/experiment.py @@ -34,7 +34,7 @@ def joules_to_kwh(n): def integrate(metric, start=None, end=None, allow_None=False): """integral of the metric values over time start, end : timestamp from which we should start computing the integral""" - r = [0] + # first, find the indices corresponding to the [start, end] temporal segment start_idx = 0 if start != None: start_idx = 0 @@ -50,6 +50,9 @@ def integrate(metric, start=None, end=None, allow_None=False): if end_idx < 0: raise Exception('period end time given in parameter is : ' + str(end) + ' and the metric starts at: ' +str(metric[0]['date'])) + print(start_idx, end_idx) + # now computing the integral on the given segments + r = [0] for i in range(start_idx, end_idx): x1 = metric[i]['date'] x2 = metric[i+1]['date'] @@ -83,12 +86,15 @@ def total(metric: list, start=None, end=None): rs = [] # store the total for all the temporal segments for segment in metric: # check if this temporal segment intersect the given start and end parameter - if is_iou(segment[0]['date'],segment[-1]['date'], start, end): - # if so, compute the integral - integral = integrate(segment,start=start,end=end)[-1] + if start != None and end != None: + if is_iou(segment[0]['date'],segment[-1]['date'], start, end): + # if so, compute the integral + integral = integrate(segment,start=start,end=end)[-1] + else: + integral = 0 else: # if there is no intersect, say the metric value is 0 - integral = 0 + integral = integrate(segment,start=start,end=end)[-1] if integral is not None: rs.append(integral) if len(rs)>0: @@ -101,10 +107,14 @@ def total(metric: list, start=None, end=None): # and then, same as case one rs = [] for segment in segments: - if is_iou(segment[0]['date'],segment[-1]['date'], start, end): - integral = integrate(segment,start=start,end=end)[-1] + if start != None and end != None: + if is_iou(segment[0]['date'],segment[-1]['date'], start, end): + # if so, compute the integral + integral = integrate(segment,start=start,end=end)[-1] + else: + integral = 0 else: - integral = 0 + integral = integrate(segment,start=start,end=end)[-1] if integral is not None: rs.append(integral) if len(rs)>0: