粒子群算法实现之python

python实现粒子群算法


粒子群算法(PSO),又可以叫做鸟群算法,是学者观察模仿鸟群的行为而发展的一种智能搜索算法,和遗传算法一样,也是一种群智能算法。
总的来说,粒子群算法也是一种进化算法,粒子分布在空间中,粒子在空间中的坐标组成的向量可以看做成遗传算法中的个体,或者是鸟群中的一只鸟儿,初始的粒子群是由随机分布于空间中的各个粒子的组成的,转换成数学就是,由很多个列向量组成的矩阵,粒子群就是矩阵,粒子就是矩阵中的列向量。那么对于粒子群中的每个粒子的属性是什么呢?有三个属性:1,粒子在空间中的位置坐标;2,粒子移动的速度;3,粒子的位置坐标对应于所求的目标函数的函数值,也就是适应度值。粒子群中的粒子中适应度值最好的那个粒子的坐标就是目标函数的解。


那么粒子是如何进化的呢?上面讲了粒子有三个属性,在遗传算法中,个体的进化是根据适应度值来的,而粒子群算法中粒子的进化是根据粒子群中的其他粒子的位置,以及粒子本身的位置,还有粒子的速度决定的。我们知道粒子在空间中的位置坐标决定了粒子所对应的适应度值,粒子的位置坐标又取决于这个粒子在上次移动前,粒子的位置坐标和粒子的速度。而粒子移动前的位置坐标已知,那么粒子的速度又是什么决定的呢?我们来看看鸟群中鸟儿的迁徙规律,鸟儿在鸟群中的移动是受两个因素制约的,第一个,受这只鸟儿自己在成长过程中形成的经验制约,可以理解为这只鸟儿自己认为食物所在的位置,对应于粒子中就是,这个粒子在过去的多次的移动过程中,适应度值最好的时候的位置坐标,第二个,受鸟群中的首领的位置制约。有了这两个因素制约,这只鸟儿就可以决定移动的速度的大小和方向了。为了表示这两个因素的强弱,我们引入两个常数c1,c2,c1表示第一个因素的强度,c2表示第二个因素的强度,c1比c2较大时,粒子群收敛慢,c2比c1较大时,粒子群收敛快。下面是粒子的迁移公式


速度迁移公式:

v = w*v +c1*(pbest-pop)+c2*(gbest-pop)

w表示粒子过去的速度所占的权重,c1,c2表示上面所说的两个参数,gbest表示粒子过去所达到的最好的适应度值对应的位置,gbest表示粒子群中的首领过去达到过的最好的适应度值对应的位置,pop表示粒子当前的位置


位置迁移公式:

pop = pop+v (默认时间取1

pop表示粒子当前的位置,v表示粒子的速度
注意:由于粒子群算法没有遗传算法的交叉、变异等操作,所以粒子群算法的效率要比遗传算法高,但是由于迁移公式本身的关系,我们无法保证粒子在迁移的过程中跑到了边界的外面,所以要对粒子的速度上限和位置上限进行限制,这样可以有效的保证算法的收敛性。


下面是具体的例子:
求解函数f = x1**2+x2**2-x3**2+3*sin(x1*x2*x3),在坐标范围x~(-10,10) z~(-10,10) y~(-10,10)的范围中的最大值,以及最大值所对应的x1,x2,x3。
分析:粒子的位置即函数的解,也就是说一个粒子就是由1x3的列向量表示

  1. 算法:
  2. 初始化粒子群
  3. 循环:
  4. 粒子群速度迁移
  5. 粒子速度限制
  6. 粒子群位置迁移
  7. 粒子位置限制
  8. 更新粒子中最好的位置
  9. 直到粒子群迁移次数达到程序设置上限
  10. 结果分析

基于numpy(python2.7.9)的粒子群算法,程序运行结果:
这里写图片描述


适应度值迭代结果:
这里写图片描述

分析:
之前同样的目标函数,使用matlab实现的遗传算法,用时3.3秒左右,使用基于numpy的python实现的遗传算法,用时1.6秒左右,现在使用基于numpy的python实现的粒子群算法,用时1.2秒!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【iOS-Cocos2d游戏开发之十】添加粒子系统特效并解决粒子特效与Layer之间的坐标问题;

李华明Himi 原创,转载务必在明显处注明: 转载自 【黑米GameDev街区】 原文链接: http://www.himigame.com/iphone-cocos2d/472.html 一直以来Himi特别想在游戏中使用粒子系统,但是之前做J2me与Android中发现使用粒子做的效果都会造成游戏运行内存的一…

第十二讲:生成树概念及STP技术应用

在传统的交换网络中,设备通过单条链路进行连接,当某一个点或是某一个链路发生故障时可能导致网络无法访问,解决这种问题的办法是在网络中提供冗余链路,但是交换机网络中的冗余链路会产生广播风暴、MAC地址失效等现象,最…

粒子群算法及其改进

1 粒子群算法介绍 求解非线性最优化问题时,有一种比较常用的算法为智能体算法,这里我们介绍的粒子群算法就隶属于智能体算法。 粒子群算法是模拟鸟寻找食物:一群鸟在随机的搜索食物。在这个区域里只有一块食物,所有的鸟都不知道食…

系统发育树的生成与美化(MEGA7和iTOL)--1.MEGA7生成系统发育树

#小白学习生成系统发育树 1.序列准备-本文中的数据LOC号是在文献中的附件中所找到的,然后在Phytozome v13中逐个查找氨基酸序列,需要输入所查找的物种名称,以及基因号,如下图所示: 下滑看到蛋白质序列 然后将蛋白质序…

PCL 基于最小生成树(MST)获取单木骨架(粗)

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 提取的过程大体上分为两个部分:生成单木MST(最小生成树)以及基于该MST获取大致的骨架结构(线条)。 具体的计算过程如下所述: 1、首先应用Delaunay三角剖分来构造初始图。Delaunay三角剖分是MST计算的基础,因…

详解综合学习粒子群算法——CLPSO(附该文作者给出的matlab代码)

最近团队出了两篇基于CLPSO[1]的改进算法,这里根据自己的理解分析一下这个综合学习的算法,并将文章作者给出的源代码分享出来供大家学习:https://download.csdn.net/download/Bernard_S/12612817 (免费下载,本身就是从作者的主页搬…

进化算法之粒子群算法和Matlab实现(多维)

(粒子群算法进阶讲解传送门:(https://blog.csdn.net/DBLLLLLLLL/article/details/103036067) ) 前面一篇文章介绍了遗传算法,这里再介绍一种进化算法,称为粒子群算法。同遗传算法类似,粒子群算法也是仿照了…

粒子群算法及通过惯性权重和学习因子对其进行改进—MATLAB实现

本文的代码将放在最后,需要的小伙伴们可以免费获取哦!!! 不要忘记点赞加关注奥😋😋 文章目录 粒子群算法一、理论基础1、介绍2、核心公式3、图形直观解释 二、问题描述三、解题思路四、MATLAB实现1、参数设…

可查看其他用户聊天记录,ChatGPT 爆出大BUG

ChatGPT一经推出,迅速出圈,用户赞誉如云,“绝对改变世界”、“第四次工业革命的“火药桶”、“苍天啊,它咋啥都会,我失业了”,一时间 ChatGPT 成为完美的代言词。 然而近日,ChatGPT 遇到了大麻烦…

ChatGPT 和 Midjourney 将改变我们的生活,日常工作流程将完全改变并与这些新型工具集成

上周末我花了很多时间先玩 Open AI ChatGPT,然后玩 Midjourney。起初我笑了,然后我开始完全被各种可能性所困扰,然后我终于意识到了它的潜力,并开始将其用于更有成效的工作。 注意:我本可以用它来制作一个引人入胜的点击诱饵标题,但我没有. 这是我问 Open AI 聊天的第一…

博弈的意思_博弈是什么意思(博弈最通俗的解释)

国学智慧《鬼谷子》:在封闭和开合的状态中,达到自己想要的目的。 鬼谷子是一本智谋之书,里面主要讲述的就是在和别人博弈的时候,以什么样的心态和姿态,来达到自己想要的目的。也是为人处世,处世权谋之中,不可不读的一本书。鬼谷子这本书中的捭阖术,其中的道理也要灵活多…

你是伪民主式父母吗?

经常给青少年做咨询,发现一个有趣的现象,就是关于他们家庭的养育方式,孩子和父母的表述是不一样的,父母说他们是民主式的家长,给孩子尽量多的自由,不去过多管制;而孩子说自己的父母是特别专制和…

聪明人是怎么说话办事的?曾国藩这幅书法对联,两句话讲解透彻!

晚清名臣曾国藩的经典对联: “大处着眼,小处着手;群居守口,独居守心”! 曾国藩是第一等的聪明人,能在复杂的官场中生存,还能赢得会做人的美誉,关键在于他做到了两件事,一…

嵌入式为什么没有软件架构师?

点击上方“小麦大叔”,选择“置顶/星标公众号” 福利干货,第一时间送达 我从事嵌入式软件开发有6、7个年头,bsp,驱动,应用软件,android hall,framework等都有涉猎。平时除了关注嵌入式行业的发展…

总结一下进程是什么

1、我们常说的进程是什么? 进程(Process)是计算机中的程序关于某数据集合上的运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。 进程是程序的基本执的实体 2、进程状态 就绪状态 进程已获得除处…

Vue 方法中this指向 引起的祸端

可忽略 最近在写 vue 项目, 使用 总监封装 好的框架,遇到一个问题: vue 实例 methods 中的 方法在传递后,通过 函数名() 方式调用后, 其内部 this 竟然没有指向 window。当时就不服了&#xff…

PHP语言25周年,PHP是世界上最好的语言

1995年6月8日,PHP 1.0版本正式问世,目前已经更迭到7.4版本,PHP 8.0 Alpha1版本也有望于今年6月中旬发布。25周年之际,杜蕾斯官方微博发文庆祝:“#PHP语言25周年#不管PHP是不是世界上最好的语言,反正—— pr…

“5G 太耗电,关掉它!”

作者 | Carol 出品 | CSDN(ID:CSDNnews) 随着5G的普及,如今已经有很多手机用户已经体验到了5G的便捷了。无论国内外,从各大运营商及手机厂商向5G的投入中可见,5G的普及只不过是时间问题罢了。 但就在大家都…

Android App 耗电量统计

前言 在Android统计App耗电量比较麻烦,直至Android 4.4,它仍没公开“电量统计”API或文档……额,是的,仅没有公开,并不是没有。平时在手机“设置- 电量”看到的数据 就是系统调用内部API的统计结果。 基础概念 1. 手机…