【SIER】基于SIRV模型的新型冠状病毒疫情预测附MATLAB仿真

本文涉及的产品
模型训练 PAI-DLC,100CU*H 3个月
模型在线服务 PAI-EAS,A10/V100等 500元 1个月
交互式建模 PAI-DSW,每月250计算时 3个月
简介: 【SIER】基于SIRV模型的新型冠状病毒疫情预测附MATLAB仿真

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

目的拟合并预测新型冠状病毒肺炎(COVID-19)疫情的发展趋势,为疫情防控提供科学依据。方法基于SIRV动力学模型,考虑COVID-19的传播机制、感染谱、隔离措施等,建立SIRV传播动力学模型。基于官方公布的每日确诊病例数进行建模,利用2020年1月20日至2月7日的报告疫情数据进行拟合。采用2月8-12日的数据评估预测效果,并进行疫情预测。结果该模型对加拿大的累计确诊病例数的过去10日拟合偏差<5%;

⛄ 部分代码

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

% MATLAB Code for the fitting of the SIRV model proposed

% in the following work:


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%% Load data

clear all;clc;close all

population='Canada';

data = xlsread('COVID19-Data-Canada',population);

N=data(1,1);

I=data(:,2);

R=data(:,3);

D=data(:,4);

S=N*ones(size(I))-R-I;

startDate= datenum('17-Jul-2020'); %start day of the data

endDate=datenum('08-Jan-2021'); %end day of the data

tmonths=startDate:30:(endDate);

%% Fitting R0;

clear x y

yS=log(S/S(1));

yS=yS(1:end);

xS=R(1:end)-R(1)*ones(size(R(1:end)));

R0=-(xS\yS)*N;

%% Fitting for gamma

idx=1;

for t=2:length(I)

 

   xR(idx)=trapz(1:t,I(1:t));

   yR(idx)=R(t)-R(1);

   idx=idx+1;

end

gamma=xR'\yR';

beta=gamma*R0;

%% Fitting for mu

xD=R(1:end)-R(1);

yD=D(1:end)-D(1);

mu=xD\yD;

yDfit=mu*xD;

%% Simulate the identified model

dt=1/24;

T=length(I)-1+dt;

[par,rms]=fminsearch(@(par)RMS_SIRV(par,I(1:end)/N,R(1:end)/N,T,dt),[beta gamma]);

beta=par(1);

gamma=par(2);

R0=beta/gamma;

[~,x2,x3,~] = SIRV_model(0,beta,gamma,I(1)/N,R(1)/N,0,T,dt,zeros(1,T/dt));

Dfit=mu*(x3-x3(1))*N+D(1);

t=startDate:dt:endDate;


% Plot the figures

figure(4)

plot(t,x2*N,'LineWidth',1.5);grid on; hold on; box on;

stem(startDate:endDate,I(1:end),'o')

ylabel('Infected $I(t)$','Interpreter','latex','fontsize',15)

title(population,'Interpreter','latex','fontsize',15)

legend({'Fitted Model','Real Data'},'Interpreter','latex','fontsize',15)

ax=gca;

ax.XTick=tmonths;

xtickangle(90)

datetick('x','mmm-yy')

set(gca,'TickLabelInterpreter','latex','fontsize',15)

xlim([startDate endDate])

ax.YAxis.Exponent = 3;

ySfit = -R0*xS/N;

axes('position',[.25 .6 .25 .25])

hold on;grid on;box on

plot(xS+R(1),ySfit,'-.','LineWidth',2);

scatter(xS+R(1),yS)

xlim([R(1) R(end)])

ylabel('$\log(S(t)/S(t_0))$','Interpreter','latex','fontsize',14)

xlabel('$R(t)$','Interpreter','latex','fontsize',14)



figure(5)

plot(t,x3*N,'LineWidth',1.5);grid on; hold on; box on;

stem(startDate:endDate,R(1:end),'o')

ylabel('Removed $R(t)$','Interpreter','latex','fontsize',15)

title(population,'Interpreter','latex','fontsize',15)

legend({'Fitted Model','Real Data'},'Interpreter','latex','fontsize',15)

ax=gca;

ax.XTick=tmonths;

xtickangle(90)

datetick('x','mmm-yy')

set(gca,'TickLabelInterpreter','latex','fontsize',15)

xlim([startDate endDate])

axes('position',[.25 .6 .25 .25])

hold on;grid on;box on

yRfit = gamma*xR;

plot(xR,yRfit+R(1),'-.','LineWidth',2);

scatter(xR,yR+R(1))

ylabel('$R(t)$','Interpreter','latex','fontsize',14)

xlabel('$\int_{t_0}^tI(\tau)d\tau$','Interpreter','latex','fontsize',14)


