Opencv Mat效率由直角三角形线性化

时间:2017-12-24 21:15:01

标签: opencv mat

如何通过直角三角形将Mat(对称矩阵)线性化为一行。 例如,当我有:

0aabbb
b0aaaa
ba0bba
bac0aa
aaaa0c
abcab0

然后我得到:

aabbbaaaabbaaac

这样的事情:

...
template<class T>
Mat SSMJ::triangleLinearized(Mat mat){
    int c = mat.cols;
    Mat row = Mat(1, ((c*c)-c)/2, mat.type());
    int i = 0;
    for(int y = 1; y < mat.rows; y++)
    for(int x = y; x < mat.cols; x++) {
        row.at<T>(i)=mat.at<T>(y, x);
        i++;
    }
    return row;
}
...

1 个答案:

答案 0 :(得分:0)

由于mat中的数据只是存储在row.data中的1d数组,因此您可以随心所欲地执行任何操作。我不认为你会发现任何更特殊的东西(没有使用矢量化方法),而不仅仅是从这个数组中复制。

int rows = 6;   
char data[] = { 0,1,2,3,4,5,
                0,1,2,3,4,5,
                0,1,2,3,4,5,
                0,1,2,3,4,5,
                0,1,2,3,4,5};
char result[100];
int offset = 0;
for (int i = 0; i < 5; offset += 5-i, i++) {
    memcpy(&result[offset] , &data[rows * i + i + 1], 5 - i);
}

或者使用opencv Mat,它将是

int rows = mat.cols;
char result[100];   // you can calculate how much data u need
int offset = 0;
for (int i = 0; i < 5; offset += 5-i, i++) {
    memcpy(&result[offset] , &mat.data[rows * i + i + 1], 5 - i);
}
Mat resultMat(1, offset, result);