新冠病毒传播预测

代码如下:

import ode_7 as ode  
import numpy as np  
import matplotlib.pyplot as plt  
# 采用matplotlib作图时默认设置下是无法显示中文的,凡是汉字都会显示成方块。  
# 实际上,matplotlib是支持unicode编码的,不能正常显示汉字主要是没有找到合适的中文字体。  
from pylab import mpl  
mpl.rcParams['font.sans-serif']= ['SimHei']  
# 解决负号显示问题  
import matplotlib  
matplotlib.rcParams['axes.unicode_minus']=False
'''  
根据传染病传播的SIR模型,微分方程组可以转换为向量运算:  
y = [S, I, R]  
f(t, y) = [-beta*y[0]*y[1], beta*y[0]*y[1]-gamma*y[1], gamma*y[1]]  
前向欧拉公式:  
    y[k+1] = y[k] + dt * f(t[k], y[k])  
后向欧拉公式(两步迭代):  
    y_p = y[k] + dt * f(t[k], y[k])  
    y[k+1] = y[k] + dt * f(x[k+1], y_p)  
改进的欧拉法:  
    y_p = y[k] + dt * f(t[k], y[k])  
    y_c = y[k] + dt * f(t[k+1], y_p)  
    y[k+1] = 1/2 * (y_p + y_c)  
'''  
class SIR(ode.ODE):  
    def f(self, 
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值