繁体   English   中英

通过 ggplot2 限制小提琴图中的分散抖动点

[英]Restrain scattered jitter points within a violin plot by ggplot2

以下用于在 ggplot2 中生成小提琴图:

ggplot(violin,aes(x=variable,y=log(value+0.5),color=Group)) + 
  geom_violin(scale="width") + 
  geom_jitter(aes(group=Group), position=position_jitterdodge()) + 
  stat_summary(fun.y="mean",geom="crossbar", mapping=aes(ymin=..y.., ymax=..y..), 
     width=1, position=position_dodge(),show.legend = FALSE) + 
  theme(axis.text.x = element_text(angle = 45, margin=margin(0.5, unit="cm")))

结果图如下所示;

在此处输入图片说明

如您所见,有些点在小提琴形状的边界外抖动,我需要将这些点放在小提琴的内部。 我玩过不同程度的抖动,但都取得了成功。 我很感激任何实现这一目标的指针。

ggbeeswarm包具有 geoms quasirandom 和 beeswarm,它们完全符合您的要求: https : //github.com/eclarke/ggbeeswarm

这是一个有点老的问题,但我认为有一个更好的解决方案。

正如@Richard Telford 在评论中指出的那样, geom_sina是 IMO 的最佳解决方案。

模拟数据

df <- data.frame(data=rnorm(1200), 
                 group=rep(c("A","A","A", "B","B","C"),
                           200)
                 )

制作情节

ggplot(df, aes(y=data,x=group,color=group)) +
  geom_violin()+
  geom_sina()

结果

在此处输入图片说明

希望这是有帮助的。

选项1

使用 geom_beeswarm 包中的 geom_quasirandom 函数:

quasirandom geom 是一种在类别内偏移点以减少过度绘制的便捷方法。 使用 vipor 包。

library(ggbeeswarm)
p <- ggplot(mpg, aes(class, hwy))
p + geom_violin(width = 1.3) + geom_quasirandom(alpha = 0.2, width = 0.2)

在此处输入图片说明

选项 2

不是一个令人满意的答案,因为通过限制水平抖动,我们破坏了处理过度绘图的目的。 但是您可以放大小提琴图的width = 1.3width = 1.3 ),并使用alpha来提高透明度并限制水平抖动( width = .02 )。

p <- ggplot(mpg, aes(class, hwy))
p + geom_violin(width = 1.3) + geom_jitter(alpha = 0.2, width = .02)

在此处输入图片说明

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM