MATLAB智能算法 - AntColonyOptimization蚁群算法

news2025/1/11 11:01:48

AntColonyOptimization蚁群算法

智能算法是路线规划、深度学习等等一系列领域所使用的优化算法,是算法进阶之路的必备之路。

前言:本文主要围绕解决TSP旅行商问题展开,对于机器人的路线规划以及非线性方程求解的问题等解决方案
对于一些其他优化算法例如遗传算法解决一些现实问题都有实现!!

先看一下效果图:

蚁群算法解决TSP问题:

TSP问题

蚁群算法解决机器人路径规划问题:

路径规划

1、什么是蚁群算法

1.1、蚁群算法的来源

  同遗传算法相似,都来自于大自然的启迪。蚁群算法就来自于蚂蚁寻找食物过程中发现路径的行为。
  蚂蚁并没有视觉却可以寻找到食物,这得益于蚂蚁分泌的信息素,蚂蚁之间相互独立,彼此之间通过信息素进行交流,从而实现群体行为。

1.2、蚁群算法的基本原理

  基本原理的过程就是蚂蚁觅食的过程。首先,蚂蚁在觅食的过程中会在路径上留下信息素的物质,并在寻找食物的过程中感知这种物质的强度,并指导自己的行为方向,他们总会朝着浓度高的方向前进。因此可以看得出来,蚂蚁觅食的过程是一个正反馈的过程,该路段经过的蚂蚁越多,信息素留下的就越多,浓度越高,更多的蚂蚁都会选择这个路段。

2、蚁群算法的实现原理

