You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							54 lines
						
					
					
						
							2.2 KiB
						
					
					
				
			
		
		
	
	
							54 lines
						
					
					
						
							2.2 KiB
						
					
					
				| import math
 | |
| from enum import StrEnum, auto
 | |
| 
 | |
| from cereal import car, messaging
 | |
| from openpilot.common.realtime import DT_CTRL
 | |
| from openpilot.selfdrive.locationd.helpers import Pose
 | |
| from opendbc.car import ACCELERATION_DUE_TO_GRAVITY
 | |
| from opendbc.car.lateral import ISO_LATERAL_ACCEL
 | |
| from opendbc.car.interfaces import ACCEL_MIN, ACCEL_MAX
 | |
| 
 | |
| MIN_EXCESSIVE_ACTUATION_COUNT = int(0.25 / DT_CTRL)
 | |
| MIN_LATERAL_ENGAGE_BUFFER = int(1 / DT_CTRL)
 | |
| 
 | |
| 
 | |
| class ExcessiveActuationType(StrEnum):
 | |
|   LONGITUDINAL = auto()
 | |
|   LATERAL = auto()
 | |
| 
 | |
| 
 | |
| class ExcessiveActuationCheck:
 | |
|   def __init__(self):
 | |
|     self._excessive_counter = 0
 | |
|     self._engaged_counter = 0
 | |
| 
 | |
|   def update(self, sm: messaging.SubMaster, CS: car.CarState, calibrated_pose: Pose) -> ExcessiveActuationType | None:
 | |
|     # CS.aEgo can be noisy to bumps in the road, transitioning from standstill, losing traction, etc.
 | |
|     # longitudinal
 | |
|     accel_calibrated = calibrated_pose.acceleration.x
 | |
|     excessive_long_actuation = sm['carControl'].longActive and (accel_calibrated > ACCEL_MAX * 2 or accel_calibrated < ACCEL_MIN * 2)
 | |
| 
 | |
|     # lateral
 | |
|     yaw_rate = calibrated_pose.angular_velocity.yaw
 | |
|     roll = sm['liveParameters'].roll
 | |
|     roll_compensated_lateral_accel = (CS.vEgo * yaw_rate) - (math.sin(roll) * ACCELERATION_DUE_TO_GRAVITY)
 | |
| 
 | |
|     # Prevent false positives after overriding
 | |
|     excessive_lat_actuation = False
 | |
|     self._engaged_counter = self._engaged_counter + 1 if sm['carControl'].latActive and not CS.steeringPressed else 0
 | |
|     if self._engaged_counter > MIN_LATERAL_ENGAGE_BUFFER:
 | |
|       if abs(roll_compensated_lateral_accel) > ISO_LATERAL_ACCEL * 2:
 | |
|         excessive_lat_actuation = True
 | |
| 
 | |
|     # livePose acceleration can be noisy due to bad mounting or aliased livePose measurements
 | |
|     livepose_valid = abs(CS.aEgo - accel_calibrated) < 2
 | |
|     self._excessive_counter = self._excessive_counter + 1 if livepose_valid and (excessive_long_actuation or excessive_lat_actuation) else 0
 | |
| 
 | |
|     excessive_type = None
 | |
|     if self._excessive_counter > MIN_EXCESSIVE_ACTUATION_COUNT:
 | |
|       if excessive_long_actuation:
 | |
|         excessive_type = ExcessiveActuationType.LONGITUDINAL
 | |
|       else:
 | |
|         excessive_type = ExcessiveActuationType.LATERAL
 | |
| 
 | |
|     return excessive_type
 | |
| 
 |