【WOA】鲸鱼优化算法详细解读

news2025/1/12 3:51:06

鲸鱼优化算法的详细解读

目录

一、引言

二、鲸鱼优化算法的原理

三、鲸鱼优化算法的主要步骤

四、鲸鱼优化算法的特点

五、Python代码实现


一、引言

在当今的优化问题中,随着问题复杂性的增加,传统的优化方法往往难以找到全局最优解。近年来,基于自然界动物行为的优化算法越来越受到研究者的关注。鲸鱼优化算法(Whale Optimization Algorithm, WOA)便是其中一种新兴的群体智能优化算法,它模拟了鲸鱼群体的捕食行为,具有较强的全局搜索能力和较快的收敛速度。本文将详细解读鲸鱼优化算法的原理、步骤,并通过Python代码展示其实现过程。

二、鲸鱼优化算法的原理

鲸鱼优化算法是由Mirjalili在2016年提出的一种全局优化算法,它受到鲸鱼捕食行为的启发。鲸鱼在捕食过程中,会采取包围猎物、狩猎和搜索猎物的行为。鲸鱼优化算法正是基于这些行为,通过模拟鲸鱼的群体活动来寻找问题的最优解。

三、鲸鱼优化算法的主要步骤

  1. 初始化

在算法开始时,需要为每个鲸鱼设定一个初始位置,并生成初始种群。这些鲸鱼个体代表了解空间中的潜在最优解。设种群大小为N,解空间的维度为D,则每个鲸鱼可以表示为一个D维的向量。

  1. 包围猎物

鲸鱼会向最优位置的鲸鱼或随机选择的鲸鱼靠近,这个过程可以模拟鲸鱼包围猎物的行为。位置更新公式如下:

X(t+1)=X(t)+r⋅(X∗−X(t))

其中,X(t)表示当前鲸鱼的位置,X∗表示最优鲸鱼的位置,r是一个介于[-1,1]之间的随机数。

  1. 狩猎行为

在狩猎阶段,鲸鱼会根据当前最优解的位置和其自身的位置进行螺旋式搜索。位置更新公式为:

X(t+1)=X∗−A⋅D1​⋅eb⋅l⋅cos(2πl)

其中,A和C是系数向量,D1​=∣C⋅X∗−X(t)∣表示当前鲸鱼与最优鲸鱼之间的距离,b是一个常数,用于控制螺旋的形状,l是在[-1,1]之间的随机数。

  1. 搜索猎物

当鲸鱼个体离最优解较远时,它们会在整个解空间进行随机搜索。位置更新公式如下:

X(t+1)=Xrand​−A⋅D2​⋅eb⋅l⋅cos(2πl)

其中,Xrand​是随机选择的鲸鱼位置,D2​=∣C⋅Xrand​−X(t)∣表示当前鲸鱼与随机鲸鱼之间的距离。

  1. 评估与更新

每当鲸鱼移动后,都会计算其适应度值。如果新的位置具有更好的适应度值,则更新当前最优解。

  1. 迭代与终止

鲸鱼优化算法会进行多次迭代,直到满足终止条件(如达到最大迭代次数或找到满足精度要求的最优解)为止。

四、鲸鱼优化算法的特点

  1. 全局搜索能力强:通过模拟鲸鱼的捕食行为,算法能够在整个解空间中进行有效的搜索。
  2. 收敛速度快:鲸鱼优化算法通过包围猎物、狩猎和搜索猎物的行为,能够迅速逼近全局最优解。
  3. 对初始值不敏感:由于算法采用群体智能的思想,因此不依赖于初始值的选取。

五、Python代码实现

以下是一个目标函数(以Rosenbrock函数为例)示例,展示了鲸鱼优化算法的实现过程:

import numpy as np  
  
# Rosenbrock函数作为目标函数  
def rosenbrock(x):  
    return 100 * (x[1] - x[0] ** 2) ** 2 + (1 - x[0]) ** 2  
  
