智能优化算法:冠状病毒群体免疫优化算法 -附代码

2024-06-18 07:19

本文主要是介绍智能优化算法:冠状病毒群体免疫优化算法 -附代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

智能优化算法:冠状病毒群体免疫优化算法

文章目录

  • 智能优化算法:冠状病毒群体免疫优化算法
    • 1.算法原理
    • 2.算法结果
    • 3.参考文献
    • 4.Matlab

摘要:冠状病毒群体免疫优化算法是于2020年提出的一种新型智能优化算法。

1.算法原理

冠状病毒群免疫优化算法(CHIO)灵感来源于应对冠状病毒大流行(2019冠状病毒疾病)的群体免疫概念。传播冠状病毒的速度取决于感染者如何与其他社会成员直接接触。为了保护社会其他成员免受这种疾病的侵害,健康专家建议社会疏远。群体免疫是当大多数群体具有免疫力时,群体达到的一种状态,这种状态可以防止疾病的传播。这些概念是根据优化概念建模的。既模仿群体免疫策略,又模仿社会距离概念。利用三种类型的个体病例进行群体免疫: 易感者、感染者和免疫者。

提出的优化算法对群体免疫策略进行了建模。

第一步初始化 CHIO和最佳化问题的参数在这一步中,最佳化问题是在目标函数的背景下建立的:
m i n f ( x ) , x ∈ [ l b , u b ] (1) minf(x),x\in[lb,ub]\tag{1} minf(x),x[lb,ub](1)
其中: l b lb lb u b ub ub​分别为搜索的上下限。

第二步:首先产生群体免疫群体 H I P HIP HIP,然后随机(或启发式)产生一组病例(个体) H I S HIS HIS。生成的病例以二维矩阵 n × H I S n×HIS n×HIS​形式存储,如下所示:
H I P = [ x 1 1 , x 2 1 , . . . , x n 1 x 1 2 , x 2 2 , . . . , x n 2 . . . , . . . , . . . , . . . x 1 H I S , x 2 H I S , . . . , x n H I S ] (2) HIP=\left[\begin{matrix}x_1^1,x_2^1,...,x_n^1\\ x_1^2,x_2^2,...,x_n^2\\ ...,...,...,...\\ x_1^{HIS},x_2^{HIS},...,x_n^{HIS} \end{matrix}\right]\tag{2} HIP=x11,x21,...,xn1x12,x22,...,xn2...,...,...,...x1HIS,x2HIS,...,xnHIS(2)
其中: x i j = l b i + ( u b i − l b i ) ∗ r a n d , i = 1 , 2 , . . , n x_i^j=lb_i+(ub_i-lb_i)*rand,i=1,2,..,n xij=lbi+(ubilbi)rand,i=1,2,..,n, H I S HIS HIS为人口数量, n n n为问题的维数。利用方程(1)计算每种情况的目标函数(或免疫率)。

第三步:冠状病毒群体免疫进化这是主要的改进循环。 x i j x_i^j xij病例的基因 x j x^j xj​​要么保持不变,要么受到社会距离的影响,其影响根据基本繁殖率 B R r BRr BRr
x i j ( t + 1 ) = { x i j ( t ) , r ≥ B R r C ( x i j ( t ) ) , r < 1 / 3 B R r N ( x i j ( t ) ) , r < 2 / 3 B R r R ( x i j ( t ) ) , r < B R r (3) x_i^j(t+1)=\begin{cases} x_i^j(t),r\geq BRr\\ C(x_i^j(t)),r<1/3BRr\\ N(x_i^j(t)),r<2/3BRr\\ R(x_i^j(t)),r<BRr \end{cases}\tag{3} xij(t+1)=xij(t),rBRrC(xij(t)),r<1/3BRrN(xij(t)),r<2/3BRrR(xij(t)),r<BRr(3)
其中: r r r为在0和1之间的随机数。 x i j ( t + 1 ) x_i^j(t+1) xij(t+1)为新基因值, x i j ( t ) x_i^j(t) xij(t)为更新前的基因值。
C ( x i j ( t ) ) = x i j ( t ) + r ∗ ( x I j ( t ) − x i c ( t ) ) (4) C(x_i^j(t))=x_i^j(t)+r*(x_I^j(t)-x_i^c(t))\tag{4} C(xij(t))=xij(t)+r(xIj(t)xic(t))(4)
其中: x i c ( t ) x_i^c(t) xic(t)为根据从感染病例随机选择的状态向量 c = { i ∣ S i = 1 } c=\{i|S_i=1\} c={iSi=1}
N ( x i j ( t ) ) = x i j ( t ) + r ( x i j ( t ) − x i m ( t ) ) (5) N(x_i^j(t))=x_i^j(t)+r(x_i^j(t)-x_i^m(t))\tag{5} N(xij(t))=xij(t)+r(xij(t)xim(t))(5)
其中: x i m ( t ) x_i^m(t) xim(t)为根据从感染病例随机选择的状态向量 m = { i ∣ S i = 0 } m=\{i|S_i=0\} m={iSi=0}
R ( x i j ( t ) ) = x i j ( t ) + r ( x i j ( t ) − x i V ( t ) ) (6) R(x_i^j(t))=x_i^j(t)+r(x_i^j(t)-x_i^V(t))\tag{6} R(xij(t))=xij(t)+r(xij(t)xiV(t))(6)
其中: x i V x_i^V xiV​​为最好的免疫病例。

第四步:更新群体免疫群体,由 x j ( t + 1 ) x^j(t+1) xj(t+1)生成的每个免疫率生成的 f ( x j ( t + 1 ) ) f(x^j(t+1)) f(xj(t+1)),若 f ( x j ( t + 1 ) ) < f ( x j ( t ) ) f(x^j(t+1))<f(x^j(t)) f(xj(t+1))<f(xj(t)),当前的 x j ( t ) x^j(t) xj(t) x j ( t + 1 ) x^j(t+1) xj(t+1)代替。年龄矢量 A j A_j Aj随着状态向量 S j = 1 S_j=1 Sj=1增加。状态向量 S j = 1 S_j=1 Sj=1可见式(7)
S j = { 1 , f ( x j ( t + 1 ) ) < f ( x ) j ( t + 1 ) Δ f ( x ) ∧ S j = 0 ∧ i s _ C o r o n a ( x j ( t + 1 ) ) 2 , f ( x j ( t + 1 ) ) > f ( x ) j ( t + 1 ) Δ f ( x ) ∧ S j = 1 (7) S_j=\begin{cases} 1,f(x^j(t+1))<\frac{f(x)^j(t+1)}{\Delta f(x)}\wedge S_j=0\wedge is\_Corona(x^j(t+1))\\ 2,f(x^j(t+1))>\frac{f(x)^j(t+1)}{\Delta f(x)}\wedge S_j=1 \end{cases}\tag{7} Sj={1,f(xj(t+1))<Δf(x)f(x)j(t+1)Sj=0is_Corona(xj(t+1))2,f(xj(t+1))>Δf(x)f(x)j(t+1)Sj=1(7)
其中: i s _ C o r o n a ( x j ( t + 1 ) ) is\_Corona(x^j(t+1)) is_Corona(xj(t+1))是当新的 x j ( t + 1 ) x^j(t+1) xj(t+1)继承了任何感染病例的值时,它是二进制值1, Δ f ( x ) \Delta f(x) Δf(x)​​为种群免疫率的平均值。注意,如果新产生的个人免疫率高于人口的平均免疫率,则人口中的个人免疫率将根据以前计算的社会距离改变。这意味着我们的人口免疫力开始提高。如果新产生的种群足够强壮,可以对流行病免疫,那么我们就达到了群体免疫阈值。

第五步:死亡病例

若免疫率 f ( x j ( t + 1 ) ) f(x^j(t+1)) f(xj(t+1)),在当前 S j = 1 S_j=1 Sj=1的迭代次数 M a x a g e Max_{age} Maxage被感染的情况不能改善下,那么这个病例就会死亡。在那之后,它被重新生成由式 x i j = l b i + ( u b i − l b i ) ∗ r a n d x_i^j=lb_i+(ub_i-lb_i)*rand xij=lbi+(ubilbi)rand​。进一步设置 S j = A j = 0 S_j=A_j=0 Sj=Aj=0​.这可能有助于使目前的人口多样化,从而避免局部最优。

第六步:停止准则 CHIO重复步骤3到步骤6直到终止准则,这通常取决于是否达到最大迭代次数。在这种情况下,易感和免疫的病例总数占主导地位。感染的病例也消失了。

算法流程:

具体可见算法原理步骤1至6。伪代码见下图:

请添加图片描述

2.算法结果

请添加图片描述

3.参考文献

[1] Al Betar Mohammed Azmi,Alyasseri Zaid Abdi Alkareem,Awadallah Mohammed A,Abu Doush Iyad. Coronavirus herd immunity optimizer (CHIO).[J]. Neural computing & applications,2020,33(prepublish):

4.Matlab

这篇关于智能优化算法:冠状病毒群体免疫优化算法 -附代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

IIS 7.0 及更高版本中的 FTP 状态代码

《IIS7.0及更高版本中的FTP状态代码》本文介绍IIS7.0中的FTP状态代码,方便大家在使用iis中发现ftp的问题... 简介尝试使用 FTP 访问运行 Internet Information Services (IIS) 7.0 或更高版本的服务器上的内容时,IIS 将返回指示响应状态的数字代

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Python实现一键PDF转Word(附完整代码及详细步骤)

《Python实现一键PDF转Word(附完整代码及详细步骤)》pdf2docx是一个基于Python的第三方库,专门用于将PDF文件转换为可编辑的Word文档,下面我们就来看看如何通过pdf2doc... 目录引言:为什么需要PDF转Word一、pdf2docx介绍1. pdf2docx 是什么2. by

基于Python实现智能天气提醒助手

《基于Python实现智能天气提醒助手》这篇文章主要来和大家分享一个实用的Python天气提醒助手开发方案,这个工具可以方便地集成到青龙面板或其他调度框架中使用,有需要的小伙伴可以参考一下... 目录项目概述核心功能技术实现1. 天气API集成2. AI建议生成3. 消息推送环境配置使用方法完整代码项目特点