carstate.py 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. import copy
  2. from collections import deque
  3. from cereal import car
  4. from common.conversions import Conversions as CV
  5. from selfdrive.car.tesla.values import DBC, CANBUS, GEAR_MAP, DOORS, BUTTONS
  6. from selfdrive.car.interfaces import CarStateBase
  7. from opendbc.can.parser import CANParser
  8. from opendbc.can.can_define import CANDefine
  9. class CarState(CarStateBase):
  10. def __init__(self, CP):
  11. super().__init__(CP)
  12. self.button_states = {button.event_type: False for button in BUTTONS}
  13. self.can_define = CANDefine(DBC[CP.carFingerprint]['chassis'])
  14. # Needed by carcontroller
  15. self.msg_stw_actn_req = None
  16. self.hands_on_level = 0
  17. self.steer_warning = None
  18. self.acc_state = 0
  19. self.das_control_counters = deque(maxlen=32)
  20. def update(self, cp, cp_cam):
  21. ret = car.CarState.new_message()
  22. # Vehicle speed
  23. ret.vEgoRaw = cp.vl["ESP_B"]["ESP_vehicleSpeed"] * CV.KPH_TO_MS
  24. ret.vEgo, ret.aEgo = self.update_speed_kf(ret.vEgoRaw)
  25. ret.standstill = (ret.vEgo < 0.1)
  26. # Gas pedal
  27. ret.gas = cp.vl["DI_torque1"]["DI_pedalPos"] / 100.0
  28. ret.gasPressed = (ret.gas > 0)
  29. # Brake pedal
  30. ret.brake = 0
  31. ret.brakePressed = bool(cp.vl["BrakeMessage"]["driverBrakeStatus"] != 1)
  32. # Steering wheel
  33. self.hands_on_level = cp.vl["EPAS_sysStatus"]["EPAS_handsOnLevel"]
  34. self.steer_warning = self.can_define.dv["EPAS_sysStatus"]["EPAS_eacErrorCode"].get(int(cp.vl["EPAS_sysStatus"]["EPAS_eacErrorCode"]), None)
  35. steer_status = self.can_define.dv["EPAS_sysStatus"]["EPAS_eacStatus"].get(int(cp.vl["EPAS_sysStatus"]["EPAS_eacStatus"]), None)
  36. ret.steeringAngleDeg = -cp.vl["EPAS_sysStatus"]["EPAS_internalSAS"]
  37. ret.steeringRateDeg = -cp.vl["STW_ANGLHP_STAT"]["StW_AnglHP_Spd"] # This is from a different angle sensor, and at different rate
  38. ret.steeringTorque = -cp.vl["EPAS_sysStatus"]["EPAS_torsionBarTorque"]
  39. ret.steeringPressed = (self.hands_on_level > 0)
  40. ret.steerFaultPermanent = steer_status == "EAC_FAULT"
  41. ret.steerFaultTemporary = (self.steer_warning not in ("EAC_ERROR_IDLE", "EAC_ERROR_HANDS_ON"))
  42. # Cruise state
  43. cruise_state = self.can_define.dv["DI_state"]["DI_cruiseState"].get(int(cp.vl["DI_state"]["DI_cruiseState"]), None)
  44. speed_units = self.can_define.dv["DI_state"]["DI_speedUnits"].get(int(cp.vl["DI_state"]["DI_speedUnits"]), None)
  45. acc_enabled = (cruise_state in ("ENABLED", "STANDSTILL", "OVERRIDE", "PRE_FAULT", "PRE_CANCEL"))
  46. ret.cruiseState.enabled = acc_enabled
  47. if speed_units == "KPH":
  48. ret.cruiseState.speed = cp.vl["DI_state"]["DI_digitalSpeed"] * CV.KPH_TO_MS
  49. elif speed_units == "MPH":
  50. ret.cruiseState.speed = cp.vl["DI_state"]["DI_digitalSpeed"] * CV.MPH_TO_MS
  51. ret.cruiseState.available = ((cruise_state == "STANDBY") or ret.cruiseState.enabled)
  52. ret.cruiseState.standstill = False # This needs to be false, since we can resume from stop without sending anything special
  53. # Gear
  54. ret.gearShifter = GEAR_MAP[self.can_define.dv["DI_torque2"]["DI_gear"].get(int(cp.vl["DI_torque2"]["DI_gear"]), "DI_GEAR_INVALID")]
  55. # Buttons
  56. buttonEvents = []
  57. for button in BUTTONS:
  58. state = (cp.vl[button.can_addr][button.can_msg] in button.values)
  59. if self.button_states[button.event_type] != state:
  60. event = car.CarState.ButtonEvent.new_message()
  61. event.type = button.event_type
  62. event.pressed = state
  63. buttonEvents.append(event)
  64. self.button_states[button.event_type] = state
  65. ret.buttonEvents = buttonEvents
  66. # Doors
  67. ret.doorOpen = any([(self.can_define.dv["GTW_carState"][door].get(int(cp.vl["GTW_carState"][door]), "OPEN") == "OPEN") for door in DOORS])
  68. # Blinkers
  69. ret.leftBlinker = (cp.vl["GTW_carState"]["BC_indicatorLStatus"] == 1)
  70. ret.rightBlinker = (cp.vl["GTW_carState"]["BC_indicatorRStatus"] == 1)
  71. # Seatbelt
  72. ret.seatbeltUnlatched = (cp.vl["SDM1"]["SDM_bcklDrivStatus"] != 1)
  73. # TODO: blindspot
  74. # AEB
  75. ret.stockAeb = (cp_cam.vl["DAS_control"]["DAS_aebEvent"] == 1)
  76. # Messages needed by carcontroller
  77. self.msg_stw_actn_req = copy.copy(cp.vl["STW_ACTN_RQ"])
  78. self.acc_state = cp_cam.vl["DAS_control"]["DAS_accState"]
  79. self.das_control_counters.extend(cp_cam.vl_all["DAS_control"]["DAS_controlCounter"])
  80. return ret
  81. @staticmethod
  82. def get_can_parser(CP):
  83. signals = [
  84. # sig_name, sig_address
  85. ("ESP_vehicleSpeed", "ESP_B"),
  86. ("DI_pedalPos", "DI_torque1"),
  87. ("DI_brakePedal", "DI_torque2"),
  88. ("StW_AnglHP", "STW_ANGLHP_STAT"),
  89. ("StW_AnglHP_Spd", "STW_ANGLHP_STAT"),
  90. ("EPAS_handsOnLevel", "EPAS_sysStatus"),
  91. ("EPAS_torsionBarTorque", "EPAS_sysStatus"),
  92. ("EPAS_internalSAS", "EPAS_sysStatus"),
  93. ("EPAS_eacStatus", "EPAS_sysStatus"),
  94. ("EPAS_eacErrorCode", "EPAS_sysStatus"),
  95. ("DI_cruiseState", "DI_state"),
  96. ("DI_digitalSpeed", "DI_state"),
  97. ("DI_speedUnits", "DI_state"),
  98. ("DI_gear", "DI_torque2"),
  99. ("DOOR_STATE_FL", "GTW_carState"),
  100. ("DOOR_STATE_FR", "GTW_carState"),
  101. ("DOOR_STATE_RL", "GTW_carState"),
  102. ("DOOR_STATE_RR", "GTW_carState"),
  103. ("DOOR_STATE_FrontTrunk", "GTW_carState"),
  104. ("BOOT_STATE", "GTW_carState"),
  105. ("BC_indicatorLStatus", "GTW_carState"),
  106. ("BC_indicatorRStatus", "GTW_carState"),
  107. ("SDM_bcklDrivStatus", "SDM1"),
  108. ("driverBrakeStatus", "BrakeMessage"),
  109. # We copy this whole message when spamming cancel
  110. ("SpdCtrlLvr_Stat", "STW_ACTN_RQ"),
  111. ("VSL_Enbl_Rq", "STW_ACTN_RQ"),
  112. ("SpdCtrlLvrStat_Inv", "STW_ACTN_RQ"),
  113. ("DTR_Dist_Rq", "STW_ACTN_RQ"),
  114. ("TurnIndLvr_Stat", "STW_ACTN_RQ"),
  115. ("HiBmLvr_Stat", "STW_ACTN_RQ"),
  116. ("WprWashSw_Psd", "STW_ACTN_RQ"),
  117. ("WprWash_R_Sw_Posn_V2", "STW_ACTN_RQ"),
  118. ("StW_Lvr_Stat", "STW_ACTN_RQ"),
  119. ("StW_Cond_Flt", "STW_ACTN_RQ"),
  120. ("StW_Cond_Psd", "STW_ACTN_RQ"),
  121. ("HrnSw_Psd", "STW_ACTN_RQ"),
  122. ("StW_Sw00_Psd", "STW_ACTN_RQ"),
  123. ("StW_Sw01_Psd", "STW_ACTN_RQ"),
  124. ("StW_Sw02_Psd", "STW_ACTN_RQ"),
  125. ("StW_Sw03_Psd", "STW_ACTN_RQ"),
  126. ("StW_Sw04_Psd", "STW_ACTN_RQ"),
  127. ("StW_Sw05_Psd", "STW_ACTN_RQ"),
  128. ("StW_Sw06_Psd", "STW_ACTN_RQ"),
  129. ("StW_Sw07_Psd", "STW_ACTN_RQ"),
  130. ("StW_Sw08_Psd", "STW_ACTN_RQ"),
  131. ("StW_Sw09_Psd", "STW_ACTN_RQ"),
  132. ("StW_Sw10_Psd", "STW_ACTN_RQ"),
  133. ("StW_Sw11_Psd", "STW_ACTN_RQ"),
  134. ("StW_Sw12_Psd", "STW_ACTN_RQ"),
  135. ("StW_Sw13_Psd", "STW_ACTN_RQ"),
  136. ("StW_Sw14_Psd", "STW_ACTN_RQ"),
  137. ("StW_Sw15_Psd", "STW_ACTN_RQ"),
  138. ("WprSw6Posn", "STW_ACTN_RQ"),
  139. ("MC_STW_ACTN_RQ", "STW_ACTN_RQ"),
  140. ("CRC_STW_ACTN_RQ", "STW_ACTN_RQ"),
  141. ]
  142. checks = [
  143. # sig_address, frequency
  144. ("ESP_B", 50),
  145. ("DI_torque1", 100),
  146. ("DI_torque2", 100),
  147. ("STW_ANGLHP_STAT", 100),
  148. ("EPAS_sysStatus", 25),
  149. ("DI_state", 10),
  150. ("STW_ACTN_RQ", 10),
  151. ("GTW_carState", 10),
  152. ("SDM1", 10),
  153. ("BrakeMessage", 50),
  154. ]
  155. return CANParser(DBC[CP.carFingerprint]['chassis'], signals, checks, CANBUS.chassis)
  156. @staticmethod
  157. def get_cam_can_parser(CP):
  158. signals = [
  159. # sig_name, sig_address
  160. ("DAS_accState", "DAS_control"),
  161. ("DAS_aebEvent", "DAS_control"),
  162. ("DAS_controlCounter", "DAS_control"),
  163. ]
  164. checks = [
  165. # sig_address, frequency
  166. ("DAS_control", 40),
  167. ]
  168. return CANParser(DBC[CP.carFingerprint]['chassis'], signals, checks, CANBUS.autopilot_chassis)