【优化算法】粒子群优化算法简介

article/2025/10/7 1:52:32

这里是引用


文章目录

  • 1. 简介
  • 2. 涌现复杂性
  • 3. 鸟群智能建模
  • 4. 代码实现
  • 5. Conclusion
  • 参考资料


1. 简介

人工智能是计算机科学的一个大领域,它模拟计算机中的智能行为。在此基础上,提出了一种基于元启发式( metaheuristic)的粒子群优化算法来模拟鸟类觅食、鱼群移动等。这种算法能够模拟群体的行为,以便迭代地优化数值问题。例如,它可以被分类为像蚁群算法、人工蜂群算法和细菌觅食这样的群体智能算法。

J. Kennedy 和 R.Eberhart 在1995年提出的粒子群优化(Particle Swarm Optimization,PSO)变得非常流行,它是一种基于随机优化(Stochastic Optimization)的强大算法,受鸟群中的规则启发,连续优化过程允许多目标和更多的变化。该方法包括不断寻找最佳解,以每次迭代计算的一定速度移动粒子(在这种情况下表示为位置 ( x , y ) (x,y) (xy))。每个粒子的运动都有其自身的影响,最著名的位置也是空间搜索中最著名的位置。最终期望的结果是粒子群收敛到最优解。重要的是要提到粒子群算法不使用梯度下降,所以它可以用于非线性问题,只要它不要求问题必须是可微的。

C++/Python代码可参考该仓库。

2. 涌现复杂性

涌现复杂性(Emergent Complexity)是一种现象,描述了大群体的各个组成部分如何以相同但更简单的规则一起工作,以创建多样而复杂的系统。有一些自然的复杂行为可以作为涌现的例子。例如,蚂蚁本能地相互交流,以建立一个活的桥梁,在寻找食物来源时最小化交换距离(Video)。鸟类相互跟随,形成更大的群体,这增加了它们发现捕食者和食物来源的可能性。不像通常的复杂性(complexity)概念,它不一定有用,自然复杂性(natural complexity)是一百万年自然选择过程的结果,在这个过程中,能源的使用是增加生存机会的最重要因素。因此,如果同一个问题有两个解决方案,更简单、需要更少能量的方法将因自然选择而存在。这就是为什么大自然建议的解决方案会很简单,但仍然能有效地尽可能减少动物的能量消耗。因此,科学家们分别观察了一群欧椋鸟(starlings,八哥😸)中的每只鸟,发现它们中的每只都采取简单的行动来形成复杂的结构。

  • 每只鸟都有自己的位置和速度;
  • 每只鸟都有自己的视野,可以跟随周围的鸟。这只鸟完全不知道超出此范围的动作。
  • 如果有任何鸟类发现食物,则该群中的所有鸟类都将趋向该方向。

3. 鸟群智能建模

在自然界中,在一个数值问题中,任何boid(类似鸟的物体)的可观察到的邻近区域都被限制在一定的范围内。因此,它可以收敛到一些局部极小值(minima)或鞍点(saddle point),其中梯度(在该情况下对应的是速度)将为0。然而,拥有一个以上的boid可以让鸟群中的所有鸟关注到误差函数的更大范围,并且如果它们中的任何一只在误差方面看到了更好的位置,就不会陷入局部极小值。对上述原则进行数学建模,使群体找到误差函数的全局最小值。

在这里插入图片描述

f(x)= x²+y² 的函数图像
  • 每个boid都有自己的位置和速度。我们可以把速度看作误差函数的偏导数的向量。
  • 每个boid都记录了它所经历过的最佳位置,这在一定程度上影响了boid的当前速度。
  • 这将是整群鸟见过的最好的位置。因此,它会以预定的速率影响所有boid的速度。

通过使用上述规则,我们可以轻松得出将驱动每个boid的数学方程式。
在这里插入图片描述

计算Delta V的向量表示

在这里插入图片描述
在以上等式中:

  • w w w:表示惯性,决定了boid的当前速度对 Δ V \Delta V ΔV 的影响程度;
  • c 1 , c 2 c_1, c_2 c1,c2:定义了boid和swarm的最佳记录位置(best-recorded position)将如何分别影响 Δ V \Delta V ΔV

