De infer-pijplijn vervolgen

Hypothesis Testing in R

Richie Cotton

Data Evangelist at DataCamp

Samenvatting: hypothesen en dataset

$H_{0}$: Het aandeel hobbyisten < 30 is gelijk aan dat van ≥ 30.

$H_{A}$: Het aandeel hobbyisten < 30 verschilt van dat van ≥ 30.

alpha <- 0.1

stack_overflow_imbalanced %>% 
  count(hobbyist, age_cat, .drop = FALSE)
  hobbyist     age_cat    n
1       No At least 30    0
2       No    Under 30  191
3      Yes At least 30   15
4      Yes    Under 30 1025
Hypothesis Testing in R

Samenvatting: workflow

null_distn <- dataset %>% 
  specify() %>% 
  hypothesize() %>% 
  generate() %>% 
  calculate()
observed_stat <- dataset %>% 
  specify() %>% 
  calculate()
get_p_value(null_distn, observed_stat)
stack_overflow_imbalanced %>%
  specify(hobbyist ~ age_cat, success = "Yes") %>% 
  hypothesize(null = "independence")
Response: hobbyist (factor)
Explanatory: age_cat (factor)
Null Hypothesis: independence
# A tibble: 1,231 x 2
  hobbyist age_cat    
  <fct>    <fct>      
1 Yes      At least 30
2 Yes      At least 30
3 Yes      At least 30
4 Yes      Under 30   
5 Yes      At least 30
6 Yes      At least 30
7 No       Under 30   
# ... with 1,224 more rows
Hypothesis Testing in R

Motivatie voor generate()

$H_{0}$: Het aandeel hobbyisten < 30 is gelijk aan dat van ≥ 30.

Als $H_{0}$ waar is, dan:

  • In elke rij kon de hobbyist-waarde bij beide leeftijdscategorieën voorkomen met gelijke kans.
  • Dit simuleren we door de hobbyist-waarden te permuten (schudden) en de leeftijdscategorieën vast te houden.
Hypothesis Testing in R
stack_overflow_imbalanced






# A tibble: 1,231 x 2
  hobbyist age_cat    
  <fct>    <fct>      
1 Yes      At least 30
2 Yes      At least 30
3 Yes      At least 30
4 Yes      Under 30   
5 Yes      At least 30
6 Yes      At least 30
7 No       Under 30   
# ... with 1,224 more rows
bind_cols(
  stack_overflow_imbalanced %>% 
    select(hobbyist) %>% 
    slice_sample(prop = 1),
  stack_overflow_imbalanced %>% 
    select(age_cat)
)
# A tibble: 1,231 x 2
  hobbyist age_cat    
  <fct>    <fct>      
1 Yes      At least 30
2 Yes      At least 30
3 No       At least 30
4 No       Under 30   
5 Yes      At least 30
6 Yes      At least 30
7 Yes      Under 30   
# ... with 1,224 more rows
Hypothesis Testing in R

Veel replicaties genereren

Het tweekoloms raster uit de specify-stap staat links. Rechts daarvan staat het woord generate met een pijl naar rechts. Rechts van de pijl staan drie extra tweekoloms rasters: de rechterkolom is identiek aan die van het origineel (verklarende variabele onveranderd), de linkerkolom verschilt (responsvariabele gepermuteerd).

Hypothesis Testing in R

generate()

generate() maakt gesimuleerde data volgens de nulhypothese.

  • Voor nulhypotheses over onafhankelijkheid: type = "permute".
  • Voor puntsgewijze nulhypotheses: type = "bootstrap" of "simulate".
stack_overflow_imbalanced %>%
  specify(hobbyist ~ age_cat, success = "Yes") %>% 
  hypothesize(null = "independence") %>% 
  generate(reps = 5000, type = "permute")
Response: hobbyist (factor)
Explanatory: age_cat (factor)
Null Hypothesis: independence
# A tibble: 6,155,000 x 3
# Groups:   replicate [5,000]
  hobbyist age_cat     replicate
  <fct>    <fct>           <int>
1 Yes      At least 30         1
2 Yes      At least 30         1
3 Yes      At least 30         1
4 Yes      Under 30            1
5 Yes      At least 30         1
6 Yes      At least 30         1
7 Yes      Under 30            1
# ... with 6,154,993 more rows
Hypothesis Testing in R

De toetsingsstatistiek berekenen

De rechthoekige rasters van het originele dataset en replicaties uit de generate-stap. Daaronder staat 'calculate' met neerwaartse pijlen naar elk replicaat. Onder elke pijl staat één gearceerde cel: de toetsingsstatistiek. Een kader eromheen heet 'nulverdeling'.

Hypothesis Testing in R

calculate()

calculate() berekent een verdeling van toetsingsstatistieken: de nulverdeling.

null_distn <- stack_overflow_imbalanced %>%
  specify(
    hobbyist ~ age_cat, 
    success = "Yes"
  ) %>%
  hypothesize(null = "independence") %>%
  generate(reps = 5000, type = "permute") %>%
  calculate(
    stat = "diff in props", 
    order = c("At least 30", "Under 30")
  )
# A tibble: 5,000 x 2
  replicate    stat
      <int>   <dbl>
1         1  0.0896
2         2  0.0896
3         3 -0.180 
4         4  0.157 
5         5  0.0896
6         6 -0.113 
7         7  0.0221
# ... with 4,993 more rows
1 De help-pagina ?calculate geeft alle mogelijke toetsingsstatistieken.
Hypothesis Testing in R

De nulverdeling visualiseren

visualize(null_distn)

Een histogram van de nulverdeling. Linksscheef, met negen unieke waarden.

null_distn %>% count(stat)
# A tibble: 9 x 2
     stat     n
    <dbl> <int>
1 -0.383      2
2 -0.315     22
3 -0.248     63
4 -0.180    246
5 -0.113    641
6 -0.0454  1132
7  0.0221  1453
8  0.0896  1063
9  0.157    378
Hypothesis Testing in R

Toetsingsstatistiek op het originele dataset

De rasters van het originele dataset en replicaties met de nulverdeling uit de calculate-stap. Nu staat er ook een pijl omlaag onder het originele dataset met één gearceerde cel: de geobserveerde statistiek.

Hypothesis Testing in R

Geobserveerde statistiek: specify() %>% calculate()

obs_stat <- stack_overflow_imbalanced %>%
  specify(hobbyist ~ age_cat, success = "Yes") %>%
  # hypothesize(null = "independence") %>%
  # generate(reps = 5000, type = "permute") %>%
  calculate(
    stat = "diff in props",
    order = c("At least 30", "Under 30")
  )
# A tibble: 1 x 1
   stat
  <dbl>
1 0.157
Hypothesis Testing in R

Nulverdeling vs. geobserveerde statistiek

visualize(null_distn) +
  geom_vline(
    aes(xintercept = stat),
    data = observed_stat, 
    color = "red"
  )

Het histogram van de nulverdeling met een extra rode verticale lijn bij de geobserveerde statistiek. De lijn staat bij de meest rechtse staaf.

Hypothesis Testing in R

Bepaal de p-waarde

get_p_value(
  null_distn, obs_stat, 
  direction = "two sided"   # Not alternative = "two.sided"
)
# A tibble: 1 x 1
  p_value
    <dbl>
1   0.151
# A tibble: 1 x 6
  statistic chisq_df p_value alternative lower_ci upper_ci
      <dbl>    <dbl>   <dbl> <chr>          <dbl>    <dbl>
1      2.79        1  0.0949 two.sided    0.00718   0.0217
Hypothesis Testing in R

Laten we oefenen!

Hypothesis Testing in R

Preparing Video For Download...