Python小白的数学建模课-B5. 新冠疫情 SEIR模型


传染病的数学模型是数学建模中的典型问题,常见的传染病模型有 SI、SIR、SIRS、SEIR 模型。

考虑存在易感者、暴露者、患病者和康复者四类人群,适用于具有潜伏期、治愈后获得终身免疫的传染病。

本文详细给出了 SEIR 模型微分方程的建模、例程、结果和分析,让小白都能懂。

『Python小白的数学建模课 @ Youcans』带你从数模小白成为国赛达人。

欢迎关注『Python小白的数学建模课 @ Youcans』系列,每周持续更新
Python小白的数学建模课-B2. 新冠疫情 SI模型
Python小白的数学建模课-B3. 新冠疫情 SIS模型
Python小白的数学建模课-B4. 新冠疫情 SIR模型
Python小白的数学建模课-B5. 新冠疫情 SEIR模型
Python小白的数学建模课-B6. 新冠疫情 SEIR改进模型
Python小白的数学建模课-09.微分方程模型
Python小白的数学建模课-10.微分方程边值问题



1. SEIR 模型

1.1 SEIR 模型的提出

建立传染病的数学模型来描述传染病的传播过程,要根据传染病的发病机理和传播规律, 结合疫情数据进行拟合分析,可以认识传染病的发展趋势,预测疫情持续时间和规模,分析和模拟各种防控措施对疫情发展的影响程度, 为传染病防控工作提供决策指导,具有重要的理论意义和现实意义。

SI 模型是最简单的传染病传播模型,把人群分为易感者(S 类)和患病者(I 类)两类,通过 SI 模型可以预测传染病高潮的到来;提高卫生水平、强化防控手段,降低病人的日接触率,可以推迟传染病高潮的到来。在 SI 模型基础上发展的 SIS 模型考虑患病者可以治愈而变成易感者,SIS 模型表面传染期接触数 σ\sigmaσ 是传染病传播和防控的关键指标,决定了疫情终将清零或演变为地方病长期存在。在 SI 模型基础上考虑病愈免疫的康复者(R 类)就得到 SIR 模型,通过 SIR 模型也揭示传染期接触数 σ\sigmaσ 是传染病传播的阈值,满足 s0>1/σs_0>1/\sigmas0>1/σ 才会发生传染病蔓延,由此可以分析各种防控措施,如:提高卫生水平来降低日接触率λ\lambdaλ、提高医疗水平来提高日治愈率 μ\muμ,通过预防接种达到群体免疫来降低 s0s_0s0 等。

传染病大多具有潜伏期(incubation period),也叫隐蔽期,是指从被病原体侵入肌体到最早临床症状出现的一段时间。在潜伏期的后期一般具有传染性。不同的传染病的潜伏期长短不同,从短至数小时到长达数年,但同一种传染病有固定的(平均)潜伏期。例如,流感的潜伏期为 1~3天,冠状病毒感染的潜伏期为4~7天,新型冠状病毒肺炎传染病(COVID-19)的潜伏期为1-14天(* 来自:新型冠状病毒肺炎诊疗方案试行第八版,潜伏时间 1~14天,多为3~7天,在潜伏期具有传染性),肺结核的潜伏期从数周到数十年。

SEIR 模型考虑存在易感者(Susceptible)、暴露者(Exposed)、患病者(Infectious)和康复者(Recovered)四类人群,适用于具有潜伏期、治愈后获得终身免疫的传染病。易感者(S 类)被感染后成为潜伏者(E类),随后发病成为患病者(I 类),治愈后成为康复者(R类)。这种情况更为复杂,也更为接近实际情况。

SEIR 模型的仓室结构示意图如下:

在这里插入图片描述

