【路径规划-机器人栅格地图】基于蚁群算法求解大规模栅格地图路径规划及避障附Matlab代码

​1 内容介绍

随着问题规模不断增加,经典优化算法难以满足实际的需求,甚至无法得到较优解。相反,现代优化算法却表现出较好的性能,其中包括模拟退火算法(Simulatedannealing),遗传算法(Geneticalgorithm),人工神经网络算法(Neuralnetworks)[1]。“师法自然”,现代优化算法中很多都通过模拟自然界或者物理世界的现实存在来进行优化计算。20世纪90年代初由MDorigo提出的蚁群优化算法(AntColonyOptimization,ACO)是现代优化算法的一种,该算法模拟了自然界中蚂蚁的觅食行为[2]。蚁群优化算法最先被成功用于解决旅行商问题(TravelSalesmanProblem,TSP),能够有效的解决组合优化问题。和其智能算法一样,蚁群算法仍然存在着问题,包括难以平衡多样性和算法的收敛速度。进一步提高蚁群算法的性能是一个具有理论意义的问题。

自然界中,蚂蚁能够在巢穴和食物源间找到一条最优路线,并通过这条路径将食物运送回巢穴中,这样可以最少的消耗能量,有利于整个蚁群的生存。虽然单只蚂蚁的行为十分简单,但是一群蚂蚁却表现出一定的智能。著名的双桥实验验证了群体中的蚂蚁通过一种化学物质进行间接交流,该化学物质被称为信息素(pheromone),又称外激素,蚂蚁对这种信息素有一定的敏感性。每一只蚂蚁会受到其他蚂蚁信息素的影响,也会在经过的路径上释放信息素。蚂蚁在选择路径时,会更大概率的选择信息素较多的路径,这种正反馈效果使得经过的蚂蚁趋向于选择最短的路径。人们自然想到是否可以利用蚂蚁的这种特性去解决某些优化问题。自然界中,蚂蚁释放的信息素消失速度很慢,短时间内几乎不会有所减少。这种机制在有利于整个蚂蚁群体的同时,也存在另一种缺陷,如造成蚂蚁死亡旋涡现象[3]。在这种现象中,由于前面蚂蚁信息素的累积,整个蚁群跟随着一个旋涡型轨迹,持续转圈,直至最后很多蚂蚁死亡。因此,在利用蚂蚁的有利信息外,我们也必须想到如何避免某些固有的缺陷。

2 部分代码

clear;clc;

tic;

close all

%% 障碍物导入,如果起点终点设置不好,会出现错误

% load('barrier_1200x1200.mat');   goal = 1240000; start = 1;

load('barrier_reality_320.mat');  goal = 102079;  start = 1;

graph = barrier;

%% 参数的设置

antNumber = 30;         % 蚂蚁数目

NCmax = 200;            % 最大迭代次数

rhoGlobal = 0.08;       % 全局信息素挥发系数

rhoLocal = 0.1;         % 局部信息素挥发系数

Beta = 1;               % 启发函数式因子

Alpha = 1;              % 信息素函数因子

q0 = 0.8;               % 偏向选择的阈值

X = size(graph,1);      % 问题的状态空间矩阵的行数

Y = size(graph,2);      % 问题的状态空间矩阵的列数

tauInit = 1/((X+Y)*(X*Y));% 初始化信息素的量

tauInfo = tauInfoInit(X,Y,tauInit);

upPheromone = 500;      % 信息素上限

lowPheromone = tauInit;         % 信息素下限

bestSoFar_path_length = inf;    % 当前最优路径长度

bestSoFar_pathNode = [];

bestSoFar_PathNode = cell(1,NCmax);

bestSoFar_PathLength = zeros(1,NCmax);

%%

