You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
34 lines
764 B
34 lines
764 B
11 months ago
|
#!/usr/bin/env python3
|
||
|
import cereal.messaging as messaging
|
||
|
|
||
|
if __name__ == "__main__":
|
||
|
modeld_sock = messaging.sub_sock("modelV2")
|
||
|
|
||
|
last_frame_id = None
|
||
|
start_t: int | None = None
|
||
|
frame_cnt = 0
|
||
|
dropped = 0
|
||
|
|
||
|
while True:
|
||
|
m = messaging.recv_one(modeld_sock)
|
||
|
if m is None:
|
||
|
continue
|
||
|
|
||
|
frame_id = m.modelV2.frameId
|
||
|
t = m.logMonoTime / 1e9
|
||
|
frame_cnt += 1
|
||
|
|
||
|
if start_t is None:
|
||
|
start_t = t
|
||
|
last_frame_id = frame_id
|
||
|
continue
|
||
|
|
||
|
d_frame = frame_id - last_frame_id
|
||
|
dropped += d_frame - 1
|
||
|
|
||
|
expected_num_frames = int((t - start_t) * 20)
|
||
|
frame_drop = 100 * (1 - (expected_num_frames / frame_cnt))
|
||
|
print(f"Num dropped {dropped}, Drop compared to 20Hz: {frame_drop:.2f}%")
|
||
|
|
||
|
last_frame_id = frame_id
|