-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path09-chap9.Rmd
331 lines (251 loc) · 21.5 KB
/
09-chap9.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
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
# Categorical Data Analysis {#chap9}
## Types of Data
There are two basic types of data, __continuous__ and __discrete__. Continuous measurements are on some kind of scale, for example an _interval_ scale, where distances between values on the scale but ratios are not, for example temperature in degrees Celsius. It makes sense to say that two temperatures are different, but it makes no sense to calculate the ratio of temperatures on the Celsius scale. Another possibility is the _ratio_ scale, where there is a meaningful zero point. Examples include body mass and temperature in degrees Kelvin. Other types of continuous data include circular data, such as angles or compass bearings.
In this chapter we will discuss the analysis of _discrete_ data. Discrete data can be _ordinal_ or ranked, such as League tables in sporting contests. Or they may be _nominal_ or categorical, falling into separate, unordered, categories.
# Multinomial Experiments
The simplest type of experiment that leads to categorical data is the ``multinomial`` experiment. A multinomial experiment consists of $n$ identical trials. The outcome of each trial falls into one of k categories or cells. The probability that the outcome of a single trial will fall in a particular cell, say, cell i is $p_i$ , where $i = 1, 2, \dots , k$, and remains the same from trial to trial. Note that:
$$p_1 + p_2 + p_3 + \dots + p_k = 1$$
(This is an example of the Law of Total Probability (LOTP). In the end, all the probabilities in a problem have to sum to one. Remembering this rule can help you solve many statistical problems.)
In a multinomial experiment, the trials are independent. We are interested in the $n_1, n_2, n_3, \dots, n_k$ where $n_i$ for $i=1,2, \dots, k$ is equal to the number of trials which the outcome falls into cell $i$. Note that $n_1+n_2+n_3+ \dots +n_k=n$ The experiment can be modelled using a __multinomial__ distribution with probability mass function: $
$$p(n_1, n_2, \dots, n_k)=\frac{n!}{n_1!n_2 \dots n_k!}p_1^{n_1}p_2^{n_2} \dots p_k^{n_k}
$$
## Pearson's $X^2$ test
```{r, echo=FALSE}
knitr::include_graphics("Karl_Pearson.jpg")
cat("Karl Pearson")
```
The $X^2$ test was proposed in 1900, and can be used for testing hypotheses about $p_1, p_2, p_3, \dots, p_k$ Suppose that $n=100$ balls were thrown into $k$ boxes. Further suppose that $p_1=0.1$. What would the expected number of balls in box 1 be? This would just be $E(n_1)=np_1=(100)(0.1)=10$ Similarly for the other boxes, we have: $E(n_i)=np_i, i= 1, 2, \dots, k$
Suppose we postulate values for the $p_i$s. If our hypothesis is correct, the $n_i$s should not depart much from the expected values (remember residuals in regression? This is the same principle.) Hence it seems reasonable to use the deviations from the expected values in a test statistic: $n_i-np_i, i=1 ,2, \dots, k$
The test can then be constructed as:
$$\displaystyle X^2=\sum_{i=1}^k\frac{(n_i-np_i)^2}{np_i}=\sum_{i=1}^k\frac{[n_i-E(n_i)]^2}{E(n_i)}$$
Asymptotically (for large $n$), $X^2$ follows a $\chi^2_{\nu}$ distribution with $\nu$ degrees of freedom. The $\chi^2$ distibution as Probability density function
$$f(y)=\frac{(y)^{\nu/2-1}e^{-y/2}}{2^{\nu/2}\Gamma(\nu/2)}, y > 0$$
It's easier to visualise the $\chi^2$ distribution:
```{r, size='tiny'}
library(ggplot2)
ggplot(data.frame(x=c(0, 80)), aes(x)) +
stat_function(fun = function (x) dchisq(x, df = 1), geom = "line", aes(colour = "1")) +
stat_function(fun = function (x) dchisq(x, df = 5), geom = "line", aes(colour = "5")) +
stat_function(fun = function (x) dchisq(x, df = 50), geom = "line", aes(colour = "50")) +
ylab("Density") +
scale_colour_manual("Degrees of Freedom", values=c("black", "red", "blue"),
breaks=c("1", "5", "50"))
```
## Example 1. Specified Cell Probabilities
Frequently we know what the cell probabilities (the $p_i$'s) should be, based on a scientific theory. For example, Mendelian genetic theory predicts that peas falling into the following classes are distributed 9:3:3:1 with the following phenotypes: Round/Yellow, Wrinkled/Yellow, Round/Green, Wrinkled/Green. Say, N = 100 peas are examined, with the following counts:
```{r}
counts <- c(56, 19, 17, 8)
names(counts) <- c("RY", "WY", "RG", "WG")
counts
ratio <- c(9, 3, 3, 1)
p <- ratio / sum(ratio)
expected <- sum(counts) * p
x2 <- sum((counts - expected)^2 / expected)
x2
pchisq(x2, df=3, lower.tail=FALSE)
```
Because the expected proportions come from theory, and not the data themselves, we do not lose any degrees of freedom apart from the restriction that $n_1+n_2+n_3+n_4=100$. Therefore there are $k-1=4-1=3$ degrees of freedom. Hence, because the p-value is >> 0.05, we do not reject the null hypothesis that the peas follow the Mendelian model. Of course, we can easily do this using the built-in ``chisq.test()`` function in R:
```{r}
chisq.test(counts, p = ratio, rescale.p = TRUE)
```
## Example 2: Goodness-of-fit
The $X^2$ test is also useful for testing whether data are consistent with a particular probability distribution. The idea is to use $X^2$ to measure the _fit_ of the probability model to the data. Significant lack of fit implies rejection of the null hypothesis of _no departure from the model_. For example, the Poisson distribution is often used to model "count" data. Consider the following data:
```{r, size='tiny'}
dat <- data.frame(birds=0:5, frequency=c(16, 19, 9, 4, 2, 0))
dat
```
Note that birds = 5 really means 5 __or greater__. The expected number of birds per site is just:
$$
\hat{\lambda}=\frac{(0)(16) + (1)(19) + (2)(9) + (3)(4) + (4)(2)}{16 + 19 + 9 + 4 +2 }=1.14
$$
Aside: Note that the numerator consists of additions and multiplications. This strongly suggests that we could summarise the numerator by using vector multiplication:
```{r}
lambdahat <- with(dat, (birds %*% frequency) / sum(frequency))
lambdahat
```
The cell probabilities are just:
$$\begin{align*}
p(y \mid \lambda) &= \frac{\lambda^y e^{-\lambda}}{y!}, y= 0, 1, 2, \dots \\
p_0 &= e^{-\lambda} = 0.3198 \\
p_1 &= \lambda e^{-\lambda} = 0.3646 \\
p_2 &= \frac{\lambda^2e^{-\lambda}}{2} = 0.2078 \\
p_3 &= \frac{\lambda^3e^{-\lambda}}{6} = 0.0790 \\
p_{4+} &= 1 - p_0 - p_1 - p_2 - p_3 = 0.0288 \; \text{(LOTP)}
\end{align*}
$$
The expected values for each cell are just:
$$
\begin{align*}
E(n_0) &=(50)(0.3198)=15.9910\\
E(n_1) &=(50)(0.3646)=18.2297\\
E(n_2) &=(50)(0.2078)=10.3909\\
E(n_3) &=(50)(0.0790)=3.9486\\
E(n_{4+}) &= (50)(0.0288)=1.4399
\end{align*}
$$
Note that $E(n_3)$ and $E(n_{4+})$ are both $< 5$. The $X^2$ approximation to the $\chi^2$ distribution is unreliable for such low values. Hence, we should pool these last 2 categories: $E(n_{3+})=3.9486+1.4399=5.3884$ And we now have $k=4$ categories. We now have to Calculate $X^2$:
$$
\begin{align*} X^2&=\sum_{i=1}^k\frac{(n_i-np_i)^2}{np_i}\\
&=\sum_{i=1}^k\frac{[n_i-E(n_i)]^2}{E(n_i)}\\
&= 0.2882\\
df &= k-1-1=4-2=2 \\
p&=\chi^2_2(0.4373)=0.8658 \gg 0.05
\end{align*}
$$
Therefore we do __not__ reject the null hypothesis that the data come from a Poisson distribution. Here is the above analysis in R:
```{r, size='tiny'}
probs <- c(dpois(0:2, lambdahat), 1-sum(dpois(0:2, lambdahat)))
probs
pooled <- c(dat$frequency[1:3], sum(dat$frequency[4:6]))
pooled
expecteds <- sum(pooled) * probs
X2 <- sum((pooled-expecteds)^2/expecteds)
X2
pchisq(X2, df=2, lower.tail=FALSE)
```
## Example 3: Contingency Tables
We can use the $X^2$ test to analyse cross-classified tabular data. The most common use of $X^2$ is a test of __independence__ of rows from columns. ie a test of __association__ between rows and columns}. Here's and example:
```{r table1, echo=F, message=F, warnings = F, results="asis"}
mat <- matrix(c(19, 6, 2, 19, 41, 27, 3, 7, 31), nrow=3, byrow=TRUE, dimnames=list(Order= c("Supervisor 1st, Student mandatory 2nd",
"Student 1st, Supervisor mandatory 2nd",
"Student 1st, Supervisor courtesy 2nd"),
Input = c("High input from Supervisor", "Medium Input", "Low Input")))
require(pander)
set.caption("Data on Students Publishing")
pander(mat, style="rmarkdown")
```
The data are numbers of published papers by students, cross-classified by the order of authorship and the input from the supervisor. Usually, the author order in biology is to have the student first, except when there is a high level of input from the supervisor. ie when the student is a low contributor to the study.
We need to __estimate__ the expected values (under the null hypothesis) in each cell. This is done by multiplying the appropriate row and column totals and dividing by the grand total: $\widehat{E(n_{ij})}=\frac{r_ic_j}{n}$. We can then use the usual formula for $X^2$, with degrees of freedom $(nrow - 1)(ncol - 1)$. Here's how to do it in R:
```{r}
mat <- matrix(c(19, 6, 2, 19, 41, 27, 3, 7, 31), nrow=3, byrow=TRUE)
csum <- colSums(mat)
rsum <- rowSums(mat)
expecteds <- outer(rsum, csum) / sum(rsum)
X2 <- sum((mat - expecteds)^2 / expecteds)
X2
pchisq(X2, df = 4, lower.tail = FALSE)
```
Therefore, we reject the null hypothesis. There __is__ an association between authorship order and the amount of input by the supervisor. Of course, it is easy to use the ``chisq.test()`` function in R:
```{r}
chisq.test(mat)
```
## Assumptions of the $X^2$ Test
1. The data must satisfy the assumptions of a multinomial experiment (independent trials, constant cell probabilities etc.)
2. Expected cell values should __not__ be $< 5$. In this case the asymptotic approximation to the $\chi^2$ doesn't hold. You can use other methods or use simulation (See ``?chisq.test``)
3. The __degrees of freedom for a contingency table__ = (r-1)(c-1)
## Loglinear Models
Another approach, which works well for multiway tables, that is, tables with greater than 2 dimensions is the technique of log-linear modelling. Here is the 2-way table described above, analysed using a loglinear model. Notice that the loglm function has a formula argument that looks very similar to the formula argument for ``aov()`` and ``lm()``. Note also that the output includes the value of the Pearson $X^2$ statistic.
```{r}
library(MASS)
dat <- as.data.frame.table(mat)
names(dat) <- c("Authorship", "Input", "Frequency")
dat
fit <- loglm(Frequency ~ Authorship + Input, data = dat)
fit
```
## Generalised Linear Models
The most flexible approach to modelling non-Normal data is the framework of __Generalised Linear Models__. GLMs allow the fitting of linear models using a large variety of distributions, including the Normal distribution. For our purposes, we will use GLMs to analyse categorical data and binary data. First we need to discuss some theory, so we can relate the GLM framework to the ordinary linear model framework. This will allow us to see that GLMs are really just an extension of the linear models that we understand already. First, we set up the mathematical formulation.
## The General Linear Model for Normal Responses
Recall that the ordinary linear model can be described in the following way:
$$
\mathbf{Y}=\mathbf{X}\beta + \epsilon, \epsilon \sim N(0, \sigma^2\mathbf{I})
$$
This can also be written as:
$$
E(\mathbf{Y}) = \mathbf{\mu} = \mathbf{X}\beta, \mathbf{Y} \sim N(\mathbf{\mu}, \sigma^2\mathbf{I})
$$
Or more generally:
$$
g(\mathbf{\mu}) = \mathbf{X\beta},\; \mathbf{\mu} \sim f(\mathbf{\mu, \theta})
$$
$g(.)$ is called the __link function__. For normally-distributed data, the link function is the _identity_ function. ie $f(x) = x$. $\mathbf{X\beta}$ is the __linear predictor__, the same as for the ordinary linear model. $f(.)$ is a probability distribution from the __exponential family__ of distributions (more on those later!). $\mu$ is the __Expectation__ of $\mathbf{Y}$ ie the mean values. $E(\mathbf{Y})=\mu$
Generalised Linear Models extend the General Linear Model in 2 directions:
1. The response variable can have a distribution other than the Normal distribution
2. The relationship between the response and explanatory variables need not be linear (on the scale of the response). That is, the link function allows us to use nonlinear functions of the linear predictor, which can be very useful.
## The Poisson GLM
One example is the Poisson Generalized Linear Model, which has many uses including the modelling of count data:
$$log(E(\mathbf{Y}))=\mathbf{X\beta}, \; \mathbf{Y} \sim Poisson(\lambda)$$
Note that the loglinear model is a special case of the Poisson GLM. The advantage of using the Poisson GLM instead of a loglinear model is that the Poisson GLM can incoporate continuous covariate, whereas the loglinear modelling formulation only works for categorical variables.
## Fitting the Poisson GLM
We shall fit the Poisson GLM to the previous contingency table data.
```{r}
fit.full <- glm(Frequency ~ Authorship * Input, data = dat, family = poisson)
fit.noint <- glm(Frequency ~ Authorship + Input, data = dat, family = poisson)
anova(fit.noint, fit.full, test = "Chisq")
# Compare with the loglinear model output:
fit
```
Notice that we have constructed a likelihood ratio $X^2$ test by comparing Poisson GLMs, one with an interaction term and one without. The statistic is equal to 54.542 with a p-value close to zero. Notice this is the same as the Likelihood Ratio statistic from the loglinear model! So there is a close mathematical relationship between Poisson GLMs, loglinear models, and the Pearson $X^2$ statistic. This commonality of the underlying mathematics makes it clear that choosing an analysis method for count data is really just a convenience. For many situations, you could use any of the 3 methods (contingency tables, loglinear models, Poisson GLM).
## Mode Diagnostics
Model diagnostics for Generalised Linear Models work in a similar way to ordinary linear models, except they are sometimes harder to interpret. Importantly, on the scale of the link function (which is usually the log function for a Poisson GLM), there should be no relationship between the residuals and the fitted values, corresponding to the assumption of homoskedasticity in the general linear model. Similarly, the residuals should be approximately Normal on the scale of the link function.
```{r}
par(mfrow = c(2, 2))
plot(fit.noint)
```
## The Binomial GLM
The Binomial GLM is useful for modelling data where the response variable has 2 categories, for example survival (lived/died), sex ratio (male/female), response to a drug (yes/no), birds in a forest fragment (present/absent) or exams (pass/fail). Poisson and Binomial GLMs are probably the most often used in the analysis of biological data. The Binomial GLM has the following form:
$$g(E(\mathbf{Y}))= \mathbf{X\beta}, \; \mathbf{Y} \sim Binomial(n, p)$$
$g(.)$ is the link function. It can take several forms. It _links_ the Expected value of the response ($\mathbf{Y}$) to the linear predictor. The __canonical__ link function for the binomial distribution is the logit function:
$$logit(p)=\log\left(\frac{p}{(1-p)}\right)$$
## Example: Beetle mortality to insecticide
Groups of beetles were exposed to different concentrations of insecticide, and the number that survived or killed by the insecticide was recorded. A binomial GLM was used in R to model the relationship between survival and insecticide dose:
```{r}
Experiment <- data.frame(Dose = c(1.6907, 1.7242, 1.7552, 1.7842, 1.8113,
1.8369, 1.8610, 1.8839),
Number.Exposed = c(59, 60, 62, 56, 63, 59, 63, 60),
Number.Killed = c(6, 13, 18, 28, 52, 53, 61, 60))
fit <- glm(cbind(Number.Exposed - Number.Killed, Number.Killed) ~ Dose,
data = Experiment, family = binomial(link=logit))
summary(fit)
```
We can see that there is a strong negative relationship between survivorship (as a proportion) and insecticide dose, as measured by the Dose coefficient in the model summary. But before going further, we should look at some diagnostic plots to see if our model appears reasonable. We see that the sample size (the number of groups exposed to insecticide) is quite small, but there seems to be no strong departures from the usual assumptions of no relationship between the residuals and fitted values, and the normality of the residuals (on the scale of the link function, which in this case is the logit() function).
## Diagnostics
```{r}
par(mfrow = c(2, 2))
plot(fit)
```
## Another approach to Diagnostics
The plot of the residuals versus the fitted values for GLMs can be hard to interpret, as the data are non-normal, or not even continuous. A package that can provide diagnostic plots that __are__ interpretable in the same way as the general linear model is the ``DHARMa`` package. It works by simulating residuals from the model and plotting these standardised, simulated residuals using the usual plots. Here is an example:
```{r}
library(DHARMa)
res <- simulateResiduals(fit, plot=TRUE)
```
Notice that the left-hand plot looks like the usual quantile-quantile plot, but with the results of some extra tests plotted on it. In fact, this is actually a quantile-quantile plot based on the __Uniform__ distribution. The right-hand plot is like the residuals versus the fitted values. You can see that this plot has a ``hump`` in it, which was not obvious from the ordinary diagnostic plots. This suggests that the data may actually follow a parabolic curve, which is described by a quadratic polynomial. We can fit a model with both a linear term and a quadratic term, and see if it is better than the model with just the linear term.
```{r}
fit2 <- glm(cbind(Number.Exposed - Number.Killed, Number.Killed) ~ poly(Dose,2),
data = Experiment, family = binomial(link=logit))
summary(fit2)
```
We see that indeed there is a significant 2nd order polynomial term ($p = 0.0143$). So it looks like the polynomial is a better fit compared to the plain linear model. However, there is still a strong linear component, although highly significant, the effect size is not as great (-6.6299).
## Some theory
The theory for GLMs was first worked out for exponential family distributions. These are distributions which can have their probability density (mass) functions written in the following form:
$$f(y\mid\theta)= e^{a(y)b(\theta)+c(\theta)+d(y)}$$
where y is the data and $\theta$ is a vector of parameters. $b(\theta)$ is known as the ``natural parameter`` and defines the __canonical__ link function. If $a(y) = y$, then the function is said to be in __canonical form__.
## Simple example: The Poisson distribution
The Poisson distribution has probability mass function:
$$f(y\mid \lambda) = \frac{\lambda^y e^{-\lambda}}{y!}, \; y = 0, 1, 2, \ldots$$
It can be written in exponential form as:
$$f(y \mid \lambda) = \exp(y \log \lambda - \lambda - \log y!)$$
Note that $a(y) = y$ so the distribution is in canonical form. Also, the natural parameter $b(\lambda) = \log \lambda$ so $\log()$ is the canonical link function.
## The Binomial distribution in exponential form
The Binomial distribution has probability mass function:
$$f(y \mid p) = \binom{n}{y} p^y(1-p)^{n-y}$$
In exponential form:
$$
\begin{align*}
f(y \mid p) &= \exp \left[ y \log p - y \log(1-p)+n \log(1-p) + log \binom{n}{y} \right] \\
&= \exp \left[ y \log \frac{p}{1-p}+ n \log(1-p) + log \binom{n}{y} \right]
\end{align*}
$$
which is in canonical form and the natural parameter is $\log \frac{p}{(1-p)}$.
## Issues when fitting with GLMs
One problem that can occur is overdispersion. This is particularly common with Poisson models. Overdispersion occurs when the variance of the data is greater than the mean. Since in a Poisson model, the variance _equals_ the mean, this is a strong restriction. There are several solutions, including fitting by a technique called quasilikelihood, which is beyond the scope of this course. An alternative approach which tends to work much better is to look for a discrete distribution that can model the overdispersion. In practice, the Negative Binomial distribution often works quite well. The Negative Binomial is a discrete distribution, taking values 0, 1, 2, ... so it is suitable for count data.
Another problem that can occur, particularly in count data is __zero inflation__. When using a Poisson model, it is expected to get at least a few zeros in the data set. However, it is often found that there are way too many zeros than predicted by a Poisson distribution:
```{r}
dat <- data.frame(Poisson=c(rpois(50, lambda=5), rep(0, 50)))
with(dat, hist(Poisson, main = "Zero Inflation"))
```
In this case, a zero-inflated Poisson model (ZIP) might work better, or a __hurdle__ model. Again, these are beyond the scope of the course.
Another issue is how to choose an appropriate link function. While the canonical link function usually performs pretty well, other link functions are possible. For a binomial model, R provides the logit, probit, cauchit, log, and complementary log-log. See ``?family`` for more details. Different link functions may model different regions of the data better.
The choice of distribution family is crucial. Generally for count data, a Poisson distribution is the first port of call, but be prepared to change it (see above). For binary data (e.g. presence/absence or alive/died etc.) the Binomial distribution is usually appropriate. For continuous data, the Normal distribution usually performs well but that leads us straight back to the general linear model. In situations where this skew in the data, a Gamma distribution model may be appropriate. Other distributions can be used other than the Exponential family distributions, but the mathematical foundations of the GLM theory are not as strong.
Another issue is the inclusion of random effects (e.g. blocking) in the model. This leads directly to Generalised Linear Mixed Models (GLMM).