|
什么是传染病动力学?numpy和matplotlib用python实现传染病模型SI模型SIS模型SIR模型SEIR模型 什么是传染病动力学?最近,在报道疫情的众多新闻中,相信大家也看到过一些来预测新型冠状病毒会导致感染肺炎的人数。你一定好奇,这个人数要怎么预测呢?预测人数又有什么用呢? 事实上,从学科方向来说,这类研究属于传染病动力学,就是用数学模型去描述传染病在人群中传播的规律,从而预测患病人数,进而指导政府制定措施和政策去控制传染病的传播。) g2 N% j$ h% Z( \
这类研究最早可追溯到18世纪Daniel Bernoulli对天花的研究,而我们今天所要介绍的SIR模型是1927年Kermack与McKendrick在为了研究伦敦黑死病而提出的,是传染病动力学中最基础的模型。 介绍了传染病模型的背景信息,不知道现在你对传染病模型更有兴趣,还是执着地对python更有兴趣呢?不论哪种,这篇文章会满足你所有的好奇心。 numpy和matplotlib首先,安装一下这节课我们需要使用的两个python包,numpy和matplotlib。: r* {; G( j' Q0 w" N# C
numpy-是python进行科学和矩阵运算最常用的包。 用numpy建立一维数组,存储和计算每天传染病人数的数据。
$ Z" G7 @, d- n# N/ Q' ]1 @import numpy as np import matplotlib.pyplot as plt 用matplotlib绘制传染病人数随天数变化的曲线,给出模型预测人数变化的直观认识。 好啦,下面开始用python实现传染病模型吧。 用python实现传染病模型为了让大家能够更好地理解,我们先不直接说SIR模型,我们从最简单的开始。 SI模型首先想象这样一个场景,一个城市有 个人,假设没有人出生和死亡,忽然有一天有 个人感染了病毒成为了患者,如果每天每个患者能够有效传染 个人,那么第二天患病人数是多少呢?最简单的答案是: ,也就是说每天都会新增 个患者。那这样以来,在无限远的将来会有无穷多的人被感染,显然这是不合理的,那错在哪里?仔细思考,你一定发现了,已经患病的人就不能再被传染了,所以我们有必要把人群分为两类,易感者(S-susceptiable)和感染者(I-infective)(你猜的没错,这就是SIR中S和I的含义,R的含义之后介绍再讲)。为了之后方便计算我们记易感者和感染者在人群中的比例为 ,那么 。我们重新考虑上面的问题,顺便来个示意图: Image Name这样的话,每天新增的患者数为 ,也就是总传染人数乘以易感者所占的人群比例。1 H; T# z% _8 M
那么每天的感染者比例的增加量就是 。我们假设城市有一千万(N=10的7次方)人,每个患者每天接触感染每天0.8人(lamda=0.8),初始感染人数为45人(i0 = 45/N),我们来模拟70天(T=70)的情况。 # population: V$ ~# [) G6 P" d$ q4 V' v
N = 1e7
2 h5 s9 `. R: |' ?0 I# simuation Time / Day
8 t8 h1 C- g/ x( @" O/ }2 ^" Y RT = 70
1 L4 r. N& k$ v9 X3 c/ S# susceptiable ratio4 P. Z' F; f# L: C
s = np.zeros([T])
- O$ Q: h9 b2 `! j+ P F# infective ratio
! R/ z& I4 g& t' j, r2 Q- ]5 \0 h3 a7 Ni = np.zeros([T])
) `' S% E6 p' \5 L3 |# contact rate
9 B7 [) V' B* \2 }0 F. o& h& @lamda = 0.8
) M7 h7 X. t' h0 K% t5 W! q
5 j" X7 [" k0 J+ _# initial infective people/ ] Q4 [9 s' ]! A
i[0] = 45.0 / N: P V: x& z2 B! H5 W( |
$ c" W5 o3 w/ {
for t in range(T-1):
$ K8 a! r& o, J: k k i[t + 1] = i[t] + i[t] * lamda * (1.0 - i[t])
$ L0 o. D2 `4 m4 r0 B' F, {$ I3 L# t$ W6 }4 h
" y9 A. N }6 y* Q- Q" A" ~, r
- U6 H0 {+ A- {* Q# ~$ k相信其他语句大家都明白,新知识是这两行:' Z/ S- x; C2 J8 I# x9 w
% P4 j* s1 E, g5 ]$ a
2 i. t2 P+ r. O. H. S1 ?/ Qs = np.zeros([T])2 L6 J3 u+ h( G3 ] D* l) P
i = np.zeros([T])
5 U2 N `* y0 w3 D5 u! ^, m& K+ e- K1 d9 P
这两句话的意思是一样的,就是利用numpy(已被我们重新命名为np)的函数(zeros())来建立一个所有元素都是零的数组,而给的参数决定了这个数组的维度。比如:: J+ ^9 F3 F% n: M$ q! q
1 i; b$ n- e, l. K+ m: q
a = np.zeros([2,3])
5 [9 p3 p: p. }+ Ca5 e5 a% X, g: b! C
& I- N# F( Y1 N0 m9 ~( [/ V- l
array([[0., 0., 0.],
. o" s$ b& w, s [0., 0., 0.]])! @! O& a" k+ D* S& G' D
, |- ~1 ~! `) f1 F9 |/ h9 Y& g4 ]
2 Z( a5 }5 H2 ` s$ s; {! v- I& }
array([0., 0., 0., 0., 0.])* `3 k0 L" h2 z2 z a: A
- a- [* O4 S( ~
; [& c; d: e3 v0 U& W* W类似的还有产生元素全部是1的数组的函数np.ones():
' E+ Y2 Q0 M' H3 z) c; x7 o6 ?- X9 y0 H& [5 U/ Z
a = np.ones([5])
, w* J' o, J6 W0 Ba6 p+ m" O$ i: I/ D8 D7 t' B
P6 \+ m" L; `, r6 j6 A# `# k0 sarray([1., 1., 1., 1., 1.])
9 `3 P/ s5 \! x# } Z% i& `2 o$ A0 ^2 A, ]2 \5 ^ f1 w
/ ?, k O4 G; N# o5 [a = np.ones([2,3])3 _$ S1 |: [! I2 E) K+ Q
a3 D. a" q9 q" F! t. P! {- P2 _/ g
, n+ ]' _. ~% [% D+ h
/ G6 F( F' L6 Z
array([[1., 1., 1.],+ |2 m7 e/ l* U
[1., 1., 1.]]): S# i: }2 L; R0 a ^5 c! a
2 _5 f) }7 Y9 O, u8 o3 O# O4 w( K% H# A: j6 l
plt.plot(i)# [/ {% k" k1 |4 B3 @
5 p6 X. o! a) \" [# J3 A2 D
/ t- o3 L$ b5 h# @) ~
[<matplotlib.lines.Line2D at 0x7f0c2768d6d8>]; d0 ~. t/ k0 j5 T1 D4 l+ N1 u9 B
! q- F6 \/ b9 l) f9 B: F. [3 w5 O7 ]! N6 F1 V/ f* E
9 w0 M" Y6 E# g) J4 j8 z
, _, s; X; B9 ?, {, C2 r
, m1 {; P* I+ O2 q7 {8 _
实现SI模型的核心代码是第三个cell的第11,12行:
9 z4 e: ?9 R3 ^- [9 g! j* N/ ~+ t
' B0 ` r6 D, Z X8 f0 wfor t in range(T-1):" V: }$ Q6 K f, s
i[t + 1] = i[t] + i[t] * lamda * (1.0 - i[t])
5 g5 {2 G; Y1 A# V7 y- M7 x4 x/ e
" ~, M. O, g" u! P8 x5 A% @就是我们建立的数学模型,利用python的for循环语句累加迭代的方式把每天的增加量叠加到感染者比例上。 运行代码完成计算,我们利用matplotlib的pyplot来画出感染者的随天数的变化曲线: % ^4 T/ e/ v6 k$ ?
fig, ax = plt.subplots(figsize=(8,4))6 g, w9 j9 @1 J, N l) C/ V" |
ax.plot(i, c='r', lw=2)
$ K" D- }" y0 |3 pax.set_xlabel('Day',fontsize=20)
' R7 G. t6 p0 i# i! A3 M. pax.set_ylabel('Infective Ratio', fontsize=20)7 _" d$ a. i5 c
ax.grid(1)
: i& {0 y% B! u& j0 v: m7 yplt.xticks(fontsize=20)
' B( z' |: y6 n- r, dplt.yticks(fontsize=20);
& v( z6 W: s& V* o* l9 I) U W* e7 y; }
/ ~9 J& y+ U& J5 ^6 c6 R
![]()
1 }7 I! X: o: N- x6 B2 m2 s2 l' i- V( F: I. |- Q
从这个结果看到,大约在25天左右,全部人群都会变成感染者,感染率 。
- e8 B9 e5 m E( ]8 l. f在程序中我们假设每天每个患者传染0.8个人,你可以改变lamda的值,观察全部人群感染的天数的变化。 j6 @" b; k0 m& E
认真思考你会知道,lamda的现实意义就是该城市的卫生水平,衡量的是消毒,隔离这些措施执行得怎么样。回到传染病模型,按照SI模型计算的结果,我们全人类都会患病,这好可怕!原因是我们忽略了一个很重要的因素,那就是我们有奋斗在一线的医护人员,我们会被治愈!所以SI模型只适合研究具有高传染风险又不能被治愈的病(比如HIV)。 但是对于其他病,我们是可以靠医疗和自身免疫系统康复的,那么紧接着的一个问题就是,被治愈后还会再被传染上嘛?根据这个问题的回答不同,我们有了两个不同的模型,SIR 和 SIS。现在可以揭晓,SIR的R的含义了,就是移出者(Removed),现实含义就是指被治愈后不会再被感染的人。而SIS表示治愈后仍然还是易感者。下面我们用python来分别实现这两个模型。 SIS模型为了实现这个模型,我们需要引入新的一个参数,治愈率 。好啦,先上我们的新示意图: Image Name和SI模型做比较,区别就是计算感染者的增加数时要减去被治愈的人数。
/ t V: Y% O. y, o所以这时候每天的增加的感染者为: ,
5 g; n: S/ d+ l% r \增加的感染率为: 。/ Z7 [9 W+ H0 s3 p& ~$ d+ B! }
模型完成啦,修改python代码:8 ^4 o! N' L/ h: C5 d/ d& d/ V
# susceptiable ratio
- ~% z+ Y. R. ]' @. q; n4 S: Fs = np.zeros([T])
7 ^- d0 x$ K7 H# infective ratio8 ^, R8 u7 ~/ C9 s; o6 r0 R
i = np.zeros([T])
. q% f' r g! T+ _8 e8 M/ i. f
8 i/ `; d, s+ V3 B# contact rate
& I+ L! L. ^$ ]7 W2 z& Klamda = 1.0
2 w8 J9 s g. s8 W. y9 q1 J. {# recover rate8 e$ q8 e4 c9 k, Q7 ^6 _5 u
gamma = 0.5 0 Q8 U( i3 l8 m2 S2 N+ A
0 s$ h/ P+ d1 q' k+ `* d' I
# initial infective people' x9 I' M* u- Z! n' f$ s
i[0] = 45.0 / N
( w2 x" V! y5 X7 ~: H0 \* t8 J+ s( T+ @# b9 d( |3 _
for t in range(T-1):
" N; _- V; [+ p i[t + 1] = i[t] + i[t] * lamda * (1.0 - i[t]) - gamma*i[t]( m: g0 G8 d& |
! }7 m8 {" V7 T2 H6 C2 @7 }
5 U2 a4 ^, e# W* ]- C
* |. h3 ]2 r( I8 a+ ]: F运行代码,我们画出曲线(代码和SI模型的画图完全一样):
: n, O5 A; y# T. ?4 y% n5 `4 m
1 {) @* {; y& p+ o4 g- d8 afig, ax = plt.subplots(figsize=(8,4))
( L6 |" r% x N: ` ^ax.plot(i, c='r', lw=2)9 T b7 z" `" d0 K G- G
ax.set_xlabel('Day',fontsize=20)
3 o) I t2 r; m Rax.set_ylabel('Infective Ratio', fontsize=20)
% q( }+ x6 i# G2 z* A1 Oax.grid(1)
- y8 L6 w" p! Y* Iplt.xticks(fontsize=20)7 p9 ]) `8 K3 ~
plt.yticks(fontsize=20);
, m& s% Y2 y6 g4 N
! [0 l) U2 G- U" b0 K, Z3 I; x![]()
8 W/ P/ C: j( y8 c- F* T4 Q! }8 a- J9 C3 I
0 ^3 @$ w4 k0 C+ t
行代码,我们画出曲线(代码和SI模型的画图完全一样)
* n2 a- @$ r V3 l& L3 @6 K/ j可以看到,达到最大感染率的时间退后10天左右,最后感染和治愈达到动态平衡,人群中有始终有一半的人感染着。所以,SIS模型适合研究具有传染性和反复性的流行病,比如常见流感。同样的,感兴趣的话,改变lamda和gamma的值,观察曲线的变化。和lamda不同的是,gamma的现实意义就是对这种疾病的治疗水平。 SIR模型加入了移出者,被治愈的病人不会再被传染,先上我们的新示意图: Image NameSIR 模型1 x# V' Y+ A4 @5 z& d
注意到这里,人群被分成了三类,不再只有I和S,所以相比于之前的模型,我们需要找到新的约束关系。现在我们需要分别计算三种人每天的增加量了: 8 o$ O7 Z% q; K' W5 |- u
- 易感者:每天都在被传染,所以一直在减少,减少量为被传染的人数:
- 感染者:增加了被感染的人,减少了治愈的人:
- 移出者:增加了治愈的人: , }5 \* a+ r x" \
建模完成,修改python代码,并且假设人群普遍易感,新型疾病,初始没有移出者。
5 S) v3 o' e8 `' H2 W3 U) [. Q2 d3 Q# population5 n0 W, O9 U2 R7 a' s9 b* N
N = 1e7 + 10 + 56 v! |* w9 J: c" U6 f+ C; Z3 r
# simuation Time / Day# r7 S9 N2 E6 n! A# t$ A: w
T = 170- A8 X- q g, p- Y/ A& ?6 k) X7 g) k
# susceptiable ratio( a6 J0 n ^( t$ n( |
s = np.zeros([T])! P! B( {% v* I# ^- b+ Y, d4 O; z
# infective ratio6 E# x9 d* k/ \) q9 W" ?
i = np.zeros([T])
, d/ p m( x+ X$ o/ R# remove ratio
7 c0 g: D& R9 j4 U( gr = np.zeros([T])
; [" A" d8 A2 ?, o( `8 X7 `# |2 P2 s5 W- z6 k1 t* \* ^6 T. a
# contact rate
! q% F8 X9 n, P" alamda = 0.2586
& c7 q2 Q8 S; \8 |1 r# recover rate
% `4 S% O3 Y0 l. ]) D2 s( Dgamma = 0.0821
1 k* h3 d% a) q; h, `9 r' S3 l$ `* W' U$ r* E7 K2 z6 b' e
# initial infective people: V& B$ w U/ W$ A, \1 b; }9 [& A
i[0] = 10.0 / N4 l4 q& T0 U8 T: N9 i8 |* k5 B* F2 A
s[0] = 1e7 / N' x: s& s+ `% D2 h6 n+ r8 Z0 I
for t in range(T-1):0 B# J5 M1 K9 n0 p
i[t + 1] = i[t] + i[t] * lamda * s[t] - gamma*i[t]
& K% A8 |1 D: e) W* w s[t + 1] = s[t] - lamda * s[t] * i[t]7 ~ U/ q3 S( k1 g
r[t + 1] = r[t] + gamma*i[t]
8 c7 n; `/ Y7 a1 |8 E4 ?, z: S; B6 `% f
fig, ax = plt.subplots(figsize=(10,6))
, E, Y7 {$ P5 r/ Cax.plot(s, c='b', lw=2, label='S')( T5 W: ?5 O( @( A7 ]
ax.plot(i, c='r', lw=2, label='I')5 \. U! @- n) f& o- l# {
ax.plot(r, c='g', lw=2, label='R')
]' h% i) C7 F" a: tax.set_xlabel('Day',fontsize=20)0 Y7 [ F) p# S8 x0 T( q/ g
ax.set_ylabel('Infective Ratio', fontsize=20)
- d Z( y& S( H+ Cax.grid(1)
& Q! T. X C# g6 v. ~plt.xticks(fontsize=20); ]- x+ `3 v, g9 b. v5 d7 `
plt.yticks(fontsize=20)
9 G- r1 Q# R! R: C8 Iplt.legend();1 @8 ~9 B% m! C
7 {3 z# g% R' d$ J- }9 N8 q
! i' N5 f; _' Z% [; B; r, P![]()
# }4 s, \/ p) H. S7 h. t) G4 ?! c' o" D! u: L5 |7 k' \
感染人数峰值发生在一个月左右,最大感染人数不到人群的20%, 但是最终人群的80%都会得此病(就是最终的移出者的比例)。SIR模型适合研究没有潜伏期的急性传染病,治疗后能够痊愈并具有抗病性。 到这里,虽然不准确,我们也可以先用SIR模型来分析一下此次疫情,武汉新型冠状病毒的传染病动力学! 模型有了,其实就是确定参数的问题。一开始就有人做了这个工作: Image Name于教授给的参数是参考了非典的, ,初始易感人数为一千万, 初始感染10人,初始移出者5人,那么我们的城市总人数 , 带入我们的模型得到结果:重现于教授的模型
- k9 \6 F0 }' R. Q( d高峰和尾声日期的推测基本相符。
* K" \% ~/ d& d8 U# susceptiable ratio
% E, W! }: D* {2 u' p6 ^4 x2 J& qs = np.zeros([T])
$ I$ U" q7 {% J8 t# infective ratio
3 u+ S' o$ I6 q/ w& {/ P$ ai = np.zeros([T])( E& }# r5 {' M8 s/ h0 C) I
# removed ratio
2 S: ]0 u! d( u+ Rr = np.zeros([T])
9 B: S+ D3 ~- I1 b. A* v6 M4 ] Y- ]& z# O
# birth ratio% ]8 y! a4 e4 L! ~ E" s
b = 20.0 / N. @8 P+ u/ v+ M: M% ]5 F
# death ratio; n, C# R9 C5 k, l% d( k, s
d = 10.0 / N" f- Z' ~" Y' C) k) ]
- N, f4 s. C2 h9 f4 @1 U0 C$ r6 _
# contact rate
) F K# v+ r2 D# Cy = 1.5
/ [' K1 N$ _' C3 C# recover rate
6 @1 d! I9 L2 m! `' a; K3 I0 z( v' Vu = 0.8 # 1 / infective_period. X/ t0 {" S0 X4 f; B
" m& i9 V. I1 _- J- _# sigma = y / u# U, Z5 s3 v6 f' H: ^2 @, J. A
4 q8 Q. ?1 f' X$ i. n# initial infective people
6 c) n) R/ o4 ?+ f! ?i[0] = 45.0 / N
- U- a$ I' J! T& d7 o( [) G2 As[0] = 1 - i[0]
' @1 U3 _4 G% Lfor t in range(T-1): @5 {/ j$ P3 f. w! f
i[t+1] = i[t] + i[t] * y * s[t] - u*i[t] - d*i[t]) d m- K1 ?, O3 x% D2 O2 F
s[t+1] = s[t] - y * s[t] * i[t] + b - d*s[t]
5 L. I& _6 R- N+ a+ f& S5 b r[t+1] = r[t] + u*i[t] - d*r[t]
( ?/ x& e' y1 M8 v7 |
, G8 ]' R+ V3 a0 K3 c6 ]plt.plot(i)
! o6 a8 Q0 N6 V4 \' rplt.plot(s)# `: S2 e! t2 d1 @) d
plt.plot(r)
( K: U7 \3 p( W4 X# Gplt.plot(np.diff(i),ls='--'): B$ p/ Q7 z9 V, s% N/ ]8 M
# o4 \9 k6 Y: }" P/ P# N5 e! Q7 F- d. N
[<matplotlib.lines.Line2D at 0x7f77796e8518>]
( J1 R' S: w! M* N: Y2 R
8 l, f9 g9 O/ X; {6 d A4 J% `- `![]()
% M' l0 M- F) C) M& ?" g2 \7 }+ C" j' x2 M: |3 M) k. O
SEIR模型但是,SIR模型和实际情况的出入会比较大,因为忽略了太多因素了,比如说潜伏期,比如说政策调控,药物,出生死亡等等。下面我们可以和前面一样,把潜伏期考虑进去,新增一个人群,叫潜伏者E(exposed): Image NameSEIR模型
' f6 l3 r; E$ P4 m {9 `3 L同样的我们需要计算各人群每天的增加量: S:每天减少:
1 @3 c% d4 H8 B! u: m$ xE:每天增加传染,减少发病: " V3 d6 g- _ Y! ?/ [
I:每天增加发病,减少治愈:
' I7 V4 [2 q- Y$ OR:每天增加治愈:
6 Q$ Y! A9 V' [: W& B6 [4 f3 M( v5 E建模完成,修改我们的python程序,这里的 可以理解为潜伏期的倒数。给的4天。新型冠状病毒给目前临床的潜伏期是3-14天。# t' I3 Q0 M- \3 h* ^6 j5 s0 |
# population# c( @: M) ]+ e6 G; g4 @) c# k9 q
N = 1e7 + 10 + 5
) h. v; A; D# `. p) R3 a' c- L# simuation Time / Day) a) V, r. Z- P" d: p+ T$ z
T = 170
$ I6 \8 T. E* X" c1 p7 C) ~" W/ |' I# susceptiable ratio
6 A. F& Q& {9 a8 X4 xs = np.zeros([T])
B& [/ P- P- O" k* k% j# exposed ratio
4 W8 Y/ b5 U' R& E ke = np.zeros([T])% |# A4 a4 P, a2 L+ a" B8 N
# infective ratio$ |* W: u6 K3 B9 y
i = np.zeros([T])# K, _5 {9 J8 ~
# remove ratio
8 h& v- t1 Q* S; br = np.zeros([T])
5 [1 k6 K$ l8 I0 P5 X+ U4 f0 D: d" R/ {' F" u
# contact rate
7 H# O+ W* H8 T* k; @7 b) @lamda = 0.5
1 l8 \% N6 B3 Y6 v1 L. n( K# recover rate
6 p. L9 F8 P, g9 X7 Y7 w3 S' ggamma = 0.0821
P. [7 s* t' ~ h: J; P2 M6 h# exposed period
7 ]1 f h2 S8 Y6 D! Z2 T3 rsigma = 1 / 4
. S& j7 u4 y% h9 ~
3 A- z1 ]/ [: u# initial infective people
1 R2 U J, U6 t$ ki[0] = 10.0 / N; k/ H2 \/ k. [. z
s[0] = 1e7 / N
6 y: x: L1 B+ `( |e[0] = 40.0 / N3 }) c& U2 x! B# ]
for t in range(T-1):* H5 |$ f. G. Y6 U7 t% j
s[t + 1] = s[t] - lamda * s[t] * i[t]* t( `9 b6 x6 f- h' N8 [: ~9 ~
e[t + 1] = e[t] + lamda * s[t] * i[t] - sigma * e[t]
( L; |8 r r6 `9 u2 ?7 x i[t + 1] = i[t] + sigma * e[t] - gamma * i[t]$ @% X2 e, V& t) o/ i
r[t + 1] = r[t] + gamma * i[t]
5 [; I8 Q W* K& ^6 i$ K2 s! i, c
2 H$ N9 u0 f8 O& N( w3 e
fig, ax = plt.subplots(figsize=(10,6))( |/ ~% L( z" X9 ~8 H
ax.plot(s, c='b', lw=2, label='S'). e4 E; w j' `# Q' @8 j: s
ax.plot(e, c='orange', lw=2, label='E')& u+ x# F- [6 C/ O# a* ]$ k, ~
ax.plot(i, c='r', lw=2, label='I')
6 i- A0 k J8 ~3 o7 C+ ?. l; pax.plot(r, c='g', lw=2, label='R')
, V+ O2 j6 D- Z( D2 qax.set_xlabel('Day',fontsize=20)
; k3 m- L, M. U4 U7 E& O# F$ |ax.set_ylabel('Infective Ratio', fontsize=20)
t* l4 f* ^ x1 r; C$ `ax.grid(1)7 x% j* Y- \$ i: b0 i
plt.xticks(fontsize=20)
7 Y1 ]0 A5 H* I( |6 Dplt.yticks(fontsize=20)! B8 k2 q9 g8 G4 S) K! G* }% g
plt.legend();# ~. ^) O) Q5 e' s* j, T
+ G( J5 ~0 G! g& I& O/ y- \
C& |. c3 x6 b# g6 u2 [% @
![]()
9 [, R4 @4 O- \* N
% M* w, ]8 K* ^7 k& o按照模型的结果,此次疫情可能真的要持续到 三四月份。这个接触率 真的非常影响表现,模型给的是个常数,但是由于政府措施的原因,这应该是个变化的值。
! V1 B# S+ }# b( ^8 _) b( R* d还有治愈率 也是。没有完美的模型,但是随着考虑因素的增多,就会越来越接近实际情况,从而指导政府的疫情方针政策的制定。
" Y8 G* ~) }: r) e3 S, n: o( H* B! S7 J/ t, O4 x5 j
; J# N6 e3 S' ] q5 D4 G/ X1 o
- ?7 R: z7 b6 s. K$ H; h3 E; i5 {3 o) P
|