m分别使用Dijkstra算法和Astar算法进行刚体机器人最短路径搜索和避障算法的matlab仿真,带GUI界面

简介: m分别使用Dijkstra算法和Astar算法进行刚体机器人最短路径搜索和避障算法的matlab仿真,带GUI界面

1.算法描述

   Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计算一个节点到其他所有节点的最短路径。主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止(BFS、prime算法都有类似思想)。Dijkstra算法能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低。

算法描述

(1)S为已经找到的从v出发的最短路径的终点集合,它的初始状态为空集,将源点加入S中。 其余顶点构成集合U。

(2)构建源点到其余顶点的距离列表,与源点不相连的顶点距离记为∞。

(3)广度遍历与源点相连的顶点,找到距离最近的顶点,则到这个顶点的最短路径就确定了,最短距离就是当前距离,将这个顶点从U中拿出,放入S中。

(4)用当前的顶点作为中间点,对其进行广度遍历,对遍历到的顶点距离进行更新。

(5)在U中搜索最短距离的顶点,将其放入S。

(6)以这个节点作为中间点广度搜索,更新距离。

(7)重复这个过程,直至U为空。

   Astar算法是一种图形搜索算法,常用于寻路。它是个以广度优先搜索为基础,集Dijkstra算法与最佳优先(best fit)算法特点于一身的一种 算法。AStar(又称 A*),它结合了 Dijkstra 算法的节点信息(倾向于距离起点较近的节点)和贪心算法的最好优先搜索算法信息(倾向于距离目标较近的节点)。可以像 Dijkstra 算法一样保证找到最短路径,同时也像贪心最好优先搜索算法一样使用启发值对算法进行引导。AStar的核心在于将游戏背景分为一个又一个格子,每个格子有自己的靠谱值,然后通过遍历起点的格子去找到周围靠谱的格子,接着继续遍历周围…… 最终找到终点。

2.仿真效果预览
matlab2022a仿真结果如下:

1.png
2.png
3.png

3.MATLAB核心程序

function pushbutton1_Callback(hObject, eventdata, handles)
% hObject    handle to pushbutton1 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
isshow = 0;
if get(handles.checkbox1,'Value')==1
   isshow = 1;%是否显示动态过程
else
   isshow = 0;
end
 
isshow2 = 0;
if get(handles.checkbox2,'Value')==1
   isshow2 = 1;%是否显示搜索区域
else
   isshow2 = 0;
end 
 
isrigid = 0;
if get(handles.checkbox3,'Value')==1
   isrigid = 1;%是否为刚体机器人
else
   isrigid = 0;
end
 
algsel = 0;
if get(handles.checkbox4,'Value')==1
   algsel = 1;%算法选择
else
   algsel = 0;
end
 
 
X      = 250;
Y      = 150;
% Resolution / Grid Size for the Map_updata
%网格化处理,转换为矩阵
step   = str2num(get(handles.edit1,'string'));;%定义精度越小,精度越高
tmps1  = str2num(get(handles.edit2,'string'));
tmps2  = str2num(get(handles.edit3,'string'));
 
tmps3  = str2num(get(handles.edit4,'string'));
tmps4  = str2num(get(handles.edit5,'string'));
 
 
% Start point
Starts    = floor([tmps1(1),tmps1(2)]/step)
% Robot radius
Rad       = floor(tmps3/step);
% Clearance 
Clearance = floor(tmps4/step);
 
% Goal point
Ends   = floor([tmps2(1),tmps2(2)]/step);
 
Map    = func_map(X,Y,step);
Mapr   = func_map_rigid(X,Y,step,Clearance);
 
[R,C] = size(Map);
 
axes(handles.axes1);
Color_Map = [1,1,1;0,0,0;1,1,0;1,1,0;0,1,1;1,0,1;1,0,0]; 
 
Map_updata1 = Map;
Map_updata2 = Mapr;
 
Map_updata1(Starts(2),Starts(1)) = 5;%起点 
Map_updata1(Ends(2)  ,Ends(1))   = 6;%终点 
Map_updata2(Starts(2),Starts(1)) = 5;%起点 
Map_updata2(Ends(2)  ,Ends(1))   = 6;%终点 
 
colormap(Color_Map); 
image(Map_updata1);  
axis image; 
 
if algsel == 0
   [Map_updata,route]=func_Dijkstra(Map_updata1,Map_updata2,Starts,Ends,R,C,isshow,isshow2,isrigid);
else
   [Map_updata,route]=func_Astar(Map_updata1,Map_updata2,Starts,Ends,R,C,isshow,isshow2,isrigid);
