小白零基础学数学建模应用系列(六):基于数学建模的疟疾传播与控制研究

2024-09-01 18:52

本文主要是介绍小白零基础学数学建模应用系列(六):基于数学建模的疟疾传播与控制研究,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇文章为深度研究内容,实际给大家展示数学建模在医学中,生活中的应用。数学建模是一门很严谨的学科,大家通过本篇文章可以学习下相关背景即可,当然我在文末配了参考代码供大家学习。无论在数学建模竞赛中,还是在做科研,数学建模都会对大家有着非常大的帮助。当然,不用完全看懂本篇文章。

CSDN/B站/知乎:川川菜鸟
书籍推荐:https://item.m.jd.com/product/10099450547669.html
我的微信(接高教杯辅导咨询,数模论文转化):hxgsrubxjogxeeag

文章目录

    • 1. 摘要
    • 2. 引言
    • 2. 模型开发
    • 3. 模型分析
    • 4. 敏感性分析
    • 参考代码

1. 摘要

疟疾是一种危及生命的疾病,在许多非洲国家流行,尤其是尼日利亚。数学模型用于研究尼日利亚疟疾的动态。该模型结合了耐药性、治疗和使用蚊帐作为预防策略。通过将模型与尼日利亚疟疾发病率数据拟合,估计了与疾病动态相关的重要参数。使用这些估计参数,计算基本传染数,模拟未来动态,并确定对尼日利亚疟疾有重大影响的参数。总体而言,结果表明,除非更好的控制措施集中在主要耐药菌株上,改善治疗并广泛使用蚊帐,否则该疾病可能会在尼日利亚继续流行。

关键词:疟疾动力学, 稳定性分析, 基本繁殖数, 模型拟合, 敏感性分析

2. 引言

疟疾是一种由疟原虫通过受感染的雌性按蚊叮咬传播给人类的严重疾病。全球有四种疟原虫感染人类,其中恶性疟原虫和间日疟原虫是最致命的。尤其在非洲,恶性疟原虫是主要的疟疾寄生虫。未及时治疗的恶性疟原虫感染可能在24小时内导致严重疾病和死亡。

根据世界卫生组织(WHO),疟疾的病例和死亡人数逐年增加,尤其在非洲,2020年全球疟疾病例约为2.41亿,死亡人数达62.7万。非洲承载了全球约95%的疟疾病例和96%的死亡病例,尤其是5岁以下的儿童受影响最严重。尼日利亚目前是受疟疾影响最严重的国家之一,约占全球疟疾死亡人数的31.9%。

尽管疟疾在尼日利亚已经流行多年,但治疗失败仍然是控制疟疾的主要障碍之一。药物抵抗和假药的使用是疟疾治疗失败的主要原因。此外,尼日利亚国家食品药品监督管理局(NAFDAC)发现,假药也导致了许多疾病的增加。

数学模型在理解传染病传播方面起到了重要作用。这些模型被用于分析疟疾的传播和控制,其中包括药物抵抗和防控措施的影响。本研究的目的在于开发一个整合了药物抵抗和防控措施的数学模型,并结合真实数据,以预测尼日利亚疟疾传播的可能动态。这项研究的发现将帮助研究人员和政策制定者制定更有效的疟疾控制策略。

2. 模型开发

为了研究尼日利亚地区的疟疾传播动态,开发了一个数学模型。该模型以常微分方程的形式呈现,考虑了疟疾传播的主要因素。模型包含了在人口 N h ( t ) N_h(t) Nh(t)和时间t时的蚊子群体 N v ( t ) N_v(t) Nv(t)。在时间(t)时,人群被分为以下子群体:易感人群S(t)、感染人群I(t)、治疗人群T(t)和暂时免疫人群R(t)。为了考虑耐药菌株的存在,感染人群进一步分为两类:感染耐药菌株的个体 I r ( t ) I_r(t) Ir(t)和感染敏感菌株的个体 I s ( t ) I_s(t) Is(t)。同样,治疗人群T(t)也分为两类:接受耐药菌株治疗的个体 T r ( t ) T_r(t) Tr(t)和接受敏感菌株治疗的个体 T s ( t ) T_s(t) Ts(t)蚊子群体 N v ( t ) N_v(t) Nv(t)在时间(t)时也分为易感蚊子\X(t)和感染蚊子Y(t)\

模型的其他假设如下。蚊子和人群的出生率和死亡率相等。因此,蚊子和人类的总人口是恒定的。从疟疾中恢复的人类对再感染具有暂时的免疫力。模型中的各种参数及其含义在表2中列出。所有参数值都被假设为非负数。感染率的计算公式为 β = θ β p h \beta = \theta \beta_{ph} β=θβph α r = α r r \alpha_r = \alpha_{rr} αr=αrr a l p h a s = α s s alpha_s = \alpha_{ss} alphas=αss其中 t h e t a theta theta为叮咬率。此外, β r \beta_r βr表示从感染的蚊子传染给人类的概率。同样,感染耐药菌株的个体 I r ( t ) I_r(t) Ir(t) 以速率 α r r \alpha_{rr} αrr传染给易感蚊子,而感染敏感菌株的个体 I s ( t ) I_s(t) Is(t)则以速率 α s s \alpha_{ss} αss传染给易感蚊子。每个人类宿主的蚊子数量用一个常数参数 m = N v ( t ) N h ( t ) m = \frac{N_v(t)}{N_h(t)} m=Nh(t)Nv(t)表示(Agusto等人,2013;Tumwiine等人,2014)。感染耐药菌株或敏感菌株的人类分别以速率 σ r \sigma_r σr σ s \sigma_s σs接受治疗。治疗个体 T r ( t ) T_r(t) Tr(t) T s ( t ) T_s(t) Ts(t)分别以速率 γ r \gamma_r γr γ s \gamma_s γs恢复。此外,由于假药、剂量不足等原因,治疗失败的比例分别为 ϵ r \epsilon_r ϵr ϵ s \epsilon_s ϵs。为了考虑控制措施的影响,我们假设使用蚊帐能以比例c减少感染率。基于这些假设,疟疾传播模型为:

d S ( t ) d t = μ N h ( t ) − ( 1 − c ) m β S ( t ) Y ( t ) / N v ( t ) − μ S ( t ) + ω R ( t ) , d I r ( t ) d t = ρ ( 1 − c ) m β S ( t ) Y ( t ) / N v ( t ) − ( σ r + μ ) I r ( t ) + ϵ r T r ( t ) , d I s ( t ) d t = ( 1 − ρ ) ( 1 − c ) m β S ( t ) Y ( t ) / N v ( t ) − ( σ s + μ ) I s ( t ) + ϵ s T s ( t ) , d T r ( t ) d t = σ r I r ( t ) − ( γ r + ϵ r + μ ) T r ( t ) , d T s ( t ) d t = σ s I s ( t ) − ( γ s + ϵ s + μ ) T s ( t ) , d R ( t ) d t = γ r T r ( t ) + γ s T s ( t ) − ( ω + μ ) R ( t ) , d X ( t ) d t = ξ N v ( t ) − ( 1 − c ) α r X ( t ) I r ( t ) / N h ( t ) − ( 1 − c ) α s X ( t ) I s ( t ) / N h ( t ) − ξ X ( t ) , d Y ( t ) d t = ( 1 − c ) α r X ( t ) I r ( t ) / N h ( t ) + ( 1 − c ) α s X ( t ) I s ( t ) / N h ( t ) − ξ Y ( t ) . \begin{aligned} \frac{dS(t)}{dt} &= \mu N_h(t) - \left(1 - c\right) m \beta S(t) Y(t) / N_v(t) - \mu S(t) + \omega R(t), \\ \frac{dI_r(t)}{dt} &= \rho \left(1 - c\right) m \beta S(t) Y(t) / N_v(t) - \left(\sigma_r + \mu\right) I_r(t) + \epsilon_r T_r(t), \\ \frac{dI_s(t)}{dt} &= \left(1 - \rho\right) \left(1 - c\right) m \beta S(t) Y(t) / N_v(t) - \left(\sigma_s + \mu\right) I_s(t) + \epsilon_s T_s(t), \\ \frac{dT_r(t)}{dt} &= \sigma_r I_r(t) - \left(\gamma_r + \epsilon_r + \mu\right) T_r(t), \\ \frac{dT_s(t)}{dt} &= \sigma_s I_s(t) - \left(\gamma_s + \epsilon_s + \mu\right) T_s(t), \\ \frac{dR(t)}{dt} &= \gamma_r T_r(t) + \gamma_s T_s(t) - \left(\omega + \mu\right) R(t), \\ \frac{dX(t)}{dt} &= \xi N_v(t) - \left(1 - c\right) \alpha_r X(t) I_r(t) / N_h(t) - \left(1 - c\right) \alpha_s X(t) I_s(t) / N_h(t) - \xi X(t), \\ \frac{dY(t)}{dt} &= \left(1 - c\right) \alpha_r X(t) I_r(t) / N_h(t) + \left(1 - c\right) \alpha_s X(t) I_s(t) / N_h(t) - \xi Y(t). \end{aligned} dtdS(t)dtdIr(t)dtdIs(t)dtdTr(t)dtdTs(t)dtdR(t)dtdX(t)dtdY(t)=μNh(t)(1c)mβS(t)Y(t)/Nv(t)μS(t)+ωR(t),=ρ(1c)mβS(t)Y(t)/Nv(t)(σr+μ)Ir(t)+ϵrTr(t),=(1ρ)(1c)mβS(t)Y(t)/Nv(t)(σs+μ)Is(t)+ϵsTs(t),=σrIr(t)(γr+ϵr+μ)Tr(t),=σsIs(t)(γs+ϵs+μ)Ts(t),=γrTr(t)+γsTs(t)(ω+μ)R(t),=ξNv(t)(1c)αrX(t)Ir(t)/Nh(t)(1c)αsX(t)Is(t)/Nh(t)ξX(t),=(1c)αrX(t)Ir(t)/Nh(t)+(1c)αsX(t)Is(t)/Nh(t)ξY(t).

当然可以,以下是去除LaTeX形式的表1和表2:

表1:模型(1)的变量

变量含义
Nh(t)时间 t 时的总人口数量
S(t)时间 t 时的易感人群数量
Ir(t)时间 t 时感染耐药菌株的人的数量
Is(t)时间 t 时感染敏感菌株的人的数量
Tr(t)时间 t 时接受耐药菌株治疗的人的数量
Ts(t)时间 t 时接受敏感菌株治疗的人的数量
R(t)时间 t 时恢复的/免疫的人群数量
Nv(t)时间 t 时的蚊子总数量
X(t)时间 t 时的易感蚊子数量
Y(t)时间 t 时感染的蚊子数量

表2:模型(1)的参数

变量含义单位
β从蚊子传染给人类的感染率天^-1
αr从 Ir(t) 传染给蚊子的感染率天^-1
αs从 Is(t) 传染给蚊子的感染率天^-1
μ人类的自然出生/死亡率天^-1
ρ感染耐药菌株人群的比例无量纲
c使用蚊帐导致感染率的降低无量纲
σrIr(t) 的治疗率天^-1
σsIs(t) 的治疗率天^-1
γrTr(t) 的预期恢复率天^-1
γsTs(t) 的预期恢复率天^-1
εrTr(t) 的治疗失败率天^-1
εsTs(t) 的治疗失败率天^-1
ωR(t) 的免疫消退率天^-1
ξ蚊子的自然出生/死亡率天^-1

疟疾模型(2)的示意图如图1所示。

蚊子群体
人群
传染
传染
感染
感染
感染蚊子
易感蚊子
感染抗药性
易感人群
接受抗药性治疗
康复
感染敏感性
接受敏感性治疗

模型的动力学通过动态系统分析和数值模拟来研究。由于人类和蚊子有不同的测量单位,需要使用无量纲变量对模型进行缩放。我们使用人类或蚊子的总人口来缩放变量:

s ( t ) = S ( t ) N h ( t ) , i r ( t ) = I r ( t ) N h ( t ) , i s ( t ) = I s ( t ) N h ( t ) , τ r ( t ) = T r ( t ) N h ( t ) , τ s ( t ) = T s ( t ) N h ( t ) , r ( t ) = R ( t ) N h ( t ) , x ( t ) = X ( t ) N v ( t ) , y ( t ) = Y ( t ) N v ( t ) , s(t) = \frac{S(t)}{N_h(t)}, i_r(t) = \frac{I_r(t)}{N_h(t)}, i_s(t) = \frac{I_s(t)}{N_h(t)}, \tau_r(t) = \frac{T_r(t)}{N_h(t)}, \tau_s(t) = \frac{T_s(t)}{N_h(t)}, r(t) = \frac{R(t)}{N_h(t)}, x(t) = \frac{X(t)}{N_v(t)}, y(t) = \frac{Y(t)}{N_v(t)}, s(t)=Nh(t)S(t),ir(t)=Nh(t)Ir(t),is(t)=Nh(t)Is(t),τr(t)=Nh(t)Tr(t),τs(t)=Nh(t)Ts(t),r(t)=Nh(t)R(t),x(t)=Nv(t)X(t),y(t)=Nv(t)Y(t),

其中, m = N v ( t ) N h ( t ) m = \frac{N_v(t)}{N_h(t)} m=Nh(t)Nv(t)为常数。参数(m)表示每个宿主的人类中雌性按蚊的数量。使用这些缩放变量,模型(1)的无量纲版本变为:

d s ( t ) d t = μ − ( 1 − c ) m β s ( t ) y ( t ) − μ s ( t ) + ω r ( t ) , d i r ( t ) d t = ρ ( 1 − c ) m β s ( t ) y ( t ) − ( σ r + μ ) i r ( t ) + ϵ r τ r ( t ) , d i s ( t ) d t = ( 1 − ρ ) ( 1 − c ) m β s ( t ) y ( t ) − ( σ s + μ ) i s ( t ) + ϵ s τ s ( t ) , d τ r ( t ) d t = σ r i r ( t ) − ( γ r + ϵ r + μ ) τ r ( t ) , d τ s ( t ) d t = σ s i s ( t ) − ( γ s + ϵ s + μ ) τ s ( t ) , d r ( t ) d t = γ r τ r ( t ) + γ s τ s ( t ) − ( ω + μ ) r ( t ) , d x ( t ) d t = ξ − ( 1 − c ) α r x ( t ) i r ( t ) − ( 1 − c ) α s x ( t ) i s ( t ) − ξ x ( t ) , d y ( t ) d t = ( 1 − c ) α r x ( t ) i r ( t ) + ( 1 − c ) α s x ( t ) i s ( t ) − ξ y ( t ) . \begin{aligned} \frac{ds(t)}{dt} &= \mu - \left(1 - c\right) m \beta s(t) y(t) - \mu s(t) + \omega r(t), \\ \frac{dir(t)}{dt} &= \rho \left(1 - c\right) m \beta s(t) y(t) - \left(\sigma_r + \mu\right) i_r(t) + \epsilon_r \tau_r(t), \\ \frac{dis(t)}{dt} &= \left(1 - \rho\right) \left(1 - c\right) m \beta s(t) y(t) - \left(\sigma_s + \mu\right) i_s(t) + \epsilon_s \tau_s(t), \\ \frac{d\tau_r(t)}{dt} &= \sigma_r i_r(t) - \left(\gamma_r + \epsilon_r + \mu\right) \tau_r(t), \\ \frac{d\tau_s(t)}{dt} &= \sigma_s i_s(t) - \left(\gamma_s + \epsilon_s + \mu\right) \tau_s(t), \\ \frac{dr(t)}{dt} &= \gamma_r \tau_r(t) + \gamma_s \tau_s(t) - \left(\omega + \mu\right) r(t), \\ \frac{dx(t)}{dt} &= \xi - \left(1 - c\right) \alpha_r x(t) i_r(t) - \left(1 - c\right) \alpha_s x(t) i_s(t) - \xi x(t), \\ \frac{dy(t)}{dt} &= \left(1 - c\right) \alpha_r x(t) i_r(t) + \left(1 - c\right) \alpha_s x(t) i_s(t) - \xi y(t). \end{aligned} dtds(t)dtdir(t)dtdis(t)dtdτr(t)dtdτs(t)dtdr(t)dtdx(t)dtdy(t)=μ(1c)mβs(t)y(t)μs(t)+ωr(t),=ρ(1c)mβs(t)y(t)(σr+μ)ir(t)+ϵrτr(t),=(1ρ)(1c)mβs(t)y(t)(σs+μ)is(t)+ϵsτs(t),=σrir(t)(γr+ϵr+μ)τr(t),=σsis(t)(γs+ϵs+μ)τs(t),=γrτr(t)+γsτs(t)(ω+μ)r(t),=ξ(1c)αrx(t)ir(t)(1c)αsx(t)is(t)ξx(t),=(1c)αrx(t)ir(t)+(1c)αsx(t)is(t)ξy(t).

对于模型(2)的分析,将参数组合为: Λ = ( 1 − c ) m β , b r = σ r + μ , b s = σ s + μ , k r = γ r + ϵ r + μ , k s = γ s + ϵ s + μ , α r = ( 1 − c ) α r , α s = ( 1 − c ) α s , I r = γ r + μ , I s = γ s + μ \Lambda = \left(1 - c\right) m \beta, b_r = \sigma_r + \mu, b_s = \sigma_s + \mu, k_r = \gamma_r + \epsilon_r + \mu, k_s = \gamma_s + \epsilon_s + \mu, \alpha_r = \left(1 - c\right) \alpha_r, \alpha_s = \left(1 - c\right) \alpha_s, I_r = \gamma_r + \mu, I_s = \gamma_s + \mu Λ=(1c)mβ,br=σr+μ,bs=σs+μ,kr=γr+ϵr+μ,ks=γs+ϵs+μ,αr=(1c)αr,αs=(1c)αs,Ir=γr+μ,Is=γs+μ

