首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >OpenCV:快速矩阵计算

OpenCV:快速矩阵计算
EN

Stack Overflow用户
提问于 2014-09-11 20:45:55
回答 1查看 299关注 0票数 1

我有一个nxd矩阵V=[v_1; v_2;...; v_n] (;意思是新行),其中v_i1xd向量。

我想计算以下和:v_1^T*v_1 + v_2^T*v_2 + ... + v_n^T*v_n,它是dxd矩阵(v_i^Tv_i)的转置)。

目前,我使用的是For循环,如下面的代码所示,当n非常大时,这个循环并不有效(我认为是这样)。

代码语言:javascript
复制
#include <iostream>
#include <opencv2/core.hpp>
using namespace cv;
using namespace std;

int main (int argc, char * argv[])
{   
    int n=5, d=3;

    Mat V = Mat(n, d, CV_32F);
    randu(V, Scalar::all(0), Scalar::all(10));        
    cout<<V<<endl<<endl;

    Mat M = Mat::zeros(d, d, CV_32F);
    for(int i=0; i<n; i++)
    {
        M = M + V.row(i).t()*V.row(i);
    }

    cout<<M<<endl<<endl;    
    return 0;
}

希望有人能提出一个更快的方法。提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-11 21:16:23

你可以用V.t()*V

(我也花了一分钟才意识到这一点,但如果你通过矩阵乘法,你就会发现它是一样的)

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25796626

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档