carrot/selfdrive/frogpilot/controls/frogpilot_planner.py

92 lines
4.1 KiB
Python
Raw Normal View History

2024-05-29 03:43:25 -07:00
import numpy as np
import cereal.messaging as messaging
from cereal import car, log
from openpilot.common.conversions import Conversions as CV
from openpilot.common.numpy_fast import interp
from openpilot.common.params import Params
from openpilot.selfdrive.car.interfaces import ACCEL_MIN, ACCEL_MAX
from openpilot.selfdrive.controls.lib.drive_helpers import V_CRUISE_UNSET
from openpilot.selfdrive.controls.lib.longitudinal_mpc_lib.long_mpc import A_CHANGE_COST, J_EGO_COST, COMFORT_BRAKE, STOP_DISTANCE, get_jerk_factor, \
get_safe_obstacle_distance, get_stopped_equivalence_factor, get_T_FOLLOW
from openpilot.selfdrive.controls.lib.longitudinal_planner import A_CRUISE_MIN, Lead, get_max_accel
from openpilot.selfdrive.frogpilot.controls.lib.conditional_experimental_mode import ConditionalExperimentalMode
2024-05-09 20:03:47 -07:00
from openpilot.selfdrive.frogpilot.controls.lib.frogpilot_functions import calculate_lane_width, calculate_road_curvature
from openpilot.selfdrive.frogpilot.controls.lib.frogpilot_variables import CITY_SPEED_LIMIT, CRUISING_SPEED
2024-05-29 03:43:25 -07:00
GearShifter = car.CarState.GearShifter
class FrogPilotPlanner:
def __init__(self):
self.params_memory = Params("/dev/shm/params")
self.cem = ConditionalExperimentalMode()
2024-05-29 03:43:25 -07:00
self.acceleration_jerk = 0
self.frame = 0
self.road_curvature = 0
self.speed_jerk = 0
2024-05-24 02:41:19 -07:00
def update(self, carState, controlsState, frogpilotCarControl, frogpilotCarState, frogpilotNavigation, liveLocationKalman, modelData, radarState, frogpilot_toggles):
2024-05-29 03:43:25 -07:00
self.lead_one = radarState.leadOne
v_cruise_kph = min(controlsState.vCruise, V_CRUISE_UNSET)
v_cruise = v_cruise_kph * CV.KPH_TO_MS
v_ego = max(carState.vEgo, 0)
v_lead = self.lead_one.vLead
lead_distance = self.lead_one.dRel
self.base_acceleration_jerk, self.base_speed_jerk = get_jerk_factor(controlsState.personality)
self.t_follow = get_T_FOLLOW(controlsState.personality)
if self.lead_one.status:
2024-05-24 02:41:19 -07:00
self.update_follow_values(lead_distance, stopping_distance, v_ego, v_lead, frogpilot_toggles)
2024-05-29 03:43:25 -07:00
else:
self.acceleration_jerk = self.base_acceleration_jerk
self.speed_jerk = self.base_speed_jerk
self.road_curvature = calculate_road_curvature(modelData, v_ego)
2024-05-24 02:41:19 -07:00
self.v_cruise = self.update_v_cruise(carState, controlsState, frogpilotCarState, frogpilotNavigation, liveLocationKalman, modelData, v_cruise, v_ego, frogpilot_toggles)
2024-05-29 03:43:25 -07:00
if frogpilot_toggles.conditional_experimental_mode:
self.cem.update(carState, controlsState.enabled, frogpilotNavigation, lead_distance, self.lead_one, modelData, self.road_curvature, self.slower_lead, v_ego, v_lead, frogpilot_toggles)
2024-05-29 03:43:25 -07:00
self.frame += 1
2024-05-24 02:41:19 -07:00
def update_follow_values(self, lead_distance, stopping_distance, v_ego, v_lead, frogpilot_toggles):
2024-05-29 03:43:25 -07:00
2024-05-24 02:41:19 -07:00
def update_v_cruise(self, carState, controlsState, frogpilotCarState, frogpilotNavigation, liveLocationKalman, modelData, v_cruise, v_ego, frogpilot_toggles):
2024-05-29 03:43:25 -07:00
v_cruise_cluster = max(controlsState.vCruiseCluster, controlsState.vCruise) * CV.KPH_TO_MS
v_cruise_diff = v_cruise_cluster - v_cruise
v_ego_cluster = max(carState.vEgoCluster, v_ego)
v_ego_diff = v_ego_cluster - v_ego
targets = []
filtered_targets = [target if target > CRUISING_SPEED else v_cruise for target in targets]
return min(filtered_targets)
2024-05-24 02:41:19 -07:00
def publish(self, sm, pm, frogpilot_toggles):
2024-05-29 03:43:25 -07:00
frogpilot_plan_send = messaging.new_message('frogpilotPlan')
frogpilot_plan_send.valid = sm.all_checks(service_list=['carState', 'controlsState'])
frogpilotPlan = frogpilot_plan_send.frogpilotPlan
frogpilotPlan.accelerationJerk = A_CHANGE_COST * float(self.acceleration_jerk)
frogpilotPlan.accelerationJerkStock = A_CHANGE_COST * float(self.base_acceleration_jerk)
frogpilotPlan.speedJerk = J_EGO_COST * float(self.speed_jerk)
frogpilotPlan.speedJerkStock = J_EGO_COST * float(self.base_speed_jerk)
frogpilotPlan.tFollow = float(self.t_follow)
frogpilotPlan.conditionalExperimental = self.cem.experimental_mode
2024-05-29 03:43:25 -07:00
frogpilotPlan.vCruise = float(self.v_cruise)
pm.send('frogpilotPlan', frogpilot_plan_send)