java - 断言失败。 convertPointsFromHomogenous

标签 java opencv

A 在执行我的代码时出现以下错误:

Caused by: CvException [org.opencv.core.CvException: cv::Exception: /home/reports/ci/slave_desktop/50-SDK/opencv/modules/calib3d/src/fundam.cpp:1152: error: (-215) npoints >= 0 && (src.depth() == CV_32F || src.depth() == CV_32S) in function void cv::convertPointsFromHomogeneous(cv::InputArray, cv::OutputArray)

这是我使用的代码:

    Mat res = new Mat(); // Result mat for triangulation

    Mat P1 = new Mat(3,4,CvType.CV_32F);
    double[] diagVal = {1,0,0,0,
                        0,1,0,0,
                        0,0,1,0};       
    P1.put(0, 0, diagVal);



    int[] max = new int[4];
    for(int i = 0; i < max.length; i++)
        max[i] = 0;

    Mat P2 = buildCameraMatrix(R1, T1);     
    Calib3d.triangulatePoints(P1, P2, objLeft, objRight, res);

TriangulatePoints 产生 CV_32F 类型的 (914,4) 垫(res.type() == 5 为真)。

我做错了什么?

最佳答案

我改用下面的转换函数:

private Mat convertPointsFromHomogeneous(Mat src) {
    Mat ret = new Mat(3, src.cols(), src.type());
    double[] data = new double[4];
    for (int i = 0; i < src.cols(); i++) {
        src.col(i).get(0, 0, data);
        ret.col(i).put(0, 0, data[0] / data[3], data[1] / data[3], data[2] / data[3]);
    }
    return ret;
}

关于java - 断言失败。 convertPointsFromHomogenous,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23290000/

相关文章:

java - 使用hibernate创建用户表名

java - 在 doFinal() 中使用二进制数据 - javax.crypto.Cipher

java - OpenCV - 在视频和图像上查找黑板边缘

c++ - cvFindContours 是如何工作的?

c++ - OpenCV imread 外来字符

java - 如何通过 .bat 文件运行 java 应用程序

java - 如何向 JFace ErrorDialog 添加按钮

java - 通用类型不匹配

c++ - 用于增强现实的 OpenCV 相机内在矩阵到 Ogre 投影矩阵

c# - Emgu cv 将 CircleF 保存为图像