【路径规划】基于果蝇优化算法实现机器人路径规划matlab源码

一、简介

果蝇优化算法(FOA)是一种基于果蝇觅食行为推演出寻求全局优化的新方法。果蝇本身在感官知觉上优于其他物种,尤其是嗅觉和视觉上。果蝇的嗅觉器官能很好的搜集漂浮在空气中的各种气味,甚至能够嗅到40公里以外的食物源。然后,飞到食物位置附近后亦可使用敏锐的视觉发现食物和同伴聚集的位置,并且向该方向飞去。\ 果蝇算法可应用于求解最优解。\ 在这里插入图片描述\ 果蝇群体迭代搜寻食物的步骤如下:\ (1)随机初始化果蝇群体位置。\ Init Xaxis\ Init Yaxis

(2)赋予果蝇个体利用嗅觉搜寻食物的随机距离与方向。\ Xi = Xaxis + Random Value\ Yi = Yaxis + Random Value

(3)由于无法得知食物的位置,因此先估计与原点的距离(Dist),再计算味道浓度判定值(S),此值为距离的倒数。\ Disti = sqrt(Xi^2 + Yi^2)\ Si = 1 / Disti

(4)味道浓度判定值(S)代入味道浓度判定函数(或称为Fitness function)以求出该果蝇个体位置的味道浓度(Smelli)。\ Smelli = Function(Si)

(5)找出该果蝇群体中味道浓度最高的果蝇(求极大值)。\ [bestSmell bestIndex] = max(Smell)

(6)保留最佳味道浓度值与x、y的坐标,此时果蝇群体利用视觉往该位置飞去。\ Smellbest = bestSmell\ Xaxis = X(bestIndex)\ Yaxis = Y(bestIndex)

(7)进入迭代寻优,重复执行步骤2-5,并判断味道浓度是否优于前一迭代味道浓度,若是则实行步骤6。

二、源代码

