Scenario: Inference for Penguin Data using prop.test() and t.test()

In this project we use the Palmer Penguins data set and formal statistical inferential framework to answer questions about the practice formal statistical inference.

The project has two parts. In Part 1, we work through four complete examples together — a hypothesis test and a confidence interval using prop.test(), followed by a hypothesis test and a confidence interval using t.test(). In Part 2, you will carry out two analyses of your own: one involving a proportion and one involving a mean (or difference in means).


Part 1: Worked Examples

1A: Hypothesis Test for a Proportion — prop.test()

Question: Is the proportion of Chinstrap penguins in the dataset different from one-third (what we would expect if all three species were equally common)?

We count the number of Chinstrap penguins and the total number of penguins with non-missing species data, then run the test.

n_total     <- penguins %>% filter(!is.na(species)) %>% nrow()
n_chinstrap <- penguins %>% filter(species == "Chinstrap") %>% nrow()

n_total
## [1] 344
n_chinstrap
## [1] 68

Our Null Hypothesis is that p = 1/3 (Chinstrap penguins make up one-third of the population)
Our Alternative Hypothesis is that p =/= 1/3 (two-sided)

prop.test(x = n_chinstrap, n = n_total, p = 1/3,
          alternative = "two.sided", correct = FALSE)
## 
##  1-sample proportions test without continuity correction
## 
## data:  n_chinstrap out of n_total, null probability 1/3
## X-squared = 28.488, df = 1, p-value = 9.426e-08
## alternative hypothesis: true p is not equal to 0.3333333
## 95 percent confidence interval:
##  0.1590290 0.2429974
## sample estimates:
##         p 
## 0.1976744

The p-value is very small (well below 0.05), so we reject the null hypothesis. There is strong evidence that Chinstrap penguins do not make up one-third of the population sampled in this data set — they appear to be underrepresented relative to the other two species.

1B: Confidence Interval for a Proportion — prop.test()

Question: What is a plausible range for the true proportion of Chinstrap penguins in the population?

prop.test(x = n_chinstrap, n = n_total, conf.level = 0.95, correct = FALSE)
## 
##  1-sample proportions test without continuity correction
## 
## data:  n_chinstrap out of n_total, null probability 0.5
## X-squared = 125.77, df = 1, p-value < 2.2e-16
## alternative hypothesis: true p is not equal to 0.5
## 95 percent confidence interval:
##  0.1590290 0.2429974
## sample estimates:
##         p 
## 0.1976744

We are 95% confident that the true proportion of Chinstrap penguins is between roughly 0.1590290 and 0.2429974. Because this interval does not include 1/3, it is consistent with the conclusion from Part 1A that the three species are not equally represented.


1C: Hypothesis Test for a Mean — t.test()

Question: A field guide published in 2010 reports that the mean flipper length for Chinstrap penguins is 200 mm. Does the Palmer Station sample support this claim?

We isolate the Chinstrap flipper lengths, then check the normality assumption with a histogram before running the test.

chinstrap_flipper <- penguins %>%
  filter(species == "Chinstrap", !is.na(flipper_length_mm)) %>%
  pull(flipper_length_mm)

length(chinstrap_flipper)
## [1] 68
mean(chinstrap_flipper)
## [1] 195.8235
sd(chinstrap_flipper)
## [1] 7.131894
ggplot(data.frame(flipper = chinstrap_flipper), aes(x = flipper)) +
  geom_histogram(binwidth = 3, fill = "steelblue", color = "white") +
  labs(title = "Chinstrap Penguin Flipper Length",
       x = "Flipper Length (mm)", y = "Count") +
  theme_minimal()

The histogram shows no extreme skew or outliers. The normality assumption is reasonable.

Our null hypothesis is that the true population mean is equal to 200 mm. Our alternative hypothesis is that the true population mean is not equal to 200 mm. This is a two-sided alternative.

t.test(chinstrap_flipper, mu = 200, alternative = "two.sided", conf.level = 0.95)
## 
##  One Sample t-test
## 
## data:  chinstrap_flipper
## t = -4.829, df = 67, p-value = 8.31e-06
## alternative hypothesis: true mean is not equal to 200
## 95 percent confidence interval:
##  194.0972 197.5498
## sample estimates:
## mean of x 
##  195.8235

The p-value is very small (well below 0.05), so we reject the null hypothesis. The Palmer penguin dataset provides strong evidence that the mean Chinstrap flipper length differs from the 200 mm value reported in the field guide. The sample mean of approximately 195.8 mm suggests flipper lengths are shorter than previously reported.


1D: Confidence Interval for a Mean — t.test()

Question: What is a plausible range for the true mean flipper length of Chinstrap penguins?

t.test(chinstrap_flipper, conf.level = 0.95)
## 
##  One Sample t-test
## 
## data:  chinstrap_flipper
## t = 226.42, df = 67, p-value < 2.2e-16
## alternative hypothesis: true mean is not equal to 0
## 95 percent confidence interval:
##  194.0972 197.5498
## sample estimates:
## mean of x 
##  195.8235

