|
|
@ -27,7 +27,7 @@ class CarController(): |
|
|
|
self.packer_obj = CANPacker(DBC[CP.carFingerprint]['radar']) |
|
|
|
self.packer_obj = CANPacker(DBC[CP.carFingerprint]['radar']) |
|
|
|
self.packer_ch = CANPacker(DBC[CP.carFingerprint]['chassis']) |
|
|
|
self.packer_ch = CANPacker(DBC[CP.carFingerprint]['chassis']) |
|
|
|
|
|
|
|
|
|
|
|
def update(self, enabled, CS, frame, actuators, |
|
|
|
def update(self, c, enabled, CS, frame, actuators, |
|
|
|
hud_v_cruise, hud_show_lanes, hud_show_car, hud_alert): |
|
|
|
hud_v_cruise, hud_show_lanes, hud_show_car, hud_alert): |
|
|
|
|
|
|
|
|
|
|
|
P = self.params |
|
|
|
P = self.params |
|
|
@ -41,7 +41,7 @@ class CarController(): |
|
|
|
if CS.lka_steering_cmd_counter != self.lka_steering_cmd_counter_last: |
|
|
|
if CS.lka_steering_cmd_counter != self.lka_steering_cmd_counter_last: |
|
|
|
self.lka_steering_cmd_counter_last = CS.lka_steering_cmd_counter |
|
|
|
self.lka_steering_cmd_counter_last = CS.lka_steering_cmd_counter |
|
|
|
elif (frame % P.STEER_STEP) == 0: |
|
|
|
elif (frame % P.STEER_STEP) == 0: |
|
|
|
lkas_enabled = enabled and not (CS.out.steerWarning or CS.out.steerError) and CS.out.vEgo > P.MIN_STEER_SPEED |
|
|
|
lkas_enabled = c.active and not (CS.out.steerWarning or CS.out.steerError) and CS.out.vEgo > P.MIN_STEER_SPEED |
|
|
|
if lkas_enabled: |
|
|
|
if lkas_enabled: |
|
|
|
new_steer = int(round(actuators.steer * P.STEER_MAX)) |
|
|
|
new_steer = int(round(actuators.steer * P.STEER_MAX)) |
|
|
|
apply_steer = apply_std_steer_torque_limits(new_steer, self.apply_steer_last, CS.out.steeringTorque, P) |
|
|
|
apply_steer = apply_std_steer_torque_limits(new_steer, self.apply_steer_last, CS.out.steeringTorque, P) |
|
|
@ -58,7 +58,7 @@ class CarController(): |
|
|
|
|
|
|
|
|
|
|
|
# Gas/regen and brakes - all at 25Hz |
|
|
|
# Gas/regen and brakes - all at 25Hz |
|
|
|
if (frame % 4) == 0: |
|
|
|
if (frame % 4) == 0: |
|
|
|
if not enabled: |
|
|
|
if not c.active: |
|
|
|
# Stock ECU sends max regen when not enabled. |
|
|
|
# Stock ECU sends max regen when not enabled. |
|
|
|
self.apply_gas = P.MAX_ACC_REGEN |
|
|
|
self.apply_gas = P.MAX_ACC_REGEN |
|
|
|
self.apply_brake = 0 |
|
|
|
self.apply_brake = 0 |
|
|
|