基于蚁群算法的MATLAB实现

合集下载

matlab基于蚁群算法的故障诊断代码

matlab基于蚁群算法的故障诊断代码

一、引言随着科技的不断发展,各种电子设备在我们的生活中起着越来越重要的作用。

然而,这些电子设备在长时间的使用过程中难免会出现故障,而故障的及时准确诊断对于设备的正常运行和维护至关重要。

故障诊断技术的研究和应用显得尤为重要。

二、故障诊断方法的研究现状1.基于蚁群算法的故障诊断方法蚁群算法是一种通过模拟蚂蚁在寻找食物过程中留下的信息素路径来解决组合优化等计算问题的启发式算法。

近年来,蚁群算法在故障诊断领域得到了广泛的应用。

其优点在于能够充分利用信息素路径的思想,通过不断搜索最优解的方式,找到最适合的故障诊断方案。

2.传统的故障诊断方法传统的故障诊断方法多为基于专家系统或规则库的方式,需要事先对设备的故障类型和规律进行深入的研究和积累。

在实际应用中存在诊断效率低、难以适应复杂环境的问题。

三、基于蚁群算法的故障诊断代码实现1. 蚁群算法的原理蚁群算法是一种模拟蚂蚁在寻找食物过程中留下信息素路径的算法,通过信息素路径的不断蒸发和更新,最终寻找到最优的路径。

在故障诊断中,可以将设备的故障模式看作“食物”,蚂蚁的行走路径看作“诊断路径”,通过模拟蚂蚁在搜索食物的过程中留下信息素路径的方式,来寻找最优的故障诊断路径。

2.算法流程(1)初始化信息素和蚂蚁的位置;(2)蚂蚁根据信息素浓度选择下一步的行走方向;(3)蚂蚁行走后更新信息素浓度;(4)重复步骤(2)和(3),直到所有蚂蚁都找到故障诊断路径;(5)根据信息素浓度更新蚂蚁的行走路径。

3.代码实现以MATLAB为例,基于蚁群算法的故障诊断代码可以通过以下步骤实现:(1)初始化信息素和蚂蚁的位置,设定设备故障模式和规则库;(2)根据信息素浓度和故障规则,确定蚂蚁下一步的行走路径;(3)蚂蚁行走后更新信息素浓度;(4)重复步骤(2)和(3),直到所有蚂蚁都找到故障诊断路径;(5)根据信息素浓度更新蚂蚁的行走路径,最终得到最优的故障诊断路径。

四、代码优化与应用1. 参数调优在实际编写故障诊断代码时,需要针对具体的设备和故障情况进行参数的调优,以保证算法的高效性和准确性。

蚁群算法路径优化matlab代码

蚁群算法路径优化matlab代码

蚁群算法路径优化matlab代码标题:蚁群算法路径优化 MATLAB 代码正文:蚁群算法是一种基于模拟蚂蚁搜索食物路径的优化算法,常用于求解复杂问题。

在路径优化问题中,蚂蚁需要从起点移动到终点,通过探索周围区域来寻找最短路径。

MATLAB 是一个常用的数值计算软件,可以用来实现蚁群算法的路径优化。

