QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2131|回复: 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 |邮箱已经成功绑定
    问题的提出, O9 ]& P' Z% F- @
    医生们发现,在一个民族或地区,当某种传染病流传时,波及到的总人数大体上保持为一个常数。即既非所有人都会得病也非毫无规律,两次流行(同种疾病)的波及人数不会相差太大。如何解释这一现象呢?试用建模方法来加以证明。' o$ Z. |8 F: l: D

    + p8 w: g' P* Z1 A/ l: C2 M指数模型
    * u& u/ Q: B$ ~6 N7 {定义已感染人数为i(t) i(t)i(t),假设每个病人单位时间有效接触(足以使人致病)的人数为λ \lambdaλ,那么,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
    & {$ f' n9 |( x9 e4 ^2 s' li(t+Δt)−i(t)=λi(t)Δt i(t+\Delta t) - i(t) = \lambda i(t)\Delta t
    2 q' B2 k% g' _* R9 Oi(t+Δt)−i(t)=λi(t)Δt- v( q# `0 z2 F% U  e! [& r
    0 v" L/ C5 L+ e! v( p& n
    将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式) M4 I+ \$ Q" \% S
    i(t+Δt)=i(t)+λi(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)\Delta t  _0 h. V- g0 W- A
    i(t+Δt)=i(t)+λi(t)Δt
    0 R( }) v" j& L5 }6 ^, `8 X9 V' s( }; b
    以上递推公式意味着,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下。
    - p! ^- w( u6 g0 o3 k( B9 a' V6 Q8 x; T& h
    import matplotlib.pyplot as plt
    & k# v# i6 i6 W8 }9 P8 @8 A; D%matplotlib inline
    ) {' ]% z* W  C" w! FdeltaT = 0.01
    " u& d" X+ X5 Flamb = 2: k' N, H2 Z) R/ r5 T% f/ x
    i_list = []
    ) U" s) ^, {( s( yi0 = 0.08; # 初始有8%的人患病) m! ]. t6 L" o! |0 N- T' i
    i_list.append(i0)  f) l0 F# r" U7 n8 k: v& @' [
    Tot_Time = 109 J$ d0 i, l0 q+ Z
    TotStep = int(Tot_Time/deltaT)6 F% ]) X  u- r. j
    ## / L% B5 _0 M* M1 c2 U
    for i in range(TotStep):; V4 G! k( R. W. G
        i_new = i_list[-1] + lamb * i_list[-1] * deltaT
    5 [# e7 L0 ~- y7 {    i_list.append(i_new)1 v  ~' o$ U, w  o
    plt.plot(i_list)
    + H8 V2 i# X, q+ _4 l
    1 Y" {, h/ X& Y* c2 s2 t5 x: `将以上代码在Jupyter Notebook中运行,得到病人人数的变化趋势见下图,从中我们可以看到病人的增长是指数级的,在短短十天后,已经有3000万人患病!这显然不符合实际情况的,那么问题出在哪里了呢?8 S$ @! K8 E+ H4 m+ F

    & T% y( w& q3 x, v6 N4 c5 T& M0 T' }. P
    实际上,若病人解除的是病人,并不能够使病人再次患病,实际上以上的算法导致了重复计数现象的发生。解决办法:必须区分已感染者和未感染者。
    0 Q0 |/ C, n* |0 i' L4 h5 K+ }. y7 R
    SI模型5 K2 b6 y( X  ~/ n& O
    现在我们将人群分成两个群体:已感染者(病人,Infected)和未感染者(健康者,Suspect),该模型称为SI模型,模型假设:- V1 J* }" t( M

    $ H8 \7 U, F7 g0 ?在研究时间内,不考虑死亡率和出生率,即总人数N NN不变,病人和健康人的比例分别为i(t) i(t)i(t)和s(t) s(t)s(t)  n6 ^% E0 r/ [8 w
    每个病人在单位时间内有效接触并致病的人数为λ \lambdaλ,且只有接触健康人才会致病,称λ \lambdaλ为日接触率$ F& f( @' x  X2 n; k5 \" p% k
    仿照指数模型里面的建模方法,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
    $ ^% Y5 l/ `1 i& Y' C
    # n+ B# w8 l- l5 @2 ^  W1 Z5 VN[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt N[i(t+\Delta t)-i(t)]=[\lambda s(t)] N i(t) \Delta t, N) u9 q8 L/ H& {1 J5 y& K
    N[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt; x0 R# J" d* q  B
    - g% s7 w, c0 k9 }+ C) J# {- K  W
    消去N NN,再将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式# G3 q3 x! u7 S% o
    i(t+Δt)=i(t)+λi(t)s(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)s(t)\Delta t/ s; x& `! l, J9 N. J/ I
    i(t+Δt)=i(t)+λi(t)s(t)Δt
    7 W( D4 g: `, U8 Q% H7 ?& d) e
    $ ~5 k% b  _6 _8 |2 N8 [, M同样地,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下:& i) {1 v1 X! A( v: k: C
      M* G+ O( A2 u3 _. ?8 N+ d
    import matplotlib.pyplot as plt
    5 \6 f; C5 ~- z. v/ @- p/ Y%matplotlib inline
    8 V: N! f& S2 L( E6 pdeltaT = 0.01$ S* T* W: C, ^6 n& N, m: @
    lamb = 2  n, R7 ]4 j6 Q& g
    i_list = []
    $ l) h8 K$ z! c' s* {7 y8 ws_list = []
    ; N$ o- n' H! r- u% w% x' V6 a+ M2 Xi0 = 0.08; # 初始有8%的人患病
    1 r1 H$ Y1 N* P, bi_list.append(i0)
    ) H) }) n* I  }" ]/ as_list.append(1 - i0)
    5 ]5 J  d1 ]( zTot_Time =5
    : @$ A" C2 N/ J. p6 ~, j% ^4 r8 xTotStep = int(Tot_Time/deltaT)
    + S! G6 Y( ~6 l' f- z( I. [##
    - `1 F4 p" |( M" cfor i in range(TotStep):
    * }1 e0 H1 @7 q# x+ ]6 P0 F% K9 j    i_new = i_list[-1] + lamb * i_list[-1] * deltaT * s_list[-1]
    ; o3 m  s- W8 R( S% l. E; R    i_list.append(i_new)
    " }; {, W! i- g  I, \2 k    s_list.append(1- i_new)
    6 i9 m# B& A7 FTime = [i * deltaT for i in range(TotStep + 1)]/ ]* ]5 S6 O  l, ~9 X+ K7 z
    plt.plot(Time,i_list)
    " p2 o: S. r$ u1 p9 nplt.plot(Time,s_list)
    8 Z/ q$ C- L$ f! h. uplt.title("SI",fontsize = 20)
    $ ]! W! A# p/ l0 rplt.xlabel("Time")
    ) N" U- W7 M4 Z, Y* i* \plt.ylabel('i(t)'); U8 }, N, m6 {/ [1 y' i7 E2 l7 ]

    " D8 E: @* `7 T# g4 h- j从SI模型我们可以看到,病人比例不再会出现"指数爆炸"的情况,在t→∞ t \rightarrow \inftyt→∞时最大患病比例为1。在SI模型中,病人数量的增长曲线是一个典型的S型曲线,又称为Logistic曲线,该曲线在生物学上经常被用来描述物种的增长模。
    " ~+ @: U; p) ~) g& ]0 ~( c! S& @/ s7 k/ p4 t2 E& E3 f, V; }$ k9 F
    然后,SI模型的结论告诉我们,无论λ \lambdaλ多么小,最终人群都会患病,这显然也是不符合实际情况的。
    ; R7 S4 V6 F1 m! c! z' T+ j" J————————————————2 S1 L0 {. ~. U: @8 J: N
    版权声明:本文为CSDN博主「任公子ha」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。- W; i9 L8 M. C
    原文链接:https://blog.csdn.net/baidu_26746963/article/details/93918383) s0 J0 u! ?; `! S. n# o- z

    ' ]& l* v' q, q8 ^0 ^1 \% ~5 N+ ?/ h/ I+ P$ l
    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-14 11:26 , Processed in 0.454324 second(s), 51 queries .

    回顶部