改进粒子速度和位置更新公式的粒子群优化算法


文章目录

  • 改进粒子速度和位置更新公式的粒子群优化算法
  • 1.粒子群优化算法
  • 2. 改进粒子群算法
  • 2.1 粒子速度和位置自适应更新策略
  • 2.2 惯性权重的选取
  • 3.实验结果
  • 4.参考文献
  • 5.Matlab代码
  • 6.Python代码



摘要:针对粒子群优化算法求解精度低、局部搜索能力差、进化后期收敛速度慢等问题,本文提出一种改进粒子速度和位置更新公式的粒子群优化算法(particle swarm optimization algorithm with improved particle velocity and position update formula, IPSO-VP). IPSO-VP算法提出一种自适应粒子速度和位置更新策略,采用基于Logistic混沌呈非线性变化的惯性权重,以此来加快算法的收敛速度、平衡算法的全局和局部搜索能力、提高收敛精度.

1.粒子群优化算法

基础粒子群算法的具体原理参考网络资料

2. 改进粒子群算法

2.1 粒子速度和位置自适应更新策略

本文结合以上分析提出一种新的自适应粒子速度和位置更新策略,如式 (10)、(11)所示.
改进粒子速度和位置更新公式的粒子群优化算法_粒子群

改进粒子速度和位置更新公式的粒子群优化算法_优化算法_02
上述自适应策略借鉴文献 改进粒子速度和位置更新公式的粒子群优化算法_粒子群_03改进粒子速度和位置更新公式的粒子群优化算法_优化算法_04 作为自适应判定条件. 当 改进粒子速度和位置更新公式的粒子群优化算法_自适应_05 时,当前粒子的适应度值远大于种群中 所有粒子平均适应度值, 表明算法处于搜索初期或者当前粒子分布较为分散,此时应采用式 (10)更新粒 子速度和位置. 式 改进粒子速度和位置更新公式的粒子群优化算法_优化算法_06 在速度更新项中引人个体最优和群体最优的线性组合, 能够使粒子的搜索空间更 广, 从而提高算法搜索到全局最优解的可能性,而位置更新则采用 “ 改进粒子速度和位置更新公式的粒子群优化算法_优化算法_07 ” 来提高算法的全局搜 索能力; 当 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_08 时, 当前粒子的适应度值与种群中所有粒子平均适应度值相差不大, 表明算法处于搜索中 后期或者当前粒子分布较为集中, 此时应采用式 (11) 更新粒子速度和位置. 在式 (11) 中, 位置更新采用 “ 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_09 ” 来保证算法局部勘探能力, 防止算法在求解复杂多峰函数时陷人局部最优, 而将粒子平均维度 信息 改进粒子速度和位置更新公式的粒子群优化算法_粒子群_10

2.2 惯性权重的选取

惯性权重 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_11 是 PSO 算法的重要参数之一, 它可以平衡算法全局开发能力和局部勘探能力, 标准 PSO 算法采用线性递减 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_11, 这种线性调整的方式可以在一定程度上平衡算法开发能力与勘探能力, 而在面对复 杂非线性多维函数优化问题时, 算法容易陷人局部最优解. 因此, 为更好改善算法性能, 一些学者提出惯 性权重非线性调整策略. 本文采用文献 改进粒子速度和位置更新公式的粒子群优化算法_粒子群_03 提出的基于 Logistic 混沌映射非线性变化惯性权重 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_11.

混沌映射作为一种非线性映射, 因其所产生的混沌序 列具有良好随机性和空间遍历性,在进化计算中得到广泛 应用,其中 Logistic 映射应用较为广泛, 它可以产生 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_15 之 间的随机数. 式 (12) 给出了 Logistic 映射的定义, 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_11 的定义 如式 (13).
改进粒子速度和位置更新公式的粒子群优化算法_优化算法_17
式中, 改进粒子速度和位置更新公式的粒子群优化算法_粒子群_18

算法实现步骤如下:
步骤 1 参数初始化, 包括种群规模 改进粒子速度和位置更新公式的粒子群优化算法_优化算法_19, 最大迭代次数 改进粒子速度和位置更新公式的粒子群优化算法_自适应_20, 学习因子 改进粒子速度和位置更新公式的粒子群优化算法_自适应_21改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_22, 惯性权重 改进粒子速度和位置更新公式的粒子群优化算法_1024程序员节_11; 并在 搜索空间内随机初始化粒子位置、速度;
步骤 2 根据给定目标函数计算所有粒子适应度值;
步骤 3 比较种群中所有粒子的适应度值与其经历过的最优位置适应度值的优劣, 若前者更优, 则用 粒子的当前位置替代粒子的个体历史最优位置;
步骤 4 比较种群中所有个体最优位置的适应度值与整个群体经历过的最优位置的适应度值的优 劣, 若前者更优,则更新全局最优位置;
步骤 5 根据式 (8) 计算 改进粒子速度和位置更新公式的粒子群优化算法_优化算法_04, 若 改进粒子速度和位置更新公式的粒子群优化算法_自适应_05, 则利用式 (10) 更新粒子的速度和位置; 否则, 利用式 (11) 更新粒 子的速度和位置;
步骤 6 判断是否满足终止条件, 若满足, 则算法终止并输出最优值; 否则, 转至步骤 2 .

3.实验结果

改进粒子速度和位置更新公式的粒子群优化算法_自适应_26

4.参考文献

[1]李二超,高振磊.改进粒子速度和位置更新公式的粒子群优化算法[J].南京师大学报(自然科学版),2022,45(01):118-126.

5.Matlab代码

6.Python代码