-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathregression.qmd
640 lines (406 loc) · 49.5 KB
/
regression.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
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
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
---
title: "Regression analysis"
author: Dr. Nicola Righetti, PhD
---
# Learning Goals
- Understand the concept of statistical model
- Understand the concept of linear regression model
- Know how to fit a linear regression model with R
- Know how to interpret the results of linear regression models
- Understand the concept of goodness of fit and know how to evaluate it
- Understand the assumptions of the linear regression model and know how to evaluate them
# What is a model?
- A **model** is an *approximate and simplified representation* of a real phenomenon which captures its most distinctive features (i.e., trends, patterns, etc).
- A **mathematical model** is a model built from mathematical objects, such as numbers, formulas, equations, and so on.
- A **statistical model** is a special kind of mathematical model, informed by data and built to predict phenomena characterized by a *certain degree of uncertainty*, and/or to test out hypotheses about how the system being modeled actually works.
## Example: the mean as a simple data model
For example, we can consider the mean as a simple data model. Indeed, it can be conceived as a synthetic, simplified, and approximate representation of the distribution of a variable. It is a mathematical model since it is a number, and a statistical model since it is informed by data and implies a certain level of uncertainty. Actually, the mean is only a rough representation of a variable. In fact, single values can be more or less in line with the mean. The mean represents "on average" the different values of a variable. We can also quantify the uncertainty in this type of simple model thanks to the standard deviation. The standard deviation can be intended as an approximate measure of the average distance between the data points and the mean. A low standard deviation indicates that the values are clustered close to the mean, making the mean an excellent model. However, a high standard deviation means that the values are generally distant from the mean, making the mean a relatively poor model of the variable.
For example, let's take a group of four friends whose monthly income is 1,000 euros, 1,500 euros, 4,000 euros, and 7,000 euros respectively. Using the mean to build a simple model of their income, we can see that the mean income is EUR 3,375. However, this is not a very good approximation of the income of these people if we want to use it to predict the income of each member of the group. The standard deviation is high (SD = 2,750 euros), indicating a great deal of variability and uncertainty. On average, the members' income is 2,750 euros far from the mean.
```{r}
income <- c(1000, 1500, 4000, 7000)
mean(income)
sd(income)
```
Let's now consider a group of four friends who have monthly incomes of EUR 1,000, EUR 1,500, EUR 1,300, and EUR 900 respectively. Using the mean to create a simple model of their income, we can see that the mean income is EUR 1,175 with a low standard deviation (SD = 275). This group is relatively homogeneous regarding their income, and therefore, the mean serves as a reliable model for predicting the income of each member.
```{r}
income <- c(1000, 1500, 1300, 900)
mean(income)
sd(income)
```
## The mean in regression analysis
In linear regression, the mean is particularly important:
- It is used as a **baseline** against which to compare the utility of the model. Linear regression modeling attempts to identify variables (independent variables) that help explain/predict another variable (the dependent variable or outcome) better than the outcome variable's average. The model using the mean that is used as a baseline is also called the **null model**.
- The linear regression model attempts to predict the mean value of a variable, given one or more other variables and assumes a linear relationship between the predictors and the outcome.
![Image from: Le Gratiet, L., Iooss, B., Blatman, G., Browne, T., Cordeiro, S., & Goursaud, B. (2017). Model assisted probability of detection curves: New statistical tools and progressive methodology. Journal of Nondestructive Evaluation, 36(1), 8](img/linear_model_gaussian_errors.png)
The image above illustrates the linear correlation between an independent variable and the mean of the dependent variable, as well as the inherent uncertainty in the statistical model. Specifically, the standard linear regression model assumes that this uncertainty follows a Gaussian (or Normal) distribution. Although the linear model predicts the variable's average, we postulate that the true values of the dependent variable are randomly distributed around the mean, with the randomness described by the normal distribution.
## Components of a statistical model
Gary King, professor at Harvard University and director of the Institute for Quantitative Social Science, explains clearly the main components of any statistical model in Chapter 1 of his book [Unifying Political Methodology. The Likelihood Theory of Statistical Inference](https://www.press.umich.edu/2153576/unifying_political_methodology). Here is what he explains.
- **Social system**: this is the largest component of interest of social scientists. Social scientists, in a way or another, study social systems. They might be a neighborhood, a community, an election, or anything else. A social system includes features that are either known or estimable, and other important elements that remain unobserved and unobservable.
- **Explanatory variables**: also called independent variables, are measures of the features of a social systems. They are symbolized as $X$, where $X$ contains measures of each of these features for all $n$ observations.
- **Output**: also dependent variable, is the output generated by the social system, and a consequence of the social system that can be observed and measured. For example, an election produces a victorious candidate, or a a mixture of certain political and cultural attitudes can generate more or less support for the government.
- When parts of the social system are under control of the researcher, the process of producing output is called an ***experiment***. True experiments are only infrequently possible in the social sciences, but in statistics this term has also another meaning, and can be used where an experiment could be conducted, if only in theory. For example, a political election cannot be controlled by the researcher, but one can imagine the same election being "run" multiple times under the essentially identical conditions. Even under identical conditions, the social system outputs different results for each experiment. This is because output is produced in a *probabilistic* instead of deterministic manner.
- **Random variables**: the output of a social system which is generated in a probabilistic manner, is a random variable (symbolized as $Y$). Random variables are, operationally, the assignment of numbers to events (e.g.: Democratic President = 1, Republican President = 0; income = number of dollars, etc.), with a probability assigned to each number. Random variables are not really "random", but follow specific probabilistic rules (i.e., they follow a particular statistical distribution, for example, a Normal distribution). Hence, although different outputs can be generated when running the same experiment under the same identical conditions, different output have different probabilities to be generated by the social system.
- **The data**: we don't observe the random variable, but the data (which are generally symbolized as $y$) , which are $n$ realizations of the random variable $Y$. The data are a set of numbers that is assumed to be randomly drawn from the random variable $Y$ through a procedure called *sampling*. A data set is also called "the sample".
- **Statistical model**: finally, a statistical model is a formal representation fo the process by which a social system produces output. The general goal of the model is to learn about the underlying process that generates output and hence the observed data. Statistical models are assumed to have both *systematic* and *stochastic* components. In the linear model below, for example, the stochastic component is represented as $\epsilon$, and the systematic part is represented as $bX_j$.
$$Y_j = i + bX_j + \epsilon_j$$
The stochastic component is also called the error term, and in a linear model is assumed to follow a normal probability distribution: $\epsilon_j \sim f_n(e_j|0,\sigma^2)$.
An equivalent and more general way to express this statistical model is as follows:
$$
Y_j \sim f_n(y_j|\mu_j, \sigma^2)\\
\mu_j = x_j\beta
$$
This expression more clearly shows that the output of the social system, the dependent variable $Y$ is a random variable, which in this case follows a normal probability distribution with mean $\mu$ and standard deviation $\sigma^2$, and where the mean $\mu$ varies across observations based on the values of the independent variables $X$. In statistical terms, the mean $\mu$ and standard deviation $\sigma^2$ are the *parameters* of the normal distribution.
Although in this course we focus only on linear model, the above expression can be further generalized to cover almost any other model, by written the two equations as follows:
$$
Y \sim f(y|\theta,\alpha)\\
\theta = g(X,\beta)
$$
The first equation represents the *stochastic* component, and is read "$Y$ is distributed as a function $f$ of the data $y$ given the parameter $\theta$ and $\alpha$". Here, $f$ is a probability distribution, which is an explicit model of the form of uncertainty in the random variable $Y$ across repeated "experiments" (see above), and $\theta$ and $\alpha$ are parameter vectors which can be predicted by using other variables.
The second equation represents the *systematic* component. Here, $g$ is a functional form, i.e., a precise statement of *how* a particular characteristics ($\theta$) of the random dependent variable ($Y$) is generated by certain features of the social system (the independent variables $X$). In the linear model case, the functional form $g$ is linear. The vector of elements $\beta$ is called the effect parameters, representing the degree and direction of dependence of $\theta$ on the explanatory variables \$X\$. They are the so-called "coefficients" that we find when we fit a linear regression model. The interpretation of the effect parameters depends on the functional form that links the independent variables $X$ to the parameter of the independent variable \$Y\$. The systematic component of the statistical model is a statement of how different known features of the social system (the explanatory variables $X$) generate various characteristics of the social system.
# Linear models
A linear model is a special kind of statistical model based on linear relationships (see the Pearson's correlation coefficient) between two or more variables.
It is represented as a mathematical equation that links one (in case of a *simple* linear regression model) or more input variables (in case of a *multiple* linear regression model) to an output variable Y, by exploiting information contained in the **association** between the **inputs** and the **output**.
- The input variables are also called "predictors", or "independent", "explanatory", or "antecedent" variables.
- The output variable is also called "outcome", "dependent", or "consequent" variable.
Linear regression models, as a basic application, can be used for answering questions of the **"whether"** or **"if"** variety. These questions ask whether two variables are correlated, causally or otherwise (*explanation*), or if something is more or less likely to happen in one set of circumstances or conditions than another (*prediction*).
- **Prediction**: predict values taken by the dependent variable when we only know the values taken on by the independent variable(s) (e.g., predict income based on sex and level of education);
- **Explanation**: explaining the structure of a phenomenon by testing hypotheses about the relationships between dependent and independent variables (i.e., is there a relationships between two variables? How strong is it?)
To do that, regression analysis computes an equation such that, given the input variables, the result of the equation yields:
- An estimate of the dependent variable (*prediction*).
- A measure of the importance and *statistical significance* of the relationships between the independent variables and the dependent variable (*explanation*).
# The equation form
The **simple linear regression model** is the simplest form of a linear regression model, in that it contains only a single independent variable ($X$). The general form of the equation is the following:
$$Y_j = i + bX_j + e_j$$
For example, $Y$ could be income, and $X$ could be a variable used to try to explain/predict it, say level of education.
The **multiple linear regression model** is an extension of this simpler model, which includes more than one independent variable. For example, it may be used to predict income based on level of education, sex, and other variables.
$$Y_j = i + b_1X_{1j} + b_2X_{2j} + ... + e_j$$
From a data set containing the values of the $Xs$ and $Y$ variables, linear regression modeling finds the weights $b_1$, $b_2$ (referred to as regression **coefficients**) that, multiplied by the values of the variable, represents the best approximation of the values of $Y$ in the equation. To estimate the coefficients of the model, the most common procedure is referred to as **ordinary least squares (OLS)** criterion.
# Multiple linear regression model
In practice, the single linear regression model is never used. If you are only interested in the relationship between two variables, you can calculate a correlation coefficient.
However, the problem with the correlation coefficient is that the relationships between two variables is always ambiguous, and **alternative explanations** abound. For example, the correlation between income and education can simply reflect a difference in the status of the family of origin. Wealthier families have more resources and connections, send their sons and daughters to a better school and help them find better jobs, resulting in higher incomes.
In general terms, what makes the association between two variables $X$ and $Y$ ambiguous, leading to alternative explanations, is that *people who differ on X and Y also likely differ on many other things, and it may be those things that are responsible for the association.*
Multiple regression gives a researcher a means of engaging in a kind of mathematically aided counter-factual reasoning by estimating what the association between each independent variable X and the dependent variable Y would be *if people did not differ on the other independent variables* in the regression model. It does this by "mathematically equating" people (or whatever the unit of analysis is) on those variables. This equating process is also referred to as *partialling out* those other variables from the association between $X$ and $Y$, or *statistically control* of those variables.
> Partial out: "to give (a variable) a fixed value while considering the relationship between two related variables"
For example, to estimate the effect of level of education on income, we could fit a multiple linear regression model. This model would include variables that we think are associated with income. For example, level of education, wealth of the family of origin, and a measure of social connection. This model can estimate the effect of education on income, *holding constant all other independent variables* (i.e., net of the effect of other variables). In practical terms, this means that the regression model shows an estimate of the effect of education on income among individuals with families of the same status and with the same type of social connections, so this variable should no longer have a confounding effect on our estimate of the effect of education.
# Elements of the linear model equation
To present the main elements of a linear regression model, let's consider its simplest form:
$$Y_j = i + bX_j + e_j$$
## The index j
The index $_j$ indicates any unique observation/case within the data set. Since rows represent cases, you can view the subscript $_j$ as a row in a data set.
```{r echo=FALSE}
data.frame(j = 1:5,
Y = c(12, 23, 34, 54, 45),
X = c(10, 35, 45, 57, 87))
```
The index may also be omitted and the regression equation represented as $Y = i + bX + e$, but it makes it explicit that, for each case, the equation establishes a relationships between the values of the variable $Y$ (the dependent or outcome variable) and $X$ (the independent or antecedent variable).
## Intercept
$$Y_j = i + bX_j + e_j$$
The $i$ indicates a numerical coefficient estimated by the regression model. It is a constant (i.e., a fixed value) and is referred to as *intercept* or *constant*. It is the average (mean) value of $Y$ when the independent variable(s) assume the value 0.
Although the intercept is mathematically significant, *sometimes* *it makes no sense and cannot be interpreted.* It is not meaningful when:
- The independent variables do not include zero in their data range;
- This value is not significant or even impossible.
For example, if we predict the weight of people based on their height, the intercept has no substantial meaning, because there is no person with a height equal to zero.
## Regression coefficient
$$Y_j = i + bX_j + e_j$$
The letter $b$ (or *beta*) indicates a numerical coefficient estimated by the regression model (e.g., through the OLS procedure). It is referred to as regression *coefficient* and represents the *weight* assigned to the values of the variable $X$.
In the simple linear model, it represents *the average change in* $Y$ *for every one unit* *increase in* $X$. In the multiple linear regression model it represents the average change in $Y$ for every one unit increase in $X$, *holding all other independent variables constant.* For this reasons, these coefficients represent measures of **partial association** (i.e., each coefficient represents the part of association that is specific to a particular variable).
## Error
The letter $e$ indicates the *error* *term* or *residual*, and represents the imprecision and uncertainty in the estimate. It is the difference between the values of $Y$ estimated by the model, and the true values of $Y$.
# Fit a linear regression model with R
The R function to fit a linear regression model is `lm`.
The function takes at least two arguments separated by a *tilde* (the symbol `~` : check online how to write that with your specific keyword. You can also copy/paste it from the help by typing `?tilde`):
- To the left of the tilde is the dependent variable ($Y$)
- To the right of the tilde is the independent variables ($X$) separated with the plus (`+`) symbol.
The argument `data` is used for the name of the data set, which is usually a data frame.
The function `summary` is used to see the results of the model fitting functions.
## Example
Load the data set `glbwarm`.
```{r}
# load the data set
glbwarm <- read.csv("data/glbwarm.csv")
```
### Simple linear regression
Let's fit a simple linear regression model that predicts support for government action to mitigate climate change (independent variable $Y = govact$), based on negative emotion about this issue ($X = negemot$).
```{r echo=TRUE}
lm1 <- lm(govact ~ negemot, data = glbwarm)
```
The function `summary` produces the output.
```{r}
summary(lm1)
```
### Multiple linear regression
The following piece of code fits a multiple linear regression model that predicts support for government action to mitigate climate change (independent variable $Y = govact$), based on several variables.
```{r}
lm2 <- lm(govact ~ negemot + posemot + ideology + sex + age,
data = glbwarm)
```
```{r}
summary(lm2)
```
### Interpretation of the output
Consider the output of the `lm2` multiple linear regression model.
```{r}
summary(lm2)
```
This output is composed of the several sections.
#### Residuals
At the top of the output, there is the five-number summary of residuals (the errors). In linear regression, the distribution is expected to have some characteristics, such as to be normally distributed and homoskedastik. These characteristics will be discussed later when presenting the linear regression assumptions.
#### **Residual standard Error**
Before interpreting the results (the coefficients), you want to determine how well the model fits the data. Does it do a good job of explaining changes in the dependent variable? At the bottom of the table, there is general information to evaluate the "goodness-of-fit" of the model:
Residual standard error (or RSE) is the standard deviation of the residuals. It is a measure of the variability or dispersion of the observed data points around the fitted regression line in a linear regression model. The lower the value for RSE, the more closely a model is able to fit the data. It is calculated as the square root of the residual sum of squares (i.e., the differences between the predicted and observed values: $RSS = \Sigma_{j=1}^{n}(\hat y_j-y_j)$) divided by the degrees of freedom ($n-p-1$), where $n$ is the number of observations in the data set, and $p$ is the number of predictors (independent variables) in the model.
In simpler terms, RSE tells you how much the observed data points deviate from the fitted regression line on average. In this case, the average deviation is 1.067 points. The RSE values are expressed in the same units as the dependent variable. In this case, the dependent variable is $govact$ which is measured on a scale from 1 to 7.
In general terms, a smaller RSE indicates that the data points are closer to the fitted line and the model is a better fit for the data. Conversely, a larger RSE indicates that the data points are more spread out and the model may not be a good fit for the data.
#### **R-squared**
The most used index of goodness-of-fit is the *R-squared* (or $R^2$). It indicates on a scale from 0 to 1 the extent to which the model can explains/predicts the dependent variable. It is calculated as the ratio of the residual sum of squares (i.e., the differences between the observed values and the predicted values: $RSS = \Sigma_{j=1}^{n}(\hat y_j-y_j)$) to the total variation (total sum of squares, i.e., the difference between the observed values and the mean of the variable: $TSS = \Sigma_{j=1}^{n}(y_j-\bar y)$).
```{r}
RSS <- sum( (lm2$fitted.values - lm2$model$govact)^2 )
TSS <- sum( (lm2$model$govact - mean(lm2$model$govact))^2 )
1 - (RSS/TSS)
```
Considering the formula, it should be clear that $R^2$ is the standardized residual standard error of the regression (RSE). It is generally interpreted as the proportion of variance (of the dependent variable) explained by the model. *Adjusted R-squared* adds a penalty based on the complexity of the model (number of variables) and can be preferred when fitting multiple linear regression models. Both the Multiple R-squared and the Adjusted R-squared values can be reported. This value can be reported as a percentage of the explained variance. For example, in this case, the model explains about 38% of the variance.
The $R$ in $R^2$ might remind you the Pearson correlation coefficient $r$. Indeed, in the simple linear regression model, $R^2$ is just the square of the Pearson correlation coefficient.
Gary King ([1998](https://www.press.umich.edu/2153576/unifying_political_methodology)) also notices that $R^2$ is a relative measure that can be used to compare different models used to predict the same dependent variable:
> $R^2$ is typically understood as the percentage of variance in $y$ (n.r.: $y$ is the observed variable) explained by the systematic component. But some of the variation in $y$ is systematic and some results from the random variation across experiments as governed by the stochastic component. Intuitively, one wants $R^2$ to measure only the proportion of systematic variation explained. To explain too little of the systematic part or too much of the random part are equally undesirable alternatives. Unfortunately, whether 58%, 5%, or 99% is all, less than all, or an over-fitting of the systematic component is not knowable in the context of one regression. The concept of an $R^2$ that is "good" in an absolute way is nonsensical. Hence, like likelihood, $R^2$ and other goodness-of-fit statistics are relative measures only ([King, G. (1998), p. 24, footnote 7](https://www.press.umich.edu/2153576/unifying_political_methodology)).
#### **F-statistic and p-value**
The last row of the output reports the *F-statistic* and the *p-value* of the model. We already said that linear regression modeling attempts to identify variables that help explain/predict another variable better than its own average (mean). The *F-statistic* compares the fitted linear model with a model that only uses the mean of the dependent variable. If the p-value is below 0.05, the fitted model is significantly better that a model that uses only the mean.
The calculation of the F-statistic employs the same mathematical and statistical elements already discussed:
```{r}
TSS <- sum( (glbwarm$govact - mean(glbwarm$govact))^2 )
RSS <- sum( (lm2$fitted.values - glbwarm$govact)^2 )
p <- 5 # number of independent variables we are testing
n <- length(glbwarm$govact) # total number of observations
F_statistic <- ( (TSS-RSS)/p ) / (RSS/(n-p-1))
F_statistic
```
The *p-value* associated with the F-statistic is the probability of obtaining a value as extreme or more extreme than the observed F-statistic, assuming that the null hypothesis is true. A small p-value (usually less than 0.05) indicates strong evidence against the null hypothesis and suggests that the regression model is a good fit to the data.
> Note: The p-value is expressed in scientific notation (e.g., 2.2e-16). To convert it to a common number, you can use the function `format`, adding the number you want to convert, and the option `scientific=FALSE`. For example:
```{r}
format(2.2e-16, scientific=FALSE)
```
#### **Coefficients**
The coefficient table includes the following information:
- **Estimate**: the regression coefficients of the model (i.e., the $b$ (beta) "weight" of the independent variables).
- **Std. Error**: the standard error of the estimates (coefficients), i.e., their standard deviations. We know that standard deviation is a measure of spread and precision with which the regression coefficient is measured.
- **t value**: this is the *t-statistic* and measures the significance of each coefficient. It is calculated as the ratio of the coefficient to its standard error. It's used to calculate the p-value ($Pr (>|t|)$). Statistically significant p-values are those lower than 0.05 and are marked with one or more asterisks. They indicate that the independent variable has a statistically significant relationship with the dependent variable. In other words, we can conclude that, if all model assumptions held, there is an association between the variables, since it would be unlikely (less than 5% chance if $p < 0.05$) to observe similar values if such an association did not exist.
> Notice that the analysis is assumed to be carried out on a *representative sample* to draw conclusions on a *population*. A sample is a subset of cases (e.g., the 815 Americans in the `glbwarm` data set) collected from a larger population (e.g., the entire American population). The sample represents the population on a small scale. A "statistically significant" relationship indicates that, under the statistical model, the observed relationship is likely true and not an artifact in the data sample we analyzed. It suggests that the relationship exists both in the observed data (a sample) and in the population from which the data originated.
# Interpretation
This is how we can interpret the output of the `lm2` multiple linear regression model.
```{r}
summary(lm2)
```
## **Goodness-of-fit**
The model explains a statistically significant (p \< .001) and substantial proportion of variance (Multiple R-squared: 0.3883, Adjusted R-squared: 0.3845).
## **Estimates**
### **Intercept**
The intercept term in a linear regression model represents the value of the dependent variable when all the independent variables in the model are equal to zero. The intercept is not always meaningful. You need to consider the distribution of your variables (e.g., using the five-number summary). For example, zero does not even exist in the distribution of `negemot` and `ideology`. Therefore, the intercept is not meaningful.
```{r}
summary(glbwarm$negemot)
summary(glbwarm$ideology)
```
### **Coefficients**
Take into consideration the statistical significance of the variables. Only two variables are statistically significant: `negemot` and `ideology`. They are significant at p \< 0.001 (three asterisks). This means that there is a 1 in 1000 chance of observing such values in a sample, if there was no real relationship between the variables in the population. The other variables are not statistically significant. This means that we cannot conclude that these independent variables are correlated to the dependent variable.
The coefficients of a multiple regression model are *measures of partial association* that quantify the component of the association between an independent and a dependent variable that is unique to that independent variable, relative to other independent variables in the model.
#### Continuous or discrete variables
When we have continuous or discrete variables (e.g.: negative emotion and ideology), we can read the coefficients as follows:
- Holding all other variables constant (or, "all other variables being equal", or a similar formulation), two cases that differ by one unit on the negative emotion scale, are estimated to differ by 0.44 unit on average in their support for government action to mitigate climate change. Or also: a one-unit increase on the negative emotion scale (`negemot`) would result in a 0.44 increase in support for government action to mitigate climate change.
- Holding all other variables constant, two cases that differ by one unit on the ideology scale, are estimated to differ by -0.22 unit in their support for government action to mitigate climate change, with cases one unit higher on that scale (i.e., republicans) estimated to be -0.22 unit lower in their support for government action. Or also, a one-unit increase in the ideology variable would result in a 0.22 *decrease* (notice the negative sign: -0.218269) in support for government action to mitigate climate change.
#### **Dichotomous variables**
A dichotomous variable is also a variable that takes on only two possible values. Examples of dichotomous variables include variables like gender (male/female), yes/no questions, and success/failure outcomes. The two values they take are usually represented by 0 and 1.
The variable `sex` in the `glbwarm` data set is a dichotomous variable where 0 represents females and 1 represents males. A unit change corresponds to switching from one category (0) to the other (1).
The coefficient for `sex` ($-0.010066$) indicates that, on average, males (1) are less supportive of government action by 0.01 units compared to females (0). However, this difference is not statistically significant, and thus, there is no evidence of systematic gender differences in support for government action.
Note that to interpret a dichotomous variable of this kind, it is necessary to know what value 0 and value 1 correspond to. Also note that the lowest value (0) is used as the *reference category*. Therefore, the coefficient of a dichotomous variable expresses the difference, on average, in the value of the dependent variable between category 0 (in this case females) and 1 (in this case males).
#### Multicategorical variables
Multicategorical variables are expressed using *dummy variables*. Notice that a *dummy variable* is a specific type of dichotomous variable, but the two are not synonymous. The term "dichotomous variable" refers to variables with only two states, such as "male" or "female". It is one of several types of variables, including "continuous variables", "discrete variables", and "ordinal variables".
On the other hand, a dummy variable represents the absence (0) or presence (1) of a particular characteristic and is often used to transform multicategorical variables. This process, called "dummy coding", involves creating a new variable that takes on a value of 1 if the original variable belongs to a certain category and 0 otherwise. For example, if the original variable was "color" with levels "red," "green," and "blue," three dummy variables could be created to represent each color: "red" (1 if red, 0 otherwise), "green" (1 if green, 0 otherwise), and "blue" (1 if blue, 0 otherwise). Therefore, dummy variables often appear as a set of variables that allows us to specify categorical explanatory variables as independent variables in statistical analyses.
Since there are no multicategorical variables in the `glbwarm` data set, we create one by grouping the age variable into age classes. We create this categorical variable as a `factor`, used for this type of variable. Note that in the last line, we specify the `levels` of the categorical variable, which are the categories included in the categorical variable. The first level is always the *reference category* in the regression analysis.
```{r message=FALSE}
require(tidyverse)
glbwarm <- glbwarm %>%
mutate(
# Create categories
age_group = dplyr::case_when(
age >= 17 & age <= 34 ~ "17-34",
age >= 35 & age <= 54 ~ "35-54",
age >= 55 ~ "55+"
),
# Convert to factor
age_group = factor(
age_group,
level = c("17-34","35-54", "55+")
)
)
barplot(table(glbwarm$age_group), main = "Age Groups")
```
We can double check the levels of the variable by using the following command:
```{r}
levels(glbwarm$age_group)
```
We use this variable in a new regression model.
```{r}
lm3 <- lm(govact ~ negemot + posemot + ideology + sex + age_group,
data = glbwarm)
summary(lm3)
```
The variable has three levels, but as can be observed, the output reports only two levels. The omitted level is the reference category. As with the dichotomous variable `sex` where the reference category is 0 (female), in this case the reference category is the age class `17-34`.
Similarly to the dichotomous variable case, the coefficients indicate the difference between the category indicated in the table and the reference category. For example, holding all other variables constant, individuals aged between 35 and 54 have, on average, a 0.015133 higher value on the dependent variable `govact` (not statistically significant).
We can also change the reference category with the command `relevel`. For instance, we can use older people as reference. The interpretation changes accordingly. For example, individuals aged between 17 and 34 have, on average, a 0.044887 higher value on the dependent variable `govact` (not statistically significant).
```{r}
glbwarm$age_group <- relevel(glbwarm$age_group, ref = "55+")
```
```{r}
lm3b <- lm(govact ~ negemot + posemot + ideology + sex + age_group,
data = glbwarm)
summary(lm3b)
```
What `R` does in the background is transform the multicategorical variable into a set of dummy variables. In this case, each dummy variable represents a specific age group and takes a value of `1` if the individual falls within that age group and `0` otherwise. Notice that to represent a variable composed of `N` categories, `N-1` dummy variables are needed. For example, in this case, we have three age groups, so `N-1 = 2` dummy variables are needed. Indeed, it is not necessary to use a dummy variable for the last age group, as it is represented by all individuals who have a value of zero in the previous dummy variables.
Consider for example three individuals of different age groups. They are represented through dummy coding. As you can see, only two dummy variables are needed, as the last category corresponds to individuals who have a value of 0 in the other categories.
```{r}
data.frame("age17_34" = c(1,0,0),
"age35_54" = c(0,1,0),
"age55+" = c(0,0,1))
```
Let's create, for comparison, two dummy variables instead of a single factor variable as previously done, and run the same regression model to compare the results. As you can see, they are identical.
```{r}
# dummy coding
glbwarm$age_17_34 <- ifelse(glbwarm$age >= 17 & glbwarm$age <= 34, 1, 0)
glbwarm$age_35_54 <- ifelse(glbwarm$age >= 35 & glbwarm$age <= 54, 1, 0)
# we omit the third class, as it is already represented by the zeros in
# the first two dummy variables
# glbwarm$age_55 <- ifelse(glbwarm$age >= 55, 1, 0)
```
```{r}
lm3c <- lm(govact ~ negemot + posemot + ideology + sex +
age_17_34 + age_35_54,
data = glbwarm)
summary(lm3c)
```
# Residuals and assumptions
The interpretation of residuals requires to discuss the assumptions of linear models. Linear regression is founded on some assumptions. The violation of these assumptions can have adverse effects on the interpretation of the model and on inference, therefore we should be mindful of the assumptions the regression model makes. The main assumptions of the linear regression model are the following:
- **Linearity**: Linearity states that the relationships between the variables in the model are linear in nature, or at least approximately linear. For obvious reasons, it's wrong to use a linear model to understand non-linear relations. Linearity is violated, for instance, when for low values of $X$, a *one* unit increase in $X$ corresponds to an increase of *one* unit in $Y$, but for high values of $X$, *one* unit increase in $X$ corresponds to an increase of *three* units in $Y$.
- **Normality**: The assumption of normality states that the errors (i.e. residuals) are normally distributed. In general, *linear regression is considered to be "robust" to mild violation of normality*. Research suggests that only the most severe violations of the normality assumption substantially affect the validity of statistical inferences from a regression analysis unless the sample size is quite small.
- **Homoscedasticity**: Homoskedasticity (also homoscedasticity) states that errors in estimation are almost equal across the range of the estimated values of the outcome $\hat Y$. When this condition is not met, the errors in estimation are said to be *heteroscedastic*.
- **Independence**: The errors in estimation should be statistically independent. In the most basic terms, two things are independent if information about one gives no information about the other. A typical violation of independence is the autocorrelation in *time series data*, which has to be handled with specific time series techniques.
- **Outliers**: Observations particularly different from the average are called outliers. They may have excessive influence over the coefficient estimates (*"influential observations"*). If so, they must be thoroughly inspected.
- **No multicollinearity**: Multicollinearity is the occurrence of high correlation among two or more independent variables in a multiple regression model. It makes it difficult to distinguish the effect of the variables.
## Check the assumptions
R can easily provide the analyst with four *diagnostic plots* you can use to assess the assumptions of the model.
You can visualize the plots by using the function `plot` applied to the "object" corresponding to your fitted model. You can visualize the plots together by using `par(mfrow=c(2,2))` before calling the `plot` function. In this way, you create a 2x2 layer to show the 4 main diagnostic plots on the same page. You can also visualize a single plot by using the number of the plot inside the *plot* function (e.g.: `plot(lm_object, 1)`).
```{r}
par(mfrow=c(2,2))
plot(lm2)
```
In general, you want the *Normal Q-Q plot* to show points along a *diagonal* line, and the other three plots showing *randomly scattered* points, without any evident systematic pattern.
Points showing a conic shape in the *Residuals vs Fitted* and *Scale-Location* plots are indicative of an *heteroskedasticity* problem (violation of the homoscedasticity assumption). Ideally, you should see a *roughly horizontal line* *with* *equally spread* *points*. A statistical test for checking homoscedasticity is the Breusch-Pagan test. It is included in the `lmtest` library. A p-value \< 0.05 suggests heteroskedasticity.
```{r eval = FALSE}
install.package("lmtest")
```
```{r}
library(lmtest)
bptest(lm2)
```
Heteroskedasticity does not impact coefficients, but affects statistical tests (e.g., tests that conclude whether the coefficients are statistically significant). There are different ways to mitigate or resolve this and other assumption issues. A way is to correct the regression model with *Heteroscedasticity-Consistent Standard Errors*. In R you need the `lmtest` and `sandwich` package.
```{r eval = FALSE}
install.package("sandwich")
```
```{r}
library(lmtest)
library(sandwich)
coeftest(lm2, vcov = vcovHC(lm2, type = "HC3"))
```
You can also see that certain dots are marked by a number. These are points with unexpectedly high residuals (error) and you could inspect them to find out why (e.g., to exclude there are errors in the data set). Also check if any point in the *Residuals vs Leverage* plot falls outside of Cook's distance (a red dashed lines). These points are considered to be *influential observations*. Influential points have a large influence on the model and should be carefully inspected. In this case there are no influential points, and the red dashed line is not even displayed.
To verify *multicollinearity* you can also calculate the *VIF (Variance Inflation Factor)*. The function to calculate it is `vif`, and is included in the package `car`. The smallest possible value of VIF is one (absence of multicollinearity), and as a rule of thumb, a VIF value that exceeds 5 or 10 indicates a problematic amount of collinearity.
```{r eval = FALSE}
# install the package
install.packages("car")
```
```{r}
library(car)
car::vif(lm2)
```
# Reading, resources, exercises
## Readings
- Hayes' book, Chapter 2 - Regression fundamentals
## Resources
There are plenty of resources online about linear regression and R. For example:
- [This website](http://www.sthda.com/english/articles/39-regression-model-diagnostics/161-linear-regression-assumptions-and-diagnostics-in-r-essentials/) provides a clear explanation of regression diagnostic plots
- Also [this youtube video](https://www.youtube.com/watch?v=eTZ4VUZHzxw&list=PLqzoL9-eJTNACQzVDW7ZhoKrveh4-mXv7&index=3) provides a simple explanation of regression diagnostic plots.
## Exercises 1
Use the data sets from the World Value Survey and the European Value Study to formulate a hypothesis and conduct a multiple linear regression analysis to either support or reject it. The model should include one dependent variable, three independent variables and two control variables (typically demographic variables such as gender and age), for a total of five predictors. Refer to the documentation to identify the variables, and utilize the provided code to generate the data set. Ensure to thoroughly examine the variables and consult the documentation to accurately interpret the variable values (i.e., to check what a high value corresponds to and what a low value corresponds to).
```{r}
# Code to create a dataset "df" that includes the desired variable ####
library(haven)
library(tidyverse)
library(janitor)
# load the full dataset: ZA7505_v4_0_0
ZA7505_v4_0_0 <- read_dta("data/ZA7505_v4-0-0.dta")
# create the research dataset "df"
df <- ZA7505_v4_0_0 %>%
# keep Austrian data only
filter(cntry_AN == "AT") %>%
# write here the codes of the variables you have choosen
select(year, cntry_AN, X003, X003R, A006, A065, E033, A124_09, D081, F120, F121, F122, C001_01) %>%
# you can choose to rename the selected columns.
# If you prefer to work with variable codes cancel everything from "rename" to the pipe
# symbol "%>%" after "F122"
rename("Age" = X003,
"Age recoded" = X003R,
"Important in life: Religion" = A006,
"Member: Belong to religious organization" = A065,
"Dont like as neighbours: homosexuals" = A124_09,
"Homosexual couples are as good parents as other couples" = D081,
"Jobs scarce: Men should have more right to a job than women" = C001_01,
"Self positioning in political scale" = E033,
"Justifiable: Abortion" = F120,
"Justifiable: Divorce" = F121,
"Justifiable: Euthanasia" = F122) %>%
# clean the column names
janitor::clean_names() %>%
# keep only positive values
filter(if_all(where(is.numeric), ~ .x >= 0))
```
In the case of this specific data set and data format, the values of the variables are labeled, and the labels can be accessed by using the `attributes` function.
```{r}
attributes(df$age_recoded)$labels
```
```{r}
attributes(df$important_in_life_religion)$labels
```
Run the analysis and write a short report including:
- Formulation of the hypothesis (one hypothesis for each of the three independent variable, one sentence for each hypothesis).
- Sample size of the data set, histogram of the dependent variable, and a table reporting the variables' summary statistics (mean and standard deviations of the variables, minimum and maximum) when appropriate (i.e., for quantitative variables). For qualitative variables, report the frequencies (using the command `table` and `prop.table`: for example:
```{r}
# absolute frequencies
table(df$age_recoded)
```
```{r}
# relative frequencies
round( prop.table(table(df$age_recoded)), 2)
```
- A multiple linear regression model to predict/explain your independent variable using dependent variables of your choice. Report the regression table and provide the appropriate interpretation.
- Check out the diagnostic plots and provide an interpretation of the appropriateness of the linear model: do you see any evident pattern in the points? Are the dots grouped along a diagonal line in the normal Q-Q plot? Also calculate the Variance Inflation Factor (VIF) using the function `vif` function in the `car` package.
Please use `Quarto Document` to create the report, as it includes the code and the output. The easiest way to create a nice report is to render to `html`. See [this tutorial](https://quarto.org/docs/get-started/authoring/rstudio.html) to create a Quarto document, and copy the options to create a self-contained `html` report [here](https://quarto.org/docs/output-formats/html-basics.html#self-contained).
Report the findings using APA-style. For example:
> We tested if negative and positive emotions significantly predicted participants' support for government, controlling for sex, age, and ideology. The results of the regression indicated the predictors explained 38.45% of the variance (Adj. R2 =.3845, F(5, 809) = 102.7, p \< .001). It was found that negative emotions significantly predicted participants' support for government (*b* = .44, p \< .001), while positive emotions did not significantly predict participants' support for government (*b* = -.027, p = .342).
Also report the results of the regression model using a standard regression table. You can refer to any regression table published on a scientific journal (e.g., [p. 970](https://www.jstor.org/stable/pdf/2111665.pdf?casa_token=9O5i9dawIt0AAAAA:RXmgYQMt08Yj71j-Rbw9ThfmMIHSFJ_Jux_n_ewPQVjWkQYm6O98wYzdzi-6F76vGdukjJDN0uqaAl7w5VtGVGCOsVecT7lZMmDAfVdP4EGGQb6Hzs6E)), and also use the `stargazer` function in the homonym package for printing the table directly in the Quarto report.
```{r eval=FALSE}
install.packages("stargazer")
```
You can print and copy
```{r message=FALSE, warning=FALSE}
library(stargazer)
stargazer(lm2, type="text", style = "apsr")
```
## Exercises 2 (optional)
The following exercise is based on the `estress` data set (`estress.csv`).
### Description of the data set
The participants in the `estress` study (162 male, 100 female, `sex` in the data, 0 = female, 1 = male) were asked a series of questions about how they felt their business was doing.
Their responses were used to construct an index of economic stress (`estress` in the data set, with high scores reflecting greater economic stress).
They were also asked the extent to which they had various feelings related to their business, such as "discouraged," "hopeless," "worthless," and the like, an aggregation of which was used to quantify business-related depressed affect (`affect` in the data set, with higher scores reflecting more depressed affect).
They were also asked a set of questions to quantify their intentions to withdraw from entrepreneurship in the next year (`withdraw` in the data set, with higher scores indicative of greater withdrawal intentions).
There is also a measure of entrepreneurial self-efficacy which indexes a person's confidence in his or her ability to successfully engage in various entrepreneurship-related tasks such as setting and meeting goals, creating new products, managing risk, and making decisions (`ese` in the data set).
The data set also includes the length of time in the business, in years (`tenure` in the data set), and the age of these entrepreneurs (`age`).
### Exercise
Using the `estress` data set, write a short data analysis report including:
- Summary statistics: five number summary, standard deviation, and the sample size of the data set.
- A multiple linear regression model to predict/explain `withdraw` intention based on the following independent variables: `affect`, `sex`, `estress`, `age`, `tenure`, `ese`. Report the regression table and provide the appropriate interpretation.
- Check out the diagnostic plots and provide an interpretation: do you see any evident pattern in the points? Are the dots grouped along a diagonal line in the normal Q-Q plot? Also calculate the Variance Inflation Factor (VIF) using the function `vif` function in the `car` package.