粒子群算法(Particle Swarm Optimization)

news2024/11/25 13:17:22

注意:本文引用自专业人工智能社区Venus AI

更多AI知识请参考原站 ([www.aideeplearning.cn])

算法背景

粒子群优化算法(Particle Swarm Optimization,PSO)的灵感来源于鸟群或鱼群的觅食行为。想象一下,你在公园里看到一群鸟,它们在空中飞翔,寻找食物。每只鸟都不知道食物在哪里,但它们会根据周围其他鸟的位置和过去自己找到食物的经验来调整自己的飞行方向。如果一只鸟发现了食物,其他鸟很快也会朝着这个方向飞去。在这个过程中,整个鸟群像一个搜索系统,通过个体间的信息共享,找到最佳的觅食地点。

这个觅食的过程非常像一个优化问题:每只鸟(粒子)都在寻找食物(最优解),它们根据自己和同伴的经验(位置信息),在整个空间(搜索空间)中移动,最终找到食物的位置(最优解的位置)。

有读者可以感觉粒子群算法与麻雀算法有些相似。粒子群算法(PSO)和麻雀搜索算法(SSA)都是受自然界中群体行为启发的优化算法,它们都模仿了生物群体的社会行为来寻找最优解。然而,PSO是基于鸟群的觅食行为,而SSA则是模仿了麻雀的觅食和警戒行为,两者在模拟策略和行为细节上有所不同。

算法应用

粒子群优化算法(PSO)是一种非常灵活和多用途的优化算法,它在许多领域都有广泛的应用。以下是一些主要的应用场景:

  1. 工程优化:在工程领域,PSO常被用于设计优化、结构优化、电力系统优化等。比如,可以用它来优化建筑的结构设计,使其在成本和稳定性之间达到最佳平衡。
  2. 机器学习和数据挖掘:在机器学习中,PSO可以用于选择最佳的特征组合、调整算法的参数,甚至是用于训练神经网络。
  3. 网络和计算机科学:在网络设计、路由优化、云计算资源分配等领域,PSO也显示出了其有效性。比如,它可以用于优化网络中的数据流,确保信息快速且准确地传输。
  4. 经济学和金融:在金融市场分析、投资组合优化等方面,PSO也被广泛应用。它可以帮助投资者决定在何处投资,以及如何分配他们的资产,以获得最大的收益。
  5. 生物医学应用:在生物医学领域,PSO被用于生物信息学、药物设计和医疗影像分析等方面,帮助研究人员解决复杂的生物医学问题。

算法计算流程

粒子群优化算法 (PSO) 的计算流程可以详细分为以下几个步骤:
1. 初始化粒子群:
– 随机生成一组粒子 (解的候选者),每个粒子代表搜索空间中的一个潜在解。
– 为每个粒子指定一个随机的位置 (即解的值) 和速度。
2. 评估粒子的适应度:
– 对每个粒子的当前位置进行评估,根据优化问题的目标函数计算其适应度(如何接近最优解)。

3. 更新速度和位置:
– 对于每个粒子,根据下面的公式更新其速度:

标准的粒子群速度更新公式如下:

v_i^\mathrm{new~}=w\cdot v_i^\mathrm{old~}+c_1\cdot rand_1\cdot\left(\mathrm{~pbest~}_i-x_i^\mathrm{old~}\right)+c_2\cdot rand_2\cdot\left(g\mathrm{~best~}-x_i^\mathrm{old~}\right)

其中:
– v_{i}^{new} 是粒子 i 在新的迭代中的速度。
– w是惯性权重,用于控制前一速度对当前速度的影响。
v_{i}^{\mathrm{old}}是粒子 i 在前一迭代中的速度。
– c_{1} 和 c_{2} 是加速常数,用于调整个体和社会学习行为的相对影响。
– rand_{1}和  rand_{2}是两个介于 0 和 1 之间的随机数。
pbset_{i}是粒子 i 到目前为止找到的最优位置。
– gbest 是整个群体到目前为止找到的最优位置。
x_{i}^{old} 是粒子 i 在前一迭代中的位置。
– 更新粒子的位置:

