基于Dijkstra和A*算法的机器人路径规划(Matlab代码实现)

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

👨‍💻4 Matlab代码


 

💥1 概述

网络分析是GIS中非常重要的空间分析功能之一, 最短路径分析又是网络分析的核心算法, 该算法的效率决定了网络分析的功能和效率。在大量的最短路算法中, Dijksta算法是一种最经典的方法, 很多算法都是在该算法的基础上经过改进发展而来的。本文就是在详细研究该算法的基础上, 结合矢量数据的拓扑关系, 满足实际应用中的网络分析需求而优化的一种算法。

使用Dijkstra算法基于网络的权矩阵求解最短路问题的计算机算法和程序中, 运用了关联矩阵、邻接矩阵和距离矩阵的概念。在存储图形数据和运算时, 需要定义N×N的数组, 其中N为网络的结点数, 当网络的结点数较大时, 将占用大量的计算机内存。如果不对Dijkstra算法进行优化, 该算法很难在实际中得到应用。

📚2 运行结果

 

🎉3 参考文献

[1]张福浩,刘纪平,李青元.基于Dijkstra算法的一种最短路径优化算法[J].遥感信息,2004(02):38-41.

👨‍💻4 Matlab代码

主函数部分代码:

%% Define a small map
map = false(10);

% Add an obstacle
map (1:9, 6) = true;

start_coords = [6, 2];
dest_coords  = [8, 9];

%%
close all;
[route, numExpanded] = DijkstraGrid (map, start_coords, dest_coords);
% Uncomment following line to run Astar
[route, numExpanded] = AStarGrid (map, start_coords, dest_coords);
 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值