nopenpilot/selfdrive/car/mock/interface.py

92 lines
2.8 KiB
Python
Raw Normal View History

2020-01-17 11:58:43 -07:00
#!/usr/bin/env python3
import math
2020-01-17 11:58:43 -07:00
from cereal import car
from common.conversions import Conversions as CV
2020-01-17 11:58:43 -07:00
from selfdrive.swaglog import cloudlog
import cereal.messaging as messaging
from selfdrive.car import gen_empty_fingerprint, get_safety_config
2020-01-17 11:58:43 -07:00
from selfdrive.car.interfaces import CarInterfaceBase
# mocked car interface to work with chffrplus
TS = 0.01 # 100Hz
YAW_FR = 0.2 # ~0.8s time constant on yaw rate filter
2020-01-17 11:58:43 -07:00
# low pass gain
LPG = 2 * math.pi * YAW_FR * TS / (1 + 2 * math.pi * YAW_FR * TS)
2020-01-17 11:58:43 -07:00
class CarInterface(CarInterfaceBase):
def __init__(self, CP, CarController, CarState):
2020-05-09 17:40:43 -06:00
super().__init__(CP, CarController, CarState)
2020-01-17 11:58:43 -07:00
cloudlog.debug("Using Mock Car Interface")
self.sensor = messaging.sub_sock('sensorEvents')
2021-02-10 17:39:39 -07:00
self.gps = messaging.sub_sock('gpsLocationExternal')
2020-01-17 11:58:43 -07:00
self.speed = 0.
self.prev_speed = 0.
self.yaw_rate = 0.
self.yaw_rate_meas = 0.
@staticmethod
def compute_gb(accel, speed):
return accel
@staticmethod
2020-11-03 20:56:25 -07:00
def get_params(candidate, fingerprint=gen_empty_fingerprint(), car_fw=None):
ret = CarInterfaceBase.get_std_params(candidate, fingerprint)
2020-01-17 11:58:43 -07:00
ret.carName = "mock"
ret.safetyConfigs = [get_safety_config(car.CarParams.SafetyModel.noOutput)]
2020-01-17 11:58:43 -07:00
ret.mass = 1700.
ret.rotationalInertia = 2500.
ret.wheelbase = 2.70
ret.centerToFront = ret.wheelbase * 0.5
ret.steerRatio = 13. # reasonable
2020-01-17 11:58:43 -07:00
ret.tireStiffnessFront = 1e6 # very stiff to neglect slip
ret.tireStiffnessRear = 1e6 # very stiff to neglect slip
return ret
# returns a car.CarState
def update(self, c, can_strings):
# get basic data from phone and gps since CAN isn't connected
sensors = messaging.recv_sock(self.sensor)
if sensors is not None:
for sensor in sensors.sensorEvents:
if sensor.type == 4: # gyro
self.yaw_rate_meas = -sensor.gyro.v[0]
gps = messaging.recv_sock(self.gps)
if gps is not None:
self.prev_speed = self.speed
2021-02-10 17:39:39 -07:00
self.speed = gps.gpsLocationExternal.speed
2020-01-17 11:58:43 -07:00
# create message
ret = car.CarState.new_message()
2020-09-13 12:31:35 -06:00
ret.canValid = True
2020-01-17 11:58:43 -07:00
# speeds
ret.vEgo = self.speed
ret.vEgoRaw = self.speed
a = self.speed - self.prev_speed
ret.aEgo = a
ret.brakePressed = a < -0.5
ret.standstill = self.speed < 0.01
ret.wheelSpeeds.fl = self.speed
ret.wheelSpeeds.fr = self.speed
ret.wheelSpeeds.rl = self.speed
ret.wheelSpeeds.rr = self.speed
self.yawRate = LPG * self.yaw_rate_meas + (1. - LPG) * self.yaw_rate
2020-01-17 11:58:43 -07:00
curvature = self.yaw_rate / max(self.speed, 1.)
ret.steeringAngleDeg = curvature * self.CP.steerRatio * self.CP.wheelbase * CV.RAD_TO_DEG
2020-01-17 11:58:43 -07:00
return ret.as_reader()
def apply(self, c):
# in mock no carcontrols
actuators = car.CarControl.Actuators.new_message()
return actuators, []