-
Notifications
You must be signed in to change notification settings - Fork 1
/
05_Metapop_practical.qmd
123 lines (95 loc) · 4.17 KB
/
05_Metapop_practical.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
---
title: "05. Metapopulations with ODEs"
---
The code below has been written to solve a Susceptible-Infected-Recovered model with two populations. Familiarise yourself with the expanded model before moving onto the activities that follow. Note: the compartments C1 and C2 reflect the cumulative numbers of people infected. This will be used later on.
```{r}
# Load in the deSolve package
library(deSolve)
# If the package is not installed, install using the install.packages() function
# Define model function
SIR_metapop_model <- function(times, state, parms){
## Define variables
S1 <- state["S1"]
I1 <- state["I1"]
R1 <- state["R1"]
C1 <- state["C1"]
N1 <- S1 + I1 + R1
S2 <- state["S2"]
I2 <- state["I2"]
R2 <- state["R2"]
C2 <- state["C2"]
N2 <- S2 + I2 + R2
# Extract parameters
beta <- parms["beta"]
gamma <- parms["gamma"]
alpha <- parms["alpha"]
lambda1 <- (beta * I1 / N1 + alpha * beta * I2 / N2)
lambda2 <- (beta * I2 / N2 + alpha * beta * I1 / N1)
# Define differential equations
dS1 <- - lambda1 * S1
dI1 <- lambda1 * S1 - gamma * I1
dR1 <- gamma * I1
dC1 <- lambda1 * S1
dS2 <- - lambda2 * S2
dI2 <- lambda2 * S2 - gamma * I2
dR2 <- gamma * I2
dC2 <- lambda2 * S2
res <- list(c(dS1, dI1, dR1, dC1, dS2, dI2, dR2, dC2))
return(res)
}
# Define parameters
parameters <- c( beta = 0.4, gamma = 0.1, alpha = 1)
# Define time to run model
times <- seq(from = 0, to = 50, by = 1)
# Define initial conditions
N1 <- 1000; N2 <- 1000
I1_0 <- 1; I2_0 <- 0
R1_0 <- 0; R2_0 <- 0
C1_0 <- 0; C2_0 <- 0
S1_0 <- N1 - I1_0
S2_0 <- N2 - I2_0
state <- c(S1 = S1_0, I1 = I1_0, R1 = R1_0, C1 = C1_0,
S2 = S2_0, I2 = I2_0, R2 = R2_0, C2 = C2_0)
# Solve equations
output_raw <- ode(y = state,
times = times,
func = SIR_metapop_model,
parms = parameters)
# Convert to data frame for easy extraction of columns
output <- as.data.frame(output_raw)
# Plot output
par(mfrow = c(1, 1))
plot(output$time, output$I1, type = "l", col = 4, lwd = 2, ylim = c(0, N1),
xlab = "Time", ylab = "Number", main = "")
lines(output$time, output$I2, lwd = 2, col = 2, type = "l")
legend("topright",
legend = c("Infected in population 1",
"Infected in population 2"),
lty = rep(1, 2), col = c(4, 2), lwd = 2, bty = "n")
```
## Question A
When you simulate the above model, you'll notice that currently the epidemics are nearly identical in the two populations. Update the model parameters so the transmission rate between the two populations is equal to 5% of the transmission rate within each population. What happens to the size and timing of the epidemics?
## Question B
What happens if the epidemic starts with 10 people infected in both populations? Why does this happen?
## Question C
The model is currently set up to record the number of cumulative cases in each population (i.e. C1 and C2). The below code will plot these cumulative numbers of cases. Update the code so you are plotting incidence, i.e. new cases appearing over time, rather than cumulative cases.
```{r}
par(mfrow = c(1, 1))
plot(output$time, output$C1, type = "l", col = 4, lwd = 2, ylim = c(0, N1+100),
xlab = "Time", ylab = "Number", main = "")
lines( output$time, output$C2, lwd = 2, col = 2, type = "l")
legend("topright",
legend = c("Cumulative cases in population 1",
"Cumulative cases in population 2"),
lty = rep(1, 2), col = c(4, 2), lwd = 2, bty = "n")
```
Hint: Create a new variable that calculates the difference between adjacent timesteps, i.e. C1\[2:t\] - C1\[1:(t-1)\]
## Question D
What does the incidence look like if only 50% of the cases in population 2 are reported?
Hint: There are several ways to do this - some are easier than others.
## Question E
If you have time, expand the model to include three populations (denoted 1, 2, 3). How would you model an epidemic where:
- mixing between population 1 and population 2 is 5% of the rate of mixing within these populations
- mixing between population 1 and population 3 is 10% of the rate of mixing within these populations
- there is no mixing between population 2 and population 3
**Solutions to this practical can be accessed [here](05_Metapop_solutions.qmd).**