Commit 478cd8b4 authored by Matt Traudt's avatar Matt Traudt
Browse files

Sort lines by bandwidth

parent d35ec89a
......@@ -18,14 +18,24 @@ def read_result_file(fname, starting_dict=None):
return data
class V3BWLine:
def __init__(self, fp, bw, nick):
self.fp = fp = bw
self.nick = nick
def __str__(self):
frmt = 'node_id={fp} bw={sp} nick={n}'
return frmt.format(fp=self.fp, sp=round(, n=self.nick)
def result_data_to_v3bw_line(data, fingerprint):
assert fingerprint in data
results = data[fingerprint]
nick = results[0]['nickname']
speeds = [r['amount'] / r['duration'] for r in results]
speed = median(speeds)
frmt = 'node_id={fp} bw={sp} nick={n}'
return frmt.format(fp=fingerprint, sp=round(speed), n=nick)
return V3BWLine(fingerprint, speed, nick)
def main(args):
......@@ -36,10 +46,12 @@ def main(args):
data = {}
for fname in data_fnames:
data = read_result_file(fname, data)
data_lines = [result_data_to_v3bw_line(data, fp) for fp in data]
data_lines = sorted(data_lines, key=lambda d:, reverse=True)
with open(args.output, 'wt') as fd:
for fp in data:
fd.write('{}\n'.format(result_data_to_v3bw_line(data, fp)))
for line in data_lines:
if __name__ == '__main__':
Supports Markdown
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