gpt4 book ai didi

r - 忽略 ggplot2 geom_violin 中的异常值

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

有没有办法忽略 geom_violin 中的异常值并使 y 轴图与 Q1 和 Q3 分位数相关? (range=1.5 在 base R 中)。如果这可以自动化(即不只是调用特定的 y 轴限制),那就太好了。

我在这里看到一个使用 geom_boxplot 的解决方案:Ignore outliers in ggplot2 boxplot

但是有没有办法在 geom_violin 中复制这种类型的解决方案?提前致谢!

下面的示例代码具有期望的结果

library(ggplot2)
Result <- as.numeric(c(.2, .03, .11, .05, .2, .02, .22, 1.1, .02, 120))
Group <- as.factor(c("a", "a", "a", "b", "b", "b", "c", "c", "c", "c"))
x <- data.frame(Result, Group)

plot = ggplot(x, aes(x=Group, y=Result)) +
geom_violin()

print(plot)

这是上面的输出(不是一个 super 有用的图形):

enter image description here

我想要使用上述数据绘制如下图所示的内容: enter image description here

最佳答案

我认为与您链接到的方法类似的方法将在这里起作用,除了您需要计算每个组的统计数据并使用最小 Q1 和最大 Q3 作为 coord_cartesian:

library(dplyr)
# compute lower and upper whiskers for each group
ylims <- x %>%
group_by(Group) %>%
summarise(Q1 = quantile(Result, 1/4), Q3 = quantile(Result, 3/4)) %>%
ungroup() %>%
#get lowest Q1 and highest Q3
summarise(lowQ1 = min(Q1), highQ3 = max(Q3))

plot + coord_cartesian(ylim = as.numeric(ylims)*1.05)

请注意,您可以更改对 coord_cartesian 的调用中的缩放比例以及计算 Q1 和 Q3 范围的代码的管道位中的分位数中断。

关于r - 忽略 ggplot2 geom_violin 中的异常值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49908469/

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