下面是一个基本的 MATLAB 代码示例,用于实现蚁群算法的路径优化:```matlab% 定义参数num_ants = 100; % 蚂蚁数量num_steps = 100; % 路径优化步数search_radius = 2; % 搜索半径max_iterations = 1000; % 最大迭代次数% 随机生成起点和终点的位置坐标start_pos = [randi(100), randi(100)];end_pos = [75, 75];% 初始化蚂蚁群体的位置和方向ants_pos = zeros(num_ants, 2);ants_dir = zeros(num_ants, 2);for i = 1:num_antsants_pos(i, :) = start_pos + randn(2) * search_radius; ants_dir(i, :) = randomvec(2);end% 初始化蚂蚁群体的速度ants_vel = zeros(num_ants, 2);for i = 1:num_antsants_vel(i, :) = -0.1 * ants_pos(i, :) + 0.5 *ants_dir(i, :);end% 初始时蚂蚁群体向终点移动for i = 1:num_antsans_pos = end_pos;ans_vel = ants_vel;for j = 1:num_steps% 更新位置和速度ans_pos(i) = ans_pos(i) + ans_vel(i);ants_vel(i, :) = ones(1, num_steps) * (-0.1 * ans_pos(i) + 0.5 * ans_dir(i, :));end% 更新方向ants_dir(i, :) = ans_dir(i, :) - ans_vel(i) * 3;end% 迭代优化路径max_iter = 0;for i = 1:max_iterations% 计算当前路径的最短距离dist = zeros(num_ants, 1);for j = 1:num_antsdist(j) = norm(ants_pos(j) - end_pos);end% 更新蚂蚁群体的位置和方向for j = 1:num_antsants_pos(j, :) = ants_pos(j, :) - 0.05 * dist(j) * ants_dir(j, :);ants_dir(j, :) = -ants_dir(j, :);end% 更新蚂蚁群体的速度for j = 1:num_antsants_vel(j, :) = ants_vel(j, :) - 0.001 * dist(j) * ants_dir(j, :);end% 检查是否达到最大迭代次数if i > max_iterationsbreak;endend% 输出最优路径[ans_pos, ans_vel] = ants_pos;path_dist = norm(ans_pos - end_pos);disp(["最优路径长度为:" num2str(path_dist)]);```拓展:上述代码仅仅是一个简单的示例,实际上要实现蚁群算法的路径优化,需要更加复杂的代码实现。

双蚁群算法的matlab实现

双蚁群算法的matlab实现

双蚁群算法的matlab实现
双蚁群算法是一种基于蚁群优化算法的改进版本,它引入了两
种不同类型的蚂蚁来模拟现实世界中的竞争和合作关系。

在Matlab
中实现双蚁群算法可以分为以下几个步骤:
1. 定义问题,首先需要明确定义需要解决的优化问题,包括目
标函数、约束条件等。

2. 初始化参数,设置算法的参数,如蚂蚁数量、迭代次数、信
息素挥发系数、信息素更新系数等。

3. 初始化蚂蚁群,随机放置两种类型的蚂蚁在问题的解空间中,每只蚂蚁都有一个位置和一个解。

4. 更新信息素,根据蚂蚁搜索的路径更新信息素的浓度。

5. 蚂蚁搜索,根据信息素浓度和启发式规则,蚂蚁在解空间中
搜索最优解。

6. 评估解的质量,计算每个蚂蚁找到的解的质量,并更新最优
解。

7. 更新信息素,根据找到的最优解更新信息素的浓度。

8. 终止条件,根据预设的迭代次数或者其他终止条件判断算法是否结束。

在Matlab中实现双蚁群算法时,可以使用向量化操作和矩阵运算来提高计算效率。

同时,可以利用Matlab的绘图功能对算法的收敛过程和最优解的搜索路径进行可视化展示,以便更直观地理解算法的运行过程。

需要注意的是,双蚁群算法的实现涉及到许多细节和参数的调节,需要经过反复实验和调优才能得到较好的效果。

同时,也可以借助Matlab中丰富的工具箱和函数来加速算法的实现和调试过程。

总之,通过以上步骤和注意事项,可以在Matlab中实现双蚁群算法,并应用于解决各种优化问题。

PythonMatlab实现蚂蚁群算法求解最短路径问题的示例

PythonMatlab实现蚂蚁群算法求解最短路径问题的示例

PythonMatlab实现蚂蚁群算法求解最短路径问题的⽰例⽬录1知识点1.1 蚁群算法步骤1.2 蚁群算法程序2蚂蚁算法求解最短路径问题——Python实现2.1源码实现2.2 ACA_TSP实现3 蚂蚁算法求解最短路径问题——Matlab实现3.1流程图3.2代码实现3.3结果1 知识点详细知识点见:我们这⼀节知识点只讲蚁群算法求解最短路径步骤及流程。

