Lecture 6
Duke University
STA 199 - Fall 2025
September 11, 2025
Which of the following is false about the following plot and the code that produced it?
Scan the QR code or go to app.wooclap.com/sta199. Log in with your Duke NetID.
legend.position = "bottom"
is set in the theme()
layer.color
and fill
.group_by(species)
is used to create the boxplots. [*]Plots should include an informative title, axes and legends should have human-readable labels, and careful consideration should be given to aesthetic choices.
Code should follow the tidyverse style (style.tidyverse.org) Particularly,
+
when building a ggplot
|>
in a data transformation pipeline=
signs and spaces after commasAll code should be visible in the PDF output, i.e., should not run off the page on the PDF. Long lines that run off the page should be split across multiple lines with line breaks. Tip: Haikus not novellas when writing code!
Whydowecareaboutthestyleandreadabilityofyourcode? \(\rightarrow\) Why do we care about the style and readability of your code?
Je voudrais un cafe \(\rightarrow\) Je voudrais un café
gerrymander
Is a Congressional District more likely to have high prevalence of gerrymandering if a Democrat was able to flip the seat in the 2018 election?
group_by()
, summarize()
, count()
group_by()
do?What does group_by()
do in the following pipeline?
What does group_by()
do in the following pipeline?
group_by()
Group by converts a data frame to a grouped data frame, where subsequent operations are performed once per group
ungroup()
removes grouping
# A tibble: 435 × 12
district last_name first_name party16 clinton16 trump16 dem16 state
<chr> <chr> <chr> <chr> <dbl> <dbl> <dbl> <chr>
1 AK-AL Young Don R 37.6 52.8 0 AK
2 AL-01 Byrne Bradley R 34.1 63.5 0 AL
3 AL-02 Roby Martha R 33 64.9 0 AL
4 AL-03 Rogers Mike D. R 32.3 65.3 0 AL
5 AL-04 Aderholt Rob R 17.4 80.4 0 AL
6 AL-05 Brooks Mo R 31.3 64.7 0 AL
7 AL-06 Palmer Gary R 26.1 70.8 0 AL
8 AL-07 Sewell Terri D 69.8 28.6 1 AL
9 AR-01 Crawford Rick R 30.2 65 0 AR
10 AR-02 Hill French R 41.7 52.4 0 AR
# ℹ 425 more rows
# ℹ 4 more variables: party18 <chr>, dem18 <dbl>, flip18 <dbl>,
# gerry <fct>
group_by() |> summarize()
A common pipeline is group_by()
and then summarize()
to calculate summary statistics for each group:
gerrymander |>
group_by(state) |>
summarize(
mean_trump16 = mean(trump16),
median_trump16 = median(trump16)
)
# A tibble: 50 × 3
state mean_trump16 median_trump16
<chr> <dbl> <dbl>
1 AK 52.8 52.8
2 AL 62.6 64.9
3 AR 60.9 63.0
4 AZ 46.9 47.7
5 CA 31.7 28.4
6 CO 43.6 41.3
7 CT 41.0 40.4
8 DE 41.9 41.9
9 FL 47.9 49.6
10 GA 51.3 56.6
# ℹ 40 more rows
group_by() |> summarize()
This pipeline can also be used to count number of observations for each group:
summarize()
What’s the difference between the following two pipelines?
count()
Count the number of observations in each level of variable(s)
Place the counts in a variable called n
count()
and sort
What does the following pipeline do? Rewrite it with count()
instead.
mutate()
Is a Congressional District more likely to have high prevalence of gerrymandering if a Democrat was able to flip the seat in the 2018 election?
vs.
Is a Congressional District more likely to be flipped to a Democratic seat if it has high prevalence of gerrymandering or low prevalence of gerrymandering?
The following code should produce a visualization that answers the question “Is a Congressional District more likely to be flipped to a Democratic seat if it has high prevalence of gerrymandering or low prevalence of gerrymandering?” However, it produces a warning
and an unexpected plot. What’s going on?
Warning: The following aesthetics were dropped during statistical
transformation: fill.
ℹ This can happen when ggplot fails to infer the correct grouping
structure in the data.
ℹ Did you forget to specify a `group` aesthetic or to convert a
numerical variable into a factor?
gerrymander
Rows: 435
Columns: 12
$ district <chr> "AK-AL", "AL-01", "AL-02", "AL-03", "AL-04", "AL-…
$ last_name <chr> "Young", "Byrne", "Roby", "Rogers", "Aderholt", "…
$ first_name <chr> "Don", "Bradley", "Martha", "Mike D.", "Rob", "Mo…
$ party16 <chr> "R", "R", "R", "R", "R", "R", "R", "D", "R", "R",…
$ clinton16 <dbl> 37.6, 34.1, 33.0, 32.3, 17.4, 31.3, 26.1, 69.8, 3…
$ trump16 <dbl> 52.8, 63.5, 64.9, 65.3, 80.4, 64.7, 70.8, 28.6, 6…
$ dem16 <dbl> 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0…
$ state <chr> "AK", "AL", "AL", "AL", "AL", "AL", "AL", "AL", "…
$ party18 <chr> "R", "R", "R", "R", "R", "R", "R", "D", "R", "R",…
$ dem18 <dbl> 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0…
$ flip18 <dbl> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0…
$ gerry <fct> mid, high, high, high, high, high, high, high, mi…
mutate()
We want to use flip18
as a categorical variable
But it’s stored as a numeric
So we need to change its type first, before we can use it as a categorical variable
The mutate()
function transforms (mutates) a data frame by creating a new column or updating an existing one
mutate()
in action# A tibble: 435 × 12
district last_name first_name party16 clinton16 trump16 dem16 state
<chr> <chr> <chr> <chr> <dbl> <dbl> <dbl> <chr>
1 AK-AL Young Don R 37.6 52.8 0 AK
2 AL-01 Byrne Bradley R 34.1 63.5 0 AL
3 AL-02 Roby Martha R 33 64.9 0 AL
4 AL-03 Rogers Mike D. R 32.3 65.3 0 AL
5 AL-04 Aderholt Rob R 17.4 80.4 0 AL
6 AL-05 Brooks Mo R 31.3 64.7 0 AL
7 AL-06 Palmer Gary R 26.1 70.8 0 AL
8 AL-07 Sewell Terri D 69.8 28.6 1 AL
9 AR-01 Crawford Rick R 30.2 65 0 AR
10 AR-02 Hill French R 41.7 52.4 0 AR
# ℹ 425 more rows
# ℹ 4 more variables: party18 <chr>, dem18 <dbl>, flip18 <fct>,
# gerry <fct>
Is a Congressional District more likely to be flipped to a Democratic seat if it has high prevalence of gerrymandering or low prevalence of gerrymandering?
Go to your ae project in RStudio.
If you haven’t yet done so, make sure all of your changes up to this point are committed and pushed, i.e., there’s nothing left in your Git pane.
If you haven’t yet done so, click Pull to get today’s application exercise file: ae-04-gerrymander-explore-II.qmd.
Work through the application exercise in class, and render, commit, and push your edits by the end of class.
Local aesthetic mappings for a given geom
Global aesthetic mappings for all geom
s