w , c 1 , c 2 , l e a r n i n g R a t e w, c_1, c_2, learningRate w,c1,c2,learningRate 是在优化过程中应微调的超参数。


粒子群优化算法伪代码:
在这里插入图片描述
其中:

  • V i ( k + 1 ) V_i(k+1) Vi(k+1) 是下一个迭代速度;
  • W W W 是惯性参数。该参数影响最后速度值给定的运动传播。
  • C 1 , C 2 C_1, C_2 C1,C2 是加速度系数。 C 1 C_1 C1 赋予个体最佳值的重要性,而 C 2 C_2 C2 则代表群体最佳值的重要性。
  • P i P_i Pi是个体最佳位置, P g P_g Pg 是群体最佳位置。在方程式中,衡量了每个参数到粒子实际位置的距离。
  • r a n d 1 rand_1 rand1 r a n d 2 rand_2 rand2 是随机数,其中 0 ≤ r a n d ≤ 1 0≤rand≤1 0rand1,它们控制每个值的影响:群体和个体,如下所示。
    在这里插入图片描述

4. 代码实现

使用Python来实现对群体智能背(swarm intelligence)后的数学理论进行了讨论和建模。为了测试算法,Rastrigin函数将被用作误差函数,这是优化问题中最具挑战性的函数之一。在平面上有很多余弦振荡会引入无数的局部极小值,在这些极小值中,boid会卡住。(图自:Source)
在这里插入图片描述

在这里插入图片描述

import numpy as npdef error(current_pos):x = current_pos[0]y = current_pos[1]return (x ** 2 - 10 * np.cos(2 * np.pi * x)) + \(y ** 2 - 10 * np.cos(2 * np.pi * y)) + 20def grad_error(current_pos):x = current_pos[0]y = current_pos[1]return np.array([2 * x + 10 * 2 * np.pi * x * np.sin(2 * np.pi * x),2 * y + 10 * 2 * np.pi * y * np.sin(2 * np.pi * y)])

如上所述,每个boid都将具有位置,速度,误差,最佳位置和已知误差(best-known error)。我们还应该编写一个setter函数来在需要时修改参数。

class Particle:def __init__(self, dim, minx, maxx):self.position = np.random.uniform(low=minx, high=maxx, size=dim)self.velocity = np.random.uniform(low=minx, high=maxx, size=dim)self.best_part_pos = self.position.copy()self.error = error(self.position)self.best_part_err = self.error.copy()def setPos(self, pos):self.position = posself.error = error(pos)if self.error < self.best_part_err:self.best_part_err = self.errorself.best_part_pos = pos

粒子群算法类将由误差函数表面上的移动粒子列表组成。要初始化函数,需要函数的维数、boids的数量以及纪元的数量。

class PSO:w = 0.729c1 = 1.49445c2 = 1.49445lr = 0.01def __init__(self, dims, numOfBoids, numOfEpochs):self.swarm_list = [self.Particle(dims, -500, 500) for i in range(numOfBoids)]self.numOfEpochs = numOfEpochsself.best_swarm_position = np.random.uniform(low=-500, high=500, size=dims)self.best_swarm_error = 1e80  # Set high value to best swarm error

最后,编写代码来找到最佳优化误差函数的位置。首先,在每个时期,每个粒子都被逐个挑选并优化其位置。一旦粒子的位置更新,“如果”语句检查它是否是粒子群的最佳位置。

def optimize(self):for i in range(self.numOfEpochs):for j in range(len(self.swarm_list)):current_particle = self.swarm_list[j]  # get current particleVcurr = grad_error(current_particle.position)  # calculate current velocity of the particledeltaV = self.w * Vcurr \+ self.c1 * (current_particle.best_part_pos - current_particle.position) \+ self.c2 * (self.best_swarm_position - current_particle.position)  # calculate delta Vnew_position = self.swarm_list[j].position - self.lr * deltaV  # calculate the new positionself.swarm_list[j].setPos(new_position)  # update the position of particleif error(new_position) < self.best_swarm_error:  # check the position if it's best for swarmself.best_swarm_position = new_positionself.best_swarm_error = error(new_position)print('Epoch: {0} | Best position: [{1},{2}] | Best known error: {3}'.format(i,self.best_swarm_position[0],self.best_swarm_position[1],self.best_swarm_error))

运行PSO并观察算法的性能。

pso = PSO(dims=2, numOfBoids=30, numOfEpochs=500)
pso.optimize()
...
Epoch: 27 | Best position: [2.1199768747964054,-1.1332450655810595] | Best known error: 11.792438949384607
Epoch: 28 | Best position: [2.1199768747964054,-1.1332450655810595] | Best known error: 11.792438949384607
Epoch: 29 | Best position: [2.1199768747964054,-1.1332450655810595] | Best known error: 11.792438949384607
Epoch: 30 | Best position: [2.1199768747964054,-1.1332450655810595] | Best known error: 11.792438949384607
Epoch: 31 | Best position: [2.1199768747964054,-1.1332450655810595] | Best known error: 11.792438949384607
Epoch: 32 | Best position: [1.0839903018536725,-1.1678886593978168] | Best known error: 8.966098069909691

从下面的等高线图可以很容易地看出,swarm只需要几个纪元就能收敛到Rastrigin函数的全局最小值。要获得创建轮廓可视化的代码以及过程的错误时期图,可以参考:T. Ahadli, Particle Swarm Optimization C++/Python Project Codes。

在这里插入图片描述
完整代码


"""
Copyright © 2020 Tarlan Ahadli
"""import numpy as np
import matplotlib.pyplot as pltdef error(current_pos):x = current_pos[0]y = current_pos[1]return (x ** 2 - 10 * np.cos(2 * np.pi * x)) + \(y ** 2 - 10 * np.cos(2 * np.pi * y)) + 20def grad_error(current_pos):x = current_pos[0]y = current_pos[1]return np.array([2 * x + 10 * 2 * np.pi * x * np.sin(2 * np.pi * x),2 * y + 10 * 2 * np.pi * y * np.sin(2 * np.pi * y)])class PSO:class Particle:def __init__(self, dim, minx, maxx):self.position = np.random.uniform(low=minx, high=maxx, size=dim)self.velocity = np.random.uniform(low=minx, high=maxx, size=dim)self.best_part_pos = self.position.copy()self.error = error(self.position)self.best_part_err = self.error.copy()def setPos(self, pos):self.position = posself.error = error(pos)if self.error < self.best_part_err:self.best_part_err = self.errorself.best_part_pos = posw = 0.729c1 = 1.49445c2 = 1.49445lr = 0.01def __init__(self, dims, numOfBoids, numOfEpochs):self.swarm_list = [self.Particle(dims, -500, 500) for i in range(numOfBoids)]self.numOfEpochs = numOfEpochsself.best_swarm_position = np.random.uniform(low=-500, high=500, size=dims)self.best_swarm_error = 1e80  # Set high value to best swarm errordef optimize(self):for i in range(self.numOfEpochs):for j in range(len(self.swarm_list)):current_particle = self.swarm_list[j]  # get current particleVcurr = grad_error(current_particle.position)  # calculate current velocity of the particledeltaV = self.w * Vcurr \+ self.c1 * (current_particle.best_part_pos - current_particle.position) \+ self.c2 * (self.best_swarm_position - current_particle.position)  # calculate delta Vnew_position = self.swarm_list[j].position - self.lr * deltaV  # calculate the new positionself.swarm_list[j].setPos(new_position)  # update the position of particleif error(new_position) < self.best_swarm_error:  # check the position if it's best for swarmself.best_swarm_position = new_positionself.best_swarm_error = error(new_position)print('Epoch: {0} | Best position: [{1},{2}] | Best known error: {3}'.format(i,self.best_swarm_position[0],self.best_swarm_position[1],self.best_swarm_error))pso = PSO(dims=2, numOfBoids=30, numOfEpochs=500)
pso.optimize()

5. Conclusion

总而言之,粒子群优化(Particle Swarm Optimization)模拟了鸟或鱼群的集体行为。它受益于自然界解决自身优化问题的方式,以最大限度地减少能量使用。自然的设计和原理在计算机科学问题上有很多出色的实际应用。


