-
Notifications
You must be signed in to change notification settings - Fork 0
/
10_ses_deprived.R
47 lines (42 loc) · 1.59 KB
/
10_ses_deprived.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#ZD by SES category
proportion_results <- map(prirhr, function(df) {
df %>%
filter(youngest_1223m == 1) %>%
mutate(weight = v005) %>%
group_by(CountryName, SES) %>%
summarise(
proportion_zd = weighted.mean(zd == 1, w = weight, na.rm = TRUE) * 100,
se = sqrt(wtd.var(zd == 1, weights = weight, na.rm = TRUE)) / sqrt(n()),
ci_lower = proportion_zd - 1.96 * (se * 100),
ci_upper = proportion_zd + 1.96 * (se * 100)
) %>%
mutate(SES = if_else(SES == 1, "SES_yes", "SES_no"))
})
# Combine the results from all countries
combined_results <- bind_rows(proportion_results)
combined_results <- na.omit(combined_results)
# Merge with other data (e.g., country regions)
tab <- merge(combined_results, country_regions, by = "CountryName")
# Sort the data by proportion_zd
tab_sorted <- tab %>%
arrange(proportion_zd)
# Plot using ggplot2
ggplot(tab_sorted, aes(x = proportion_zd, y = reorder(CountryName, proportion_zd), color = SES)) +
geom_point(size = 3) +
geom_line(aes(group = CountryName)) +
geom_errorbar(aes(xmin = ci_lower, xmax = ci_upper), width = 0.2) + # Add confidence intervals
labs(
x = "Percentage of Zero Dose Children (12-23m)",
y = "Country",
title = "Proportion of Zero Dose Children by SES"
) +
theme_minimal() +
theme(
panel.grid = element_blank(),
plot.title = element_text(hjust = 0.5)
) +
scale_color_manual(
name = "SES", # Label the legend
values = c("SES_no" = "orange", "SES_yes" = "skyblue"),
labels = c("SES_no" = "No", "SES_yes" = "Yes")
)