gpt4 book ai didi

r - 按 y 轴值对 ggplot 的每个方面的因子进行排序

转载 作者:行者123 更新时间:2023-12-01 08:48:54 26 4
gpt4 key购买 nike

可以说,在 R 中,我有一个数据框字母、数字和动物,我想以图形方式检查这三者之间的关系。我可以做类似的事情。

library(dplyr)
library(ggplot2)
library(gridExtra)

set.seed(33)
my_df <- data.frame(
letters = c(letters[1:10], letters[6:15], letters[11:20]),
animals = c(rep('sheep', 10), rep('cow', 10), rep('horse', 10)),
numbers = rnorm(1:30)
)

ggplot(my_df, aes(x = letters, y = numbers)) + geom_point() +
facet_wrap(~animals, ncol = 1, scales = 'free_x')

我会得到一些看起来像的东西。 unsorted letters

但是,我希望 x 轴的顺序取决于 y 轴的顺序。根据 example,这很容易在没有方面的情况下完成。 .
我什至可以为每只动物制作一个有序的图形,然后将它们与 grid.arrange 绑定(bind)在一起,如 example
my_df_shp <- my_df %>% filter(animals == 'sheep')
my_df_cow <- my_df %>% filter(animals == 'cow')
my_df_horse <- my_df %>% filter(animals == 'horse')

my_df_shp1 <- my_df_shp %>% mutate(letters = reorder(letters, numbers))
my_df_cow1 <- my_df_cow %>% mutate(letters = reorder(letters, numbers))
my_df_horse1 <- my_df_horse %>% mutate(letters = reorder(letters, numbers))

p_shp <- ggplot(my_df_shp1, aes(x = letters, y = numbers)) + geom_point()
p_cow <- ggplot(my_df_cow1, aes(x = letters, y = numbers)) + geom_point()
p_horse <- ggplot(my_df_horse1, aes(x = letters, y = numbers)) + geom_point()

grid.arrange(p_shp, p_cow, p_horse, ncol = 1)

ordered animals figure

不过,我并不特别喜欢这个解决方案,因为它不容易推广到有很多方面的情况。

我宁愿做类似的事情
ggplot(my_df, aes(x = y_ordered_by_facet(letters, by = numbers), y = numbers)) + geom_point() +
facet_wrap(~animals, ncol = 1, scales = 'free_x')

其中 y_ordered 是一些函数,它巧妙地将字母因子排序为与数字相同的顺序。

接近这一点但似乎不太奏效的东西是
ggplot(my_df, aes(x = reorder(letters, numbers), y = numbers)) +
geom_point() + facet_wrap(~animals, ncol = 1, scales = 'free_x')

这并不完全奏效,因为订单最终在刻面包装之前而不是之后生效,因此每个面板的标签顺序并不完全正确。
almost ordered

有什么聪明的主意吗?

最佳答案

我发现 dplyr 不适用于 group_by()在处理每个组中的不同因素水平时。因此,一种解决方法是考虑为每个动物字母组合创建一个独特的新因子并对其进行排序。首先,我们使用动物+字母创建一个交互变量,并确定动物每个字母的正确顺序

new_order <- my_df %>% 
group_by(animals) %>%
do(data_frame(al=levels(reorder(interaction(.$animals, .$letters, drop=TRUE), .$numbers)))) %>%
pull(al)

现在我们在要绘制的数据中创建交互变量,使用这个新的排序,最后更改标签,使它们再次看起来像字母
my_df %>% 
mutate(al=factor(interaction(animals, letters), levels=new_order)) %>%
ggplot(aes(x = al, y = numbers)) +
geom_point() + facet_wrap(~animals, ncol = 1, scales = 'free_x') +
scale_x_discrete(breaks= new_order, labels=gsub("^.*\\.", "", new_order))

enter image description here

关于r - 按 y 轴值对 ggplot 的每个方面的因子进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48179726/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com