传染病的数学模型是数学建模中的典型问题,常见的传染病模型有 SI、SIR、SIRS、SEIR 模型。html
SI 模型是最简单的传染病模型,适用于只有易感者和患病者两类人群。python
咱们就从 SI 模型开始吧,从模型、例程、运行结果到模型分析,全都在这个系列中。算法
『Python小白的数学建模课 @ Youcans』带你从数模小白成为国赛达人。编程
Python小白的数学建模课-09.微分方程模型
Python小白的数学建模课-B2.新冠疫情 SI模型
Python小白的数学建模课-B3.新冠疫情 SIS模型
Python小白的数学建模课-B4.新冠疫情 SIR模型
Python小白的数学建模课-B5.新冠疫情 SEIR模型
Python小白的数学建模课-B6.改进 SEIR疫情模型数组
新冠疫情不只严重影响到全球的政治和经济,深入和全面地影响着社会和生活的方方面面,也已经成为数学建模竞赛的背景帝。ide
传染病的数学模型是数学建模中的典型问题,标准名称是流行病的数学模型(Mathematical models of epidemic diseases)。创建传染病的数学模型来描述传染病的传播过程,研究传染病的传播速度、空间范围、传播途径、动力学机理等问题,以指导对传染病的有效地预防和控制,具备重要的现实意义。函数
不一样类型传染病的传播具备不一样的特色,传染病的传播模型不是从医学角度分析传染病的传播过程,而是按照传播机理创建不一样的数学模型。工具
首先,把传染病流行范围内的人群分为 S、E、I、R 四类,具体含义以下:学习
S 类(Susceptible),易感者,指缺少免疫能力的健康人,与感染者接触后容易受到感染;spa
E 类(Exposed),暴露者,指接触过感染者但暂无传染性的人,适用于存在潜伏期的传染病;
I 类(Infectious),患病者,指具备传染性的患病者,能够传播给 S 类成员将其变为 E 类或 I 类成员;
R 类(Recovered),康复者,指病愈后具备免疫力的人。若是免疫期有限,仍能够从新变为 S 类成员,进而被感染;若是是终身免疫,则不能再变为 S类、E类或 I 类成员。
常见的传染病模型按照传染病类型分为 SI、SIR、SIRS、SEIR 模型等,就是由以上四类人群根据不一样传染病的特征进行组合而产生的不一样模型。
SI 模型适用于只有易感者和患病者两类人群,且没法治愈的疾病,例如 T型病、僵尸。
由
得:
这是 Logistic 模型,用分离变量法能够求出其解析解为:
上文已经获得 SI 模型的解析解,对此很容易经过 Python 编程实现,详见本文例程。
虽然 SI 模型的解析解并不复杂,并且解的精度固然是最好的,但咱们仍然不鼓励用解析解的方法。缘由在于,一是对于小白求解析解的过程相对复杂困难,并且可能出错,二是对于更复杂的模型是没有解析解的,即使大神也只能用数值方法求解。既然如此,不如从一开始就学习、掌握数值求解方法,熟悉数值解法的编程实现。
SI 模型是常微分方程初值问题,可使用 Scipy 工具包的 scipy.integrate.odeint() 函数求数值解,具体方法能够参考前文《Python小白的数学建模课-09 微分方程模型》。
scipy.integrate.odeint(func, y0, t, args=())
**scipy.integrate.odeint() **是求解微分方程的具体方法,经过数值积分来求解常微分方程组。
odeint() 的主要参数:
odeint() 的返回值:
odeint() 的编程步骤:
# 1. SI 模型,常微分很是,解析解与数值解的比较 from scipy.integrate import odeint # 导入 scipy.integrate 模块 import numpy as np # 导入 numpy包 import matplotlib.pyplot as plt # 导入 matplotlib包 def dy_dt(y, t, lamda, mu): # 定义导数函数 f(y,t) dy_dt = lamda*y*(1-y) # di/dt = lamda*i*(1-i) return dy_dt # 设置模型参数 number = 1e7 # 总人数 lamda = 1.0 # 日接触率, 患病者天天有效接触的易感者的平均人数 mu1 = 0.5 # 日治愈率, 天天被治愈的患病者人数占患病者总数的比例 y0 = i0 = 1e-6 # 患病者比例的初值 tEnd = 50 # 预测日期长度 t = np.arange(0.0,tEnd,1) # (start,stop,step) yAnaly = 1/(1+(1/i0-1)*np.exp(-lamda*t)) # 微分方程的解析解 yInteg = odeint(dy_dt, y0, t, args=(lamda,mu1)) # 求解微分方程初值问题 yDeriv = lamda * yInteg *(1-yInteg) # 绘图 plt.plot(t, yAnaly, '-ob', label='analytic') plt.plot(t, yInteg, ':.r', label='numerical') plt.plot(t, yDeriv, '-g', label='dy_dt') plt.title("Comparison between analytic and numerical solutions") plt.legend(loc='right') plt.axis([0, 50, -0.1, 1.1]) plt.show()
本图为例程 2.3 的运行结果,图中对解析解(蓝色)与使用 odeint() 获得的数值解(红色)进行比较。在该例中,没法观察到解析解与数值解的差别,代表数值解的偏差很小。
图中 \(di/dt\) 具备最大值,最大值表示疫情增加的高潮,达到最大值后 \(di/dt\) 逐渐减少,但患病者比例很快增加到 100%,代表全部人都被感染成为患者。
这是特定参数的结果,仍是模型的必然趋势,须要对参数的影响进行更详细的研究。
对于 SI 模型,只有日接触率 \(\lambda\) 和患病者比例的初值 \(i_0\) 会影响模型的结果,其它参数如总人数 N 并无影响。
对不一样日接触率的比较代表:
对患病者比例初值的比较代表,患病者初值的人数或比例只影响疫情爆发期到来的快慢,对疫情传播的过程和结果几乎没有影响。
这与咱们直观的经验不太一致,一个缘由是 SI 模型自己存在不足,另外一方面也说明若是对传染病不加控制,即便开始患病人数不多,通过一段时间的传播后也终将会引发爆发。
【本节完】
版权声明:
欢迎关注『Python小白的数学建模课 @ Youcans』 原创做品
原创做品,转载必须标注原文连接:(https://www.cnblogs.com/youcans/p/14944259.html)。
Copyright 2021 Youcans, XUPT
Crated:2021-06-09
欢迎关注 『Python小白的数学建模课 @ Youcans』,每周更新数模笔记
Python小白的数学建模课-01.新手必读
Python小白的数学建模课-02.数据导入
Python小白的数学建模课-03.线性规划
Python小白的数学建模课-04.整数规划
Python小白的数学建模课-05.0-1规划
Python小白的数学建模课-06.固定费用问题
Python小白的数学建模课-07.选址问题
Python小白的数学建模课-09.微分方程模型
Python小白的数学建模课-B2.新冠疫情 SI模型
Python数模笔记-PuLP库
Python数模笔记-StatsModels统计回归
Python数模笔记-Sklearn
Python数模笔记-NetworkX
Python数模笔记-模拟退火算法