python实现粒子群算法


Posted in Python onOctober 15, 2020

粒子群算法

粒子群算法源于复杂适应系统(Complex Adaptive System,CAS)。CAS理论于1994年正式提出,CAS中的成员称为主体。比如研究鸟群系统,每个鸟在这个系统中就称为主体。主体有适应性,它能够与环境及其他的主体进行交流,并且根据交流的过程“学习”或“积累经验”改变自身结构与行为。整个系统的演变或进化包括:新层次的产生(小鸟的出生);分化和多样性的出现(鸟群中的鸟分成许多小的群);新的主题的出现(鸟寻找食物过程中,不断发现新的食物)。

PSO初始化为一群随机粒子(随机解)。然后通过迭代找到最优解。在每一次的迭代中,粒子通过跟踪两个“极值”(pbest,gbest)来更新自己。
在找到这两个最优值后,粒子通过下面的公式来更新自己的速度和位置。

python实现粒子群算法

python实现粒子群算法

i 表示第 i 个粒子, d 表示粒子的第 d 个维度。r1, r2 表示两个位于 [0, 1] 的随机数(对于一个粒子的不同维度,r1, r2 的值不同)。pbest[i] 是指粒子取得最高(低)适应度时的位置,gbest[i] 指的是整个系统取得最高(低)适应度时的位置。

实践

我们用 PSO 算法求解如下函数的最小值

python实现粒子群算法

可以在空间画出图像

python实现粒子群算法

下图是使用 5 个粒子的收敛情况

python实现粒子群算法

可以看到,fitness 在第 12 轮就几乎收敛到 -10.0。

下面是完整代码

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D


INF = 1e5

def plot_cost_func():
  """画出适应度函数"""
  fig = plt.figure()
  ax = Axes3D(fig)
  X = np.arange(-4, 4, 0.25)
  Y = np.arange(-4, 4, 0.25)
  X, Y = np.meshgrid(X, Y)
  Z = (X**2 + Y**2) - 10
  ax.plot_surface(X, Y, Z, rstride=1, cstride=1, cmap='rainbow')
  plt.show()

def fitness(x):
  return x[0]**2 + x[1]**2 - 10

class PSOSolver(object):
  def __init__(self, n_iter, weight=0.5, c1=2, c2=2, n_particle=5):
    self.n_iter = n_iter
    self.weight = weight
    self.c1 = c1
    self.c2 = c2
    self.n_particle = n_particle
    self.gbest = np.random.rand(2)
    # gbest 对应的函数值
    self.gbest_fit = fitness(self.gbest)
    # 将位置初始化到 [-5, 5]
    self.location = 10 * np.random.rand(n_particle, 2) - 5
    # 将速度初始化到 [-1, 1]
    self.velocity = 2 * np.random.rand(n_particle, 2) - 1
    self.pbest_fit = np.tile(INF, n_particle)
    self.pbest = np.zeros((n_particle, 2))
    # 记录每一步的最优值
    self.best_fitness = []
  
  def new_velocity(self, i):
    r = np.random.rand(2, 2)
    v = self.velocity[i]
    x = self.location[i]
    pbest = self.pbest[i]
    return self.weight * v + self.c1 * r[0] * (pbest - x) + \
        self.c2 * r[1] * (self.gbest - x)

  def solve(self):
    for it in range(self.n_iter):
      for i in range(self.n_particle):
        v = self.new_velocity(i)
        x = self.location[i] + v
        fit_i = fitness(x)
        if fit_i < self.pbest_fit[i]:
          self.pbest_fit[i] = fit_i
          self.pbest[i] = x
          if fit_i < self.gbest_fit:
            self.gbest_fit = fit_i
            self.gbest = x
        self.velocity[i] = v
        self.location[i] = x
      self.best_fitness.append(self.gbest_fit)

  
if __name__ == '__main__':
  plot_cost_func()
  n_iter = 20
  s = PSOSolver(n_iter)
  s.solve()
  print(s.gbest_fit)
  plt.title("Fitness Curve")
  plt.xlabel("iter")
  plt.ylabel("fitness")
  plt.plot(np.arange(n_iter), np.array(s.best_fitness))
  plt.show()