x_i^\text{new }=x_i^\text{old }+v_i^\text{new}

4. 更新个体和全局最优解:
– 对于每个粒子,如果当前位置比之前遇到的最佳位置更优,则更新其个体最优解 (pbest)。
– 同时,从所有粒子中找出具有最佳适应度的位置,更新为全局最优解 (gbest)。

5. 迭代和终止条件:
– 重复步骤2-4,直到满足终止条件(如达到最大迭代次数或解的质量达到预定阈值) 。
6. 输出结果:
– 算法结束时,全局最优解 gbest 即为找到的最优解。

注意,粒子群优化算法 (PSO) 中的速度更新公式设计得非常巧妙,它反映了算法的核心思想: 通过模拟鸟群的社会行为来指导搜索过程。公式的设计考虑了以下几个关键因素:
1. 惯性权重 w :
– 这部分表示粒子的当前速度对其未来速度的影响,即粒子的惯性。较大的惯性权重有助于粒子探索更远的区域,促进全局搜索;较小的权重有利于粒子在局部区域进行详细搜索,促进局部优化。
2. 个体经验 c_1\cdot rand_1\cdot\left(\mathrm{~pbest~}_i-x_i^\mathrm{old~}\right) :
– 这部分反映了粒子自身的历史最佳位置 (个体经验) 对其速度的影响。粒子会考虑自己之前找到的最优位置(pbest),并朝这个方向调整速度。这里的随机数 rand 1 保证了搜索的随机性和多样性。
3. 社会经验c_2\cdot rand_2\cdot\left(g\mathrm{~best~}-x_i^\mathrm{old~}\right) :
– 这部分考虑了群体中其他粒子的信息。每个粒子也会朝着当前群体中已知的最优位置 (gbest) 移动。这里的随机数 rand 2 同样增加了搜索的随机性和多样性。
4. 学习因子 c1 和 c2 :
– 这两个学习因子分别表示个体经验和社会经验对速度更新的影响程度。这些因子的值决定了算法是倾向于利用个体的过去经验还是群体的共同经验。

总的来说,速度更新公式通过结合个体历史信息和群体共享信息,以及通过引入随机因素来增加搜索的多样性,从而有效地指导粒子群体在解空间中的搜索行为,这既保证了全局搜索能力,又保留了局部搜索的细致性。通过调整公式中的参数,可以控制算法的探索和开发能力,使其适应不同类型的优化问题。

算法示例推导

上述函数求解的python代码实现如下:

import numpy as np
import matplotlib.pyplot as plt
# 粒子群优化算法(PSO)求解 f(x, y) = x^2 + y^2
# 目标函数
def objective_function(position):
    x, y = position
    return x**2 + y**2
# 参数设置
n_particles = 50
n_iterations = 10
dim = 2  # 搜索空间的维度,这里是二维空间
w = 0.5  # 惯性权重
c1 = 0.8  # 个体学习因子
c2 = 0.9  # 社会学习因子
# 初始化粒子群
particle_position = np.random.rand(n_particles, dim) * 10 - 5  # 初始位置
particle_velocity = np.random.rand(n_particles, dim) * 2 - 1  # 初始速度
pbest_position = particle_position.copy()  # 个体最优位置
pbest_value = np.full(n_particles, float('inf'))  # 个体最优值
gbest_value = float('inf')  # 全局最优值
gbest_position = np.array([float('inf'), float('inf')])  # 全局最优位置
# 迭代过程
for i in range(n_iterations):
    for j in range(n_particles):
        # 计算每个粒子的适应度值
        fitness = objective_function(particle_position[j])
        # 更新个体最优
        if fitness < pbest_value[j]:
            pbest_value[j] = fitness
            pbest_position[j] = particle_position[j].copy()
        # 更新全局最优
        if fitness < gbest_value:
            gbest_value = fitness
            gbest_position = particle_position[j].copy()
    for j in range(n_particles):
        # 更新速度
        particle_velocity[j] = (w * particle_velocity[j] + 
                                c1 * np.random.rand() * (pbest_position[j] - particle_position[j]) + 
                                c2 * np.random.rand() * (gbest_position - particle_position[j]))
        # 更新位置
        particle_position[j] += particle_velocity[j]
# 输出结果
print(f"全局最优位置:{gbest_position}")
print(f"全局最优值:{gbest_value}")
# 重新执行粒子群优化算法,进行5次迭代
# 重新初始化粒子位置和速度
particle_position = initial_particle_position.copy()  # 粒子位置
particle_velocity = np.random.rand(n_particles, dim) * 2 - 1  # 初始速度
pbest_position = particle_position.copy()  # 个体最优位置
pbest_value = np.full(n_particles, float('inf'))  # 个体最优值
gbest_value = float('inf')  # 全局最优值
gbest_position = np.array([float('inf'), float('inf')])  # 全局最优位置
# 执行5次迭代的过程
for _ in range(5):
    for j in range(n_particles):
        fitness = objective_function(particle_position[j][0], particle_position[j][1])
        if fitness < pbest_value[j]:
            pbest_value[j] = fitness
            pbest_position[j] = particle_position[j].copy()
        if fitness < gbest_value:
            gbest_value = fitness
            gbest_position = particle_position[j].copy()
    for j in range(n_particles):
        particle_velocity[j] = (w * particle_velocity[j] + 
                                c1 * np.random.rand() * (pbest_position[j] - particle_position[j]) + 
                                c2 * np.random.rand() * (gbest_position - particle_position[j]))
        particle_position[j] += particle_velocity[j]
# 创建3D图形
fig = plt.figure(figsize=(12, 6))
# 初始状态
ax1 = fig.add_subplot(1, 2, 1, projection='3d')
ax1.plot_surface(x, y, z, cmap='viridis', alpha=0.6)
ax1.scatter(initial_particle_position[:, 0], initial_particle_position[:, 1], 
            objective_function(initial_particle_position[:, 0], initial_particle_position[:, 1]), 
            color='r', s=10)
ax1.set_title('初始状态')
ax1.set_xlabel('X axis')
ax1.set_ylabel('Y axis')
ax1.set_zlabel('Z axis')
# 优化后的状态(5次迭代后)
ax2 = fig.add_subplot(1, 2, 2, projection='3d')
ax2.plot_surface(x, y, z, cmap='viridis', alpha=0.6)
ax2.scatter(particle_position[:, 0], particle_position[:, 1], 
            objective_function(particle_position[:, 0], particle_position[:, 1]), 
            color='r', s=10)
ax2.set_title('优化后的状态(5次迭代)')
ax2.set_xlabel('X axis')
ax2.set_ylabel('Y axis')
ax2.set_zlabel('Z axis')
plt.show()

最后,我分别可视化了粒子群优化算法初始状态和优化5轮后的状态,对比表明粒子群优化算法的效果。

图片[1]-粒子群算法(Particle Swarm Optimization)-VenusAI

  • 左图(初始状态):展示了目标函数的表面,并标记了初始化时粒子群的位置(红色点)。这些点代表粒子群初始时的随机分布。
  • 右图(优化后的状态 – 5次迭代):同样展示了目标函数的表面,并标记了经过5次迭代后粒子群的位置(红色点)。可以看到,粒子群的位置相比于初始状态有了明显的聚集,部分粒子开始靠近函数的最小值点(原点)。

这两幅图形象地说明了粒子群优化算法的工作原理:从随机搜索开始,经过多次迭代,粒子逐渐聚焦于搜索空间中的优化区域。虽然只进行了5次迭代,但我们已经可以看到粒子群朝着问题的最优解方向的逐渐聚集。随着更多迭代的进行,粒子群将更加集中地趋向于全局最优解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1671812.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

QX---mini51单片机学习---(9)中断系统

