I'm trying to reproduce a graph from Clause Willke's data visualization guide (https://clauswilke.com/dataviz/visualizing-uncertainty.html#fig:cocoa-data-vs-CI), and the code he wrote is choking for me.
I apologize in advance if this is long, but trying to explain what I think is going on. (Also, you can find the cacao data at https://github.com/clauswilke/dviz.supp/blob/master/data/cacao.rda.)
Full code chunk:
cacao %>% 
  filter(location == "Canada") -> cacao_single
fit <- lm(rating ~ 1, data = cacao_single)
CI_df <- data.frame(type = c(0.8, 0.95, 0.99)) %>%
  mutate(df = map(type, ~tidy(emmeans(fit, ~ 1, options = list(level = .x)
  )))) %>%
  unnest(c()) %>%
  select(type, estimate, std.error, conf.low, conf.high) %>%
  mutate(type = paste0(signif(100*type, 2), "% confidence interval"))
Error: Can't subset columns that don't exist.
x Column `estimate` doesn't exist.
The emmeans() function normally returns the beta estimate, SE, df, and upper and lower confidence bounds, as in:
> emmeans(fit, ~1)
 1       emmean     SE  df lower.CL upper.CL
 overall   3.32 0.0379 124     3.25      3.4
Confidence level used: 0.95 
When I run the piped statement above, I get a list of tibbles, but the list-element tibbles do not have CIs attached. This is in addition to the select() not finding estimate (as the error message appears to indicate). Thus,
- Why doesn't the list of tibbles have the CIs associated with each confidence level in the typecolumn? Should it?
- How can I get select()to, well, select?
 
                        
Try removing
c()inunnest()(it gives a warning but it works). It may be thatunnest()syntax has changed.