r - 将相关的嵌套列表元素向量组合成矩阵

标签 r list

我有一个列表,其中每个列表元素本身都包含另一个带有多个名称对象的列表。这些命名对象中的每一个都是相同长度的向量。我的目标是通过连接向量有效地将相关对象(同名对象)组合成一个矩阵。

这是我正在使用的结构类型的示例。但是,在当前的应用程序中,它来自 mclapply,因为它是一个并行化的多级模型,我认为没有办法返回列表列表。

> test=lapply(1:2,function(x){out = list(); out$t=rnorm(3)+x; out$p =rnorm(3)+ x+.1; return(out)})
> test
[[1]]
[[1]]$t
[1] 0.5950165 0.8827352 0.5614947

[[1]]$p
[1] 2.6144102 1.9688743 0.6241944


[[2]]
[[2]]$t
[1] 2.562030 1.832571 3.018756

[[2]]$p
[1] 1.7431969 0.5305784 2.6935106

这是一种粗略的方法来完成我想要的
> t.matrix = cbind(test[[1]]$t,test[[2]]$t)
> t.matrix
           [,1]     [,2]
[1,]  2.2094525 2.634907
[2,] -0.2822453 2.440666
[3,]  1.1704518 2.483424

但相反,我希望能够为一个很长的列表(大约 100 万个元素)执行此操作,而我当前的解决方案无法扩展。

我想我可以使用 for 循环,但似乎必须有更好的方法来巧妙地使用 reduce 或 unlist 或 sapply 或类似的东西。

最佳答案

test <- lapply(1:4, function(x) { 
          out = list(); out$t=rnorm(3)+x; out$p =rnorm(3)+ x+.1; return(out)})

do.call(cbind, lapply(test, function(X) X[["t"]]))
## do.call(cbind, lapply(test, "[[", "t"))          ## Or, equivalently 
#           [,1]      [,2]     [,3]     [,4] 
# [1,] 0.7382887 0.9248296 4.205222 5.847823 
# [2,] 3.0321069 3.6806652 3.324739 3.695195 
# [3,] 2.3611483 1.9305901 1.574586 4.287534 

或者,同时处理两组列表元素:
elems <- c("t", "p")
sapply(elems, function(E) {
     do.call(cbind,
             lapply(test, function(X) {
                 X[[E]]
             }))
}, simplify=FALSE)
# $t
#           [,1]       [,2]     [,3]     [,4]
# [1,] 1.9226614 0.66463844 2.558517 2.743381
# [2,] 3.0026400 0.03238983 2.195404 3.824127
# [3,] 0.9371057 3.54638107 2.968717 2.434471
# 
# $p
#           [,1]     [,2]     [,3]     [,4]
# [1,] 0.8544413 2.942780 4.693698 4.158212
# [2,] 0.7172070 2.381438 4.869630 3.503361
# [3,] 3.1369674 2.464447 2.484968 3.626174

关于r - 将相关的嵌套列表元素向量组合成矩阵,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14839523/

相关文章:

r - 局部变量的用法

r - 如何在 R-Markdown 的 R block 中使用 LaTeX 代码?

r - 使用 iGraph 中的 ego 函数生成连接 Node 列表以通过函数进行解析

r - ggplot2 和 gganimate : How to make an animated line change colors depending on Y axis values

css - 使用 CSS 使 <li> 适合 <ul> 的宽度

java - Hibernate 多值关联最佳实践

java - 转换一个类相同的对象

r - 并行读/写文件是个好主意吗?

c# - 如何清除嵌套 List<T> 的值?

python - 查找每次删除不同元素的列表的所有组合