gpt4 book ai didi

ggplot、ggridges 中的倒序

转载 作者:行者123 更新时间:2023-12-05 04:04:34 40 4
gpt4 key购买 nike

我有一个包含长度(整数)和年份(因子)的数据集,我想使用 ggridges 绘制它。这是一个包含整数和因子数据的类似数据集。如何更改 y 轴上 Species(即因子)的顺序?

library(ggplot2)
library(ggridges)
library(viridis)
library(datasets)

order <- c("setosa", "versicolor", "virginica")

ggplot(iris, aes(x = Sepal.Length, y = Species, fill = ..x..), order(Species)) +
geom_density_ridges_gradient(scale = 3, rel_min_height = 0.01) +
scale_fill_viridis(name = "Sepal.Length", option = "A") +
theme_ridges() +
labs(title = 'Sepal Length distributions for irises')

在这里,order(Species)order(order) 不起作用。

我试过:

scale_y_reverse(breaks=order), expand = c(0.01, 0))

但后来意识到这是针对连续变量的(尝试将年份作为数字 - 没有用)。

最佳答案

这是你想要的吗?我在你的代码中添加了 mutate(Species = factor(Species, levels = rev(myorder)))

library(dplyr)
library(ggplot2)
library(ggridges)
library(viridis)
library(datasets)

myorder <- c("setosa", "versicolor", "virginica")
iris <- iris %>%
mutate(Species = factor(Species, levels = rev(myorder)))

ggplot(iris, aes(x = Sepal.Length, y = Species, fill = ..x..), Species) +
geom_density_ridges_gradient(scale = 3, rel_min_height = 0.01) +
scale_fill_viridis(name = "Sepal.Length", option = "A") +
theme_ridges() +
labs(title = 'Sepal Length distributions for irises')
#> Picking joint bandwidth of 0.181

编辑:另一种更简单的方法是使用 forcats 包中的 fct_rev()

library(forcats)
library(ggplot2)
library(ggridges)

ggplot(iris, aes(x = Sepal.Length, y = fct_rev(Species), fill = ..x..), Species) +
geom_density_ridges_gradient(scale = 3, rel_min_height = 0.01) +
scale_fill_viridis_c(name = "Sepal.Length", option = "A") +
theme_ridges() +
labs(title = 'Sepal Length distributions for irises')
#> Picking joint bandwidth of 0.181

reprex package 创建于 2018-09-27 (v0.2.1.9000)

关于ggplot、ggridges 中的倒序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52542676/

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