一、无人机简介

0 引言
随着现代技术的发展,飞行器种类不断变多,应用也日趋专一化、完善化,如专门用作植保的大疆PS-X625无人机,用作街景拍摄与监控巡察的宝鸡行翼航空科技的X8无人机,以及用作水下救援的白鲨MIX水下无人机等,决定飞行器性能主要是内部的飞控系统和外部的路径规划问题。就路径问题而言,在具体实施任务时仅靠操作员手中的遥控器控制无人飞行器执行相应的工作,可能会对操作员心理以及技术提出极高的要求,为了避免个人操作失误,进而造成飞行器损坏的危险,一种解决问题的方法就是对飞行器进行航迹规划。
飞行器的测量精度,航迹路径的合理规划,飞行器工作时的稳定性、安全性等这些变化对飞行器的综合控制系统要求越来越高。无人机航路规划是为了保证无人机完成特定的飞行任务,并且能够在完成任务的过程中躲避各种障碍、威胁区域而设计出最优航迹路线的问题。

1 常见的航迹规划算法

图1 常见路径规划算法
文中主要对无人机巡航阶段的航迹规划进行研究,假设无人机在飞行中维持高度与速度不变,那么航迹规划成为一个二维平面的规划问题。在航迹规划算法中,A算法计算简单,容易实现。在改进A算法基础上,提出一种新的、易于理解的改进A算法的无人机航迹规划方法。传统A算法将规划区域栅格化,节点扩展只限于栅格线的交叉点,在栅格线的交叉点与交叉点之间往往存在一定角度的两个运动方向。将存在角度的两段路径无限放大、细化,然后分别用两段上的相应路径规划点作为切点,找到相对应的组成内切圆的圆心,然后作弧,并求出相对应的两切点之间的弧所对应的圆心角,根据下式计算出弧线的长度

式中:R———内切圆的半径;
α———切点之间弧线对应的圆心角。

二、蝙蝠优化算法(BA)简介

蝙蝠算法( BA) 是 Yang 教授于 2010 年基于群体智能提出的启发式搜索算法,是一种搜索全局最优解的有效方法。该算法是一种基于迭代的优化技术,初始化为一组随机解,然后 通过迭代搜寻最优解,且在最优解周围通过随机飞行产生局部新解,加强了局部搜索。与其他算法相比,BA 在准确性和有效性方面远优于其他算法,且没有许多参数要进行调整。

三、部分源代码

clear all clc
%改进的蝙蝠算法在无人机航向上的规划应用第X次实验startX=0;startY=0;                            %起开始坐标                          endX=700;endY=700;                            %结束坐标gridCount=30;                                 %段点%% 蝙蝠算法相关参数Qmax=0.5;                                     %最大频率Qmin=0;                                       %最小频率Rmax=1;pop=20;                                       %种群个数N_gen=50;                                     %迭代的次数c1=2;                                         %粒子群算法系数c2=2;                                         %粒子群算法系数V=zeros(pop,2*gridCount);                     %速度的初始化Q=zeros(pop,gridCount);                       %频率的初始化S=zeros(pop,2*gridCount);                     %速度的初始化fang=0;                                       %早熟因子Std=0;                                        %标准系数F0=0.5;                                       %变异因子CR=0.5;                                       %杂交参数w=0.8;                                        %惯性权重pathMax=700;                                  %边界最大值pathMin=0;                                    %边界最小值a=0.9;path_bar_best=[];position_bar_best=[];%%%%%%%%%%%%%%%%%%%%初始化确立%%%%%%%%%%%%%%%%%%%        for i=1:pop           f(i)=rand();fang=fang+f(i);for j=1:2*gridCountR(i,j)=rand();A(i,j)=rand();endend%%%%%%%%%%%%%%%%%%%%参考差分进化算法中对早熟机制的处理%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%fang=fang/pop;for i=1:popf1(i)=abs(f(i)-fang);endif max(f1(i))>1ff=max(f1(i));elseff=1;endStd=Std+((f(i)-fang)/ff);Std=Std/pop;
%% 生成山峰threat=[304 400 0;404 320 0;440 500 0;279 310 0;560 220 0;172 527 0;....194 220 0;272 522 0;350 200 0;....650 400 0;740 250 0;540 375 0;510 600 0];r=[45 50 55 10 70 65 55 25 50 30 40 40 35];for i=1:length(r)figure(1)[x,y,z]=sphere;mesh(threat(i,1)+r(i)*x,threat(i,2)+r(i)*y,abs(threat(i,3)+r(i)*z));hold onendview([-30,-30,70])
%% 初始化粒子数
% for o=1:3
%     switch o
%         case 1
%             N_gen=100;
%         case 2
%             N_gen=200;
%         case 3
%             N_gen=300;
%     endtic
%     for u=1:25for i=1:popfor j=1:gridCountX(i,j)=startX+j*(endX-startX)/(gridCount+1);Y(i,j)=startY+rand()*(endY-startY);path(i,2*j-1)=X(i,j);path(i,2*j)=Y(i,j);endendfor i=1:pop[distance,pathpoint,positionPoint]=verify(path(i,:),threat,....r,startX,startY,endX,endY,gridCount);fitness(i)=distance;end[bestFitness,bestindex]=min(fitness);bestpath=path(bestindex,:);T=std(fitness); BestFitness=Inf;globalFitness=Inf;pathRecord=zeros(1,gridCount+1); bestRecord=zeros(1,gridCount+1);position=zeros(gridCount+1,2);%%  迭代开始for t=1:N_genfor i=1:pop    Q(i)=Qmin+(Qmin-Qmax)*rand();                      %蝙蝠算法的核心公式V(i,:)=V(i,:)+(bestpath-path(i,:))*Q(i);S(i,:)=path(i,:)+V(i,:);S(i,find(S(i,:)>pathMax))=pathMax;     S(i,find(S(i,:)<pathMin))=pathMin;aa=6^(-30*(-t/N_gen)^4);if  rand>R(i,:)                                  %step3 进行随机扰动A1=mean(A(i,:));S(i,:)=bestpath(:)+A1*aa;end[distance,pathpoint,positionPoint]=verify(bestpath,threat,....r,startX,startY,endX,endY,gridCount);fnew=distance;if rand<A(i)&&fitness(i)<fnew;A(i)=a*A(i);R(i,:)=Rmax*(1-exp(-0.9*t));enda=1;b=pop;dx=randperm(b-a+1)+a-1;j=dx(1);k=dx(2);p=dx(3);if j==ij=dx(4);elseif k==ik=dx(4);elseif p==ip=dx(4);end

