Perché codice più pulito?

Programmazione funzionale intermedia con purrr

Colin Fay

Data Scientist & R Hacker

Dov'è Wally?

library(broom)
library(dplyr)
lm(Sepal.Length ~ Species, data=iris) %>% tidy() %>% filter(p.value < 0.05)
lm(Pepal.Length ~ Species, data=iris) %>% tidy() %>% filter(p.value < 0.05)
lm(Sepal.Width ~ Species, data=iris) %>% tidy() %>% filter(p.value < 0.05)
lm(Sepal.Length ~ Species, data=iris) %>% tidy() %>% ilter(p.value < 0.05)
Programmazione funzionale intermedia con purrr

Trovare Wally

library(purrr)
tidy_iris_lm <- compose(
  as_mapper(~ filter(.x, p.value < 0.05)), 
  tidy, 
  partial(lm, data=iris, na.action = na.fail)
)

list( Petal.Length ~ Petal.Width, Petal.Width ~ Sepal.Width, Sepal.Width ~ Sepal.Length ) %>% map(tidy_iris_lm)
Programmazione funzionale intermedia con purrr

Cos'è il codice pulito?

Il codice pulito è:

  • Leggero
  • Leggibile
  • Interpretabile
  • Manutenibile
Programmazione funzionale intermedia con purrr

compose()

Comporre funzioni:

library(purrr)

rounded_mean <- compose(round, mean)
rounded_mean(1:2811)
1406
Programmazione funzionale intermedia con purrr

Comporre codice più pulito

# DA
round(mean(1:10))
round(mean(1:100))
round(mean(1:1000))
round(mean(1:10000))
# A
round(median(1:10))
round(median(1:100))
round(median(1:1000))
round(median(1:10000))

-> 4 modifiche

# DA
my_stats <- compose(round, mean)
my_stats(1:10)
my_stats(1:100)
my_stats(1:1000)
my_stats(1:10000)
# A
my_stats <- compose(round, median)
my_stats(1:10)
my_stats(1:100)
my_stats(1:1000)
my_stats(1:10000)

-> 1 modifica

Programmazione funzionale intermedia con purrr

Passiamo alla pratica !

Programmazione funzionale intermedia con purrr

Preparing Video For Download...