• 基于粒子群算法(PSO)的路径规划问题研究 (Matlab代码实现)


    目录

    1 概述

    2 粒子群算法简介

    3 问题分析

    4 基本原理

    5 运行结果

    6 参考文献

    7 Matlab代码实现 


    1 概述

    最早科学家发现生物群体存在着某种有规律的趋利避害和活动觅食的生命活动,像鸟类、鱼群的觅食活动,蜂群的种族繁衍活动,狮群的家庭捕食行动等等,诸如此类的生物活动后来被联想到解决工程学上比较复杂的最优解问题,如比较复杂的电网规划求解,灌溉管道铺设路径最优化求解和建筑高楼的造价最优值。 大家比较熟悉的有遗传算法(BA)(上世纪六七十年代),粒子群算法(1995)和差分进化算法(1995)。

    2 粒子群算法简介

    粒子群算法1995年由J. Kennedy和R. C. Eberhart提出的一种智能计算的算法,以高速,整洁,求解精度高的特点迅速广为人知。 粒子群算法的提出也造就了学术界的诸多人物,很多学位的论文都会围绕粒子群算法的优化改进。 原理核心是“迭代进化,适者生存”。粒子群优化算法是一种新型群智能优化算法,因其概念简单,参数较少,容易实现等优点,使其获得了国内外众多研究人员的青睐,现已被广泛应用在函数优化、自动控制、机器学习、工程设计等领域。但由于 PSO 算法仍在发展中,其理论基础以及改进方法和应用领域还需要进一步的研究和拓展。

    3 问题分析

    路径规划是移动机器人导航最基本环节之一 ,它是按照某一性能指标 (如路径最短 、使用时间最 短或消耗能量最少等)搜索一条从起始状态到目标状态的最优或近似最优的无碰撞路径。传统的路径规划算法如势场法 、可视图法、遗传算法等,自身都存在一定的缺陷,使得路径搜索出现计算量过大 、效率不高 、寻优能力差等问题 ,保证不了对路径规划的计算效率和可靠性要求。
    粒子群优化算法 (ParticleSwarm Optimization,简称 PSO)是一种进化计算技术 ,同遗传算法类似,是一种基于迭代的优化工具 ,通过迭代搜寻最优值 。同遗传算法相比, PSO的优势在于简单、容易实现并且许多参数不需要调整。神经网络作为一个高度并行的分布式系统,为解决机器人系统的高实时性问题提供了可能性 ,并应用于智能自主移动机器人导航与路径规划等方面。

    基本原理

    为了解决传统路径规划算法存在的问题 ,本文采用一种新的智能算法进行路径规划 ,首先采用神经网络训练碰撞罚函数 ,得到无碰撞路径 ,然后采用粒子群优化算法解决路径的最优问题 。

    5 运行结果

    1. clear all
    2. clc
    3. % for o=1:4
    4. tic
    5. % for u=1:50
    6. %% 设置各参数值
    7. startX=0;startY=0; %起开始坐标
    8. endX=700;endY=700; %结束坐标
    9. c1=2;
    10. c2=2; %学习因子
    11. w=0.7; %惯性权数
    12. pop=20; %粒子数
    13. N_gen=500;
    14. popmax=700;
    15. popmin=0; %位置范围,根据测试函数而定
    16. Vmax=20;
    17. Vmin=-20; %速度范围,根据测试函数而定
    18. gridCount=30;
    19. %% 生成山峰
    20. threat=[304 400 0;404 320 0;440 500 0;279 310 0;560 220 0;172 527 0;....
    21. 194 220 0;272 522 0;350 200 0;....
    22. 650 400 0;740 250 0;540 375 0;510 600 0];
    23. r=[45 50 55 10 70 65 55 25 50 30 40 40 35];
    24. for i=1:length(r)
    25. figure(1)
    26. [x,y,z]=sphere;
    27. mesh(threat(i,1)+r(i)*x,threat(i,2)+r(i)*y,abs(threat(i,3)+r(i)*z));
    28. hold on
    29. end
    30. view([-30,-30,70])
    31. %% 初始化粒子
    32. for i=1:pop
    33. for j=1:gridCount
    34. X(i,j)=startX+j*(endX-startX)/(gridCount+1);
    35. Y(i,j)=startY+rand()*(endY-startY);
    36. path(i,2*j-1)=X(i,j);
    37. path(i,2*j)=Y(i,j);
    38. end
    39. end
    40. for i=1:pop
    41. [distance,pathpoint,positionPoint]=verify(path(i,:),threat,....
    42. r,startX,startY,endX,endY,gridCount);
    43. fitness(i)=distance;
    44. V(i,:)=5*rands(1,gridCount*2); %分布在速度范围内
    45. end
    46. [bestFitness,bestindex]=min(fitness);
    47. bestpath=path(bestindex,:);
    48. pbest=path;
    49. T=std(fitness);
    50. BestFitness=Inf;
    51. globalFitness=Inf;
    52. pathRecord=zeros(1,gridCount+1); bestRecord=zeros(1,gridCount+1);
    53. position=zeros(gridCount+1,2);
    54. %% 迭代取优
    55. for i=1:N_gen
    56. for j=1:pop
    57. V(j,:)=w*V(j,:)+c1*rand*(pbest(j,:)-path(j,:))+c2*rand*(bestpath-path(j,:)); %根据公式更新速度
    58. V(j,find(V(j,:)>Vmax))=Vmax; %限制速度大小
    59. V(j,find(V(j,:)<Vmin))=Vmin;
    60. path(j,:)=path(j,:)+V(j,:); %根据公式更新位置
    61. path(j,find(path(j,:)>popmax))=popmax; %限制位置大小
    62. path(j,find(path(j,:)<popmin))=popmin;
    63. [distance,pathpoint,positionPoint]=verify(path(j,:),threat,....
    64. r,startX,startY,endX,endY,gridCount);
    65. fmin=distance;
    66. if fmin<fitness(j)
    67. fitness(j)=fmin; %更新个体最优适应度
    68. pbest(j,:)=path(j,:); %更新个体最优值
    69. end
    70. if fmin<bestFitness
    71. bestFitness=fmin; %更新全局最优适应度
    72. bestpath=path(j,:); %更新全局最优值
    73. pathRecord=pathpoint;
    74. position=positionPoint;
    75. end
    76. end
    77. Fmin(i)=bestFitness;
    78. end
    79. % end
    80. % end
    81. %% 画出实体图
    82. record=[];
    83. count=1;
    84. i=gridCount+1;
    85. while i>1
    86. j=pathRecord(i);
    87. record(count,1)=position(i,1); record(count,2)=position(i,2);
    88. count=count+1;
    89. plot([position(i,1),position(j,1)],[position(i,2),position(j,2)],'Linewidth',2)
    90. axis([0,700,0,700]);
    91. i=j;
    92. end
    93. record(count,1)=position(i,1); record(count,2)=position(i,2);
    94. text(position(1,1)',position(1,2)','S');
    95. text(position(gridCount+1,1)',position(gridCount+1,2)','T');
    96. figure(2)
    97. plot(Fmin);
    98. % title(['最佳个体适应度变化趋势,最佳适应值=' num2str(BestFitness)])
    99. title(['最后适应值 =' num2str(min(Fmin))]);
    100. xlabel('迭代次数')
    101. ylabel('适应度值')
    102. %% 分析结果
    103. % plot(yy);
    104. % title(['适应度曲线 最优适应度值:' num2str(yy(500))]);
    105. % xlabel('进化次数');
    106. % ylabel('适应度');

    部分理论引用网络文献,如有侵权请联系删除。 

    6 参考文献

    [1]白晓兰,周文全,张振朋,袁铮.基于启发式粒子群算法的机器人平滑路径规划[J].组合机床与自动化加工技术,2022(08):44-47+52.DOI:10.13462/j.cnki.mmtamt.2022.08.011.

    [2]屈文婷. 基于粒子群算法及RBF神经网络技术的粮食产量预测方法[D].河南师范大学,2016.

    [3]吴高超. 基于粒子群算法的路径规划问题研究[D].燕山大学,2016.

    7 Matlab代码实现 

  • 相关阅读:
    c语言基础:L1-057 PTA使我精神焕发
    SveletJs学习——数据绑定
    python文件打包分发方法
    Windows下IntelliJ IDEA远程连接服务器中Hadoop运行WordCount(详细版)
    RTC实验
    http和dubbo接口调用主动设置超时时间
    【postgresql 】 ERROR: “name“ is not supported as an alias
    构建系列之前端脚手架vite
    机器学习:集成学习(Python)
    [附源码]计算机毕业设计面向高校活动聚AppSpringboot程序
  • 原文地址:https://blog.csdn.net/weixin_46039719/article/details/126940003