我有一个data.frame
5 列,我想生成一个密度图矩阵,这样每个密度图都是两个密度图的叠加。(这类似于 plotmatrix,除了在我的情况下,每列中非 NA 值的数量因列而异,我想要叠加分布而不是散点图)。
我的第一次尝试没有成功,如下所示:
library(ggplot2)
library(reshape)
tmp1 <- data.frame(do.call(cbind, lapply(1:5, function(x) {
r <- rnorm(100)
r[sample(1:100, 20)] <- NA
return(r)
})))
ggplot( melt(tmp1), aes(x=value, fill=variable))+
geom_density(alpha=0.2, position="identity")+opts(legend.position = "none")+
facet_grid(variable ~ variable)
我的第二种方法让我接近了那里,但我不想使用 5 种不同的颜色,而只想在所有地块中使用两种颜色。而且,我确信有一种更优雅的方式来构建这个扩展矩阵:
tmp2 <- do.call(rbind, lapply(1:5, function(i) {
do.call(rbind, lapply(1:5, function(j) {
r <- rbind(data.frame(var=sprintf('X%d', i), val=tmp1[,i]),
data.frame(var=sprintf('X%d', j), val=tmp1[,j]))
r <- data.frame(xx=sprintf('X%d', i), yy=sprintf('X%d', j), r)
return(r)
}))
}))
ggplot(tmp2, aes(x=val, fill=var))+
geom_density(alpha=0.2, position="identity")+opts(legend.position = "none")+
facet_grid(xx ~ yy)
我的解决方案是手动循环遍历成对的列并手动生成叠加密度图,将它们保存到列表中。然后我使用“grid.arrange”将它们排列在一个网格中,如下图所示。
但是是否可以改为使用来实现这一目标facet_grid
?