本文介绍了矩阵按行相乘的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

有什么方法可以更快地计算矩阵c吗?

Is there any way to calculate matrix c faster?

a=matrix(runif(10),2,5)
b=matrix(runif(15),3,5)

c=matrix(,nrow(a)*nrow(b),5)
k=0
for(i in 1:nrow(a)){
  for(j in 1:nrow(b)){
    k=k+1
    c[k,]=a[i,]*b[j,]
  }
}

推荐答案

这是我的版本:

c1 =  a[ rep(1:nrow(a), each = nrow(b)), ] *
      b[ rep(1:nrow(b), times = nrow(a)), ];
all.equal(c, c1);

> TRUE

这篇关于矩阵按行相乘的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

09-15 04:52