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
						
					
					
						
							795 B
						
					
					
				
			
		
		
	
	
							34 lines
						
					
					
						
							795 B
						
					
					
				| #!/usr/bin/env python3
 | |
| import cereal.messaging as messaging
 | |
| from typing import Optional
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|   modeld_sock = messaging.sub_sock("modelV2")
 | |
| 
 | |
|   last_frame_id = None
 | |
|   start_t: Optional[int] = 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
 | |
| 
 |