1.1 蚁群算法步骤设蚂蚁的数量为m,地点的数量为n,地点i与地点j之间相距Dij,t时刻地点i与地点j连接的路径上的信息素浓度为Sij,初始时刻每个地点间路径上的信息素浓度相等。

蚂蚁k根据各个地点间连接路径上的信息素决定下⼀个⽬标地点,Pijk表⽰t时刻蚂蚁k从地点i转移的概率,概率计算公式如下:上式中,为启发函数,,表⽰蚂蚁从地点i转移到地点j的期望程度;为蚂蚁k即将访问地点的集合,开始时中有n-1个元素(除出发地点),随时间的推移,蚂蚁每到达下⼀个地点,中的元素便减少⼀个,直⾄空集,即表⽰所有地点均访问完毕;a为信息素重要程度因⼦,值越⼤,表明信息素的浓度在转移中起到的作⽤越⼤,也就是说蚂蚁选择距离近的下⼀个地点的概率更⼤,β为启发函数重要程度因⼦。

蚂蚁在释放信息素的同时,每个地点间连接路径上的信息素逐渐消失,⽤参数表⽰信息素的挥发程度。

因此,当所有蚂蚁完成⼀次循环后,每个地点间连接路径上的信息素浓度需更新,也就是有蚂蚁路过并且留下信息素,有公式表⽰为:其中,表⽰第k只蚂蚁在地点i与j连接路径上释放的信息素浓度;表⽰所有蚂蚁在地点i与j连接路径上释放的信息素浓度之和;Q为常数,表⽰蚂蚁循环⼀次所释放的信息素总量;Lk表⽰第k只蚂蚁经过路径的长度,总的来说,蚂蚁经过的路径越短,释放的信息素浓度越⾼,最终选出最短路径。

1.2 蚁群算法程序(1)参数初始化在寻最短路钱,需对程序各个参数进⾏初始化,蚁群规模m、信息素重要程度因⼦α、启发函数重要程度因⼦β、信息素会发因⼦、最⼤迭代次数ddcs_max,初始迭代值为ddcs=1。

蚁群算法matlab代码讲解

蚁群算法matlab代码讲解

蚁群算法matlab代码讲解蚁群算法(Ant Colony Algorithm)是模拟蚁群觅食行为而提出的一种优化算法。

它以蚁群觅食的方式来解决优化问题,比如旅行商问题、图着色问题等。

该算法模拟了蚂蚁在寻找食物时的行为,通过信息素的正反馈和启发式搜索来实现问题的最优解。

在蚁群算法中,首先需要初始化一组蚂蚁和问题的解空间。

每只蚂蚁沿着路径移动,通过信息素和启发式规则来选择下一步的移动方向。

当蚂蚁到达目标位置后,会根据路径的长度来更新信息素。

下面是一个用MATLAB实现蚁群算法的示例代码:```matlab% 参数设置num_ants = 50; % 蚂蚁数量num_iterations = 100; % 迭代次数alpha = 1; % 信息素重要程度因子beta = 5; % 启发式因子rho = 0.1; % 信息素蒸发率Q = 1; % 信息素增加强度因子pheromone = ones(num_cities, num_cities); % 初始化信息素矩阵% 初始化蚂蚁位置和路径ants = zeros(num_ants, num_cities);for i = 1:num_antsants(i, 1) = randi([1, num_cities]);end% 迭代计算for iter = 1:num_iterations% 更新每只蚂蚁的路径for i = 1:num_antsfor j = 2:num_cities% 根据信息素和启发式规则选择下一步移动方向next_city = choose_next_city(pheromone, ants(i, j-1), beta);ants(i, j) = next_city;endend% 计算每只蚂蚁的路径长度path_lengths = zeros(num_ants, 1);for i = 1:num_antspath_lengths(i) = calculate_path_length(ants(i, :), distances);end% 更新信息素矩阵pheromone = (1 - rho) * pheromone;for i = 1:num_antsfor j = 2:num_citiespheromone(ants(i, j-1), ants(i, j)) = pheromone(ants(i, j-1), ants(i, j)) + Q / path_lengths(i); endendend```上述代码中的参数可以根据具体问题进行调整。