四、运行结果


五、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1] 包子阳,余继周,杨杉.智能优化算法及其MATLAB实例(第2版)[M].电子工业出版社,2016.
[2]张岩,吴水根.MATLAB优化算法源代码[M].清华大学出版社,2017.

【三维路径规划】基于matlab改进的蝙蝠算法农用无人机三维路径规划【含Matlab源码 1514期】相关推荐

  1. 【BA三维路径规划】基于matlab改进的蝙蝠算法农用无人机三维路径规划【含Matlab源码 1514期】

    一.无人机简介 0 引言 随着现代技术的发展,飞行器种类不断变多,应用也日趋专一化.完善化,如专门用作植保的大疆PS-X625无人机,用作街景拍摄与监控巡察的宝鸡行翼航空科技的X8无人机,以及用作水下 ...

  2. 【Matlab人脸识别】人脸实时检测与跟踪【含GUI源码 673期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]人脸实时检测与跟踪[含GUI源码 673期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]孟逸凡,柳益君 ...

  3. 【Matlab指纹识别】指纹识别门禁系统【含GUI源码 1692期】

    一.代码运行视频(哔哩哔哩) [Matlab指纹识别]指纹识别门禁系统[含GUI源码 1692期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 包子阳,余继 ...

  4. 【Matlab树叶分类】BP神经网络植物叶片分类【含GUI源码 916期】

    一.代码运行视频(哔哩哔哩) [Matlab树叶分类]BP神经网络植物叶片分类[含GUI源码 916期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  5. 【Matlab水果蔬菜识别】形态学水果蔬菜识别【含GUI源码 919期】

    一.代码运行视频(哔哩哔哩) [Matlab水果蔬菜识别]形态学水果蔬菜识别[含GUI源码 919期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅. ...

  6. 【Matlab青草识别】形态学马唐草+牛筋草识别【含GUI源码 908期】

    一.代码运行视频(哔哩哔哩) [Matlab青草识别]形态学马唐草+牛筋草识别[含GUI源码 908期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  7. 【Matlab限速标志识别】形态学限速标志识别【含GUI源码 1142期】

    一.代码运行视频(哔哩哔哩) [Matlab限速标志识别]形态学限速标志识别[含GUI源码 1142期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  8. 【Matlab路径规划】改进的遗传算法机器人避障路径规划【含GUI源码 703期】

    一.代码运行视频(哔哩哔哩) [Matlab路径规划]改进的遗传算法机器人避障路径规划[含GUI源码 703期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] ...

  9. 【Matlab生物电信号】生物电信号仿真【含GUI源码 684期】

    一.代码运行视频(哔哩哔哩) [Matlab生物电信号]生物电信号仿真[含GUI源码 684期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]董兵,超于毅,李 ...

  10. 【Matlab语音分析】语音信号分析【含GUI源码 1718期】

    一.代码运行视频(哔哩哔哩) [Matlab语音分析]语音信号分析[含GUI源码 1718期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆,张磊,郑铁 ...

最新文章

  1. Linux运维工程师面试题第二套
  2. Zuul:智能路由和过滤(译)
  3. 好好学python·函数
  4. Linux Namespace系列(01):Namespace概述
  5. 隐藏频道_《TED频道》-隐藏真实自我
  6. 力争营收渠道多样化,Line 向自拍应用 Snow 投资 4500 万美元
  7. ARM9学习笔记之——SDRAM实验
  8. Android P环境 bootchart使用
  9. 台式计算机开机密码设置,设置台式电脑的开机锁屏密码的方法步骤
  10. “超详细” 山特UPS C3KR 的驱动安装教程
  11. esp8266控制ws2812b
  12. mysql 5.6 cmake 参数_编译cmake MySQL 5.6.10报错
  13. map转字符串数组中 php_php array_map()数组函数使用说明_PHP - ucfirst
  14. 【今日CV 计算机视觉论文速览 第150期】Fri, 2 Aug 2019
  15. Git 单文件上传大小限制
  16. 1024happyCTF
  17. 网络安全应急响应有哪些相关知识?
  18. 空间数据计算引擎GeoSpark调研
  19. 树莓派3B+安装JupyterLab
  20. PPT里面的背景音乐找不到?

热门文章

  1. Java 后端彻底解决跨域问题(CORS)
  2. C#与JavaScript中URL编码解码问题(转)
  3. 如何判断对象是否存活/死去
  4. Android开发——使用高级的RecyclerView实现侧滑菜单删除功能(SwipeRecyclerView)
  5. 使用git第一次成功,记录
  6. bzoj1692 [Usaco2007 Dec]队列变换
  7. C++中方法的(值参数、ref、out、params)详解
  8. 全触摸模式,让你尽享ipad 开发出的精品
  9. 七月算法机器学习 10 聚类算法与应用
  10. tinyxml读xml文件,转化字节,c#解析