Interaktyvus pratimas nr. 7. SIR modelis
Šiame interaktyviame pratime nagrinėsime SIR modelį, kuris yra skirtas epidemiologams, kurie prognozuoja pandemijos elgesį šalyje. Kaip jau buvo minėta paskaitos metu, šis modelis yra pakankamai paprastai suvokiamas, tačiau nagrinėja tik tris asmenų tipus:
- Liga nepaveikti asmenys (angl. susceptible individuals);
- Liga užkrėsti asmenys (angl. infectious individuals);
- Pasveikę asmenys (angl. recovered individuals).
Iš angliškų grupių pavadinimų galite suprasti, kodėl modelis turi tokį pavadinimą.
Dėja, prie paskutinės grupės taip tat yra priskiriami ir mirę nuo ligos asmenys. Kitaip sakoma, kad trečiąją asmenų grupę sudaro taip vadinami pasibaigę atvėjai, t.y. tie, kuriems jau yra žinomas rezultatas (asmuo pasveiko arba mirė).
Modelis nagrinėja šių trijų grupių pokyčius realiuoju laiku. Dėl to modelyje susiduriame su išvestinės sąvoka. Jeigu konkrečiau, tai yra nagrinėjama diferencialinių lygčių sistema:
čia
yra koeficientai, kurie parodo šias tikimybes: - Koeficientas b parodo tikimybę, kad ligos nepaveikas asmuo bus užkrėstas po kontakto su sergančiu asmeniu (epidemijos vystimosi sparta);
- Koeficientas c parodo tikimybę, kad užkrėstas žmogus pasveiko (epidemijos išnykimo sparta).
Šiuos koeficientus siūlome keisti. Apačioje grafiškai pavaizduotos trys funkcijos
- sveikieji asmenys,
- užkrėstieji asmenys ir
- pasveikę (arba mirę) asmenys. Visą populiaciją laikydami lygią 1 galime keisti sveikųjų asmenų dalį populiacijoje pradiniu laiko momentu. Laikysime, kad visi kiti asmenys yra užsikrėtę, o pasveikusių asmenų pradiniu laiko momentu nėra. Taip pat galite keisti stebimo laiko intervalo galą T, t.y. epidemija bus stebima laikotarpiu
. IC = [healphy, infected, recovered];
[t, X] = ode45(@(t, X) SIR(t, X, b, c), t_int, IC);
legend('S(t)', 'I(t)', 'R(t)')
function dxdt = SIR(t, X, b, c)
dx2 = b * X(2) * X(1) - c * X(2);
Pabandykite patys
- Pakeiskite modelį taip, kad būtų vertinamas faktas, jog pasveikęs žmogus gali pakairtotinai susirgti šia lyga su tam tikra tikimybe p.