-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvisualizer.py
More file actions
41 lines (31 loc) · 1.73 KB
/
visualizer.py
File metadata and controls
41 lines (31 loc) · 1.73 KB
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
# visualizer.py
# Modul 8: 3D vizualizace dráhy a konvergence Kalmanova filtru
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
class NavigationVisualizer:
@staticmethod
def plot_3d_trajectory(true_pos, raw_history, kalman_history):
fig = plt.figure(figsize=(10, 8))
ax = fig.add_subplot(111, projection='3d')
# Rozbalení souřadnic pro historii Kalmanova filtru
kx = [p[0] for p in kalman_history]
ky = [p[1] for p in kalman_history]
kz = [p[2] for p in kalman_history]
# Rozbalení souřadnic pro surová měření (přeskočíme ty, které spadly na [0,0,0])
rx = [p[0] for p in raw_history if p != [0,0,0]]
ry = [p[1] for p in raw_history if p != [0,0,0]]
rz = [p[2] for p in raw_history if p != [0,0,0]]
# Vykreslení surových dat (šum) jako červené tečky
ax.scatter(rx, ry, rz, color='red', s=10, label='Raw Measurements (Noise)', alpha=0.3)
# Vykreslení cesty Kalmanova filtru jako modrá čára
ax.plot(kx, ky, kz, color='blue', marker='o', markersize=3, label='Kalman Filter Path', linewidth=2)
# Vykreslení skutečné pozice lodi jako velká zelená hvězda
ax.scatter(true_pos[0], true_pos[1], true_pos[2], color='green', marker='*', s=400, label='True Spacecraft Position')
# Vykreslení startovní (špatné) pozice jako oranžový křížek
ax.scatter(kx[0], ky[0], kz[0], color='orange', marker='X', s=150, label='Initial Bad Guess')
ax.set_xlabel('X Coordinate (km)')
ax.set_ylabel('Y Coordinate (km)')
ax.set_zlabel('Z Coordinate (km)')
ax.set_title('PulseWay: 3D Navigation Convergence')
ax.legend()
plt.show()