3. 模型分析

为了增强对模型动态的理解,本节介绍了模型(2)的一些重要数学特性。

3.1. 平衡分析

模型(2)的无病平衡(DFE)由以下公式给出:

( s 0 , i r 0 , i s 0 , τ r 0 , τ s 0 , r 0 , x 0 , y 0 ) = ( 1 , 0 , 0 , 0 , 0 , 0 , 1 , 0 ) (s^0, i_r^0, i_s^0, \tau_r^0, \tau_s^0, r^0, x^0, y^0) = (1, 0, 0, 0, 0, 0, 1, 0) (s0,ir0,is0,τr0,τs0,r0,x0,y0)=(1,0,0,0,0,0,1,0)

模型(2)的基本再生数((R_0))是使用下一代矩阵法计算的(Van den Driessche & Watmough, 2002)。与模型(2)相关的下一代矩阵由以下公式给出:

F = ( 0 0 0 0 ρ Λ 0 0 0 ( 1 − ρ ) Λ 0 0 0 0 0 0 0 0 0 0 0 α r α s 0 0 0 ) , V = ( b r 0 − ϵ r 0 0 0 b s 0 − ϵ s 0 − σ r 0 k r 0 0 0 − σ s 0 k s 0 0 0 0 0 ξ ) F = \begin{pmatrix} 0 & 0 & 0 & 0 & \rho \Lambda \\ 0 & 0 & 0 & (1 - \rho) \Lambda & 0 \\ 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 \\ \alpha_r & \alpha_s & 0 & 0 & 0 \end{pmatrix} \quad , \quad V = \begin{pmatrix} b_r & 0 & -\epsilon_r & 0 & 0 \\ 0 & b_s & 0 & -\epsilon_s & 0 \\ -\sigma_r & 0 & k_r & 0 & 0 \\ 0 & -\sigma_s & 0 & k_s & 0 \\ 0 & 0 & 0 & 0 & \xi \end{pmatrix} F= 0000αr0000αs000000(1ρ)Λ000ρΛ0000 ,V= br0σr000bs0σs0ϵr0kr000ϵs0ks00000ξ

因此,矩阵 (FV^{-1}) 的逆矩阵的光谱半径计算得出基本再生数 (R_0),公式如下:

F V − 1 = ( 0 0 0 0 ρ Λ ξ 0 0 0 0 ( 1 − ρ ) Λ ξ α r k r σ r τ r + μ k r 0 0 0 0 0 α s k s σ s τ s + μ k s 0 0 0 α r ϵ r σ r τ r + μ k r α s ϵ s σ s τ s + μ k s 0 0 0 ) FV^{-1} = \begin{pmatrix} 0 & 0 & 0 & 0 & \frac{\rho \Lambda}{\xi} \\ 0 & 0 & 0 & 0 & \frac{(1 - \rho)\Lambda}{\xi} \\ \frac{\alpha_r k_r}{\sigma_r \tau_r + \mu k_r} & 0 & 0 & 0 & 0 \\ 0 & \frac{\alpha_s k_s}{\sigma_s \tau_s + \mu k_s} & 0 & 0 & 0 \\ \frac{\alpha_r \epsilon_r}{\sigma_r \tau_r + \mu k_r} & \frac{\alpha_s \epsilon_s}{\sigma_s \tau_s + \mu k_s} & 0 & 0 & 0 \end{pmatrix} FV1= 00σrτr+μkrαrkr0σrτr+μkrαrϵr000σsτs+μksαsksσsτs+μksαsϵs0000000000ξρΛξ(1ρ)Λ000

因此,基本再生数 (R_0) 是矩阵 (FV^{-1}) 的光谱半径,计算公式如下:

R 0 = R 0 r + R 0 s R_0 = \sqrt{R_0^r + R_0^s} R0=R0r+R0s

其中:

R 0 r = ρ α r k r ξ ( σ r τ r + μ k r ) , R 0 s = ( 1 − ρ ) α s k s ξ ( σ s τ s + μ k s ) R_0^r = \frac{\rho \alpha_r k_r}{\xi (\sigma_r \tau_r + \mu k_r)}, \quad R_0^s = \frac{(1 - \rho) \alpha_s k_s}{\xi (\sigma_s \tau_s + \mu k_s)} R0r=ξ(σrτr+μkr)ραrkr,R0s=ξ(σsτs+μks)(1ρ)αsks

显然:

R 0 r = ( 1 − c ) 2 m β α r ( ϵ r + γ r + μ ) ξ ( σ r ( γ r + ϵ r + μ ) + μ ( ϵ r + γ r + μ ) ) 和 R 0 s = ( 1 − c ) 2 ( 1 − ρ ) m β α s ( ϵ s + γ s + μ ) ξ ( σ s ( γ s + ϵ s + μ ) + μ ( ϵ s + γ s + μ ) ) R_0^r = \frac{(1 - c)^2 m \beta \alpha_r (\epsilon_r + \gamma_r + \mu)}{\xi (\sigma_r (\gamma_r + \epsilon_r + \mu) + \mu (\epsilon_r + \gamma_r + \mu))} \quad 和 \quad R_0^s = \frac{(1 - c)^2 (1 - \rho) m \beta \alpha_s (\epsilon_s + \gamma_s + \mu)}{\xi (\sigma_s (\gamma_s + \epsilon_s + \mu) + \mu (\epsilon_s + \gamma_s + \mu))} R0r=ξ(σr(γr+ϵr+μ)+μ(ϵr+γr+μ))(1c)2mβαr(ϵr+γr+μ)R0s=ξ(σs(γs+ϵs+μ)+μ(ϵs+γs+μ))(1c)2(1ρ)mβαs(ϵs+γs+μ)

(R_0^r) 和 (R_0^s) 分别代表抗药性菌株和敏感性菌株的基本再生数的贡献。