# 鲸鱼优化算法实现  
def whale_optimization_algorithm(fitness_func, lb, ub, dimension, population_size=30, iterations=1000):  
    # 初始化鲸鱼种群  
    whales = np.random.uniform(lb, ub, (population_size, dimension))  
    fitness = np.apply_along_axis(fitness_func, 1, whales)  
    best_whale_index = np.argmin(fitness)  
    best_whale_position = whales[best_whale_index]  
    best_fitness = fitness[best_whale_index]  
      
    a, b, l = 2, 1, (a - 1) / iterations  # 初始化参数  
      
    for t in range(iterations):  
        for i in range(population_size):  
            r1 = np.random.random()  # 随机数r1  
            r2 = np.random.random()  # 随机数r2  
            A = 2 * a * r1 - a  # 线性减小a的值  
            C = 2 * r2  
            p = np.random.random()  # 随机数p  
            b1 = 1  # 定义形状参数b  
            l = (a - 1) * np.exp(-b1 * t / iterations)  # 螺旋形状参数  
              
            if p < 0.5:  
                if abs(A) >= 1:  
                    rand_leader_index = np.random.randint(0, population_size)  
                    X_rand = whales[rand_leader_index]  
                    D_X_rand = abs(C * X_rand - whales[i])  
                    whales[i] = X_rand - A * D_X_rand  
                else:  
                    D_1 = abs(C * best_whale_position - whales[i])  
                    whales[i] = best_whale_position - A * D_1  
            else:  
                D_2 = abs(best_whale_position - whales[i])  
                whales[i] = best_whale_position + D_2 * np.exp(b * l) * np.cos(2 * np.pi * l)  
                  
            # 更新适应度值  
            fitness[i] = fitness_func(whales[i])  
            if fitness[i] < best_fitness:  
                best_fitness = fitness[i]  
                best_whale_position = whales[i]  
                  
        a -= l  # 更新a值  
          
        # 打印最优解信息(可选)  
        if t % 100 == 0:  
            print(f'Iteration {t}, Best Fitness: {best_fitness}, Best Position: {best_whale_position}')  
              
    return best_whale_position, best_fitness  
  
# 设置参数并运行算法  
lb = -5  # 变量下界  
ub = 10  # 变量上界  
dimension = 2  # 变量维度  
population_size = 30  # 种群大小  
iterations = 1000  # 迭代次数  
best_position, best_fitness = whale_optimization_algorithm(rosenbrock, lb, ub, dimension, population_size, iterations)  
print(f'Optimal solution: {best_position}, Fitness: {best_fitness}')

上述代码实现了鲸鱼优化算法,并使用Rosenbrock函数作为目标函数进行优化。可以运行这段代码来查看算法如何找到Rosenbrock函数的最小值。

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

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

相关文章

【计算机毕业设计】​720图书馆智能选座系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

仓库物品与装备物品替换

思路 1、创建UI面板以承载仓库中的物品和已装备的物品&#xff0c;以及物品名称和物品描述&#xff1b; 2、创建ItemData.cs装载物品的缩略图、描述并创建ItemData对象 3、创建一个脚本&#xff0c;声明并定义承载ItemData对象的数组、承载缩略图的数组。 4、显示缩略图、文…

6.key的层级结构

redis的key允许多个单词形成层级结构&#xff0c;多个单词之间用:隔开&#xff0c;格式如下&#xff1a; 项目名:业务名:类型:id 这个格式并非固定的&#xff0c;可以根据自己的需求来删除或添加词条。 例如&#xff1a; taobao:user:1 taobao:product:1 如果value是一个java对…

【Golang 面试 - 进阶题】每日 3 题(十一)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/UWz06 &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 Golang 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏…

提升SEO排名的谷歌外链策略

​要提升SEO排名&#xff0c;谷歌外链策略必须聚焦于外链数量和质量的合理搭配。市场上那些SEO表现优秀的网站&#xff0c;无一例外地拥有数万甚至数十万的外链&#xff0c;而且这些外链在结构上表现出复杂和多样化。这不仅仅是因为数量众多&#xff0c;还因为这些外链质量的高…

酷家乐--应用频繁报出cause java.net.SocketTimeoutException: Read timed out怎么办

涉及到网络层面的问题一般都比较复杂&#xff0c;场景多&#xff0c;定位难&#xff0c;成为了大多数开发的噩梦&#xff0c;应该是最复杂的了。下面通过一个实际的例子来阐述遇到了要怎么办。 现象 部署在矩阵机房的较多应用频繁报出toad异常&#xff0c;Encounter unknown …

嵌入式学习第13天——C语言循环结构break和continue

break和continue break 功能&#xff1a; 1.用在switch中&#xff0c;用来跳出switch的case语句;如果case没有break&#xff0c;可能会产生case穿透。 2.用在循环中(while、do..while、for..)&#xff0c;提前结束循环&#xff0c;也就是跳出整个循环。 说明&#xff1a; …

spring的三级缓存与源码分析--解决循环依赖

三级缓存介绍 Spring 通过三层缓存来处理循环依赖&#xff0c;这些缓存分别是&#xff1a; 一级缓存&#xff08;内存中的 singletonObjects&#xff09; 二级缓存&#xff08;earlySingletonObjects&#xff09; 三级缓存&#xff08;singletonFactories&#xff09; 1. 一…

深入理解C语言结构体

目录 引言 一. 结构体的基本概念 1.结构体的声明 2. 结构体变量的创建和初始化 3. 结构体成员访问操作符 4.结构体的特殊声明 1. 匿名结构体 2. 嵌套结构体 3.结构体自引用 4. typedef 声明 二、结构体内存对⻬ 1.对⻬规则 2.为什么存在内存对⻬? 3.修改默认对齐…

