QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2124|回复: 0
打印 上一主题 下一主题

数学建模中的传染病模型及其编程求解

[复制链接]
字体大小: 正常 放大
浅夏110 实名认证       

542

主题

15

听众

1万

积分

  • TA的每日心情
    开心
    2020-11-14 17:15
  • 签到天数: 74 天

    [LV.6]常住居民II

    邮箱绑定达人

    群组2019美赛冲刺课程

    群组站长地区赛培训

    群组2019考研数学 桃子老师

    群组2018教师培训(呼伦贝

    群组2019考研数学 站长系列

    跳转到指定楼层
    1#
    发表于 2020-5-17 09:59 |只看该作者 |正序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    问题的提出
    2 z  p" @" X: P( O% O, |4 l2 C医生们发现,在一个民族或地区,当某种传染病流传时,波及到的总人数大体上保持为一个常数。即既非所有人都会得病也非毫无规律,两次流行(同种疾病)的波及人数不会相差太大。如何解释这一现象呢?试用建模方法来加以证明。/ N, ]  k& |( g1 @

    : Z9 X, C: y& x$ O% b# P) M% I指数模型
    7 j! e; n5 b/ [$ |定义已感染人数为i(t) i(t)i(t),假设每个病人单位时间有效接触(足以使人致病)的人数为λ \lambdaλ,那么,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算6 S( C& X, M* a$ ?% i
    i(t+Δt)−i(t)=λi(t)Δt i(t+\Delta t) - i(t) = \lambda i(t)\Delta t
    ; D$ d( i8 Z* }* Di(t+Δt)−i(t)=λi(t)Δt
    9 |4 L" j3 l/ g( }4 ^$ z1 G* |, ?0 ]5 r7 t/ S7 N; ?; K
    将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式, e/ J  L% J( P0 D0 F
    i(t+Δt)=i(t)+λi(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)\Delta t, H. x" c. k6 l
    i(t+Δt)=i(t)+λi(t)Δt
      Q2 m8 H5 z, |, x6 T7 f# u  G3 b5 `3 p3 B1 B2 F
    以上递推公式意味着,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下。
    2 j+ z7 h4 L. _
    / @$ m" v' A, h7 Qimport matplotlib.pyplot as plt6 |$ \  X4 |& K- B, P: G6 b$ _
    %matplotlib inline
    7 Q; p: F! e/ J+ C0 ~' N% ~deltaT = 0.01
    1 V& `0 E: J8 u# Glamb = 2
    0 J0 V: f2 X8 _6 s+ pi_list = []" S' F+ q* W8 z4 l  Y  |
    i0 = 0.08; # 初始有8%的人患病
    * O7 J/ U% O. O1 d' H  l2 X" mi_list.append(i0)
    9 b4 F) I: R0 wTot_Time = 10: Q1 n) A" `1 h& b. y
    TotStep = int(Tot_Time/deltaT)+ n2 B: o* s3 m( N' c% o: m
    ## & P: Y8 {. ]" x- M1 v; v
    for i in range(TotStep):
    + o4 [2 Q' j9 G    i_new = i_list[-1] + lamb * i_list[-1] * deltaT
    * I  R7 p9 \+ r* ?: f4 x    i_list.append(i_new)
    2 h4 f: h3 ~5 I% l- ~- z- L8 xplt.plot(i_list)0 Z" H) Z$ g! c+ w2 M

    7 ^9 I3 ?4 _0 x& X2 k. t将以上代码在Jupyter Notebook中运行,得到病人人数的变化趋势见下图,从中我们可以看到病人的增长是指数级的,在短短十天后,已经有3000万人患病!这显然不符合实际情况的,那么问题出在哪里了呢?
    5 q7 d9 j+ Y! x, V8 I. g: X7 D8 Z9 T/ X8 r
    7 Q, _$ P# E% T, ~: t& a' z' ?
    实际上,若病人解除的是病人,并不能够使病人再次患病,实际上以上的算法导致了重复计数现象的发生。解决办法:必须区分已感染者和未感染者。2 K/ Q( L; F; `4 J* Z
    1 b% b' R# _2 s' @4 a9 W3 H% R
    SI模型$ {+ J" r9 ]& P0 P" Y1 P
    现在我们将人群分成两个群体:已感染者(病人,Infected)和未感染者(健康者,Suspect),该模型称为SI模型,模型假设:
    2 ]# U9 |" R8 w1 o2 d
    ' D  v+ l9 A8 c1 U' c: ~5 \% q- S在研究时间内,不考虑死亡率和出生率,即总人数N NN不变,病人和健康人的比例分别为i(t) i(t)i(t)和s(t) s(t)s(t)
    3 C# f! k2 `7 j2 y每个病人在单位时间内有效接触并致病的人数为λ \lambdaλ,且只有接触健康人才会致病,称λ \lambdaλ为日接触率
      o+ S. Q0 S7 P' ~( A0 V5 |4 s8 w6 n仿照指数模型里面的建模方法,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算: B8 {5 l7 D1 v: C: A8 u
    3 r3 _/ i( T1 M% D2 D; t
    N[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt N[i(t+\Delta t)-i(t)]=[\lambda s(t)] N i(t) \Delta t1 w8 x2 d, q1 p( P; W
    N[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt
    ( {6 C/ f  W1 K1 L' O0 a3 T+ p* w  \
    ; \6 D, t" M4 [  S  o; }消去N NN,再将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式- j" h1 ^, s- ?* @& N, W7 F
    i(t+Δt)=i(t)+λi(t)s(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)s(t)\Delta t
    8 S  g) q- O) ui(t+Δt)=i(t)+λi(t)s(t)Δt
    ' Q2 M/ D2 F- ~+ [# z& l1 A) K) c  A4 L
    同样地,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下:
    ! p+ Q. q) E4 p6 y: t0 V! ^0 a  R0 a9 K* F: `
    import matplotlib.pyplot as plt; `. J6 l3 r* Z9 f& }
    %matplotlib inline$ j) y9 Q+ b) }- o# q
    deltaT = 0.01
    : Q# X1 L9 k0 U4 jlamb = 2
      h9 k7 ?+ M$ L: _/ z4 Li_list = []" x- q0 \6 X! ^$ X2 v' ]% t, n
    s_list = []
    ) x' y* v7 v0 D9 si0 = 0.08; # 初始有8%的人患病4 k3 a* }9 W& f5 d! z/ l4 ?
    i_list.append(i0)
    , Q" Q* U, C* J# b0 z- N( Us_list.append(1 - i0). n8 `4 f) i+ q
    Tot_Time =5, K. t9 W1 L. \1 t1 K+ t) g2 y( @
    TotStep = int(Tot_Time/deltaT)( a$ l8 g0 o* L' `# O/ z
    ## $ ^8 N/ Z" u1 E; P8 S
    for i in range(TotStep):7 u- }- K: c! x! l, Z
        i_new = i_list[-1] + lamb * i_list[-1] * deltaT * s_list[-1]
    2 R  p3 R" ~& @) Z/ O; H% m+ e/ s    i_list.append(i_new)' b9 M9 Q% e, ~' H5 H2 u
        s_list.append(1- i_new)
    8 {0 _3 U& {2 A, Q" ETime = [i * deltaT for i in range(TotStep + 1)]
    3 ^/ E- x% K% V/ f' ?4 Tplt.plot(Time,i_list)* A  v4 g2 f' Z6 q, {, f
    plt.plot(Time,s_list)1 |( f7 ?2 [8 D* M
    plt.title("SI",fontsize = 20)  M6 N6 P+ e- B* w, |
    plt.xlabel("Time")
    ( P4 h' i% I6 K6 T  cplt.ylabel('i(t)')$ G  D, O, J$ O6 K

    , l( c, e" Z) p2 g, M5 x/ h从SI模型我们可以看到,病人比例不再会出现"指数爆炸"的情况,在t→∞ t \rightarrow \inftyt→∞时最大患病比例为1。在SI模型中,病人数量的增长曲线是一个典型的S型曲线,又称为Logistic曲线,该曲线在生物学上经常被用来描述物种的增长模。
    . b$ N# s) ]$ k' U
      g, k; `' e) s+ u5 f3 _9 j& l然后,SI模型的结论告诉我们,无论λ \lambdaλ多么小,最终人群都会患病,这显然也是不符合实际情况的。
    : J/ V0 v, F- t3 u8 i2 i( D- O! x  v————————————————' ]" L4 c/ X2 {8 i( C
    版权声明:本文为CSDN博主「任公子ha」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。9 K0 I7 o5 ?" n1 [9 \! b
    原文链接:https://blog.csdn.net/baidu_26746963/article/details/93918383
    " V5 v! y* D6 h# C/ z( o* o1 l6 D* _; A% N, r" f
    3 P/ Q; ], p( J
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-9 20:24 , Processed in 0.376265 second(s), 51 queries .

    回顶部