QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2095|回复: 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 |邮箱已经成功绑定
    问题的提出
      q: s7 R1 ]& ^. x* \! s医生们发现,在一个民族或地区,当某种传染病流传时,波及到的总人数大体上保持为一个常数。即既非所有人都会得病也非毫无规律,两次流行(同种疾病)的波及人数不会相差太大。如何解释这一现象呢?试用建模方法来加以证明。
    6 A3 @: n% y$ n: B( ?& l& B% \+ p* d& M7 S) ]7 P
    指数模型8 e7 @" ^5 z* Y9 B
    定义已感染人数为i(t) i(t)i(t),假设每个病人单位时间有效接触(足以使人致病)的人数为λ \lambdaλ,那么,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
      ~% o6 c; @" s  ]i(t+Δt)−i(t)=λi(t)Δt i(t+\Delta t) - i(t) = \lambda i(t)\Delta t" d5 \5 p9 p% i- y$ z
    i(t+Δt)−i(t)=λi(t)Δt
    8 X* V4 _! @' j' O, Q- \$ r. k0 Y* o$ e5 [9 S# F9 |' t8 ]' f+ o
    将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式3 n0 o3 l( i+ L' z0 A
    i(t+Δt)=i(t)+λi(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)\Delta t
    + `( q1 u. G4 Z( O: x9 ^8 u! mi(t+Δt)=i(t)+λi(t)Δt( W& y1 {( S; ]6 [
    $ Y$ s2 W) H& ?4 e7 N
    以上递推公式意味着,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下。
    4 {, I- A3 \- R2 c% }# w( }! U$ a$ S# {% B& h# u
    import matplotlib.pyplot as plt9 y, ~, V( v/ r, o
    %matplotlib inline
    ) B; ~9 z7 P8 }( A6 z+ S! g% j  {) }deltaT = 0.01
    + _2 N# I* I" }2 A0 j. {lamb = 2- R5 f# k8 u$ ~/ N$ y7 H
    i_list = []
    , C: b; [+ A" i* {2 O4 `4 j7 B0 E3 Si0 = 0.08; # 初始有8%的人患病
    ; q$ _" O# G& {3 ?9 {& h( y/ x  Si_list.append(i0): F6 a: ]2 v- [8 B: s3 N
    Tot_Time = 101 c/ l0 j. Q' [; v. [/ M" [4 l
    TotStep = int(Tot_Time/deltaT)
    4 c" U" y4 N/ `. ]) @( V## $ K8 j: s! Y: x5 x0 \0 l
    for i in range(TotStep):
    4 y) [/ s; X$ R3 C: o- B/ f8 r5 l    i_new = i_list[-1] + lamb * i_list[-1] * deltaT) X/ u" _: \- K, U0 m+ i* }
        i_list.append(i_new)
    & j& Q6 t9 ^. t9 d+ m4 F. o7 mplt.plot(i_list)+ Y: J$ N( a. w* Q$ g

    7 b. j8 I! {3 ~& s5 H5 O6 n3 O将以上代码在Jupyter Notebook中运行,得到病人人数的变化趋势见下图,从中我们可以看到病人的增长是指数级的,在短短十天后,已经有3000万人患病!这显然不符合实际情况的,那么问题出在哪里了呢?
    - p2 a0 W2 x2 }/ b6 J$ n
    5 s: L( S8 A1 c+ b
    * m( {1 ~9 Q7 [* F8 [& L% r9 |. D8 F: V" O实际上,若病人解除的是病人,并不能够使病人再次患病,实际上以上的算法导致了重复计数现象的发生。解决办法:必须区分已感染者和未感染者。
    ( y$ g; g, J3 X, O# p8 L- ?0 A2 j& @& ^
    SI模型% h, A: @7 |3 W' h
    现在我们将人群分成两个群体:已感染者(病人,Infected)和未感染者(健康者,Suspect),该模型称为SI模型,模型假设:
    " _* A! ~# c3 w& c% D1 _2 N4 e3 M$ I( q" e& R
    在研究时间内,不考虑死亡率和出生率,即总人数N NN不变,病人和健康人的比例分别为i(t) i(t)i(t)和s(t) s(t)s(t): b3 P; ~$ }( ]4 m
    每个病人在单位时间内有效接触并致病的人数为λ \lambdaλ,且只有接触健康人才会致病,称λ \lambdaλ为日接触率
    8 o% x" M( z/ d. |  T; O' @- f仿照指数模型里面的建模方法,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
    5 B: b- S5 D; N8 d* e
    : v6 R2 [9 H$ e) E+ a, t6 c: K4 LN[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt N[i(t+\Delta t)-i(t)]=[\lambda s(t)] N i(t) \Delta t3 q3 o& m+ [  e" v; R! Q
    N[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt
    " B* k4 F, w! c( B. ~7 l$ z5 g) o% A  N2 h5 n) `. i
    消去N NN,再将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式
    ( M. A$ M/ `+ ?; |i(t+Δt)=i(t)+λi(t)s(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)s(t)\Delta t' a) E3 `) f, P9 R+ {% s
    i(t+Δt)=i(t)+λi(t)s(t)Δt% N3 Y; q/ e) H3 |5 ?$ I

    7 ]% Q. Z& B3 B6 _4 O同样地,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下:5 g: f+ [5 x/ l. ?/ g5 U

    , P$ `0 @% a3 d1 I% ~2 w6 H: J' kimport matplotlib.pyplot as plt
    ; K# E# r# d! A! `1 Z%matplotlib inline0 _+ r# a6 ]1 j/ `$ u$ [7 f
    deltaT = 0.010 Q8 m: u+ Z$ T3 k( e' i
    lamb = 2
    - N, C, K; j: Qi_list = []& V# |( _/ Q+ o5 \2 O  R' S& Y
    s_list = []
    / b3 i( w4 _$ j' A- Pi0 = 0.08; # 初始有8%的人患病- l8 p% R5 [9 c; v; F) ?
    i_list.append(i0)
    : S  Y! b' F4 Q2 rs_list.append(1 - i0)0 k) o' l4 _4 t5 i  I+ D
    Tot_Time =56 l) Z1 c+ K: P1 }
    TotStep = int(Tot_Time/deltaT)! I3 Q# {1 }# ]* f
    ## ( y; p* ~8 F! T2 g3 _' h7 ?+ G) [
    for i in range(TotStep):
    / x2 ]" I2 x' R" c    i_new = i_list[-1] + lamb * i_list[-1] * deltaT * s_list[-1]& {' }, S; V+ Z
        i_list.append(i_new)7 i4 F; L0 ^$ U3 \! y% L1 E
        s_list.append(1- i_new)
    - F6 [. s& W( r- j$ yTime = [i * deltaT for i in range(TotStep + 1)]! u) `" B% f" q7 d5 w1 k3 {
    plt.plot(Time,i_list)2 {! _( R; A( U' |0 S2 B: g
    plt.plot(Time,s_list)! N3 N  W' X/ Q/ F5 x& v. }( Q2 z4 }
    plt.title("SI",fontsize = 20)
    / e1 ?; v0 P: f  Iplt.xlabel("Time")
    " a- X/ H6 ^: jplt.ylabel('i(t)')% N' p& C/ m( F5 x( K; A- y+ q" ^

      `$ f+ g; m. @8 ?7 Q从SI模型我们可以看到,病人比例不再会出现"指数爆炸"的情况,在t→∞ t \rightarrow \inftyt→∞时最大患病比例为1。在SI模型中,病人数量的增长曲线是一个典型的S型曲线,又称为Logistic曲线,该曲线在生物学上经常被用来描述物种的增长模。
    5 ?" p$ R" X2 g, b6 N% w# }8 C1 o
    . ~* v$ W3 R5 S! G0 c5 i然后,SI模型的结论告诉我们,无论λ \lambdaλ多么小,最终人群都会患病,这显然也是不符合实际情况的。
    % q( C. f$ D# g2 y————————————————+ h. P/ L+ I+ b2 v4 j
    版权声明:本文为CSDN博主「任公子ha」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。5 c6 L2 R& N1 m  p
    原文链接:https://blog.csdn.net/baidu_26746963/article/details/93918383
    ) }) @) m+ _' Z. I
    " L( N/ E0 N" H9 Z* n) q" q  A7 M( X9 E
    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 07:52 , Processed in 0.409326 second(s), 51 queries .

    回顶部