目录 1什么是中断 2中断系统在单片机系统中的作用 3如何使用单片机的中断系统 4实践 1什么是中断 RST P0想输出高电平接上拉电阻 2中断系统在单片机系统中的作用 3如何使用单片机的中断系统 可位寻址&#xff1a;IE中的EA可以直接&#xff0c;EA1&#xff1b; 外部中断&…

OSS证书自动续签,一分钟轻松搞定,解决阿里云SSL免费证书每3个月失效问题

文章目录 一、&#x1f525;httpsok-v1.11.0支持OSS证书自动部署介绍支持特点 二、废话不多说上教程&#xff1a;1、场景2、实战Stage 1&#xff1a;ssh登录阿里云 ECSStage 2&#xff1a;进入nginx &#xff08;docker&#xff09;容器Stage 3&#xff1a;执行如下指令Stage 3…

第五百零三回

文章目录 1. 概念介绍2. 使用方法2.1 普通路由2.2 命名路由 3. 示例代码4. 内容总结 我们在上一章回中介绍了"使用get显示Dialog"相关的内容&#xff0c;本章回中将介绍使用get进行路由管理.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1. 概念介绍 我们在本章…

【算法】滑动窗口——最小覆盖子串

本节博客是对“最小覆盖子串”题目由暴力求解到滑动窗口的思路解析&#xff0c;有需要借鉴即可。 目录 1.题目2.滑动窗口解法3.总结 1.题目 题目链接&#xff1a;LINK 这个题目是困难难度&#xff0c;感觉是一个中等题目的感觉。 首先我肯定想到的是暴力求解的方法&#xff…

Spring:@Async注解使用注意事项及九大失效场景

前言 原文作者&#xff1a;微信公众号&#xff1a;苏三说技术 场景举例 代码案例 点击此处可观看&#xff1a;Async注解使用注意事项及九大失效场景

7B2 PRO主题5.4.2 免授权开心版源码 | WordPress主题

简介&#xff1a; B2 PRO 5.4.2 最新免授权版不再需要改hosts&#xff0c;和正版一样上传安装就可以激活。 直接在WordPress上传安装即可 点击下载

DS:顺序表、单链表的相关OJ题训练(2)

欢迎各位来到 Harper.Lee 的学习世界&#xff01; 博主主页传送门&#xff1a;Harper.Lee的博客主页 想要一起进步的uu欢迎来后台找我哦&#xff01; 一、力扣--141. 环形链表 题目描述&#xff1a;给你一个链表的头节点 head &#xff0c;判断链表中是否有环。如果链表中有某个…

Spring框架概述

目录 1. Spring框架的起源 2. Spring框架的构成 3. Spring的发展历程 4. Spring的开发环境 4.1. Maven安装与配置 &#xff08;1&#xff09;Maven的下载与安装 &#xff08;2&#xff09;配置Maven的环境变量 &#xff08;3&#xff09;本地仓库的配置 &#xff08;4…

前端开发者必备:Nginx入门实战宝典,从部署到优化一网打尽

&#x1f525; 个人主页&#xff1a;空白诗 文章目录 引言 &#x1f44b;一、Nginx简介 &#x1f4da;二、常见的Web服务器架构 &#x1f300;&#x1f4cc; 架构概述&#x1f4cc; Nginx的深入探讨 三、正向代理与反向代理 &#x1f52e;&#x1f4cc; 正向代理工作原理&#…

synchronized 使用及实现原理

synchronized 关键字 如何使用 synchronized 关键字的使用方式主要有下面 3 种&#xff1a; 修饰实例方法 修饰静态方法 修饰代码块 1、修饰实例方法 &#xff08;锁当前对象实例&#xff09; 给当前对象实例加锁&#xff0c;进入同步代码前要获得 当前对象实例的锁 。 …

【opencv】图像处理(二)

