forked from arghasen10/mmPhase
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrack_clusters.py
158 lines (135 loc) · 6.38 KB
/
track_clusters.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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
from helper import *
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation
from sklearn.cluster import DBSCAN
from sklearn.preprocessing import MinMaxScaler
from statistics import mode
# fig = plt.figure()
# ax = fig.add_subplot(111,)
# scat = ax.scatter([], [], s=50)
fig, ax = plt.subplots()
ax.set_xlim(-10, 10)
ax.set_ylim(0, 10)
ax.set_xlabel('X axis')
ax.set_ylabel('Y axis')
def get_traj(P1, P2, v_b, t, prev_point):
C1 = np.array([(v_b * t) - P1[1] + (P1[0]**2 / (v_b * t - P1[0]))])
B1 = np.array(P2[0] + (P2[1] * P1[0] / (v_b * t - P1[1])))
translation_magnitude = v_b*t
angle = np.arcsin((-B1) / C1)[0][0]
rotation_matrix = np.array([
[np.cos(angle), -np.sin(angle)],
[np.sin(angle), np.cos(angle)]
])
P1 = P1.flatten()
rotated_point = np.dot(rotation_matrix, prev_point)
translation_vector = translation_magnitude * np.array([np.sin(angle), np.cos(angle)])
current_point = rotated_point + translation_vector
# current_point += prev_point
return current_point
def plot_traj(frame, points):
ax.clear() # Clear the previous frame
ax.set_xlim(-10, 10)
ax.set_ylim(0, 10)
ax.set_xlabel('X axis')
ax.set_ylabel('Y axis')
current_point = points[frame]
# Plot the points
scatter = ax.scatter(current_point[0], current_point[1], s=50, color='blue')
ax.set_title(f'Trajectory Plot Animation (Frame {frame})')
return scatter,
def update(frame,raw_poincloud_data_for_plot,cluster_labels):
ax.clear() # Clear the previous frame
ax.set_xlim(-10, 10)
ax.set_ylim(0, 10)
ax.set_xlabel('X axis')
ax.set_ylabel('Y axis')
current_data = raw_poincloud_data_for_plot[frame]
labels = cluster_labels[frame]
scatter = ax.scatter(current_data[:, 0], current_data[:, 1], s=50)
scatter = ax.scatter([np.median(current_data[:, 0]),], [np.median(current_data[:, 1]),], s=50,color='red')
ax.set_title(f'3D Scatter Plot Animation (Frame {frame})')
fig.tight_layout()
return scatter,
class DetectStatic:
def __init__(self,vel_eps=0.0005, xyz_std=1, min_points=50):
self.min_max_scaler=MinMaxScaler()
self.vel_scanner = DBSCAN(eps=vel_eps, min_samples=5)
self.xy_scanner= lambda e: (np.linalg.norm(e[:,:2].std(axis=0))<xyz_std) and (e.shape[0]>min_points)
def static_clusters(self,pointCloud): #col_vec of vel
self.vel_scanner.fit(self.min_max_scaler.fit_transform(pointCloud[:,[3]]))
clusters=self.vel_scanner.labels_
unique_cids=np.unique(clusters)
#e[0]-->ucid, e[1]--> pointCloud
return dict(filter(lambda e: self.xy_scanner(e[1]),{ucid:pointCloud[np.where(clusters==ucid)] for ucid in unique_cids}.items()))
def point_cloud_frames(file_name = None):
info_dict = get_info(file_name)
run_data_read_only_sensor(info_dict)
bin_filename = 'datasets/only_sensor' + info_dict['filename'][0]
bin_reader = RawDataReader(bin_filename)
total_frame_number = int(info_dict[' Nf'][0])
pointCloudProcessCFG = PointCloudProcessCFG()
velocities = []
for frame_no in range(total_frame_number):
bin_frame = bin_reader.getNextFrame(pointCloudProcessCFG.frameConfig)
np_frame = bin2np_frame(bin_frame)
frameConfig = pointCloudProcessCFG.frameConfig
reshapedFrame = frameReshape(np_frame, frameConfig)
rangeResult = rangeFFT(reshapedFrame, frameConfig)
range_result_absnormal_split = []
for i in range(pointCloudProcessCFG.frameConfig.numTxAntennas):
for j in range(pointCloudProcessCFG.frameConfig.numRxAntennas):
r_r = np.abs(rangeResult[i][j])
r_r[:, 0:10] = 0
min_val = np.min(r_r)
max_val = np.max(r_r)
r_r_normalise = (r_r - min_val) / (max_val - min_val) * 1000
range_result_absnormal_split.append(r_r_normalise)
range_abs_combined_nparray = np.zeros((pointCloudProcessCFG.frameConfig.numLoopsPerFrame, pointCloudProcessCFG.frameConfig.numADCSamples))
for ele in range_result_absnormal_split:
range_abs_combined_nparray += ele
range_abs_combined_nparray /= (pointCloudProcessCFG.frameConfig.numTxAntennas * pointCloudProcessCFG.frameConfig.numRxAntennas)
range_abs_combined_nparray_collapsed = np.sum(range_abs_combined_nparray, axis=0) / pointCloudProcessCFG.frameConfig.numLoopsPerFrame
peaks, _ = find_peaks(range_abs_combined_nparray_collapsed)
intensities_peaks = [[range_abs_combined_nparray_collapsed[idx], idx] for idx in peaks]
peaks = [i[1] for i in sorted(intensities_peaks, reverse=True)[:3]]
dopplerResult = dopplerFFT(rangeResult, frameConfig)
pointCloud = frame2pointcloud(dopplerResult, pointCloudProcessCFG)
vel_array_frame = np.array(get_velocity(rangeResult, peaks, info_dict)).flatten()
mean_velocity = np.median(vel_array_frame)
yield pointCloud, mean_velocity
gen=point_cloud_frames(file_name = "2024-03-29_vicon_test_15.bin")
total_data = []
total_ids = []
total_frames=0
sdetect=DetectStatic()
first_frame = True
initial_coordinates = {}
current_cluster = {}
points = []
prev_point = np.array([0,0])
for frame, v_b in gen:
clusters=sdetect.static_clusters(frame)
datas=[];ids=[]
for c,p in clusters.items():
if first_frame:
initial_coordinates.update({c:np.array([[np.median(p[:,0])],[np.median(p[:,1])]])})
first_frame = False
continue
# print(c, p.shape)
datas.extend(p)
ids.extend([c]*len(p))
current_cluster.update({c:np.array([[np.median(p[:,0])],[np.median(p[:,1])]])})
prev_point = get_traj(initial_coordinates[c],current_cluster[c],v_b, 0.2, prev_point)
initial_coordinates.update({c:np.array([[np.median(p[:,0])],[np.median(p[:,1])]])})
points.append(prev_point)
if len(datas) == 0:
continue
print(f"Frame number: {total_frames}")
total_data.append(np.array(datas))
total_ids.append(np.array(ids))
total_frames+=1
# anim = FuncAnimation(fig, update, frames=total_frames, interval=50, blit=True, fargs=(total_data,total_ids,))
# anim.save('3d_scatter_animation_new.gif', writer='ffmpeg', fps=10)
anim = FuncAnimation(fig, plot_traj, frames=total_frames, interval=50, blit=True, fargs=(points,))
anim.save('plot_trajectory.gif', writer='ffmpeg', fps=10)