1

我想将列表中的所有矩阵加在一起。这是我正在尝试做的一个例子:

## sets up the problem
m1 <- matrix(0,nrow=9,ncol=4)
row.pres <- lapply(1:4,function(x) seq(x,x+2))
m1.l <- lapply(1:4,function(y) {m1[row.pres[[y]],y] <- 1
                        return(m1)}
       )

我想将 的所有元素相加,m1.l得出一个与它们中的每一个具有相同维度的单个矩阵。这是我的解决方案:

test <- lapply(1:4,function(x) paste("m1.l[[",x,"]]",sep=''))
add.all <- paste(test,collapse="+")
eval(parse(text=add.all))

但一定有更好的办法!也许通过do.call什么?

4

1 回答 1

4
 > Reduce("+", m1.l)
      [,1] [,2] [,3] [,4]
 [1,]    1    0    0    0
 [2,]    1    1    0    0
 [3,]    1    1    1    0
 [4,]    0    1    1    1
 [5,]    0    0    1    1
 [6,]    0    0    0    1
 [7,]    0    0    0    0
 [8,]    0    0    0    0
 [9,]    0    0    0    0

这会将前两个相加,然后将结果和第三个矩阵相加。然后它将该结果添加到第四个矩阵等,直到它通过整个列表工作。

于 2012-12-11T19:22:40.503 回答