有效地填充具有相同对象的列表

时间:2013-07-21 10:31:43

标签: r list memory-management

假设我有一些对象(任何对象),例如:

X <- array(NA,dim=c(2,2))

我也有一些清单:

L <- list()

我希望L[[1]]L[[2]]L[[3]],...,L[[100]],...,L[[1000]]全部拥有对象{{1 }} 在里面。也就是说,如果我输入控制台X,它将返回L[[i]],其中我在{1,2,...,1000}。

如何在不依赖Xfor loop的情况下有效地执行此操作?

2 个答案:

答案 0 :(得分:5)

使用replicate即使它仍然是一种循环解决方案:

L <- replicate(1000,X,simplify=FALSE)

编辑对2个解决方案进行基准测试:

X <- array(NA,dim=c(2,2))
library(microbenchmark)
microbenchmark( rep(list(X), 10000),
               replicate(10000,X,simplify=FALSE))

                              expr      min       lq    median        uq      max neval
                  rep(list(X), 10000) 1.743070 2.114173  3.088678  5.178768 25.62722   100
replicate(10000, X, simplify = FALSE) 5.977105 7.573593 10.557783 13.647407 80.69774   100

rep快5倍。我猜是因为replicate将在每次迭代时评估表达式。

答案 1 :(得分:5)

列出1并复制它。

L <- rep(list(x), 1000)