主頁 > 後端開發 > Python小白的數學建模課-B2. 新冠疫情 SI模型

Python小白的數學建模課-B2. 新冠疫情 SI模型

2021-06-29 06:11:09 後端開發


傳染病的數學模型是數學建模中的典型問題,常見的傳染病模型有 SI、SIR、SIRS、SEIR 模型,

SI 模型是最簡單的傳染病模型,適用于只有易感者和患病者兩類人群,

我們就從 SI 模型開始吧,從模型、例程、運行結果到模型分析,全都在這個系列中,

『Python小白的數學建模課 @ Youcans』帶你從數模小白成為國賽達人,



1. 前言

新冠疫情不僅嚴重影響到全球的政治和經濟,深刻和全面地影響著社會和生活的方方面面,也已經成為數學建模競賽的背景帝,

傳染病的數學模型是數學建模中的典型問題,標準名稱是流行病的數學模型(Mathematical models of epidemic diseases),建立傳染病的數學模型來描述傳染病的傳播程序,研究傳染病的傳播速度、空間范圍、傳播途徑、動力學機理等問題,以指導對傳染病的有效地預防和控制,具有重要的現實意義,

不同型別傳染病的傳播具有不同的特點,傳染病的傳播模型不是從醫學角度分析傳染病的傳播程序,而是按照傳播機理建立不同的數學模型,

首先,把傳染病流行范圍內的人群分為 S、E、I、R 四類,具體含義如下:

  • S 類(Susceptible),易感者,指缺乏免疫能力的健康人,與感染者接觸后容易受到感染;

  • E 類(Exposed),暴露者,指接觸過感染者但暫無傳染性的人,適用于存在潛伏期的傳染病;

  • I 類(Infectious),患病者,指具有傳染性的患病者,可以傳播給 S 類成員將其變為 E 類或 I 類成員;

  • R 類(Recovered),康復者,指病愈后具有免疫力的人,如果免疫期有限,仍可以重新變為 S 類成員,進而被感染;如果是終身免疫,則不能再變為 S類、E類或 I 類成員,

常見的傳染病模型按照傳染病型別分為 SI、SIR、SIRS、SEIR 模型等,就是由以上四類人群根據不同傳染病的特征進行組合而產生的不同模型,



2. 疫情傳播 SI 模型

2.1 SI 模型的適用范圍

SI 模型適用于只有易感者和患病者兩類人群,且無法治愈的疾病,例如 T型病、僵尸,

2.2 SI 模型的假設

  1. 考察地區的總人數 N 不變,即不考慮生死或遷移;
  2. 人群分為易感者(S類)和患病者(I類)兩類;
  3. 易感者(S類)與患病者(I類)有效接觸即被感染,變為患病者,無潛伏期、無治愈情況、無免疫力;
  4. 每個患病者每天有效接觸的易感者的平均人數(日接觸數)是 \(\lambda\),稱為日接觸率;
  5. 將第 t 天時 S類、I 類人群的占比記為 \(s(t)\)\(i(t)\),數量為 \(S(t)\)\(I(t)\);初始日期 \(t=0\) 時, S類、I 類人群占比的初值為 \(s_0\)\(i_0\)

2.3 SI 模型的微分方程

\[\begin{align*} N\frac{di}{dt} = N\lambda s i \end{align*} \]

得:

\[\begin{align*} \frac{di}{dt} = \lambda i (1-i),\ i(0) = i_0 \end{align*} \]

這是 Logistic 模型,用分離變數法可以求出其決議解為:

\[\begin{align*} & i(t)=\frac{1}{1+(1/i_0 - 1)\ e^{-\lambda t}}\\ & I(t)= N\ i(t) \end{align*} \]



3. SI 模型的 Python 編程

3.1 SI 模型的決議解

上文已經得到 SI 模型的決議解,對此很容易通過 Python 編程實作,詳見本文例程,

