1

我写了一个校准代码如下:

int numBoards = 20;
int numCornersHor=6;
int numCornersVer=9;
int numSquares = numCornersHor * numCornersVer;
cv::Size board_sz = cv::Size(numCornersHor, numCornersVer);

std::vector<std::vector<cv::Point3f> > object_points;
std::vector<std::vector<cv::Point2f> > image_points;
std::vector<cv::Point2f> corners;
std::vector<cv::Point3f> obj;
    for(int j=0;j<numSquares;j++)
        obj.push_back(cv::Point3f(j/numCornersHor, j%numCornersHor, 0.0f));

int successes=0;

初始化有用变量后,我从网络摄像头获取帧并将其存储在缓冲区中。

    while(successes<numBoards)
    {        
        unsigned char* buffer=eyeCamera->getFrame();
        cv::Mat rawImg=cv::Mat(cv::Size(widthCam,heightCam),CV_8UC4, buffer,cv::Mat::AUTO_STEP);
        cv::Mat grayImg;
        cv::cvtColor(rawImg,grayImg,CV_BGR2GRAY);

        bool found = findChessboardCorners(rawImg, board_sz, corners,
                                           CV_CALIB_CB_ADAPTIVE_THRESH | CV_CALIB_CB_FILTER_QUADS);
        if(found)
        {
            cv::cornerSubPix(grayImg, corners, cv::Size(11, 11), cv::Size(-1, -1),
                             cv::TermCriteria(CV_TERMCRIT_EPS | CV_TERMCRIT_ITER, 30, 1.1));
            cv::drawChessboardCorners(grayImg, board_sz, corners, found);
        }

        cv::imshow("win2", grayImg);

到目前为止一切都很好。我显示了 grayImg 和棋盘角。

        int key = cv::waitKey(1);
        if(key==27)
            return;

        if(key==' ' && found!=0)
        {
          image_points.push_back(corners);
          object_points.push_back(obj);

          successes++;

          if(successes>=numBoards)
              break;
        }

    }

    cv::Mat intrinsic = cv::Mat(3, 3, CV_64F);
    cv::Mat distCoeffs= cv::Mat(8, 1, CV_64F);
    std::vector<cv::Mat> rvecs;
    std::vector<cv::Mat> tvecs;
    intrinsic.at<double>(0,0) = 1.0;

    int widthCam=640; 
    int heightCam=480;

object_points 和 image_points 填充了 54 个元素 ~ 9 * 6

    cv::calibrateCamera(object_points, image_points, cv::Size(widthCam,heightCam), intrinsic, distCoeffs, rvecs, tvecs);

我正在使用 Qt 创建者。调用最后一行时总是出现运行时错误:calibrateCamera()

编辑:我尝试了相同的代码,cvCalibrateCamera2但又遇到了同样的错误。我提供opencv Exeption:

OpenCV error: Bad argument (the output array of translation vectors must be 3-channel
1xn or nx1 array or 1-channel nx3 array, where n is the bumber of views) in
cvCalibrateCamera2, file F:\OpenCV\opencv\modules\calib3d\src\calibration.cpp,line 1506
terminate called after throwing an instance of 'cv::Exeption'

我正在使用 10 个快照,我定义的 rvec 和 tvec 如下:

CvMat* rvec  = cvCreateMat(10,3,CV_32FC1);
CvMat* tvec  = cvCreateMat(10,3,CV_32FC1);

谁能帮我解决这个错误?

谢谢。

4

2 回答 2

0

好的,现在在我的系统上本地尝试了这个,结果发现 rVecs 和 tVecs 的定义实际上与我预期的不同。

CvMat* rVecs = cvCreateMat( 1, 1, CV_32FC3 );
CvMat* tVecs = cvCreateMat( 1, 1, CV_32FC3 );

为我完成了这项工作。

于 2012-10-17T21:52:39.897 回答
0

我想知道是否 CvMat* tvec = cvCreateMat(3,10,CV_32FC1); 会有所帮助。

还有,试试 CvMat* tvec = cvCreateMat(1,10,CV_32FC3);

于 2017-05-09T12:11:05.673 回答