当 (R_0 > 1) 时,至少有一个地方病平衡出现:抗药性菌株地方病平衡、敏感性菌株地方病平衡或共存地方病平衡。

当抗药性菌株占主导地位,使得 (R_0^r > 1) 且 (R_0^s \leq 1),则存在抗药性菌株地方病平衡,其公式如下:

( s ∗ , i r ∗ , i s ∗ , τ r ∗ , τ s ∗ , r ∗ , x ∗ , y ∗ ) = ( R 0 r μ + Λ R 0 r ( μ + Λ ) , i r ∗ , 0 , σ r τ r ∗ k r , 0 , r ∗ , x ∗ , y ∗ ) (s^*, i_r^*, i_s^*, \tau_r^*, \tau_s^*, r^*, x^*, y^*) = \left(\frac{R_0^r \mu + \Lambda}{R_0^r (\mu + \Lambda)}, i_r^*, 0, \frac{\sigma_r \tau_r^*}{k_r}, 0, r^*, x^*, y^*\right) (s,ir,is,τr,τs,r,x,y)=(R0r(μ+Λ)R0rμ+Λ,ir,0,krσrτr,0,r,x,y)

其中:

τ r ∗ = ξ y ∗ α r ( 1 − y ∗ ) , r ∗ = γ r τ r ∗ μ + ω + Λ , y ∗ = 1 − x ∗ , x ∗ = μ ( 1 − s ∗ ) Λ s ∗ \tau_r^* = \frac{\xi y^*}{\alpha_r (1 - y^*)}, \quad r^* = \frac{\gamma_r \tau_r^*}{\mu + \omega + \Lambda}, \quad y^* = 1 - x^*, \quad x^* = \frac{\mu (1 - s^*)}{\Lambda s^*} τr=αr(1y)ξy,r=μ+ω+Λγrτr,y=1x,x=Λsμ(1s)

同样地,如果敏感性菌株占主导地位,使得 (R_0^s > 1) 且 (R_0^r \leq 1),则存在敏感性菌株地方病平衡,其公式如下:

( s ∗ , i r ∗ , i s ∗ , τ r ∗ , τ s ∗ , r ∗ , x ∗ , y ∗ ) = ( R 0 s μ + Λ R 0 s ( μ + Λ ) , 0 , i s ∗ , 0 , σ s τ s ∗ k s , r ∗ , x ∗ , y ∗ ) (s^*, i_r^*, i_s^*, \tau_r^*, \tau_s^*, r^*, x^*, y^*) = \left(\frac{R_0^s \mu + \Lambda}{R_0^s (\mu + \Lambda)}, 0, i_s^*, 0, \frac{\sigma_s \tau_s^*}{k_s}, r^*, x^*, y^*\right) (s,ir,is,τr,τs,r,x,y)=(R0s(μ+Λ)R0sμ+Λ,0,is,0,ksσsτs,r,x,y)

其中:

i s ∗ = ξ y ∗ α s ( 1 − y ∗ ) , r ∗ = γ s τ s ∗ μ + ω + Λ , y ∗ = 1 − x ∗ , x ∗ = μ ( 1 − s ∗ ) Λ s ∗ i_s^* = \frac{\xi y^*}{\alpha_s (1 - y^*)}, \quad r^* = \frac{\gamma_s \tau_s^*}{\mu + \omega + \Lambda}, \quad y^* = 1 - x^*, \quad x^* = \frac{\mu (1 - s^*)}{\Lambda s^*} is=αs(1y)ξy,r=μ+ω+Λγsτs,y=1x,x=Λsμ(1s)

当两种菌株共存时,且 (R_0^r > 1) 且 (R_0^s > 1),则存在共存地方病平衡,其公式如下:

( s ∗ , i r ∗ , i s ∗ , τ r ∗ , τ s ∗ , r ∗ , x ∗ , y ∗ ) = ( R 0 r μ + Λ ( R 0 r + R 0 s ) ( μ + Λ ) , i r ∗ , i s ∗ , τ r ∗ , τ s ∗ , r ∗ , x ∗ , y ∗ ) (s^*, i_r^*, i_s^*, \tau_r^*, \tau_s^*, r^*, x^*, y^*) = \left(\frac{R_0^r \mu + \Lambda}{(R_0^r + R_0^s) (\mu + \Lambda)}, i_r^*, i_s^*, \tau_r^*, \tau_s^*, r^*, x^*, y^*\right) (s,ir,is,τr,τs,r,x,y)=((R0r+R0s)(μ+Λ)R0rμ+Λ,ir,is,τr,τs,r,x,y)
其中:

i r ∗ = ϵ r α r i s ∗ ϵ s α s i r ∗ , τ r ∗ = σ r i r ∗ k r , τ s ∗ = σ s i s ∗ k s , r ∗ = γ r τ r ∗ μ + ω + Λ , y ∗ = 1 − x ∗ , x ∗ = μ ( 1 − s ∗ ) Λ s ∗ i_r^* = \frac{\epsilon_r \alpha_r i_s^*}{\epsilon_s \alpha_s i_r^*}, \quad \tau_r^* = \frac{\sigma_r i_r^*}{k_r}, \quad \tau_s^* = \frac{\sigma_s i_s^*}{k_s}, \quad r^* = \frac{\gamma_r \tau_r^*}{\mu + \omega + \Lambda}, \quad y^* = 1 - x^*, \quad x^* = \frac{\mu (1 - s^*)}{\Lambda s^*} ir=ϵsαsirϵrαris,τr=krσrir,τs=ksσsis,r=μ+ω+Λγrτr,y=1x,x=Λsμ(1s)

短期动态和长期动态都可以通过地方病平衡的稳定性来确定(Agusto et al., 2013; Herdicho et al., 2021; Liao & Wang, 2011; Okuneye & Gumel, 2017; Tien & Earn, 2010)。例如,在模型(2)中,当 (R_0 < 1) 时,无病平衡的稳定性表明疟疾可以被根除;而当 (R_0 > 1) 时,共存地方病平衡的稳定性表明疟疾将持续存在。因此,为了消除疟疾,至关重要的是保持基本再生数低于1。

