将Mat转换为Keypoint?

时间:2013-02-15 16:01:17

标签: c++ opencv type-conversion computer-vision surf

我正在将两个描述符(SurfDescriptorExtractor输出)和关键点(SurfFeatureDetector输出)写入XML文件。 在写入关键点(std :: vector)之前,转换为Mat(在此之后:convert keypoints to mat or save them to text file opencv)。因为描述符不是必需的,所以它们已经是Mat。 所以两者都保存为Mat,读也没有问题。但是当使用FlannBasedMatcher,然后使用drawMatches时,此方法会询问关键点数据。

问题是:你如何将Mat转换为Keypoint的向量,哪种方法最好?

2 个答案:

答案 0 :(得分:1)

这是opencv source code Java 中进行转换的方式,我在C ++中找不到这种转换,它可能不存在。您可能能够将其转换为C ++,它不是很复杂。

 //Code from Opencv4Android: utils/Converters.java
 public static void Mat_to_vector_KeyPoint(Mat m, List<KeyPoint> kps) {
        if (kps == null)
            throw new java.lang.IllegalArgumentException("Output List can't be null");

        int count = m.rows();
        if (CvType.CV_64FC(7) != m.type() || m.cols() != 1)
            throw new java.lang.IllegalArgumentException(
                    "CvType.CV_64FC(7) != m.type() ||  m.cols()!=1\n" + m);

        kps.clear();
        double[] buff = new double[7 * count];
        m.get(0, 0, buff);

        for (int i = 0; i < count; i++) {
            kps.add(new KeyPoint((float) buff[7 * i], (float) buff[7 * i + 1], (float) buff[7 * i + 2], (float) buff[7 * i + 3],
                    (float) buff[7 * i + 4], (int) buff[7 * i + 5], (int) buff[7 * i + 6]));
        }
    }

答案 1 :(得分:1)

通过查看OpenCV源代码(在/sodules/java/generator/src/cpp/converters.cpp下,在第185行附近)找到了这个:

void Mat_to_vector_KeyPoint(Mat& mat, vector<KeyPoint>& v_kp)
{
    v_kp.clear();
    CHECK_MAT(mat.type()==CV_32FC(7) && mat.cols==1);
    for(int i=0; i<mat.rows; i++)
    {
        Vec<float, 7> v = mat.at< Vec<float, 7> >(i,0);
        KeyPoint kp(v[0], v[1], v[2], v[3], v[4], (int)v[5], (int)v[6]);
        v_kp.push_back(kp);
    }
    return;
}

我正在使用它:

vector<KeyPoint> mat_to_keypoints(Mat* mat) {

    vector<KeyPoint>  c_keypoints;

    for ( int i = 0; i < mat->rows; i++) {
        Vec<float, 7> v = mat.at< Vec<float, 7> >(i,0);

        KeyPoint kp(v[0], v[1], v[2], v[3], v[4], (int)v[5], (int)v[6]);

        c_keypoints.push_back(kp);

    };

    return c_keypoints;

};