关键词
Python | 数学 | 流感 | 病情 | 感染 | 病毒 | 常微分方程 | 模型 | 求解器 | 推理 | 人口 | 分布 | 感染率 | 免疫力 | 表征 | 相图 | 流图 | 时间 | 衰减率 | 携带者 | 宿主 | 异质 | 矩阵 | 接触网络 | 年龄 | 种群 | 病原体 | 传播 | 动力学 | 交叉免疫 | 平衡态 | 稳定性 | 晶格 | 欧拉
🏈指点迷津 | Brief🎯要点
🎯房室数学模型:🖊常微分方程推理模型 | 🖊模型求解条件:静态人口、混合均匀分布、感染率相同、健康免疫力 | 🖊绘制模型表征接近平衡相图 | 🖊计算模型随时间变化有效传染数 | 🖊计算免疫力衰减率 | 🖊计算反复感染和传染性关系模型 | 🖊计算病毒携带者模型 | 🖊计算低传染性。🎯宿主模型:🖊计算风险异质人群 | 🖊计算接触网络混合矩阵 | 🖊年龄异质性耦种群变化 | 🖊感染矩阵模型推理。🎯病原体模型:🖊疟疾传播常微分方程模型 | 🖊绘制模型单相剖面流图 | 🖊媒介传播疾病推理 | 🖊人畜共患疾病模型。🎯病原体动力学:🖊无共感染无交叉免疫微分方程模型。🎯疫苗建模 | 🎯流感时间动态平衡态和稳定性分析 | 🎯流感空间动态晶格模型。
🎯常微分方程-用例:Python机器人动力学和细胞酶常微分方程。
🍇Python欧拉法求解一般流感常微分方程模型
这些模型通常使用常微分方程(确定性)运行,但也可以与随机框架一起使用,这种框架更现实,但分析起来要复杂得多。
此类模型可以预测诸如疾病如何传播、感染总数或流行病持续时间之类的事情,并估计各种流行病学参数,如再生数。 还可以显示不同的公共卫生干预措施如何影响流感的结果,例如,在特定人群中发放有限数量的疫苗的最有效技术是什么。
模型参数假设:
平均而言,群体中的S个体每单位时间会遇到β个体。
每单位时间离开房室I的感染者的比率是γ I(一旦一个人被感染,他就会对该疾病产生免疫力)。
人口规模N=S+I+R是恒定的
这是模型的方程组:
⎩⎨⎧dtdS=−NβSIdtdI=NβSI−γI,dtdR=γI. 模型图示:
问题公式化
X=SIR 微分系统写为:
X˙=−NβSINβSI−γIγI=f(X) 💦通用方法求解
import numpy as np
import matplotlib.pyplot as plt
import matplotlib as mpl
import pandas as pd
import numba
from scipy import integrate
💦给定相应数据:
N = 350.
I0, R0 = 1., 0
S0 = N - I0 - R0
beta, gamma = 0.4, 0.1
tmax = 160
Nt = 160
t = np.linspace(0, tmax, Nt+1)
💦定义微分函数:
def derivative(X, t):
S, I, R = X
dotS = -beta * S * I / N
dotI = beta * S * I / N - gamma * I
dotR = gamma * I
return np.array([dotS, dotI, dotR])
X0 = S0, I0, R0 #Initial conditions vector
res = integrate.odeint(derivative, X0, t)
S, I, R = res.T
Seuil = 1 - 1 / (beta/gamma)
Seuil
绘制个体疑似感染、感染和恢复趋势图:
plt.figure()
plt.grid()
plt.title("odeint method")
plt.plot(t, S, 'orange', label='Susceptible')
plt.plot(t, I, 'r', label='Infected')
plt.plot(t, R, 'g', label='Recovered with immunity')
plt.xlabel('Time t, [days]')
plt.ylabel('Numbers of individuals')
plt.ylim([0,N])
plt.legend()
plt.show();
💦欧拉法求解:
def Euler(func, X0, t):
dt = t[1] - t[0]
nt = len(t)
X = np.zeros([nt, len(X0)])
X[0] = X0
for i in range(nt-1):
X[i+1] = X[i] + func(X[i], t[i]) * dt
return X
Nt = 100
Xe = Euler(derivative, X0, t)
plt.figure()
plt.title("Euler method")
plt.plot(t, Xe[:,0], color = 'orange', linestyle = '-.', label='Susceptible')
plt.plot(t, Xe[:,1], 'r-.', label='Infected')
plt.plot(t, Xe[:,2], 'g-.', label='Recovered with immunity')
plt.grid()
plt.xlabel("Time, $t$ [s]")
plt.ylabel("Numbers of individuals")
plt.legend(loc = "best")
plt.show();