路径规划 | 图解粒子群(PSO)算法(附ROS C++仿真)

目录

  • 0 专栏介绍
  • 1 从鸟群迁徙说起
  • 2 粒子群算法基本概念
  • 3 粒子群算法流程
  • 4 粒子群算法ROS实现

0 专栏介绍

🔥附C++/Python/Matlab全套代码🔥课程设计、毕业设计、创新竞赛必备!详细介绍全局规划(图搜索、采样法、智能算法等);局部规划(DWA、APF等);曲线优化(贝塞尔曲线、B样条曲线等)。

🚀详情:图解自动驾驶中的运动规划(Motion Planning),附几十种规划算法


在这里插入图片描述

1 从鸟群迁徙说起

粒子群算法(Particle Swarm Optimization, PSO)的发展历史可以追溯到上世纪90年代初,由美国印第安纳大学的Eberhart和肯塔基大学的Kennedy教授提出,其灵感来源于对鸟群等生物群体行为的观察和研究。鸟群在自然界中展现了许多集体智慧的行为特征,比如鸟群在觅食、迁徙或逃避天敌时表现出协同行动和集体智慧。这些行为背后蕴含着群体成员之间的合作、信息交流和相互影响,从而使整个群体能够以高效的方式完成各种任务。

在PSO算法中,许多算法原理的设计都与鸟群行为密切相关。举例而言:

  • 群体协作和信息共享:在鸟群中,鸟类之间会相互沟通、协作以及分享信息,以便更好地寻找食物或者栖息地。类似地,在PSO算法中,每个“粒子”代表了待优化问题的一个潜在解,这些粒子通过相互影响和信息共享来共同搜索最优解。粒子之间不断地交换自身的位置和速度信息,以便通过群体智慧的方式来逐步靠近最佳解。

在这里插入图片描述

  • 个体适应度和集体最优解:在鸟群中,每只鸟都会根据自身感知到的环境信息和个体经验来调整自己的飞行方向和速度。类似地,PSO算法中的每个粒子也具有自身的适应度值(即目标函数值),它会根据自身的经验和当前群体的最优解来调整自己的位置和速度,以期望更好地逼近最优解。
  • 群体智能的搜索行为:鸟群在搜索食物或栖息地时会展现出一种集体智能的搜索行为,即通过相互协作和信息共享来快速找到最佳路径。同样地,PSO算法通过模拟群体的协作和信息共享,使得整个粒子群体能够在解空间中高效地搜索到最优解。

2 粒子群算法基本概念

接下来,我们形式化地描述上面的概念

在这里插入图片描述

