繁体   English   中英

OpenCV:快速矩阵计算

[英]OpenCV: fast matrix computation

我有一个nxd矩阵V=[v_1; v_2;...; v_n] V=[v_1; v_2;...; v_n] 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)的转置v_i)

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

#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;
}

希望有人可以提出更快的方法。 提前致谢。

你可以取Vt()* V

(我也花了一点时间才意识到这一点,但是如果您经过矩阵乘法,您会发现它是相同的)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM