【智能算法】蝙蝠算法(BA)原理及实现

在这里插入图片描述

目录

    • 1.背景
    • 2.算法原理
      • 2.1算法思想
      • 2.2算法过程
    • 3.代码实现
    • 4.参考文献


1.背景

2010年,Yang受到蝙蝠回声定位的特性启发,提出了蝙蝠算法(Bat Algorithm, BA)。

2.算法原理

2.1算法思想

蝙蝠算法模拟了蝙蝠利用回声定位系统寻找小型昆虫进行捕食的行为,主要分为速度位置更新和随机飞行

2.2算法过程

速度位置更新
v i t = v i t − 1 + ( x i t − x ∗ ) f i \mathbf{v}_i^t=\mathbf{v}_i^{t-1}+(\mathbf{x}_i^t-\mathbf{x}_*)f_i vit=vit1+(xitx)fi
其中, x ∗ x_* x为最优个体位置, f i f_i fi为超声频率:
f i = f min ⁡ + ( f max ⁡ − f min ⁡ ) β f_i=f_{\min}+(f_{\max}-f_{\min})\beta fi=fmin+(fmaxfmin)β
位置更新:
x i t = x i t − 1 + v i t \mathbf{x}_i^t=\mathbf{x}_i^{t-1}+\mathbf{v}_i^t xit=xit1+vit
随机飞行
随机生成一个数,蝙蝠根据是否大于脉冲频率进行随机飞行:
x n e w = x o l d + ϵ A t \mathbf{x_{new}}=\mathbf{x_{old}}+\epsilon A^{t} xnew=xold+ϵAt
伪代码
在这里插入图片描述

3.代码实现

% 蝙蝠算法
function [Best_pos, Best_fitness, Iter_curve, History_pos, History_best]=BA(pop, maxIter, lb, ub, dim,fobj)
%input
%pop 种群数量
%dim 问题维数
%ub 变量上边界
%lb 变量下边界
%fobj 适应度函数
%maxIter 最大迭代次数
%output
%Best_pos 最优位置
%Best_fitness 最优适应度值
%Iter_curve 每代最优适应度值
%History_pos 每代种群位置
%History_best 每代最优个体位置
%% 控制参数
A=0.5;      % Loudness
r=0.5;      % Pulse rate
Qmin=0;         % Frequency minimum
Qmax=2;         % Frequency maximum
Q=zeros(pop,1);   % Frequency
v=zeros(pop,dim);   % Velocities
%% 初始化种群
for i=1:pop
  Sol(i,:)=lb+(ub-lb).*rand(1,dim);
  Fitness(i)=fobj(Sol(i,:));
end
% Find the initial best solution
[Best_fitness,I]=min(Fitness);
Best_pos=Sol(I,:);
%% 迭代
for t=1:maxIter
        for i=1:pop
          % 速度&位置更新
          Q(i)=Qmin+(Qmin-Qmax)*rand;
          v(i,:)=v(i,:)+(Sol(i,:)-Best_pos)*Q(i);
          S(i,:)=Sol(i,:)+v(i,:);
          % 边界处理
          Sol(i,:)=simplebounds(Sol(i,:),lb,ub);

          % 随机飞行
          if rand>r
              S(i,:)=Best_pos+0.001*randn(1,dim);
          end
          
           Fnew=fobj(S(i,:));
           if (Fnew<=Fitness(i)) & (rand<A)
                Sol(i,:)=S(i,:);
                Fitness(i)=Fnew;
           end

          if Fnew<=Best_fitness
                Best_pos=S(i,:);
                Best_fitness=Fnew;
          end
            

        end
        
        Iter_curve(t) = Best_fitness;
        History_best{t} = Best_pos;
        History_pos{t} = Sol;
end
end
function s=simplebounds(s,Lb,Ub)
  ns_tmp=s;
  I=ns_tmp<Lb;
  ns_tmp(I)=Lb(I);
  
  J=ns_tmp>Ub;
  ns_tmp(J)=Ub(J);
  s=ns_tmp;
end

在这里插入图片描述

4.参考文献

