from common . numpy_fast import clip
from cereal import car
class EventTypes :
ENABLE = ' enable '
PRE_ENABLE = ' preEnable '
NO_ENTRY = ' noEntry '
WARNING = ' warning '
USER_DISABLE = ' userDisable '
SOFT_DISABLE = ' softDisable '
IMMEDIATE_DISABLE = ' immediateDisable '
def create_event ( name , types ) :
event = car . CarEvent . new_message ( )
event . name = name
for t in types :
setattr ( event , t , True )
return event
def get_events ( events , types ) :
out = [ ]
for e in events :
for t in types :
if getattr ( e , t ) :
out . append ( e . name )
return out
def rate_limit ( new_value , last_value , dw_step , up_step ) :
return clip ( new_value , last_value + dw_step , last_value + up_step )
def learn_angle_offset ( lateral_control , v_ego , angle_offset , c_poly , c_prob , angle_steers , steer_override ) :
# simple integral controller that learns how much steering offset to put to have the car going straight
# while being in the middle of the lane
min_offset = - 5. # deg
max_offset = 5. # deg
alpha = 1. / 36000. # correct by 1 deg in 2 mins, at 30m/s, with 50cm of error, at 20Hz
min_learn_speed = 1.
# learn less at low speed or when turning
alpha_v = alpha * c_prob * ( max ( v_ego - min_learn_speed , 0. ) ) / ( 1. + 0.2 * abs ( angle_steers ) )
# only learn if lateral control is active and if driver is not overriding:
if lateral_control and not steer_override :
angle_offset + = c_poly [ 3 ] * alpha_v
angle_offset = clip ( angle_offset , min_offset , max_offset )
return angle_offset