我使用添加回归趋势线xy
对我正在绘制R
的数据进行了分组:ggplot2
geom_violin
以下是数据:
library(dplyr)
library(plotly)
library(ggplot2)
set.seed(1)
df <- data.frame(value = c(rnorm(500,8,1),rnorm(600,6,1.5),rnorm(400,4,0.5),rnorm(500,2,2),rnorm(400,4,1),rnorm(600,7,0.5),rnorm(500,3,1),rnorm(500,3,1),rnorm(500,3,1)),
age = c(rep("d3",500),rep("d8",600),rep("d24",400),rep("d3",500),rep("d8",400),rep("d24",600),rep("d3",500),rep("d8",500),rep("d24",500)),
group = c(rep("A",1500),rep("B",1500),rep("C",1500))) %>%
dplyr::mutate(time = as.integer(age)) %>%
dplyr::arrange(group,time) %>%
dplyr::mutate(group_age=paste0(group,"_",age))
df$group_age <- factor(df$group_age,levels=unique(df$group_age))
而我目前的情节:
ggplot(df,aes(x=group_age,y=value,fill=age,color=age,alpha=0.5)) +
geom_violin() + geom_boxplot(width=0.1,aes(fill=age,color=age,middle=mean(value))) +
geom_smooth(data=df,mapping=aes(x=group_age,y=value,group=group),color="black",method='lm',size=1,se=T) + theme_minimal()
我的问题是:
- 我如何摆脱的
alpha
部分legend
? - 我希望
x-axis
ticks
是df$group
而不是df$group_age
,这意味着tick
每个标签所在group
的中心都有一个。考虑并非所有s 都具有所有s 的情况 - 例如,如果某个人只有两个s 并且我很确定只会呈现这两个s,我希望 s仍然位于他们的两个s之间.group
group
group
age
group
age
ggplot
age
tick
age
还有一个问题:
将每个拟合斜率的 p 值绘制在每个group
.
我试过:
library(ggpmisc)
my.formula <- value ~ group_age
ggplot(df,aes(x=group_age,y=value,fill=age,color=age,alpha=0.5)) +
geom_violin() + geom_boxplot(width=0.1,aes(fill=age,color=age,middle=mean(value))) +
geom_smooth(data=df,mapping=aes(x=group_age,y=value,group=group),color="black",method='lm',size=1,se=T) + theme_minimal() +
stat_poly_eq(formula = my.formula,aes(label=stat(p.value.label)),parse=T)
但我得到与上面相同的情节,并带有以下warning
消息:
Warning message:
Computation failed in `stat_poly_eq()`:
argument "x" is missing, with no default