figure(6)

plot(t,Dfit,'LineWidth',1.5);grid on; hold on; box on;

stem(startDate:endDate,D(1:end),'o')

ylabel('Deaths $D(t)$','Interpreter','latex','fontsize',15)

title(population,'Interpreter','latex','fontsize',15)

legend({'Fitted Model','Real Data'},'Interpreter','latex','fontsize',15)

ax=gca;

ax.YAxis.Exponent = 3;

ax.XTick=tmonths;

xtickangle(90)

datetick('x','mmm-yy')

set(gca,'TickLabelInterpreter','latex','fontsize',15)

xlim([startDate endDate])

axes('position',[.25 .6 .25 .25])

hold on;grid on;box on;

plot(xD+R(1),yDfit+D(1),'-.','LineWidth',2);

scatter(xD+R(1),yD+D(1))

xlim([R(1) R(end)])

ylabel('$D(t)$','Interpreter','latex','fontsize',14)

xlabel('$R(t)$','Interpreter','latex','fontsize',14)

⛄ 运行结果

⛄ 参考文献

[1] 朱仁杰, 唐仕浩, 刘彤彤,等. 基于改进SIR模型的新型冠状病毒肺炎疫情预测及防控对疫情发展的影响[J]. 陕西师范大学学报:自然科学版, 2020, 48(3):6.

[2] 康观龙, 柳炳祥. 基于SIR模型的新型冠状病毒肺炎预测分析[J]. 中阿科技论坛(中英文), 2020, 000(006):P.151-153.

[3] 丁美丽, 彭润龙, 郭荣伟. 基于传染病模型的新冠肺炎传播问题研究[J]. 齐鲁工业大学学报, 2020, 34(6):9.

[4] 祁冬, 姜研, 姚传顺,等. 单能量技术结合ASIR-V算法在疑似新型冠状病毒肺炎患者行低剂量CT扫描中的应用价值[J]. 中国中西医结合影像学杂志, 2020, 018(005):453-457.

⛳️ 代码获取关注我

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
3月前
|
数据可视化
基于MATLAB的OFDM调制发射与接收仿真
基于MATLAB的OFDM调制发射与接收仿真
|
2月前
|
5G
基于IEEE 802.11a标准的物理层MATLAB仿真
基于IEEE 802.11a标准的物理层MATLAB仿真
174 0
|
2月前
|
算法
基于MATLAB/Simulink平台搭建同步电机、异步电机和双馈风机仿真模型
基于MATLAB/Simulink平台搭建同步电机、异步电机和双馈风机仿真模型
|
2月前
|
机器学习/深度学习 算法 数据可视化
基于MVO多元宇宙优化的DBSCAN聚类算法matlab仿真
本程序基于MATLAB实现MVO优化的DBSCAN聚类算法,通过多元宇宙优化自动搜索最优参数Eps与MinPts,提升聚类精度。对比传统DBSCAN,MVO-DBSCAN有效克服参数依赖问题,适应复杂数据分布,增强鲁棒性,适用于非均匀密度数据集的高效聚类分析。
|
2月前
|
开发框架 算法 .NET
基于ADMM无穷范数检测算法的MIMO通信系统信号检测MATLAB仿真,对比ML,MMSE,ZF以及LAMA
简介:本文介绍基于ADMM的MIMO信号检测算法,结合无穷范数优化与交替方向乘子法,降低计算复杂度并提升检测性能。涵盖MATLAB 2024b实现效果图、核心代码及详细注释,并对比ML、MMSE、ZF、OCD_MMSE与LAMA等算法。重点分析LAMA基于消息传递的低复杂度优势,适用于大规模MIMO系统,为通信系统检测提供理论支持与实践方案。(238字)
|
3月前
|
机器学习/深度学习 传感器 算法
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
214 2
|
3月前
|
监控
基于MATLAB/Simulink的单机带负荷仿真系统搭建
使用MATLAB/Simulink平台搭建一个单机带负荷的电力系统仿真模型。该系统包括同步发电机、励磁系统、调速系统、变压器、输电线路以及不同类型的负荷模型。
459 5
|
3月前
|
传感器 机器学习/深度学习 编解码
【电缆】中压电缆局部放电的传输模型研究(Matlab代码实现)
【电缆】中压电缆局部放电的传输模型研究(Matlab代码实现)
131 3
|
3月前
|
机器学习/深度学习 边缘计算 算法
【无人机】无人机群在三维环境中的碰撞和静态避障仿真(Matlab代码实现)
【无人机】无人机群在三维环境中的碰撞和静态避障仿真(Matlab代码实现)
186 0
|
2月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
213 0

热门文章

最新文章