2016-03-25 3 views
1

calibrateCameraを使用しますが、calibrateCameraを使用するとエラーが発生します。出力はそれほど役に立ちません。findChessboardCornersとcalibrateCameraの使い方は?

OpenCV Error: Assertion failed (i < 0) in cv::_OutputArray::create

static const Size patterSize(8, 6); 
auto image = imread("x.jpg", IMREAD_GRAYSCALE); 

Mat corners; 
auto found = findChessboardCorners(image, patterSize, corners); 

//constructing objectPoints 
vector<vector<Vec3f>> objectPoints; 
objectPoints.push_back(vector<Vec3f>()); 
for (int row = 0; row < patterSize.height; row++) { 
    for (int col = 0; col < patterSize.width; col++) { 
     objectPoints.at(0).push_back(Vec3f(row, col, 0)); 
    } 
} 

vector<vector<Vec2f>> imagePoints; 
imagePoints.push_back(vector<Vec2f>()); 
for (int row = 0; row < patterSize.height; row++) { 
    for (int col = 0; col < patterSize.width; col++) { 
     int num = row*patterSize.width + col; 
     imagePoints.at(0).push_back(corners.at<Vec2f>(num, 0)); 
    } 
} 

Mat cameraMatrix, distMatrix, rvecs, tvecs; 

calibrateCamera(objectPoints, imagePoints, Size(image.size().width, image.size().height), cameraMatrix, distMatrix, rvecs, tvecs); 

答えて

1

rvecs, tvecsのdeclerationはvector<Mat>いうよりMatする必要があり、その後、すべてが正常になります。詳細については、3calibration.cppをご覧ください。

+0

しかし、これは解決策だと思います。今は 'findChessboardCorners'とは何の関係もないことに気付きました。なぜそれを答えにしておきませんか? @IwillnotexistIdonotexist – Zen

+0

ああ、それはあなたの問題を解決しましたか?私はその後、私のコメントを吹くことができます。私はまた、あなた自身の答えを受け入れたものとしてマークしたいので、これが解決策であることは明らかです。 –