QQ登录

只需要一步,快速开始

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

    % I& t& j$ m9 B% H0 e; z0 }指数模型
    0 r5 R2 ?0 u9 a定义已感染人数为i(t) i(t)i(t),假设每个病人单位时间有效接触(足以使人致病)的人数为λ \lambdaλ,那么,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
    8 \! g* [# ~. l$ Q9 i6 pi(t+Δt)−i(t)=λi(t)Δt i(t+\Delta t) - i(t) = \lambda i(t)\Delta t- s: m8 k$ |& p
    i(t+Δt)−i(t)=λi(t)Δt4 M) M8 u- E8 y% J
    1 d9 ~% h$ U5 h1 A
    将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式' u! n2 Q+ I0 `! X  B( Q
    i(t+Δt)=i(t)+λi(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)\Delta t, w# z+ n: a& R- Y7 x: X
    i(t+Δt)=i(t)+λi(t)Δt, n$ R( Q+ H  p# l

    6 z. [: G, P3 ?1 }2 x0 C, B. e- f: X以上递推公式意味着,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下。: S0 \' V: c+ C+ i, V8 ~. M4 |0 d

    ) G, [* m  g7 [% z! m" R$ zimport matplotlib.pyplot as plt7 _3 l; W) w9 V. x$ ]# q
    %matplotlib inline
    3 ]$ r4 f0 |+ F- ~/ ddeltaT = 0.01
    7 E; n% `% n; B$ ?8 l% M* V' P/ blamb = 22 z. E: y0 ?) Y, ~6 f- N( O
    i_list = []
    ' `9 N# K% o+ g; Y( ]: ai0 = 0.08; # 初始有8%的人患病
    % _( J( K8 }$ G/ o$ h, \i_list.append(i0)1 L: {7 L' G. o9 h# \1 I/ Q
    Tot_Time = 10' i' h& l" e- a, g
    TotStep = int(Tot_Time/deltaT)
      O/ b' r" a: c' `# o, ]## % o  X! V: I& A
    for i in range(TotStep):
    ; b# O9 A1 I$ m    i_new = i_list[-1] + lamb * i_list[-1] * deltaT
    - B7 C2 D* W. I2 }5 F: e    i_list.append(i_new)
    5 ]" ]0 c: q- A1 Z1 C* vplt.plot(i_list)
    * w, _  ?5 i/ K  }- C6 q9 g1 M# b4 E5 `! A6 f% f) v1 [
    将以上代码在Jupyter Notebook中运行,得到病人人数的变化趋势见下图,从中我们可以看到病人的增长是指数级的,在短短十天后,已经有3000万人患病!这显然不符合实际情况的,那么问题出在哪里了呢?
    4 m9 q: ]. F0 E( I" V3 M4 N3 S* x3 h, e

    / D7 H( R- ]; b5 N3 ]. p5 J实际上,若病人解除的是病人,并不能够使病人再次患病,实际上以上的算法导致了重复计数现象的发生。解决办法:必须区分已感染者和未感染者。  K2 R7 [6 X  O

    0 y3 c: e6 B+ o$ B7 y9 d3 \SI模型8 i; Y5 {& C. H$ X4 h* w3 Z
    现在我们将人群分成两个群体:已感染者(病人,Infected)和未感染者(健康者,Suspect),该模型称为SI模型,模型假设:- {& c4 O* \% r( V$ ~* m* ~8 U! o

    3 D; U. i* J- f! B) I在研究时间内,不考虑死亡率和出生率,即总人数N NN不变,病人和健康人的比例分别为i(t) i(t)i(t)和s(t) s(t)s(t)
    - v( |; R$ I7 [每个病人在单位时间内有效接触并致病的人数为λ \lambdaλ,且只有接触健康人才会致病,称λ \lambdaλ为日接触率9 L5 h9 ^7 q8 ~5 R  R" [1 b& P; W
    仿照指数模型里面的建模方法,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
    % E% H# d5 Z2 h5 \
    ! t' c/ ^' `3 n( f5 V7 I1 [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% T1 O1 x: M% M  K  H3 k
    N[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt5 P  Z" Y7 A6 B2 u) @) H7 K( V7 F& {
    ) f9 Q  i. S0 Z' m$ V; P4 M. H& g
    消去N NN,再将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式! J7 U) v% J+ |( x
    i(t+Δt)=i(t)+λi(t)s(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)s(t)\Delta t1 }2 A( g& [8 @9 w# n
    i(t+Δt)=i(t)+λi(t)s(t)Δt
    0 U+ q. q; }4 t3 {" \
    3 t) ?- @8 f1 c: f& Y+ c, P同样地,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下:
    ( V5 N& O2 S! z; k& y* ]
    ( ?8 `1 C1 l3 w7 _1 Q+ qimport matplotlib.pyplot as plt
    4 ?9 E, v3 G* o3 K! w# [7 d%matplotlib inline
    . N4 J2 x2 N/ N, K0 {8 y3 R9 MdeltaT = 0.01
    * m% `& H* U5 Olamb = 2) E: P8 s- [. j" I
    i_list = []) v0 W# E$ h  u6 T' X) v
    s_list = []
    ( A3 B, l, L' k' z- L, Oi0 = 0.08; # 初始有8%的人患病! p  M3 V; j+ T1 g  t3 Y- R$ f
    i_list.append(i0)
    # q" [3 R7 z( b. Q. bs_list.append(1 - i0)
    3 v  {$ n4 i% N/ P/ e6 ATot_Time =5
    ! A* A( W& I$ A0 V- F  vTotStep = int(Tot_Time/deltaT)8 f6 e6 ~* c* Z* N
    ## 8 D, _- K6 b' Q, j
    for i in range(TotStep):
    " J7 ^% T- t: I. C1 ^6 R$ y9 r    i_new = i_list[-1] + lamb * i_list[-1] * deltaT * s_list[-1], N/ L4 W' I; U" |5 K# y2 h
        i_list.append(i_new)
    1 j" s6 n! u/ c2 C    s_list.append(1- i_new)
    , Z! p5 e! l2 p4 zTime = [i * deltaT for i in range(TotStep + 1)]( i6 h4 l- v$ m% i- G5 f  J: s& A
    plt.plot(Time,i_list)! t1 _1 Y& p' C/ x, @- Z
    plt.plot(Time,s_list)
    1 A4 B: a6 q- i' @2 D4 }plt.title("SI",fontsize = 20)- S( u0 _, x0 M: e
    plt.xlabel("Time")% b" i8 }+ m# Y; ]+ T5 v' J. t
    plt.ylabel('i(t)')2 `6 W# H: c/ K5 j# {5 W
    ( B& @# V$ R9 n: V) i! c' W* ~
    从SI模型我们可以看到,病人比例不再会出现"指数爆炸"的情况,在t→∞ t \rightarrow \inftyt→∞时最大患病比例为1。在SI模型中,病人数量的增长曲线是一个典型的S型曲线,又称为Logistic曲线,该曲线在生物学上经常被用来描述物种的增长模。
    " v( x0 `5 T+ E! [
      A% a/ b- T- s  e2 A3 `然后,SI模型的结论告诉我们,无论λ \lambdaλ多么小,最终人群都会患病,这显然也是不符合实际情况的。
    ; ]! f, w" b1 l9 Q0 y————————————————
    0 v  H1 o5 r6 V; g版权声明:本文为CSDN博主「任公子ha」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    2 k% w8 T" I1 Z$ }原文链接:https://blog.csdn.net/baidu_26746963/article/details/93918383, ~5 w0 |& J+ O! L* N) V+ b
    2 P4 [  k$ i/ m: A
    6 l. I( y" B4 Q& T
    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 17:27 , Processed in 0.305729 second(s), 51 queries .

    回顶部