萤火虫优化算法(Firefly Algorithm)

news2024/11/16 13:04:49

注意:本文引用自专业人工智能社区Venus AI

更多AI知识请参考原站 ([www.aideeplearning.cn])

算法背景

萤火虫优化算法,是由剑桥大学的Xin-She Yang在2009年提出的一种基于群体智能的优化算法。它的灵感来源于萤火虫在夜晚闪烁发光的行为。在自然界中,萤火虫通过发光来吸引配偶或猎物,而且通常光线越亮,越能吸引其他萤火虫。 想象一下,在一个夏夜的草地上,成群的萤火虫在草尖上闪烁着光芒。每只萤火虫都试图飞向光线更亮的同伴,因为在它们看来,光亮代表着更佳的配偶或更丰富的食物。这个场景就是萤火虫算法的微缩模型:每只萤火虫代表一个潜在的解决方案,而它们相互间的吸引就是寻找最优解的过程。

萤火虫优化算法的核心思想是模拟自然界中萤火虫的行为特点,主要包括以下几个关键点:

  1. 亮度(吸引力):在萤火虫算法中,每只萤火虫的亮度代表着它的优化目标函数值。在优化问题中,这可以是函数的最大值或最小值。亮度越高的萤火虫,代表着更优的解决方案。
  2. 吸引和移动:萤火虫会被周围更亮的萤火虫所吸引,并朝着更亮的萤火虫移动。这意味着每只萤火虫会根据周围的“最佳”解决方案来调整自己的位置。在优化过程中,这就是搜索空间中的移动过程。
  3. 光度衰减:自然界中,光线的强度会随着距离的增加而减弱。在算法中,这被模拟为吸引力随距离而减弱。这意味着,只有在较近的距离内,萤火虫之间才会有较强的相互吸引力。
  4. 随机行为:萤火虫的移动不仅仅由吸引力引导,还包含一定的随机性。这有助于算法探索更广阔的搜索空间,避免陷入局部最优解。

通过这种方式,萤火虫群体逐渐聚集到最亮的点,即问题的最优解。萤火虫算法的优势在于它的简单性和能够有效避免局部最优解的能力,特别适用于复杂的优化问题。

算法应用

萤火虫算法的应用领域主要包括:

  1. 工程优化:在工程设计和优化中,比如机械设计、结构优化、电气系统设计等,萤火虫算法可以用来寻找最优的设计参数,以达到成本最低、性能最佳等目标。
  2. 机器学习:在机器学习领域,萤火虫算法可以用于特征选择和算法调优。它可以帮助识别出最重要的特征,或者找到最佳的算法参数。
  3. 调度问题:在生产调度和任务调度问题中,萤火虫算法可以帮助找到最优的任务安排方案,以减少时间和成本。
  4. 网络设计:在通信网络和计算机网络设计中,萤火虫算法可以用于寻找最佳的网络布局和资源分配方案。
  5. 组合优化问题:比如旅行商问题(TSP),萤火虫算法可以帮助找到最短的路径,以解决复杂的组合优化问题。
  6. 环境模型和优化:在环境科学中,萤火虫算法可以用来模拟和优化环境系统,比如水资源管理、污染控制等。

算法计算流程

萤火虫优化算法的计算流程通常包括以下几个步骤:

  1. 初始化:生成初始的萤火虫群体。每个萤火虫代表一个潜在的解,并且有一个与之相关的亮度,通常是由优化问题的目标函数决定的。
  2. 亮度评估:计算每个萤火虫的亮度。在最简单的形式中,亮度可以直接等于目标函数的值。在其他情况下,可能需要对目标函数值进行转换或调整。
  3. 移动萤火虫:根据其他萤火虫的亮度更新萤火虫的位置。每个萤火虫会向更亮的萤火虫移动,移动的方式可以是简单的向量加法。移动的距离可以取决于两个萤火虫之间的距离和亮度差。
  4. 光吸收:由于光的传播,亮度会随着距离的增加而减少。这通常通过一个衰减系数来模拟,它决定了亮度如何随距离减少。
  5. 更新和迭代:根据新的位置更新萤火虫的亮度。重复步骤3和4,直到满足停止准则,比如达到预定的迭代次数或解的质量。
  6. 选择最优解:在所有迭代完成后,选择亮度最高(或根据问题设定,可能是最低)的萤火虫所代表的解作为最终解。