matlab的蚂蚁算法的实现

matlab的蚂蚁算法的实现
city+1)) + Q / distances(positions(ant, city), positions(ant, city+1)); end deltaPheromones(positions(ant, numCities), positions(ant, 1)) = deltaPheromones(positions(ant, numCities), positions(ant,
matlab的蚂蚁算法的实现
在上述代码中,我们首先设置了一些参数,如蚂蚁数量、迭代次数、信息素和启发式信息 的重要程度等。然后,根据参数初始化了信息素矩阵,并进行了迭代优化过程。
在每次迭代中,我们先初始化蚂蚁的位置,然后根据信息素和启发式信息的重要程度,以 及当前城市和已访问城市的距离,计算每个城市被选择的概率。根据概率选择下一个城市, 直到完成整个路径的选择。然后,根据蚂蚁的路径更新信息素矩阵。重复迭代过程,直到达 到指定的迭代次数。
最后,输出最优路径和最优距离。
matlab的蚂蚁算法的实现
需要注意的是,上述代码只是一个简单的示例,实际应用中可能需要根据具体问题进行适 当的调整和扩展。蚂蚁算法的实现也可能因问题的复杂性和特点而有所不同。
Байду номын сангаас
matlab的蚂蚁算法的实现
以下是一个使用 MATLAB 实现蚂蚁算法的简单示例:
```matlab % 参数设置 numAnts = 10; % 蚂蚁数量 numIterations = 100; % 迭代次数 alpha = 1; % 信息素重要程度 beta = 5; % 启发式信息重要程度 rho = 0.5; % 信息素挥发率 Q = 1; % 信息素增量 numCities = 10; % 城市数量 distances = rand(numCities); % 城市之间的距离矩阵

蚁群算法(ACA)及其Matlab实现

蚁群算法(ACA)及其Matlab实现

蚁群算法(ACA)及其Matlab实现1基本原理:本质上也是⼀种概率算法,通过⼤概率收敛到最佳值,和其他的智能算法很相似。

蚁群分泌的信息素存在正反馈,使得较佳的解具有⼤概率被选到,当全局都选⽤较佳的解,变可以得到整体的最优解。

2⼏个关键点:1)概率选择:受信息素浓度和启发函数影响,启发函数为距离的倒数2)信息素挥发考虑到信息素随时间的挥发,加⼊挥发因⼦3程序设计步骤:1初始化各个参数:包括各点的距离,信息素的初始浓度,蚂蚁数量,信息素挥发因⼦,信息素和启发函数的重要度因⼦,启发函数,最⼤迭代次数,路径记录表等等2迭代:对每个蚂蚁随机制定初始值,再根据概率选择,选择出每只蚂蚁的路径,确定每只蚂蚁的路径总长度,以及蚁群的最佳路径长度和平均长度,并对信息素进⾏更新。

3展⽰:展⽰出最佳路径,以及最佳路径对迭代的变化图4Matlab代码clc,clear %清空环境中的变量load data.txt %读⼊城市的坐标t0 = clock; %程序计时开始%%%%%%%%%%%%%%%%%%%%%初始化%%%%%%%%%%%%%%%%%city=data;n = size(city,1); %城市距离初始化D = zeros(n,n);for i = 1:nfor j = 1:nif i ~= jD(i,j) = sqrt(sum((city(i,:) - city(j,:)).^2));elseD(i,j) = 0; %设定的对⾓矩阵修正值endendendm=30; %蚂蚁数量alpha = 1; % 信息素重要程度因⼦beta = 5; % 启发函数重要程度因⼦v = 0.1; % 信息素挥发因⼦Q = 0.5; % 信息因⼦常系数H= 1./D; % 启发函数T= ones(n,n); % 信息素矩阵Table = zeros(m,n); % 路径记录表iter = 1; % 迭代次数初值iter_max = 50; % 最⼤迭代次数best_route = zeros(iter_max,n); % 各代最佳路径best_length = zeros(iter_max,1); % 各代最佳路径的长度%%while iter<=iter_max% 随机产⽣每只蚂蚁的起点城市start = zeros(m,1);for i = 1:mtemp = randperm(n);start(i) = temp(1);endTable(:,1) = start;city_index=1:n;for i = 1:m% 逐个城市路径选择for j = 2:ntabu = Table(i,1:(j - 1)); % 已访问的城市集合allow =city_index( ~ismember(city_index,tabu)); % 筛选出未访问的城市集合P = zeros(1,length(allow));% 计算相连城市的转移概率for k = 1:length(allow)P(k) = T(tabu(end),allow(k))^alpha * H(tabu(end),allow(k))^beta;endP = P/sum(P);% 轮盘赌法选择下⼀个访问城市Pc = cumsum(P); %参加说明2(程序底部)target_index = find(Pc >= rand);target = allow(target_index(1));Table(i,j) = target;endend% 计算各个蚂蚁的路径距离Length = zeros(m,1);for i = 1:mRoute = [Table(i,:) Table(i,1)];for j = 1:nLength(i) = Length(i) + D(Route(j),Route(j + 1));endend%对最优路线和距离更新if iter == 1[min_length,min_index] = min(Length);best_length(iter) = min_length;best_route(iter,:) = Table(min_index,:);else[min_length,min_index] = min(Length);if min_length<best_length(iter-1)best_length(iter)=min_length;best_route(iter,:)=Table(min_index,:);elsebest_length(iter)=best_length(iter-1);best_route(iter,:)=best_route(iter-1,:);endend% 更新信息素Delta_T= zeros(n,n);% 逐个蚂蚁计算for i = 1:m% 逐个城市计算Route = [Table(i,:) Table(i,1)];for j = 1:nDelta_T(Route(j),Route(j+1)) = Delta_T(Route(j),Route(j+1)) +D(Route(j),Route(j+1))* Q/Length(i); endendT= (1-v) * T + Delta_T;% 迭代次数加1,并清空路径记录表iter = iter + 1;Table = zeros(m,n);end%--------------------------------------------------------------------------%% 结果显⽰shortest_route=best_route(end,:); %选出最短的路径中的点short_length=best_length(end);Time_Cost=etime(clock,t0);disp(['最短距离:' num2str(short_length)]);disp(['最短路径:' num2str([shortest_route shortest_route(1)])]);disp(['程序执⾏时间:' num2str(Time_Cost) '秒']);%--------------------------------------------------------------------------%% 绘图figure(1)%采⽤连线图画起来plot([city(shortest_route,1);city(shortest_route(1),1)], [city(shortest_route,2);city(shortest_route(1),2)],'o-');for i = 1:size(city,1)%对每个城市进⾏标号text(city(i,1),city(i,2),[' ' num2str(i)]);endxlabel('城市位置横坐标')ylabel('城市位置纵坐标')title(['蚁群算法最优化路径(最短距离):' num2str(short_length) ''])figure(2)%画出收敛曲线plot(1:iter_max,best_length,'b')xlabel('迭代次数')ylabel('距离')title('迭代收敛曲线') 程序说明:采⽤蚁群算法求取TSP问题,共有34个城市,从txt⽂件加载数据:运⾏结果:。

蚁群算法matlab代码

蚁群算法matlab代码

蚁群算法matlab代码蚁群算法,英文名为Ant Colony Algorithm,缩写为ACO,是一种启发式算法,是一种模拟蚂蚁寻找食物路径的算法。

在实际生活中,蚂蚁找到食物并返回巢穴后,将其找到食物的路径上的信息素留下,其他蚂蚁通过检测信息素来指导寻路,成为了一种集体智慧行为。

ACO也是通过模拟蚂蚁寻找食物路径的方式来寻找优化问题的最优解。

在ACO算法中,信息素是一个重要的概念,代表了走过某一路径的“好概率”,用这个“好概率”更新一些路径上的信息素,使得其他蚂蚁更可能选择经过这条路径,从而实现路径优化的目的。

在本文中,我们将讨论如何使用Matlab实现蚁群算法来优化问题。

1. 设定问题首先,我们要选取一个优化问题,并将其转换为需要在优化过程中进行选择的决策变量。

例如,我们想要优化旅行商问题(TSP)。

在TSP中,我们需要让旅行商以最短的距离经过所有城市,每个城市仅经过一次,最终回到出发的城市。

我们可以将每个城市编号,然后将TSP转化为一个最短路径选择的问题,即最短路径从编号为1的城市开始,经过所有城市,最终回到编号为1的城市。

2. 设定ACO参数在使用ACO优化问题时,需要设定一些参数,这些参数会影响算法的表现。

ACO算法需要设定的参数有:1.信息素含量:初始信息素的大小,即每个路径上的信息素浓度。

2.信息素挥发速度:信息素的随时间“减弱”程度。

3.信息素加成强度:蚂蚁经过路径后增加的信息素量。

4.启发式权重:用于计算启发式因子,即节点距离的贡献值。

5.蚂蚁数量:模拟蚂蚁数量,即同时寻找路径的蚂蚁个数。

6.迭代次数:模拟的迭代次数,即ACO算法运行的次数。

7.初始节点:ACO算法开始的节点。

3. 创建ACO优化函数我们可以使用Matlab来创建一个函数来实现ACO算法。

我们称其为“ACOoptimization.m”。

function best_path =ACOoptimization(city_location,iter_num,ant_num,init ial_path,alpha,beta,rho,update_flag) %ACO优化函数 %输入: %city_location: 城市坐标矩阵,格式为[x1,y1;x2,y2;...;xn,yn] %iter_num: 迭代次数 %ant_num: 蚂蚁数量 %initial_path: 起始路径,即初始解 %alpha,beta,rho: 超参数,用于调节蚂蚁选择路径的概率 %update_flag: 是否更新信息素的标志(1表示更新,0表示否) %输出: %best_path: 最优解,即最短路径%初始化信息素 pheromone = 0.01 *ones(length(city_location),length(city_location)); %初始化路径权重 path_weight =zeros(ant_num,1); %城市数量 n_cities =length(city_location);%主循环 for iter = 1:iter_num %一个迭代里所有蚂蚁都寻找一遍路径 for ant =1:ant_num %初始化蚂蚁位置current_city = initial_path; %标记是否经过了某个城市 visit_flag =zeros(1,n_cities);visit_flag(current_city) = 1; %用来存储当前路径 current_path = [current_city];%蚂蚁找东西 for i =1:n_cities-1 %计算路径概率p =calculate_probability(current_city,visit_flag,phero mone,city_location,alpha,beta); %蚂蚁选择路径 [next_city,next_index] = select_path(p);%路径更新current_path = [current_path;next_city];visit_flag(next_city) = 1;current_city = next_city;%更新路径权重path_weight(ant) = path_weight(ant) +Euclidean_distance(city_location(current_path(end-1),:),city_location(current_path(end),:));end%加入回到起点的路径权重path_weight(ant) = path_weight(ant) +Euclidean_distance(city_location(current_path(end),:),city_location(current_path(1),:));%判断是否为最优解 ifant == 1 best_path = current_path; else if path_weight(ant) <path_weight(ant-1) best_path =current_path; end end%更新信息素 ifupdate_flag == 1 pheromone =update_pheromone(pheromone,path_weight,initial_path,current_path,rho); end end end end在函数中,我们首先定义了ACOalg函数的参数,包括城市坐标矩阵,迭代次数,蚂蚁数量,初始路径,超参数alpha,beta,rho,以及是否需要更新信息素。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

基于蚁群算法的机器人路径规划MATLAB源代码基本思路是,使用离散化网格对带有障碍物的地图环境建模,将地图环境转化为邻接矩阵,最后使用蚁群算法寻找最短路径。

function [ROUTES,PL,Tau]=ACASPS(G,Tau,K,M,S,E,Alpha,Beta,Rho,Q)%% ---------------------------------------------------------------% ACASP.m% 基于蚁群算法的机器人路径规划% GreenSim团队——专业级算法设计&代写程序% 欢迎访问GreenSim团队主页→/greensim%% ---------------------------------------------------------------% 输入参数列表% G 地形图为01矩阵,如果为1表示障碍物% Tau 初始信息素矩阵(认为前面的觅食活动中有残留的信息素)% K 迭代次数(指蚂蚁出动多少波)% M 蚂蚁个数(每一波蚂蚁有多少个)% S 起始点(最短路径的起始点)% E 终止点(最短路径的目的点)% Alpha 表征信息素重要程度的参数% Beta 表征启发式因子重要程度的参数% Rho 信息素蒸发系数% Q 信息素增加强度系数%% 输出参数列表% ROUTES 每一代的每一只蚂蚁的爬行路线% PL 每一代的每一只蚂蚁的爬行路线长度% Tau 输出动态修正过的信息素%% --------------------变量初始化----------------------------------%loadD=G2D(G);N=size(D,1);%N表示问题的规模(象素个数)MM=size(G,1);a=1;%小方格象素的边长Ex=a*(mod(E,MM)-0.5);%终止点横坐标if Ex==-0.5Ex=MM-0.5;endEy=a*(MM+0.5-ceil(E/MM));%终止点纵坐标Eta=zeros(1,N);%启发式信息,取为至目标点的直线距离的倒数%下面构造启发式信息矩阵for i=1:Nix=a*(mod(i,MM)-0.5);if ix==-0.5ix=MM-0.5;endiy=a*(MM+0.5-ceil(i/MM));if i~=EEta(1,i)=1/((ix-Ex)^2+(iy-Ey)^2)^0.5;elseEta(1,i)=100;endendROUTES=cell(K,M);%用细胞结构存储每一代的每一只蚂蚁的爬行路线PL=zeros(K,M);%用矩阵存储每一代的每一只蚂蚁的爬行路线长度%% -----------启动K轮蚂蚁觅食活动,每轮派出M只蚂蚁--------------------for k=1:K%disp(k);for m=1:M%% 第一步:状态初始化W=S;%当前节点初始化为起始点Path=S;%爬行路线初始化PLkm=0;%爬行路线长度初始化TABUkm(S)=0;%已经在初始点了,因此要排除DD=D;%邻接矩阵初始化%% 第二步:下一步可以前往的节点DW=DD(W,:);DW1=find(DW<inf);for j=1:length(DW1)if TABUkm(DW1(j))==0endendLJD=find(DW<inf);%可选节点集Len_LJD=length(LJD);%可选节点的个数%% 觅食停止条件:蚂蚁未遇到食物或者陷入死胡同while W~=E&&Len_LJD>=1%% 第三步:转轮赌法选择下一步怎么走PP=zeros(1,Len_LJD);for i=1:Len_LJDendPP=PP/(sum(PP));%建立概率分布Pcum=cumsum(PP);Select=find(Pcum>=rand);to_visit=LJD(Select(1));%下一步将要前往的节点%% 第四步:状态更新和记录Path=[Path,to_visit];%路径增加PLkm=PLkm+DD(W,to_visit);%路径长度增加W=to_visit;%蚂蚁移到下一个节点for kk=1:Nif TABUkm(kk)==0DD(W,kk)=inf;DD(kk,W)=inf;endendTABUkm(W)=0;%已访问过的节点从禁忌表中删除DW=DD(W,:);LJD=find(DW<inf);%可选节点集Len_LJD=length(LJD);%可选节点的个数end%% 第五步:记下每一代每一只蚂蚁的觅食路线和路线长度ROUTES{k,m}=Path;if Path(end)==EPL(k,m)=PLkm;elsePL(k,m)=inf;endend%% 第六步:更新信息素Delta_Tau=zeros(N,N);%更新量初始化for m=1:Mif PL(k,m)<infROUT=ROUTES{k,m};TS=length(ROUT)-1;%跳数PL_km=PL(k,m);for s=1:TSx=ROUT(s);y=ROUT(s+1);Delta_Tau(x,y)=Delta_Tau(x,y)+Q/PL_km;Delta_Tau(y,x)=Delta_Tau(y,x)+Q/PL_km;endendendTau=(1-Rho).*Tau+Delta_Tau;%信息素挥发一部分,新增加一部分end%% ---------------------------绘图--------------------------------plotif=0;%是否绘图的控制参数if plotif==1%绘收敛曲线meanPL=zeros(1,K);minPL=zeros(1,K);for i=1:KPLK=PL(i,:);Nonzero=find(PLK<inf);PLKPLK=PLK(Nonzero);meanPL(i)=mean(PLKPLK);minPL(i)=min(PLKPLK);endfigure(1)plot(minPL);hold onplot(meanPL);grid ontitle('收敛曲线(平均路径长度和最小路径长度)'); xlabel('迭代次数');ylabel('路径长度');%绘爬行图figure(2)axis([0,MM,0,MM])for i=1:MMfor j=1:MMif G(i,j)==1x1=j-1;y1=MM-i;x2=j;y2=MM-i;x3=j;y3=MM-i+1;x4=j-1;y4=MM-i+1;fill([x1,x2,x3,x4],[y1,y2,y3,y4],[0.2,0.2,0.2]);hold onelsex1=j-1;y1=MM-i;x2=j;y2=MM-i;x3=j;y3=MM-i+1;x4=j-1;y4=MM-i+1;fill([x1,x2,x3,x4],[y1,y2,y3,y4],[1,1,1]);hold onendendendhold onROUT=ROUTES{K,M};Rx=ROUT;Ry=ROUT;for ii=1:LENROUTRx(ii)=a*(mod(ROUT(ii),MM)-0.5);if Rx(ii)==-0.5Rx(ii)=MM-0.5;endRy(ii)=a*(MM+0.5-ceil(ROUT(ii)/MM));endplot(Rx,Ry)endplotif2=0;%绘各代蚂蚁爬行图if plotif2==1figure(3)axis([0,MM,0,MM])for i=1:MMfor j=1:MMif G(i,j)==1x1=j-1;y1=MM-i;x2=j;y2=MM-i;x4=j-1;y4=MM-i+1;fill([x1,x2,x3,x4],[y1,y2,y3,y4],[0.2,0.2,0.2]);hold onelsex1=j-1;y1=MM-i;x2=j;y2=MM-i;x3=j;y3=MM-i+1;x4=j-1;y4=MM-i+1;fill([x1,x2,x3,x4],[y1,y2,y3,y4],[1,1,1]);hold onendendendfor k=1:KPLK=PL(k,:);minPLK=min(PLK);pos=find(PLK==minPLK);m=pos(1);ROUT=ROUTES{k,m};LENROUT=length(ROUT);Rx=ROUT;Ry=ROUT;for ii=1:LENROUTRx(ii)=a*(mod(ROUT(ii),MM)-0.5);if Rx(ii)==-0.5Rx(ii)=MM-0.5;endRy(ii)=a*(MM+0.5-ceil(ROUT(ii)/MM));endplot(Rx,Ry)hold onendend源代码运行结果展示。

相关文档
最新文档