【路径规划】基于Lazy

编程入门 行业动态 更新时间:2024-10-11 03:25:45

【<a href=https://www.elefans.com/category/jswz/34/1771438.html style=路径规划】基于Lazy"/>

【路径规划】基于Lazy

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信       无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机 

⛄ 内容介绍

​Lazy_Theta_star是在 Theta_star上的进一步改进,Theta_star是当节点加入open表时和当前点的父节点进行比较g值是否更小,对一些不必要的节点计算浪费了时间,而Lazy_Theta_star则是在弹出open表后进行比较,减少了不必要点的计算。

⛄ 部分代码

function Lazy_Theta_star

clc;

clear;

close all

%% 初始化界面

%load maze.mat map

 n = 20;   % field size n x n tiles  20*20的界面

%wallpercent = 0.3;  % this percent of field is walls   15%的界面作为阻碍物(墙)

cmap = [1 1 1; ...%  1 - white - 空地

        0 0 0; ...% 2 - black - 障碍 

        1 0 0; ...% 3 - red - 已搜索过的地方

        0 0 1; ...% 4 - blue - 下次搜索备选中心 

        0 1 0; ...% 5 - green - 起始点

        1 1 0;...% 6 - yellow -  到目 标点的路径 

       1 0 1];% 7 - -  目标点 

colormap(cmap); 

global field

field= ones(n);

startposind =22;   %sub2ind用来将行列坐标转换为线性坐标,这里是必要的,因为如果把startposind设置成[x,y]的形式,访问field([x,y])的时候

goalposind =250;    %它并不是访问x行y列元素,而是访问线性坐标为x和y的两个元素

 %field(ceil(n^2.*rand(floor(n*n*wallpercent),1) )) =2;

field(1:5, 7) = 2;

field(8,1:3) = 2; 

field(3:5,1:5)=2;

field(5,4)=2;

% startposind = sub2ind([n,n],ceil(n.*rand),ceil(n.*rand));   %sub2ind用来将行列坐标转换为线性坐标,这里是必要的,因为如果把startposind设置成[x,y]的形式,访问field([x,y])的时候

%goalposind = sub2ind([n,n],ceil(n.*rand),ceil(n.*rand));    %它并不是访问x行y列元素,而是访问线性坐标为x和y的两个元素

field(startposind )=5;

field(goalposind )=7;

costchart = NaN*ones(n);      %costchart用来存储各个点的实际代价,NaN代表不是数据(不明确的操作)

costchart(startposind) = 0;     %起点的实际代价

fieldpointers = zeros(n); %fieldpointers用来存储节点的父节点

global setOpenCosts;

setOpen = (startposind); setOpenCosts = (0); setOpenHeuristics = (Inf);

setClosed = []; setClosedCosts = [];%初始化起点的open表和close表

 [goalpos(1) ,goalpos(2)] = ind2sub([n n],goalposind); 

% uicontrol('Style','pushbutton','String','RE-DO', 'FontSize',12, ...

%          'Position', [10 10 60 40], 'Callback','ASTAR');

⛄ 运行结果

⛄ 参考文献

⛳️ 代码获取关注我

❤️部分理论引用网络文献,若有侵权联系博主删除

❤️ 关注我领取海量matlab电子书和数学建模资料

 

更多推荐

【路径规划】基于Lazy

本文发布于:2024-03-14 14:47:33,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1736706.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:路径   Lazy

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!