【PSO】Python 实现粒子群算法

粒子群算法原理很简单,用matlab和Python都很快实现编程。

程序:

参数部分,需要修改的可以修改。这个程序实现的是基本粒子群算法,对于提升粒子群算法的表现,

可以在上面进行更多的功能添加。


# coding: utf-8
import numpy as np  
import random   
import matplotlib.pyplot as plt  

#----------------------PSO参数设置---------------------------------  
class PSO():  
    def __init__(self,pN,dim,max_iter):  
        self.w = 0.8    
        self.c1 = 2     
        self.c2 = 2     
        self.r1= 0.6  
        self.r2=0.3  
        self.pN = pN                #粒子数量  
        self.dim = dim              #搜索维度  
        self.max_iter = max_iter    #迭代次数  
        self.X = np.zeros((self.pN,self.dim))       #所有粒子的位置和速度  
        self.V = np.zeros((self.pN,self.dim))  
        self.pbest = np.zeros((self.pN,self.dim))   #个体经历的最佳位置和全局最佳位置  
        self.gbest = np.zeros((1,self.dim))  
        self.p_fit = np.zeros(self.pN)              #每个个体的历史最佳适应值  
        self.fit = 1e10             #全局最佳适应值  
          
#---------------------目标函数Sphere函数-----------------------------  
    def function(self,x):  
        sum = 0  
        length = len(x)  
        x = x**2  
        for i in range(length):  
            sum += x[i]  
        return sum
#---------------------初始化种群----------------------------------  
    def init_Population(self):  
        for i in range(self.pN):  
            for j in range(self.dim):  
                self.X[i][j] = random.uniform(0,1)  
                self.V[i][j] = random.uniform(0,1)  
            self.pbest[i] = self.X[i]  
            tmp = self.function(self.X[i])  
            self.p_fit[i] = tmp  
            if(tmp < self.fit):  
                self.fit = tmp  
                self.gbest = self.X[i]  
      
#----------------------更新粒子位置----------------------------------  
    def iterator(self):  
        fitness = []  
        for t in range(self.max_iter):  
            for i in range(self.pN):         #更新gbest\pbest  
               temp = self.function(self.X[i])  
               if(temp<self.p_fit[i]):      #更新个体最优  
                   self.p_fit[i] = temp  
                   self.pbest[i] = self.X[i]  
                   if(self.p_fit[i] < self.fit):  #更新全局最优  
                       self.gbest = self.X[i]  
                       self.fit = self.p_fit[i]  
            for i in range(self.pN):  
                self.V[i] = self.w*self.V[i] + self.c1*self.r1*(self.pbest[i] - self.X[i]) + \
                            self.c2*self.r2*(self.gbest - self.X[i])  
                self.X[i] = self.X[i] + self.V[i]  
            fitness.append(self.fit)  
            print(self.fit)                   #输出最优值  
        return fitness  
 
#----------------------程序执行-----------------------  
my_pso = PSO(pN=30,dim=5,max_iter=100)  
my_pso.init_Population()  
fitness = my_pso.iterator()
#-------------------画图--------------------  
plt.figure(1)  
plt.title("Figure1")  
plt.xlabel("iterators", size=14)  
plt.ylabel("fitness", size=14)  
t = np.array([t for t in range(0,100)])  
fitness = np.array(fitness)  
plt.plot(t,fitness, color='b',linewidth=3)  
plt.show() 


计算结果:fitness = 8.64346866606e-07


================================================================

超参数优化PSO

https://github.com/numenta/hypersearch

带约束条件的PSO

https://github.com/tisimst/pyswarm

微调整探索过程的PSO

https://github.com/duaraghav8/Particle-Swarm-Optimization


  • 7
    点赞
  • 118
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要使用Python实现粒子群算法,你可以按照以下步骤进行操作: 1. 首先,创建一个Particle类来表示每个粒子。这个类应该具有初始化方法(init),其中包括粒子的维度(dim)、位置范围(minx和maxx)、当前位置(pos)、当前速度(vel)、个体最优位置(best_pos)和个体最优值(best_val)。可以参考上述的代码来实现这个类。 2. 然后,创建一个PSO类来表示粒子群算法。这个类应该具有初始化方法(init),其中包括粒子的维度(dim)、粒子群的大小(size)、迭代次数(iter_num)、最大速度(max_vel)、位置范围(minx和maxx)以及变异概率(pm)。可以参考上述的代码来实现这个类。 3. 在PSO类中,你需要定义一个run方法来执行粒子群算法的主要逻辑。在这个方法中,你需要创建一群粒子,并在每次迭代中更新每个粒子的速度和位置。你还需要更新每个粒子的个体最优位置和最优值,并记录全局最优位置和最优值。可以参考以下伪代码来实现这个方法: - 初始化一个空的粒子群列表。 - 创建size个粒子并添加到粒子群列表中。 - 初始化全局最优位置和最优值为第一个粒子的位置和值。 - 进入迭代循环,重复iter_num次: - 对于每个粒子: - 计算粒子的速度。 - 更新粒子的位置。 - 更新粒子的个体最优位置和最优值。 - 更新全局最优位置和最优值。 - 返回全局最优位置和最优值。 4. 最后,你可以在主函数(if __name__ == '__main__')中创建一个PSO对象,并调用run方法来运行粒子群算法。你需要提供适当的参数,例如维度、粒子群大小、迭代次数、最大速度、位置范围和变异概率。 通过以上步骤,你就可以用Python实现粒子群算法了。参考上述代码和中的示例来编写你自己的代码。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值