|  |  | @ -16,9 +16,8 @@ LON_MPC_N = 32 | 
			
		
	
		
		
			
				
					
					|  |  |  | CONTROL_N = 17 |  |  |  | CONTROL_N = 17 | 
			
		
	
		
		
			
				
					
					|  |  |  | CAR_ROTATION_RADIUS = 0.0 |  |  |  | CAR_ROTATION_RADIUS = 0.0 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | # this corresponds to 80deg/s and 20deg/s steering angle in a toyota corolla |  |  |  | # EU guidelines | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | MAX_CURVATURE_RATES = [0.03762194918267951, 0.003441203371932992] |  |  |  | MAX_LATERAL_JERK = 5.0 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | MAX_CURVATURE_RATE_SPEEDS = [0, 35] |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | CRUISE_LONG_PRESS = 50 |  |  |  | CRUISE_LONG_PRESS = 50 | 
			
		
	
		
		
			
				
					
					|  |  |  | CRUISE_NEAREST_FUNC = { |  |  |  | CRUISE_NEAREST_FUNC = { | 
			
		
	
	
		
		
			
				
					|  |  | @ -107,11 +106,13 @@ def get_lag_adjusted_curvature(CP, v_ego, psis, curvatures, curvature_rates): | 
			
		
	
		
		
			
				
					
					|  |  |  |   curvature_diff_from_psi = psi / (max(v_ego, 1e-1) * delay) - current_curvature |  |  |  |   curvature_diff_from_psi = psi / (max(v_ego, 1e-1) * delay) - current_curvature | 
			
		
	
		
		
			
				
					
					|  |  |  |   desired_curvature = current_curvature + 2 * curvature_diff_from_psi |  |  |  |   desired_curvature = current_curvature + 2 * curvature_diff_from_psi | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   max_curvature_rate = interp(v_ego, MAX_CURVATURE_RATE_SPEEDS, MAX_CURVATURE_RATES) |  |  |  |   v_ego = max(v_ego, 0.1) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   max_curvature_rate = MAX_LATERAL_JERK / (v_ego**2) | 
			
		
	
		
		
			
				
					
					|  |  |  |   safe_desired_curvature_rate = clip(desired_curvature_rate, |  |  |  |   safe_desired_curvature_rate = clip(desired_curvature_rate, | 
			
		
	
		
		
			
				
					
					|  |  |  |                                           -max_curvature_rate, |  |  |  |                                           -max_curvature_rate, | 
			
		
	
		
		
			
				
					
					|  |  |  |                                           max_curvature_rate) |  |  |  |                                           max_curvature_rate) | 
			
		
	
		
		
			
				
					
					|  |  |  |   safe_desired_curvature = clip(desired_curvature, |  |  |  |   safe_desired_curvature = clip(desired_curvature, | 
			
		
	
		
		
			
				
					
					|  |  |  |                                      current_curvature - max_curvature_rate * DT_MDL, |  |  |  |                                      current_curvature - max_curvature_rate * DT_MDL, | 
			
		
	
		
		
			
				
					
					|  |  |  |                                      current_curvature + max_curvature_rate * DT_MDL) |  |  |  |                                      current_curvature + max_curvature_rate * DT_MDL) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   return safe_desired_curvature, safe_desired_curvature_rate |  |  |  |   return safe_desired_curvature, safe_desired_curvature_rate | 
			
		
	
	
		
		
			
				
					|  |  | 
 |