import  numpy  as  np 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  random 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  cereal . messaging  as  messaging 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  msgq . visionipc  import  VisionIpcServer ,  VisionStreamType 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  opendbc . car . car_helpers  import  get_demo_car_params 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  openpilot . common . params  import  Params 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  openpilot . common . transformations . camera  import  DEVICE_CAMERAS 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  openpilot . common . realtime  import  DT_MDL 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  openpilot . system . manager . process_config  import  managed_processes 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  openpilot . selfdrive . test . process_replay . vision_meta  import  meta_from_camera_state 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								CAM  =  DEVICE_CAMERAS [ ( " tici " ,  " ar0231 " ) ] . fcam 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								IMG  =  np . zeros ( int ( CAM . width * CAM . height * ( 3 / 2 ) ) ,  dtype = np . uint8 ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								IMG_BYTES  =  IMG . flatten ( ) . tobytes ( ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  TestModeld : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  def  setup_method ( self ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . vipc_server  =  VisionIpcServer ( " camerad " ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self . vipc_server . create_buffers ( VisionStreamType . VISION_STREAM_ROAD ,  40 ,  CAM . width ,  CAM . height ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . vipc_server . create_buffers ( VisionStreamType . VISION_STREAM_DRIVER ,  40 ,  CAM . width ,  CAM . height ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . vipc_server . create_buffers ( VisionStreamType . VISION_STREAM_WIDE_ROAD ,  40 ,  CAM . width ,  CAM . height ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . vipc_server . start_listener ( ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Params ( ) . put ( " CarParams " ,  get_demo_car_params ( ) . to_bytes ( ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . sm  =  messaging . SubMaster ( [ ' modelV2 ' ,  ' cameraOdometry ' ] ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self . pm  =  messaging . PubMaster ( [ ' roadCameraState ' ,  ' wideRoadCameraState ' ,  ' liveCalibration ' ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    managed_processes [ ' modeld ' ] . start ( ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self . pm . wait_for_readers_to_update ( " roadCameraState " ,  10 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  def  teardown_method ( self ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    managed_processes [ ' modeld ' ] . stop ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    del  self . vipc_server 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  def  _send_frames ( self ,  frame_id ,  cams = None ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  cams  is  None : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      cams  =  ( ' roadCameraState ' ,  ' wideRoadCameraState ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    cs  =  None 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  cam  in  cams : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      msg  =  messaging . new_message ( cam ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      cs  =  getattr ( msg ,  cam ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      cs . frameId  =  frame_id 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      cs . timestampSof  =  int ( ( frame_id  *  DT_MDL )  *  1e9 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      cs . timestampEof  =  int ( cs . timestampSof  +  ( DT_MDL  *  1e9 ) ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      cam_meta  =  meta_from_camera_state ( cam ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      self . pm . send ( msg . which ( ) ,  msg ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      self . vipc_server . send ( cam_meta . stream ,  IMG_BYTES ,  cs . frameId , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            cs . timestampSof ,  cs . timestampEof ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  cs 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  def  _wait ( self ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . sm . update ( 5000 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  self . sm [ ' modelV2 ' ] . frameId  !=  self . sm [ ' cameraOdometry ' ] . frameId : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      self . sm . update ( 1000 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  def  test_modeld ( self ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  n  in  range ( 1 ,  500 ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      cs  =  self . _send_frames ( n ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      self . _wait ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      mdl  =  self . sm [ ' modelV2 ' ] 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      assert  mdl . frameId  ==  n 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      assert  mdl . frameIdExtra  ==  n 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      assert  mdl . timestampEof  ==  cs . timestampEof 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      assert  mdl . frameAge  ==  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      assert  mdl . frameDropPerc  ==  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      odo  =  self . sm [ ' cameraOdometry ' ] 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      assert  odo . frameId  ==  n 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      assert  odo . timestampEof  ==  cs . timestampEof 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  def  test_dropped_frames ( self ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """ 
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      modeld  should  only  run  on  consecutive  road  frames 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """ 
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    frame_id  =  - 1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    road_frames  =  list ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  n  in  range ( 1 ,  50 ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  ( random . random ( )  <  0.1 )  and  n  >  3 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        cams  =  random . choice ( [ ( ) ,  ( ' wideRoadCameraState ' ,  ) ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . _send_frames ( n ,  cams ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      else : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . _send_frames ( n ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        road_frames . append ( n ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      self . _wait ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  len ( road_frames )  <  3  or  road_frames [ - 1 ]  -  road_frames [ - 2 ]  ==  1 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        frame_id  =  road_frames [ - 1 ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      mdl  =  self . sm [ ' modelV2 ' ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      odo  =  self . sm [ ' cameraOdometry ' ] 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      assert  mdl . frameId  ==  frame_id 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      assert  mdl . frameIdExtra  ==  frame_id 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      assert  odo . frameId  ==  frame_id 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  n  !=  frame_id : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        assert  not  self . sm . updated [ ' modelV2 ' ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        assert  not  self . sm . updated [ ' cameraOdometry ' ]