【toolschain algorithm cpp ros】cpp工厂模式实现--后续填充具体规划算法,控制器版的已填充了算法接入了仿真器

news/2024/10/18 5:49:44/

写在前面

现在局势危机,于是想复习一下之前写的设计模式,之前提到,做过一个闭环仿真器(借用ros),见https://blog.csdn.net/weixin_46479223/article/details/134864123我的控制器的建立遵循了工厂模式(多态、工厂、客户订阅)。 目前按照之前的设计,把规划器也改写成类似的模式。未来接入我的闭环仿真器械中。

本篇文章只设计框架的搭建,具体算法lattice搭建完毕填充以及其他算法为看时间缓慢的更新吧。

有错误和问题 还请大大们指点阿

基本结构

在这里插入图片描述
最外面是我的ros节点(目前刚建立没有接入ros以及控制器 用while先测试了

然后包一个planner的调度器(scheduler:planner.cpp)
传建一个基类然后动态多态的方式实现不同规划器的注册,把根据类型注册的规划器放入到一个哈希map,实现增删。(这里临时固定)。控制器和规划器的这个架构原来的设想是根据不同的场景可以有一个判断器自动实现合适的控制器和规划器的切换(也就是自动驾驶行泊一体啦)

对外接口是run和init和update,基本每行代码都有注释。

参数使用yaml管理

跑起来的样子

之前跑起来的并且接入了我的闭环无敌可进化仿真器的视频。我的git也放了一版。
这里不能贴视频。
仿真器想表现车辆追随一段轨迹,前面是轨迹(预瞄)。后面是我的车实不断更新的位置。(实现了闭环)
在这里插入图片描述
0 1 2 3 4 是假设的控制类型,这里先跑0.

部分重要代码

代码在git上

origin git@github.com:HerrQQ/MPotherSet.git (fetch)
origin git@github.com:HerrQQ/MPotherSet.git (push)
第一版如此
未来不断调整

工厂类

#ifndef _PlannerFactory_H_
#define _PlannerFactory_H_#include "planner_A.h"
#include "planner_B.h"
#include "planner_C.h"
#include "planner_D.h"/*** @brief PlannerFactory* @author kaifeng* @date 
*/
#include <memory>
namespace planner { 
class PlannerFactory//factory 
{
public :PlannerFactory()=default;~PlannerFactory()=default;/*** @brief creat planner* @param needed planner type*/std::shared_ptr<PlannerBase> fCreateplanner (const PlannerType& type){if (type == B) {return std::make_shared<planner_B>();}else if (type == A) {return std::make_shared<planner_A>();}else if (type == C) {return std::make_shared<planner_C>();}else if (type == D) {return std::make_shared<planner_D>();}else {return nullptr;}}};
}// class PlannerFactory_D :public PlannerFactory //factory son
// {
// public ://     PlannerFactory_D()=default;
//     virtual ~PlannerFactory_D() override
//     {
//         LOG(INFO)<<"D plannerBase created"<<std::endl;
//     }
//     virtual planner::plannerBase* fCreateplanner ()override
//     {
//         return new planner::planner_D();
//     }
// };// class PlannerFactory_A :public PlannerFactory //factory son
// {
// public ://     PlannerFactory_A()=default;
//     virtual ~PlannerFactory_A() override
//     {
//         LOG(INFO)<<"A plannerBase created"<<std::endl;
//     }
//     virtual planner::plannerBase* fCreateplanner ()override
//     {
//         return new planner::planner_A();
//     }
// };// class PlannerFactory_B :public PlannerFactory //factory son
// {
// public ://     PlannerFactory_B()=default;
//     virtual ~PlannerFactory_B() override
//     {
//         LOG(INFO)<<"B plannerBase created"<<std::endl;
//     }
//     virtual planner::plannerBase* fCreateplanner ()override
//     {
//         return new planner::planner_B();
//     }
// };// class PlannerFactory_B :public PlannerFactory //factory son
// {
// public ://     PlannerFactory_B()=default;
//     virtual ~PlannerFactory_B() override
//     {
//         LOG(INFO)<<"B plannerBase created"<<std::endl;
//     }
//     virtual planner::plannerBase* fCreateplanner ()override
//     {
//         return new planner::planner_B();
//     }
// };#endif

基类

#ifndef _PLANNER_H_
#define _PLANNER_H_
#include "structPlanner_t.h"
#include <Eigen/Dense>
#include <vector>
#include <map>
#include <unordered_map>
#include "glog/logging.h"
#include <yaml-cpp/yaml.h>/*** @brief Planner_base* @author kaifeng* @date 
*/namespace planner { /*** @brief base class for all planners.*/
class PlannerBase//client
{public:/*** @brief constructor*/PlannerBase() = default;/*** @brief destructor*/virtual ~PlannerBase() = default;/*** @brief initialize PlannerBase* @param config_path path of config file, yaml  * @return Status initialization status*/virtual uint8_t initialize(const std::string& config_path) = 0;/*** @brief compute planner command* @param PlannerDataFlow saving relativ infos of planning* @param locInfo reference of LocInfo instance* @param VehicleState reference of VehicleState instance* @return reference of Command instance, which is private member*/virtual void run( const Location& locInfo,const VehicleState& VehicleState,PlannerDataFlow& PlannerDataFlow) = 0;virtual void noRun(const Location& locInfo,const VehicleState& VehicleState) = 0;/*** @brief stop planner*/// virtual void stop();protected:double cmd_; //Command cmd_;//Debug debug_ptr_;
};}#endif

其中一个子class

#ifndef __A_planner_h__
#define __A_planner_h__#include "planner_base.h"
#include "glog/logging.h"
#include <vector>
#include <map>
#include <cmath>
#include <utility>/*** @brief A* @author kaifeng* @date 
*/
namespace planner
{class planner_A:public PlannerBase{ // product sonpublic:planner_A(){LOG(INFO)<<"A in progress"<<std::endl;}~planner_A(){LOG(INFO)<<"A stop"<<std::endl;}uint8_t initialize(const std::string& config_path)override;void run( const Location& locInfo,const VehicleState& VehicleState,PlannerDataFlow& PlannerDataFlow) override;void noRun(const Location& locInfo,const VehicleState& VehicleState) override;private:/*** @brief read configuration*/void readConfig(const std::string& path);private:// cost parametersstruct CostParameter {float Xxxx{0.f};float xXxx{0.f};float xxXx{0.f};float xxxX{0.f};};CostParameter* p_parameter_;// };}
#endif

调度

在这里插入图片描述

commen 内实现了几个filter 封装成了类


http://www.ppmy.cn/news/1283200.html

相关文章

Java web汽车销售管理系统JavaServelet Jsp(Java毕业设计)

大家好&#xff0c;我是DeBug&#xff0c;很高兴你能来阅读&#xff01;作为一名热爱编程的程序员&#xff0c;我希望通过这些教学笔记与大家分享我的编程经验和知识。在这里&#xff0c;我将会结合实际项目经验&#xff0c;分享编程技巧、最佳实践以及解决问题的方法。无论你是…

【SpringCloud笔记】(11)消息驱动之Stream

Stream 技术背景 底层不同模块可能使用不同的消息中间件&#xff0c;这就导致技术的切换&#xff0c;微服务的维护及开发变得麻烦起来 概述 官网&#xff1a; https://spring.io/projects/spring-cloud-stream#overview https://cloud.spring.io/spring-cloud-static/spring…

Hive-数据模型详解(超详细)

文章目录 一、Hive数据模型1. 概述2. 数据库和表(1) 创建数据库(2) 使用数据库(3) 创建表格(4) 查看表结构 3. 分区与桶(1) 分区(2) 桶 4. 数据加载与查询(1) 数据导入(2) 查询语句 5. 总结 一、Hive数据模型 1. 概述 Hive是基于Hadoop的数据仓库工具&#xff0c;它提供了类似…

git远程操作,推送【push】,拉取【pull】,忽略特殊文件,配置别名,标签管理

文章目录 前言&#xff1a;新建远程仓库克隆推送【push】拉取【pull】 配置git忽略特殊文件给命令配置别名 标签管理理解标签创建标签操作标签 前言&#xff1a; 大家如果没有看过前几章git的基础操作的话&#xff0c;推荐先看一下&#xff0c;看完再来看这个远程操作&#xf…

声明 | 为打击假冒账号、恶意抄袭账号等诈骗活动,提升本账号权威,本博主特此郑重声明

声明 | 为打击假冒账号、恶意抄袭账号诈骗活动&#xff0c;提升本账号权威&#xff0c;本博主特此郑重声明 一、本账号为《机器学习之心》博主CSDN唯一官方账号&#xff0c;唯一联系方式见文章底部。 二、《机器学习之心》博主未授权任何第三方账号进行模型合作、程序设计、源…

【数据库系统概论】第3章-关系数据库标准语言SQL(3)

文章目录 3.5 数据更新3.5.1 插入数据3.5.2 修改数据3.5.3 删除数据 3.6 空值的处理3.7 视图3.7.1 建立视图3.7.2 查询视图3.7.3 更新视图3.7.4 视图的作用 3.5 数据更新 3.5.1 插入数据 注意&#xff1a;插入数据时要满足表或者列的约束条件&#xff0c;否则插入失败&#x…

安全运维是做什么的,主要工作内容是什么

安全运维&#xff0c;简称SecOps&#xff0c;是一种集成安全措施和流程到信息技术运维的实践。它的目的是确保在日常运维活动中&#xff0c;如网络管理、系统维护、软件更新等&#xff0c;均考虑并融入安全策略。安全运维的核心是实现安全和运维团队的密切协作&#xff0c;以快…

【并发设计模式】聊聊 基于Copy-on-Write模式下的CopyOnWriteArrayList

在并发编程领域&#xff0c;其实除了使用上一篇中的属性不可变。还有一种方式那就是针对读多写少的场景下。我们可以读不加锁&#xff0c;只针对于写操作进行加锁。本质上就是读写复制。读的直接读取&#xff0c;写的使用写一份数据的拷贝数据&#xff0c;然后进行写入。在将新…