-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_and_plot.py
113 lines (86 loc) · 2.98 KB
/
run_and_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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#!/usr/bin/env python3
import os
import pathlib
import multiprocessing
import shutil
import subprocess
import sys
import time
import functools
import matplotlib.pyplot as plt
import pandas as pd
def plot(file, min_ticks=0):
with open(file, "r") as f:
seed = f.readline().strip()
df = pd.read_csv(f)
ticks = df.shape[0]
if ticks < min_ticks:
return None
x = range(ticks)
if ticks > 25000:
figsize = (6.4 * ticks / 25000, 4.8)
else:
figsize = (6.4, 4.8)
plt.figure(figsize=figsize)
plt.title(f"Seed: {seed}", fontweight="bold")
plt.plot(x, df["chicken"], label="prey", c="green")
plt.plot(x, df["wolf"], label="predator", c="red")
plt.xlabel("tick", fontweight="bold")
plt.ylabel("population", fontweight="bold")
plt.legend()
outfile = f"png/{ticks}_{seed}.png"
plt.savefig(outfile, dpi=300)
plt.clf()
return outfile
def run(sim_exe, ticks, script, file):
with open(file, "w") as f:
subprocess.run([sim_exe, str(ticks), script], stdout=f)
return plot(file)
def main():
if len(sys.argv) == 3 and sys.argv[1] == "choose":
min_ticks = int(sys.argv[2])
shutil.rmtree("png", ignore_errors=True)
os.mkdir("png")
csv = []
for (directory, _, files) in os.walk("csv"):
for file in files:
path = pathlib.Path(os.path.join(directory, file))
if path.suffix == ".csv":
csv.append(path)
plot_at_least = functools.partial(plot, min_ticks=min_ticks)
with multiprocessing.Pool(processes=32) as pool:
for i, png in enumerate(pool.imap_unordered(plot_at_least, csv)):
if png:
print(f"[{i+1}/{len(csv)}] {png} replotted")
return
if len(sys.argv) not in [4, 5]:
print(
f"usage: {sys.argv[0]} <sim executable> <ticks> <script> <iterations> [processes]",
file=sys.stderr,
)
print(
"\nAfter running this script you can later run this command to replot only the best seeds:"
)
print(f" {sys.argv[0]} choose <min_ticks>")
sys.exit(1)
sim_exe = sys.argv[1]
ticks = int(sys.argv[2])
script = "assets/scripts/" + sys.argv[3]
iterations = int(sys.argv[4])
processes = multiprocessing.cpu_count() if len(sys.argv) == 5 else int(sys.argv[5])
run_simulation = functools.partial(run, sim_exe, ticks, script)
shutil.rmtree("csv", ignore_errors=True)
shutil.rmtree("png", ignore_errors=True)
os.mkdir("csv")
os.mkdir("png")
files = [f"csv/{i}.csv" for i in range(iterations)]
start = time.time()
i = 0
with multiprocessing.Pool(processes=processes) as pool:
for png in pool.imap_unordered(run_simulation, files):
i += 1
print(f"[{i}/{iterations}] {png} finished")
elapsed = time.time() - start
print(f"\nelapsed time: {elapsed:.3f}s")
if __name__ == "__main__":
main()