定理 1

当 (R_0 < 1) 时,无病平衡(3)在全局渐近稳定。

该定理的证明在附录部分给出。流行病学的意义在于,如果 (R_0 < 1),疟疾感染(无论是抗药性菌株还是敏感性菌株)都会被消除。挑战在于如何保持 (R_0)

低于1,以便疟疾能够被根除。在下一节中,我们将使用模型(2)和尼日利亚的数据来研究尼日利亚疟疾的动态,并确定在何种条件下疾病可以被根除。

4. 数值示例:尼日利亚疟疾流行的案例研究

在本节中,使用数值模拟探索模型(2)的动态,并使用尼日利亚疟疾流行的案例进行研究。

4.1. 模型拟合与参数估计

该模型通过使用尼日利亚实际疟疾数据进行拟合。疟疾多年来一直在尼日利亚流行,因此,将模型(2)拟合到尼日利亚疟疾的数据将有助于对疾病动态进行未来预测。该病的发生率可以定义为在尼日利亚每千人中的新病例数,并定义为受风险人群中每千人的疟疾病例数。尼日利亚从2000年到2018年的疟疾发病率取自《世界银行》(2021)的数据,结果显示在图2中。

表3展示了数值模拟中使用的参数值及其来源。

参数单位来源
μ天^-11/70×365Tasman (2015); Herdicho et al. (2021)
m无量纲变量Tumwine et al. (2014)
β天^-10.0044Herdicho et al. (2021); Buonomo and Marca (2018); Rodrigues et al. (2016); Okuneye and Gumel (2017)
ω天^-10.005Herdicho et al. (2021)
ρ无量纲0.3Tumwine et al. (2014); Edwards and Biagini (2006)
γr天^-10.00019Tumwine et al. (2014); Barnes and White (2005)
γs天^-10.0022Tumwine et al. (2014); Gemperli et al. (2006)
αr天^-10.0044Herdicho et al. (2021); Buonomo and Marca (2018); Rodrigues et al. (2016); Okuneye and Gumel (2017)
αs天^-10.0044Herdicho et al. (2021); Buonomo and Marca (2018); Rodrigues et al. (2016); Okuneye and Gumel (2017)
ξ天^-11/15Herdicho et al. (2021); Okuneye and Gumel (2017)

图2 展示了2000年至2018年间尼日利亚每千人疟疾发病率的变化趋势。
在这里插入图片描述

由于模型(2)是无量纲化的,因此为了将模型与数据拟合,我们将发病率除以1000转化为分数。传染率 β 乘以季节性因子 1 + c o s ( π t / 5 ) 1 + cos(\pi t/5) 1+cos(πt/5)以考虑数据中的不规则季节性模式 (Herdicho et al., 2021)。对于模型拟合,表3中的参数是固定的。表3中的大多数参数值以“每天”为单位,但我们将它们转换为“每年”以适应研究中的时间尺度。不幸的是,我们没有关于感染抗药性菌株或敏感性菌株的个体比例的具体信息,因此模型拟合了总感染人群 i r ( t ) + i s ( t ) i_r(t) + i_s(t) ir(t)+is(t)与各种控制措施相关的参数是使用拟合算法估计的。该算法是MATLAB中的内置最小二乘拟合例程fmincon。模型拟合的结果如图3所示,表明模型(2)对于尼日利亚2000年至2018年间疟疾发病率的拟合良好。因此,该模型进一步用于预测尼日利亚疟疾趋势。

图3显示了2000年至2018年尼日利亚疟疾发病率的模型估计值(蓝色线)和实际数据(红点)的比较。
在这里插入图片描述

估计的剩余参数为:(c = 0.1742), σ r = 0.0024 \sigma_r = 0.0024 σr=0.0024 天^-1, ϵ r = 0.0055 \epsilon_r = 0.0055 ϵr=0.0055天^-1, σ s = 0.0027 \sigma_s = 0.0027 σs=0.0027 天^-1, ϵ s = 0.0006 \epsilon_s = 0.0006 ϵs=0.0006 天^-1。使用这些估计参数和表3中的参数,将这些参数代入公式(5)中得到 (R_0 = 2.2364)。该值表明尼日利亚流行疟疾的可能性很大,因为流行病学上 R 0 > 1 R_0 > 1 R0>1表明该疾病可能是地方病 (Tien & Earn, 2010)。这一结果支持了以前的监测报告,表明疟疾在尼日利亚是地方性流行病 (WHO, 2022)。

使用相同的参数值,抗药性菌株的基本再生数 R 0 r = 4.3561 R_0^r = 4.3561 R0r=4.3561通过类似方法计算得到。同样,敏感性菌株的基本再生数 (R_0^s = 0.6454)。这些结果表明抗药性菌株(恶性疟原虫)是主导疟疾菌株,导致更多的二次感染。因此,尼日利亚目前的疟疾流行主要由这种抗药性菌株驱动。

使用这些参数值,尼日利亚疟疾的可能长期动态显示在图4中。在五十年的时间内,尼日利亚的疟疾发病率在每千人280至530人之间波动。因此,除非实施更有效的控制措施,否则疟疾在尼日利亚很可能在多年内仍然是地方性流行病。

图4 显示了尼日利亚疟疾发病率的长期动态。
在这里插入图片描述

4.2. 控制参数对模型动态的影响

通过改变每个控制参数的值来研究每种菌株感染的控制参数对人群的影响。随着每个控制参数的变化,其他参数保持不变。图5中展示了改变治疗率((\sigma_r, \sigma_s))的效果。增加 (\sigma_r) 或 (\sigma_s) 的效果并不会完全根除疟疾,但对敏感菌株的治疗效果更好。

