假设我有一个数值型的矩阵
:
set.seed(1)
mat <- matrix(rnorm(1000), ncol = 100)
我希望生成所有由mat
中所有唯一向量对的元素乘积得到的向量。
我们如何改进下面的代码:
all.pairs <- t(combn(1:ncol(mat), 2))
res <-
do.call(cbind,
lapply(1:nrow(all.pairs),
function(p) mat[, all.pairs[p, 1]] * mat[, all.pairs[p, 2]]))