for NC=1:NCmax

    for k=1:antNumber

        currentNode = start;

        pathInfo = currentNode; % 记录一只蚂蚁的行驶路径的节点信息

        path_length = 0; % 记录蚂蚁走过的路径长度

        

        availableNode = findNextNodeSet(graph,currentNode); %% 未经过禁忌表处理的可选节点

        nodeNumber = size(availableNode,1);

        while(nodeNumber>0&&currentNode~=goal)

            heuristicInfo = computeHeuristicInfo(goal,currentNode,graph);

            tauInfo_ = tauInfo(currentNode,:)';

            [info,availableNode_] = computeConvertProbability(...

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%% 画出栅格

axis([0,X,0,Y])

figure(1)

for i=1:X

    for j=1:Y

        if barrier(i,j)==1

            x1=j;   y1=Y-i;

            x2=j;   y2=Y-i+1;

            x3=j-1; y3=Y-i+1;

            x4=j-1; y4=Y-i;

            fill([x1,x2,x3,x4],[y1,y2,y3,y4],[0,0,0]);

            hold on

        end

    end

end

%% 绘制全局最优路径节点信息

the_end_path = bestSoFar_pathNode;

the_end = length(bestSoFar_PathLength);

length_shortest = bestSoFar_PathLength(1,the_end);

len_ROUTS = length(the_end_path);

Rx = the_end_path;

Ry = the_end_path;

for i=1:len_ROUTS

    Rx(i) = ( mod(the_end_path(i)-1,X) +1-0.5);

    Ry(i) = ( Y- ceil(the_end_path(i)/Y) +1-0.5);

end

plot(Rx,Ry,'r-','lineWidth',2);% 画出最优路径图

title(['Length of the global shortest road is ',num2str(length_shortest)])

%% 绘制迭代图

figure(2)

plot(bestSoFar_PathLength,'r*-')

xlabel('Iterations')

ylabel('Length of the shortest road')

title(['Length of the global shortest road is ',num2str(length_shortest)])

% %% 清除参数

% clear x X x1 x2 x3 x4 xi y Y y1 y2 y3 y3 y4 yi the_end_path the_end tauInfo_ Rx Ry i j k lehgth_shortest...

%     len_ROUTS  upPheromone lowPheromone

%% 保存结果和参数

% str = strcat('result_',num2str(exercise));

% save(str)

% clear str

3 运行结果

4 参考文献

[1]周东健, 张兴国, 马海波,等. 基于栅格地图-蚁群算法的机器人最优路径规划[J]. 南通大学学报:自然科学版, 2013, 12(4):91-94.

博主简介:擅长智能优化算法神经网络预测信号处理元胞自动机图像处理路径规划无人机雷达通信无线传感器等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是基于蚁群算法求解栅格地图路径规划避障Matlab代码。 ```matlab clc; clear; close all; % 初始化地图 map = zeros(20, 20); map(1,:) = 1; map(end,:) = 1; map(:,1) = 1; map(:,end) = 1; map(10:15,6:8) = 1; map(5:8,12:15) = 1; % 绘制地图 figure(1); imagesc(map); colormap(gray); hold on; axis equal; axis off; % 蚂蚁个数 ant_num = 100; % 迭代次数 max_iter = 100; % 信息素挥发因子 rho = 0.5; % 最大信息素浓度 tau_max = 10; % 最小信息素浓度 tau_min = 0.1; % 蚂蚁初始位置 ant_pos = [2, 2]; % 目标位置 goal_pos = [18, 18]; % 初始化信息素浓度 tau = ones(size(map)) * tau_max; % 执行蚁群算法 for iter = 1:max_iter % 蚂蚁前进 for ant = 1:ant_num % 判断是否到达目标位置 if ant_pos(ant,:) == goal_pos continue; end % 根据信息素浓度和距离选择下一个位置 next_pos = choose_next_pos(ant_pos(ant,:), goal_pos, map, tau); % 新蚂蚁位置 ant_pos(ant,:) = next_pos; end % 新信息素浓度 delta_tau = zeros(size(map)); for ant = 1:ant_num % 计算蚂蚁完成任务的距离 dist = sqrt(sum((ant_pos(ant,:) - goal_pos).^2)); % 新信息素浓度 delta_tau(ant_pos(ant,1), ant_pos(ant,2)) = 1 / dist; end tau = (1 - rho) * tau + delta_tau; tau = max(tau, tau_min); tau = min(tau, tau_max); % 绘制路径 path = ant_pos(1,:); for ant = 1:ant_num if ant_pos(ant,:) == goal_pos path = [path; ant_pos(ant,:)]; end end plot(path(:,2), path(:,1), 'r', 'LineWidth', 2); drawnow; end % 选择下一个位置函数 function next_pos = choose_next_pos(curr_pos, goal_pos, map, tau) [m, n] = size(map); curr_row = curr_pos(1); curr_col = curr_pos(2); goal_row = goal_pos(1); goal_col = goal_pos(2); dist_to_goal = sqrt((curr_row - goal_row)^2 + (curr_col - goal_col)^2); p = zeros(3, 3); for r = -1:1 for c = -1:1 if r == 0 && c == 0 continue; end neighbor_row = curr_row + r; neighbor_col = curr_col + c; if neighbor_row < 1 || neighbor_row > m || neighbor_col < 1 || neighbor_col > n continue; end if map(neighbor_row, neighbor_col) == 1 continue; end dist_to_neighbor = sqrt((r)^2 + (c)^2); if dist_to_neighbor == 0 p(r+2, c+2) = 0; else p(r+2, c+2) = tau(neighbor_row, neighbor_col) * (1/dist_to_neighbor)^2; end end end p = p / sum(p, 'all'); [max_p, idx] = max(p(:)); [max_row, max_col] = ind2sub(size(p), idx); next_pos = [curr_row+max_row-2, curr_col+max_col-2]; end ``` 代码,我们首先初始化了一个20x20的栅格地图,并在其添加了两个障碍物。接着,我们定义了一些参数,如蚂蚁个数、迭代次数、信息素挥发因子、最大和最小信息素浓度等。然后,我们执行了蚁群算法,每个蚂蚁根据当前位置、目标位置、地图和信息素浓度选择下一个位置,新蚂蚁位置和信息素浓度,并绘制路径。最后,我们定义了一个函数`choose_next_pos`,用于选择下一个位置。 执行代码后,可以看到蚂蚁群在地图搜索路径并绕过障碍物,最终到达目标位置。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

matlab科研助手

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值