|  |  | @ -3,7 +3,7 @@ import numpy as np | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | from cereal import log |  |  |  | from cereal import log | 
			
		
	
		
		
			
				
					
					|  |  |  | from common.realtime import DT_CTRL |  |  |  | from common.realtime import DT_CTRL | 
			
		
	
		
		
			
				
					
					|  |  |  | from common.numpy_fast import clip |  |  |  | from common.numpy_fast import clip, interp | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | from selfdrive.car.toyota.values import CarControllerParams |  |  |  | from selfdrive.car.toyota.values import CarControllerParams | 
			
		
	
		
		
			
				
					
					|  |  |  | from selfdrive.car import apply_toyota_steer_torque_limits |  |  |  | from selfdrive.car import apply_toyota_steer_torque_limits | 
			
		
	
		
		
			
				
					
					|  |  |  | from selfdrive.controls.lib.drive_helpers import get_steer_max |  |  |  | from selfdrive.controls.lib.drive_helpers import get_steer_max | 
			
		
	
	
		
		
			
				
					|  |  | @ -28,16 +28,18 @@ class LatControlINDI(): | 
			
		
	
		
		
			
				
					
					|  |  |  |                   [7.29394177e+00, 1.39159419e-02], |  |  |  |                   [7.29394177e+00, 1.39159419e-02], | 
			
		
	
		
		
			
				
					
					|  |  |  |                   [1.71022442e+01, 3.38495381e-02]]) |  |  |  |                   [1.71022442e+01, 3.38495381e-02]]) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     self.speed = 0. | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.K = K |  |  |  |     self.K = K | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.A_K = A - np.dot(K, C) |  |  |  |     self.A_K = A - np.dot(K, C) | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.x = np.array([[0.], [0.], [0.]]) |  |  |  |     self.x = np.array([[0.], [0.], [0.]]) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.enforce_rate_limit = CP.carName == "toyota" |  |  |  |     self.enforce_rate_limit = CP.carName == "toyota" | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.RC = CP.lateralTuning.indi.timeConstant |  |  |  |     self._RC = (CP.lateralTuning.indi.timeConstantBP, CP.lateralTuning.indi.timeConstantV) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     self.G = CP.lateralTuning.indi.actuatorEffectiveness |  |  |  |     self._G = (CP.lateralTuning.indi.actuatorEffectivenessBP, CP.lateralTuning.indi.actuatorEffectivenessV) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     self.outer_loop_gain = CP.lateralTuning.indi.outerLoopGain |  |  |  |     self._outer_loop_gain = (CP.lateralTuning.indi.outerLoopGainBP, CP.lateralTuning.indi.outerLoopGainV) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     self.inner_loop_gain = CP.lateralTuning.indi.innerLoopGain |  |  |  |     self._inner_loop_gain = (CP.lateralTuning.indi.innerLoopGainBP, CP.lateralTuning.indi.innerLoopGainV) | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     self.alpha = 1. - DT_CTRL / (self.RC + DT_CTRL) |  |  |  |     self.alpha = 1. - DT_CTRL / (self.RC + DT_CTRL) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.sat_count_rate = 1.0 * DT_CTRL |  |  |  |     self.sat_count_rate = 1.0 * DT_CTRL | 
			
		
	
	
		
		
			
				
					|  |  | @ -45,10 +47,27 @@ class LatControlINDI(): | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.reset() |  |  |  |     self.reset() | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   @property | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   def RC(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     return interp(self.speed, self._RC[0], self._RC[1]) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   @property | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   def G(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     return interp(self.speed, self._G[0], self._G[1]) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   @property | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   def outer_loop_gain(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     return interp(self.speed, self._outer_loop_gain[0], self._outer_loop_gain[1]) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   @property | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   def inner_loop_gain(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     return interp(self.speed, self._inner_loop_gain[0], self._inner_loop_gain[1]) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   def reset(self): |  |  |  |   def reset(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.delayed_output = 0. |  |  |  |     self.delayed_output = 0. | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.output_steer = 0. |  |  |  |     self.output_steer = 0. | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.sat_count = 0.0 |  |  |  |     self.sat_count = 0.0 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     self.speed = 0. | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   def _check_saturation(self, control, check_saturation, limit): |  |  |  |   def _check_saturation(self, control, check_saturation, limit): | 
			
		
	
		
		
			
				
					
					|  |  |  |     saturated = abs(control) == limit |  |  |  |     saturated = abs(control) == limit | 
			
		
	
	
		
		
			
				
					|  |  | @ -63,6 +82,7 @@ class LatControlINDI(): | 
			
		
	
		
		
			
				
					
					|  |  |  |     return self.sat_count > self.sat_limit |  |  |  |     return self.sat_count > self.sat_limit | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   def update(self, active, CS, CP, path_plan): |  |  |  |   def update(self, active, CS, CP, path_plan): | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     self.speed = CS.vEgo | 
			
		
	
		
		
			
				
					
					|  |  |  |     # Update Kalman filter |  |  |  |     # Update Kalman filter | 
			
		
	
		
		
			
				
					
					|  |  |  |     y = np.array([[math.radians(CS.steeringAngle)], [math.radians(CS.steeringRate)]]) |  |  |  |     y = np.array([[math.radians(CS.steeringAngle)], [math.radians(CS.steeringRate)]]) | 
			
		
	
		
		
			
				
					
					|  |  |  |     self.x = np.dot(self.A_K, self.x) + np.dot(self.K, y) |  |  |  |     self.x = np.dot(self.A_K, self.x) + np.dot(self.K, y) | 
			
		
	
	
		
		
			
				
					|  |  | 
 |