QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2093|回复: 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 |邮箱已经成功绑定
    问题的提出7 x9 ~3 @: h/ B: A
    医生们发现,在一个民族或地区,当某种传染病流传时,波及到的总人数大体上保持为一个常数。即既非所有人都会得病也非毫无规律,两次流行(同种疾病)的波及人数不会相差太大。如何解释这一现象呢?试用建模方法来加以证明。
    6 o% j; A6 q! u2 `3 i- H& f+ e3 Z; G% l# ]% P5 X
    指数模型
    0 s7 _7 d1 [0 i5 h定义已感染人数为i(t) i(t)i(t),假设每个病人单位时间有效接触(足以使人致病)的人数为λ \lambdaλ,那么,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算6 x( J+ n# w3 n0 ]% S
    i(t+Δt)−i(t)=λi(t)Δt i(t+\Delta t) - i(t) = \lambda i(t)\Delta t6 W# B: w' c5 q) n" u
    i(t+Δt)−i(t)=λi(t)Δt: `$ F) V5 h) z' p: }; Y+ ^) `
    3 A, I( x3 Z) z) K0 ]* I2 c; g  q' @- x
    将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式
    8 |7 N& L! ~% ?# H& pi(t+Δt)=i(t)+λi(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)\Delta t% t9 b+ X7 X' X8 j
    i(t+Δt)=i(t)+λi(t)Δt9 Z! s- N  I- T* i4 I) A

    1 A/ c8 t+ N+ E6 o% Z! k, P以上递推公式意味着,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下。
    0 c4 L% ^5 B: y5 j1 u! ?8 V; l# w6 q; l9 X3 h
    import matplotlib.pyplot as plt* `$ g: q! E/ S, p! M
    %matplotlib inline
    # ~. v% m  l& q4 [4 ^6 f' o7 l( c. OdeltaT = 0.01: @1 t4 x5 T2 i/ e3 Q# U# U
    lamb = 2. q- i/ i5 X& V' N$ A( h1 x
    i_list = []) L: @0 r' _' O: b7 K
    i0 = 0.08; # 初始有8%的人患病
    3 c& h3 t& D8 I: O$ g/ Vi_list.append(i0)2 Q3 }8 I  P$ }( V- a! T/ ~
    Tot_Time = 10
    ) j  [1 H$ v* O. d# STotStep = int(Tot_Time/deltaT)
    3 C' T& F+ i' K3 G9 a. s##
    ! b  n7 {( A: H$ j6 Vfor i in range(TotStep):  r1 R! E6 {' `% t- q
        i_new = i_list[-1] + lamb * i_list[-1] * deltaT
    ) w2 ?% i3 \& T    i_list.append(i_new). w0 c5 [& D3 V, j2 U! q# P- L
    plt.plot(i_list)5 b# [8 g2 b. j3 E& i. A( i
    ( v7 N+ @' {, f0 B, c
    将以上代码在Jupyter Notebook中运行,得到病人人数的变化趋势见下图,从中我们可以看到病人的增长是指数级的,在短短十天后,已经有3000万人患病!这显然不符合实际情况的,那么问题出在哪里了呢?
    + ^& {0 O( F/ {3 B( H! M$ u7 d
    " y/ r3 A1 v  r- x- F, Q
    & A+ z( m) S2 ?. I4 [' R+ d, }实际上,若病人解除的是病人,并不能够使病人再次患病,实际上以上的算法导致了重复计数现象的发生。解决办法:必须区分已感染者和未感染者。2 {8 {; s8 E! c" F
    * F; b) W+ ^: t/ K4 r0 p( L
    SI模型( ]! _* I; [7 P
    现在我们将人群分成两个群体:已感染者(病人,Infected)和未感染者(健康者,Suspect),该模型称为SI模型,模型假设:1 K+ @8 t) b* c2 e8 X

    5 z0 |) l) T) S( A! d" M在研究时间内,不考虑死亡率和出生率,即总人数N NN不变,病人和健康人的比例分别为i(t) i(t)i(t)和s(t) s(t)s(t)
    # T+ E' R" \3 r; Q) C每个病人在单位时间内有效接触并致病的人数为λ \lambdaλ,且只有接触健康人才会致病,称λ \lambdaλ为日接触率6 @) Z. o9 O. K1 i% M4 T% H' n
    仿照指数模型里面的建模方法,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
    0 V, d( y0 U5 l2 w/ g8 a
    6 ~+ [4 g- }9 }% j3 ?. x  K% }+ oN[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& z+ R; G1 k& ^# Y, uN[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt3 z* o# V7 }; Y( @, c, s) L# v8 F

    4 C& E# S2 |! v消去N NN,再将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式
    $ [3 d0 \7 h3 \. _; [% Pi(t+Δt)=i(t)+λi(t)s(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)s(t)\Delta t3 D6 u; U# R% J6 z+ r
    i(t+Δt)=i(t)+λi(t)s(t)Δt. L5 H/ u/ p2 R( e; ^) P
    / c7 c- Y/ p: `' n6 c3 I/ N, @
    同样地,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下:. v' N3 R; L6 L( _: D9 u# u

    " d7 O5 I8 R6 T+ a$ Bimport matplotlib.pyplot as plt
    7 y8 j+ @9 _% _2 O& c%matplotlib inline# h4 _" ?8 o5 o( S* }  S0 P
    deltaT = 0.01
    - ~  I6 V& _( p- o+ E6 Y# t1 x* plamb = 22 w/ N5 p$ H2 e! V
    i_list = []6 l9 \+ d9 H3 U3 j' I% o
    s_list = []
    3 y! ~; B% ]4 f# r/ l8 q( [i0 = 0.08; # 初始有8%的人患病4 X& A7 ?, F) f# I/ R0 _2 s
    i_list.append(i0)) n3 |6 R: Q) c1 R
    s_list.append(1 - i0)" S; f% s; ]+ e) }
    Tot_Time =51 _; g, A4 S3 O0 s# R3 _
    TotStep = int(Tot_Time/deltaT)6 W1 c: D0 {9 j, f
    ##
      n+ \% E' f' Y4 u# c" p' P9 Y" ]for i in range(TotStep):
    7 t# D1 {% a: s' b: H1 a    i_new = i_list[-1] + lamb * i_list[-1] * deltaT * s_list[-1]8 Q* {$ `& z7 U
        i_list.append(i_new)
    * ?( E7 }9 D' v8 o- g    s_list.append(1- i_new)+ Z/ C- m. b. `& D' A0 X7 i& h
    Time = [i * deltaT for i in range(TotStep + 1)]' V9 g: ]0 m) e- n# ~7 j; S
    plt.plot(Time,i_list)
    2 ]9 J8 w3 {2 U+ h- A7 ?! m5 _plt.plot(Time,s_list)2 k6 h% \: U! N9 v7 b
    plt.title("SI",fontsize = 20)
    # O5 A& _( Q8 d2 r. gplt.xlabel("Time")! |& y" F% T$ T  Y: b
    plt.ylabel('i(t)')
    ) A# Y* U2 \0 ~" R. u
    , m7 @* H$ _8 n8 A& f从SI模型我们可以看到,病人比例不再会出现"指数爆炸"的情况,在t→∞ t \rightarrow \inftyt→∞时最大患病比例为1。在SI模型中,病人数量的增长曲线是一个典型的S型曲线,又称为Logistic曲线,该曲线在生物学上经常被用来描述物种的增长模。2 Z1 N/ R) @' {4 e7 W( v3 [5 ~
    * B, ~; Z1 k4 M# r( K. }/ t+ s
    然后,SI模型的结论告诉我们,无论λ \lambdaλ多么小,最终人群都会患病,这显然也是不符合实际情况的。
    . A8 F' M' m1 @————————————————4 e8 C* k) N$ l. \
    版权声明:本文为CSDN博主「任公子ha」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    + Y7 A- S7 K+ q1 s4 G7 J9 s7 L原文链接:https://blog.csdn.net/baidu_26746963/article/details/93918383
    ( i7 f6 r' Q9 S/ {0 v9 L: s
    * a" A8 |  g: Z
      @8 W$ S6 @! j$ G# @1 f/ h
    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-4-20 05:40 , Processed in 0.557420 second(s), 51 queries .

    回顶部