我不知道这个问题是否微不足道,但是.
我试图用类似于成对图的形式绘制一组变量。
但是,我不想在图形的行和列中使用相同的变量,而是希望有不同的变量。例如,如果我有一个带有X1的数据集、.、X7和另一个Y1、.、Y7的数据集。
我尝试过布局和par(mfrow),但是当我想交叉7个变量x7变量时,它给了我一个溢出错误。
有没有办法做这个图矩阵7x7?
谢谢
发布于 2014-07-17 18:45:39
我不知道使用基本R中的pairs(...)来实现这一点的方法,但是这里有一个ggplot解决方案,假设您的x值和y值都在名为df.x和df.y的数据文件中。
# create a sample dataset - you have this already...
set.seed(1) # for reproducible example
df.x <- data.frame(matrix(sample(1:50,350,replace=T),nc=7))
df.y <- 2*df.x + rnorm(350,sd=5)
colnames(df.y) <- paste0("Y",1:7)
# this makes the plot - you start here.
library(ggplot2)
library(data.table)
library(reshape2) # for melt(...)
xDT <- data.table(melt(cbind(id=1:nrow(df.x),df.x),id="id",value.name="xval",variable.name="H"),key="id")
yDT <- data.table(melt(cbind(id=1:nrow(df.y),df.y),id="id",value.name="yval",variable.name="V"),key="id")
xy <- xDT[yDT,allow.cartesian=T]
# simulates pairs() in base R
ggp = ggplot(xy,aes(x=xval,y=yval))
ggp = ggp + geom_point()
ggp = ggp + facet_grid(V~H, scales="free")
ggp = ggp + labs(x="",y="")
print(ggp)

这假设(但不进行测试) df.x和df.y中的行数相同。
您不一定需要data.tables来做到这一点,但是如果您的数据集很大,并且语法更简洁,它可能会更快。
https://stackoverflow.com/questions/24810193
复制相似问题