【免费分享】2024最新优化算法-黑翅鸢算法BKA

2024-09-01 22:04

本文主要是介绍【免费分享】2024最新优化算法-黑翅鸢算法BKA,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

黑翅鸢优化算法(Black-winged kite algorithm,BKA)是一种受自然界启发的群体智能优化算法,其设计灵感源自黑翅鸢(Black-winged kite)的生存策略。黑翅鸢在攻击和迁徙过程中展现出的高度适应性和智能行为,激发了我们开发这一算法,以更好地解决复杂问题。该算法具有强大的进化能力、快速的搜索速度和优异的寻优性能。此研究成果已于2024年发表在知名SCI期刊《Artificial Intelligence Review》上,并在工程优化、机器学习、数据挖掘等领域得到了广泛应用。

代码如下

function [Best_Fitness_BKA,Best_Pos_BKA,Convergence_curve]=BKA(pop,T,lb,ub,dim,fobj)
%% ----------------Initialize the locations of Blue Sheep------------------%p=0.9;r=rand;
XPos=initialization(pop,dim,ub,lb);% Initial population
for i =1:popXFit(i)=fobj(XPos(i,:));
end
Convergence_curve=zeros(1,T);%% -------------------Start iteration------------------------------------%for t=1:T[~,sorted_indexes]=sort(XFit);XLeader_Pos=XPos(sorted_indexes(1),:);XLeader_Fit = XFit(sorted_indexes(1));%% -------------------Attacking behavior-------------------%for i=1:popn=0.05*exp(-2*(t/T)^2);if p<rXPosNew(i,:)=XPos(i,:)+n.*(1+sin(r))*XPos(i,:);elseXPosNew(i,:)= XPos(i,:).*(n*(2*rand(1,dim)-1)+1);endXPosNew(i,:) = max(XPosNew(i,:),lb);XPosNew(i,:) = min(XPosNew(i,:),ub);%%Boundary checking
%% ------------ Select the optimal fitness value--------------%XFit_New(i)=fobj(XPosNew(i,:));if(XFit_New(i)<XFit(i))XPos(i,:) = XPosNew(i,:);XFit(i) = XFit_New(i);end
%% -------------------Migration behavior-------------------%m=2*sin(r+pi/2);s = randi([1,30],1);r_XFitness=XFit(s);ori_value = rand(1,dim);cauchy_value = tan((ori_value-0.5)*pi);if XFit(i)< r_XFitnessXPosNew(i,:)=XPos(i,:)+cauchy_value(:,dim).* (XPos(i,:)-XLeader_Pos);elseXPosNew(i,:)=XPos(i,:)+cauchy_value(:,dim).* (XLeader_Pos-m.*XPos(i,:));endXPosNew(i,:) = max(XPosNew(i,:),lb);XPosNew(i,:) = min(XPosNew(i,:),ub); %%Boundary checking
%% --------------  Select the optimal fitness value---------%XFit_New(i)=fobj(XPosNew(i,:));if(XFit_New(i)<XFit(i))XPos(i,:) = XPosNew(i,:);XFit(i) = XFit_New(i);endend%% -------Update the optimal Black-winged Kite----------%if(XFit<XLeader_Fit)Best_Fitness_BKA=XFit(i);Best_Pos_BKA=XPos(i,:);elseBest_Fitness_BKA=XLeader_Fit;Best_Pos_BKA=XLeader_Pos;endConvergence_curve(t)=Best_Fitness_BKA;
end
end

这篇关于【免费分享】2024最新优化算法-黑翅鸢算法BKA的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128165

相关文章

Python虚拟环境与Conda使用指南分享

《Python虚拟环境与Conda使用指南分享》:本文主要介绍Python虚拟环境与Conda使用指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python 虚拟环境概述1.1 什么是虚拟环境1.2 为什么需要虚拟环境二、Python 内置的虚拟环境工具

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Java SWT库详解与安装指南(最新推荐)

《JavaSWT库详解与安装指南(最新推荐)》:本文主要介绍JavaSWT库详解与安装指南,在本章中,我们介绍了如何下载、安装SWTJAR包,并详述了在Eclipse以及命令行环境中配置Java... 目录1. Java SWT类库概述2. SWT与AWT和Swing的区别2.1 历史背景与设计理念2.1.

Java日期类详解(最新推荐)

《Java日期类详解(最新推荐)》早期版本主要使用java.util.Date、java.util.Calendar等类,Java8及以后引入了新的日期和时间API(JSR310),包含在ja... 目录旧的日期时间API新的日期时间 API(Java 8+)获取时间戳时间计算与其他日期时间类型的转换Dur

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

MySQL 存储引擎 MyISAM详解(最新推荐)

《MySQL存储引擎MyISAM详解(最新推荐)》使用MyISAM存储引擎的表占用空间很小,但是由于使用表级锁定,所以限制了读/写操作的性能,通常用于中小型的Web应用和数据仓库配置中的只读或主要... 目录mysql 5.5 之前默认的存储引擎️‍一、MyISAM 存储引擎的特性️‍二、MyISAM 的主

Python处理大量Excel文件的十个技巧分享

《Python处理大量Excel文件的十个技巧分享》每天被大量Excel文件折磨的你看过来!这是一份Python程序员整理的实用技巧,不说废话,直接上干货,文章通过代码示例讲解的非常详细,需要的朋友可... 目录一、批量读取多个Excel文件二、选择性读取工作表和列三、自动调整格式和样式四、智能数据清洗五、

JDK9到JDK21中值得掌握的29个实用特性分享

《JDK9到JDK21中值得掌握的29个实用特性分享》Java的演进节奏从JDK9开始显著加快,每半年一个新版本的发布节奏为Java带来了大量的新特性,本文整理了29个JDK9到JDK21中值得掌握的... 目录JDK 9 模块化与API增强1. 集合工厂方法:一行代码创建不可变集合2. 私有接口方法:接口

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

Python多进程、多线程、协程典型示例解析(最新推荐)

《Python多进程、多线程、协程典型示例解析(最新推荐)》:本文主要介绍Python多进程、多线程、协程典型示例解析(最新推荐),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 目录一、multiprocessing(多进程)1. 模块简介2. 案例详解:并行计算平方和3. 实现逻