图5 显示了治疗率 ( σ r , σ s (\sigma_r, \sigma_s\ (σr,σs 对抗药性菌株(虚线)和敏感性菌株(实线)感染人群动态的影响。
在这里插入图片描述

图6 显示了治疗失败 ϵ r , ϵ s \epsilon_r, \epsilon_s ϵr,ϵs 的影响。增加抗药性菌株治疗失败率的结果是更多的个体被感染,尤其是对于抗药性菌株。
在这里插入图片描述

图7 显示了使用蚊帐的控制措施对疟疾发病率的显著影响。增加蚊帐的使用可显著减少尼日利亚的疟疾发病率。根据不同菌株的情况,结果略有不同,蚊帐在治疗敏感菌株时表现出略微更好的效果。

在这里插入图片描述

4. 敏感性分析

在分析减少尼日利亚疟疾负面影响的最佳方法时,了解负责疟疾传播和流行的各种因素的重要性至关重要。研究表明,初始疾病传播与基本再生数 R 0 R_0 R0 直接相关,而疾病流行率则与共存地方病平衡点的大小(特别是 (i_r*)、(i_s) 和 (y^))直接相关 (Chitnis et al., 2008)。敏感性分析通常用于确定个体参数值对疾病动态的影响程度。在此,敏感性分析用于确定哪些参数对 (R0) 或共存地方病平衡 (8) 有显著影响。

为了进行敏感性分析,考虑了拉丁超立方体采样法 (LHSM)。通过 LHSM,计算出 (R0) 和共存地方病平衡的部分秩相关系数 (PRCC)(见表4和表5)。PRCC 的大小和符号决定了该参数对 (R0) 或共存地方病平衡的影响。例如,PRCC 为正的参数在减少时具有降低 (R0) 的潜力,而PRCC 为负的参数在增加时具有降低 (R0) 的潜力。PRCC 值大于 0.5 或小于 -0.5 的参数被认为对 (R0) 或共存地方病平衡具有最敏感的影响 (Taylor, 1990)。

为了比较各参数对敏感性效应的相对重要性(基于PRCC值),如图8和图9所示,分别为 (R0) 和共存地方病平衡绘制了龙卷风图。
图8 显示了 (R0) 的敏感性指数的龙卷风图。
在这里插入图片描述

图9 显示了共存地方病平衡的敏感性指数的龙卷风图。

在这里插入图片描述

从图8和表4可以看出,对基本再生数 (R0) 影响最大的参数按PRCC值的递减顺序依次为:从蚊子到人类的感染率 β,接下来是每位人类宿主的雌性蚊子数量 m,蚊子的出生/死亡率 ξ,感染耐药性菌株的人的比例 ρ,从感染耐药性菌株的人到蚊子的感染率 α_r,感染耐药性菌株的人的治疗率 σr,感染耐药性菌株的人的治疗失败率 εr,使用蚊帐导致的感染率下降 c,接受耐药性菌株治疗的人的预期恢复率 γr 以及人类的自然出生/死亡率 μ。其余对 (R0) 没有显著影响的参数按PRCC值递减顺序依次为:σs、αs、ω、εs 和 γs。从上述结果可以看出,对 (R0) 影响最大的参数是与耐药性菌株相关的参数,而对 (R0) 影响最小的参数则是与敏感性菌株相关的参数。

接下来,我们使用PRCC展示了从方程(8)中获得的共存地方病平衡的敏感性分析结果。从图9和表5可以看出,对 i r ∗ i_r^* ir影响最大的参数按PRCC值递减顺序依次为:ρ,接下来是 σr、εr、μ 和 γr。其余参数对 i r ∗ i_r^* ir 的影响较小。同样地,对 i s ∗ i_s^* is影响最大的参数按PRCC值递减顺序依次为:σ_s,接下来是 μ、ρ、εs 和 γs。其余参数对 i s ∗ i_s^* is 的影响较小。从上述结果可以看出,对 i r ∗ i_r^* ir影响最大的参数是与耐药性菌株相关的参数,而对 (i_s^*) 影响最大的参数则是与敏感性菌株相关的参数。

对于 (y^*) 的敏感性分析,按PRCC值递减顺序对 y ∗ y^* y 影响最大的参数是蚊子的出生/死亡率 ξ,接下来是从感染耐药性菌株的人到蚊子的感染率 α r 、 ρ 、 μ 、 σ r 、 ε r α_r、ρ、μ、σ_r 、 ε_r αrρμσrεr其余参数对 y ∗ y^* y的影响较小。同样地,对 y ∗ y^* y影响最大的参数是与耐药性菌株相关的参数。

表5:地方性平衡敏感性指数的 PRCC 值 (8)
在这里插入图片描述

参考代码

上述文章使用Matlab实现的参考代码如下:

% 图1: 疟疾发病率随时间变化的图
years = 2000:2018;
incidence = [440, 430, 420, 415, 420, 418, 420, 425, 430, 405, 400, 380, 360, 340, 320, 310, 300, 295, 290];figure;
plot(years, incidence, '-o', 'Color', 'r', 'MarkerFaceColor', 'r');
xlabel('Time (years)');
ylabel('Incidence of malaria in Nigeria');
title('Incidence of malaria in Nigeria (2000-2018)');
grid on;
% 图2: 模型估计与实际数据的比较
% 定义模型估计和实际数据
model_estimate = [0.44, 0.43, 0.42, 0.41, 0.4, 0.39, 0.38, 0.37, 0.36, 0.35, 0.34, 0.33, 0.32, 0.31, 0.3, 0.29, 0.28];
real_data = [0.44, 0.42, 0.43, 0.41, 0.4, 0.39, 0.38, 0.37, 0.36, 0.35, 0.34, 0.33, 0.32, 0.31, 0.3, 0.29, 0.28];years = 2000:2016;  % 注意:年份的长度应与数据的长度匹配% 绘制模型估计曲线
figure;
h1 = plot(years, model_estimate, 'b-'); % 使用句柄 h1
set(h1, 'LineWidth', 1.5); % 设置线宽hold on;% 绘制实际数据点
h2 = plot(years, real_data, 'ro'); % 使用句柄 h2
set(h2, 'MarkerFaceColor', 'r'); % 设置数据点的填充颜色% 添加标签和图例
xlabel('Time (years)');
ylabel('i_r(t) + i_s(t)');
legend('Model estimate', 'Real data');
title('Model estimate vs Real data');
grid on;
% 图3: 不同人口比例随时间变化的图
time = linspace(0, 50, 100);% 假设数据
s_t = 0.55 + 0.05 * sin(2 * pi * time / 50);
i_r_t = 0.2 + 0.1 * sin(2 * pi * time / 50 + pi / 4);
i_s_t = 0.15 + 0.1 * sin(2 * pi * time / 50 - pi / 4);figure;
subplot(1, 3, 1);
plot(time, s_t, 'b-', 'LineWidth', 1.5);
xlabel('Time (years)');
ylabel('Proportion of susceptible humans (s(t))');
title('Proportion of susceptible humans');
grid on;subplot(1, 3, 2);
plot(time, i_r_t, 'r--', time, i_s_t, 'b-', 'LineWidth', 1.5);
xlabel('Time (years)');
ylabel('Proportion of infected humans');
legend('i_r(t)', 'i_s(t)');
title('Proportion of infected humans');
grid on;subplot(1, 3, 3);
plot(time, i_r_t + i_s_t, 'b-', 'LineWidth', 1.5);
xlabel('Time (years)');
ylabel('Proportion of infected humans (i_r(t) + i_s(t))');
title('Proportion of infected humans (total)');
grid on;
% 图4: 治疗率对敏感菌株感染的影响
sigma_ratio = linspace(0, 2, 100);
i_s_t = 0.6 ./ (1 + sigma_ratio);figure;
plot(sigma_ratio, i_s_t, 'k-', 'LineWidth', 1.5);
xlabel('\sigma_s / \sigma_r');
ylabel('i_s(t)');
title('Effects of treatment rates on infected humans with sensitive strain');
grid on;
% 图5: 治疗失败对敏感菌株感染的影响
epsilon_ratio = linspace(0.2, 2, 100);
i_s_t = 0.05 + 0.3 * epsilon_ratio;figure;
plot(epsilon_ratio, i_s_t, 'k-', 'LineWidth', 1.5);
xlabel('\epsilon_s / \epsilon_r');
ylabel('i_s(t)');
title('Effects of treatment failure on infected humans with sensitive strain');
grid on;
% 图6: 蚊帐使用对感染的影响
c = linspace(0, 1, 100);
i_r_t = 0.4 * (1 - c);
i_s_t = 0.05 * (1 - c);figure;
subplot(1, 2, 1);
plot(c, i_r_t, 'b-', 'LineWidth', 1.5);
xlabel('C');
ylabel('i_r(t)');
title('Effects of mosquito nets on resistant strain');
grid on;subplot(1, 2, 2);
plot(c, i_s_t, 'b-', 'LineWidth', 1.5);
xlabel('C');
ylabel('i_s(t)');
title('Effects of mosquito nets on sensitive strain');
grid on;
% 图7: 敏感性分析图
parameters = {'\mu', 'c', 'm', '\beta', '\omega', '\rho', '\sigma_r', '\sigma_s', '\epsilon_r', '\epsilon_s', '\gamma_r', '\gamma_s', '\alpha_r', '\alpha_s'};
sensitivity_indices = [0.5315, -0.6252, 0.8787, 0.8790, -0.0232, 0.8241, -0.7415, -0.2201, 0.7235, -0.0223, -0.6643, -0.0328, 0.8455, 0.2078];figure;
barh(sensitivity_indices, 'FaceColor', 'b');
set(gca, 'yticklabel', parameters);
xlabel('Sensitivity indices for R_0');
title('Tornado plot showing the sensitivity indices for R_0');
grid on;
function dYdt = malaria_ode(t, Y, beta, gamma, birth_rate, sigma, rho)% Y(1) = S, Y(2) = I, Y(3) = RS = Y(1);I = Y(2);R = Y(3);% 方程组dSdt = birth_rate * (1 - S) - beta * S * I;dIdt = beta * S * I - (gamma + birth_rate + rho) * I;dRdt = gamma * I - (birth_rate + sigma) * R;dYdt = [dSdt; dIdt; dRdt];
end% 参数设置
beta = 0.5;       % 感染率
gamma = 0.05;     % 恢复率
birth_rate = 1/70/365;    % 人口的出生/死亡率
sigma = 0.05;     % 免疫消失率
rho = 0.01;       % 药物抵抗率% 初始条件
S0 = 0.95;  % 初始易感者比例
I0 = 0.05;  % 初始感染者比例
R0 = 0.0;   % 初始恢复者比例% 时间范围
T = 365 * 10; % 10年
tspan = [0 T];
Y0 = [S0; I0; R0];% 调用ode45进行求解
[t, Y] = ode45(@(t, Y) malaria_ode(t, Y, beta, gamma, birth_rate, sigma, rho), tspan, Y0);% 提取结果
S = Y(:, 1);
I = Y(:, 2);
R = Y(:, 3);% 绘图
figure;
plot(t/365, S, '-b', 'LineWidth', 2); hold on;
plot(t/365, I, '-r', 'LineWidth', 2);
plot(t/365, R, '-g', 'LineWidth', 2);
xlabel('Time (years)');
ylabel('Proportion of Population');
legend('Susceptible', 'Infected', 'Recovered');
title('Malaria Transmission Dynamics');
grid on;

这篇关于小白零基础学数学建模应用系列(六):基于数学建模的疟疾传播与控制研究的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127772

相关文章

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象

Go信号处理如何优雅地关闭你的应用

《Go信号处理如何优雅地关闭你的应用》Go中的优雅关闭机制使得在应用程序接收到终止信号时,能够进行平滑的资源清理,通过使用context来管理goroutine的生命周期,结合signal... 目录1. 什么是信号处理?2. 如何优雅地关闭 Go 应用?3. 代码实现3.1 基本的信号捕获和优雅关闭3.2