资源简介
用MATLAB 实现,基于栅格地图的Dijkstra算法路径规划。

代码片段和文件信息
function [] = Dijkstraguihua()
clear all;
close all;
disp(‘Dijkstra Path Planning start!!‘);
p.start=[4.527.5];
p.goal=[26.52.5];
p.XYMAX=30;
obstacle=GetBoundary(p);%初始化障碍物
path=Dijkstra(obstaclep);%30x2
figure(1)
if length(obstacle)>=1
plot(obstacle(:1)obstacle(:2)‘Or‘);
hold on;
end
plot(p.start(1)p.start(2)‘*b‘);hold on;
plot(p.goal(1)p.goal(2)‘*r‘);hold on;
if length(path)>=1
%plot(path(:1)path(:2)‘b‘‘linewidth‘2);
hold on;
end
j=size(path1);%30
mindistance=0;
for i=j:-1:2
s=distance(path(i1)path(i2)path(i-11)path(i-12));
mindistance=s+mindistance;
end
axis([0 p.XYMAX 0 p.XYMAX])
set(gca‘xtick‘0:1:p.XYMAX‘ytick‘0:1:p.XYMAX‘GridLinestyle‘‘-‘...
‘xgrid‘‘on‘‘ygrid‘‘on‘);
grid on;
disp(‘Shortest Length is‘)
disp( mindistance)
end
function path=Dijkstra(obstaclep)
path=[];
open=[p.start(1) p.start(2) 0 p.start(1) p.start(2)];
close=[];
next=MotionModel();
findFlag=false;
while ~findFlag
initNopen=length(open(:1));
if initNopen==0
disp(‘No path to goal!!‘);
return;
end
for io=1:initNopen
if isSamePosi(open(io1:2)p.goal)
disp(‘Find Goal!!‘);
close=[open;close];
findFlag=true;
break;
end
for in=1:length(next(:1))
m=[open(io1)+next(in1) open(io2)+next(in2) open(io3)+next(in3)];
if isObstacle(mobstacle)
continue;
end
[flag targetInd]=FindList(mopenclose);
if flag==1
if m(3) open(targetInd3)=m(3);
open(targetInd4)=open(io1);
open(targetInd5)=open(io2);
end
elseif flag==2
if m(3) close(targetInd4)=open(io1);
close(targetInd5)=open(io2);
open=[open; close(targetInd:)];
close(targetInd:)=[];
end
else
open=[open;[m open(io1) open(io2)]];
end
end
end
if findFlag==false
close=[close; open(1:initNopen:)];
open(1:initNopen:)=[];
end
%animation(openclosepobstacle);
end
path=GetPath(closep.startio);
end
function result=isSamePosi(ab)
result=false;
if a(1)==b(1) && a(2)==b(2)
result=true;
end
end
function boundary=GetBoundary(~)
boundary=[];
for i1=0:30
boundary=[boundary;[0.5 i1+0.5]];
boundary=[boundary;[28.5 i1+0.5]];
boundary=[boundary;[29.5 i1+0.5]];
end
for i2=0:30
%boundary=[boundary;[i2+0.5 0.5]];
boundary=[boundary;[i2+0.5 29.5]];
end
for i3=0:10
boundary=[boundary;[i3+8.5 24.5]];
boundary=[boundary;[i3+8.5 25.5]];
end
for i4=0:1
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 63140 2014-09-24 22:49 Dijkstra\09-24-2014 10-48-51 _jpg
文件 1515 2017-05-08 11:41 Dijkstra\DijkstraPlan.m
文件 10664 2017-05-08 14:20 Dijkstra\DijkstraSample.m
文件 5949 2017-06-01 12:06 Dijkstra\Dijkstraguihua.m
文件 4604 2017-05-09 16:42 Dijkstra\Dijkstrasampleyichu.m
文件 156 2017-05-09 16:48 Dijkstra\distance.m
目录 0 2018-01-19 09:30 Dijkstra\
- 上一篇:Matlab一维FDTD卷积边界条件CPML
- 下一篇:简单的声音滤波 matlab
相关资源
- Matlab路面裂缝识别69319
- 高灵敏度GPS接收机MATLAB仿真,附捕获
- 基于MATLAB的质点弹道计算与外弹道优
- 阵列天线的matlab仿真
- MATLAB 经典程序源代码大全
- MATLAB小波软阈值去噪代码33473
- 天线阵的波束形成在MATLAB仿真程序及
- 非线性SVM算法-matlab实现
- 《MATLAB 智能算法超级学习手册》-程序
- 组合导航matlab程序
- 读取txt文件内容matlab代码实现
- Matlab实现基于相关的模板匹配程序
- matlab优化工具箱讲解
- 基于MATLAB的快速傅里叶变换
- 光纤传输中的分布傅立叶算法matlab实
- 基于matlab的图像处理源程序
- matlab 椭圆拟合程序
- 算术编码解码matlab源代码
- optical_flow 光流法 matlab 实现程序
- 引导图像滤波器 Matlab实现
- 分形几何中一些经典图形的Matlab画法
- OFDM系统MATLAB仿真代码
- SVM工具箱(matlab中运行)
- 图像小波变换MatLab源代码
- LU分解的MATLAB实现
- 冈萨雷斯数字图像处理matlab版(第三
- 替代数据法的matlab程序
- 用matlab实现的多站定位系统性能仿真
- 通过不同方法进行粗糙集属性约简m
- k近邻算法matlab实现
评论
共有 条评论