Ошибки с функцией стереокалибровки в OpenCV

Я пытаюсь откалибровать вывод трехмерной камеры panasonic z10000, преобразованной в два тестовых файла 640x360px mp4.

-Я больше дизайнер, чем программист (у меня в колледже не было никаких предметов по математике), поэтому, пожалуйста, извините за некоторые ошибки supid

Я думаю, что мой код выглядит хорошо, но я не получаю хороших результатов в процессе калибровки, ошибка проецирования SterecoCalibrate составляет около 6-20, но она должна быть < 0,3 (я читал здесь)

Я предполагаю, что я делаю что-то не так с imagePoints и objectPoints - но я не могу понять это.

После нахождения шахматных углов я освобождаю видеокадр, чтобы перезагрузить его после калибровки

Вся программа (переназначение, disparitymap) работает, но результаты плохие.

//Länge des Vektors zuweisen anhand der Bildpunkte
vector<Point3f> obj;
for(int j=0;j < (Chess_X*Chess_Y);j++)
    obj.push_back(Point3f(j/Chess_X, j%Chess_Y, 0.0f));

//Schleife für Frame Wiedergabe
for(int counterLP= 0; Chess_Found< Chess_Count; counterLP++)
{
    //Übertrage Frame auf Matrix
    capRight>>rMat;
    capLeft>>lMat;

    //Prüfe auf Side by Side Video
    if(vid_input==2 || vid_input==3)
    {
        //Übertrage ROI auf Matrix
        lMat= roi( roiLeft);
        rMat= roi( roiRight);
    }

    //Ausgabe
    //cout<<rMat.cols<<"r"<<rMat.rows<<"\n";
    //cout<<lMat.cols<<"l"<<lMat.rows<<"\n";


    //Farben Konvertieren
    cvtColor( lMat, lMat_grey, CV_RGB2GRAY);
    cvtColor( rMat, rMat_grey, CV_RGB2GRAY);

    //Überprüfe jeden fünften Frame
    if(counterLP%5==0)
    {
        //Suche Schachbrettmuster auf Matrix
        successLeft= findChessboardCorners( lMat_grey, Chess_size, cornersLeft, CALIB_CB_ADAPTIVE_THRESH);
        successRight= findChessboardCorners( rMat_grey, Chess_size, cornersRight, CALIB_CB_ADAPTIVE_THRESH);

        //Wenn Schachbrettmuster gefunden wurde
        if( successLeft && successRight)
        {

            //Muster genauer bestimmen
            cornerSubPix( lMat_grey, cornersLeft, Size( 5, 5),Size( -1, -1),TermCriteria( CV_TERMCRIT_ITER + CV_TERMCRIT_EPS, 50, 0.01 ));
            cornerSubPix( rMat_grey, cornersRight, Size( 5, 5),Size( -1, -1),TermCriteria( CV_TERMCRIT_ITER + CV_TERMCRIT_EPS, 50, 0.01 ));

            //Zeichne Schachbrettmuster
            drawChessboardCorners( lMat, Chess_size, Mat(cornersLeft), successLeft);
            drawChessboardCorners( rMat, Chess_size, Mat(cornersRight), successRight);

            //
            imagePointsLeft.push_back(cornersLeft);
            imagePointsRight.push_back(cornersRight);

            objectPoints.push_back(obj);
            cout << "Punkte gespeichert\n";

            //Zeige Farbbild
            imshow( "Left", lMat);
            imshow( "Right", rMat);

            //Erfolgreich
            Chess_Found++;
            //cout<< Chess_Found << " Muster gefunden!\n";

            //Sicherheitsprüfung
            successLeft= false;
            successRight= false;
        }
    }
    else
    {
        //Zeige graues Bild
        imshow( "Left", lMat_grey);
        imshow( "Right", rMat_grey);
    }

    //33ms verzögerung
    if (waitKey(30) >= 0)
        break;
}

//Schließe Streams
capLeft.release();
capRight.release();

//Schließe Fenster
destroyAllWindows();

//Erzeuge identifizierte Kamera Matrix
Mat camMatLeft = Mat::eye(3, 3, CV_64FC1);
Mat camMatRight = Mat::eye(3, 3, CV_64FC1);

//Erzeuge Distranzkoeffizienten
Mat distCoLeft;
Mat distCoRight;

//Erzeuge Rotationsvektor
Mat rvecs;

//Erzeuge Verschiebungsvektor
Mat tvecs;

//Erzeuge Output essential Matrix
Mat essMat;

//Erzeuge Output fundamental Matrix
Mat funMat;

//Starte Kalibrierung
cout << "Starte Kalibrierung\n";



//Kalibrierung
double s = stereoCalibrate(objectPoints, imagePointsLeft, imagePointsRight, camMatLeft, distCoLeft, camMatRight, distCoRight, Size(640,360), rvecs,  tvecs, essMat, funMat, cvTermCriteria(CV_TERMCRIT_ITER+CV_TERMCRIT_EPS, 100, 1e-5),CV_CALIB_FIX_ASPECT_RATIO+CV_CALIB_ZERO_TANGENT_DIST + CV_CALIB_SAME_FOCAL_LENGTH);
cout <<"Fehler: " <<s<<endl;

Спасибо

1 ответ

cornerSubPix() может привести к худшим результатам, чем обычный findChessboardCorners(), попробуйте не использовать это. Вы должны увидеть найденные углы и то, насколько они соответствуют изображению, в окнах изображений.

кроме этого, ваш код выглядит нормально.

Другие вопросы по тегам