1、粒子群算法的惯性权重调整策略 李丽 1 薛冰 2 牛 奔 3 1 深圳大学管理学院信管系 , 广东深圳 ( 518060) 2深圳大学管理学院信管系 , 广东深圳 ( 518060) 3深圳大学管理学院信管系 , 广东深圳 ( 518060) E-mail(小五, Times New Roman) 摘 要: 惯性权重是粒子群算法改进的一个重要出发点, 通过调整惯性权重可以大大提高算法的性能 。本文 在介绍粒子群算法原理、 流程的基础上,分析了惯性权重在算法寻优过程中的重要作用,然后归纳了 运用不同方法对 惯性权重 的改进 , 进行了简单的讨论,并对下一 步工作进行了展望。 关键词: 粒子群算法
2、 惯性权重 改进策略 1 引言 粒子群优化算法( Particle Swarm Optimization, PSO)是 1995年由 Eberhant和 Kennedy在文献 1中提出的一种基于群体智能、自适应的搜索优化方法。 其基本思想源于对鱼类、鸟类等群体社会行为的观察研究。粒子群算法提出以后,由于其算法概念简单、需要调整的参数较少、容易实现和快速收敛能力,已被广泛地用在科学和工程领域,如电力系统优化 (文献 31 33) 、 TSP 问题 (文献 34)、神经网络训练 (文献 35)、函数优化 (文献 37、 38)等。 粒子群算法在应用过程中体现出了很强的寻优能力, 但与其他全局优化算
3、法相同,粒子群算 法也存在早熟局部收敛和后期震荡现象。针对这些问题,国内外学者经过大量研究工 作,提出了多种改进方法,包括参数改进,拓扑结构改进和混合算法等 。 其中惯性权重是最重要的可调整参数, 惯性权重 由于其 概念简单 、 容易理解、 改进 的 方法 较 多 、改进的空间较大且容易实现 等特点,成为很多学者研究的焦点 。 通过调整惯性权重的值可以实现全局搜索和局部搜索之间的平衡 :较大的权值有利于提高全局搜索能力,而较小的权 会提高局部搜索能力。诸多研究者运用线性递减、非线性递减等方法对惯性权重进行调整,实现了算法在不同方面和不同程度上的改进。本文通过对国内外研究人员所提出的调整惯性权重
4、策略进行归纳总结,讨论了各种策略的优缺点,并在此基础上提出了下一步工作方向及需要解决的问题。 2 基本粒子群算法 在粒子群算法中,每个寻优的问题解都被想像成一只“鸟”,也称为一个没有重量和体积的粒子,每个的粒子在 n 维搜索空间里飞行,并有一个速度决定其飞行的距离与方向,所有粒子都有一个适应值函数来判断其目 前位置的好坏,且在飞行过程中,每一个粒子都是具有记忆性的,能记得所搜寻到的最佳位置。 因此,在飞行过程中,每一代都能找出两个“极值”:每一个粒子到目前为止的搜寻过程中最优解,代表粒子自身认知水平,称之为个体极值 Pbest;所有群体中的最优解,代表社会认知水平,称之为全局极值 Gbest。
5、粒子群算法首先初始化一群随机粒子,然后根据两个“极值”通过更新迭代找到最优解,其基本迭代方程如下: )()()()1( 21 txpr a n dctxpr a n dctVtV idgdidididid ( 1) )1()()1( tVtxtx iii ( 2) 其中, idv 表示粒子 i 在第 d 维的速度, n 维向量 ),()( 21i inii xxxtx 表示 迭代到 第 t 代时粒子 i 的位置, n 维向量 ),()( 21 iniii vvvtv 表示 粒子 i的速度 。 1c 、 2c 是学习因子, ()rand 是均匀分布于 0,1之间的随机数 , idp 表示个体极值
6、 Pbest, gdp 表示全局极值 Gbest。为了 防止 )(txi 溢出 ,设置 maxv 来控制 )(tvi 的范围: m a xm a xm a x)(. . . . . . . . . . . . . . . . )(. . . . . . .) . . . . . . . . .()( VtVV VtVtVtViiii( 3) 具体算法流程如下: (1) 初始化所有微粒 (群体规模为 N ,在允许范围内随机设置微粒的初始位置和速度 ,并将各微粒的 idp 设为初始位置 ,取 gdp 为 idp 中的最优值。 (2) 评价每个微粒的适应值 ,即分别计算每个微粒的目标函数值。 (3)
7、 对于每个微粒 ,将其适应值与所经历过的最好位置 idp 的适应值进行比较 ,若较好 ,则将其作为当前的最优位置。 (4) 对于每个微粒 ,将其适应值与群体所经历过的最好位置 gdp 的适应值进行比较 ,若较好 ,则将其作为当前的全局最优位置。 (5) 根据速度和位置更新方程对微粒的速度和位置进行更新。 (6) 如未达到结束条件 ,通常为足够好的适应值或是达到一个预设的最大迭代代数 ,则返回第( 2)步。 具体算法流程图如下: 是 微粒适度值评价 开 始 微粒群体初始化 计算个体历史最优值和 全局最优值 群体历史最优值 根据速度和位置更新方程更新微粒速度和位置 算法结束 满足 终止条件 ? 否
8、 3 惯性权重的提出 经过大量的研究试验,为了提高基本粒子群算法的收敛性能和避免算法陷入局部最优,Y.Shi 和 R.C.Eberhant 于 1998 年在 A modified particle swarm optimizer(文献 2)一文中提出了惯性权重这一概念,在进化方程( 1)中引入惯性权重因子 w ,即: )()()()1( 21 txpr a n dctxpr a n dctwVtV idgdidididid ( 4) 等式右边的结构和( 1)式一样,第一部分是粒子先 前的自身速度,用来保证算法的全局收敛性;第二和第三部分是引起微粒速度变化的社会因素,使算法具有局部搜索能力。所
9、以 w 起到了一个平衡全局搜索能力和局部搜索能力的作用, w 值较大时全局搜索能力强,局部搜索能力弱; w 值较小时,反之。恰当的 w 值可以提高算法性能,提高寻优能力,减少迭代次数。 惯性权重的引入,对粒子群算法的发展起到了很大推动作用,大 大拓展了算法改进的空间。但是要达到算法性能最优还存在很多缺陷,因为当 w 值较大时,有利于全局搜索,虽收敛速度快,但不易得到精确解; w 值较小时有利于局部搜索和得到更为精确的解,但收敛速度慢且有时会陷入局部极值。如何寻找合适的 w 值使之在搜索精度和搜索速度方面起恰当的协调作用,成为很多学者研究的一个新方向,通过几年的发展,已有了不少研究成果。 4 惯
10、性权重调整策略 基于研究各种问题的复 杂性和惯性权重在算法迭代过程中所起到的平衡作用,除了固定惯性权重以外,学者们还提出了很多种惯性权重调整策略,主要有线性递减策略、非线性递减策略和自适应调整策略等 以 下几种: 4.1 线性递减策略 由于在一般的全局优化算法中,总希望前期有较高的全局搜索能力以找到合适的种子,而在后期有较高的开发能力,以加快收敛速度,所以惯性权重的值应该是递减的。其中的线性递减策略主要有以下几种: 4.1.1 典型线性递减策略 Y.Shi 和 R.C.Eberhant 在文献 2还中提到了 w 应 是随着进化线性递减的。这是首次提出的惯性权重递减策略,我们称之为典型线性递减策
11、略, w 的计算公式如下: tt wwwtw m ax m i nm axm ax)( ( 5) 其中 maxw 、 minw 分别是 w 的最大值和最小值; t 、 maxt 分别是当前迭代次数和最大迭代次数(全文中符号表 示意义相同)。文献 9试验了将 w 设置为从 0.9 到 0.4 的线性下降,使得 PSO 在开始时探索较大的区域,较快地定位最优解的大致位置,随着 w 逐渐减小,粒子速度减慢,开始精细的局部搜索。该方法使 PSO 更好地控制全局搜索能力和局部搜索能力,加快了收敛速度,提高了算法的性能。 这种典型的惯性权重线性递减策略在目前是应用最为广泛,但是由于这种策略下,迭代初期全局
12、搜索能力较强,如果在初期搜索不到最好点,那么随着 w 的减小,局部搜索能力加强,就易陷入局部极值。 4.1.2 线性微分递减策略 为了克服典型线性递减策略的局限性,文献 14中提出了一种线性微分递减策略,惯性权重的计算公式如下: tt wwdtdw m ax2 m inm ax )(2 ( 6) 22m axm i nm axm ax )()t( tt wwww ( 7) 通过对 w 变化方程及实验结果进行分析,由于在算法进化初期 w 的减小趋势缓慢,全局搜索能力很强,有利于 找到很好的优化种子,在算法进化后期, w 的减小趋势加快,因此一旦在前期找到合适的种子,可以使得算法收敛速度加快,在一
13、定程度上减弱了典型线性递减策略的局限性,相应地在算法性能提高上有了很大改善。 4.2 非线性递减策略 4.2.1 带阀值的非线性递减策略 惯性权重线性递减策略经过不断改进,已经比原始的惯性策略有了很大改善。但是由于其线性递减的特征,对于很多问题,在迭代过程中,算法一旦进入局部极值点邻域内就很难跳出来,为了克服这种不足, 文献 18在典型线性递减策略的基础上引入了递减指数 和迭代阀值 0T ,提出了一种惯性权重的非线性递减策略,即: )()11()( m i nm a x0m a x wwTtwtw ( 8) 此时参数集变为 , maxw 、 minw 、 0T ,当迭代次数到达 0T 时,令
14、max)( wtw ,并保持到搜索结束,整个迭代过程由于 的引入, )(tw 随着 t 的增大而非线性递减,有利于跳出局部极值点。迭代初期 w 较大,粒子以较大的飞行速度遍布整个搜索空间从而确定最优值的大概范围,随着迭代的进行 w 非线性减小,大部分粒子的搜索空间逐渐减小,并且集中在最优值的邻域范围内;在迭代末期当达到迭代阀值时,将惯性权重限定为 maxw ,粒子以近乎不变的飞行速度在最优值邻域范围内找到全局最优解,有利于提高算法的收敛速度,尤其对于低维测试函数,无论在搜索最优值精度、收敛速度还是在稳定性方面都有明显的优势。 4.2.2 先增后减策略 针对递减策略中仍然存在的不足,文献 16提
15、出了一种具有先增后减惯性权重的微粒群算法, w 的惯性权重计算方程如下: 15.0. . . . . . . . . .4.115.00. . . . . . . . . . . . .4.01W ( t )m axm axm axm axtttttttt( 9) 文献 16经过试验 研究 ,这种先增后减的惯性权重,在前期有较快的收敛速度,而后期的局部搜索能力也不错 ,在一定程度上保持了递减和递增策略的优点,同时克服了一些缺点,相对提高了算法性能。 此外,国内还有人提出了其他的非线性动态递减惯性权重,如文献 19中提出依据下式来计算惯性权重的方法: m a x2 /111m i nm a x
16、)()( ttdedwwtw ( 10) 其中 1d , 2d 为控制因子,目的是为了控制 w 在 maxw 和 minw 之间。经 过大量实验证明当 2.01d , 7.02 d 时算法的性能会大大提高。 4.3 自适应动态改变惯性权重 4.3.1 依据 早熟收敛程度和 适应值 进行 调整 以上的惯性权重调整策略都是依据迭代次数的递增而递减的,文献 20提出了一中自适应调整策略,根据群体早熟收敛程度和个体适应值的来确定惯性权重的变化。 设粒子 ip 的适应值为 if ,最优粒子的适应值是 mf 粒子群的平均适应值是 ni ifnf 1avg1 ;将优于 avgf 的适应值求平均得到 avgf
17、 ; 且定义 avgm ff 。依据 if 、 avgf 和 avgf 将群体分为 3 个子群,分别进行不同的自适应操作。则其惯性权重的调整如下: ( 1) if 优于 avgf 则 a v gma v gi ff ffwwwtw m in )()( ( 11) ( 2) if 优于 avgf 但次于 avgf ,则惯性权重不变; ( 3) if 次于 avgf 则 )e x p (1 15.1)( 21 kktw( 12) 其中第一类子群是群体中较优秀的粒子,已经接近全 局最优解,赋予其较小的惯性权重,从而强化了局部搜索能力;第二类粒子为一般粒子,具有较好的全局搜索能力和局部搜索能力,不需要
18、改变其惯性权重;第三类粒子为群体中较差粒子,借鉴自适应调整遗传算法控制参数的方法对其进行调整。 1k 、 2k 为控制参数, 1k 用来控制 w 的上限(一般为大于 1的常数), 2k 主要用来控制上式的调节能 力。当算法停止时,若粒子分布较为分散,则较大,由上式来降低粒子的 w ,加强局部搜索能力,以使群体趋于收敛,若粒子分布较为聚集,则较小,由上式增加粒子的 w ,使粒子具有较强的探查能力,从而有效地跳出局部最优。 4.3.2 根据距全局最优点的距离进行调整 国内一些学者认为惯性权重的大小还应该和其距全局最优点的距离有关。文献 21中提出各不同粒子的惯性权重 w 的值不仅随迭代次数的增加而
19、递减, 并且应该随 其 距全局最优点距离增加而递增,即权重 w 根据粒子的位置不同而动态变化: m a xm i nm a xm i nm a xm i nm a x )( )()( tll twwllwtw ig ( 13) 其中 igl 为第 i 个粒子到最优粒子的距离, maxl 和 minl 分别是预先设的最大距离和最小距离参数。根据上式,当 maxllig 时, maxww ;当 mi nll ig 时, minww ;当 maxmin lll ig 时, w 随着 igl 单调递增。仿真实验结果表明在这种策略下算法在收敛速度和迭代次数方面都有了改进,特别是对于多峰函数效果提高的更明
20、显。 4.4 其他的惯性权重调整策略 4.4.1 模糊调整 w 的策略 Shi 等 认为粒子群算法搜索过程是一个非线性的复杂过程,让 w 线性下降的方法不能正确的反映真实的搜索过程。因而,提出用模糊推理机来动态地调整惯性权重的技术 6。模糊 w 法的优缺点如下:模糊推理机能预测合适的 w ,动态地平衡全局和局部搜索能力,大为提高了平均适应值;但是其参数比较多,增加了算法的复杂度,使得其实现较为困难。 4.4.2 随机调整 w 的策略 目前的研究中,很多学者认为 w 应为一组随机值,如: Eberhart7等提出一种动态惯性权重法以试图解决优化目标变化显著的问题,该方法令 0.2 ()5.0)(
21、 randtw ( 14) 能产生一个在 0.5, 1之间的 w 值。通过使用函数测试性能,显示这种策略下的粒子群算法能跟随非静态目标函数,比进化规划和进化策略得到的结果精度更高,收敛速度更快 8。 国内也有很多学者在这方面有所研究,提出了 w 服从均匀分布、正态分布等随机策略,使算法性能较线性递减策略都有明显提高。 5 结论 综上所述可以看出,惯性权重作为粒子群算法中的一个重要参数,是算法改进的一个重要途径,可改进的方向和方法有很多种,已经有很多学者经过长期研究提出了不同的改进策略,本文通过对各种改进策略的归纳总结,分类说明了各种策略的优缺点,为使用者提供了方便。作者的进一步工作有两个方面:
22、 1. 通过仿真试验 对各种算法进行更深层次的分析对比,找出适合不同问题的最优改进算法; 2 结合各种问题和各种测试函数,提出效果更优的惯性权重调整策略。 参考文献 1J.Kennedy,R.C. Eberhart. Particle swarm optimization A.Proceedings of the IEEE International Conference on Neural Networks C. 1995:19421948 2ShiYuhui,Eberhart,R.A modified particle swarm optimizerA.Proc IEEE Int Conf
23、on Evolu- tional ComputationC.Anchorage,1998.69-73 3Kennedy J.The particle swarm Sociala adaptation knowledge A.Proc IEEE Int Confon Evolutional ComputationC.Indiamapolis,1997.303-308 4J.Kennedy,R.C.Eberhart.A Discrete Binary Version of the Particle Swarm Algorithm. Proceedings of the World Multi co
24、nference on Systemic, Cybernetics and Informatics C. Piscataway, NJ: IEEE Service Center, 1997:4104410 5Kennedy J,EberhartRC.Particle Swarm Optimization C.Proc IEEE Int Conf Neural Networks .Piscataway,NJ:IEEEServiceCenter,1995:1942-1948 6Y. H. Shi, R. C. Fuzzy Adaptive Particle Swarm Optimization A
25、. Proceedings of the Congress on Evolutionary Computation C. Seoul, Korea, 2001:101106 7R. C. Eberhart,. H. Shi. Tracking and Optimizing Dynamic Systems with Particle Swarms A. Proceedings of the 2001 Congress on Evolutionary Computation C. Piscataway, NJ: IEEE Press, 2001:94100 8Van den Bergh F. An
26、 Analysis of Particle Swarm Optimizer D. South Africa: Department of Computer Science, University of Pretoria,2002 9Y. H. Shi,R. C. Eberhart. Empirical Study of Particle Swarm Optimization A. Proceeding of Congress on Evolutionary Computation C. Piscataway,NJ:IEEE Service Center, 1999:19451949 10Ele
27、gbede C.Structural reliability assessment based on particles swarm optimization J Structural Safety2005.27(10)1 171-186 11 Robinson J,Rahmat-Samii Y Particle swarm optimization in electromagneticJ IEEE Transactions on Antennas and Propagation,2004,52(2):397 406 12 Salman A。 Ahmad I,A1 一 Madani S Par
28、ticle swarm optimization for task assignment problem FJ Microprocessors and Microsystems, 2002,26 (8):363 371 13谢晓锋,张文俊,杨之廉 .微粒群算法综述 J.控制与决策 .2003, 18(2):129)133 14胡建秀 曾建潮 . 微粒群算法中惯性权重的调整策略 J.计算机工程 ,2007.6 15肖人彬,陶振武 .群体智能研究进展 J.管理科学学报 ,2007 16崔红梅,朱庆 保 .微粒群算法的参数选择及收敛性分析 J. 计算机工程与应用 ,2007 17曾建潮,崔志华 .一
29、种保证全局收敛的 PSO 算法 J.计算机研究与发展 ,2004,( 8) :1333 1338 18王丽,王晓凯 .一种非线性改变惯性权重的粒子群算法 J.计算机工程与应用 ,2007.43 19李会荣,高岳林,李济民 .一种非线性递减惯性权重策略的粒子群优化算法 J.商洛学院学报 2007.12 20韩江洪,李正荣,魏振春 .一种自适应粒子群优化算法及其仿真研究 J.系统仿真学报 ,2006.10 21刘建华,樊晓平 .一种惯性权重动态调整的新型粒子群算法 J.计算机工程与应用,2007.43( 7) 22胡建秀,曾建潮 .具有随机惯性权重的 PSO 算法 J.计算机仿真 ,2006.8
30、23郭文忠 .粒子群优化算法中惯性调整的一种新策略 J.计算机工程与科学 ,2007.10 24王伯成,施锦丹,王凯 .粒子群优化算法的研究现状与发展概述 J.电视技术 ,2008.5 25唐岑琦,周有人 .具有综合学习机制的粒子群算法 J.计算机工程与应用 ,2007, 43( 31) 26陈贵敏 .粒子群优化算法 的惯性权值递减策略研究 J.西安交通大学学报 ,2006. 27王启付,王战江 .一种改变惯性权重的粒子群优化算法 J.中国机械工程 ,2005.16(11) 28王俊伟,汪定伟 .粒子群算法中惯性权重的实验与分析 J.系统工程学报 ,2005.20( 2) :194-198 2
31、9 张选平,杜玉平 .秦国强,覃征 .一种动态改变惯性权重的自适应粒子群算法 J.西安交通大学学报 ,2005.10 30张丽平 ,俞欢军 .粒子群优化算法的分析与改进 J.信息与控制 ,2004.33( 5) :513-517 31张振宇 .粒子群优化算法及其在电力系统优化运行中的应用 D.天津 :天津大学 ,2007 32李丹 ,高立群 .电力系统机组组合问题的动态双种群粒子群算法 J.计算机应用 ,2008 33侯颖君 .粒子群优化算法在电力系统规划中的应用研究 D.杭州 :浙江大学 , 2008.03 34肖健梅 .李军军 .改进微粒群优化算法求解旅行商问题 J.计算机工程与应用 ,2
32、004.35 35高海兵 .基于粒子群优化的神经网络训练算法研究 J.计算机工程与应用 , 2004.9 36 卜 雷 , 蒲 云 , 尹传忠 .城市 公交车路线选择的遗传算法 J.世界科技研究与发展 .2004 37陈永刚 .粒子群算法及其在函数优化和路径优化问题上的应用 D.长春 :吉林大学 , 2006.08 38曹国华 ,李婷婷 .改进 PSO 算法及其在函数优化中的应用 J.南京师范大学学报 (工程技术版 ), 2007,02.002 39徐小平 ,钱富才 ,刘丁 .基于 PSO 算法的系统辨识方法 J.系统仿真学报 , 2008.13 40胡家声 .粒子群优化算法及其在电力系统中的
33、应用 D.武汉 :华中科技大学 , 2005.03 Study on the inertia weight of the particle swarm optimization (PSO) Li Li, Bing Xue, and Ben Niu Abstract: The inertia weight is an important way to improve the particle swarm optimization (PSO) algorithm. This paper introduces the basic theory and the process of the PSO, then analyses the importance of the inertia weight, summarize the different improved PSO algorithms caused by the different inertia weight strategy and discusses them, At last the further researches on the inertia weight are given. Keywords: Particle swarm optimization; inertia weight; strategy.