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


     👨‍🎓个人主页:研学社的博客 

    💥💥💞💞欢迎来到本博客❤️❤️💥💥

    🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

    ⛳️座右铭:行百里者,半于九十。

    📋📋📋本文目录如下:🎁🎁🎁

    目录

    💥1 概述

    📚2 运行结果

    🌈3 Matlab代码实现

    🎉4 参考文献


    💥1 概述

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

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

    📚2 运行结果

     部分代码:

    %% 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);

    %% 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);

    %% 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);

    %% 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);

    🌈3 Matlab代码实现

    🎉4 参考文献

    部分理论来源于网络,如有侵权请联系删除。

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

  • 相关阅读:
    Vue入门
    c++_learning-进阶部分
    【Linux】操作系统以及虚拟机的安装与配置
    2022“杭电杯”中国大学生算法设计超级联赛(4)签到题5题
    java实现快速排序的方法
    WKWebview加载SVG显示不全
    (附源码)python电影院信息管理系统 毕业设计 021844
    [附源码]java毕业设计公益劳动招募管理系统
    vue2和vue3浏览器兼容性对比
    6134. 找到离给定两个节点最近的节点-力扣双百代码
  • 原文地址:https://blog.csdn.net/weixin_46039719/article/details/128180635