参考资料

Nature-Inspired Optimization Algorithms: Particle Swarm Optimization Using Python
Implementing the Particle Swarm Optimization (PSO) Algorithm in Python


http://chatgpt.dhexx.cn/article/TwiD3y2T.shtml

相关文章

粒子群优化算法(Particle Swarm Optimization)

转自&#xff1a;https://www.cnblogs.com/21207-iHome/p/6062535.html 粒子群算法的思想源于对鸟/鱼群捕食行为的研究&#xff0c;模拟鸟集群飞行觅食的行为&#xff0c;鸟之间通过集体的协作使群体达到最优目的&#xff0c;是一种基于Swarm Intelligence的优化方法。它没有遗…

粒子群优化(PSO)算法

一.算法思想 粒子群算法( Particle Swarm Optimization, PSO)最早是由Eberhart和Kennedy于1995年提出,它的基本概念源于对鸟群觅食行为的研究。设想这样一个场景:一群鸟在随机搜寻食物,在这个区域里只有一块食物,所有的鸟都不知道食物在哪里,但是它们知道当前的位置离食…

智能优化算法——粒子群优化算法(PSO)(小白也能看懂)

前言&#xff1a; 本文主要参考B站的一篇学习视频后&#xff0c;加之自己的理解和浓缩精华&#xff0c;不想看文字的可以直接划到末尾去b站看原视频&#xff0c;非常通俗易懂。 理论知识&#xff1a; 感性认知&#xff1a;如下面一张图片所示。在一个范围内&#xff0c;以三…

智能算法系列之粒子群优化算法

本博客封面由ChatGPT DALLE 2共同创作而成。 文章目录 前言1. 算法思想2. 细节梳理2.1 超参数的选择2.2 一些trick 3. 算法实现3.1 问题场景3.2 python实现 代码仓库&#xff1a;IALib[GitHub] 前言 本篇是智能算法(Python复现)专栏的第三篇文章&#xff0c;主要介绍粒子群优化…

粒子群优化算法(PSO)

粒子群优化算法&#xff08;PSO&#xff09; 粒子群优化算法&#xff08;PSO&#xff09;是一种进化计算技术&#xff0c;源于对鸟群捕食行为的研究。该算法最初是受到飞鸟集群活动的规律性启发&#xff0c;进而利用群体智能建立的一个简化模型。粒子群算法在对动物及群活动行…

数学建模——粒子群优化算法(PSO)【有详细样例 + 工具:matlab】(万字总结)

文章目录 一、粒子群优化算法(PSO)是什么&#xff1f;二、粒子群优化算法有什么用&#xff1f;三、粒子群优化算法的适用范围&#xff1f;四、算法简介(有助于理解)五、算法流程第一步&#xff1a;初始化第二步&#xff1a;计算粒子的适应度第三步&#xff1a;更新个体极值与全…

粒子群优化算法(PSO)附代码