[1] Yang X S. A new metaheuristic bat-inspired algorithm[M]//Nature inspired cooperative strategies for optimization (NICSO 2010). Berlin, Heidelberg: Springer Berlin Heidelberg, 2010: 65-74.

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ICLR 2024 | Meta AI提出ViT寄存器结构,巧妙消除大型ViT中的伪影以提高性能

论文题目&#xff1a;Vision Transformers Need Registers 论文链接&#xff1a;https://arxiv.org/abs/2309.16588 视觉Transformer&#xff08;ViT&#xff09;目前已替代CNN成为研究者们首选的视觉表示backbone&#xff0c;尤其是一些基于监督学习或自监督学习预训练的ViT&a…

Python3虚拟环境之virtualenv

virtualenv 在开发Python应用程序的时候&#xff0c;系统安装的Python3只有一个版本&#xff1a;3.7。所有第三方的包都会被pip安装到Python3的site-packages目录下。 如果要同时开发多个应用程序&#xff0c;这些应用程序都会共用一个Python&#xff0c;就是安装在系统的Pyt…

【力扣100】【好题】322.零钱兑换 || 01背包完全背包

添加链接描述 思路&#xff1a; dp[j]数组表示的是在金额达到 j 的时候所需要的最小硬币数金额&#xff1a;背包容量&#xff0c;每个硬币的个数都为1&#xff1a;背包中物品的价值&#xff0c;硬币面额&#xff1a;物品重量dp[j]min(dp[j],dp[j-coin]1) class Solution:def …

【c语言 】数组入门

&#x1f388;个人主页&#xff1a;豌豆射手^ &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;C语言 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进步&…

Redhat Linux(RHEL) - Primavera P6 EPPM 安装及分享

引言 继上一期发布的Oracle Linux版环境发布之后&#xff0c;近日我又制作了基于Redhat Linux 的P6虚拟机环境&#xff0c;同样里面包含了全套P6 最新版应用服务 此虚拟机仅用于演示、培训和测试目的。如您在生产环境中使用此虚拟机&#xff0c;请先与Oracle Primavera销售代表…

什么是农业四情监测设备?

【TH-Q2】智慧农业四情监测设备是一种高科技的农田监测工具&#xff0c;旨在实时监测和管理农田中的土壤墒情、作物生长、病虫害以及气象条件。具体来说&#xff0c;它主要包括以下组成部分&#xff1a; 气象站&#xff1a;用于监测气温、湿度、风速等气象数据&#xff0c;为农…

proxy配置代理

通过代理配置可以实现以下几个作用 跨域请求处理&#xff1a;当前端应用运行在一个域名下&#xff0c;而需要请求的 API 接口位于另一个域名下时&#xff0c;由于浏览器的同源策略限制&#xff0c;会导致跨域请求失败。通过代理配置&#xff0c;可以将前端应用的请求先发送到同…

基于鹦鹉优化算法(Parrot optimizer,PO)的无人机三维路径规划(提供MATLAB代码)

一、无人机路径规划模型介绍 无人机三维路径规划是指在三维空间中为无人机规划一条合理的飞行路径&#xff0c;使其能够安全、高效地完成任务。路径规划是无人机自主飞行的关键技术之一&#xff0c;它可以通过算法和模型来确定无人机的航迹&#xff0c;以避开障碍物、优化飞行…

2024最新最全【网络安全】学习路线,零基础入门到精通

01 什么是网络安全 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 无论网络、Web、移动、桌面、云等哪个领域&#xff0c;都有攻与防两面…

Linux安装Mysql8.0

本案例为linux安装mysql8.0.27 若非新服务器可先查看是否已安装mysql&#xff0c;若已安装先进行卸载。 1、Linux查看glibc版本信息&#xff0c;下载相应的MYSQL ldd --version2、mysql下载 https://downloads.mysql.com/archives/community/ 3、安装 linux打开目录&#xf…

python数据类型 -- 元组Tuple

你好, 我是木木, 目前正在做两件事   1. 沉淀自己的专业知识   2. 探索了解各种副业项目&#xff0c;同时将探索过程进行分享&#xff0c;帮助自己以及更多朋友找到副业, 做好副业 文末有惊喜 在Python中&#xff0c;元组&#xff08;tuple&#xff09;是一种不可变序列类型&…

(二十四)Flask之flask-session组件

目录&#xff1a; 每篇前言&#xff1a;Flask-session 每篇前言&#xff1a; &#x1f3c6;&#x1f3c6;作者介绍&#xff1a;【孤寒者】—CSDN全栈领域优质创作者、HDZ核心组成员、华为云享专家Python全栈领域博主、CSDN原力计划作者 &#x1f525;&#x1f525;本文已收录于…

qt-C++笔记之使用Cmake来组织和构建QWidget工程项目

qt-C笔记之使用Cmake来组织和构建QWidget工程项目 —— 杭州 2024-03-10 code review! 文章目录 qt-C笔记之使用Cmake来组织和构建QWidget工程项目1.运行2.文件结构3.CMakeLists.txt4.main.cpp5.widget.h6.widget.cpp7.widget.ui 1.运行 2.文件结构 3.CMakeLists.txt 代码 c…

批量文本处理:轻松提取与整理大量文本内容

在数字时代&#xff0c;内容创作已成为企业与个人传递信息、展示品牌形象的重要手段。然而&#xff0c;面对海量的文本信息&#xff0c;如何高效地提取关键内容&#xff0c;并将其转化为引人注目的标题和宣传软文&#xff0c;成为了摆在我们面前的一大挑战。 第一步&#xff0…

电脑桌面图标变大了怎么恢复?5种简单方法帮你恢复正常

在使用电脑的过程中&#xff0c;有时候我们可能会遇到桌面图标变得异常大的情况。这种问题不仅影响了桌面的整洁度&#xff0c;也可能会影响我们的操作体验。电脑桌面图标变大了怎么恢复&#xff1f;如果你也遇到了这种情况&#xff0c;不用担心&#xff0c;本文将为你介绍五种…

【C++从0到王者】第五十二站:跳表

文章目录 一、什么是跳表二、skiplist的效率三、skiplist的实现 一、什么是跳表 skiplist本质上也是一种查找结构&#xff0c;用于解决算法中的查找问题&#xff0c;跟平衡搜索树和哈希表的价值是一样的&#xff0c;可以作为key或者key/value的查找模型。 skiplist&#xff0c;…

c++的STL(3)-- deque容器

目录 deque概述 deque的内存模型 注意: 1. deque的默认构造(和vector类似) 代码: 2. deque的有参构造(和vector类似) 代码: 3. deque容器在首部和尾部添加或者元素 代码: 相关知识点: 4. deque容器的元素个数 (和vector类似) 代码: 5. deque在指定位置插入元素(和…

Linux搭建ftp服务

使用yum 进行安装 # 在线安装FTP yum install -y vsftpd 安装完成后查看ftp状态 # 查看ftp状态 systemctl status vsftpd.service # 启动ftp状态 重启&#xff1a;restart&#xff0c;停止&#xff1a;stop&#xff0c;开机自启&#xff1a;enable&#xff0c;关闭开机自启&…

【小黑送书—第十二期】>>一本书讲透Elasticsearch:原理、进阶与工程实践(文末送书)

Elasticsearch 是一种强大的搜索和分析引擎&#xff0c;被广泛用于各种应用中&#xff0c;以其强大的全文搜索能力而著称。 不过&#xff0c;在日常管理 Elasticsearch 时&#xff0c;我们经常需要对索引进行保护&#xff0c;以防止数据被意外修改或删除&#xff0c;特别是在进…

图片二维码能长期扫码展示吗?在线图片快速生码的文字教学

很多人在制作图片二维码的时候&#xff0c;比较关注的问题一个是扫码次数&#xff0c;另一个是二维码有效期&#xff0c;那么满足这两个需求的图片二维码该如何制作呢&#xff1f;想要制作不限制扫码次数并且长期有效的图片二维码&#xff0c;大家可以通过图片二维码生成器的功…