-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathanalyze.py
39 lines (34 loc) · 1 KB
/
analyze.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
import matplotlib.pyplot as plt
from rebound import SimulationArchive, Particle, Simulation
from extradata import ExtraData
from utils import filename_from_argv, plot_settings, is_ci
plot_settings()
fn = filename_from_argv()
sa = SimulationArchive(str(fn.with_suffix(".bin")))
ed = ExtraData.load(fn)
print(ed.meta)
data = {}
sim: Simulation
print(f"{len(sa)} Snapshots found")
for sim in sa:
t = sim.t
for pn in range(1, sim.N):
part: Particle = sim.particles[pn]
hash = part.hash.value
if hash not in data:
data[hash] = ([], [])
data[hash][0].append(t)
data[hash][1].append(part.a)
for name, d in data.items():
times, values = d
print(list(map(len, [times, values])))
if False:
plt.scatter(times, values, label=name, s=.9)
else:
plt.plot(times, values, label=name, linewidth=0.6)
# plt.legend()
# OrbitPlot(sim, slices=1)
plt.tight_layout()
if not is_ci():
plt.savefig("/home/lukas/tmp/time.pdf", transparent=True)
plt.show()