-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path01_introduction.qmd
47 lines (33 loc) · 2.69 KB
/
01_introduction.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
# Introduction
A regression model is a way to express a relationship between some response and one or more predictor variables. It's such a common method of analysis that it can occasionally be difficult to remember that there is anything else to do.
Nearly every day I am asked questions about regression models, and they often seem motivated by anxiety about assumptions and validity of an interpretation. I'm going to try to provide you with the tools to begin answering those questions yourself. With practice you'll hopefully begin to develop the ability to reason about your models and how they work.
Anyway, you've probably heard of and tried regression. Now you're here. Why? I don't know. Hopefully this will help!
## Data
The data for a linear model are typically in a tabular format (imagine a spreadsheet), where each row of data is called an **observation** and each column is called a **feature**. The column that is the outcome of the model is called the **response**. Each observation should include a value for every feature (there are some ways of handling missing data but that's beyond our scope for this workshop).
## Plot before you model!
Your computer will do whatever you tell it to do, even if it's not a good idea. With this great power comes the responsibility to think, and to check your assumptions.
The first one to mention is the assumption that there is a relationship between the features and the response, of the type that the model describes. Your first, best way to test that assumption is to plot the data. Summaries like the means, variances, and correlations can only tell you so much. The following example points out why.
The Datasaurus Dozen are a collection of thirteen data sets. Each consists of two features (x and y) that have the same means, variances, and correlations.
```{r install-datasaurus}
#| include: false
#| eval: false
#| echo: false
remotes::install_github("jumpingrivers/datasauRus")
```
```{r plot-datasaurus}
#| message: false
#| warning: false
#| echo: false
library(datasauRus)
library(dplyr)
library(ggplot2)
library(tidyr)
group_by(datasaurus_dozen, dataset) |>
summarize(correlation = round(cor(x, y), 3), across(c('x', 'y'), .fns=list('mean'=~round(mean(.x), 1), 'variance'= ~ round(var(.x), 1))))
ggplot(datasaurus_dozen, aes(x = x, y = y, colour = dataset)) +
geom_point() +
theme_void() +
theme(legend.position = "none") +
facet_wrap(~dataset, ncol = 3)
```
You probably wouldn't use a linear model for most of the panels of that plot because there isn't a linear relationship between the feature (x-direction) and the response (y-direction). Plotting the data can also reveal problems or oddities in the data that will guide your further investigation.