diff options
| author | Daniel Friesel <daniel.friesel@uos.de> | 2019-11-19 09:17:38 +0100 | 
|---|---|---|
| committer | Daniel Friesel <daniel.friesel@uos.de> | 2019-11-19 09:17:38 +0100 | 
| commit | ab08353463dde17746148f6fd2ba4278c237acc3 (patch) | |
| tree | 37a6d09a3b810a866786bf257bbbe025c89629b8 | |
| parent | fbc02b8a4fb32a9b75ea00e48789f2fba89f7470 (diff) | |
EnergyTraceLog: clean up function signatures
| -rw-r--r-- | lib/dfatool.py | 38 | 
1 files changed, 19 insertions, 19 deletions
| diff --git a/lib/dfatool.py b/lib/dfatool.py index cb1667c..382c2ce 100644 --- a/lib/dfatool.py +++ b/lib/dfatool.py @@ -381,8 +381,8 @@ def _preprocess_etlog(measurement):      setup = measurement['setup']      etlog = EnergyTraceLog(float(setup['voltage']), int(setup['state_duration']), measurement['transition_names'])      try: -        timestamps, durations, mean_power = etlog.load_data(measurement['content']) -        states_and_transitions = etlog.analyze_states(timestamps, durations, mean_power, measurement['expected_trace'], measurement['repeat_id']) +        etlog.load_data(measurement['content']) +        states_and_transitions = etlog.analyze_states(measurement['expected_trace'], measurement['repeat_id'])      except EOFError as e:          etlog.errors.append('EnergyTrace logfile error: {}'.format(e))          trigidx = list() @@ -2239,7 +2239,7 @@ class EnergyTraceLog:          return self._ts_to_index(timestamp, mid_index, right_index) -    def analyze_states(self, interval_start_timestamp, interval_duration, interval_power, traces, offline_index: int): +    def analyze_states(self, traces, offline_index: int):          u"""          Split log data into states and transitions and return duration, energy, and mean power for each element. @@ -2264,7 +2264,7 @@ class EnergyTraceLog:              * `uW_mean_delta_next`: Differenz zwischen uW_mean und uW_mean des Folgezustands          """ -        first_sync = self.find_first_sync(interval_start_timestamp, interval_power) +        first_sync = self.find_first_sync()          energy_trace = list() @@ -2280,7 +2280,7 @@ class EnergyTraceLog:          next_barcode = first_sync          for name, duration in expected_transitions: -            bc, start, stop, end = self.find_barcode(interval_start_timestamp, interval_power, next_barcode) +            bc, start, stop, end = self.find_barcode(next_barcode)              if bc is None:                  print('[!!!] did not find transition "{}"'.format(name))                  break @@ -2327,15 +2327,15 @@ class EnergyTraceLog:          return energy_trace -    def find_first_sync(self, interval_ts, interval_power): +    def find_first_sync(self):          # LED Power is approx. self.led_power W, use self.led_power/2 W above surrounding median as threshold -        sync_threshold_power = np.median(interval_power[: int(3 * self.sample_rate)]) + self.led_power/3 -        for i, ts in enumerate(interval_ts): -            if ts > 2 and interval_power[i] > sync_threshold_power: -                return interval_ts[i - 300] +        sync_threshold_power = np.median(self.interval_power[: int(3 * self.sample_rate)]) + self.led_power/3 +        for i, ts in enumerate(self.interval_start_timestamp): +            if ts > 2 and self.interval_power[i] > sync_threshold_power: +                return self.interval_start_timestamp[i - 300]          return None -    def find_barcode(self, interval_ts, interval_power, start_ts): +    def find_barcode(self, start_ts):          """          Return absolute position and content of the next barcode following `start_ts`. @@ -2344,7 +2344,7 @@ class EnergyTraceLog:          :param start_ts: timestamp at which to start looking for a barcode [s]          """ -        for i, ts in enumerate(interval_ts): +        for i, ts in enumerate(self.interval_start_timestamp):              if ts >= start_ts:                  start_position = i                  break @@ -2354,7 +2354,7 @@ class EnergyTraceLog:          # LED Power is approx. self.led_power W, use self.led_power/2 W above surrounding median as threshold -        sync_threshold_power = np.median(interval_power[start_position - lookaround : start_position + lookaround]) + self.led_power/3 +        sync_threshold_power = np.median(self.interval_power[start_position - lookaround : start_position + lookaround]) + self.led_power/3          vprint(self.verbose, 'looking for barcode starting at {:0.2f} s, threshold is {:0.1f} mW'.format(start_ts, sync_threshold_power * 1e3)) @@ -2362,16 +2362,16 @@ class EnergyTraceLog:          sync_start_ts = None          sync_area_end = None          sync_end_ts = None -        for i, ts in enumerate(interval_ts): -            if sync_area_start is None and ts >= start_ts and interval_power[i] > sync_threshold_power: +        for i, ts in enumerate(self.interval_start_timestamp): +            if sync_area_start is None and ts >= start_ts and self.interval_power[i] > sync_threshold_power:                  sync_area_start = i - 300                  sync_start_ts = ts -            if sync_area_start is not None and sync_area_end is None and ts > sync_start_ts + self.min_barcode_duration and (ts > sync_start_ts + self.max_barcode_duration or abs(sync_threshold_power - interval_power[i]) > self.led_power): +            if sync_area_start is not None and sync_area_end is None and ts > sync_start_ts + self.min_barcode_duration and (ts > sync_start_ts + self.max_barcode_duration or abs(sync_threshold_power - self.interval_power[i]) > self.led_power):                  sync_area_end = i                  sync_end_ts = ts                  break -        barcode_data = interval_power[sync_area_start : sync_area_end] +        barcode_data = self.interval_power[sync_area_start : sync_area_end]          vprint(self.verbose, 'barcode search area: {:0.2f} .. {:0.2f} seconds ({} samples)'.format(sync_start_ts, sync_end_ts, len(barcode_data))) @@ -2380,8 +2380,8 @@ class EnergyTraceLog:          if bc is None:              return None, None, None, None -        start_ts = interval_ts[sync_area_start + start] -        stop_ts = interval_ts[sync_area_start + stop] +        start_ts = self.interval_start_timestamp[sync_area_start + start] +        stop_ts = self.interval_start_timestamp[sync_area_start + stop]          end_ts = stop_ts + self.module_duration * padding_bits + self.quiet_zone_duration | 
