将堆叠矩阵转换为块矩阵。

3

我目前的数据是一系列叠放在一起的3x3矩阵。结构看起来像这样(以下示例为3个矩阵,但我的实际数据要大得多/更长):

0   1   1
0   0   1
1   1   0
0   1   1
1   0   1
1   0   0
0   1   1
0   0   1
1   1   0

使用R,我希望它看起来像这样:

0   1   1                       
0   0   1                       
1   1   0                       
            0   1   1           
            1   0   1           
            1   0   0           
                        0   1   1
                        0   0   1
                        1   1   0
2个回答

2
我们通过使用由“gl”创建的分组索引将矩阵拆分为矩阵列表,并应用“Matrix”中的“bdiag”来获取块对角稀疏矩阵。
library(Matrix)
m2 <- bdiag(lapply(split(d1, as.integer(gl(nrow(d1), 3, nrow(d1)))), as.matrix))
m2
#9 x 9 sparse Matrix of class "dgCMatrix"
#                       
# [1,] . 1 1 . . . . . .
# [2,] . . 1 . . . . . .
# [3,] 1 1 . . . . . . .
# [4,] . . . . 1 1 . . .
# [5,] . . . 1 . 1 . . .
# [6,] . . . 1 . . . . .
# [7,] . . . . . . . 1 1
# [8,] . . . . . . . . 1
# [9,] . . . . . . 1 1 .

使用as.matrix函数将其转换为常规矩阵。

as.matrix(m2)

数据

m1 <- structure(c(0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 
       1, 1, 1, 0, 1, 1, 0, 1, 1, 0), .Dim = c(9L, 3L))
d1 <- as.data.frame(m1)

1
你可以使用 split 和一个变量来分组每个包含3行的集合。
split(as.data.frame(mat), ceiling(seq_len(nrow(mat) / 3)))

数据:

mat <- matrix(sample(0:1, 9*3, replace=TRUE), ncol=3)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接