end
Map_updata_=Map_updata;
for k = 2:length(route)-1 
    Map_updata(route(k)) = 7; 
    tmps = Map_updata_(route(k));
    Map_updata_(route(k))= 7; 
    
    image(Map_updata); 
    %显示机器人
    [x,y]=find(Map_updata_==7);
    hold on
    if isrigid==0
       plot(y(1),x(1),'bo','MarkerSize',2); 
    else
       [xrr,yrr] = rigid_robot(Rad,y(1),x(1));  
       plot(xrr,yrr,'b-');     
    end
    hold off;
    axis image; 
    
    Map_updata_(route(k))= tmps; 
    pause(0.00002);         
end 
02_064m
相关文章
|
5天前
|
机器学习/深度学习 人工智能 算法
基于DCT和扩频的音频水印嵌入提取算法matlab仿真
本文介绍了结合DCT和扩频技术的音频水印算法,用于在不降低音质的情况下嵌入版权信息。在matlab2022a中实现,算法利用DCT进行频域处理,通过扩频增强水印的隐蔽性和抗攻击性。核心程序展示了水印的嵌入与提取过程,包括DCT变换、水印扩频及反变换步骤。该方法有效且专业,未来研究将侧重于提高实用性和安全性。
|
3天前
|
机器学习/深度学习 算法 数据挖掘
基于PSO优化的CNN-LSTM-Attention的时间序列回归预测matlab仿真
该文档介绍了使用MATLAB2022A中PSO优化算法提升时间序列预测模型性能的过程。PSO优化前后对比显示了优化效果。算法基于CNN、LSTM和Attention机制构建CNN-LSTM-Attention模型,利用PSO调整模型超参数。代码示例展示了PSO的迭代优化过程及训练、预测和误差分析环节。最终,模型的预测结果以图形形式展示,并保存了相关数据。
|
24天前
雷达模糊函数及MATLAB仿真(三)
雷达模糊函数及MATLAB仿真
15 0
|
2月前
|
传感器 人工智能 监控
智能耕耘机器人
智能耕耘机器人
43 3
|
6月前
|
人工智能 自然语言处理 机器人
智能电话机器人核心技术:自然语言处理
什么是自然语言处理? 自然语言处理是计算机科学领域与人工智能领域中的一个重要方向.它研究能实现人与计算机之间用自然语言进行有效通信的各种理论和方法.自然语言处理是一门融语言学、计算机科学、数学于一体的科学.因此,这一领域的研究将涉及自然语言,即人们日常使用的语言,所以它与语言学的研究有着密切的联系,但又有重要的区别. 自然语言处理并不是一般地研究自然语言,而在于研制能有效地实现自然语言通信的计算机系统,特别是其中的软件系统.因而它是计算机科学的一部分. 自然语言处理(NLP)是计算机科学,人工智能,语言学关注计算机和人类(自然)语言之间的相互作用的领域.
|
1月前
|
传感器 人工智能 自然语言处理
智能咖啡厅助手:人形机器人 +融合大模型,行为驱动的智能咖啡厅机器人
智能咖啡厅助手:人形机器人 +融合大模型,行为驱动的智能咖啡厅机器人
智能咖啡厅助手:人形机器人 +融合大模型,行为驱动的智能咖啡厅机器人
|
2月前
|
传感器 机器学习/深度学习 算法
植保机器人具备智能感知与决策能力
植保机器人具备智能感知与决策能力
19 2
|
3月前
|
传感器 搜索推荐 机器人
具身智能赋能人形机器人产业将蓬勃发展
【1月更文挑战第12天】具身智能赋能人形机器人产业将蓬勃发展
45 3
具身智能赋能人形机器人产业将蓬勃发展
|
3月前
|
机器学习/深度学习 人工智能 算法
智能AI机器人管家
应用场景:四层别墅,每层面积1000平+,有自己的地下停车场,地下酒窖,阳光房,花园,广场。在此场景下想做一个智能机器人管家。 主要功能: 1、自动跟随制定的人,可以根据设定的人的语音指令做一些动作,比如:停下、充电、倒退、去某个地方等等。 2、可以根据设定的人的语音回答一些常见问题,比如:今天天气,股票走势,黄金走势,钢铁走势等能够从网上直接获取到的信息。 3、可以根据设定的人的语音回答一些本地问题,比如家里还有多少酒,调一下某地的监控,花房的温度多少,打开某房间的空调。 4、可以帮助做一些本企业决策性的问题。
|
3月前
|
人工智能 自然语言处理 搜索推荐
基于阿里云向量检索服务搭建AI智能问答机器人
基于阿里云向量检索服务搭建AI智能问答机器人
123285 38