• 蚁群算法ACO求解连续函数极值


    目录

    一、蚁群算法特点

    二、基本蚁群算法及其流程

    三、改进蚁群算法

    1.精英蚂蚁系统

    2.最大最小蚂蚁系统

    3.基于排序的蚁群算法

    4.自适应蚁群算法

    四、例题


    一、蚁群算法特点

    (1)自组织算法
    组织力和组织指令来自系统内部
    (2)并行算法
    蚂蚁搜索过程彼此独立,仅通过信息素进行通信
    (3)正反馈算法
    信息素堆积是一个正反馈的过程

    二、基本蚁群算法及其流程

        算法初始时刻,将m只蚂蚁随机放到n座城市,同时,将每只蚂蚁的禁忌表tabu的第一个元素设置为它当前所在城市。此时个路径上的信息素相等,接下来每只蚂蚁根据路径上残留的信息素量和启发式信息(两城市距离)独立地选择下一座城市,在时刻t,蚂蚁k从城市i转移到城市j的概率p_{ij}^{k}(t)为:

    当所有蚂蚁完成一次周游后,各路径上的信息素更新:

    其中\Delta \tau _{ij}表示本次迭代中边ij上信息素的增量,即

    \Delta \tau _{ij}^{k}表示第k只蚂蚁在被刺迭代中留在边ij上的信息素两,如果蚂蚁没有经过,则其值为零。

    M。Dorigo提出了3中蚂蚁系统,上面这种称为ant-cycle模型,另外两种模型称为ant-quantity模型和ant-density模型,其差别主要在于\Delta \tau _{ij}^{k}

    ant-quantity模型

    ant-density模型

    实验结果表明,ant-cycle模型比ant-quantity和ant-density模型有更好的性能。这是因为ant-cycle模型利用全局信息更新路径上的信息素量,而ant-quantity和ant-density模型使用局部信息 

    三、改进蚁群算法

    1.精英蚂蚁系统

    该算法将已经发现的最好解称为T^{bs}(best-so-far),而该路径在修改信息素轨迹时,人工释放额外的信息孙,以增强正反馈的效果。信息素修改功式为

    式中,e式调整T^{bs}影响权重的参数,而\Delta\tau^{bs}_{ij}由下式给出

    L_{bs}是已知最优路径的长度 

    2.最大最小蚂蚁系统

    该算法主要有三方面不同

    1)每次循环,只有一只蚂蚁进行信息素过呢更新,该蚂蚁可以是本次循环最优解,也可以是全局最优解

    2)信息素轨迹量的值域限制在[\tau_{min},\tau_{max}]

    3)信息素初始值设置在\tau_{max}

    3.基于排序的蚁群算法

    蚂蚁按旅行长度排名(短的靠前),蚂蚁释放的信息素的量要和蚂蚁的排名相乘。每次循环中,排名前w-1位的蚂蚁和精英蚂蚁才允许释放信息。排名第r位的蚂蚁乘以系数w-r

    4.自适应蚁群算法

    自适应地改变\rho的值。\rho的初始值\rho(t_{0})=1;当算法求得的最优值在N次循环内没有明显改进时,\rho减为

    四、例题

    求函数 f(x,y)=20(x^2-y^2)2-(1-y)^2-3(1+y)^2+0.3 的最小值,其中 x的取值范围为 [–5,5],y的取值范围为 [–5,5]。这是一个有多个局部极值的函数,其函数值图形如下图所示。

     解:仿真过程如下:

    (1)初始化蚂蚁个数 m = 20,最大迭代次数 G = 500,信息素蒸发系数 Rho = 0.9,转移概率常数 P0 = 0.2,局部搜索补偿 step = 0.1。

    (2)随机产生蚂蚁初始位置,计算适应度函数值,设为初始信息素,计算状态转移概率。

    (3)进行位置更新:当状态转移概率小于转移概率常数时,进行局部搜索;当状态转移概率大于转移概率常数时,进行全局搜索,产生新的蚂蚁位置,并利用边界吸收方式进行边界条件处理,将蚂蚁位置界定在取值范围内。

    (4)计算新的蚂蚁位置的适应度值,判断蚂蚁是否移动,更新信息素。

    (5)判断是否满足终止条件:若满足,则结束搜索过程,输出优化值;若不满足,则继续进行迭代优化。

    1. %%%%%%%%%%%%%%%%%%%%蚁群算法求函数极值%%%%%%%%%%%%%%%%%%%%%%%
    2. %%%%%%%%%%%%%%%%%%%%%%%%%初始化%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    3. clear all; %清除所有变量
    4. close all; %清图
    5. clc; %清屏
    6. m=20; %蚂蚁个数
    7. G_max=200; %最大迭代次数
    8. Rho=0.9; %信息素蒸发系数
    9. P0=0.2; %转移概率常数
    10. XMAX= 5; %搜索变量x最大值
    11. XMIN= -5; %搜索变量x最小值
    12. YMAX= 5; %搜索变量y最大值
    13. YMIN= -5; %搜索变量y最小值
    14. %%%%%%%%%%%%%%%%%随机设置蚂蚁初始位置%%%%%%%%%%%%%%%%%%%%%%
    15. for i=1:m
    16. X(i,1)=(XMIN+(XMAX-XMIN)*rand);
    17. X(i,2)=(YMIN+(YMAX-YMIN)*rand);
    18. Tau(i)=func(X(i,1),X(i,2));
    19. end
    20. step=0.1; %局部搜索步长
    21. for NC=1:G_max
    22. lamda=1/NC;
    23. [Tau_best,BestIndex]=min(Tau);
    24. %%%%%%%%%%%%%%%%%%计算状态转移概率%%%%%%%%%%%%%%%%%%%%
    25. for i=1:m
    26. P(NC,i)=(Tau(BestIndex)-Tau(i))/Tau(BestIndex);
    27. end
    28. %%%%%%%%%%%%%%%%%%%%%%位置更新%%%%%%%%%%%%%%%%%%%%%%%%
    29. for i=1:m
    30. %%%%%%%%%%%%%%%%%局部搜索%%%%%%%%%%%%%%%%%%%%%%
    31. if P(NC,i)<P0
    32. temp1=X(i,1)+(2*rand-1)*step*lamda;
    33. temp2=X(i,2)+(2*rand-1)*step*lamda;
    34. else
    35. %%%%%%%%%%%%%%%%全局搜索%%%%%%%%%%%%%%%%%%%%%%%
    36. temp1=X(i,1)+(XMAX-XMIN)*(rand-0.5);
    37. temp2=X(i,2)+(YMAX-YMIN)*(rand-0.5);
    38. end
    39. %%%%%%%%%%%%%%%%%%%%%边界处理%%%%%%%%%%%%%%%%%%%%%%%
    40. if temp1<XMIN
    41. temp1=XMIN;
    42. end
    43. if temp1>XMAX
    44. temp1=XMAX;
    45. end
    46. if temp2<YMIN
    47. temp2=YMIN;
    48. end
    49. if temp2>YMAX
    50. temp2=YMAX;
    51. end
    52. %%%%%%%%%%%%%%%%%%蚂蚁判断是否移动%%%%%%%%%%%%%%%%%%
    53. if func(temp1,temp2)1),X(i,2))
    54. X(i,1)=temp1;
    55. X(i,2)=temp2;
    56. end
    57. end
    58. %%%%%%%%%%%%%%%%%%%%%%%更新信息素%%%%%%%%%%%%%%%%%%%%%%%
    59. for i=1:m
    60. Tau(i)=(1-Rho)*Tau(i)+func(X(i,1),X(i,2));
    61. end
    62. [value,index]=min(Tau);
    63. trace(NC)=func(X(index,1),X(index,2));
    64. end
    65. [min_value,min_index]=min(Tau);
    66. minX=X(min_index,1); %最优变量
    67. minY=X(min_index,2); %最优变量
    68. minValue=func(X(min_index,1),X(min_index,2)); %最优值
    69. figure
    70. plot(trace)
    71. xlabel('搜索次数');
    72. ylabel('适应度值');
    73. title('适应度进化曲线')
    74. %%%%%%%%%%%目标函数
    75. %%%%%%%%%%%%%%%%%%%%%%%适应度函数%%%%%%%%%%%%%%%%%%%%%%%
    76. function value=func(x,y)
    77. value =20*(x^2-y^2)^2-(1-y)^2-3*(1+y)^2+0.3;
    78. end
  • 相关阅读:
    Hadoop2.7.6集群安装部署记录(3台云服务器)
    Golang PDF转图片 拼接长图 压缩PDF及图片 输出JPEG
    “现在没有人能离开Linux一天”——Linux基金会发布2021年度报告
    nodejs毕业设计拼车租车平台
    Spring Security详细讲解(JWT+SpringSecurity登入案例)
    如何用python给女神写一封照片情书?亲测表白率100%~
    XMind 桌面版新手指南
    Gradle 构建环境变量配置
    【AcWing 学习】图论与搜索
    自制数据集:点云变化
  • 原文地址:https://blog.csdn.net/qq_54169998/article/details/126679361