1.2 SEIR 模型假设

  1. 考察地区的总人数 N 不变,即不考虑生死或迁移;

  2. 人群分为易感者(S 类)、暴露者(E 类)、患病者(I 类)和康复者(R 类)四类;

  3. 易感者(S 类)与患病者(I 类)有效接触即变为暴露者(E 类),暴露者(E 类)经过平均潜伏期后成为患病者(I 类);患病者(I 类)可被治愈,治愈后变为康复者(R 类);康复者(R类)获得终身免疫不再易感;

  4. 将第 t 天时 S 类、E 类、I 类、R 类人群的占比记为 s(t)s(t)s(t)e(t)e(t)e(t)i(t)i(t)i(t)r(t)r(t)r(t),数量分别为 S(t)S(t)S(t)E(t)E(t)E(t)I(t)I(t)I(t)R(t)R(t)R(t);初始日期 t=0t=0t=0 时,各类人群占比的初值为 s0s_0s0e0e_0e0i0i_0i0r0r_0r0

  5. 日接触数 λ\lambdaλ,每个患病者每天有效接触的易感者的平均人数;

  6. 日发病率 δ\deltaδ,每天发病成为患病者的暴露者占暴露者总数的比例;

  7. 日治愈率 μ\muμ,每天被治愈的患病者人数占患病者总数的比例,即平均治愈天数为 1/μ1/\mu1/μ

  8. 传染期接触数 σ=λ/μ\sigma = \lambda / \muσ=λ/μ,即每个患病者在整个传染期内有效接触的易感者人数。


1.3 SEIR 模型的微分方程