2.1、蚁群算法实现的重要规则(细品

1. 避障规则
  如果蚂蚁要移动的方向有障碍物挡住,他会随机的选择另外一个方向,如果有信息素指引的话,会按照信息素的指引前进。
2. 散播信息素规则
  每只蚂蚁在刚找到食物的时候散发出来的信息素最多,并随着走选的距离,散播的信息越少。
3. 范围
  蚂蚁观察的范围有限,只能在局部的范围内进行选择。例如蚂蚁观察的范围为3*3,那么它能够移动的范围也就是在这个3*3区域内。
4. 移动规则
  前面也说过,蚂蚁的前进方向的选择依赖于信息素的浓度,回朝向信息素高的方向移动。当周围没有信息素或者信息素相同的时候,那么蚂蚁就会按照原来的方向继续前进,并且在前进方向上受到一个随机的扰动,为了避免再原地转圈,他会记住之前经过的点,下一次遇到的时候就会避开这个已经经过的点。
5. 觅食规则
  如果蚂蚁在感知范围内找到食物则直接过去,加速模型的收敛,否则朝着信息素高的方向前进,并且每只蚂蚁都有小概率的犯错误,从而不是信息素最多的点移动,打破局部最优解的情况。
6. 环境
  每只蚂蚁之间相互独立,他们依赖环境中的信息素进行交流。每只蚂蚁都仅仅能感知到环境内的信息。并且随机信息素会随着时间逐渐减少。如果这条路上经过的蚂蚁越来越少,那么信息素也会越来越少。

2.2、蚁群算法解决TSP问题的过程

  旅行商问题(Traveling saleman problem, TSP)是物流配送的典型问题,他的求解有十分重要的理论和现实意义。

  旅行商问题传统的解决方法都是遗传算法,但是遗传算法的收敛速度慢,具有一定的缺陷。

  在求解TSP蚁群算法中,每只蚂蚁相互独立,用于构造不同的路线,蚂蚁之间通过信息素进行交流,合作求解。

基本过程如下:

  1. 初始化,设置迭代次数;
  2. 将 ants 只蚂蚁放置到 cities 个城市上;
  3. ants只蚂蚁按照概率函数选择下一个城市,并完成所有城市的周游;
  4. 记录本次迭代的最优路线;
  5. 全局更新信息素。
  6. 终止。本例终止条件是迭代次数,也可以设置运行时间或最短路径的下限。
  7. 输出结果

  应用全局更新信息素来改变路径上信息素的值。当ants蚂蚁生成了ants个解,其中最短路径的是本代最优解,将属于这条路线上的所有关联的路线进行信息素更新。

  之所以使用全局信息素,是为了让最优路径上有格外的信息素支持,这样后面的蚂蚁会优先选择这条路线。并且伴随着信息素的挥发,全局最短路径关联路线信息素得到进一步增强。

3、蚁群算法TSP程序实现

3.1、程序中矩阵大小以及含义

程序中矩阵说明(首字母大写):

矩阵大小含义
Distance(城市数量,城市数量)表征各个城市之间的距离信息
Eta(城市数量,城市数量)表征各个城市之间的启发因子
Tau(城市数量,城市数量)表征各个城市之间信息素的值
Route(蚂蚁个数,城市数量)每只蚂蚁周游城市的记录矩阵
R_best(迭代次数,城市数量)每次迭代的最优路线
L_best(迭代次数,1)每次迭代的最短距离
L_ave(迭代次数,1)每次迭代的平均距离

3.2、整体架构

'3.3、初始化变量参数'
'3.4、初始化矩阵参数'

while '迭代次数'
    '3.5、安排蚂蚁初始位置'
    '3.6、蚂蚁周游'
    '3.7、记录最优路线以及最短距离'
    '3.8、更新信息素'
end
'3.9、结果输出'

3.3、初始化变量参数

初始化主要对程序当中重要参数进行声明。
程序实现:

% 随机产生40个城市的坐标
position = 50 * randn(40, 2);
epochs = 50;  % 迭代次数
% 蚂蚁个数最好大于等于城市个数,保证每个城市都有一个蚂蚁
ants = 40;  
alpha = 1.4;  % 表征信息素重要程度参数
beta = 2.2;  % 表征启发因子重要程度参数
rho = 0.15;  % 信息素挥发参数
Q = 10^6;  % 信息素增强系数
cities = size(position, 1);  % 城市个数

3.4、初始化矩阵参数

主要实现了重要矩阵声明以及初始化。
程序实现:

% 城市之间的距离矩阵
Distance = ones(cities, cities);
for i = 1: cities
    for j = 1: cities
        if i ~= j
            % 坐标点欧氏距离
            Distance(i, j) = ((position(i, 1) - position(j, 1))^2 + (position(i, 2) - position(j, 2))^2)^0.5;
        else
            % 因为后面要取倒数,所以取一个浮点数精度大小
            Distance(i, j) = eps;
        end
        Distance(j, i) = Distance(i, j);
    end
end
% 启发因子矩阵
Eta = 1./Distance;
% 信息素初始值每个路线均相同为 1
Tau = ones(cities, cities);
% 每只蚂蚁的路线图
Route = zeros(ants, cities);
epoch = 1;
% 记录每回合最优城市
R_best = zeros(epochs, cities);
% 记录每回合最短距离
L_best = inf .* ones(epochs, 1);
% 记录每回合平均距离
L_ave = zeros(epochs, 1);

3.5、安排蚂蚁初始位置

  主要是将所有的蚂蚁安置在所有的城市当中,蚂蚁个数 >= 城市个数。并且保证均匀分布。

% 初始随机位置
RandPos = [];
for i = 1: ceil(ants / cities)
    RandPos = [RandPos, randperm(cities)];
end
% 初始位置转置就对应了Route矩阵中每只蚂蚁的初始位置
Route(:, 1) = (RandPos(1, 1:ants))';

3.6、蚂蚁周游

  由于蚂蚁的初始位置已经确定,所有主要就是周游剩余的所有城市,循环(cities-1)次。里面的循环就是将所有的蚂蚁进行周游一次。

  对于每只蚂蚁的周游主要是对剩余的城市进行周游,不能重复拜访同一个城市。NoVisited矩阵存储着该蚂蚁未访问的城市。然后在所有没有访问过城市中选择一个。选择的方式也是类似于轮盘赌法。概率函数表征信息素和启发因子,两者有着不同的重要程度。
P = [ τ i j ( t ) ] α ⋅ [ η i j ] β P = [\tau_{ij}(t)]^\alpha · [\eta_{ij}]^\beta P=[τij(t)]α[ηij]β
其中 τ i j ( t ) \tau_{ij}(t) τij(t)为路线上 ( i , j ) (i, j) (i,j)上的信息素浓度; η i j \eta_{ij} ηij为路线上 ( i , j ) (i, j) (i,j)上的启发式信息;
程序实现:

for j = 2: cities
        for i = 1: ants
            Visited = Route(i, 1:j-1);
            NoVisited = zeros(1, (cities - j + 1));
            P = NoVisited;
            num = 1;
            for k = 1: cities
                if length(find(Visited == k)) == 0
                    NoVisited(num) = k;
                    num = num + 1;
                end
            end
            for k = 1: length(NoVisited)
                P(k) = (Tau(Visited(end), NoVisited(k))^alpha) * (Eta(Visited(end), NoVisited(k))^beta);
            end
            P = P / sum(P);
            Pcum = cumsum(P);
            select = find(Pcum >= rand);
            to_visit = NoVisited(select(1));
            Route(i, j) = to_visit;
        end
    end

3.7、记录最优路线以及最短距离

  计算每个回合每只蚂蚁走过的距离。并记录该回合最短路径,最短距离和平均距离。

Distance_epoch = zeros(ants, 1);
for i = 1: ants
    R = Route(i, :);
    for j = 1: cities - 1
        Distance_epoch(i) = Distance_epoch(i) + Distance(R(j), R(j + 1));
    end
    Distance_epoch(i) = Distance_epoch(i) + Distance(R(1), R(cities));
end
L_best(epoch) = min(Distance_epoch);
pos = find(Distance_epoch == L_best(epoch));
R_best(epoch, :) = Route(pos(1), :);
L_ave(epoch) = mean(Distance_epoch);
epoch = epoch + 1;

3.8、更新信息素

  更新信息素主要保证获得最优距离的那条路线的信息素得到最大的增强。

Delta_Tau = zeros(cities, cities);
for i = 1: ants
    for j = 1: (cities - 1)
        Delta_Tau(Route(i, j), Route(i, j + 1)) = Delta_Tau(Route(i, j), Route(i, j + 1)) + Q / Distance_epoch(i);
    end
    Delta_Tau(Route(i, 1), Route(i, cities)) = Delta_Tau(Route(i, 1), Route(i, cities)) + Q / Distance_epoch(i);
end
Tau = (1 - rho) .* Tau + Delta_Tau;
Route = zeros(ants, cities);

3.9、结果输出

  迭代完成后,在R_best矩阵中得到最短路径的最小路线,最后输出最优的结果。
结果输出实现:

Pos = find(L_best == min(L_best));
Short_Route = R_best(Pos(1), :);
Short_Length = L_best(Pos(1), :);
figure
subplot(121);
DrawRoute(position, Short_Route);
subplot(122);
plot(L_best);
hold on
plot(L_ave, 'r');
title('平均距离和最短距离');

画图函数实现:

function DrawRoute(C, R)
N = length(R);
scatter(C(:, 1), C(:, 2));
hold on
plot([C(R(1), 1), C(R(N), 1)], [C(R(1), 2), C(R(N), 2)], 'g');
hold on
for ii = 2: N
    plot([C(R(ii - 1), 1), C(R(ii), 1)], [C(R(ii - 1), 2), C(R(ii), 2)], 'g');
    hold on
end
title('旅行商规划');

4、结果

结果展示

最后

学习到的小伙伴,请不要吝啬自己的点赞机会哦,主页资源有更多的学习资料,谢谢支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2215749.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

线上找工作小程序源码系统 带完整的安装代码包以及搭建部署教程

系统概述 这款线上找工作小程序源码系统是一款集成了岗位发布、简历投递、在线沟通等核心功能的一站式解决方案。系统采用主流的技术栈开发,如PHP后端配合MySQL数据库,前端则利用了Vue.js框架或原生微信小程序技术,确保了系统的高性能与良好…

AWS账号与邮箱的关系解析

在当今数字化时代,云计算服务的普及使得越来越多的企业和个人用户开始使用亚马逊网络服务(AWS)。作为全球领先的云服务平台,AWS为用户提供了丰富的计算、存储和数据库服务。然而,对于许多新用户来说,关于AW…

IT圈大实话!卷运维不如卷网络安全

前言 在刚刚过去的金九银十,我进行了多场网络安全的技术面试,我发现最近很多从事运维的选择了辞职,转行到了网络安全这个发展路线。 说实话,运维工程师这个岗位在IT行业里面确实是处于最底层的,不管什么环节出现问题…

从“寻鲜市集”看巴奴产品主义的「新生命力」

【潮汐商业评论/原创】 “这个就是获得‘国家地理标志产品’的金阳青花椒,七分麻三分香,是麻辣火锅的灵魂;这个菌汤用了3种云南野生牛肝菌熬制,味道鲜香,口感顺滑;还有这个龙竹鲜笋可不得了,它…

【基于docker的深度学习训练环境】关键步骤记录

最近给公司搭建了一个小型的深度学习环境,实现了多人通过SSH对GPU资源的利用,下面对一些关键架构和易用性部分进行记录。 一、整体软硬件框架 1、硬件配置,采用的双GPU的方案,两块消费级显卡。 2、应用层架构 宿主机系统为ubunt…

猎板PCB:军工武器系统中的PCB线路板技术要求

PCB线路板在军工武器系统中的应用非常广泛,它们是现代军事装备中不可或缺的组成部分。军工级PCB因其在极端环境下的稳定性和可靠性而受到重视,这些环境可能包括高温、低温、高湿度、强辐射、高震动等条件。以下是一些关键点,概述了PCB线路板在…

基于华为云智慧生活生态链设计的智能鱼缸

一. 引言 1.1 项目背景 随着智能家居技术的发展和人们对高品质生活的追求日益增长,智能鱼缸作为一种结合了科技与自然美的家居装饰品,正逐渐成为智能家居领域的新宠。本项目旨在设计一款基于华为云智慧生活生态链的智能鱼缸,它不仅能够提供…

vue3播放m3u8格式hls监控流

1. 摄像头的hls监控流不同于普通m3u8的视频,video标签,iframe,videojs,vue-video-player无法解析 2. 解决办法 更换LivePlayer插件 官网https://www.liveqing.com/docs/manuals/LivePlayer.html#%E5%B1%9E%E6%80%A7-property 3…

kubernets(二)

集群操作 查看集群信息 kubectl get查看各组件信息 格式:kubectl get 资源类型 【资源名】 【选项】 events #查看集群中的所有日志信息 -o wide # 显示资源详细信息,包括节点、地址... -o yaml/json #将当前资源对象输出至 yaml/json 格式文…

windows安装VMware虚拟机 在虚拟机中安装Centos系统

文章目录 安装虚拟机Centos7.5 软硬件安装安装Centos所需的硬件配置处理器与内核 安装虚拟机 Centos7.5 软硬件安装 安装Centos所需的硬件 配置处理器与内核 一个CPU可以有多个内核 此处可以看出该电脑一个处理器,四个内核。配置虚拟器的原则是不能超过总数的一半…

Mybatis全局配置介绍

【mybatis全局配置介绍】 mybatis-config.xml,是MyBatis的全局配置文件,包含全局配置信息,如数据库连接参数、插件等。整个框架中只需要一个即可。 1、mybatis全局配置文件是mybatis框架的核心配置,整个框架只需一个&#xff1b…

BFS处理最短路问题

BFS与最短路问题小结 - AcWing 题目 这题就可以BFS&#xff08;边权值相同&#xff09;&#xff08;g[i][j]也可以为inf&#xff0c;g[i][i]还能为0&#xff09; 代码 #include <bits/stdc.h> using namespace std; const int N 510; const int inf 0x3f3f3f3f; int n…

【火山引擎】AIGC图像风格化 | 风格实践 | PYTHON

目录 1 准备工作 2 实践 代码 效果图 1 准备工作 ① 服务开通 确保已开通需要访问的服务。您可前往火山引擎控制台,在左侧菜单中选择或在顶部搜索栏中搜索需要使用的服务,进入服务控制台内完成开通流程。

大话C++:第18篇 类继承与派生

1 类继承的概述 类继承&#xff08;Class Inheritance&#xff09;是面向对象编程&#xff08;Object-Oriented Programming&#xff0c;OOP&#xff09;中的一个核心概念。它允许我们创建一个新的类&#xff08;子类或派生类&#xff09;&#xff0c;该类继承了另一个已存在的…

深度学习模型量化方法-【文末含实战】主流深度学习框架

目录 一&#xff0c;深度学习模型量化概述 1.1 模型量化定义 1.2 模型量化的方案 1.3&#xff0c;量化的分类 1.4 模型量化好处 总结&#xff1a; 二&#xff0c;常用量化框架 2.1 OpenVINO NCCF OpenVINO NCCF量化流程 OpenVINO NCCF量化优势 2.2 TensorRT量化框架…

如何向两个不同 MySQL 数据源的相同数据库与表写入数据

个人名片 &#x1f393;作者简介&#xff1a;java领域优质创作者 &#x1f310;个人主页&#xff1a;码农阿豪 &#x1f4de;工作室&#xff1a;新空间代码工作室&#xff08;提供各种软件服务&#xff09; &#x1f48c;个人邮箱&#xff1a;[2435024119qq.com] &#x1f4f1…

AcWing 3188:Manacher 算法 → 最长回文子串

【题目来源】https://www.acwing.com/problem/content/3190/【题目描述】 给定一个长度为 n 的由小写字母构成的字符串&#xff0c;求它的最长回文子串的长度是多少。【输入格式】 一个由小写字母构成的字符串。【输出格式】 输出一个整数&#xff0c;表示最长回文子串的长度。…

VSCode创建插件HelloWorld找不到指令解决办法

按照网上的教程执行yo code并且生成成功 但是F5打开调试新窗口后&#xff0c;ctrl shift P&#xff0c;输入helloworld并没有指令提示 原因&#xff1a;当前电脑安装的VSCode版本过低&#xff0c;不支持当前插件的使用&#xff08;因为自动生成的插件总是默认使用最新版VSC…

00 springboot项目创建

我们创建SpringBoot项目有两种方式: Spring Initializr spring initerzie 方式创建: 启动类, 依赖 生成,但是需要网络maven的方式 maven方式创建: 启动类, 依赖, 这些都需要手动编写,但是不需要网络 如果你觉得我分享的内容或者我的努力对你有帮助&#xff0c;或者你只是想表…