1
我有一个n x p
矩阵,看起来像这样:“角化”矩阵中的每一行
n = 100
p = 10
x <- matrix(sample(c(0,1), size = p*n, replace = TRUE), n, p)
我想沿着第一维A
,其k
个项创建n x p x p
阵列是包含p x p
对角矩阵x[k,]
的元素。 R中最有效的方法是什么?我正在寻找一种使用outer
(或其他矢量化方法)的方法,而不是apply
函数之一。
解决方案使用lapply
:
A <- aperm(simplify2array(lapply(1:nrow(x), function(i) diag(x[i,]))), c(3,2,1))
我正在寻找的东西比这更有效。
感谢。