我在这里有一些数据[在 .txt 文件中],我将其读入数据框 df,
df <- read.table("data.txt", header=T,sep="\t")
我使用以下代码删除列中的负值x
(因为我只需要正值) ,df
yp <- subset(df, x>0)
现在我想在同一层绘制多个箱线图。我首先融化了数据框df
,结果图包含几个异常值,如下所示。
# Melting data frame df
df_mlt <-melt(df, id=names(df)[1])
# plotting the boxplots
plt_wool <- ggplot(subset(df_mlt, value > 0), aes(x=ID1,y=value)) +
geom_boxplot(aes(color=factor(ID1))) +
scale_y_log10(breaks = trans_breaks("log10", function(x) 10^x), labels = trans_format("log10", math_format(10^.x))) +
theme_bw() +
theme(legend.text=element_text(size=14), legend.title=element_text(size=14))+
theme(axis.text=element_text(size=20)) +
theme(axis.title=element_text(size=20,face="bold")) +
labs(x = "x", y = "y",colour="legend" ) +
annotation_logticks(sides = "rl") +
theme(panel.grid.minor = element_blank()) +
guides(title.hjust=0.5) +
theme(plot.margin=unit(c(0,1,0,0),"mm"))
plt_wool
现在我需要有一个没有任何异常值的图,所以首先我计算下限和上限晶须,我使用以下代码,如下所示,
sts <- boxplot.stats(yp$x)$stats
为了消除异常值,我添加了上下晶须限制,如下所示,
p1 = plt_wool + coord_cartesian(ylim = c(sts*1.05,sts/1.05))
结果图如下所示,而上面的代码行正确地删除了大部分顶部异常值,所有底部异常值仍然存在。有人可以建议如何从这个情节中完全删除所有异常值,谢谢。