diff options
| author | Florian Fischer <florian.fl.fischer@fau.de> | 2019-08-26 20:34:43 +0200 |
|---|---|---|
| committer | Florian Fischer <florian.fl.fischer@fau.de> | 2019-08-26 20:34:43 +0200 |
| commit | 5d106be3ed2cfae5da5a5d87e7826b7c45870f09 (patch) | |
| tree | 18a71e62629eb4f947be270e3a7522dd22827212 /merge.py | |
| parent | 18f850dd06b771aa625f3f2f8a4a0a9efc433cd2 (diff) | |
| download | allocbench-5d106be3ed2cfae5da5a5d87e7826b7c45870f09.tar.gz allocbench-5d106be3ed2cfae5da5a5d87e7826b7c45870f09.zip | |
move scripts from scripts/ to root and fix some pylint hints
Diffstat (limited to 'merge.py')
| -rwxr-xr-x | merge.py | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/merge.py b/merge.py new file mode 100755 index 0000000..935e809 --- /dev/null +++ b/merge.py @@ -0,0 +1,55 @@ +#!/usr/bin/env python3 + +import argparse +import os +import pickle + + +def main(): + parser = argparse.ArgumentParser(description="Merge to allocbench results") + parser.add_argument("src", help="results which should be merged into dest", type=str) + parser.add_argument("dest", help="results in which src should be merged", type=str) + parser.add_argument("-b", "--benchmarks", help="benchmarks to summarize", nargs='+') + parser.add_argument("-x", "--exclude-benchmarks", help="benchmarks to exclude", nargs='+') + + args = parser.parse_args() + + for src_save in os.listdir(args.src): + if not src_save.endswith(".save"): + continue + if src_save == "facts.save": + continue + if args.benchmarks and not src_save[:-5] in args.benchmarks: + continue + if args.exclude_benchmarks and src_save[:-5] in args.exclude_benchmarks: + continue + + src_save = os.path.join(args.src, src_save) + dest_save = os.path.join(args.dest, os.path.basename(src_save)) + + if not os.path.isfile(dest_save): + print("Can't merge", src_save, "because", os.path.basename(src_save), "not in", args.dest) + continue + + with open(src_save, "rb") as src_file: + src_results = pickle.load(src_file) + + with open(dest_save, "rb") as dest_file: + dest_results = pickle.load(dest_file) + + for alloc in src_results["allocators"]: + if alloc in dest_results["allocators"]: + print(alloc, "already in", dest_save) + continue + + print("merging", alloc, "from", src_save, "into", dest_save) + dest_results["allocators"][alloc] = src_results["allocators"][alloc] + dest_results[alloc] = src_results[alloc] + dest_results["stats"][alloc] = src_results["stats"][alloc] + + with open(dest_save, "wb") as result_file: + pickle.dump(dest_results, result_file) + + +if __name__ == "__main__": + main() |