雖然 SI 模型的決議解并不復雜,而且解的精度當然是最好的,但我們仍然不鼓勵用決議解的方法,原因在于,一是對于小白求決議解的程序相對復雜困難,而且可能出錯,二是對于更復雜的模型是沒有決議解的,即便大神也只能用數值方法求解,既然如此,不如從一開始就學習、掌握數值求解方法,熟悉數值解法的編程實作,

3.2 SI 模型的數值解

SI 模型是常微分方程初值問題,可以使用 Scipy 工具包的 scipy.integrate.odeint() 函式求數值解,具體方法可以參考前文《Python小白的數學建模課-09 微分方程模型》,

scipy.integrate.odeint(func, y0, t, args=())

**scipy.integrate.odeint() **是求解微分方程的具體方法,通過數值積分來求解常微分方程組,

odeint() 的主要引數:

  • func: callable(y, t, …)   導數函式 \(f(y,t)\) ,即 y 在 t 處的導數,以函式的形式表示
  • y0: array:  初始條件 \(y_0\),對于常微分方程組 \(y_0\) 則為陣列向量
  • t: array:  求解函式值對應的時間點的序列,序列的第一個元素是與初始條件 \(y_0\) 對應的初始時間 \(t_0\);時間序列必須是單調遞增或單調遞減的,允許重復值,
  • args: 向導數函式 func 傳遞引數,當導數函式 \(f(y,t,p1,p2,..)\) 包括可變引數 p1,p2.. 時,通過 args =(p1,p2,..) 可以將引數p1,p2.. 傳遞給導數函式 func,