``` %% 清空环境 clc; clear all; close all; tic %% 障碍物数据 position = load('barrier1.txt'); % plot([0,100],[0,100],'.'); axis([0 100 0 100]); hold on B = load('barrier1.txt'); xlabel('km','fontsize',12) ylabel('km','fontsize',12) title('二维规划空间','fontsize',12) %圆形障碍物数据 % r=10; theta=0:pi/100:2pi; % x=rcos(theta)+65; y=r*sin(theta)+50; % sizep = size(position); % sizet = size(theta); % for kk=1:sizet(2) % position(sizep(1)+kk,1)=x(kk); % position(sizep(1)+kk,2)=y(kk); % B(sizep(1)+kk,1)=x(kk); % B(sizep(1)+kk,2)=y(kk); % end

%% 描述起点和终点 Start = [0,0]; Target = [100,100]; plot([Start(1),Target(1)],[Start(2),Target(2)],'.');

% 图形标注 text(Start(1)+3,Start(2)+4,'S'); text(Target(1)-3,Target(2)-4,'T');

%% 描绘障碍物图形 fill(position([2,7,8,3],1),position([2,7,8,3],2),[0,0,0]); fill(position([4,9,10,5],1),position([4,9,10,5],2),[0,0,0]); fill(position([11,15,16,13],1),position([11,15,16,13],2),[0,0,0]); fill(position([17,20,21,18],1),position([17,20,21,18],2),[0,0,0]);

%% 描绘线及中点 % 下载链路端点数据 L = load('lines1.txt');

v = zeros(size(L)); %存储中点的坐标 for i=1:13 %%19表示连线数目即中点数目 plot([position(L(i,1),1),position(L(i,2),1)],[position(L(i,1),2)... ,position(L(i,2),2)],'color','black','LineStyle','--'); v(i,:) = (position(L(i,1),:)+position(L(i,2),:))/2; plot(v(i,1),v(i,2),'*'); text(v(i,1)+2,v(i,2),strcat('v',num2str(i))); end

%% 描绘可行路径 sign = load('matrix1.txt');%邻接矩阵 [n,m]=size(sign);

for i=1:n

if i == 1
    for k=1:m-1
        if sign(i,k) == 1
            plot([Start(1),v(k-1,1)],[Start(2),v(k-1,2)],'color',...
                'black','Linewidth',1,'LineStyle','-');
        end
    end
    continue;
end

for j=2:i
    if i == m
        if sign(i,j) == 1
            plot([Target(1),v(j-1,1)],[Target(2),v(j-1,2)],'color',...
                'black','Linewidth',1,'LineStyle','-');
        end
    else
        if sign(i,j) == 1
            plot([v(i-1,1),v(j-1,1)],[v(i-1,2),v(j-1,2)],...
                'color','black','Linewidth',1,'LineStyle','-');
        end
    end
end

end %到此能画出MAKLINK链路图 v1=zeros(15,2); %13个中点加上起始点和终止点 %v1存放包括S和T的总共22个结点,作为DijkstraPlan的参数 v1(1,:)=[0,0]; v1(15,:)=[100,100]; for i=2:14 v1(i,:)=v(i-1,:); end path = DijkstraPlan(v1,sign); j = path(15); plot([Target(1),v(j-1,1)],[Target(2),v(j-1,2)],'color','black','LineWidth',3,'LineStyle',':'); i = path(15); j = path(i); count = 0; while true plot([v(i-1,1),v(j-1,1)],[v(i-1,2),v(j-1,2)],'color','black','LineWidth',3,'LineStyle',':'); count = count + 1; i = j; j = path(i); if i == 1 || j==1 break; end end plot([Start(1),v(i-1,1)],[Start(2),v(i-1,2)],'color','black','LineWidth',3,'LineStyle',':'); count = count+3; pathtemp(count) = 15; j = 15; for i=2:count pathtemp(count-i+1) = path(j); j = path(j); end path = pathtemp; %到此能在规划空间中用黄线描绘出次优最短路径 pathCount = length(path)-2; %经过线段数量,相当于维数D

%% 经过的链接线 lines = zeros(pathCount,4); for i = 1:pathCount %lines用于存放各个结点所在链接线的起点和终点 lines(i,1:2) = B(L(path(i+1)-1,1),:); lines(i,3:4) = B(L(path(i+1)-1,2),:); end

% 初始最短路径 dijpathlen = 0; vv = zeros(15,2); vv(1,:) = Start; vv(15,:) = Target; vv(2:14,:) = v; for i=1:pathCount+1 dijpathlen = dijpathlen + sqrt((vv(path(i),1)-vv(path(i+1),1))^2+(vv(path(i),2)-vv(path(i+1),2))^2); end LL = dijpathlen; %得出的LL为次优最短路径的长度

%% 果蝇优化算法参数初始化 popsize=200; maxgen=200; gen=0; D=zeros(popsize,pathCount); S=zeros(popsize,pathCount); bestgensmell=zeros(1,maxgen);

%% 果蝇位置初始化及食物浓度计算 %* 随机初始果蝇群体位置。 Xaxis=1+1*rands(1,pathCount); Yaxis=1+1*rands(1,pathCount);

% * 果蝇寻优开始,利用嗅觉寻找食物。 for p=1:popsize X(p,:)=Xaxis+2*rand()-1; Y(p,:)=Yaxis+2*rand()-1;

for i=1:pathCount
%*** 求出与原点之距离

% D(p,i)=(X(p,i)^2+Y(p,i)^2)^0.5; % %* 味道浓度为距离之倒数,先求出味道浓度判定值。 % S(p,i)=1/D(p,i); S(p,i)=(X(p,i)+Y(p,i))*1.0/2; %%%%%% if(S(p,i)>1)%%范围限定在0到1之间 S(p,i)=1; end if(S(p,i)<0) S(p,i)=0; end

end

end

%*** 利用味道浓度判定函数求出味道浓度

for p=1:popsize w=S(p,:); Smell(p)=distance(w,pathCount,lines,Start,Target); end

%% 初始化公告板 [bestsmell, bestindex]=min(Smell); %* 利用视觉寻找伙伴聚集味道浓度最高之处,做法是保留最佳值初始位置及初始味道浓度。 Xaxis=X(bestindex,:); Yaxis=Y(bestindex,:); bestS=S(bestindex,:); SmellBest=bestsmell;

%% 果蝇搜索过程 %* 果蝇迭代寻优 for gen=1:maxgen % 利用嗅觉寻找食物 for p=1:popsize %* 初始果蝇个体飞行距离 X(p,:)=X_axis+2rand()-1; Y(p,:)=Y_axis+2*rand()-1;

for i=1:pathCount
%*** 求出与原点之距离

% D(p,i)=(X(p,i)^2+Y(p,i)^2)^0.5; % %* 味道浓度为距离之倒数,先求出味道浓度判定值。 % S(p,i)=1/D(p,i); S(p,i)=(X(p,i)+Y(p,i))*1.0/2; %%%%%% if(S(p,i)>1)%%范围限定在0到1之间 S(p,i)=1; end if(S(p,i)<0) S(p,i)=0; end end

end

```

