-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplot.py
99 lines (94 loc) · 4.18 KB
/
plot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
from grapher.grapher import Grapher
import argparse
import json
def plot(args):
if args.threedimensions:
data = {}
filenames = [args.filename] + args.additionalfiles
for i in range(len(filenames)):
if args.folder is None:
with open(f"./data/{filenames[i]}", "r") as f:
print(f"opening ./data/{filenames[i]}")
data[args.simulationparameters[i]] = json.load(f)
else:
with open(f"./data/{args.folder}/{filenames[i]}", "r") as f:
print(f"opening ./data/{args.folder}/{filenames[i]}")
data[args.simulationparameters[i]] = json.load(f)
grapher = Grapher(
data, args.xlabel, args.ylabel, args.zlabel, args.savefile, args.range
)
if args.multiline:
grapher.generate_multiline_plot(args.simulationparameters)
else:
if args.timetogoal:
grapher.generate_time_to_goal_heatmap(args.simulationparameters)
else:
grapher.generate_3d_contour(args.simulationparameters)
else:
if args.folder is None:
with open(f"./data/{args.filename}", "r") as f:
data = json.load(f)
else:
with open(f"./data/{args.folder}/{args.filename}", "r") as f:
data = json.load(f)
grapher = Grapher(
data, args.xlabel, args.ylabel, args.zlabel, args.savefile, args.range
)
if args.colours is not None:
grapher.generate_errorbar(args.colours[0], args.labels[0])
else:
grapher.generate_errorbar()
if args.extrafiles is not None:
for i in range(len(args.extrafiles)):
extra_file = args.extrafiles[i]
if args.folder is None:
with open(f"./data/{extra_file}", "r") as f:
data = json.load(f)
else:
with open(f"./data/{args.folder}/{extra_file}", "r") as f:
data = json.load(f)
grapher.data = data
if args.colours is not None:
grapher.generate_errorbar(args.colours[i + 1], args.labels[i + 1])
else:
grapher.generate_errorbar()
if args.display:
if args.labels is not None:
grapher.legend()
grapher.show()
if args.save:
grapher.save()
if __name__ == "__main__":
parser = argparse.ArgumentParser(
prog="Swarm Dissertation Plotting",
description="Plot data from the swarm.",
)
parser.add_argument("-f", "--filename", required=True)
parser.add_argument("-d", "--display", action="store_true")
parser.add_argument("-s", "--save", action="store_true")
parser.add_argument("-3d", "--threedimensions", action="store_true", default=False)
parser.add_argument("-x", "--xlabel")
parser.add_argument("-y", "--ylabel")
parser.add_argument("-z", "--zlabel")
parser.add_argument(
"-af",
"--additionalfiles",
nargs="*",
help="For additional heatmap files, used in conjunction with -sps, these should match.",
)
parser.add_argument("-sps", "--simulationparameters", nargs="*")
parser.add_argument("-sf", "--savefile")
parser.add_argument("-ml", "--multiline", action="store_true")
parser.add_argument("-r", "--range", type=int)
parser.add_argument("-ttg", "--timetogoal", action="store_true")
parser.add_argument("-fo", "--folder")
parser.add_argument(
"-efs",
"--extrafiles",
nargs="*",
help="For drawing multiple errorbars on one plot.",
)
parser.add_argument("-cs", "--colours", nargs="*")
parser.add_argument("-lbs", "--labels", nargs="*")
plot(parser.parse_args())
# Example: python plot.py -f of0p0oe0to100.json -d -3d -af of0p1oe0to100.json of0p2oe0to100.json of0p3oe0to100.json of0p4oe0to100.json of0p5oe0to100.json of0p6oe0to100.json of0p7oe0to100.json of0p8oe0to100.json of0p9oe0to100.json of1p0oe0to100.json -sps 0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 -y "number of entities overriden" -z "distance to goal" -x lambda -sf heatmap-magma-contour.png -s