Introduction à la régression dans R
Richie Cotton
Data Evangelist at DataCamp
Brème commune

Perche

Parfois appelé « r au carré » ou « R au carré ».
la proportion de la variance de la variable de réponse qui est prévisible à partir de la variable explicative
1 signifie un ajustement parfait0 signifie le pire ajustement possibleExaminer la valeur intitulée « R-carré multiple ».
mdl_bream <- lm(mass_g ~ length_cm, data = bream)
summary(mdl_bream)
# Some lines of output omitted
Residual standard error: 74.15 on 33 degrees of freedom
Multiple R-squared: 0.8781, Adjusted R-squared: 0.8744
F-statistic: 237.6 on 1 and 33 DF, p-value: < 2.2e-16
library(broom)
library(dplyr)
mdl_bream %>%
glance()
# A tibble: 1 × 12
r.squared adj.r.squared sigma statistic p.value df logLik AIC BIC
<dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl>
1 0.878 0.874 74.2 238. 1.22e-16 1 -199. 405. 409.
# ... with 3 more variables: deviance <dbl>, df.residual <int>, nobs <int>
mdl_bream %>%
glance() %>%
pull(r.squared)
0.8780627
bream %>%
summarize(
coeff_determination = cor(length_cm, mass_g) ^ 2
)
coeff_determination
1 0.8780627
une différence « typique » entre une prédiction et une réponse observée
Elle a la même unité que la variable de réponse.
Veuillez examiner la valeur intitulée « Erreur type résiduelle ».
summary(mdl_bream)
# Some lines of output omitted
Residual standard error: 74.15 on 33 degrees of freedom
Multiple R-squared: 0.8781, Adjusted R-squared: 0.8744
F-statistic: 237.6 on 1 and 33 DF, p-value: < 2.2e-16
library(broom)
library(dplyr)
mdl_bream %>%
glance()
# A tibble: 1 x 11
r.squared adj.r.squared sigma statistic p.value df logLik AIC BIC deviance df.residual
<dbl> <dbl> <dbl> <dbl> <dbl> <int> <dbl> <dbl> <dbl> <dbl> <int>
1 0.878 0.874 74.2 238. 1.22e-16 2 -199. 405. 409. 181452. 33
mdl_bream %>%
glance() %>%
pull(sigma)
74.15224
bream %>%
mutate(
residuals_sq = residuals(mdl_bream) ^ 2
)
species mass_g length_cm residuals_sq
1 Bream 242 23.2 138.9571
2 Bream 290 24.0 260.7586
3 Bream 340 23.9 5126.9926
4 Bream 363 26.3 1318.9197
5 Bream 430 26.5 390.9743
6 Bream 450 26.8 547.9380
...
bream %>%
mutate(
residuals_sq = residuals(mdl_bream) ^ 2
) %>%
summarize(
resid_sum_of_sq = sum(residuals_sq)
)
resid_sum_of_sq
1 181452.3
Le nombre de degrés de liberté correspond au nombre d'observations moins le nombre de coefficients du modèle.
bream %>%
mutate(
residuals_sq = residuals(mdl_bream) ^ 2
) %>%
summarize(
resid_sum_of_sq = sum(residuals_sq),
deg_freedom = n() - 2
)
resid_sum_of_sq deg_freedom
1 181452.3 33
bream %>%
mutate(
residuals_sq = residuals(mdl_bream) ^ 2
) %>%
summarize(
resid_sum_of_sq = sum(residuals_sq),
deg_freedom = n() - 2,
rse = sqrt(resid_sum_of_sq / deg_freedom)
)
resid_sum_of_sq deg_freedom rse
1 181452.3 33 74.15224
mdl_bream a un RSE de 74.
La différence entre les masses prévues et les masses observées pour les brèmes communes est généralement d'environ 74 g.
Erreur type résiduelle
bream %>%
mutate(
residuals_sq = residuals(mdl_bream) ^ 2
) %>%
summarize(
resid_sum_of_sq = sum(residuals_sq),
deg_freedom = n() - 2,
rse = sqrt(resid_sum_of_sq / deg_freedom)
)
Erreur quadratique moyenne
bream %>%
mutate(
residuals_sq = residuals(mdl_bream) ^ 2
) %>%
summarize(
resid_sum_of_sq = sum(residuals_sq),
n_obs = n(),
rmse = sqrt(resid_sum_of_sq / n_obs)
)
Introduction à la régression dans R