前文指引 一、使用到的图片 一、梯度计算 原始图片 img cv2.imread(circle.jpg)plt.imshow(img) plt.show()sobel算子 使用两个核 Gx [[-1,0,1], [-2,0,2], [-1,0,1]] Gy [[-1,-2,-1], [0,0,0], [1,2,1]] dst cv2.Sobel(src, ddepth, dx, dy, ksize) ddepth 深度 -1d…

添砖Java之路(其四)——面向对象的编程,类和对象

目录 前言&#xff1a; 面向对象的编程&#xff1a; this关键字&#xff1a; 构造方法&#xff1a; 前言&#xff1a; 其实中间我还有很多地方没有去讲&#xff0c;因为我觉得里面的很多东西和c/c差不太多&#xff0c;就比如逻辑运算&#xff0c;方法重载&#xff0c;以及数…

庙算兵棋推演AI开发初探(4-调用AI模型)

前面讲了如何开展编写规则脚本型Agent&#xff08;智能体&#xff09;的方法&#xff0c;现在探究一下如何调用知识型&#xff08;一般而言的训练出的模型&#xff09;智能体的方法。 这次调用的是庙算平台的demo&#xff08;网址见图&#xff09; 下载了“知识强化学习型”…

详解依赖注入的三种方法以及遇到问题的解决

各位大佬光临寒舍&#xff0c;希望各位能赏脸给个三连&#xff0c;谢谢各位大佬了&#xff01;&#xff01;&#xff01; 目录 1.三种依赖注入的方法 1.属性注入 优点 缺点 2.构造方法注入 优点 缺点 3.Setter注入 优点 缺点 4.小结 2.依赖注入常见问题的解决 1…

全国防灾减灾日主题活动投稿我可算找对了投稿方法

作为一名社区公众人员,我深知对外信息宣传的重要性。特别是在全国防灾减灾日这样的特殊时刻,我们不仅要向居民普及防灾减灾知识,还要通过媒体将社区的活动和成果展示给更多人。然而,在投稿的过程中,我最初却遭遇了诸多挑战。 起初,我采用传统的邮箱投稿方式,将精心撰写的稿件发…

网页如何集成各社区征文活动

Helllo , 我是小恒 由于我需要腾讯云社区&#xff0c;稀土掘金以及CSDN的征文活动RSS&#xff0c;找了一下没发现&#xff0c;所以使用GET 请求接口对网页定时进行拉取清洗&#xff0c;甚至无意间做了一个简单的json格式API 最终网址:hub.liheng.work API:http://hub.liheng.wo…

ubuntu server 22.04.4 系统安装详细教程

本教程使用vmware workstation 17创建虚拟机进行安装演示&#xff0c;安装方式和真机安装没有区别。 1、下载镜像 下载ubuntu server版本系统镜像&#xff0c;官网下载地址&#xff1a;https://cn.ubuntu.com/download/server/step1 注意&#xff1a;自己下载时需要确认是否是…

向银行家应用程序添加日期

● 首先我们将下面图片上的时间更换成现在的时间 const now new Date(); const day now.getDate(); const month now.getMonth() 1; const year now.getFullYear(); const hour now.getHours(); const min now.getMinutes();labelDate.textContent ${day}/${month}/$…

从头开始学Spring—01Spring介绍和IOC容器思想

目录 1.Spring介绍 1.1Spring概述 1.2特性 1.3五大功能模块 2.IOC容器 2.1IOC思想 ①获取资源的传统方式 ②反转控制方式获取资源 ③DI 2.2IOC容器在Spring中的实现 ①BeanFactory ②ApplicationContext ③ApplicationContext的主要实现类 1.Spring介绍 1.1Sprin…

ASP.NET Web Api 如何使用 Swagger 管理 API

前言 Swagger 是一个开源的框架&#xff0c;支持 OpenAPI 规范&#xff0c;可以根据 API 规范自动生成美观的、易于浏览的 API 文档页面&#xff0c;包括请求参数、响应示例等信息&#xff0c;并且&#xff0c;Swagger UI 提供了一个交互式的界面&#xff0c;可以帮助我们快速…