《从0开始搭建实现apollo9.0》系列八 泊车模块解读

2024-06-01 12:36

本文主要是介绍《从0开始搭建实现apollo9.0》系列八 泊车模块解读,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《从0开始搭建实现apollo9.0》系列八 泊车模块解读
泊车规划模块位置

modules/planning/scenarios/valet_parking/

泊车阶段的开始条件:

  1. planning command里存在泊车命令
  2. 距离泊车点距离parking_spot_range_to_start以内

配置文件
pipeline.pb.txt可以看到泊车分为两个阶段,一个是ApproachingParking,一个是Parking。其中ApproachingParking可以当作是一个行车的过程,引导车辆沿主路行驶到泊车位,行车的终点为泊车车位。Parking为泊入车位过程,包括可行驶区域构建,轨迹生成,轨迹分类(档位切换),轨迹决策。

stage: {name: "VALET_PARKING_APPROACHING_PARKING_SPOT"type: "StageApproachingParkingSpot"enabled: true
stage: {name: "VALET_PARKING_PARKING"type: "StageParking"

scenario_conf.pb.txt中定义了参数

parking_spot_range_to_start: 20.0
max_valid_stop_distance: 1.0

一个为stage切换判断的距离,一个是stop距离。
valet_parking_scenario.h

class ValetParkingScenario : public Scenario {//继承基类Scenario   重写基类中的成员函数public:bool Init(std::shared_ptr<DependencyInjector> injector,const std::string& name) override;/*** @brief Get the scenario context.*/ValetParkingContext* GetContext() override { return &context_; }bool IsTransferable(const Scenario* const other_scenario,const Frame& frame) override;private:static bool SearchTargetParkingSpotOnPath(//不确定为何使用static类型const hdmap::Path& nearby_path, const std::string& target_parking_id,hdmap::PathOverlap* parking_space_overlap);static bool CheckDistanceToParkingSpot(const Frame& frame, const common::VehicleState& vehicle_state,const hdmap::Path& nearby_path, const double parking_start_range,const hdmap::PathOverlap& parking_space_overlap);private:bool init_ = false;ValetParkingContext context_;const hdmap::HDMap* hdmap_ = nullptr;
};

#静态成员函数知识点:

归属 : 在 C++ 类中 , 静态成员函数 是一种 特殊的函数 , 该函数属于类 , 而不是属于 类实例对象 ;
静态成员函数调用不依赖于对象 : 即使 没有创建 类 的 实例对象 , 也可以 通过 类名:: 调用 类中定义的 静态成员函数 ;
静态成员函数作用 : 静态成员函数 通常用于 执行与类本身相关的操作 , 执行该函数 不涉及到 类实例对象中的信息 , 也不能在 静态成员函数 中访问 普通的 成员变量 和 成员函数 ;
//静态函数的特点
//1.静态函数无需生成对象就可被调用
//2.静态函数不能直接调用非静态的成员变量
//3.不能使用this引用
IsTransferable函数用于判断other_scenario是否能够转移到当前的Scenario中,代码做了以下判断:

  1. planning command里存在泊车命令和车位id
  2. 距离泊车点距离parking_spot_range_to_start以内
if (!frame.local_view().planning_command->has_parking_command()) {return false;}if (other_scenario == nullptr || frame.reference_line_info().empty()) {return false;}std::string target_parking_spot_id;if (frame.local_view().planning_command->has_parking_command() &&frame.local_view().planning_command->parking_command().has_parking_spot_id()) {target_parking_spot_id = frame.local_view().planning_command->parking_command().parking_spot_id();}

SearchTargetParkingSpotOnPath函数 确定具有当前位置到车位的路径;

if (!SearchTargetParkingSpotOnPath(nearby_path, target_parking_spot_id,&parking_space_overlap)) {ADEBUG << "No such parking spot found after searching all path forward ""possible"<< target_parking_spot_id;return false;}double parking_spot_range_to_start =context_.scenario_config.parking_spot_range_to_start();if (!CheckDistanceToParkingSpot(frame, vehicle_state, nearby_path,parking_spot_range_to_start,parking_space_overlap)) {ADEBUG << "target parking spot found, but too far, distance larger than ""pre-defined distance"<< target_parking_spot_id;return false;}

CheckDistanceToParkingSpot 函数确定目标停车点距离在parking_spot_range_to_start范围内,使用delata_s来进行判断。

if (std::abs(center_point_s - vehicle_point_s) < parking_start_range) {return true;}

Stage1:StageApproachingParkingSpot

Stage2:StageParking

StageResult StageParking::Process(const common::TrajectoryPoint& planning_init_point, Frame* frame) {// Open space planning doesn't use planning_init_point from upstream because// of different stitching strategyauto scenario_context = GetContextAs<ValetParkingContext>();frame->mutable_open_space_info()->set_is_on_open_space_trajectory(true);//确保在open_space中*(frame->mutable_open_space_info()->mutable_target_parking_spot_id()) =//具有车位idscenario_context->target_parking_spot_id;StageResult result = ExecuteTaskOnOpenSpace(frame);//进行task状态机if (result.HasError()) {AERROR << "StageParking planning error";return result.SetStageStatus(StageStatusType::ERROR);}return result.SetStageStatus(StageStatusType::RUNNING);
}

这篇关于《从0开始搭建实现apollo9.0》系列八 泊车模块解读的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1021030

相关文章

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u