python实现粒子群算法
作者:农大鲁迅 发布时间:2021-03-20 02:27:34
标签:python,粒子群,算法
粒子群算法
粒子群算法源于复杂适应系统(Complex Adaptive System,CAS)。CAS理论于1994年正式提出,CAS中的成员称为主体。比如研究鸟群系统,每个鸟在这个系统中就称为主体。主体有适应性,它能够与环境及其他的主体进行交流,并且根据交流的过程“学习”或“积累经验”改变自身结构与行为。整个系统的演变或进化包括:新层次的产生(小鸟的出生);分化和多样性的出现(鸟群中的鸟分成许多小的群);新的主题的出现(鸟寻找食物过程中,不断发现新的食物)。
PSO初始化为一群随机粒子(随机解)。然后通过迭代找到最优解。在每一次的迭代中,粒子通过跟踪两个“极值”(pbest,gbest)来更新自己。
在找到这两个最优值后,粒子通过下面的公式来更新自己的速度和位置。
i 表示第 i 个粒子, d 表示粒子的第 d 个维度。r1, r2 表示两个位于 [0, 1] 的随机数(对于一个粒子的不同维度,r1, r2 的值不同)。pbest[i] 是指粒子取得最高(低)适应度时的位置,gbest[i] 指的是整个系统取得最高(低)适应度时的位置。
实践
我们用 PSO 算法求解如下函数的最小值
可以在空间画出图像
下图是使用 5 个粒子的收敛情况
可以看到,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()
来源:https://www.jianshu.com/p/a79a3d7be8cc


猜你喜欢
- 一、条件控制Python条件语句是通过一条或多条语句的执行结果(True或者False)来决定执行的代码块,而计算机很多自动化任务,也是根据
- 守护进程主进程创建子进程目的是:主进程有一个任务需要并发执行,那开启子进程帮我并发执行任务主进程创建子进程,然后将该进程设置成守护自己的进程
- vue动态绑定class练习。:class=“{ ‘类名1':条件表达式,‘类名2':条件表达式… }”<templa
- 今天打算通过绘制正弦和余弦函数,从默认的设置开始,一步一步地调整改进,让它变得好看,变成我们初高中学习过的图象那样。通过这个过程来学习如何进
- 本文实例讲述了PHP实现无限极分类的两种方式。分享给大家供大家参考,具体如下:面试的时候被问到无限极分类的设计和实现,比较常见的做法是在建表
- 一、显示信息的命令代码如下:<!DOCTYPE html><html><head><title&g
- 前言:MySQL 的二进制日志 binlog 可以说是 MySQL 最重要的日志,它记录了所有的 DDL 和 DML 语句(除了数据查询语句
- 本文实例讲述了Python实现115网盘自动下载的方法。分享给大家供大家参考。具体实现方法如下:实例中的1.txt,是网页http://bb
- 在写代码的时候,往往会漏掉日志这个关键因素,导致功能在使用的时候出错却无法溯源。其实,只需要写一个非常简单的日志装饰器,我们就能大大提升排查
- 参考阅读:https://www.jb51.net/article/169285.htm代码:set objTTS = createobje
- 一、注册自定义指令以下实例都是实现一个输入框自动获取焦点的自定义指令。1.1、全局自定义指令在vue2中,全局自定义指令通过 directi
- 前言在《Python中if语句的使用方法》中提到,对于一种可能性、两种可能性或者多种可能性的情况,可以通过if语句来实现。而用if语句实现多
- 1、查看数据库中有哪些用户? select username from all_users;
- 有时候想同时(同级)展示多个视图,而不是嵌套展示,例如创建一个布局,有 sidebar(侧导航) 和 main(主内容) 两个视图,这个时候
- 直方图处理直方图从图像内部灰度级的角度对图像进行表述从直方图的角度对图像进行处理,可以达到增强图像显示效果的目的。直方图的含义直方图是图像内
- openlayer是目前我们gis常用的一款开源的,并且反馈都特别好的软件了,像之前的ol3, 风靡一时,地图实现也很简单,很实用,目前vu
- 本文以Python3.8为例1、 compileall py文件转换为pyc1.1、compileall命令行模式不需要额外安装,pytho
- 本文实例讲述了python自定义类并使用的方法。分享给大家供大家参考。具体如下:class Person: def __init
- 本文实例讲述了Java使用JDBC连接数据库的实现方法,是Java数据库程序设计里非常实用的重要技巧。分享给大家供大家参考。具体如下:JDB
- 装饰器通用模型def wrapper(fn): def inner(*args, **kwargs):