QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2122|回复: 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 |邮箱已经成功绑定
    问题的提出; s4 l0 ]: L% u4 t+ k: x% t7 `$ x
    医生们发现,在一个民族或地区,当某种传染病流传时,波及到的总人数大体上保持为一个常数。即既非所有人都会得病也非毫无规律,两次流行(同种疾病)的波及人数不会相差太大。如何解释这一现象呢?试用建模方法来加以证明。
    0 V, h7 }7 ]+ D+ [# P1 N7 [7 {5 y3 s$ _+ ~' J
    指数模型- C4 i& |0 N! `* P; ~: L
    定义已感染人数为i(t) i(t)i(t),假设每个病人单位时间有效接触(足以使人致病)的人数为λ \lambdaλ,那么,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算& r; T/ X- d. R
    i(t+Δt)−i(t)=λi(t)Δt i(t+\Delta t) - i(t) = \lambda i(t)\Delta t
    ' e7 j6 Q; \, r2 ^( qi(t+Δt)−i(t)=λi(t)Δt: e) P" h/ h- b1 ]9 G
    5 Z: K: Y( q; P  h+ ^
    将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式$ X, U. b2 @, O. j2 h* L' U1 g7 M
    i(t+Δt)=i(t)+λi(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)\Delta t7 P, m8 @: U! l; G# h) B7 }
    i(t+Δt)=i(t)+λi(t)Δt  Y" [9 d$ a; N. z' y- O$ O8 a, U

    ! O: r+ x6 G& b+ g+ n: j5 \以上递推公式意味着,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下。. Y5 z$ l5 Y0 [

    * D. x6 I7 m( ?" k& K& `import matplotlib.pyplot as plt" E: M+ o& G6 L% D4 B3 I. U
    %matplotlib inline7 L7 g9 u0 W% ]
    deltaT = 0.01( n9 t, @4 X9 X+ u& l) }
    lamb = 2
    $ R" b. s8 }0 n# s2 F3 ^) Fi_list = []
    ! K( \- U' ]8 l" `i0 = 0.08; # 初始有8%的人患病
    $ s9 U5 G$ L3 `* u! p3 ~( x) qi_list.append(i0)
    7 c7 l$ ]" q) y7 S: J  \( A. D1 x, |Tot_Time = 10- m3 p$ W& |  J% \: L
    TotStep = int(Tot_Time/deltaT)& p3 A& M+ z# F: j7 ^0 u
    ##
    8 N, `2 c7 Y8 p) l$ cfor i in range(TotStep):
    " m$ U6 _! m- d5 c/ m7 e) s    i_new = i_list[-1] + lamb * i_list[-1] * deltaT
    9 E* n9 _) z" _. U: E- Q2 B; k    i_list.append(i_new)
    2 J% R" z& a% j' tplt.plot(i_list)
    ( R- f3 K3 s: f& V9 K0 @+ f3 Z8 d3 c
    将以上代码在Jupyter Notebook中运行,得到病人人数的变化趋势见下图,从中我们可以看到病人的增长是指数级的,在短短十天后,已经有3000万人患病!这显然不符合实际情况的,那么问题出在哪里了呢?
    ( v7 H9 l! {0 Y  y# }
    ; P. V0 D! O* M7 v  j3 o
      {' W, ~& ?/ Z; J" ~实际上,若病人解除的是病人,并不能够使病人再次患病,实际上以上的算法导致了重复计数现象的发生。解决办法:必须区分已感染者和未感染者。* P8 g8 G( r$ V8 H& Q. H1 ?% `3 r/ J

    , }, U  J  Z3 `9 R/ kSI模型
    - \. S/ k1 T1 G& Q现在我们将人群分成两个群体:已感染者(病人,Infected)和未感染者(健康者,Suspect),该模型称为SI模型,模型假设:
    7 |. q# W1 e( R7 W. R
    ; }1 C' [/ ]0 J' A! C2 ?* O在研究时间内,不考虑死亡率和出生率,即总人数N NN不变,病人和健康人的比例分别为i(t) i(t)i(t)和s(t) s(t)s(t)
    ! `$ U- c7 V) G, J( D每个病人在单位时间内有效接触并致病的人数为λ \lambdaλ,且只有接触健康人才会致病,称λ \lambdaλ为日接触率
    ; U* O3 Y; d/ V1 R. j仿照指数模型里面的建模方法,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算, P- I. e5 q- ]! ~
    & o5 e" u0 h5 ~, ?1 J) \
    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 t
    : @* B( e; |2 X' d9 KN[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt
      A' l6 G) Q0 _' x) [# Y/ }* i3 q/ O, C) Y. A% p1 d* a
    消去N NN,再将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式
    ! \; [8 a. r/ Z$ q8 t9 di(t+Δt)=i(t)+λi(t)s(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)s(t)\Delta t
    , g4 ~' t8 |6 d8 N2 x& o+ D$ yi(t+Δt)=i(t)+λi(t)s(t)Δt# x2 R0 k3 x* h2 Q; r$ a8 {" ]' \

    " e9 g' Z8 ?8 s& [$ m同样地,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下:
    ) a' }3 m6 ]  E% a6 t5 o4 r* m. r+ H+ z
    import matplotlib.pyplot as plt  {6 f2 d: Z8 y3 ]  v
    %matplotlib inline- b4 e+ X0 C8 ^, `$ G
    deltaT = 0.01
    % Y3 E# X3 b6 \: G1 ^& }' @- h  Elamb = 2
    - ?, m5 {' r$ \) J5 ni_list = []
    ; w3 y0 w; ?, R/ z: _6 B, ys_list = []( E6 p0 k) [4 N4 x: ~4 X0 B
    i0 = 0.08; # 初始有8%的人患病
    1 c+ O& y. I0 [% j  ]/ j# H7 ji_list.append(i0); A) a4 {+ H& W. U' c$ H: p
    s_list.append(1 - i0)3 Y+ K  G% Q+ F) A! j0 R
    Tot_Time =5
    . E) T! Y. O: l0 G7 F" e) E) RTotStep = int(Tot_Time/deltaT)
    / r7 ]- p# l5 K3 L% u" E##
    % C& Q) f- t  s( ofor i in range(TotStep):
    3 L- _+ A' _% D- \) P+ u$ f9 V    i_new = i_list[-1] + lamb * i_list[-1] * deltaT * s_list[-1]
    # g% }+ o9 |4 `0 U: K4 |, i    i_list.append(i_new)' o8 Z% x6 T/ _7 b! C4 N
        s_list.append(1- i_new)4 ?/ y9 d" x  f* R
    Time = [i * deltaT for i in range(TotStep + 1)]
    . h3 `3 H9 t6 g" K8 v3 y1 q7 Rplt.plot(Time,i_list)
    1 D( c0 f$ A% ^2 m& ]* oplt.plot(Time,s_list)
    6 g1 m( Q1 b& T  I: V1 hplt.title("SI",fontsize = 20)
    % b: l" {$ N( Rplt.xlabel("Time")
    . Y0 |. @# i0 W& ~% c" E$ Q' J" _! Aplt.ylabel('i(t)')2 M6 @& k8 W2 t! u! l; |

    ' b) w% I/ ~0 f. b$ O! K0 G) _7 ~! q从SI模型我们可以看到,病人比例不再会出现"指数爆炸"的情况,在t→∞ t \rightarrow \inftyt→∞时最大患病比例为1。在SI模型中,病人数量的增长曲线是一个典型的S型曲线,又称为Logistic曲线,该曲线在生物学上经常被用来描述物种的增长模。2 D6 h( Z4 N* u- h, A# P  V- Y

    ) ~3 q* q) L1 V/ |! W然后,SI模型的结论告诉我们,无论λ \lambdaλ多么小,最终人群都会患病,这显然也是不符合实际情况的。9 X. e  |! s7 ^
    ————————————————2 W8 \' r; o" b/ y, t! u% H
    版权声明:本文为CSDN博主「任公子ha」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    / s' ^5 K, ^7 h8 o原文链接:https://blog.csdn.net/baidu_26746963/article/details/93918383
    ! T) ?/ k+ L- T% R# X0 q! Q, x$ U0 k* p" V- j) F  D) g

    ! N6 G& K; c% |& U
    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 18:42 , Processed in 0.377890 second(s), 51 queries .

    回顶部