|  |  | @ -31,6 +31,8 @@ CameraState::CameraState(MultiCameraState *multi_camera_state, const CameraConfi | 
			
		
	
		
		
			
				
					
					|  |  |  |     camera_num(config.camera_num), |  |  |  |     camera_num(config.camera_num), | 
			
		
	
		
		
			
				
					
					|  |  |  |     stream_type(config.stream_type), |  |  |  |     stream_type(config.stream_type), | 
			
		
	
		
		
			
				
					
					|  |  |  |     focal_len(config.focal_len), |  |  |  |     focal_len(config.focal_len), | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     publish_name(config.publish_name), | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     init_camera_state(config.init_camera_state), | 
			
		
	
		
		
			
				
					
					|  |  |  |     enabled(config.enabled) { |  |  |  |     enabled(config.enabled) { | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -941,33 +943,36 @@ void CameraState::set_camera_exposure(float grey_frac) { | 
			
		
	
		
		
			
				
					
					|  |  |  |   sensors_i2c(exp_reg_array.data(), exp_reg_array.size(), CAM_SENSOR_PACKET_OPCODE_SENSOR_CONFIG, ci->data_word); |  |  |  |   sensors_i2c(exp_reg_array.data(), exp_reg_array.size(), CAM_SENSOR_PACKET_OPCODE_SENSOR_CONFIG, ci->data_word); | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | static void process_driver_camera(MultiCameraState *s, CameraState *c, int cnt) { |  |  |  | void CameraState::run() { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   c->set_camera_exposure(set_exposure_target(&c->buf, c->ae_xywh, 2, 4)); |  |  |  |   util::set_thread_name(publish_name); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   for (uint32_t cnt = 0; !do_exit; ++cnt) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     // Acquire the buffer; continue if acquisition fails
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (!buf.acquire()) continue; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     MessageBuilder msg; |  |  |  |     MessageBuilder msg; | 
			
		
	
		
		
			
				
					
					|  |  |  |   auto framed = msg.initEvent().initDriverCameraState(); |  |  |  |     auto framed = (msg.initEvent().*init_camera_state)(); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   fill_frame_data(framed, c->buf.cur_frame_data, c); |  |  |  |     fill_frame_data(framed, buf.cur_frame_data, this); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   c->ci->processRegisters(c, framed); |  |  |  |     // Log raw frames for road camera
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   s->pm->send("driverCameraState", msg); |  |  |  |     if (env_log_raw_frames && stream_type == VISION_STREAM_ROAD && cnt % 100 == 5) {  // no overlap with qlog decimation
 | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       framed.setImage(get_raw_frame_image(&buf)); | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |     // Log frame id for road and wide road cameras
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | void process_road_camera(MultiCameraState *s, CameraState *c, int cnt) { |  |  |  |     if (stream_type != VISION_STREAM_DRIVER) { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   const CameraBuf *b = &c->buf; |  |  |  |       LOGT(buf.cur_frame_data.frame_id, "%s: Image set", publish_name); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   MessageBuilder msg; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   auto framed = c == &s->road_cam ? msg.initEvent().initRoadCameraState() : msg.initEvent().initWideRoadCameraState(); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   fill_frame_data(framed, b->cur_frame_data, c); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   if (env_log_raw_frames && c == &s->road_cam && cnt % 100 == 5) {  // no overlap with qlog decimation
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     framed.setImage(get_raw_frame_image(b)); |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   LOGT(c->buf.cur_frame_data.frame_id, "%s: Image set", c == &s->road_cam ? "RoadCamera" : "WideRoadCamera"); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   c->ci->processRegisters(c, framed); |  |  |  |     // Process camera registers and set camera exposure
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   s->pm->send(c == &s->road_cam ? "roadCameraState" : "wideRoadCameraState", msg); |  |  |  |     ci->processRegisters(this, framed); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     set_camera_exposure(set_exposure_target(&buf, ae_xywh, 2, stream_type != VISION_STREAM_DRIVER ? 2 : 4)); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   const int skip = 2; |  |  |  |     // Send the message
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   c->set_camera_exposure(set_exposure_target(b, c->ae_xywh, skip, skip)); |  |  |  |     multi_cam_state->pm->send(publish_name, msg); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (stream_type == VISION_STREAM_ROAD && cnt % 100 == 3) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       publish_thumbnail(multi_cam_state->pm, &buf);  // this takes 10ms???
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | MultiCameraState::MultiCameraState() |  |  |  | MultiCameraState::MultiCameraState() | 
			
		
	
	
		
		
			
				
					|  |  | @ -979,9 +984,9 @@ MultiCameraState::MultiCameraState() | 
			
		
	
		
		
			
				
					
					|  |  |  | void cameras_run(MultiCameraState *s) { |  |  |  | void cameras_run(MultiCameraState *s) { | 
			
		
	
		
		
			
				
					
					|  |  |  |   LOG("-- Starting threads"); |  |  |  |   LOG("-- Starting threads"); | 
			
		
	
		
		
			
				
					
					|  |  |  |   std::vector<std::thread> threads; |  |  |  |   std::vector<std::thread> threads; | 
			
		
	
		
		
			
				
					
					|  |  |  |   if (s->driver_cam.enabled) threads.push_back(start_process_thread(s, &s->driver_cam, process_driver_camera)); |  |  |  |   if (s->driver_cam.enabled) threads.emplace_back(&CameraState::run, &s->driver_cam); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   if (s->road_cam.enabled) threads.push_back(start_process_thread(s, &s->road_cam, process_road_camera)); |  |  |  |   if (s->road_cam.enabled) threads.emplace_back(&CameraState::run, &s->road_cam); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   if (s->wide_road_cam.enabled) threads.push_back(start_process_thread(s, &s->wide_road_cam, process_road_camera)); |  |  |  |   if (s->wide_road_cam.enabled) threads.emplace_back(&CameraState::run, &s->wide_road_cam); | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   // start devices
 |  |  |  |   // start devices
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   LOG("-- Starting devices"); |  |  |  |   LOG("-- Starting devices"); | 
			
		
	
	
		
		
			
				
					|  |  | 
 |