Ggplot заменить счетчик в процентах в geom_bar

У меня есть dataframe d:

> head(d,20)
   groupchange Symscore3
1            4         1
2            4         2
3            4         1
4            4         2
5            5         0
6            5         0
7            5         0
8            4         0
9            2         2
10           5         0
11           5         0
12           5         1
13           5         0
14           4         1
15           5         1
16           1         0
17           4         0
18           1         1
19           5         0
20           4         0

Что я рисую с помощью:

ggplot(d, aes(groupchange, y=..count../sum(..count..),  fill=Symscore3)) +
  geom_bar(position = "dodge") 

Таким образом, каждый бар представляет свой процент по всем данным.

Вместо этого я хотел бы, чтобы каждый бар представлял относительный процент; т.е. сумма бара, полученного с помощью groupchange = k, должна быть 1.

Ответ 1

Сначала суммируйте и преобразуйте свои данные:

library(dplyr)
d2 <- d %>% 
  group_by(groupchange,Symscore3) %>% 
  summarise(count=n()) %>% 
  mutate(perc=count/sum(count))

Затем вы можете построить его:

ggplot(d2, aes(x = factor(groupchange), y = perc*100, fill = factor(Symscore3))) +
  geom_bar(stat="identity", width = 0.7) +
  labs(x = "Groupchange", y = "percent", fill = "Symscore") +
  theme_minimal(base_size = 14)

это дает:

введите описание изображения здесь


В качестве альтернативы вы можете использовать функцию percent из пакета scales:

brks <- c(0, 0.25, 0.5, 0.75, 1)

ggplot(d2, aes(x = factor(groupchange), y = perc, fill = factor(Symscore3))) +
  geom_bar(stat="identity", width = 0.7) +
  scale_y_continuous(breaks = brks, labels = scales::percent(brks)) +
  labs(x = "Groupchange", y = NULL, fill = "Symscore") +
  theme_minimal(base_size = 14)

который дает:

введите описание изображения здесь

Ответ 2

Если ваша цель - визуализация в минимальном коде, используйте position = "fill" в качестве аргумента в geom_bar().

Если вы хотите в процентах от группы, ответ на вопрос @Jaap dplyr - это путь.

Вот пример воспроизводимости с использованием вышеуказанного набора данных для копирования/вставки:

library(tidyverse)

d <- data_frame(groupchange = c(4,4,4,4,5,5,5,4,2,5,5,5,5,4,5,1,4,1,5,4),
                Symscore3 = c(1,2,1,2,0,0,0,0,2,0,0,1,0,1,1,0,0,1,1,0))

ggplot(d, aes(x = factor(groupchange), fill = factor(Symscore3))) +
  geom_bar(position="fill")

enter image description here