位置: IT常识 - 正文

GWO灰狼优化算法综述(Grey Wolf Optimization)(灰狼算法的改进)

编辑:rootadmin
GWO灰狼优化算法综述(Grey Wolf Optimization)

推荐整理分享GWO灰狼优化算法综述(Grey Wolf Optimization)(灰狼算法的改进),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:郊狼优化算法,鲸鱼优化算法和灰狼优化算法,灰狼优化算法和遗传算法,基于灰狼优化算法的改进研究及其应用,灰狼优化算法和遗传算法,gwo灰狼优化算法发展历史,灰狼优化算法和遗传算法,基于灰狼优化算法的改进研究及其应用,内容如对您有帮助,希望把文章链接给更多的朋友!

       GWO通过模拟灰狼群体捕食行为,基于狼群群体协作的机制来达到优化的目的。

       GWO算法具有结构简单、需要调节的参数少、容易实现等特点,其中存在能够自适应调整的收敛因子以及信息反馈机制,能够在局部寻优与全局搜索之间实现平衡,因此在对问题的求解精度和收敛速度方面都有良好的性能。

1. 灰狼优化算法原理

        第一层:层狼群。种群中的领导者,负责带领整个狼群狩猎猎物,即优化算法中的最优解。 

        第二层:层狼群。负责协助 层狼群,即优化算法中的次优解。

        第三层:层狼群。听从和的命令和决策,负责侦查、放哨等。适应度差的 和 会降为。

        第四层:层狼群。它们环绕、或进行位置更新。

        灰狼的狩猎过程包含如下:①包围、跟踪猎物②追捕、骚扰猎物③攻击猎物。

2. 数学模型建立

        为了对 GWO中灰狼的社会等级进行数学建模,将前3匹最好的狼(最优解)分别定义为α,β和δ,它们指导其他狼向着目标搜索。其余的狼 (候选解)被定义为 ω,它们围绕α,β或δ来更新位置。

2.1 包围猎物

        在 GWO 中,灰狼在狩猎过程中利用以下位置更新公式实现对猎物的包围 :

 

        式(1)为灰狼和猎物之间的距离,式(2)是灰狼的位置更新公式,和分别是猎物的位置向量和灰狼的位置向量,t为当前迭代次数。和为确定的系数,其计算公式分别为:

        其中,,是两个一维分量取值在[0,1]内的随机数向量,用于模拟灰狼对猎物的攻击行为,它的取值受到的影响。收敛因子 是一个平衡GWO 勘探与开发能力的关键参数。的取值随着迭代次数的增大从 2 到 0 线性递减。

2.2 追捕猎物GWO灰狼优化算法综述(Grey Wolf Optimization)(灰狼算法的改进)

        在自然界中,虽然狩猎过程通常由头狼 α 狼引导,其它等级的狼配合对猎物进行包围、追捕和攻击,但在演化计算过程中,猎物(最优解)位置是未知的,因此在 GWO 中我们认为最优的灰狼为α ,次优的灰狼为 β ,第三优的灰狼为 δ ,其余的灰狼是 ω,根据 α (潜在最优解)、β  和 δ 对猎物的位置有更多知识的这一特性建立模型,迭代过程中采用 α 、β 和 δ 来指导 ω 的移动,从而实现全局优化。利用α 、β  和 δ 的位置、、,使用下述方程更新所有灰狼的位置:

        分别表示灰狼个体距离  层狼群、 层狼群、层狼群的距离。

       X1、X2、X3分别表示受 层狼群、 层狼群、层狼群影响, 灰狼个体需要调整的位置。

这里取平均值,即

         灰狼的位置更新方式可以用下图表示。

2.3 攻击猎物

        在下面的公式中,t 表示当前迭代次数,T 为设定的最大迭代次数。当 a的值从 2 递减至 0时,其对应的 A 的值也在区间[-a, a]变化: a 的取值越大则会使灰狼远离猎物,希望找到一个更适合的猎物,因而促使狼群进行全局搜索(|𝐴| > 1),若 a 的取值越小则会使灰狼靠近猎物,促使狼群进行局部搜索(|𝐴| < 1)。 

3. Matlab算法实现

 GWO灰狼算法的Matlab代码如下:

%pop——种群数量%dim——问题维度%ub——变量上界,[1,dim]矩阵%lb——变量下界,[1,dim]矩阵%fobj——适应度函数(指针)%MaxIter——最大迭代次数%Best_Pos——x的最佳值%Best_Score——最优适应度值clc;clear all;close all;pop=50;dim=2;ub=[10,10];lb=[-10,-10];MaxIter=100;fobj=@(x)fitness(x);%设置适应度函数[Best_Pos,Best_Score,IterCurve]=GWO(pop,dim,ub,lb,fobj,MaxIter);%…………………………………………绘图…………………………………………figure(1);plot(IterCurve,'r-','linewidth',2);grid on;title('灰狼迭代曲线');xlabel('迭代次数');ylabel('适应度值');%…………………………………… 结果显示……………………………………disp(['求解得到的x1,x2是:',num2str(Best_Pos(1)),' ',num2str(Best_Pos(2))]);disp(['最优解对应的函数:',num2str(Best_Score)]);%种群初始化函数function x=initialization(pop,ub,lb,dim)for i=1:pop for j=1:dim x(i,j)=(ub(j)-lb(j))*rand()+lb(j); endendend%狼群越界调整函数function x=BoundrayCheck(x,ub,lb,dim)for i=1:size(x,1) for j=1:dim if x(i,j)>ub(j) x(i,j)=ub(j); end if x(i,j)<lb(j) x(i,j)=lb(j); end endendend%适应度函数,可根据自身需要调整function [Fitness]=fitness(x) Fitness=sum(x.^2);end%…………………………………………灰狼算法主体………………………………………function [Best_Pos,Best_Score,IterCurve]=GWO(pop,dim,ub,lb,fobj,MaxIter)Alpha_Pos=zeros(1,dim);%初始化Alpha狼群Alpha_Score=inf;Beta_Pos=zeros(1,dim);%初始化Beta狼群Beta_Score=inf;Delta_Pos=zeros(1,dim);%初始化化Delta狼群Delta_Score=inf;x=initialization(pop,ub,lb,dim);%初始化种群Fitness=zeros(1,pop);%初始化适应度函数for i=1:pop Fitness(i)=fobj(x(i,:));end[SortFitness,IndexSort]=sort(Fitness);Alpha_Pos=x(IndexSort(1),:);Alpha_Score=SortFitness(1);Beta_Pos=x(IndexSort(2),:);Beta_Score=SortFitness(2);Delta_Pos=x(IndexSort(3),:);Delta_Score=SortFitness(3);Group_Best_Pos=Alpha_Pos;Group_Best_Score=Alpha_Score;for t=1:MaxIter a=2-t*((2)/MaxIter);%线性调整a的值 for i=1:pop for j=1:dim %根据Alpha狼群更新位置X1 r1=rand; r2=rand; A1=2*a*r1-a;%计算A1 C1=2*r2;%计算C1 D_Alpha=abs(C1*Alpha_Pos(j)-x(i,j));%计算种群中其它狼只与Alpha狼群的距离 X1=Alpha_Pos(j)-A1*D_Alpha;%更新X1 %根据Beta狼群更新位置X2 r1=rand; r2=rand; A2=2*a*r1-a;%计算A2 C2=2*r2;%计算C2 D_Beta=abs(C2*Beta_Pos(j)-x(i,j));%计算种群中其它狼只与Beta狼群的距离 X2=Beta_Pos(j)-A2*D_Beta;%更新X2 %根据Delta狼群更新位置X3 r1=rand; r2=rand; A3=2*a*r1-a; C3=2*r2; D_Delta=abs(C3*Delta_Pos(j)-x(i,j));%计算种群中其它狼只与BDelta狼群的距离 X3=Delta_Pos(j)-A3*D_Delta;%更新X3 x(i,j)=(X1+X2+X3)/3;%更新后的狼只位置 end end x=BoundrayCheck(x,ub,lb,dim);%狼只越界调整 for i=1:pop Fitness(i)=fobj(x(i,:)); if Fitness(i)<Alpha_Score%替换Aplha狼 Alpha_Score=Fitness(i); Alpha_Pos=x(i,:); end if Fitness(i)>Alpha_Score&&Fitness(i)<Beta_Score%替换Beta狼 Beta_Score=Fitness(i); Beta_Pos=x(i,:); end if Fitness(i)>Alpha_Score&&Fitness(i)>Beta_Score&&Fitness(i)<Delta_Score%替换Delta狼 Delta_Score=Fitness(i); Delta_Pos=x(i,:); end end Group_Best_Pos=Alpha_Pos; Group_Best_Score=Alpha_Score; IterCurve(t)=Group_Best_Score;end Best_Pos=Group_Best_Pos; Best_Score=Group_Best_Score;end4. GWO算法的优化过程

        GWO算法的优化从随机创建 一个灰狼种群(候选方案)开始。在迭代过程中,α,β和δ狼估计猎物的可能位置(最优解)。灰狼根据它们与猎物的距离更新其位置。为了搜索过程中的勘探和开发,参数a应该从2递减到0。如果||>1,候选解远离猎物;如果||<1,候选解逼近猎物。GWO算法的流程图如下图所示。

         目前对于GWO算法的改进很多,可以参考以下的文献

参考文献

        1.张晓凤,王秀英.灰狼优化算法研究综述[M].青岛科技大学

        2.张森.灰狼优化算法研究及应用[M],广西民族大学

本文链接地址:https://www.jiuchutong.com/zhishi/289603.html 转载请保留说明!

上一篇:微前端架构-qiankun在vue3的应用(微前端架构实现)

下一篇:Mont Choisy Beach, Mauritius (© Robert Harding World Imagery/Offset by Shutterstock)

  • 华为gt2pro怎么添加音乐(华为gt2pro怎么添加网易云音乐)

    华为gt2pro怎么添加音乐(华为gt2pro怎么添加网易云音乐)

  • 华为p40使用鸿蒙系统吗(华为p40如何用鸿蒙)

    华为p40使用鸿蒙系统吗(华为p40如何用鸿蒙)

  • 华为nova4支持内存扩展吗(华为nova4支持外置内存卡吗)

    华为nova4支持内存扩展吗(华为nova4支持外置内存卡吗)

  • 为什么qq字符突然不显示了(qq字符为什么会消失)

    为什么qq字符突然不显示了(qq字符为什么会消失)

  • 拼多多砍价网页打不开是为什么(拼多多砍价网站链接)

    拼多多砍价网页打不开是为什么(拼多多砍价网站链接)

  • 电话拨号连接是计算机个人用户常用的接入(电脑拨号电话机)

    电话拨号连接是计算机个人用户常用的接入(电脑拨号电话机)

  • 快充协议有几种(快充协议有几种接口)

    快充协议有几种(快充协议有几种接口)

  • 菜鸟裹裹删除包裹亲友还看得到吗(菜鸟裹裹删除包裹影响运输吗)

    菜鸟裹裹删除包裹亲友还看得到吗(菜鸟裹裹删除包裹影响运输吗)

  • 计算机有多种技术指标其中主频是指(计算机有多种技术指标其中决定计算机的计算精度的是)

    计算机有多种技术指标其中主频是指(计算机有多种技术指标其中决定计算机的计算精度的是)

  • tpguest是什么wifi

    tpguest是什么wifi

  • sav文件怎么打开(sav文件怎么打开 游戏)

    sav文件怎么打开(sav文件怎么打开 游戏)

  • 被注销的qq长什么样(被注销的qq长什么样图片)

    被注销的qq长什么样(被注销的qq长什么样图片)

  • 苹果11可以放两张移动卡吗(苹果11可以放两张联通卡吗)

    苹果11可以放两张移动卡吗(苹果11可以放两张联通卡吗)

  • 华为mate30pro支持红外吗(华为mate30pro支持wifi6吗)

    华为mate30pro支持红外吗(华为mate30pro支持wifi6吗)

  • 小米9pro怎么设置息屏预览(小米9a怎么设置)

    小米9pro怎么设置息屏预览(小米9a怎么设置)

  • vue视频的总时长能变长吗(vue视频时间怎么设置)

    vue视频的总时长能变长吗(vue视频时间怎么设置)

  • 华为手机mate30pro与p30pro区别在哪(华为手机mate30pro音量键在哪里)

    华为手机mate30pro与p30pro区别在哪(华为手机mate30pro音量键在哪里)

  • 抖音多少粉丝才可以直播(抖音多少粉丝才算网红)

    抖音多少粉丝才可以直播(抖音多少粉丝才算网红)

  • 苹果怎么取消拍照声音(苹果怎么取消拍照锐化)

    苹果怎么取消拍照声音(苹果怎么取消拍照锐化)

  • 华为手机自带软件怎么卸载(华为手机自带软件可以删除吗)

    华为手机自带软件怎么卸载(华为手机自带软件可以删除吗)

  • office用32位还是64位(office用32位还是)

    office用32位还是64位(office用32位还是)

  • 小米手环3和nfc区别(小米手环3和3nfc表带通用吗)

    小米手环3和nfc区别(小米手环3和3nfc表带通用吗)

  • word字间距突然变大(word文档的字间距突然变宽是怎么回事)

    word字间距突然变大(word文档的字间距突然变宽是怎么回事)

  • 小红书订单在哪儿看(小红书的订单在哪里)

    小红书订单在哪儿看(小红书的订单在哪里)

  • 魅族16如何分享网络(魅族16怎么互传)

    魅族16如何分享网络(魅族16怎么互传)

  • bengine.exe是什么进程 bengine进程安全吗(wrme.exe是什么)

    bengine.exe是什么进程 bengine进程安全吗(wrme.exe是什么)

  • 企业付房租怎么做会计分录
  • 红冲以后怎么做账
  • 国家电子产品投诉电话
  • 利息费用和利息支出的区别计算公式
  • 缴纳增值税和附加税
  • 滞纳金开专票要交税吗
  • 财务合理化建议例子
  • 回购股份限售
  • 轿车被盗
  • 员工上下班交通安全培训
  • 房屋租赁合同样本书
  • 加计扣除要交企业所得税吗
  • 增值税专用发票和普通发票的区别
  • 盘亏固定资产会计处理
  • 特种设备培训费计入什么会计科目
  • 现金支票存根会计要签字吗
  • 发票一定要开完了才能领取吗?
  • 离职有补偿金的可不可以领取失业金
  • 应收账款无法收回确认为坏账分录
  • 一式三联的收据哪一联要盖财务章
  • 车间管理人员工资记什么费用
  • 从银行提取备用金填制什么凭证
  • vue3.0组件库
  • 房地产业务招待费
  • 缴纳集团公司的税收
  • 调入的无形资产记入哪里
  • php中get_magic_quotes_gpc()函数说明
  • php单例模式连接数据库
  • vue3.0项目创建
  • 攻防世界web高手题答案
  • print函数php
  • php服务端开发教程
  • 进口付汇和出口收汇
  • phpcms二次开发教程
  • 来料加工企业的税率是多少
  • 认缴出资和注册资本
  • 当月确认收入可以下月确认成本吗
  • python合并集合
  • 收回投资收到的现金减少
  • 公司成立开的户叫什么
  • 企业年金是否要交个税
  • 公司买手表可以抵扣增值税吗
  • 去银行打对账单和回执单需要拿什么
  • 交加盟费送赠品可以吗
  • 差额开票和全额开票
  • 公司与个人可以合伙吗
  • 税金及附加怎么算
  • 土地使用权入账务处理
  • 费用发票可以不抵扣进项税吗
  • 结转已到期未兑现的商业承兑汇票会计分录
  • 如何理解事业单位处罚暂行条例中第十八条的兼职规定
  • 外购货物会计分录
  • 坏账准备计提标准
  • 营业账簿如何缴纳税款
  • 4s店收取保险服务费合理吗
  • 公司在筹备阶段怎么办
  • 排污费计入管理费用吗
  • 记账凭证烂了要紧吗
  • win mysql
  • vb.net with
  • 安装windowsserver2008r2提示无法定位程序输入点
  • Windows 7 64位系统手动添加Editplus到鼠标右键的方法
  • win7看视频黑屏有声音
  • win8升级win10补丁
  • mpcmdrun.exe是什么进程
  • win7开机屏幕狂闪不停怎么解决
  • windows向microsoft报告
  • opengl帧缓冲
  • jquery右击事件
  • qt::windowtype
  • javascript entries
  • 各类扩展名
  • javascript高级程序设计第五版 pdf下载
  • jquery里面的$是什么意思
  • javascript default
  • 税控盘解除风险
  • 西藏拉萨工业园主要生产什么
  • 陕西省税务发票查询系统
  • 税务ukey登录界面
  • 土地增值税逾期罚款
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设