-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathibm_slides.Rmd
206 lines (144 loc) · 6.15 KB
/
ibm_slides.Rmd
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
---
title: "Introduction to individual-based modelling using R"
subtitle: https://stirlingcodingclub.github.io/individual_based_modelling
author: "Brad Duthie"
date: "05 April 2023"
output:
beamer_presentation:
theme: "default"
colortheme: "default"
fonttheme: "default"
ioslides_presentation: default
slidy_presentation: default
header-includes:
- \usepackage{hyperref}
- \usepackage{tikz}
- \usepackage{caption}
- \definecolor{links}{HTML}{2A1B81}
- \hypersetup{colorlinks,linkcolor=,urlcolor=links}
colorlinks: true
linkcolor: blue
urlcolor: blue
---
```{r, echo = FALSE}
library(knitr);
opts_chunk$set(echo = FALSE);
```
## Individual-based modelling: what is it?
- Simulate a system *in silico*, using computer code \newline\pause
- Individuals are represented as discrete entities
```{r, out.width = "80%", echo = FALSE, fig.cap = ""}
include_graphics("images/individuals.pdf");
```
\footnotetext[1]{Duthie, A. B., \& Reid, J. M. (2016). {\it Am. Nat.} \href{https://doi.org/10.1086/688919}{186, 651-667}.}
## Individual-based modelling: what is it?
\begin{columns}
\begin{column}{0.4\textwidth}
```{r, out.width = "100%", echo = FALSE, fig.cap = ""}
include_graphics("images/df_fig1.png");
```
\end{column}
\begin{column}{0.6\textwidth}
\begin{itemize}
\item Processes are often stochastic (events probabilistic) \newline\pause
\item Can test ideas by simulating across many parameters \newline\pause
\item Highly mechanistic models are possible
\end{itemize}
\end{column}
\end{columns}
\footnotetext[1]{Duthie, A. B., \& Falcy, M. R. (2013). {\it Ecol. Modell.} \href{https://doi.org/10.1016/j.ecolmodel.2012.12.019}{251, 260-270}.}
## Advantages & disadvantages of using IBMs
**Advantages**
1. Very easy to model individual variation (genetic, phenotypic, environment, etc.)
2. Key biological processes are inherent to the model (e.g., drift, mutation, demography)
3. Models can often be more detailed and therefore more targeted \pause
**Disadvantages**
1. Computational power can be limiting
2. Sometimes difficult to see the link between model assumptions and model predictions (i.e., difficult to interpret results)
## Advantages & disadvantages of using IBMs
```{r, out.width = "80%", echo = FALSE, fig.cap = ""}
include_graphics("images/big_results.png");
```
\footnotetext[1]{Duthie, A. B., \& Reid, J. M. (2016). {\it Am. Nat.} \href{https://doi.org/10.1086/688919}{186, 651-667}.}
## Getting started using R for IBMs
- **Objective**: Learn how to start writing IBMs from a basic knowledge of R coding \newline
- **Notes**: Walk through [all of the code](https://stirlingcodingclub.github.io/individual_based_modelling/ibm_notes.html) required to get started with a basic predator-prey model \newline
- **Caveat**: Code in the notes is not optimised for speed \newline
- **Languages**: Other languages such as [C](https://en.wikipedia.org/wiki/C_(programming_language)), [C++](https://en.wikipedia.org/wiki/C%2B%2B), or [NetLogo](https://ccl.northwestern.edu/netlogo/) are also worth considering
## One way to model individuals in an IBM
**Rows are individuals \& columns are individual characteristics** \newline
```{r, echo = FALSE}
library(knitr);
inds <- array(data = 0, dim = c(8, 5));
colnames(inds) <- c("ind_ID", "x_loc", "y_loc", "body_mass", "age");
#rownames(inds) <- c("ind_1", "ind_2", "ind_3", "ind_4", "ind_5", "ind_6", "ind_7", "ind_8");
inds[,1] <- 1:8;
inds[,2] <- sample(x = 1:8, size = 8, replace = TRUE);
inds[,3] <- sample(x = 1:8, size = 8, replace = FALSE);
inds[,4] <- round(rnorm(n = 8, mean = 40, sd = 6), digits = 2);
inds[,5] <- sample(x = 1:6, size = 8, replace = TRUE);
kable(inds);
```
The process of modelling is then to do something to the individuals and their characteristics -- have them interact, change, be removed, have more added. Models are as complex as we are willing to code.
## Individual-based models are often spatially explicit
```{r, echo = FALSE}
xlocs <- sample(x = 1:8, size = 6, replace = TRUE);
ylocs <- sample(x = 1:8, size = 6, replace = FALSE);
ind2 <- array(data = 0, dim = c(6, 3));
colnames(ind2) <- c("ind_ID", "x_loc", "y_loc");
ind2[,1] <- 1:6;
ind2[,2] <- xlocs;
ind2[,3] <- ylocs;
```
\begin{columns}
\begin{column}{0.5\textwidth}
```{r, out.width = "100%", echo = FALSE, fig.cap = "", fig.width = 4.5, fig.height = 4.5}
par(mar = c(5, 5, 1, 1));
plot(x = 1:8, y = 1:8, type = "n", xaxt = "n", yaxt = "n", xlab = "x location",
ylab = "y location", xlim = c(0.5, 8.5), ylim = c(0.5, 8.5), yaxs= 'i',
xaxs = 'i', cex.lab = 1.5);
axis(side = 1, at = 1:8, labels = 1:8, cex.axis = 1.5);
axis(side = 2, at = 1:8, labels = 1:8, cex.axis = 1.5);
pt <- seq(from = 0.5, to = 7.5, length = 8);
for(i in 1:8){
abline(v = pt[i]);
abline(h = pt[i]);
}
points(x = inds[,2], y = inds[,3], pch = 20, cex = 6, col = "blue");
text(x = inds[,2], y = inds[,3], labels = 1:8, col = "white");
```
\end{column}
\begin{column}{0.5\textwidth}
\begin{itemize}
\item Individual locations can be mapped to a landscape, with rules for movement
\item Movement entails rules for changing x and y locations
\item Landscape need not be represented in code, but can be to define landscape properties
\end{itemize}
\end{column}
\end{columns}
## Simulate individuals over multiple time steps
**Define individuals**
```
inds <- array(data = 0, dim = c(5, 3));
inds[, 1] <- 1:5;
inds[, 2] <- sample(x = 1:8, size = 5, replace = TRUE);
inds[, 3] <- sample(x = 1:8, size = 5, replace = TRUE);
```
**Move individuals to the right 5 times**
```
ts <- 0;
time_steps <- 5;
while(ts < time_steps){
inds[, 2] <- inds[, 2] + 1;
ts <- ts + 1;
}
```
## Working through the IBM notes
\hrule\vspace{2mm}
[https://stirlingcodingclub.github.io/individual_based_modelling/ibm_notes.html](https://stirlingcodingclub.github.io/individual_based_modelling/ibm_notes.html)
\vspace{2mm}
\hrule
\vspace{10mm}
- Walks through R code for modelling individual movement, birth, death, and predation over time \newline
- Meant to be a starting point for further development \newline
- Ask questions in Teams chat and in the [GitHub Repository issues page](https://github.com/StirlingCodingClub/individual_based_modelling/issues)