Как проанализировать возвращаемый результат cv::калиброватьКамера?Android

Форум для тех, кто программирует под Android
Anonymous
Как проанализировать возвращаемый результат cv::калиброватьКамера?

Сообщение Anonymous »

В соответствии с примером кода, предоставленным opencv, среднеквадратичное значение, возвращаемое калибровкойCamera, является ошибкой перепроецирования, а возврат ComputeReprojectionErrors также является ошибкой перепроецирования. Я провел эксперимент, и оба возвращенных результата в основном одинаковы.
Так зачем же вам выполнять ComputeReprojectionErrors?
Как посмотреть на взаимосвязь между rms и totalAvgErr?
rms = cv::calibrateCamera(objectPoints, imagePointsL, imageSize, cameraMatrixL, distcoeffsL, rvecsL, tvecsL, flags);

totalAvgErr = computeReprojectionErrors(objectPoints, imagePointsL, rvecsL, tvecsL, cameraMatrixL, distcoeffsL);

///////////////////////////////////////////////////////////////////////////////////////////////
static double computeReprojectionErrors( const vector& objectPoints,
const vector& imagePoints,
const vector& rvecs, const vector& tvecs,
const Mat& cameraMatrix , const Mat& distCoeffs,
vector& perViewErrors, bool fisheye)
{
vector imagePoints2;
size_t totalPoints = 0;
double totalErr = 0, err;
perViewErrors.resize(objectPoints.size());

for(size_t i = 0; i < objectPoints.size(); ++i )
{
if (fisheye)
{
fisheye::projectPoints(objectPoints, imagePoints2, rvecs, tvecs, cameraMatrix,
distCoeffs);
}
else
{
projectPoints(objectPoints, rvecs, tvecs, cameraMatrix, distCoeffs, imagePoints2);
}
err = norm(imagePoints, imagePoints2, NORM_L2);

size_t n = objectPoints.size();
perViewErrors = (float) std::sqrt(err*err/n);
totalErr += err*err;
totalPoints += n;
}

return std::sqrt(totalErr/totalPoints);
}


Подробнее здесь: https://stackoverflow.com/questions/700 ... ratecamera

Вернуться в «Android»