We are 95% confident that the true mean flipper length for Chinstrap penguins is between approximately 194.1 mm and 197.5 mm. Notice that this interval does not include 200 mm, which is consistent with our conclusion in Part 1C.


Part 2: Your Turn

Now it is your turn. You will carry out two analyses: one using prop.test() and one using t.test(). For each analysis, choose a question from the options below, then follow the steps shown in Part 1.


2A: Analysis with prop.test()

Choose one of the following questions to investigate:

  • (Option 1) Is there evidence that more than half of Gentoo penguins in the dataset are male?
  • (Option 2) Is there evidence that the proportion of penguins with body mass above 4200 g differs from 0.50?
  • (Option 3) A researcher claims that fewer than 30% of all penguins sampled are from Biscoe Island. Does the data support or contradict this claim?

State which option you chose:

option 1

State your null and alternative hypotheses:

H0: mu = 0.50 Ha: mu =/= 0.50

Set up the counts and run the test. Include a clear code chunk:

gentoo <- penguins %>% filter(species == "Gentoo", !is.na(sex))

n_gentoo <- nrow(gentoo)
n_male   <- sum(gentoo$sex == "male")

n_gentoo
## [1] 119
n_male
## [1] 61
prop.test(x = n_male, n = n_gentoo, p = 0.50,
          alternative = "two.sided", correct = FALSE)
## 
##  1-sample proportions test without continuity correction
## 
## data:  n_male out of n_gentoo, null probability 0.5
## X-squared = 0.07563, df = 1, p-value = 0.7833
## alternative hypothesis: true p is not equal to 0.5
## 95 percent confidence interval:
##  0.4238191 0.6006026
## sample estimates:
##        p 
## 0.512605

Interpret the output. Your answer should address:

(1) What are x and n in your test?

x= total number of male gentoo penguins n= total number of gentoo penguins with known sex

(2) What is the p-value, and what does it tell you? (Use alpha = 0.05.)

p-value = 0.067 this value is greater then 0.05 so we fail to reject the null hypothesis, meaning there is strong evidence that the population of male gentoo penguins is not 0.50.

(3) Report and interpret the 95% confidence interval from the output.

The 95% CI for the true proportion of male Gentoo penguins is: (0.431, 0.606)

This interval includes 0.50, which means 0.50 is a possible value for the true proportion.


2B: Analysis with t.test()

Choose one of the following questions to investigate:

  • (Option 1 — one-sample t-test) The literature suggests that Adelie penguins have a mean bill length of 39 mm. Does the Palmer Station sample support this claim? Use a two-sided test.

  • (Option 2 — one-sample t-test) Is there evidence that the mean body mass of Gentoo penguins exceeds 5000 g? Use a right-tailed test.

  • (Option 3 - one-sample t-test) Is there evidence that Gentoo penguins have a mean bill depth of less than 16mm?

  • (Option 4 — two-sample t-test) Does mean bill length differ between Adelie and Chinstrap penguins?

  • (Option 5 — two-sample t-test) Among Adelie penguins only, does mean flipper length differ between males and females?

  • (Option 6 — two-sample t-test) Does mean body mass differ between Gentoo and Chinstrap penguins? State which option you chose:

*option 1

State your null and alternative hypotheses:

H0: mu= 39 Ha: mu=/= 39

Use dplyr to isolate your data, make a histogram to check the normality assumption, and run the test:

adelie_billlength <- penguins %>%
  filter(species == "Adelie", !is.na(bill_length_mm)) %>%
  pull(bill_length_mm)

# Summary statistics
length(adelie_billlength)
## [1] 151
mean(adelie_billlength)
## [1] 38.79139
sd(adelie_billlength)
## [1] 2.663405
ggplot(data.frame(bill = adelie_billlength), aes(x = bill)) +
  geom_histogram(binwidth = 2, fill = "blue", color = "pink") +
  labs(title = "Adelie Bill Length", 
       x = "Bill Length (mm)", 
       y = "Count") +
  theme_minimal()

t.test(adelie_billlength, 
       mu = 39, 
       alternative = "two.sided", 
       conf.level = 0.95)
## 
##  One Sample t-test
## 
## data:  adelie_billlength
## t = -0.96246, df = 150, p-value = 0.3374
## alternative hypothesis: true mean is not equal to 39
## 95 percent confidence interval:
##  38.36312 39.21966
## sample estimates:
## mean of x 
##  38.79139

Interpret the output. Your answer should address:

(1) What is the sample mean (or difference in sample means)?

The sample mean Adelie bill length is 38.8 mm.

(2) What is the t statistic and degrees of freedom?

t statistic = –0.63 df = 150

(3) What is the p-value, and what is your decision at alpha = 0.05?

p‑value = 0.53 fail to reject the null hypothesis There is not enough evidence to conclude that the true mean Adelie bill length differs from 39 mm.

(4) Report and interpret the 95% confidence interval. Does it contain 0 (for a two-sample test) or your null value (for a one-sample test)? Is this consistent with your decision in (3)?

confidence interval = (38.4 mm, 39.2 mm)

interval does include 39 mm = null value.

means the sample is consistent with the said value.

This agrees that we fail to reject the null hypothesis