QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2075|回复: 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 |邮箱已经成功绑定
    问题的提出0 |' D8 I1 v1 x
    医生们发现,在一个民族或地区,当某种传染病流传时,波及到的总人数大体上保持为一个常数。即既非所有人都会得病也非毫无规律,两次流行(同种疾病)的波及人数不会相差太大。如何解释这一现象呢?试用建模方法来加以证明。
    * Q0 r4 ~4 {1 e3 u( E3 N
    8 i; z3 }* z$ X3 y指数模型  ?% R6 Q8 @; h3 q1 b6 E
    定义已感染人数为i(t) i(t)i(t),假设每个病人单位时间有效接触(足以使人致病)的人数为λ \lambdaλ,那么,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算0 J; r/ \  c( e( @
    i(t+Δt)−i(t)=λi(t)Δt i(t+\Delta t) - i(t) = \lambda i(t)\Delta t) ~5 D2 C) E6 \
    i(t+Δt)−i(t)=λi(t)Δt# f% o) c) P- \

    / Z/ }5 t1 j4 c9 @) U& F) c将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式
    2 w/ a% P. o  D" hi(t+Δt)=i(t)+λi(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)\Delta t
    ' P; E! n4 n8 k+ }7 li(t+Δt)=i(t)+λi(t)Δt. W4 B8 Y9 q7 _( X/ ?

    % n- B7 H$ ]3 O; K6 _以上递推公式意味着,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下。4 |- u5 N! }; R$ z/ q$ e( n' |0 U
    : g' `5 k# K% K7 ?+ J
    import matplotlib.pyplot as plt$ I, I; O0 A' X# g# p- _! z
    %matplotlib inline
    ' t$ v& t  C" O/ cdeltaT = 0.01
    & M  u, B/ F! C7 i/ `6 @8 U9 Rlamb = 21 j& ]9 N5 [1 Z* R. }4 C$ Z
    i_list = []% z* i0 o  g; C, x* r2 ]' Q6 x% E* L
    i0 = 0.08; # 初始有8%的人患病
    ; C; l1 V& ?- e8 P' y, r0 @i_list.append(i0)) U0 M  g6 y1 l4 I  T5 a0 z
    Tot_Time = 10
    # f8 _3 V. d1 i# ]; Q9 vTotStep = int(Tot_Time/deltaT)
    : p$ \; v3 |$ b$ s##
    5 m4 n8 S" D8 E0 [3 xfor i in range(TotStep):! g2 j* k4 t7 @7 m
        i_new = i_list[-1] + lamb * i_list[-1] * deltaT8 Y  r1 k" T; N* w( L1 I# U
        i_list.append(i_new)
    5 ~$ x. G4 ~7 W* i9 `plt.plot(i_list)- k: O/ i4 j' j# A
    2 q3 R( u8 b! i' e
    将以上代码在Jupyter Notebook中运行,得到病人人数的变化趋势见下图,从中我们可以看到病人的增长是指数级的,在短短十天后,已经有3000万人患病!这显然不符合实际情况的,那么问题出在哪里了呢?
    & d6 U# ^8 }# z2 {
    % w  F% r, V1 W4 J, S6 G/ v# H
    & \- d9 b' f2 _* u1 C, d实际上,若病人解除的是病人,并不能够使病人再次患病,实际上以上的算法导致了重复计数现象的发生。解决办法:必须区分已感染者和未感染者。
    + A3 |: N" `6 S6 M7 _4 i8 n. Y: U& R: r/ [
    SI模型. Z+ w9 d7 }! r* \) N
    现在我们将人群分成两个群体:已感染者(病人,Infected)和未感染者(健康者,Suspect),该模型称为SI模型,模型假设:
    . u0 G7 ]0 q7 ~0 G5 A$ j' T$ P, y" v* Z1 n
    在研究时间内,不考虑死亡率和出生率,即总人数N NN不变,病人和健康人的比例分别为i(t) i(t)i(t)和s(t) s(t)s(t)
    7 r' L$ H# ^8 S4 _$ \0 {每个病人在单位时间内有效接触并致病的人数为λ \lambdaλ,且只有接触健康人才会致病,称λ \lambdaλ为日接触率6 s( ]* [* n+ a0 {+ V6 L
    仿照指数模型里面的建模方法,在时间段Δt \Delta tΔt内,病人的增量可以用如下的公式进行计算
    2 J- K4 J. e, D" T5 Y5 W% [
    7 Z; K% O! i( `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' t" _4 h5 ]; v3 o" X' g. ~- I# [* w
    N[i(t+Δt)−i(t)]=[λs(t)]Ni(t)Δt! m' A8 }/ |' U' c

    , _0 W" \4 {+ D消去N NN,再将i(t) i(t)i(t)移到等式的右边,我们得到如下的递推公式
    , ~# v) U/ j% v7 Pi(t+Δt)=i(t)+λi(t)s(t)Δt i(t+\Delta t) = i(t) + \lambda i(t)s(t)\Delta t
    0 q) d: i- V2 w; y. z* \) R# Li(t+Δt)=i(t)+λi(t)s(t)Δt$ c3 V' q2 x  m

    0 ^0 X2 E! u" p4 O$ E" p同样地,我们可以通过当前时刻的病人人数和致病参数λ \lambdaλ,计算得到Δt \Delta tΔt时间后的病人人数,将以上思想在Python中进行实现,代码如下:2 h1 s5 t9 F& N. l: ^; P- @

    / f2 \! \+ Q; t, ?+ R/ h/ ^9 rimport matplotlib.pyplot as plt* C  L- H7 ^- L+ R! R
    %matplotlib inline6 N; \# [) X( ?6 m, R% G3 ~' F4 ?
    deltaT = 0.01
    ' J. n* f2 o/ W- ]! k7 q: Mlamb = 2% S, K7 C4 X. U7 _( H3 b
    i_list = []
      `8 {) s' g8 y/ ^+ @" V# ns_list = []
    3 ]1 M& q7 C" k4 j& `i0 = 0.08; # 初始有8%的人患病
    1 f8 ~5 l; ~: c# Mi_list.append(i0)! u, N7 K' F& K
    s_list.append(1 - i0)
    + ]; J3 g4 e0 U( m! oTot_Time =5
    $ X6 L3 }/ S3 n$ VTotStep = int(Tot_Time/deltaT)
    7 |7 Y* ?9 \" `4 F# ^8 n9 b! D4 L##
    , M- U2 w; T( c0 zfor i in range(TotStep):7 ?- G* e) r; Z6 J' l" w+ V
        i_new = i_list[-1] + lamb * i_list[-1] * deltaT * s_list[-1]
    1 Y8 {; G5 R+ {( o0 H    i_list.append(i_new)4 T  S! E: E/ c$ J6 [7 W
        s_list.append(1- i_new)
    1 ~) D5 Y* y4 w- Q3 bTime = [i * deltaT for i in range(TotStep + 1)]
    3 k, `$ r+ ?( Yplt.plot(Time,i_list)
    0 g9 m7 g) r0 y/ P( x4 wplt.plot(Time,s_list)
    0 e. |2 ?2 @( ^2 Y0 r% aplt.title("SI",fontsize = 20)/ z- s! N: l, m1 ~' f
    plt.xlabel("Time")
    9 v, q3 M: L/ [; m! H. Q6 V; `plt.ylabel('i(t)')
    - s' s7 N5 ?% v7 F
    ! }' ~3 c$ S' R- w' ^; A从SI模型我们可以看到,病人比例不再会出现"指数爆炸"的情况,在t→∞ t \rightarrow \inftyt→∞时最大患病比例为1。在SI模型中,病人数量的增长曲线是一个典型的S型曲线,又称为Logistic曲线,该曲线在生物学上经常被用来描述物种的增长模。) M) P- Q$ M# Y7 K
    - B$ m0 A9 o4 v/ W/ Z; w0 d
    然后,SI模型的结论告诉我们,无论λ \lambdaλ多么小,最终人群都会患病,这显然也是不符合实际情况的。
    5 |- x9 E4 I/ B6 l+ M. ^0 H————————————————
    7 M' s' ]* D5 t7 W: j; S版权声明:本文为CSDN博主「任公子ha」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。9 g# B! h5 |$ s& w% X( _3 t" A2 ~
    原文链接:https://blog.csdn.net/baidu_26746963/article/details/93918383+ h! x7 U# a% h0 D
    ' {  j: t# U/ F1 X. y; E  O

    : ^1 C4 g- v- e( i
    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, 2025-12-30 00:10 , Processed in 0.533656 second(s), 50 queries .

    回顶部