ffmpeg命令-Windows下常用最全

查询命令 参数 说明 -version 显示版本。 -formats 显示可用的格式&#xff08;包括设备&#xff09;。 -demuxers 显示可用的demuxers。 -muxers 显示可用的muxers。 -devices 显示可用的设备。 -codecs 显示libavcodec已知的所有编解码器。 -decoders 显示可用…

基于SpringBoot+Vue的小区物业管理系统(带1w+文档)

基于SpringBootVue的小区物业管理系统(带1w文档) 基于SpringBootVue的小区物业管理系统(带1w文档) 小区物业管理系统采用B/S(Browser/Server)架构和MVC模型进行设计开发。在B/S架构下&#xff0c;用户在浏览器端进行使用&#xff0c;主要工作通过服务器端进行实现&#xff0c;用…

电脑缺少dll文件怎么解决?10款dll修复工具大盘点,赶紧收藏起来!

电脑缺少dll文件怎么解决&#xff1f;DLL&#xff08;动态链接库&#xff09;是一种重要文件&#xff0c;包含了一系列指令&#xff0c;用于运行几乎所有 Win10、Win8和 Win7的程序。如果Windows 操作系统中缺少DLL文件&#xff0c;您可能会无法启动所需的程序或应用。在 Win10…

【AndroidStudio】修改app名称、版本号、图标

文章目录 1. 修改app名称(AndroidManifest.xml-app_name字段)2. 修改app版本号和版本名称3. 修改app图标4. 修改app启动过渡图片 1. 修改app名称(AndroidManifest.xml-app_name字段) 2. 修改app版本号和版本名称 通常是app目录下的build.gradle文件找到“versionCode”和“ver…

基于域名+基于ip+基于端口的虚拟主机+上线商务系统

一、回顾 1.jdk环境 tomcat服务器需要jdk环境 版本对应 ​ tomcat9>jdk1.8 配置系统变量JAVA_HOME sed -i $aexport JAVA_HOME/usr/local/jdk22/ /etc/profile sed -i $aexport PATH$JAVA_HOME/bin:$PATH /etc/profile ​ source /etc/profile ​ java -version java…

LeetCode | 441 | 排列硬币 | 二分查找

&#x1f64b;大家好&#xff01;我是毛毛张! &#x1f308;个人首页&#xff1a; 神马都会亿点点的毛毛张 今天分享的是LeetCode中一道标签为简单的算法题&#xff0c;本质是一道数学题 文章目录 1.题目描述2.题解2.1 公式解法2.2 暴力解法2.3 二分查找 LeetCode链接&#…

【 问题 】 AT32 F413CB 设置SRAM大小为64KB 导致Flash后64KB代码执行变慢 解决办法

背景 AT32的SRAM可以设置为16KB/32KB/64KB的不同大小&#xff0c;设置SRAM大小将导致Flash的部分空间的读写速度减缓&#xff0c;如下图&#xff1a; 这个问题看似不是很大&#xff0c;但是当运行一些很保证实时性&#xff0c;速度性的代码时&#xff0c;就会产生一些问题。 …

react-日期选择器封装

文件 import { useMemo, useState, useEffect } from "react" import dayjs, { Dayjs } from "dayjs" import "dayjs/locale/zh-cn" import "./App.css" dayjs.locale("zh-cn")function SimpleCalendar() {// 当前时间对象…

【数值计算方法】数值积分微分-python实现-p2

原文链接&#xff1a;https://www.cnblogs.com/aksoam/p/18279394 更多精彩&#xff0c;关注博客园主页&#xff0c;不断学习&#xff01;不断进步&#xff01; 我的主页 csdn很少看私信&#xff0c;有事请b站私信 博客园主页-发文字笔记-常用 有限元鹰的主页 内容&#xf…

基于ThinkPHP开发的校园跑腿社区小程序系统源码,包含前后端代码

基于ThinkPHP开发的校园跑腿社区小程序系统源码&#xff0c;包含前后端代码 最新独立版校园跑腿校园社区小程序系统源码 | 附教程 测试环境&#xff1a;NginxPHP7.2MySQL5.6 多校版本&#xff0c;多模块&#xff0c;适合跑腿&#xff0c;外卖&#xff0c;表白&#xff0c;二…

【Android】Kotlin 实现底部弹框日历组件

需求 如下图所示, 底部弹出日历组件 原生插件使用的有一个好处是可以根据你的系统语言切换插件内的语言, 刚好我们这个app面向的国外用户, 而产品对日历组件的日期显示有特别要求, 因此这无疑减少了我们切换语言的开发工作量 代码 1. custom_bottom_datepicker.xml <R…