以上就是python实现粒子群算法的详细内容,更多关于python 粒子群算法的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python运算符重载用法实例
May 28 Python
python开发之基于thread线程搜索本地文件的方法
Nov 11 Python
python实现壁纸批量下载代码实例
Jan 25 Python
Python实现Pig Latin小游戏实例代码
Feb 02 Python
利用scrapy将爬到的数据保存到mysql(防止重复)
Mar 31 Python
Python使用Flask-SQLAlchemy连接数据库操作示例
Aug 31 Python
python读取各种文件数据方法解析
Dec 29 Python
pyqt5 QScrollArea设置在自定义侧(任何位置)
Sep 25 Python
Python namedtuple命名元组实现过程解析
Jan 08 Python
2020新版本pycharm+anaconda+opencv+pyqt环境配置学习笔记,亲测可用
Mar 24 Python
Python爬虫爬取全球疫情数据并存储到mysql数据库的步骤
Mar 29 Python
Matplotlib绘制混淆矩阵的实现
May 27 Python
如何将anaconda安装配置的mmdetection环境离线拷贝到另一台电脑
Oct 15 #Python
Python3.7安装PyQt5 运行配置Pycharm的详细教程
Oct 15 #Python
python利用faker库批量生成测试数据
Oct 15 #Python
如何利用python检测图片是否包含二维码
Oct 15 #Python
用python实现一个简单计算器(完整DEMO)
Oct 14 #Python
python在linux环境下安装skimage的示例代码
Oct 14 #Python
python中如何使用虚拟环境
Oct 14 #Python
You might like
php 仿Comsenz安装效果代码打包提供下载
2010/05/09 PHP
PHP字符串的连接的简单实例
2013/12/30 PHP
ThinkPHP中Session用法详解
2014/11/29 PHP
php实现发送微信模板消息的方法
2015/03/07 PHP
php简单获取文件扩展名的方法
2015/03/24 PHP
下载网站打开页面后间隔多少时间才显示下载链接地址的代码
2010/04/25 Javascript
调试Node.JS的辅助工具(NodeWatcher)
2012/01/04 Javascript
js 表单提交后按钮变灰的实例代码
2013/08/16 Javascript
node.js中的fs.fchownSync方法使用说明
2014/12/16 Javascript
javascript显式类型转换实例分析
2015/04/25 Javascript
Jquery和angularjs获取check框选中的值的方法汇总
2016/01/17 Javascript
详解Wondows下Node.js使用MongoDB的环境配置
2016/03/01 Javascript
jQuery常用的一些技巧汇总
2016/03/26 Javascript
使用plupload自定义参数实现多文件上传
2016/07/19 Javascript
Django+Vue.js搭建前后端分离项目的示例
2017/08/07 Javascript
微信小程序 页面跳转事件绑定的实例详解
2017/09/20 Javascript
通过源码分析Vue的双向数据绑定详解
2017/09/24 Javascript
JS实现点击按钮可实现编辑功能
2018/07/03 Javascript
JS实现将二维数组转为json格式字符串操作示例
2018/07/12 Javascript
Node.js从字符串生成文件流的实现方法
2019/08/18 Javascript
[46:28]EG vs Liquid 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.23
2019/09/05 DOTA
Python3读取文件常用方法实例分析
2015/05/22 Python
python 自动批量打开网页的示例
2019/02/21 Python
Python基础学习之基本数据结构详解【数字、字符串、列表、元组、集合、字典】
2019/06/18 Python
python实现翻译word表格小程序
2020/02/27 Python
浅谈keras中loss与val_loss的关系
2020/06/22 Python
pycharm 多行批量缩进和反向缩进快捷键介绍
2021/01/15 Python
印尼旅游网站:via
2017/11/12 全球购物
L*SPACE官网:比基尼、泳装和度假服装
2019/03/18 全球购物
优秀求职信范文分享
2013/12/19 职场文书
四年大学自我鉴定
2014/02/17 职场文书
艺术学院毕业生自荐信
2014/07/05 职场文书
小学生竞选班干部演讲稿(5篇)
2014/09/12 职场文书
初中信息技术教学计划
2015/01/22 职场文书
大学四年个人总结
2015/03/03 职场文书
单位接收证明格式
2015/06/18 职场文书