我们可以使用萤火虫优化算法来优化函数 f(x,y)=x^2+y^2,这是一个典型的优化问题,其目标是找到使 f(x,y) 最小的 x 和 y 的值。在这个例子中,最优解显然是 x=0 和 y=0 。

让我们通过一个简化的例子来手动演示一轮迭代的过程:

初始设置
– 假设营火虫 A 的初始位置为(x_A,y_A)=(1,2) ,其函数值f_A=1^2+2^2=5 。
– 假设萤火虫 B 的初始位置为(x_B,y_B)=(2,3),其函数值 f_B=2^2+3^2=13 。

计算亮度
– 因为我们希望最小化函数,所以亮度可以用 1/f(x,y) 表示(为了避免除以零的情况,我们可以使用1/(1+f(x,y)) 。
– 因此,萤火虫 A 的亮度为 L_A=1/(1+5)=1/6,萤火虫 B 的亮度为 LB= 1/(1+13)=1/14 。

移动萤火虫
由于 B 比 A 更暗,B 将朝着 A 移动。移动的距离取决于亮度差和距离。萤火虫 B 向 A 移动的距离可以通过以下公式计算:


其中:
– β 是吸引力的基础值,通常设置为一个常数,例如 1 。
– γ 是光强衰减系数,它决定了亮度随距离减少的速率。
– 距离是两个茧火虫之间的欧几里得距离。

让我们使用此公式来计算 B 向 A 移动的新位置。首先,我们需要计算 A 和 B 之间的距离:

– 距离d=\sqrt{(x_B-x_A)^2+(y_B-y_A)^2}

应用移动公式计算得分B的新位置:
– 假设 β=1 和 γ=1 (这些值通常是根据问题和实验结果来调整的)。

根据萤火虫优化算法的计算公式,我们得到 B 的新位置为大约 (1.865,2.865) 。

结果比较
– 初始的 f_B=13 ,更新后的f_{B}^{\prime}=11.7。这证明了经过一轮迭代后,萤火虫 B 的位置更接近最优解,因为函数值减小了。

代码实现

下面,我们来实现一个简化版的萤火虫优化算法。假设我们有一个问题需要解决,比如寻找一个函数的最大值。每只萤火虫代表了搜索空间中的一个潜在解决方案,而它们的亮度则代表了解决方案的好坏(在我们的例子中,函数值越高,亮度越亮)。


import numpy as np
class FireflyAlgorithm():
    def __init__(self, n_fireflies, dim, alpha, beta, gamma, objective_function):
        self.n_fireflies = n_fireflies
        self.dim = dim
        self.alpha = alpha
        self.beta = beta
        self.gamma = gamma
        self.objective_function = objective_function
        self.fireflies = np.random.rand(n_fireflies, dim)
        self.light_intensity = np.zeros(n_fireflies)
    def update_light_intensity(self):
        for i in range(self.n_fireflies):
            self.light_intensity[i] = self.objective_function(self.fireflies[i])
    def move_firefly(self, i, j):
        r = np.linalg.norm(self.fireflies[i] - self.fireflies[j])
        attractiveness = self.beta * np.exp(-self.gamma * r ** 2)
        self.fireflies[i] += attractiveness * (self.fireflies[j] - self.fireflies[i]) + self.alpha * (np.random.rand(self.dim) - 0.5)
    def optimize(self, max_generations):
        for _ in range(max_generations):
            self.update_light_intensity()
            for i in range(self.n_fireflies):
                for j in range(self.n_fireflies):
                    if self.light_intensity[j] > self.light_intensity[i]:
                        self.move_firefly(i, j)
# 示例目标函数
def objective_function(x):
    return -np.sum(x**2)
# 算法参数
n_fireflies = 40
dim = 2
alpha = 0.5
beta = 1.0
gamma = 1.0
max_generations = 100
# 执行优化
fa = FireflyAlgorithm(n_fireflies, dim, alpha, beta, gamma, objective_function)
fa.optimize(max_generations)
# 找到的最佳解
best_firefly_index = np.argmax(fa.light_intensity)
best_solution = fa.fireflies[best_firefly_index]
best_value = fa.light_intensity[best_firefly_index]
print("最佳解:", best_solution)
print("最佳值:", best_value)

请可视化初始化状态与训练后的状态做对比,结果如下:

图片[1]-萤火虫优化算法(Firefly Algorithm)-VenusAI

这幅图展示了萤火虫算法在初始化状态(左图)和训练后状态(右图)的对比。在初始化状态下,萤火虫(红色点)随机分布在搜索空间中。经过训练(迭代优化)之后,我们可以看到萤火虫(蓝色点)聚集在了函数值最高的区域,即我们的目标函数的最大值附近。这清晰地展示了萤火虫算法是如何从随机分布逐渐向最优解聚集的过程。通过这样的可视化,我们能够直观地理解算法的工作原理和效果。 ​

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python | Leetcode Python题解之第83题删除排序链表中的重复元素

题目: 题解: class Solution:def deleteDuplicates(self, head: ListNode) -> ListNode:if not head:return headcur headwhile cur.next:if cur.val cur.next.val:cur.next cur.next.nextelse:cur cur.nextreturn head

PDF文件恢复:四种实用方法全解析

如何恢复已删除的PDF文件? PDF是Portable Document Format(便携式文档格式)的缩写,是一种由Adobe Systems开发的文件格式。PDF文件可以包含文本、图形、链接、多媒体以及其他各种元素,并且能够在各种操作系统和设备上…

XXE-lab靶场搭建

源码下载地址 https://github.com/c0ny1/xxe-lab1.php_xxe 直接放在php web页面下即可运行。 2.java_xxe java_xxe是serlvet项目,直接导入eclipse当中即可部署运行。 3.python_xxe: 安装好Flask模块python xxe.py 4.Csharp_xxe 直接导入VS中运行 phpstudy…

树莓派遇到ping的奇葩问题解决办法

首先,先 ping raspberrypi 一下。获得树莓派的ip 然后开始配置静态ip winR后输入命令ipconfig查询当前网关ip 输入命令sudo nano /etc/dhcpcd.conf 在最末尾输入以下信息 -----------------------------------------------------------------------------------…

波动性悖论:为何低风险股票长期跑赢高风险对手?

从去年开始,“红利低波”类的产品净值稳步向上,不断新高,让很多人关注到了A股“分红高”、“波动率低”这两类股票。分红高的公司更受投资者青睐,这从基本面的角度很容易理解,那么波动率低的股票明明波动更小&#xff…

8、QT——QLabel使用小记2

前言:记录开发过程中QLabel的使用,持续更新ing... 开发平台:Win10 64位 开发环境:Qt Creator 13.0.0 构建环境:Qt 5.15.2 MSVC2019 64位 一、基本属性 技巧:对于Qlabel这类控件的属性有一些共同的特点&am…

使用html和css实现个人简历表单的制作

根据下列要求,做出下图所示的个人简历(表单) 表单要求 Ⅰ、表格整体的边框为1像素,单元格间距为0,表格中前六列列宽均为100像素,第七列 为200像素,表格整体在页面上居中显示; Ⅱ、前…

猜猜歇后语

页面 在输入框中填写你猜的答案,点击“显示答案”按钮,显示正确答案。 页面代码 function showAnswer(element){var elem$(element);elem.next().show();} //# // 初始化DataGrid对象 $(#dataGrid).dataGrid({searchForm: $(#searchForm),columnModel:…

Django性能之道:缓存应用与优化实战

title: Django性能之道:缓存应用与优化实战 date: 2024/5/11 18:34:22 updated: 2024/5/11 18:34:22 categories: 后端开发 tags: 缓存系统Redis优点Memcached优缺点Django缓存数据库优化性能监控安全实践 引言 在当今的互联网时代,用户对网站和应用…

Virtualbox7.0.10+Ubuntu20.04网络配置

虚拟机部署在服务器上时,需要进行网络配置,使虚拟机和服务器在同网段下,以保证内网的终端可以访问到虚拟机 1. 设置虚拟机 打开虚拟机设置,选择“网络”,将网卡设为桥接网卡 注:设置前,需要先…

JavaScript 防抖与节流——以游戏智慧解锁实战奥秘

🔥 个人主页:空白诗 文章目录 🎮 引言❓ 什么是防抖和节流🏹 防抖(Debounce) - 锁定追击,精确无误📌 基础概念📌 适用场景📌 实战代码:防抖 应用于输入框的实时搜索 &…

FANUC机器人工具坐标偏移的用法

一、工具坐标偏移的使用场景 在机器人位置不改变的情况下,工业机器人使用默认工具坐标系示教的一系列运动点位,要保持原本点位位置不变的情况下,改变机器人工具坐标的参数,就要用到机器人坐标转化的功能。在FANUC机器人上体现为机…

基于Django实现的校园疫情监控平台

基于Django实现的校园疫情监控平台 开发语言:Python 数据库:MySQL所用到的知识:Django框架工具:pycharm、Navicat、Maven 系统功能实现 登录注册功能 用户在没有登录自己的用户名之前只能浏览本网站的首页,想要使用其他功能都会…

百度GL地图实现某一段路的路况(new BMapGL.DrivingRouteLine)

功能描述: 1.百度地图实现点击地图出现起点,再次点击出现终点(起点终点能拖动)绘制完终点后获取该路的路况并且起点和终点可以拖动实现实时更新(新绘制的路段的)路况 2.地点搜索 效果如下: 关键…

Python计算器程序代码

from tkinter import * import random class App: def __init__(self, master): self.master master self.initwidgets() #表达式的值 self.expr None def initwidgets(self): #定义一个输入组件 self.show Label(relief SUNKEN, font (Courier New, 24), width 25, bg …

taro3兼容支付宝/微信小程序的自定义拖拽排序组件

描述:列表可以完成拖拽排序 此组件是根据支付宝原生文档改编成taro-vue3的形式,只保留了拖拽的部分,其他功能都去除了,测试下来可以兼容支付宝和微信小程序。 支付宝原生文档: https://opendocs.alipay.com/support/…

0X JavaSE-- UML、

# Unified Modeling Language UML 统一建模语言 UML 是一种图形化的语言。 UML 不是专门为 Java 准备的。 只要是面向对象的编程语言,开发前的设计,都需要画 UML 图进行系统设计。 最常用的四个 UML 图是 类图(Class Diagram)&…

【JavaEE】Maven简介与实用指南:项目构建和依赖管理的高效工具

目录 Maven什么是 Maven为什么学 Maven创建一个Maven项目依赖传递依赖排除 Maven 仓库本地仓库中央仓库私服 Maven设置国内源配置当前项⽬setting设置新项⽬的setting Maven 什么是 Maven 官⽅对于 Maven 的描述: Maven 是⼀个项⽬管理⼯具。基于 POM(Project Object Model,…

RS3236-ADJ8YF5功能和参数介绍及PDF资料

RS3236-ADJ8YF5功能和参数介绍及PDF资料-公司新闻-配芯易-深圳市亚泰盈科电子有限公司 品牌: RUNIC(润石) 封装: SOT-23-5 描述: 输出电压可调(参考电压0.81V),Iout500mA(Max),Vin7.5V(Max),带过温保护 输出类型: 可调 最大输入电压: 7.5V 输出电压: 810mV~6.6V 最大输出电流…

C语言学习(九)多文件编程 存储类型 结构体

目录 一、多文件编程(一)不写头文件的方方式进行多文件编程 (二)通过头文件方式进行多文件编程(1)方法(2)头文件守卫 (三) 使用多文件编程实现 - * / 功能 二…