如何在 R 中的 x 轴上使用两个分类变量制作散点图

How to make scatterplot with two categorical variables on x-axis in R

我正在尝试在 R 中绘制一个散点图,其中两个分类变量位于 x 轴上。对于箱线图,我知道如何执行此操作(请参阅下面代码的第一部分),但不知何故我无法让它用于散点图。我尝试了几件事,但是当我绘制点时,它们总是重叠并且不再显示我的第二个分类变量。抖动也不起作用,因为我希望我的类别聚集而不是随机分散。有谁知道如何做到这一点?您可以在下面找到一些示例数据和我尝试过的一些图表,包括评论。第一张图给了我一些与我想要的类似的东西,但后来用的是箱线图而不是散点图。第二张图给出了一个散点图(为第二个分类变量人工创建数字),但随后我松开了我的第二个分类变量的标签,它在一次 space 中绘制了两次。

为了让它更复杂,我还想用所有散点图显示一条平均值线。类似于 Categorical scatter plot with mean segments using ggplot2 in R 中所做的事情。我该如何添加?

感谢您的帮助!

time = c(rep('t1',12),rep('t2',12))
Origin =  c(rep('I1B',4),rep('I1C',4),rep('J4A',4),rep('I1B',4),rep('I1C',4),rep('J4A',4))
LB_FR = runif(24)

df = data.frame(time,Origin,LB_FR)

#does not work with geom_point
ggplot(df, aes(x = time, y = LB_FR, fill = Origin)) + geom_boxplot() + ggtitle('LB_FR')

#create df_2 with numbers instead of categories for Origin
df_2 = df
for (r in 1:nrow(df)){
  if (df$Origin[r] == 'I1B') df_2[r,'OriginNr'] = 1
  if (df$Origin[r] == 'I1C') df_2[r,'OriginNr'] = 2
  if (df$Origin[r] == 'J4A') df_2[r,'OriginNr'] = 3
}

# indices for time
t1 = df_2$time=="t1"
t2 = df_2$time=="t2"

plot(df_2$OriginNr,df$LB_FR, 
     xlim = c(0,4), ylim = c(0,1), bty = 'n',
     main = 'LB_FR', ylab = 'Fraction remaining', xlab = 'Origin', type = 'n')
points(df_2$OriginNr[t1],df_2$LB_FR[t1],col='red')
points(df_2$OriginNr[t2],df_2$LB_FR[t2],col='blue')
legend(0.1,0.9,legend=c('month 0-6','month 6-12'),pch=1,col=c('red','blue'),bty='n',cex=1.2)

geom_boxplot 的默认 "position" 是 闪避 位置。你也可以用 geom_point 模拟这个:

ggplot(df, aes(x = time, y = LB_FR, color = Origin)) + 
    geom_point(position = position_dodge(width = 0.4))

我建议让您的问题保持重点:而不是 "making your question even more complicated",针对平均线问题提出新问题。