Introduzione alle statistiche in R

Distanza media di ogni punto dati dalla media dei dati


dists <- msleep$sleep_total - mean(msleep$sleep_total)
dists
1.66626506 6.56626506 ... -4.13373494 2.06626506 -0.63373494
squared_dists <- (dists)^2
2.776439251 43.115836841 ... 17.087764552 4.269451299 0.401619974
sum_sq_dists <- sum(squared_dists)
sum_sq_dists
1624.066
sum_sq_dists/82
19.80568
var(msleep$sleep_total)
19.80568
sqrt(var(msleep$sleep_total))
4.450357
# Standard deviation of 'sleep_total'
sd(msleep$sleep_total)
4.450357
dists <- msleep$sleep_total - mean(msleep$sleep_total)
mean(abs(dists))
3.566701
Deviazione standard vs. deviazione media assoluta
quantile(msleep$sleep_total)
0% 25% 50% 75% 100%
1.90 7.85 10.10 13.75 19.90
Second quartile/50th percentile = median
ggplot(msleep, aes(y = sleep_total)) +
geom_boxplot()

quantile(msleep$sleep_total, probs = c(0, 0.2, 0.4, 0.6, 0.8, 1))
0% 20% 40% 60% 80% 100%
1.90 6.24 9.48 11.14 14.40 19.90
seq(from, to, by)
quantile(msleep$sleep_total, probs = seq(0, 1, 0.2))
0% 20% 40% 60% 80% 100%
1.90 6.24 9.48 11.14 14.40 19.90
Altezza del riquadro in un boxplot
iqr = quantile(msleep$sleep_total, 0.75) - quantile(msleep$sleep_total, 0.25)
iqr
75%
5.9
Outlier: punto di dati che è sostanzialmente diverso dagli altri
Come facciamo a sapere qual è una differenza sostanziale? Un dato è un outlier se:
iqr <- quantile(msleep$bodywt, 0.75) - quantile(msleep$bodywt, 0.25)lower_threshold <- quantile(msleep$bodywt, 0.25) - 1.5 * iqr upper_threshold<- quantile(msleep$bodywt, 0.75) + 1.5 * iqr
msleep %>% filter(bodywt < lower_threshold | bodywt > upper_threshold ) %>%
select(name, vore, sleep_total, bodywt)
# A tibble: 11 x 4
name vore sleep_total bodywt
<chr> <chr> <dbl> <dbl>
1 Cow herbi 4 600
2 Asian elephant herbi 3.9 2547
3 Horse herbi 2.9 521
...
Introduzione alle statistiche in R