【发布时间】:2010-11-28 12:41:35
【问题描述】:
假设我有一个矩阵x,它包含 10 行和 2 列。我想生成一个新矩阵 M,其中包含来自 x 的每一对唯一行 - 即一个具有 55 行和 4 列的新矩阵。
例如,
x <- matrix (nrow=10, ncol=2, 1:20)
M <- data.frame(matrix(ncol=4, nrow=55))
k <- 1
for (i in 1:nrow(x))
for (j in i:nrow(x))
{
M[k,] <- unlist(cbind (x[i,], x[j,]))
k <- k + 1
}
所以,x 是:
[,1] [,2]
[1,] 1 11
[2,] 2 12
[3,] 3 13
[4,] 4 14
[5,] 5 15
[6,] 6 16
[7,] 7 17
[8,] 8 18
[9,] 9 19
[10,] 10 20
然后M 有 4 列,前两列是来自 x 的一行,接下来的两列是来自 x 的另一行:
> head(M,10)
X1 X2 X3 X4
1 1 11 1 11
2 1 11 2 12
3 1 11 3 13
4 1 11 4 14
5 1 11 5 15
6 1 11 6 16
7 1 11 7 17
8 1 11 8 18
9 1 11 9 19
10 1 11 10 20
在 R 中是否有更快或更简单(或两者兼有)的方法?
【问题讨论】: