diff options
| author | Mac Mollison <mollison@cs.unc.edu> | 2010-02-11 19:35:47 -0500 |
|---|---|---|
| committer | Mac Mollison <mollison@cs.unc.edu> | 2010-02-11 19:35:47 -0500 |
| commit | a92bbe8cf94f28b250cf023b3e4cfea148738468 (patch) | |
| tree | 3143d40015413d890e842cffc7a127f397a858f9 | |
| parent | 0b581a1f70086961e487108bddee4013c77e42b7 (diff) | |
Implement statistics module
| -rwxr-xr-x | run.py | 2 | ||||
| -rw-r--r-- | stats.py | 36 | ||||
| -rw-r--r-- | stdout_printer.py | 19 |
3 files changed, 53 insertions, 4 deletions
| @@ -15,6 +15,7 @@ | |||
| 15 | import trace_reader | 15 | import trace_reader |
| 16 | import sanitizer | 16 | import sanitizer |
| 17 | import gedf_test | 17 | import gedf_test |
| 18 | import stats | ||
| 18 | import stdout_printer | 19 | import stdout_printer |
| 19 | 20 | ||
| 20 | ############################################################################### | 21 | ############################################################################### |
| @@ -35,4 +36,5 @@ g6 = [ | |||
| 35 | stream = trace_reader.trace_reader(g6) | 36 | stream = trace_reader.trace_reader(g6) |
| 36 | stream = sanitizer.sanitizer(stream) | 37 | stream = sanitizer.sanitizer(stream) |
| 37 | stream = gedf_test.gedf_test(stream) | 38 | stream = gedf_test.gedf_test(stream) |
| 39 | stream = stats.stats(stream) | ||
| 38 | stdout_printer.stdout_printer(stream) | 40 | stdout_printer.stdout_printer(stream) |
diff --git a/stats.py b/stats.py new file mode 100644 index 0000000..6216f44 --- /dev/null +++ b/stats.py | |||
| @@ -0,0 +1,36 @@ | |||
| 1 | ############################################################################### | ||
| 2 | # Description | ||
| 3 | ############################################################################### | ||
| 4 | # Compute and produce statistics | ||
| 5 | |||
| 6 | |||
| 7 | ############################################################################### | ||
| 8 | # Public Functions | ||
| 9 | ############################################################################### | ||
| 10 | |||
| 11 | def stats(stream): | ||
| 12 | min_inversion = -1 | ||
| 13 | max_inversion = -1 | ||
| 14 | sum_inversions = 0 | ||
| 15 | num_inversions = 0 | ||
| 16 | for record in stream: | ||
| 17 | if record.type_name == 'inversion_end': | ||
| 18 | length = record.job.inversion_end - record.job.inversion_start | ||
| 19 | if length > 0: | ||
| 20 | num_inversions += 1 | ||
| 21 | if length > max_inversion: | ||
| 22 | max_inversion = length | ||
| 23 | if length < min_inversion or min_inversion == -1: | ||
| 24 | min_inversion = length | ||
| 25 | sum_inversions += length | ||
| 26 | yield record | ||
| 27 | avg_inversion = int(sum_inversions / num_inversions) | ||
| 28 | class Obj(): pass | ||
| 29 | rec = Obj() | ||
| 30 | rec.record_type = "meta" | ||
| 31 | rec.type_name = "stats" | ||
| 32 | rec.num_inversions = num_inversions | ||
| 33 | rec.min_inversion = min_inversion | ||
| 34 | rec.max_inversion = max_inversion | ||
| 35 | rec.avg_inversion = avg_inversion | ||
| 36 | yield rec | ||
diff --git a/stdout_printer.py b/stdout_printer.py index 466f734..5bbcead 100644 --- a/stdout_printer.py +++ b/stdout_printer.py | |||
| @@ -12,10 +12,14 @@ def stdout_printer(stream): | |||
| 12 | for record in stream: | 12 | for record in stream: |
| 13 | if record.record_type == "event": | 13 | if record.record_type == "event": |
| 14 | _print_event(record) | 14 | _print_event(record) |
| 15 | elif record.type_name == 'inversion_start': | 15 | elif record.record_type == "meta" and record.type_name == "stats": |
| 16 | _print_stats(record) | ||
| 17 | elif record.record_type == "error" and record.type_name == 'inversion_start': | ||
| 16 | _print_inversion_start(record) | 18 | _print_inversion_start(record) |
| 17 | elif record.type_name == 'inversion_end': | 19 | elif record.record_type == "error" and record.type_name == 'inversion_end': |
| 18 | _print_inversion_end(record) | 20 | _print_inversion_end(record) |
| 21 | else: | ||
| 22 | continue | ||
| 19 | print("") | 23 | print("") |
| 20 | 24 | ||
| 21 | ############################################################################### | 25 | ############################################################################### |
| @@ -39,7 +43,7 @@ def _print_inversion_start(record): | |||
| 39 | print("On CPU: ",end="") | 43 | print("On CPU: ",end="") |
| 40 | for job in record.on_cpu: | 44 | for job in record.on_cpu: |
| 41 | print(str(job) + " ",end="") | 45 | print(str(job) + " ",end="") |
| 42 | print("") | 46 | print("") #newline |
| 43 | 47 | ||
| 44 | def _print_inversion_end(record): | 48 | def _print_inversion_end(record): |
| 45 | print("Type: {}".format("Inversion end")) | 49 | print("Type: {}".format("Inversion end")) |
| @@ -55,4 +59,11 @@ def _print_inversion_end(record): | |||
| 55 | print("On CPU: ",end="") | 59 | print("On CPU: ",end="") |
| 56 | for job in record.on_cpu: | 60 | for job in record.on_cpu: |
| 57 | print(str(job) + " ",end="") | 61 | print(str(job) + " ",end="") |
| 58 | print("") | 62 | print("") #newline |
| 63 | |||
| 64 | def _print_stats(record): | ||
| 65 | print("Inversion statistics") | ||
| 66 | print("Num inversions: {}".format(record.num_inversions)) | ||
| 67 | print("Min inversion: {}".format(record.min_inversion)) | ||
| 68 | print("Max inversion: {}".format(record.max_inversion)) | ||
| 69 | print("Avg inversion: {}".format(record.avg_inversion)) | ||