粒子群算法的主要概念有:

  • M M M:粒子群个体数量
  • x i \boldsymbol{x}_i xi:粒子 i i i在问题解空间中的广义位置,即 x i = [ x i 1 x i 2 ⋯ x i d ] T ( i = 1 , 2 , ⋯   , M ) \boldsymbol{x}_i=\left[ \begin{matrix} x_{i}^{1}& x_{i}^{2}& \cdots& x_{i}^{d}\\\end{matrix} \right] ^T\left( i=1,2,\cdots ,M \right) xi=[xi1xi2xid]T(i=1,2,,M) x i j ∈ [ x min ⁡ j , x max ⁡ j ] x_{i}^{j}\in [ x_{\min}^{j},x_{\max}^{j} ] xij[xminj,xmaxj],其中 d d d为解空间维度,种群初始化方程为
    x i j = x min ⁡ j + r 0 1 ( x max ⁡ j − x min ⁡ j )    j = 1 , 2 , ⋯   , d x_{i}^{j}=x_{\min}^{j}+r_{0}^{1}\left( x_{\max}^{j}-x_{\min}^{j} \right) \,\, j=1,2,\cdots ,d xij=xminj+r01(xmaxjxminj)j=1,2,,d
    其中 r 0 1 r_{0}^{1} r01 [ 0 , 1 ] [0, 1] [0,1]上的随机数。
  • v i \boldsymbol{v}_i vi:粒子 i i i在问题解空间中的速度向量,即 v i = [ v i 1 v i 2 ⋯ v i d ] T ( i = 1 , 2 , ⋯   , M ) \boldsymbol{v}_i=\left[ \begin{matrix} v_{i}^{1}& v_{i}^{2}& \cdots& v_{i}^{d}\\\end{matrix} \right] ^T\left( i=1,2,\cdots ,M \right) vi=[vi1vi2vid]T(i=1,2,,M),速度更新公式为
    v i ∗ = v i + c 1 r 0 1 ( p i − x i ) + c 2 r 0 1 ( p g − x i ) \boldsymbol{v}_{i}^{*}=\boldsymbol{v}_i+c_1r_{0}^{1}\left( \boldsymbol{p}_i-\boldsymbol{x}_i \right) +c_2r_{0}^{1}\left( \boldsymbol{p}_g-\boldsymbol{x}_i \right) vi=vi+c1r01(pixi)+c2r01(pgxi)
    其中 p i \boldsymbol{p}_i pi为粒子 i i i的历史最优位置,按
    p i ∗ = { p i    , f i t ( p i ) ⩾ f i t ( x i ∗ ) x i ∗ , f i t ( p i ) < f i t ( x i ∗ ) \boldsymbol{p}_{i}^{*}=\begin{cases} \boldsymbol{p}_i\,\,, fit\left( \boldsymbol{p}_i \right) \geqslant fit\left( \boldsymbol{x}_{i}^{*} \right)\\ \boldsymbol{x}_{i}^{*}, fit\left( \boldsymbol{p}_i \right) <fit\left( \boldsymbol{x}_{i}^{*} \right)\\\end{cases} pi={pi,fit(pi)fit(xi)xi,fit(pi)<fit(xi)
    更新; p g \boldsymbol{p}_g pg为粒子群的历史最优位置,按
    p g ∗ = a r g max ⁡ p ∈ { p 1 ∗ , p 2 ∗ , ⋯   , p M ∗ }    f i t ( p ) \boldsymbol{p}_{g}^{*}=\underset{\boldsymbol{p}\in \left\{ \boldsymbol{p}_{1}^{*},\boldsymbol{p}_{2}^{*},\cdots ,\boldsymbol{p}_{M}^{*} \right\}}{\mathrm{arg}\max}\,\,fit\left( \boldsymbol{p} \right) pg=p{p1,p2,,pM}argmaxfit(p)
    更新; c 1 c_1 c1 c 2 c_2 c2为学习因子,表征粒子个体向其个体最优与群体最优位置移动的加速权重。得到速度向量后即可迭代粒子位置
    p g ∗ = a r g max ⁡ p ∈ { p 1 ∗ , p 2 ∗ , ⋯   , p M ∗ }    f i t ( p ) \boldsymbol{p}_{g}^{*}=\underset{\boldsymbol{p}\in \left\{ \boldsymbol{p}_{1}^{*},\boldsymbol{p}_{2}^{*},\cdots ,\boldsymbol{p}_{M}^{*} \right\}}{\mathrm{arg}\max}\,\,fit\left( \boldsymbol{p} \right) pg=p{p1,p2,,pM}argmaxfit(p)
  • f i t ( ⋅ ) fit\left( \cdot \right) fit():位置适应度函数;
  • v max ⁡ \boldsymbol{v}_{\max} vmax:速度极限,又称粒子群动态系统的lipschitz条件,对于不符合lipschitz条件的粒子需要进行处理确保算法运行在可行域

在这里插入图片描述

3 粒子群算法流程

粒子群算法基本原理如下所示

在这里插入图片描述

4 粒子群算法ROS实现

核心代码如下所示

bool PSO::plan(const unsigned char* global_costmap, const Node& start, const Node& goal, std::vector<Node>& path,
               std::vector<Node>& expand)
{
  start_ = std::pair<double, double>(static_cast<double>(start.x_), static_cast<double>(start.y_));
  goal_ = std::pair<double, double>(static_cast<double>(goal.x_), static_cast<double>(goal.y_));
  costmap_ = global_costmap;
  expand.clear();

  // variable initialization
  double init_fitness;
  Particle best_particle;
  PositionSequence init_positions;
  std::vector<Particle> particles;

  // Particle initialization
  for (int i = 0; i < n_particles_; ++i)
  {
    std::vector<std::pair<int, int>> init_position;
    if ((i < n_inherited_) && (inherited_particles_.size() == n_inherited_))
      init_position = inherited_particles_[i].best_pos;
    else
      init_position = init_positions[i];

    std::vector<std::pair<int, int>> init_velocity(point_num_, std::make_pair(0, 0));

    // Calculate fitness
    init_fitness = calFitnessValue(init_position);

    if ((i == 0) || (init_fitness > best_particle.fitness))
    {
      best_particle.fitness = init_fitness;
      best_particle.position = init_position;
    }
    // Create and add particle objects to containers
    particles.emplace_back(init_position, init_velocity, init_fitness);
  }

  // random data
  std::random_device rd;
  std::mt19937 gen(rd());

  // Iterative optimization
  for (size_t iter = 0; iter < max_iter_; iter++)
  {
    std::vector<std::thread> particle_list = std::vector<std::thread>(n_particles_);
    for (size_t i = 0; i < n_particles_; ++i)
      particle_list[i] = std::thread(&PSO::optimizeParticle, this, std::ref(particles[i]), std::ref(best_particle),
                                     std::ref(gen), std::ref(expand));
    for (size_t i = 0; i < n_particles_; ++i)
      particle_list[i].join();
  }

  // Generating Paths from Optimal Particles
 ...

  return !path.empty();
}

在这里插入图片描述

上面的绿色符号就是粒子群

完整工程代码请联系下方博主名片获取


🔥 更多精彩专栏

  • 《ROS从入门到精通》
  • 《Pytorch深度学习实战》
  • 《机器学习强基计划》
  • 《运动规划实战精讲》

👇源码获取 · 技术交流 · 抱团学习 · 咨询分享 请联系👇

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/648441.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

跨境热销爆款货源哪里找?选品工具不能少

通常&#xff0c;跨境电商找热销货源的几种方法&#xff1a; 1、使用Google Trends、亚马逊销售排行等来追踪和分析当前的市场趋势和热门产品&#xff1b; 2、关注社交媒体、行业论坛和博客等渠道&#xff0c;以获取最新的市场信息和消费者反馈&#xff1b; 3、在主流的跨境…

Oracle实践|内置函数之数学型函数

&#x1f4eb; 作者简介&#xff1a;「六月暴雪飞梨花」&#xff0c;专注于研究Java&#xff0c;就职于科技型公司后端工程师 &#x1f3c6; 近期荣誉&#xff1a;华为云云享专家、阿里云专家博主、腾讯云优秀创作者、ACDU成员 &#x1f525; 三连支持&#xff1a;欢迎 ❤️关注…

CDC 数据实时同步入湖的技术、架构和方案(截至2024年5月的现状调研)

近期&#xff0c;对 “实时摄取 CDC 数据同步到数据湖” 这一技术主题作了一系列深入的研究和验证&#xff0c;目前这部分工作已经告一段落&#xff0c;本文把截止目前&#xff08;2024年5月&#xff09;的研究结果和重要结论做一下梳理和汇总。为了能给出针对性的技术方案&…

基于小波分析和机器学习(SVM,KNN,NB,MLP)的癫痫脑电图检测(MATLAB环境)

癫痫是一种由大脑神经元突发性异常放电导致的大脑功能性障碍疾病。据世界卫生组织统计&#xff0c;全球约有7000万人患有癫痫。癫痫患者在发病时呈现肌肉抽搐、呼吸困难、意识丧失等症状。由于癫痫发作的偶然性&#xff0c;患者极有可能在高空、驾驶、游泳等危险情况下发病并丧…

掌握栈回溯意味着什么?

来源&#xff1a;公众号【鱼鹰谈单片机】 作者&#xff1a;鱼鹰Osprey ID &#xff1a;emOsprey 历时两个月&#xff08;1/3&#xff09;&#xff0c;第一个完成电子表项目的学员出现了&#xff0c;并且顺利的掌握了栈回溯技巧&#xff0c;在工作中快速定位了一个任务异常挂起…

【STM32】 独立看门狗配置方法

什么是看门狗 看门狗&#xff08;watchdog&#xff09;指的是一种监控系统或程序&#xff0c;用于定期检测和监控其他系统或程序的运行状态&#xff0c;并在出现问题或故障时采取相应的措施。它可以是硬件设备&#xff0c;也可以是软件程序。 在计算机领域中&#xff0c;看门狗…

全国青少年信息素养大赛历届复赛、国赛真题

由于2024年信息素养大赛初赛比较简单&#xff0c;特别是Scrath图形化编程和Python编程&#xff0c;八九分钟及半个小时内交卷的也多&#xff0c;100分及80分以上的比较多&#xff0c;&#xff08;各赛区复赛晋级根据两个指标进行排名&#xff0c;初赛成绩和答题用时。首先根据分…

AC/DC电源模块:提供高质量的电力转换解决方案

BOSHIDA AC/DC电源模块&#xff1a;提供高质量的电力转换解决方案 AC/DC电源模块是一种电力转换器件&#xff0c;可以将交流电转换为直流电。它通常用于各种电子设备和系统中&#xff0c;提供高质量的电力转换解决方案。 AC/DC电源模块具有许多优点。首先&#xff0c;它能够提…

玩机进阶教程------固件中的分区表 gpt_backup0.bin gpt_both0.bin gpt_main0.bin有什么区别 怎么修改分区表【一】

不管是emmc还是ufs在官方的线刷包中都有分区表存在。分区表包含有各个分区的地址段落。如果你在fast模式刷入官方固件还解决不了系统问题。那有几率是分区表损坏。这种情况无论你怎么刷写分区是解决不了问题的。 此类话题在百度很难搜索到,大多都是讲分区表的类型 结构 等等,…

23种设计模式全面总结 | 快速复习(附PDF+MD版本)

本篇文章是对于23种设计模式的一个全面的总结&#xff0c;受限于文章篇幅无法对每个设计模式做到全面的解析&#xff0c;但几乎每个设计模式都提供了案例和类图结构&#xff0c;非常适合快速复习和在学习设计模式之前的全预习把握。 &#x1f4a1;文章的 pdf markdown 版本可通…

驱动开发执行应用层时报ELF: not found,syntax error: unexpected “(“错误

问题&#xff1a; 原因&#xff1a;在跨平台的时候注意我们使用的编译器&#xff0c;我是因为没有没有交叉编译导致的。 出问题之前使用的是gcc test_01_normal.c -o test_01_normal生成的文件&#xff0c;导致&#xff0c;执行时报ELF这种问题。 解决办法&#xff1a;arm-li…

将本地项目上传到 gitee 仓库

1、创建 gitee 仓库 到 gitee 官网&#xff0c;新建仓库 配置新建仓库 完成仓库的创建 项目上传到仓库 上传项目需要安装git git官方下载地址&#xff1a;git下载地址 安装完成&#xff0c;前往本地项目所在文件夹&#xff0c;右击选择 Git Bash Here 刚下载完成需要配置G…

粤嵌—2024/5/13—删除排序链表中的重复元素(✔)

代码实现&#xff1a; /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/ struct ListNode* deleteDuplicates(struct ListNode *head) {if (head NULL || head->next NULL) {return head;}struct ListNode *…

【计算机毕业设计】基于SSM+Vue的新能源汽车在线租赁管理系统【源码+lw+部署文档】

摘 要 随着科学技术的飞速发展&#xff0c;社会的方方面面、各行各业都在努力与现代的先进技术接轨&#xff0c;通过科技手段来提高自身的优势&#xff0c;新能源汽车在线租赁当然也不能排除在外。新能源汽车在线租赁是以实际运用为开发背景&#xff0c;运用软件工程开发方法&…

【Linux部署】【pig前端部署】Linux安装- docker/docker-compose/nginx (使用docker优雅部署nginx)

&#x1f338;&#x1f338; Linux安装- docker/docker-compose/nginx 优雅部署 &#x1f338;&#x1f338; 一、一键安装jdk yum install -y java-1.8.0-openjdk.x86_64验证 二、安装docker yum list docker-ce --showduplicates | sort -rsudo yum install -y yum-utils …

Visual Studio和Visual Studio Code分清了? 都是IDE,可不是框架。

Visual Studio和VSCode两者都是 Microsoft 制造的IDE&#xff08;集成开发环境&#xff09;。尽管它们的名字相似&#xff0c;但它们的功能却大不相同。 一、什么是Visual Studio&#xff08;VS&#xff09; Visual Studio&#xff08;简称VS&#xff09;是由微软公司开发的一…

用go语言实现一个有界协程池

写在文章开头 本篇文章算是对go语言系列的一个收尾&#xff0c;通过go语言实现一个实现一个简单的有界协程池。 Hi&#xff0c;我是 sharkChili &#xff0c;是个不断在硬核技术上作死的 java coder &#xff0c;是 CSDN的博客专家 &#xff0c;也是开源项目 Java Guide 的维护…

AIGC时代算法工程师的面试秘籍(2024.4.29-5.12第十三式) |【三年面试五年模拟】

写在前面 【三年面试五年模拟】旨在整理&挖掘AI算法工程师在实习/校招/社招时所需的干货知识点与面试方法&#xff0c;力求让读者在获得心仪offer的同时&#xff0c;增强技术基本面。也欢迎大家提出宝贵的优化建议&#xff0c;一起交流学习&#x1f4aa; 欢迎大家关注Rocky…

引入安全生产培训云平台,实现“人人讲安全、个个会应急”

引入安全生产培训云平台&#xff0c;旨在全面提升企业及员工的安全意识与应急处理能力&#xff0c;通过数字化手段实现“人人讲安全、个个会应急”的目标。这一平台的构建和应用&#xff0c;不仅促进了安全知识的普及&#xff0c;还极大提高了培训的效率与效果。以下是该平台几…

Backend - postgresSQL DB 存储过程(数据库存储过程)

目录 一、存储过程的特性 &#xff08;一&#xff09;作用 &#xff08;二&#xff09;特点 &#xff08;三&#xff09;编码结构的区别 二、定时执行存储过程 三、2种编码结构 &#xff08;一&#xff09;函数结构 1. SQL代码 2. 举例 &#xff08;1&#xff09;例1-循…