路径规划 | 图解粒子群(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 initializationdouble init_fitness;Particle best_particle;PositionSequence init_positions;std::vector<Particle> particles;// Particle initializationfor (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;elseinit_position = init_positions[i];std::vector<std::pair<int, int>> init_velocity(point_num_, std::make_pair(0, 0));// Calculate fitnessinit_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 containersparticles.emplace_back(init_position, init_velocity, init_fitness);}// random datastd::random_device rd;std::mt19937 gen(rd());// Iterative optimizationfor (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深度学习实战》
  • 《机器学习强基计划》
  • 《运动规划实战精讲》

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【题解】—— LeetCode一周小结21

&#x1f31f;欢迎来到 我的博客 —— 探索技术的无限可能&#xff01; &#x1f31f;博客的简介&#xff08;文章目录&#xff09; 【题解】—— 每日一道题目栏 上接&#xff1a;【题解】—— LeetCode一周小结20 20.找出最长的超赞子字符串 题目链接&#xff1a;1542. 找出…

2024年150道高频Java面试题(七十三)

145. MyBatis 支持哪些类型的 SQL 语句&#xff1f; MyBatis 是一个优秀的持久层框架&#xff0c;它支持多种类型的 SQL 语句&#xff0c;包括但不限于以下几种&#xff1a; 查询语句&#xff1a; SELECT&#xff1a;用于从数据库表中检索数据。SELECTIVE&#xff1a;根据条件…

请说出vue.cli项目中src目录每个文件夹和文件的用法

在Vue CLI项目中&#xff0c;src目录是存放项目源码及需要引用的资源文件的主要位置。以下是src目录下常见文件夹和文件的用法&#xff1a; components 用途&#xff1a;存放可重用的Vue组件。这些组件通常用于在多个页面或布局中共享UI和功能。特点&#xff1a;组件应该是模块…

Midjourney 推出Style Tuner工具 ,统一风格,提升创作效率!

Midjourney 由前 Magic Leap 程序员大卫 - 霍尔茨&#xff08;David Holz&#xff09;构思&#xff0c;于 2022 年夏天推出&#xff0c;在独立消息应用 Discord 的服务器上吸引了超过 1600 万用户&#xff0c;并由一个小规模的程序员团队不断更新&#xff0c;推出了包括平移、扩…

【openlayers系统学习】00官网的Workshop介绍

00Workshop介绍 官方文档&#xff1a;https://openlayers.org/workshop/en/ openlayers官网Workshop学习。 通过官网Workshop&#xff0c;系统学习openlayers的使用。 基本设置 这些说明假定您从最新Workshop版本的 openlayers-workshop-en.zip​ 文件开始。此外&#xff…

并行模拟退火算法的golang练手实现

模拟退火&#xff08;Simulated Annealing, SA&#xff09;算法是一种概率型启发式搜索算法&#xff0c;它模仿了物理世界中的退火过程。退火是一种金属加工技术&#xff0c;通过缓慢降低材料的温度来减少其内部的缺陷。在优化问题中&#xff0c;模拟退火算法用于寻找全局最优解…

AI大模型探索之路-实战篇8:多轮对话与Function Calling技术应用

系列篇章&#x1f4a5; AI大模型探索之路-实战篇4&#xff1a;深入DB-GPT数据应用开发框架调研 AI大模型探索之路-实战篇5&#xff1a;探索Open Interpreter开放代码解释器调研 AI大模型探索之路-实战篇6&#xff1a;掌握Function Calling的详细流程 AI大模型探索之路-实战篇7…

Nginx SSL/TLS配置:搭建安全的HTTPS网站

随着互联网安全性的日益提升&#xff0c;HTTPS已经成为网站安全通信的标配。Nginx作为一款高性能的HTTP和反向代理服务器&#xff0c;支持SSL/TLS协议&#xff0c;使得我们可以轻松地搭建安全的HTTPS网站。下面&#xff0c;我们将详细介绍如何在Nginx上配置SSL/TLS&#xff0c;…

实验五:实现循环双链表各种基本运算的算法

实验五&#xff1a;实现循环双链表各种基本运算的算法 一、实验目的与要求 目的:领会循环双链表存储结构和掌握循环双链表中各种基本运算算法设计。 内容:编写一个程序cdinklist.cpp,实现循环双链表的各种基本运算和整体建表算法(假设循环双链表的元素类型ElemType为char),并…

俄罗斯半导体领域迈出坚实步伐:首台光刻机诞生,目标直指7纳米工艺

近日&#xff0c;国外媒体纷纷报道&#xff0c;俄罗斯在半导体技术领域取得了重要突破&#xff0c;首台光刻机已经制造完成并正在进行严格的测试阶段。这一里程碑式的事件标志着俄罗斯在自主发展半导体技术的道路上迈出了坚实的一步。 据俄罗斯联邦工业和贸易部副部长瓦西里-什…

基于光纤传感器的平面曲线重建算法建模

**基于光纤传感器的平面曲线重建算法建模** 一、引言 随着科技的快速发展&#xff0c;光纤传感技术作为一种新型传感器技术&#xff0c;已经广泛应用于各个领域。其中&#xff0c;基于光纤传感器的平面曲线重建算法建模是一个重要的研究方向。本文旨在探讨如何利用光纤传感器…

【源码】2024心悦搜剧源码百万级网盘资源

1、一键转存他人链接&#xff1a;就是将别人的分享链接转为你自己的 2、转存心悦搜剧资源&#xff1a;就是将心悦搜剧平台上的所有资源都转成你自己的 3、每日自动更新&#xff1a;自动转存每天的资源并入库 前端uin-app&#xff0c;后端PHP&#xff0c;兼容微信小程序

【VTKExamples::Utilities】第一期 动画模拟Animation

很高兴在雪易的CSDN遇见你 VTK技术爱好者 QQ:870202403 公众号:VTK忠粉 前言 本文分享VTK样例Animation,希望对各位小伙伴有所帮助! 感谢各位小伙伴的点赞+关注,小易会继续努力分享,一起进步! 你的点赞就是我的动力(^U^)ノ~YO 1. Animation 该样例介绍如…

【设计模式深度剖析】【4】【结构型】【组合模式】| 以文件系统为例加深理解

&#x1f448;️上一篇:适配器模式 设计模式深度剖析-专栏&#x1f448;️ 目 录 组合模式定义英文原话直译如何理解&#xff1f; 3个角色UML类图代码示例 组合模式的优点组合模式的使用场景示例解析&#xff1a;文件系统 组合模式 组合模式&#xff08;Composite Pattern&a…

多段图最短路径(动态规划法)

目录 前言 一、多段图的分析 二、算法思路 三、代码如下&#xff1a; 总结 前言 问题描述&#xff1a;设图G(V, E)是一个带权有向图&#xff0c;如果把顶点集合V划分成k个互不相交的子集Vi (2≤k≤n, 1≤i≤k)&#xff0c;使得对于E中的任何一条边(u, v)&#xff0c;必有u∈Vi&…

MSI U盘重装系统

MSI U盘重装系统 1. 准备一块U盘 首先需要将U盘格式化&#xff0c;这个格式化并不是在文件管理中将U盘里面的所有东西都删干净就可以了&#xff0c;需要在磁盘管理中&#xff0c;将这块U盘格式化&#xff0c;如果这块U盘有分区的话&#xff0c;那将所有的分区都格式化并且删除…

说说你了解过、使用过什么编程语言?比较小他们的优势说说你了解过、使用过什么编程工具?

我了解并且使用过多种编程语言&#xff0c;包括&#xff1a; 1. Python&#xff1a;Python是一种简洁而强大的编程语言&#xff0c;它具有易读性和易学性的特点。它支持面向对象编程和函数式编程&#xff0c;拥有丰富的第三方库和工具&#xff0c;适用于多种应用场景&#xff0…

一个专为程序员设计的精致 Java 博客系统

大家好&#xff0c;我是 Java陈序员。 今天&#xff0c;给大家介绍一个设计精致的博客系统&#xff0c;基于 Java 实现&#xff01; 关注微信公众号&#xff1a;【Java陈序员】&#xff0c;获取开源项目分享、AI副业分享、超200本经典计算机电子书籍等。 项目介绍 bolo-solo …

List过滤重复数据

一、背景&#xff08;着急的同学直接看实现&#xff09; 产品部门向小王提出了一项需求&#xff0c;要求根据多变的条件灵活组合&#xff0c;从一个对象集合中筛选出符合条件的项目。小王初时考虑通过创建多个定制化的equals方法来逐一对比筛选&#xff0c;正当他准备埋头编码…