#!/usr/bin/env python3 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								# type: ignore 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  carla  # pylint: disable=import-error 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  time 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  math 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  atexit 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  numpy  as  np 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  threading 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  cereal . messaging  as  messaging 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  argparse 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from  common . params  import  Params 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  common . realtime  import  Ratekeeper ,  DT_DMON 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from  lib . can  import  can_function 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  selfdrive . car . honda . values  import  CruiseButtons 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  selfdrive . test . helpers  import  set_params_enabled 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								parser  =  argparse . ArgumentParser ( description = ' Bridge between CARLA and openpilot. ' ) 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								parser . add_argument ( ' --joystick ' ,  action = ' store_true ' ) 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								parser . add_argument ( ' --town ' ,  type = str ,  default = ' Town04 ' ) 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								parser . add_argument ( ' --spawn_point ' ,  dest = ' num_selected_spawn_point ' , 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        type = int ,  default = 16 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								parser . add_argument ( ' --cloudyness ' ,  default = 0.1 ,  type = float ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								parser . add_argument ( ' --precipitation ' ,  default = 0.0 ,  type = float ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								parser . add_argument ( ' --precipitation_deposits ' ,  default = 0.0 ,  type = float ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								parser . add_argument ( ' --wind_intensity ' ,  default = 0.0 ,  type = float ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								parser . add_argument ( ' --sun_azimuth_angle ' ,  default = 15.0 ,  type = float ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								parser . add_argument ( ' --sun_altitude_angle ' ,  default = 75.0 ,  type = float ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								args  =  parser . parse_args ( ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								W ,  H  =  1164 ,  874 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								REPEAT_COUNTER  =  5 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								PRINT_DECIMATION  =  100 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								STEER_RATIO  =  15. 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pm  =  messaging . PubMaster ( [ ' frame ' ,  ' sensorEvents ' ,  ' can ' ] ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								sm  =  messaging . SubMaster ( [ ' carControl ' , ' controlsState ' ] ) 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class  VehicleState : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  def  __init__ ( self ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . speed  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . angle  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . cruise_button =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self . is_engaged = False 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  steer_rate_limit ( old ,  new ) : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # Rate limiting to 0.5 degrees per step 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  limit  =  0.5 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  if  new  >  old  +  limit : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  old  +  limit 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  elif  new  <  old  -  limit : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  old  -  limit 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  else : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  new 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								frame_id  =  0 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  cam_callback ( image ) : 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  global  frame_id 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  img  =  np . frombuffer ( image . raw_data ,  dtype = np . dtype ( " uint8 " ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  img  =  np . reshape ( img ,  ( H ,  W ,  4 ) ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  img  =  img [ : ,  : ,  [ 0 ,  1 ,  2 ] ] . copy ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  dat  =  messaging . new_message ( ' frame ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . frame  =  { 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " frameId " :  image . frame , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " image " :  img . tostring ( ) , 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " transform " :  [ 1.0 ,  0.0 ,  0.0 ,  0.0 ,  1.0 ,  0.0 ,  0.0 ,  0.0 ,  1.0 ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  } 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  pm . send ( ' frame ' ,  dat ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  frame_id  + =  1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  imu_callback ( imu ) : 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  dat  =  messaging . new_message ( ' sensorEvents ' ,  2 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 0 ] . sensor  =  4 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 0 ] . type  =  0x10 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 0 ] . init ( ' acceleration ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 0 ] . acceleration . v  =  [ imu . accelerometer . x ,  imu . accelerometer . y ,  imu . accelerometer . z ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # copied these numbers from locationd 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 1 ] . sensor  =  5 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 1 ] . type  =  0x10 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 1 ] . init ( ' gyroUncalibrated ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  dat . sensorEvents [ 1 ] . gyroUncalibrated . v  =  [ imu . gyroscope . x ,  imu . gyroscope . y ,  imu . gyroscope . z ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  pm . send ( ' sensorEvents ' ,  dat ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  health_function ( ) : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  pm  =  messaging . PubMaster ( [ ' health ' ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  while  1 : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    dat  =  messaging . new_message ( ' health ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    dat . valid  =  True 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    dat . health  =  { 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      ' ignitionLine ' :  True , 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      ' pandaType ' :  " blackPanda " , 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      ' controlsAllowed ' :  True , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      ' safetyModel ' :  ' hondaNidec ' 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    pm . send ( ' health ' ,  dat ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    time . sleep ( 0.5 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  fake_gps ( ) : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # TODO: read GPS from CARLA 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  pm  =  messaging . PubMaster ( [ ' gpsLocationExternal ' ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  while  1 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    dat  =  messaging . new_message ( ' gpsLocationExternal ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    pm . send ( ' gpsLocationExternal ' ,  dat ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    time . sleep ( 0.01 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  fake_driver_monitoring ( ) : 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  pm  =  messaging . PubMaster ( [ ' driverState ' , ' driverMonitoringState ' ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  while  1 : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # dmonitoringmodeld output 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    dat  =  messaging . new_message ( ' driverState ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    dat . driverState . faceProb  =  1.0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    pm . send ( ' driverState ' ,  dat ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # dmonitoringd output 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    dat  =  messaging . new_message ( ' driverMonitoringState ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    dat . driverMonitoringState  =  { 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      " faceDetected " :  True , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      " isDistracted " :  False , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      " awarenessStatus " :  1. , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      " isRHD " :  False , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pm . send ( ' driverMonitoringState ' ,  dat ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    time . sleep ( DT_DMON ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  can_function_runner ( vs ) : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  i  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  while  1 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    can_function ( pm ,  vs . speed ,  vs . angle ,  i ,  vs . cruise_button ,  vs . is_engaged ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    time . sleep ( 0.01 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    i + = 1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  go ( q ) : 
 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  # setup CARLA 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  client  =  carla . Client ( " 127.0.0.1 " ,  2000 ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  client . set_timeout ( 10.0 ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  world  =  client . load_world ( args . town ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blueprint_library  =  world . get_blueprint_library ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  world_map  =  world . get_map ( ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  vehicle_bp  =  blueprint_library . filter ( ' vehicle.tesla.* ' ) [ 0 ] 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  spawn_points  =  world_map . get_spawn_points ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  assert  len ( spawn_points )  >  args . num_selected_spawn_point ,  \
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    f ''' No spawn point  { args . num_selected_spawn_point } , try a value between 0 and 
   
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    { len ( spawn_points ) }  for  this  town . ''' 
   
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  spawn_point  =  spawn_points [ args . num_selected_spawn_point ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  vehicle  =  world . spawn_actor ( vehicle_bp ,  spawn_point ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  max_steer_angle  =  vehicle . get_physics_control ( ) . wheels [ 0 ] . max_steer_angle 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  # make tires less slippery 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  # wheel_control = carla.WheelPhysicsControl(tire_friction=5) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  physics_control  =  vehicle . get_physics_control ( ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  physics_control . mass  =  2326 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # physics_control.wheels = [wheel_control]*4 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  physics_control . torque_curve  =  [ [ 20.0 ,  500.0 ] ,  [ 5000.0 ,  500.0 ] ] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  physics_control . gear_switch_time  =  0.0 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  vehicle . apply_physics_control ( physics_control ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blueprint  =  blueprint_library . find ( ' sensor.camera.rgb ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blueprint . set_attribute ( ' image_size_x ' ,  str ( W ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blueprint . set_attribute ( ' image_size_y ' ,  str ( H ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blueprint . set_attribute ( ' fov ' ,  ' 70 ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  blueprint . set_attribute ( ' sensor_tick ' ,  ' 0.05 ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  transform  =  carla . Transform ( carla . Location ( x = 0.8 ,  z = 1.45 ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  camera  =  world . spawn_actor ( blueprint ,  transform ,  attach_to = vehicle ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  camera . listen ( cam_callback ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  world . set_weather ( carla . WeatherParameters ( 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    cloudyness = args . cloudyness , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    precipitation = args . precipitation , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    precipitation_deposits = args . precipitation_deposits , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    wind_intensity = args . wind_intensity , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sun_azimuth_angle = args . sun_azimuth_angle , 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sun_altitude_angle = args . sun_altitude_angle 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  # reenable IMU 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  imu_bp  =  blueprint_library . find ( ' sensor.other.imu ' ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  imu  =  world . spawn_actor ( imu_bp ,  transform ,  attach_to = vehicle ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  imu . listen ( imu_callback ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  def  destroy ( ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    print ( " clean exit " ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    imu . destroy ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    camera . destroy ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vehicle . destroy ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    print ( " done " ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  atexit . register ( destroy ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  vehicle_state  =  VehicleState ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # launch fake car threads 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  threading . Thread ( target = health_function ) . start ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  threading . Thread ( target = fake_driver_monitoring ) . start ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  threading . Thread ( target = fake_gps ) . start ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  threading . Thread ( target = can_function_runner ,  args = ( vehicle_state , ) ) . start ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # can loop 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  rk  =  Ratekeeper ( 100 ,  print_delay_threshold = 0.05 ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # init 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  throttle_ease_out_counter  =  REPEAT_COUNTER 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  brake_ease_out_counter  =  REPEAT_COUNTER 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  steer_ease_out_counter  =  REPEAT_COUNTER 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  vc  =  carla . VehicleControl ( throttle = 0 ,  steer = 0 ,  brake = 0 ,  reverse = False ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  is_openpilot_engaged  =  False 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  throttle_out  =  steer_out  =  brake_out  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  throttle_op  =  steer_op  =  brake_op  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  throttle_manual  =  steer_manual  =  brake_manual  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  old_steer  =  old_brake  =  old_throttle  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  throttle_manual_multiplier  =  0.7  #keyboard signal is always 1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  brake_manual_multiplier  =  0.7  #keyboard signal is always 1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  steer_manual_multiplier  =  45  *  STEER_RATIO   #keyboard signal is always 1 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  while  1 : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # 1. Read the throttle, steer and brake from op or manual controls 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # 2. Set instructions in Carla 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # 3. Send current carstate to op via can 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    cruise_button  =  0 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    throttle_out  =  steer_out  =  brake_out  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    throttle_op  =  steer_op  =  brake_op  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    throttle_manual  =  steer_manual  =  brake_manual  =  0 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # --------------Step 1------------------------------- 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  not  q . empty ( ) : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      message  =  q . get ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      m  =  message . split ( ' _ ' ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      if  m [ 0 ]  ==  " steer " : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        steer_manual  =  float ( m [ 1 ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        is_openpilot_engaged  =  False 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      if  m [ 0 ]  ==  " throttle " : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        throttle_manual  =  float ( m [ 1 ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        is_openpilot_engaged  =  False 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      if  m [ 0 ]  ==  " brake " : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        brake_manual  =  float ( m [ 1 ] ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        is_openpilot_engaged  =  False 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      if  m [ 0 ]  ==  " reverse " : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        #in_reverse = not in_reverse 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        cruise_button  =  CruiseButtons . CANCEL 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								        is_openpilot_engaged  =  False 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  m [ 0 ]  ==  " cruise " : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  m [ 1 ]  ==  " down " : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								          cruise_button  =  CruiseButtons . DECEL_SET 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								          is_openpilot_engaged  =  True 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  m [ 1 ]  ==  " up " : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								          cruise_button  =  CruiseButtons . RES_ACCEL 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								          is_openpilot_engaged  =  True 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  m [ 1 ]  ==  " cancel " : 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								          cruise_button  =  CruiseButtons . CANCEL 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								          is_openpilot_engaged  =  False 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								      throttle_out  =  throttle_manual  *  throttle_manual_multiplier 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      steer_out  =  steer_manual  *  steer_manual_multiplier 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      brake_out  =  brake_manual  *  brake_manual_multiplier 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      #steer_out = steer_out 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      # steer_out = steer_rate_limit(old_steer, steer_out) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      old_steer  =  steer_out 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      old_throttle  =  throttle_out 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      old_brake  =  brake_out 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      # print('message',old_throttle, old_steer, old_brake) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  is_openpilot_engaged : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      sm . update ( 0 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      throttle_op  =  sm [ ' carControl ' ] . actuators . gas  #[0,1] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      brake_op  =  sm [ ' carControl ' ] . actuators . brake  #[0,1] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      steer_op  =  sm [ ' controlsState ' ] . angleSteersDes  # degrees [-180,180] 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      throttle_out  =  throttle_op 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      steer_out  =  steer_op 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      brake_out  =  brake_op 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      steer_out  =  steer_rate_limit ( old_steer ,  steer_out ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      old_steer  =  steer_out 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # OP Exit conditions 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # if throttle_out > 0.3: 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #   cruise_button = CruiseButtons.CANCEL 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #   is_openpilot_engaged = False 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # if brake_out > 0.3: 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #   cruise_button = CruiseButtons.CANCEL 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #   is_openpilot_engaged = False 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # if steer_out > 0.3: 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #   cruise_button = CruiseButtons.CANCEL 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #   is_openpilot_engaged = False 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  throttle_out == 0  and  old_throttle > 0 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  throttle_ease_out_counter > 0 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          throttle_out  =  old_throttle 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          throttle_ease_out_counter  + =  - 1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          throttle_ease_out_counter  =  REPEAT_COUNTER 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          old_throttle  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  brake_out == 0  and  old_brake > 0 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  brake_ease_out_counter > 0 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          brake_out  =  old_brake 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          brake_ease_out_counter  + =  - 1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          brake_ease_out_counter  =  REPEAT_COUNTER 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          old_brake  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      if  steer_out == 0  and  old_steer != 0 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  steer_ease_out_counter > 0 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          steer_out  =  old_steer 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          steer_ease_out_counter  + =  - 1 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          steer_ease_out_counter  =  REPEAT_COUNTER 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          old_steer  =  0 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # --------------Step 2------------------------------- 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steer_carla  =  steer_out  /  ( max_steer_angle  *  STEER_RATIO  *  - 1 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steer_carla  =  np . clip ( steer_carla ,  - 1 , 1 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    steer_out  =  steer_carla  *  ( max_steer_angle  *  STEER_RATIO  *  - 1 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    old_steer  =  steer_carla  *  ( max_steer_angle  *  STEER_RATIO  *  - 1 ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vc . throttle  =  throttle_out / 0.6 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vc . steer  =  steer_carla 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vc . brake  =  brake_out 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vehicle . apply_control ( vc ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # --------------Step 3------------------------------- 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    vel  =  vehicle . get_velocity ( ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								    speed  =  math . sqrt ( vel . x * * 2  +  vel . y * * 2  +  vel . z * * 2 )  # in m/s 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vehicle_state . speed  =  speed 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vehicle_state . angle  =  steer_out 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vehicle_state . cruise_button  =  cruise_button 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vehicle_state . is_engaged  =  is_openpilot_engaged 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  rk . frame % PRINT_DECIMATION  ==  0 : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      print ( " frame:  " ,  " engaged: " ,  is_openpilot_engaged ,  " ; throttle:  " ,  round ( vc . throttle ,  3 ) ,  " ; steer(c/deg):  " ,  round ( vc . steer ,  3 ) ,  round ( steer_out ,  3 ) ,  " ; brake:  " ,  round ( vc . brake ,  3 ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    rk . keep_time ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if  __name__  ==  " __main__ " : 
 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  # make sure params are in a good state 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  params  =  Params ( ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  params . clear_all ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  set_params_enabled ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  params . delete ( " Offroad_ConnectivityNeeded " ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  params . put ( " CalibrationParams " ,  ' { " calib_radians " : [0,0,0],  " valid_blocks " : 20} ' ) 
  
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
									
										 
								
							 
							
								 
							
							
								  from  multiprocessing  import  Process ,  Queue 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  q  =  Queue ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  p  =  Process ( target = go ,  args = ( q , ) ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  p . daemon  =  True 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  p . start ( ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  if  args . joystick : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # start input poll for joystick 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    from  lib . manual_ctrl  import  wheel_poll_thread 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    wheel_poll_thread ( q ) 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  else : 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # start input poll for keyboard 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    from  lib . keyboard_ctrl  import  keyboard_poll_thread 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    keyboard_poll_thread ( q )