文章目录 1 算法介绍2 算法模型3 实现步骤4 MATLAB代码实现PSO算法4.1. main.m4.2. 运行结果 1 算法介绍 粒子群优化算法(Particle Swarm Optimization&#xff0c;PSO)是一种经典的群智能算法&#xff0c;该算法灵感源自于鸟类飞行和觅食的社会活动&#xff0c;鸟群通过个体之…

浏览器添加划词翻译插件

网站&#xff1a;https://github.com/Selection-Translator/crx-selection-translate 安装下载的扩展程序

Chrome划词翻译-Saladict

Saladict 沙拉查词是一款专业划词翻译扩展&#xff0c;为交叉阅读而生。大量权威词典涵盖中英日韩法德西语&#xff0c;支持复杂的 划词操作、网页翻译、生词本、PDF&#xff0c;以及 Vimium 全键盘操作 。 迄今为止最好用的网页划词翻译插件。 下载安装地址&#xff1a;Chrome…

谷歌划词翻译

谷歌划词翻译是个谷歌插件 复制及时翻译很好用 插件下载地址 配置谷歌翻译方法

惊了,MATLAB竟能制作如此方便的划词翻译工具???

我点开程序一看&#xff0c;程序第一行就写着import&#xff0c; 却歪歪斜斜的每行上都是着MATLAB几个大字。 我横竖睡不着&#xff0c;仔细看了半夜&#xff0c; 才从字缝里看出字来&#xff0c;满页都写着 ⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀——Java 其实用的…

python实现划词翻译

最近因为编程&#xff0c;需要大量地看一些说明文档&#xff0c;无奈说明文档都是英文的&#xff0c;可把我这个半桶水折腾死了&#xff0c;太多词汇不知道&#xff0c;一个个复制翻译太麻烦了。于是我根据自己的需要&#xff0c;用python写了一个划词翻译。 一&#xff1a;使…

划词翻译简单实现

环境&#xff1a;archlinux &#xff0c;其余linux系统类似 安装依赖 sudo pacman -S xsel sudo pacman -S translate-shell sudo pacman -S libnotify脚本书写 创建脚本 touch word_translate.sh chmod x word_translate.sh vim word_tranlate.sh#!/bin/bashwhile true; d…

Chrome划词插件-有道词典

当我们在阅读文章&#xff0c;查找资料或者查看英文文献时&#xff0c;经常会遇到不认识的英文单词&#xff0c;这时&#xff0c;我们往往会复制单词百度一下才行。 其实&#xff0c;遇到这种情况&#xff0c;我们可以直接下载一个有道词典的Chrome划词插件&#xff0c;遇到需…

PDF划词翻译插件

PDF划词翻译插件 1、打开一个拓展插件的下载网站2、下载沙拉查词并安装3、进入详情&#xff0c;设置为允许打开文件网址4、固定她5、打开她的设置最终划词结果 1、打开一个拓展插件的下载网站 点击此网站地址 2、下载沙拉查词并安装 打开开发者模式&#xff0c;把下载好的.cr…

福昕pdf阅读器的划词翻译功能如何添加(图文并茂)

一、打开福昕阅读器 二、可在上方工具栏&#xff0c;点击“帮助”&#xff0c;关于福昕阅读器领鲜版查看安装的版本信息&#xff0c;如图1-1&#xff0c;图1-2 图1-1 图1-2 三、找到上方工具栏的图标按键&#xff0c;名为“自定义快速访问工具栏”&#xff0c;如图1-3&#…

谷歌浏览器无法翻译成中文,谷歌翻译,最新(沉浸式翻译和划词翻译,chrome无法翻译,谷歌浏览器无法翻译此网页)

简介&#xff1a;谷歌浏览器自带的翻译功能&#xff0c;对我们来说用处很大&#xff0c;但有的时候突然就会变成“无法翻译此网页”&#xff0c;之前给大家提供过两种无法翻译此网页的解决方案&#xff0c;这次再给大家分享下两款别的翻译方法&#xff1b; 一、上次介绍&#x…

关于网页划词翻译

2013-4-21 近日偶然看到js页面文字选中后分享到新浪微博实现&#xff0c;发现原来竟然只要一句话就可以实现获取划词。便萌生自己写个划词翻译的东东&#xff0c;方便自己看文档。 我首先想到了之前看到的油猴插件&#xff0c;最早是在看优酷去广告插件的原理时知道这个东西。感…

基于Edge浏览器的沙拉划词插件使用教程(好用的翻译插件)

1.使用目的 - 使用沙拉划词实现网页多种翻译源进行实时翻译。 - 使用沙拉划词实现PDF翻译。 2.安装方法 2.1 打开edge扩展 点击工具栏右侧… 然后点击扩展 进入扩展 2.2 下载沙拉划词 2.2.1 点击获取扩展 2.2.2点击搜索 搜索沙拉划词 回车搜索 正常获取并添加扩展 出现沙…

PDF划词翻译软件

PDF划词翻译 一个简单的PDF划词翻译软件。 Github仓库地址&#xff1a;https://github.com/WCX1024979076/simple_pdf_translator Github下载地址&#xff1a; https://github.com/WCX1024979076/simple_pdf_translator/releases/tag/v0.1.0 Gitee仓库地址&#xff1a; htt…