三、源代码

在这里插入图片描述\ 在这里插入图片描述\ 在这里插入图片描述

MATLAB智能算法的源代码%% 清空环境 clc;clear %% 障碍物数据 position = load('barrier.txt'); plot([0,200],[0,200],'.'); hold on B = load('barrier.txt'); xlabel('km','fontsize',12) ylabel('km','fontsize',12) title('二维规划空间','fontsize',12) %% 描述起点和终点 S = [20,180]; T = [160,90]; plot([S(1),T(1)],[S(2),T(2)],'.'); % 图形标注 text(S(1)+2,S(2),'S'); text(T(1)+2,T(2),'T'); %% 描绘障碍物图形 fill(position(1:4,1),position(1:4,2),[0,0,0]); fill(position(5:8,1),position(5:8,2),[0,0,0]); fill(position(9:12,1),position(9:12,2),[0,0,0]); fill(position(13:15,1),position(13:15,2),[0,0,0]); % 下载链路端点数据 L = load('lines.txt'); %% 描绘线及中点 v = zeros(size(L)); for i=1:20 plot([position(L(i,1),1),position(L(i,2),1)],[position(L(i,1),2)... ,position(L(i,2),2)],'color','black','LineStyle','--'); v(i,:) = (position(L(i,1),:)+position(L(i,2),:))/2; plot(v(i,1),v(i,2),'*'); text(v(i,1)+2,v(i,2),strcat('v',num2str(i))); end %% 描绘可行路径 sign = load('matrix.txt'); [n,m]=size(sign); for i=1:n if i == 1 for k=1:m-1 if sign(i,k) == 1 plot([S(1),v(k-1,1)],[S(2),v(k-1,2)],'color',... 'black','Linewidth',2,'LineStyle','-'); end end continue; end for j=2:i if i == m if sign(i,j) == 1 plot([T(1),v(j-1,1)],[T(2),v(j-1,2)],'color',... 'black','Linewidth',2,'LineStyle','-'); end else if sign(i,j) == 1 plot([v(i-1,1),v(j-1,1)],[v(i-1,2),v(j-1,2)],... 'color','black','Linewidth',2,'LineStyle','-'); end end end end path = DijkstraPlan(position,sign); j = path(22); plot([T(1),v(j-1,1)],[T(2),v(j-1,2)],'color','yellow','LineWidth',3,'LineStyle','-.'); i = path(22); j = path(i); count = 0; while true plot([v(i-1,1),v(j-1,1)],[v(i-1,2),v(j-1,2)],'color','yellow','LineWidth',3,'LineStyle','-.'); count = count + 1; i = j; j = path(i); if i == 1 || j==1 break; end end plot([S(1),v(i-1,1)],[S(2),v(i-1,2)],'color','yellow','LineWidth',3,'LineStyle','-.'); count = count+3; pathtemp(count) = 22; j = 22; for i=2:count pathtemp(count-i+1) = path(j); j = path(j); end path = pathtemp; path = [1 9 8 7 13 14 12 22]; %% 蚁群算法参数初始化 pathCount = length(path)-2; %经过线段数量 pheCacuPara=2; %信息素计算参数 pheThres = 0.8; %信息素选择阈值 pheUpPara=[0.1 0.0003]; %信息素更新参数 qfz= zeros(pathCount,10); %启发值 phePara = ones(pathCount,10)*pheUpPara(2); %信息素 qfzPara1 = ones(10,1)*0.5; %启发信息参数 qfzPara2 = 1.1; %启发信息参数 m=10; %种群数量 NC=500; %循环次数 pathk = zeros(pathCount,m); %搜索结果记录 shortestpath = zeros(1,NC); %进化过程记录 %% 初始最短路径 dijpathlen = 0; vv = zeros(22,2); vv(1,:) = S; vv(22,:) = T; vv(2:21,:) = v; for i=1:pathCount-1 dijpathlen = dijpathlen + sqrt((vv(path(i),1)-vv(path(i+1),1))^2+(vv(path(i),2)-vv(path(i+1),2))^2); end LL = dijpathlen; %% 经过的链接线 lines = zeros(pathCount,4); for i = 1:pathCount lines(i,1:2) = B(L(path(i+1)-1,1),:); lines(i,3:4) = B(L(path(i+1)-1,2),:); end %% 循环搜索 for num = 1:NC %% 蚂蚁迭代寻优一次 for i=1:pathCount for k=1:m q = rand(); qfz(i,:) = (qfzPara2-abs((1:10)'/10-qfzPara1))/qfzPara2; %启发信息 if q<=pheThres%选择信息素最大值 arg = phePara(i,:).*(qfz(i,:).^pheCacuPara); j = find(arg == max(arg)); pathk(i,k) = j(1); else % 轮盘赌选择 arg = phePara(i,:).*(qfz(i,:).^pheCacuPara); sumarg = sum(arg); qq = (q-pheThres)/(1-pheThres); qtemp = 0; j = 1; while qtemp < qq qtemp = qtemp + (phePara(i,j)*(qfz(i,j)^pheCacuPara))/sumarg; j=j+1; end j=j-1; pathk(i,k) = j(1); end % 信息素更新 phePara(i,j) = (1-pheUpPara(1))*phePara(i,j)+pheUpPara(1)*pheUpPara(2); end end %% 计算路径长度 len = zeros(1,k); for k=1:m Pstart = S; Pend = lines(1,1:2) + (lines(1,3:4)-lines(1,1:2))*pathk(1,k)/10; for l=1:pathCount len(1,k) = len(1,k)+sqrt(sum((Pend-Pstart).^2)); Pstart = Pend; if l<pathCount Pend = lines(l+1,1:2) + (lines(l+1,3:4)-lines(l+1,1:2))*pathk(l+1,k)/10; end end Pend = T; len(1,k) = len(1,k)+sqrt(sum((Pend-Pstart).^2)); end %% 更新信息素 % 寻找最短路径 minlen = min(len); minlen = minlen(1); minant = find(len == minlen); minant = minant(1); % 更新全局最短路径 if minlen < LL LL = minlen; end % 更新信息素 for i=1:pathCount phePara(i,pathk(i,minant)) = (1-pheUpPara(1))* phePara(i,pathk(i,minant))+pheUpPara(1)*(1/minlen); end shortestpath(num) = minlen; end figure; plot(1:NC,shortestpath,'color','blue'); hold on % plot(1:NC,dijpathlen,'color','red'); ylabel('路径总长度'); xlabel('迭代次数');
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Matlab科研辅导帮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值