|  |  |  | @ -53,20 +53,21 @@ class LongControl(): | 
			
		
	
		
			
				
					|  |  |  |  |     self.pid.reset() | 
			
		
	
		
			
				
					|  |  |  |  |     self.v_pid = v_pid | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |   def update(self, active, CS, CP, long_plan, accel_limits): | 
			
		
	
		
			
				
					|  |  |  |  |   def update(self, active, CS, CP, long_plan, accel_limits, t_since_plan): | 
			
		
	
		
			
				
					|  |  |  |  |     """Update longitudinal control. This updates the state machine and runs a PID loop""" | 
			
		
	
		
			
				
					|  |  |  |  |     # Interp control trajectory | 
			
		
	
		
			
				
					|  |  |  |  |     # TODO estimate car specific lag, use .15s for now | 
			
		
	
		
			
				
					|  |  |  |  |     speeds = long_plan.speeds | 
			
		
	
		
			
				
					|  |  |  |  |     if len(speeds) == CONTROL_N: | 
			
		
	
		
			
				
					|  |  |  |  |       v_target_lower = interp(CP.longitudinalActuatorDelayLowerBound, T_IDXS[:CONTROL_N], speeds) | 
			
		
	
		
			
				
					|  |  |  |  |       a_target_lower = 2 * (v_target_lower - speeds[0])/CP.longitudinalActuatorDelayLowerBound - long_plan.accels[0] | 
			
		
	
		
			
				
					|  |  |  |  |       v_target = interp(t_since_plan, T_IDXS[:CONTROL_N], speeds) | 
			
		
	
		
			
				
					|  |  |  |  |       a_target = interp(t_since_plan, T_IDXS[:CONTROL_N], long_plan.accels) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |       v_target_upper = interp(CP.longitudinalActuatorDelayUpperBound, T_IDXS[:CONTROL_N], speeds) | 
			
		
	
		
			
				
					|  |  |  |  |       a_target_upper = 2 * (v_target_upper - speeds[0])/CP.longitudinalActuatorDelayUpperBound - long_plan.accels[0] | 
			
		
	
		
			
				
					|  |  |  |  |       v_target_lower = interp(CP.longitudinalActuatorDelayLowerBound + t_since_plan, T_IDXS[:CONTROL_N], speeds) | 
			
		
	
		
			
				
					|  |  |  |  |       a_target_lower = 2 * (v_target_lower - v_target) / CP.longitudinalActuatorDelayLowerBound - a_target | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |       v_target_upper = interp(CP.longitudinalActuatorDelayUpperBound + t_since_plan, T_IDXS[:CONTROL_N], speeds) | 
			
		
	
		
			
				
					|  |  |  |  |       a_target_upper = 2 * (v_target_upper - v_target) / CP.longitudinalActuatorDelayUpperBound - a_target | 
			
		
	
		
			
				
					|  |  |  |  |       a_target = min(a_target_lower, a_target_upper) | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |       v_target = speeds[0] | 
			
		
	
		
			
				
					|  |  |  |  |       v_target_future = speeds[-1] | 
			
		
	
		
			
				
					|  |  |  |  |     else: | 
			
		
	
		
			
				
					|  |  |  |  |       v_target = 0.0 | 
			
		
	
	
		
			
				
					|  |  |  | 
 |