odeint() 的回傳值:

  • y: array   陣列,形狀為 (len(t),len(y0),給出時間序列 t 中每個時刻的 y 值,

odeint() 的編程步驟:

  1. 匯入 scipy、numpy、matplotlib 包;
  2. 定義導數函式 \(f(i,t)=\lambda i (1-i)\)
  3. 定義初值 \(i_0\)\(i\) 的定義區間 \([t_0,\ t]\)
  4. 呼叫 odeint() 求 \(i\) 在定義區間 \([t_0,\ t]\) 的數值解,

3.3 Python例程:SI 模型的決議解與數值解

# 1. SI 模型,常微分非常,決議解與數值解的比較
from scipy.integrate import odeint  # 匯入 scipy.integrate 模塊
import numpy as np  # 匯入 numpy包
import matplotlib.pyplot as plt  # 匯入 matplotlib包

def dy_dt(y, t, lamda, mu):  # 定義導數函式 f(y,t)
    dy_dt = lamda*y*(1-y)  # di/dt = lamda*i*(1-i)
    return dy_dt

# 設定模型引數
number = 1e7  # 總人數
lamda = 1.0  # 日接觸率, 患病者每天有效接觸的易感者的平均人數
mu1 = 0.5  # 日治愈率, 每天被治愈的患病者人數占患病者總數的比例
y0 = i0 = 1e-6  # 患病者比例的初值
tEnd = 50  # 預測日期長度
t = np.arange(0.0,tEnd,1)  # (start,stop,step)

yAnaly = 1/(1+(1/i0-1)*np.exp(-lamda*t))  # 微分方程的決議解
yInteg = odeint(dy_dt, y0, t, args=(lamda,mu1))  # 求解微分方程初值問題
yDeriv = lamda * yInteg *(1-yInteg)

# 繪圖
plt.plot(t, yAnaly, '-ob', label='analytic')
plt.plot(t, yInteg, ':.r', label='numerical')
plt.plot(t, yDeriv, '-g', label='dy_dt')
plt.title("Comparison between analytic and numerical solutions")
plt.legend(loc='right')
plt.axis([0, 50, -0.1, 1.1])
plt.show()

3.4 決議解與數值解的比較

本圖為例程 2.3 的運行結果,圖中對決議解(藍色)與使用 odeint() 得到的數值解(紅色)進行比較,在該例中,無法觀察到決議解與數值解的差異,表明數值解的誤差很小,

圖中 \(di/dt\) 具有最大值,最大值表示疫情增長的高潮,達到最大值后 \(di/dt\) 逐漸減小,但患病者比例很快增長到 100%,表明所有人都被感染成為患者,

這是特定引數的結果,還是模型的必然趨勢,需要對引數的影響進行更詳細的研究,



4. SI 模型引數的影響

對于 SI 模型,只有日接觸率 \(\lambda\) 和患病者比例的初值 \(i_0\) 會影響模型的結果,其它引數如總人數 N 并沒有影響,

4.1 日接觸率對 SI 模型的影響

對不同日接觸率的比較表明:

  1. 日接觸率越大,疫情從發生到爆發的時間越短,爆發程序的增長速度也越快,
  2. 不論日接觸率多大,患病者的比例最終都會增長到 1,表明所有人都被感染成為患者,
  3. 不論日接觸率多大,都具有緩慢發展、爆發、增長放緩 3 個階段,進入爆發階段后患病者的比例急劇增長,疫情就很難控制了,

4.2 患病者比例的初值對 SI 模型的影響

對患病者比例初值的比較表明,患病者初值的人數或比例只影響疫情爆發期到來的快慢,對疫情傳播的程序和結果幾乎沒有影響,

這與我們直觀的經驗不太一致,一個原因是 SI 模型本身存在不足,另一方面也說明如果對傳染病不加控制,即使開始患病人數很少,經過一段時間的傳播后也終將會引起爆發,

4.3 SI 模型結果討論

  1. \(i(t)=0.5,\ I(t) = N/2\) 時 $ di/dt$ 達到最大值,病人數目 \(I(t)\) 增加最快,由此可以預報傳染病高潮的到來,即為醫院的門診量最大的一天,衛生部門要重點關注,
  2. \(t_m\)\(\lambda\) 成反比,日接觸率 \(\lambda\) 反映衛生水平、防控手段,提高衛生水平、強化防控手段,降低病人的日接觸率,可以推遲傳染病高潮的到來,
  3. 當 $ t \to \infty$ 時 \(i \to 1\) ,表明所有人最終都會被傳染而變成病人,這完全不符合實際情況,表明該模型太不講 politics 了,只能適用于美帝國家建模,
  4. SI 模型非常明顯而嚴重的缺陷,是該模型沒有考慮患病者可以治愈,因此只能是健康人患病,而患病者不能恢復健康(甚至也不會死亡,而是不斷傳播疫情),所以終將全部被傳染,

【本節完】

著作權宣告:

歡迎關注『Python小白的數學建模課 @ Youcans』 原創作品

原創作品,轉載必須標注原文鏈接:(https://www.cnblogs.com/youcans/p/14944259.html),

Copyright 2021 Youcans, XUPT

Crated:2021-06-09


歡迎關注 『Python小白的數學建模課 @ Youcans』,每周更新數模筆記
Python小白的數學建模課-01.新手必讀
Python小白的數學建模課-02.資料匯入
Python小白的數學建模課-03.線性規劃
Python小白的數學建模課-04.整數規劃
Python小白的數學建模課-05.0-1規劃
Python小白的數學建模課-06.固定費用問題
Python小白的數學建模課-07.選址問題
Python小白的數學建模課-09.微分方程模型
Python小白的數學建模課-B2.新冠疫情 SI模型
Python數模筆記-PuLP庫
Python數模筆記-StatsModels統計回歸
Python數模筆記-Sklearn
Python數模筆記-NetworkX
Python數模筆記-模擬退火演算法


轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/288609.html

標籤:Python

上一篇:Python 執行緒池 ThreadPoolExecutor(一) - Python零基礎入門教程

下一篇:Python 執行緒池 ThreadPoolExecutor(二) - Python零基礎入門教程

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more