码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 路径规划算法:基于果蝇优化的路径规划算法- 附代码


    路径规划算法:基于果蝇优化的路径规划算法- 附代码

    文章目录

    • 路径规划算法:基于果蝇优化的路径规划算法- 附代码
      • 1.算法原理
        • 1.1 环境设定
        • 1.2 约束条件
        • 1.3 适应度函数
      • 2.算法结果
      • 3.MATLAB代码
      • 4.参考文献

    摘要:本文主要介绍利用智能优化算法果蝇算法来进行路径规划。

    1.算法原理

    果蝇算法原理请参考:https://blog.csdn.net/u011835903/article/details/108344654

    1.1 环境设定

    在移动机器人的路径优化中,每个优化算法的解代表机器人的一条运动路径。优化算法会通过优化计算在众多路径中找出一条最优路径。
    优化算法的设定必须和机器人运动环境模型相对应。不失一般性,假设在用栅格法对机器人运动环境建模后得出的结果是 m×n 的矩形区域,坐标值从 1 开始,如图1 。其中坐标原点栅格代表机器人的初始位置,坐标 (m,n)对应的栅格代表机器人的移动目标位置。优化算法设定的一个重要内容是确定优化算法的数学表达形式,在这里这个问题转化为用一个向量表示机器人的移动路径。经过分析发现,尽管栅格法建立的模型对空间进行了离散化,但本质上机器人的移动路径依然是连续的。

    在这里插入图片描述

    图1.栅格地图

    1.2 约束条件

    对于机器人的路径优化来说,其运动路径必须局限在栅格空间内,即搜索不能越过栅格的矩形边界。此外,还应受障碍物的限制,即机器人的运动轨迹不能穿过存在障碍物的栅格区域。

    1.3 适应度函数

    在本文的建模方法中,本文路径规划目标是路径长度最短。路径的长度可以表示为:

    L ( P a t h ) = ∑ i = 0 n − 1 ( x l i + 1 − x l i ) 2 + ( y l i + 1 − y l i ) 2 (1) L(Path) = \sum_{i=0}^{n-1}\sqrt{(xl_{i+1} - xl_i)^2 + (yl_{i+1} - yl_{i})^2}\tag{1} L(Path)=i=0∑n−1​(xli+1​−xli​)2+(yli+1​−yli​)2 ​(1)
    其中(x,y)是路径中间点的坐标

    利用果蝇算法对上式进行寻优,找到最短路径。果蝇算法参数设定如下:

    %% 果蝇算法参数设置
    dim=length(noLM);%维度,即为非障碍物个数。
    numLM0=round((EndPoint(1)-StartPoint(1))/4);%每次迭代选取的的中间路径点个数,可调
    lb=0;%下边界
    ub=1;%上边界
    Max_iteration = 100;%最大迭代次数
    SearchAgents_no = 30;%种群数量
    fobj = @(x)fun(x,noS,noE,numLM0,net);%适应度函数
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2.算法结果

    在这里插入图片描述

    3.MATLAB代码

    本程序中,支持1.地图任意创建保存。2.其实点任意更改。

    4.参考文献

    [1]罗阳阳,彭晓燕.基于改进PSO的四轮移动机器人全局路径规划[J].计算机仿真,2020,37(07):373-379.

    [2]鲁丹. 粒子群算法在移动机器人路径规划中的应用研究[D].武汉科技大学,2009.

  • 相关阅读:
    金仓数据库 KingbaseES SQL 语言参考手册 (14. SQL语句:COMMIT 到 CREATE LANGUAGE)
    Cookie、Session、Token三者的区别
    C Primer Plus(6) 中文版 第2章 C语言概述 2.6 多个函数
    MYSQL sql的技巧与避坑
    UNPV2 学习:Posix Message Queues Exercise 解答记录
    【2022最新核心面试资料 】最强Java面试八股文秋招offer召唤术!入职薪资53k
    MCU USB设备
    你写过的最蠢的代码是?
    来看看安卓机的几个应用程序
    nonebot2-2.0.0b4 QQ机器人详细教程
  • 原文地址:https://blog.csdn.net/u011835903/article/details/130902816
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号