{Ndsdt=−NλsiNdedt=Nλsi−NδeNdidt=Nδe−NμiNdrdt=Nμi\begin{cases} N \frac{ds}{dt} = - N \lambda s i\\ N \frac{de}{dt} = N \lambda s i - N \delta e\\ N \frac{di}{dt} = N \delta e - N \mu i\\ N \frac{dr}{dt} = N \mu i\\ \end{cases} Ndtds=NλsiNdtde=NλsiNδeNdtdi=NδeNμiNdtdr=Nμi
得:
{dsdt=−λsi,s(0)=s0dedt=λsi−δe,e(0)=e0didt=δe−μi,i(0)=i0\begin{cases} \frac{ds}{dt} = -\lambda s i, &s(0)=s_0\\ \frac{de}{dt} = \lambda s i - \delta e, &e(0)=e_0\\ \frac{di}{dt} = \delta e - \mu i, &i(0)=i_0 \end{cases} dtds=λsi,dtde=λsiδe,dtdi=δeμi,s(0)=s0e(0)=e0i(0)=i0

SEIR 模型不能求出解析解,可以通过数值计算方法求解。


2. SEIR 模型的 Python 编程

2.1 Scipy 工具包求解微分方程组

SIS 模型是常微分方程初值问题,可以使用 Scipy 工具包的 scipy.integrate.odeint() 函数求数值解。

scipy.integrate.odeint(func, y0, t, args=())

**scipy.integrate.odeint() **是求解微分方程的具体方法,通过数值积分来求解常微分方程组。

odeint() 的主要参数:

  • func: callable(y, t, …)   导数函数 f(y,t)f(y,t)f(y,t) ,即 y 在 t 处的导数,以函数的形式表示
  • y0: array:  初始条件 y0y_0y0,注意 SEIR模型是二元常微分方程组, 初始条件为数组向量 y0=[i0,s0]y_0=[i_0, s_0]y0=[i0,s0]
  • t: array:  求解函数值对应的时间点的序列。序列的第一个元素是与初始条件 y0y_0y0 对应的初始时间 t0t_0t0;时间序列必须是单调递增或单调递减的,允许重复值。
  • args: 向导数函数 func 传递参数。当导数函数 f(y,t,p1,p2,..)f(y,t,p1,p2,..)f(y,t,p1,p2,..) 包括可变参数 p1,p2… 时,通过 args =(p1,p2,…) 可以将参数p1,p2… 传递给导数函数 func。

odeint() 的返回值:

  • y: array   数组,形状为 (len(t),len(y0),给出时间序列 t 中每个时刻的 y 值。

2.2 odeint() 求解 SEIR 模型的编程步骤

  1. 导入 scipy、numpy、matplotlib 包。
  2. 定义导数函数 f(y,t)f(y,t)f(y,t)。注意对于常微分方程(例如 SI模型)和常微分方程组(SEIR模型),y 分别表示标量和向量,函数定义略有不同,以下给出两种情况的例程以供对比。

常微分方程的导数定义(SIS模型)

def dySIS(y, t, lamda, mu):  # SIS 模型,导数函数dy_dt = lamda*y*(1-y) - mu*y  # di/dt = lamda*i*(1-i)-mu*ireturn dy_dt

常微分方程组的导数定义(SEIR模型)

def dySEIR(y, t, lamda, delta, mu):  # SEIR 模型,导数函数s, e, i = yds_dt = - lamda*s*i  # ds/dt = -lamda*s*ide_dt = lamda*s*i - delta*e  # de/dt = lamda*s*i - delta*edi_dt = delta*e - mu*i  # di/dt = delta*e - mu*ireturn np.array([ds_dt,de_dt,di_dt])

Python 可以直接对向量、向量函数进行定义和赋值,使程序更为简洁。但考虑读者主要是 Python 小白,又涉及到看着就心烦的微分方程组,所以我们宁愿把程序写得累赘一些,便于读者将程序与前面的微分方程组逐项对应。

  1. 定义初值 y0y_0y0yyy 的定义区间 [t0,t][t_0,\ t][t0, t],注意初值为数组向量 y0=[s0,e0,i0]y_0=[s_0,e_0,i_0]y0=[s0,e0,i0]
  2. 调用 odeint() 求 yyy 在定义区间 [t0,t][t_0,\ t][t0, t] 的数值解。

SEIR 模型是三元常微分方程,返回值 y 是 len(t)*3 的二维数组。


2.3 Python例程:SEIR 模型

# modelCovid4_v1.py
# Demo01 of mathematical modeling for Covid2019
# SIR model for epidemic diseases.
# Copyright 2021 Youcans, XUPT
# Crated:2021-06-13
# Python小白的数学建模课 @ Youcans# 1. SEIR 模型,常微分方程组
from scipy.integrate import odeint  # 导入 scipy.integrate 模块
import numpy as np  # 导入 numpy包
import matplotlib.pyplot as plt  # 导入 matplotlib包def dySIS(y, t, lamda, mu):  # SI/SIS 模型,导数函数dy_dt = lamda*y*(1-y) - mu*y  # di/dt = lamda*i*(1-i)-mu*ireturn dy_dtdef dySIR(y, t, lamda, mu):  # SIR 模型,导数函数s, i = y  # youcansds_dt = -lamda*s*i  # ds/dt = -lamda*s*idi_dt = lamda*s*i - mu*i  # di/dt = lamda*s*i-mu*ireturn np.array([ds_dt,di_dt])def dySEIR(y, t, lamda, delta, mu):  # SEIR 模型,导数函数s, e, i = y  # youcansds_dt = -lamda*s*i  # ds/dt = -lamda*s*ide_dt = lamda*s*i - delta*e  # de/dt = lamda*s*i - delta*edi_dt = delta*e - mu*i  # di/dt = delta*e - mu*ireturn np.array([ds_dt,de_dt,di_dt])# 设置模型参数
number = 1e5  # 总人数
lamda = 0.3  # 日接触率, 患病者每天有效接触的易感者的平均人数
delta = 0.03  # 日发病率,每天发病成为患病者的潜伏者占潜伏者总数的比例
mu = 0.06  # 日治愈率, 每天治愈的患病者人数占患病者总数的比例
sigma = lamda / mu  # 传染期接触数
fsig = 1-1/sigma
tEnd = 300  # 预测日期长度
t = np.arange(0.0,tEnd,1)  # (start,stop,step)
i0 = 1e-3  # 患病者比例的初值
e0 = 1e-3  # 潜伏者比例的初值
s0 = 1-i0  # 易感者比例的初值
Y0 = (s0, e0, i0)  # 微分方程组的初值# odeint 数值解,求解微分方程初值问题
ySI = odeint(dySIS, i0, t, args=(lamda,0))  # SI 模型
ySIS = odeint(dySIS, i0, t, args=(lamda,mu))  # SIS 模型
ySIR = odeint(dySIR, (s0,i0), t, args=(lamda,mu))  # SIR 模型
ySEIR = odeint(dySEIR, Y0, t, args=(lamda,delta,mu))  # SEIR 模型# 输出绘图
print("lamda={}\tmu={}\tsigma={}\t(1-1/sig)={}".format(lamda,mu,sigma,fsig))
plt.title("Comparison among SI, SIS, SIR and SEIR models")
plt.xlabel('t-youcans')
plt.axis([0, tEnd, -0.1, 1.1])
plt.plot(t, ySI, 'cadetblue', label='i(t)-SI')
plt.plot(t, ySIS, 'steelblue', label='i(t)-SIS')
plt.plot(t, ySIR[:,1], 'cornflowerblue', label='i(t)-SIR')
# plt.plot(t, 1-ySIR[:,0]-ySIR[:,1], 'cornflowerblue', label='r(t)-SIR')
plt.plot(t, ySEIR[:,0], '--', color='darkviolet', label='s(t)-SIR')
plt.plot(t, ySEIR[:,1], '-.', color='orchid', label='e(t)-SIR')
plt.plot(t, ySEIR[:,2], '-', color='m', label='i(t)-SIR')
plt.plot(t, 1-ySEIR[:,0]-ySEIR[:,1]-ySEIR[:,2], ':', color='palevioletred', label='r(t)-SIR')
plt.legend(loc='right')  # youcans
plt.show()

2.4 SI /SIS/SIR 模型与SEIR 模型的比较

在这里插入图片描述

例程 2.3 的参数和初值为:λ=0.3,δ=0.03,μ=0.06,(s0,e0,i0)=(0.001,0.001,0.998)\lambda=0.3,\delta=0.03,\mu=0.06,(s_0,e_0,i_0)=(0.001,0.001,0.998)λ=0.3δ=0.03μ=0.06(s0,e0,i0)=(0.001,0.001,0.998),上图为例程的运行结果。

曲线 i(t)-SI 是 SI 模型的结果,患病者比例急剧增长到 1.0,所有人都被传染而变成患病者。

曲线 i(t)-SIS 是 SIS 模型的结果,患病者比例快速增长并收敛到某个常数,即稳态特征值 i∞=1−μ/λ=0.8i_\infty=1-\mu/\lambda = 0.8i=1μ/λ=0.8,表明疫情稳定,并将长期保持一定的患病率,称为地方病平衡点。

曲线 i(t)-SIR 是 SIR 模型的结果,患病者比例 i(t) 先上升达到峰值,然后再逐渐减小趋近于常数。

曲线 s(t)-SEIR、e(t)-SEIR、i(t)-SEIR、r(t)-SEIR 分别表示 SEIR模型中易感者(S类)、潜伏者(E类)、患病者(I类)和康复者(R 类)人群的占比。

图中易感者比例 s(t) 单调递减并收敛到接近于 0 的稳定值。潜伏者比例 e(t) 曲线存在波峰,先逐渐上升而达到峰值,然后再逐渐减小,最终趋于 0。患病者比例 i(t) 曲线与潜伏者比例曲线类似,上升达到峰值后逐渐减小,最终趋于 0;但患病者比例曲线发展、达峰的时间比潜伏者曲线要晚一些,峰值强度也较低。康复者比例 r(i) 单调递增并收敛到非零的稳态值。以上分析只是对本图进行的讨论,并非普遍结论,取决于具体参数条件。

比较相同参数条件下 SIR 和 SEIR 模型的结果,SIR 模型中患病者比例 i(t) 的波形起点、峰值和终点到来的时间都显著早于 SEIR 模型,峰值强度也高于 SEIR 模型。这表明具有潜伏期的传染病,疫情发生和峰值的到来要晚于没有潜伏期的传染病,而且持续时间更长。



3. SEIR 模型参数的影响

SEIR 模型中有日接触率 λ\lambdaλ 、日发病率 δ\deltaδ 和日治愈率 μ\muμ 三个参数,还有 i0、e0、s0i_0、e_0、s_0i0e0s0 等初始条件,我们先用单因素分析的方法来观察参数条件对于疫情传播的影响。

3.1 初值条件 i0、e0、s0i_0、e_0、s_0i0e0s0 初始条件的影响

SEIR 模型中有 i0、e0、s0i_0、e_0、s_0i0e0s0 等 3个初始条件,组合众多无法穷尽。考虑实际情况中,疫情初始阶段尚无康复者,而潜伏者比例往往高于确诊的发病者,我们假定 e0/i0=2,r0=0e_0/i_0=2,r_0=0e0/i0=2r0=0,考察不同 i0i_0i0 时的疫情传播情况。
在这里插入图片描述

通过对于该参数下不同的患病者、潜伏者比例初值条件的模拟,可以看到患病者、潜伏者比例的初值条件对疫情发生、达峰、结束的时间早晚具有直接影响,但对疫情曲线的形态和特征影响不大。不同初值条件下的疫情曲线,几乎是沿着时间指标平移的。

这说明如果不进行治疗防控等人为干预,疫情传播过程与初始患病者、潜伏者比例关系并不大,该来的总会来。

图中患病率达到高峰后逐步降低,直至趋近于 0;易感率在疫情爆发后迅速下降,直至趋近于 0。但这一现象是基于具体的参数条件的观察,仅由该图并不能确定其是否普遍规律。


3.2 日接触率 λ\lambdaλ 的影响

首先考察日接触率 λ\lambdaλ 的影响。

保持参数 δ=0.1,μ=0.06,(i0=0.001,e0=0.002,s0=0.997)\delta =0.1,\mu=0.06, (i_0=0.001,e_0=0.002,s_0=0.997)δ=0.1μ=0.06,(i0=0.001,e0=0.002,s0=0.997) 不变,$\lambda = [0.12, 0.25, 0.5, 1.0, 2.0] $ 时 i(t),s(t)i(t), s(t)i(t),s(t) 的变化曲线如下图所示。
在这里插入图片描述
通过对于该条件下日接触率的单因素分析,可以看到随着日接触率 λ\lambdaλ 的增大,患病率比例 i(t)i(t)i(t) 出现的峰值更早、更强,而易感者比例 s(t)s(t)s(t) 逐渐降低,但最终都趋于稳定。


3.3 日发病率 δ\deltaδ 的影响

下面考察日发病率 δ\deltaδ 的影响。保持参数 λ=0.25,μ=0.06,(i0=0.001,e0=0.002,s0=0.997)\lambda =0.25,\mu=0.06, (i_0=0.001,e_0=0.002,s_0=0.997)λ=0.25μ=0.06,(i0=0.001,e0=0.002,s0=0.997) 不变,$\delta = [0.02, 0.05, 0.1, 0.2, 0.4] $ 时 i(t),s(t)i(t), s(t)i(t),s(t) 的变化曲线如下图所示。
在这里插入图片描述

通过对于该条件下日接触率的单因素分析,可以看到随着日接触率 λ\lambdaλ 的增大,患病率比例 i(t)i(t)i(t) 出现的峰值更早、更强,而易感者比例 s(t)s(t)s(t) 逐渐降低,但最终都趋于稳定。


3.4 日治愈率 μ\muμ 的影响

下面考察日治愈率 μ\muμ 的影响。保持参数 λ=0.25,δ=0.1,(i0=0.001,e0=0.002,s0=0.997)\lambda =0.25,\delta=0.1, (i_0=0.001,e_0=0.002,s_0=0.997)λ=0.25δ=0.1(i0=0.001,e0=0.002,s0=0.997) 不变,$\mu = [0.02, 0.05, 0.1, 0.2, 0.4] $ 时 i(t),s(t)i(t), s(t)i(t),s(t) 的变化曲线如下图所示。
在这里插入图片描述

通过对该条件下日治愈率的单因素分析,可以看到在日治愈率 μ=0.4\mu=0.4μ=0.4 时,患病者比例始终非常低并趋于 0,易感者比例几乎不变,表明疫情不会传播,这是因为患病者治愈的速度快于易感者被感染的速度。

在日治愈率 μ=0.2\mu=0.2μ=0.2 时,患病者比例也始终非常低(接近 0),易感者比例缓慢降低并趋于稳定值,表明疫情的传播十分缓慢微弱,这是因为患病者治愈的速度较快,在易感者比例逐渐降低到某一水平后治愈人数与感染人数将达到平衡。

在日治愈率较低时 (μ<0.2\mu<0.2μ<0.2 ),患病者比例曲线存在波峰,然后再逐渐减小,最终趋于 0。随着日治愈率 μ\muμ 的减小,患病率比例 i(t)i(t)i(t) 曲线的峰值更强、也稍早。易感者比例 s(t)s(t)s(t) 随着患病者比例上升而迅速降低,最终趋于某个稳定值,也达到治愈与感染的平衡。

通过对不同参数的单因素实验和结果分析,可以发现虽然各个模型参数和初始条件都会影响疫情曲线,但日治愈率 与日接触率的关系更为重要。进一步的分析和模拟可以发现,传染期接触数 σ=λ/μ\sigma = \lambda / \muσ=λ/μ是传染病蔓延的阈值,满足 s0>1/σs_0>1/\sigmas0>1/σ 才会发生传染病蔓延。

这说明具有决定性影响的特征参数,往往不是模型中的某个参数,而是多个参数特定关系的组合,仅从单因素实验很难充分反映模型中的内在特征。



4. SEIR 模型的相空间分析

4.1 Python例程:SEIR 模型的相轨迹

# modelCovid4_v1.py
# Demo01 of mathematical modeling for Covid2019
# SIR model for epidemic diseases.
# Copyright 2021 Youcans, XUPT
# Crated:2021-06-15
# Python小白的数学建模课 @ Youcans# 7. SEIR 模型,常微分方程组 相空间分析: e(t)~i(t)
from scipy.integrate import odeint  # 导入 scipy.integrate 模块
import numpy as np  # 导入 numpy包
import matplotlib.pyplot as plt  # 导入 matplotlib包def dySEIR(y, t, lamda, delta, mu):  # SEIR 模型,导数函数s, e, i = yds_dt = -lamda*s*i  # ds/dt = -lamda*s*ide_dt = lamda*s*i - delta*e  # de/dt = lamda*s*i - delta*edi_dt = delta*e - mu*i  # di/dt = delta*e - mu*ireturn np.array([ds_dt,de_dt,di_dt])# 设置模型参数
number = 1e5  # 总人数
lamda = 0.3  # 日接触率, 患病者每天有效接触的易感者的平均人数
delta = 0.1  # 日发病率,每天发病成为患病者的潜伏者占潜伏者总数的比例
mu = 0.1  # 日治愈率, 每天治愈的患病者人数占患病者总数的比例
sigma = lamda / mu  # 传染期接触数
tEnd = 500  # 预测日期长度
t = np.arange(0.0, tEnd, 1)  # (start,stop,step)# e0List = np.arange(0.01,0.4,0.05)  # (start,stop,step)e0List = np.arange(0.01,0.4,0.05)  # (start,stop,step)
for e0 in e0List:# odeint 数值解,求解微分方程初值问题i0 = 0  # 潜伏者比例的初值s0 = 1 - i0 - e0  # 易感者比例的初值ySEIR = odeint(dySEIR, (s0,e0,i0), t, args=(lamda,delta,mu))  # SEIR 模型plt.plot(ySEIR[:,1], ySEIR[:,2])  # (e(t),i(t))print("lamda={}\tdelta={}\mu={}\tsigma={}\ti0={}\te0={}".format(lamda,delta,mu,lamda/mu,i0,e0))# 输出绘图
plt.title("Phase trajectory of SEIR models: e(t)~i(t)")
plt.axis([0, 0.4, 0, 0.4])
plt.plot([0,0.4],[0,0.35],'y--')  #[x1,x2][y1,y2]
plt.plot([0,0.4],[0,0.18],'y--')  #[x1,x2][y1,y2]
plt.text(0.02,0.36,r"$\lambda=0.3, \delta=0.1, \mu=0.1$",color='black')
plt.xlabel('e(t)')
plt.ylabel('i(t)')
plt.show()


4.2 SEIR 模型的相轨迹分析

在这里插入图片描述
在这里插入图片描述
上图为例程 4.2 的运行结果,是 SEIR 模型的相轨迹图。

图中每一条 e-s 曲线,从直线 i(t)+s(t)=1 上的某一初值点出发,最终收敛于 s轴上的某一点,对应着某一个初值条件下的患病者与易感者比例随时间的变化关系。

SEIR 模型的相轨迹图比较复杂,难以在本文展开进行讨论。但是,相轨迹图中的虚线还是反映出了时间变化曲线图中难以表达的一些重要特征,以此为线索可以进行更深入的研究。



5. SEIR 模型结果讨论

最后,我们简单总结一下 SEIR 模型的特点:

  1. SEIR 模型是一个单向模型,易感者(S)不断转变为潜伏者(E),潜伏者(E)发病后成为患病者(I),患病者(I)不断转变为康复者(R),因此易感者比例 s(t) 单调递减,康复者比例 r(i) 单调递增。

  2. SEIR 模型假设潜伏期无传染性,因此潜伏期延迟了传染期的开始,疫情发生和峰值的到来要晚于没有潜伏期的 SIR 模型。但潜伏期不会改变感染人群的累计数量,而且持续时间更长。

  3. 1/σ1/\sigma1/σ 是传染病蔓延的阈值,满足 s0>1/σs_0>1/\sigmas0>1/σ 才会发生传染病蔓延。因此,为了控制传染病的蔓延:一方面要提高阈值 1/σ1/\sigma1/σ,这可以通过提高卫生水平来降低日接触率λ\lambdaλ、提高医疗水平来提高日治愈率 μ\muμ;另一方面要降低 s0s_0s0,这可以通过预防接种达到群体免疫来实现。

  4. 在 SEIR 模型的基础上,可以根据不同传染病病理特征及疫情传播特点,对模型进行进一步的改进,使模型与实际情况更加吻合,以便更准确地预测疫情发展趋势。

  5. 在 SEIR 模型的基础上,可以结合实际的疫情数据来拟合和估计模型参数,进而用来模拟和分析不同治疗方案和防控措施对疫情发展的影响,为新冠疫情的防控工作提供决策指导。


【本节完】

版权声明:

欢迎关注『Python小白的数学建模课 @ Youcans』 原创作品

原创作品,转载必须标注原文链接:(https://blog.csdn.net/youcans/article/details/117932162)。

Copyright 2021 Youcans, XUPT

Crated:2021-06-15



欢迎关注 『Python小白的数学建模课 @ Youcans』 系列,持续更新
Python小白的数学建模课-01.新手必读
Python小白的数学建模课-02.数据导入
Python小白的数学建模课-03.线性规划
Python小白的数学建模课-04.整数规划
Python小白的数学建模课-05.0-1规划
Python小白的数学建模课-06.固定费用问题
Python小白的数学建模课-07.选址问题
Python小白的数学建模课-09.微分方程模型
Python小白的数学建模课-10.微分方程边值问题
Python小白的数学建模课-A1.国赛赛题类型分析
Python小白的数学建模课-A2.2021年数维杯C题探讨
Python小白的数学建模课-A3.12个新冠疫情数模竞赛赛题及短评
Python小白的数学建模课-B2. 新冠疫情 SI模型
Python小白的数学建模课-B3. 新冠疫情 SIS模型
Python小白的数学建模课-B4. 新冠疫情 SIR模型
Python小白的数学建模课-B5. 新冠疫情 SEIR模型
Python小白的数学建模课-B6. 新冠疫情 SEIR改进模型
Python数模笔记-PuLP库
Python数模笔记-StatsModels统计回归
Python数模笔记-Sklearn
Python数模笔记-NetworkX
Python数模笔记-模拟退火算法



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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python小白的数学建模课-B6. 新冠疫情 SEIR 改进模型

传染病的数学模型是数学建模中的典型问题&#xff0c;常见的传染病模型有 SI、SIR、SIRS、SEIR 模型。 SEIR 模型考虑存在易感者、暴露者、患病者和康复者四类人群&#xff0c;适用于具有潜伏期、治愈后获得终身免疫的传染病。 本文详细给出了几种改进 SEIR 模型微分方程的思…

iOS里面MVC模式详解

iOS里面MVC模式详解MVC是IOS里面也是很多程序设计里面的一种设计模式&#xff0c;M是model&#xff0c;V是view&#xff0c;C是controller。MVC模式在ios开发里面可谓是用得淋漓尽致。 以下是对斯坦福大学ios开发里面MVC模式的一段话的翻译 主要的宗旨是把所有的对象分为3个阵营…

Python小白的数学建模课-10.微分方程边值问题

小白往往听到微分方程就觉得害怕&#xff0c;其实数学建模中的微分方程模型不仅没那么复杂&#xff0c;而且很容易写出高水平的数模论文。 本文介绍微分方程模型边值问题的建模与求解&#xff0c;不涉及算法推导和编程&#xff0c;只探讨如何使用 Python 的工具包&#xff0c;…

千帆起航:探索百度智能云千帆AppBuilder在AI原生应用开发中的革新之路

千帆起航&#xff1a;探索百度千帆AppBuilder在AI原生应用开发中的革新之路 1.揭开帷幕&#xff0c;大模型第二次战役 自从 ChatGPT 横空出世后&#xff0c;一石激起千层浪&#xff0c;人工智能也正在从感知理解走向生成创造&#xff0c;这是一个关键里程碑。生成式大模型完成…

iOS开发里面的4个层次

iOS开发里面的4个层次ios开发具体体现为4个层次&#xff0c;你可以看我下面的思维导图。 Media 虽然是媒体层了&#xff0c;然而还是和硬件比较接近。 Core OS 主要是mach 4.x BSD UNIX 内核&#xff0c;也就是Mac OS 10操作系统&#xff0c;一个在硬件上能执行多任务的UNIX内核…

Python小白的数学建模课-12.非线性规划

非线性规划是指目标函数或约束条件中包含非线性函数的规划问题&#xff0c;实际就是非线性最优化问题。从线性规划到非线性规划&#xff0c;不仅是数学方法的差异&#xff0c;更是解决问题的思想方法的转变。非线性规划问题没有统一的通用方法&#xff0c;我们在这里学习的当然…

小程序真机如何清除订阅数据

在做小程序订阅消息开发的过程中发现&#xff0c;真机上如果是选择了‘总是保持以上选择’&#xff0c;一旦用户授权后&#xff0c;后面就不会再弹出申请改订阅消息的授权弹窗&#xff0c;这对于开发过程中是很不方便的。 曾试过清除缓存&#xff0c;重进小程序也不能清除掉 解…

Python小白的数学建模课-15.图论的基本概念

图论中所说的图&#xff0c;不是图形图像或地图&#xff0c;而是指由顶点和边所构成的图形结构。图论不仅与拓扑学、计算机数据结构和算法密切相关&#xff0c;而且正在成为机器学习的关键技术。本系列结合数学建模的应用需求&#xff0c;来介绍 NetworkX 图论与复杂网络工具包…

swift面向对象之属性

swift面向对象之属性 swift属性存储属性 可以存储常量和变量 惰性存储属性 语法&#xff1a;lazy var 变量 惰性存储属性只有在用的时候才会完成真正的初始化&#xff0c;刚开始的初始化代码只是类型占位&#xff0c;并没有分配存储空间。 比如 class people{ var name:Strin…

Python小白的数学建模课-16.最短路径算法

最短路径问题是图论研究中的经典算法问题&#xff0c;用于计算图中一个顶点到另一个顶点的最短路径。在图论中&#xff0c;最短路径长度与最短路径距离却是不同的概念和问题&#xff0c;经常会被混淆。求最短路径长度的常用算法是 Dijkstra 算法、Bellman-Ford 算法和Floyd 算法…

虚拟机(centos)磁盘空间不够

磁盘空间不够 1.关机 2.打开设置-->硬盘 --> 扩展 3.搞定一半 4.开机进入终端 4.1 查看 lsblk 4.2 加起来 growpart /dev/sda 3 注1&#xff1a; 如果 growpart 提示没有的话需要安装一下 yum -y install cloud-utils-growpart 注2&#xff1a;3前面有个空格 4.3 再次…

swift面向对象之方法

swift面向对象之方法 1.下标方法 下标方法仅用于实例&#xff0c;可以在类&#xff0c;结构体&#xff0c;枚举中使用&#xff0c;作用简化类型中的访问方式&#xff0c;注意以下几点 下标方法属于三栖方法&#xff0c;可用于类&#xff0c;结构体和枚举 下标方法的格式为subsc…

Python小白的数学建模课-17.条件最短路径算法

条件最短路径问题&#xff0c;指带有约束条件、限制条件的最短路径问题。例如&#xff1a; 顶点约束&#xff0c;包括必经点或禁止点的限制&#xff1b; 边的约束&#xff0c;包括必经路段、禁行路段和单向路段&#xff1b;无权路径长度的限制&#xff0c;如要求经过几步或不超…

Python小白的数学建模课-18.最小生成树问题

Python小白的数学建模课-18.最小生成树问题 最小生成树&#xff08;MST&#xff09;是图论中的基本问题&#xff0c;具有广泛的实际应用&#xff0c;在数学建模中也经常出现。路线设计、道路规划、官网布局、公交路线、网络设计&#xff0c;都可以转化为最小生成树问题&#xf…

Css表格

Css表格 Css表格 css表格属性可以帮助你极大的改善表格的外观 1.表格内间距 2.折叠边框 border-collapse属性设置是否将表格边框折叠为单一边框&#xff1a; table { border-collapse:collapse; } 3.表格边框 下面的例子为table、th以及td设置了蓝色边框&#xff1a; …

Python小白的数学建模课-19.网络流优化问题

流在生活中十分常见&#xff0c;例如交通系统中的人流、车流、物流&#xff0c;供水管网中的水流&#xff0c;金融系统中的现金流&#xff0c;网络中的信息流。网络流优化问题是基本的网络优化问题&#xff0c;应用非常广泛。网络流优化问题最重要的指标是边的成本和容量限制&a…

Python小白的数学建模课-20.网络流优化案例

在实际工作和数模竞赛中&#xff0c;网络最大流问题、最小费用流问题和最小费用最大流问题都有很多延伸和推广的应用。本文介绍了常见的网络最大流问题、最小费用流问题的应用与推广&#xff0c;及其解题方法。本文选择多源多汇物流转运问题、多商品流问题案例&#xff0c;详细…

HTML文档类型

HTML文档类型 HTML5 <!DOCTYPE html> HTML4.01 <!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 4.01 Transitional//EN” “http://www.w3.org/TR/html4/loose.dtd”> XHTML1.0 <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w…