改进萤火虫优化算法(python代码)

1.效果图

 2.改进萤火虫代码

import numpy as np
import matplotlib.pyplot as plt

def rastrigin(x):
    d = len(x)
    return 10*d + np.sum(x**2 - 10*np.cos(2*np.pi*x))

def firefly_algorithm(dim, fobj, nfireflies=20, alpha=0.5, betamin=0.2, gamma=1.0, lb=-5.12, ub=5.12, maxiter=100):
    
    X = np.random.uniform(lb, ub, (nfireflies, dim))
    I = np.array([fobj(x) for x in X])
    
    curve = np.zeros(maxiter)
    
    for t in range(maxiter):
        curve[t] = np.min(I)
        
        for i in range(nfireflies):
            for j in range(nfireflies):
                if I[j] < I[i]:
                    r = np.sqrt(np.sum((X[i]-X[j])**2))
                    beta = betamin + (1 - betamin)*np.exp(-gamma*r**2)
                    X[i] += alpha*beta*(X[j
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

深度学习的奋斗者

你的鼓励是我努力的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值