commit f34d0c0df1ec4b2babd45f8ccfb71a7d8924c1d5 Author: juga0 juga@riseup.net Date: Thu Aug 30 12:49:47 2018 +0000
Make V3BWFile from results depend on the scaling method --- sbws/lib/v3bwfile.py | 65 ++++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 53 insertions(+), 12 deletions(-)
diff --git a/sbws/lib/v3bwfile.py b/sbws/lib/v3bwfile.py index 22bf245..cdcbad8 100644 --- a/sbws/lib/v3bwfile.py +++ b/sbws/lib/v3bwfile.py @@ -8,7 +8,10 @@ import os from statistics import median, mean
from sbws import __version__ -from sbws.globals import SPEC_VERSION, BW_LINE_SIZE, SCALE_CONSTANT +from sbws.globals import (SPEC_VERSION, BW_LINE_SIZE, SBWS_SCALE_CONSTANT, + TORFLOW_SCALING, SBWS_SCALING, TORFLOW_BW_MARGIN, + TORFLOW_OBS_LAST, TORFLOW_OBS_MEAN, + fail_hard) from sbws.lib.resultdump import ResultSuccess, _ResultType from sbws.util.filelock import DirectoryLock from sbws.util.timestamp import now_isodt_str, unixts_to_isodt_str @@ -38,7 +41,8 @@ BW_KEYVALUES_BASIC = ['node_id', 'bw'] BW_KEYVALUES_FILE = BW_KEYVALUES_BASIC + \ ['master_key_ed25519', 'nick', 'rtt', 'time', 'success', 'error_stream', 'error_circ', 'error_misc'] -BW_KEYVALUES_EXTRA_BWS = ['bw_bs_median', 'bw_bs_mean', 'desc_avg_bw_bs'] +BW_KEYVALUES_EXTRA_BWS = ['bw_bs_median', 'bw_bs_mean', 'desc_avg_bw_bs', + 'desc_obs_bw_bs_last', 'desc_obs_bw_bs_mean'] BW_KEYVALUES_EXTRA = BW_KEYVALUES_FILE + BW_KEYVALUES_EXTRA_BWS BW_KEYVALUES_INT = ['bw', 'rtt', 'success', 'error_stream', 'error_circ', 'error_misc'] + BW_KEYVALUES_EXTRA_BWS @@ -355,20 +359,52 @@ class V3BWFile(object): self.bw_lines = v3bwlines
def __str__(self): - return str(self.header) + ''.join([str(bw_line) + return str(self.header) + ''.join([str(bw_line) or '' for bw_line in self.bw_lines])
@classmethod def from_results(cls, results, state_fpath='', - scale_constant=None): - bw_lines = [V3BWLine.from_results(results[fp]) for fp in results] - bw_lines = sorted(bw_lines, key=lambda d: d.bw, reverse=True) - if scale_constant is not None: - bw_lines = cls.bw_sbws_scale(bw_lines, scale_constant) + scale_constant=SBWS_SCALE_CONSTANT, + scaling_method=None, torflow_obs=TORFLOW_OBS_LAST, + reverse=False): + """Create V3BWFile class from sbws Results. + + :param dict results: see below + :param str state_fpath: path to the state file + :param int scaling_method: + Scaling method to obtain the bandwidth + Posiable values: {NONE, SBWS_SCALING, TORFLOW_SCALING} = {0, 1, 2} + :param int scale_constant: sbws scaling constant + :param int torflow_obs: method to choose descriptor observed bandwidth + :param bool reverse: whether to sort the bw lines descending or not + + Results are in the form:: + + {'relay_fp1': [Result1, Result2, ...], + 'relay_fp2': [Result1, Result2, ...]} + + """ + # TODO: change scaling_method to TORFLOW_SCALING before getting this + # in production + log.info('Processing results to generate a bandwidth list file.') + header = V3BWHeader.from_results(results, state_fpath) + bw_lines_raw = [] + for fp in results.keys(): + l = V3BWLine.from_results(results[fp]) + if l is not None: + bw_lines_raw.append(l) + if not bw_lines_raw: + return cls(header, []) + if scaling_method == SBWS_SCALING: + bw_lines = cls.bw_sbws_scale(bw_lines_raw, scale_constant) cls.warn_if_not_accurate_enough(bw_lines, scale_constant) + # log.debug(bw_lines[-1]) + elif scaling_method == TORFLOW_SCALING: + bw_lines = cls.bw_torflow_scale(bw_lines_raw, torflow_obs) + # log.debug(bw_lines[-1]) else: - bw_lines = cls.bw_kb(bw_lines) - header = V3BWHeader.from_results(results, state_fpath) + bw_lines = cls.bw_kb(bw_lines_raw) + # log.debug(bw_lines[-1]) f = cls(header, bw_lines) return f
@@ -380,7 +416,7 @@ class V3BWFile(object): return sorted(bw_lines_scaled, key=lambda x: x.bw, reverse=reverse)
@staticmethod - def bw_sbws_scale(bw_lines, scale_constant=SCALE_CONSTANT, + def bw_sbws_scale(bw_lines, scale_constant=SBWS_SCALE_CONSTANT, reverse=False): """Return a new V3BwLine list scaled using sbws method.
@@ -417,7 +453,7 @@ class V3BWFile(object):
@staticmethod def warn_if_not_accurate_enough(bw_lines, - scale_constant=SCALE_CONSTANT): + scale_constant=SBWS_SCALE_CONSTANT): margin = 0.001 accuracy_ratio = median([l.bw for l in bw_lines]) / scale_constant log.info('The generated lines are within {:.5}% of what they should ' @@ -426,6 +462,11 @@ class V3BWFile(object): log.warning('There was %f%% error and only +/- %f%% is ' 'allowed', (1 - accuracy_ratio) * 100, margin * 100)
+ @staticmethod + def bw_lines_torflow(bw_lines, desc_obs_bws=TORFLOW_OBS_LAST, + cap=TORFLOW_BW_MARGIN, reverse=False): + pass + @property def sum_bw(self): return sum([l.bw for l in self.bw_lines])
tor-commits@lists.torproject.org