mirror of
https://github.com/sunnypilot/sunnypilot.git
synced 2026-06-27 18:12:04 +08:00
9219b7966c
# Conflicts: # panda # release/build_release.sh # selfdrive/car/car_helpers.py # selfdrive/car/chrysler/carcontroller.py # selfdrive/car/chrysler/carstate.py # selfdrive/car/chrysler/interface.py # selfdrive/car/ford/carstate.py # selfdrive/car/ford/interface.py # selfdrive/car/gm/carcontroller.py # selfdrive/car/gm/carstate.py # selfdrive/car/gm/interface.py # selfdrive/car/honda/carcontroller.py # selfdrive/car/honda/interface.py # selfdrive/car/hyundai/carcontroller.py # selfdrive/car/hyundai/carstate.py # selfdrive/car/hyundai/hyundaican.py # selfdrive/car/hyundai/interface.py # selfdrive/car/interfaces.py # selfdrive/car/mazda/carcontroller.py # selfdrive/car/mazda/carstate.py # selfdrive/car/mazda/interface.py # selfdrive/car/nissan/carcontroller.py # selfdrive/car/nissan/interface.py # selfdrive/car/subaru/carstate.py # selfdrive/car/subaru/interface.py # selfdrive/car/subaru/subarucan.py # selfdrive/car/toyota/carcontroller.py # selfdrive/car/toyota/carstate.py # selfdrive/car/toyota/interface.py # selfdrive/car/toyota/toyotacan.py # selfdrive/car/volkswagen/carcontroller.py # selfdrive/car/volkswagen/carstate.py # selfdrive/car/volkswagen/interface.py # selfdrive/controls/controlsd.py # selfdrive/controls/lib/latcontrol_torque.py # selfdrive/controls/lib/lateral_planner.py # selfdrive/controls/lib/longitudinal_mpc_lib/long_mpc.py # selfdrive/controls/lib/longitudinal_planner.py # selfdrive/locationd/paramsd.py # selfdrive/manager/manager.py # selfdrive/manager/process.py # selfdrive/manager/process_config.py # selfdrive/sentry.py # selfdrive/ui/SConscript # selfdrive/ui/qt/home.cc # selfdrive/ui/qt/maps/map_settings.cc # selfdrive/ui/qt/maps/map_settings.h # selfdrive/ui/qt/offroad/settings.cc # selfdrive/ui/qt/onroad.cc # selfdrive/ui/qt/onroad.h # selfdrive/ui/qt/util.cc # selfdrive/ui/qt/util.h # selfdrive/ui/soundd/sound.h # selfdrive/ui/ui.h # system/version.py
71 lines
2.7 KiB
Python
Executable File
71 lines
2.7 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
import os
|
|
import numpy as np
|
|
from cereal import car
|
|
from openpilot.common.params import Params
|
|
from openpilot.common.realtime import Priority, config_realtime_process
|
|
from openpilot.system.swaglog import cloudlog
|
|
from openpilot.selfdrive.modeld.constants import T_IDXS
|
|
from openpilot.selfdrive.controls.lib.longitudinal_planner import LongitudinalPlanner
|
|
from openpilot.selfdrive.controls.lib.lateral_planner import LateralPlanner
|
|
import cereal.messaging as messaging
|
|
|
|
def cumtrapz(x, t):
|
|
return np.concatenate([[0], np.cumsum(((x[0:-1] + x[1:])/2) * np.diff(t))])
|
|
|
|
def publish_ui_plan(sm, pm, lateral_planner, longitudinal_planner):
|
|
plan_odo = cumtrapz(longitudinal_planner.v_desired_trajectory_full, T_IDXS)
|
|
model_odo = cumtrapz(lateral_planner.v_plan, T_IDXS)
|
|
|
|
ui_send = messaging.new_message('uiPlan')
|
|
ui_send.valid = sm.all_checks(service_list=['carState', 'controlsState', 'modelV2'])
|
|
uiPlan = ui_send.uiPlan
|
|
uiPlan.frameId = sm['modelV2'].frameId
|
|
uiPlan.position.x = np.interp(plan_odo, model_odo, lateral_planner.lat_mpc.x_sol[:,0]).tolist()
|
|
uiPlan.position.y = np.interp(plan_odo, model_odo, lateral_planner.lat_mpc.x_sol[:,1]).tolist()
|
|
uiPlan.position.z = np.interp(plan_odo, model_odo, lateral_planner.path_xyz[:,2]).tolist()
|
|
uiPlan.accel = longitudinal_planner.a_desired_trajectory_full.tolist()
|
|
pm.send('uiPlan', ui_send)
|
|
|
|
def plannerd_thread(sm=None, pm=None):
|
|
config_realtime_process(5, Priority.CTRL_LOW)
|
|
|
|
cloudlog.info("plannerd is waiting for CarParams")
|
|
params = Params()
|
|
with car.CarParams.from_bytes(params.get("CarParams", block=True)) as msg:
|
|
CP = msg
|
|
cloudlog.info("plannerd got CarParams: %s", CP.carName)
|
|
|
|
debug_mode = bool(int(os.getenv("DEBUG", "0")))
|
|
|
|
use_lanelines = False
|
|
|
|
cloudlog.event("e2e mode", on=use_lanelines)
|
|
|
|
longitudinal_planner = LongitudinalPlanner(CP)
|
|
lateral_planner = LateralPlanner(CP, debug=debug_mode, use_lanelines=use_lanelines)
|
|
|
|
if sm is None:
|
|
sm = messaging.SubMaster(['carControl', 'carState', 'controlsState', 'radarState', 'modelV2', 'longitudinalPlan', 'lateralPlan', 'liveMapData', 'navInstruction', 'e2eLongState'],
|
|
poll=['radarState', 'modelV2'], ignore_avg_freq=['radarState'])
|
|
|
|
if pm is None:
|
|
pm = messaging.PubMaster(['longitudinalPlan', 'lateralPlan', 'uiPlan'])
|
|
|
|
while True:
|
|
sm.update()
|
|
|
|
if sm.updated['modelV2']:
|
|
lateral_planner.update(sm)
|
|
lateral_planner.publish(sm, pm)
|
|
longitudinal_planner.update(sm)
|
|
longitudinal_planner.publish(sm, pm)
|
|
publish_ui_plan(sm, pm, lateral_planner, longitudinal_planner)
|
|
|
|
def main(sm=None, pm=None):
|
|
plannerd_thread(sm, pm)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|