OpenCV相机标定与3D重建(9)相机标定函数calibrateCameraRO()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

cv::calibrateCameraRO 是 OpenCV 中用于相机标定的函数,它允许固定某些点来进行更精确的标定。

函数原型

cpp 复制代码
double cv::calibrateCameraRO	
(
	InputArrayOfArrays 	objectPoints,
	InputArrayOfArrays 	imagePoints,
	Size 	imageSize,
	int 	iFixedPoint,
	InputOutputArray 	cameraMatrix,
	InputOutputArray 	distCoeffs,
	OutputArrayOfArrays 	rvecs,
	OutputArrayOfArrays 	tvecs,
	OutputArray 	newObjPoints,
	OutputArray 	stdDeviationsIntrinsics,
	OutputArray 	stdDeviationsExtrinsics,
	OutputArray 	stdDeviationsObjPoints,
	OutputArray 	perViewErrors,
	int 	flags = 0,
	TermCriteria 	criteria = TermCriteria(TermCriteria::COUNT+TermCriteria::EPS, 30, DBL_EPSILON) 
)		

参数

  • 参数objectPoints: 标志点在世界坐标系中的位置。
  • 参数imagePoints: 标志点在图像平面上的位置。
  • 参数imageSize: 图像的大小。
  • 参数iFixedPoint: 固定点的数量。
  • 参数cameraMatrix: 相机内参矩阵。
  • 参数distCoeffs: 径向畸变和切向畸变系数。
  • 参数rvecs: 每个视角的旋转向量。
  • 参数tvecs: 每个视角的平移向量。
  • 参数newObjPoints: 优化后的标志点在世界坐标系中的位置。
  • 参数stdDeviationsIntrinsics: 内参的标准偏差。
  • 参数stdDeviationsExtrinsics: 外参的标准偏差。
  • 参数stdDeviationsObjPoints: 标志点位置的标准偏差。
  • 参数perViewErrors: 每个视角的重投影误差。
  • 参数flags: 标定选项。
  • 参数criteria: 终止条件。

代码示例

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>

using namespace cv;
using namespace std;

int main()
{
    // 已知的世界坐标系中标记点的位置
    vector< vector< Point3f > > objectPoints;  // 存储所有棋盘格角点的真实坐标
    Size boardSize( 7, 5 );                    // 棋盘格的尺寸
    float squareSize = 1.0f;                   // 实际单位下的边长

    for ( int i = 0; i < boardSize.height; i++ )
    {
        for ( int j = 0; j < boardSize.width; j++ )
        {
            objectPoints.push_back( vector< Point3f >( 1, Point3f( j * squareSize, i * squareSize, 0 ) ) );
        }
    }

    // 图像中找到的标记点的位置
    vector< vector< Point2f > > imagePoints;  // 存储每个棋盘格角点的图像坐标

    // 加载图像并检测棋盘格角点
    Mat image = imread( "path_to_your_image.jpg" );
    if ( image.empty() )
    {
        cout << "Could not open or find the image!" << endl;
        return -1;
    }

    bool found = false;
    vector< Point2f > corners;
    found = findChessboardCorners( image, boardSize, corners );

    if ( found )
    {
        cornerSubPix( image, corners, Size( 11, 11 ), Size( -1, -1 ), TermCriteria( TermCriteria::EPS + TermCriteria::COUNT, 30, 0.1 ) );
        imagePoints.push_back( corners );
    }
    else
    {
        cout << "Chessboard not found in the image." << endl;
        return -1;
    }

    // 相机内参和畸变系数
    Mat cameraMatrix = Mat::eye( 3, 3, CV_64F );
    Mat distCoeffs;

    // 输出参数
    vector< Mat > rvecs, tvecs;
    Mat newObjPoints;
    Mat stdDeviationsIntrinsics, stdDeviationsExtrinsics, stdDeviationsObjPoints;
    Mat perViewErrors;

    int iFixedPoint = 0;  // 固定点数量
    int flags       = 0;  // 默认标定选项
    TermCriteria criteria( TermCriteria::COUNT + TermCriteria::EPS, 30, DBL_EPSILON );

    // 执行相机标定
    double rms = calibrateCameraRO( objectPoints, imagePoints, image.size(), iFixedPoint, cameraMatrix, distCoeffs, rvecs, tvecs, newObjPoints, stdDeviationsIntrinsics, stdDeviationsExtrinsics,
                                    stdDeviationsObjPoints, perViewErrors, flags, criteria );

    cout << "RMS re-projection error: " << rms << endl;
    cout << "Camera matrix:\n" << cameraMatrix << endl;
    cout << "Distortion coefficients:\n" << distCoeffs << endl;

    return 0;
}
相关推荐
正在走向自律1 小时前
AI数字人:繁荣背后的伦理困境与法律迷局(8/10)
人工智能·python·opencv·语音识别·ai数字人·ai伦理与法律
陈小峰_iefreer1 小时前
stone 3d v3.3.0版本发布,含时间线和连接器等新功能
3d·webgl·metaverse·cadcg
起个破名想半天了12 小时前
计算机视觉cv入门之答题卡自动批阅
人工智能·opencv·计算机视觉
鸿蒙布道师12 小时前
OpenAI为何觊觎Chrome?AI时代浏览器争夺战背后的深层逻辑
前端·人工智能·chrome·深度学习·opencv·自然语言处理·chatgpt
神奇侠202413 小时前
基于opencv和PaddleOCR识别身份证信息
opencv·paddleocr
满怀101515 小时前
【OpenCV图像处理实战】从基础操作到工业级应用
图像处理·人工智能·python·opencv·计算机视觉·编程入门
Tech Synapse16 小时前
人脸识别考勤系统实现教程:基于Face-Recognition、OpenCV与SQLite
人工智能·opencv·sqlite
子燕若水17 小时前
“Daz to Unreal”将 G8 角色(包括表情)从 daz3d 导入到 UE5。在 UE5 中,我发现使用某个表情并与闭眼混合后,上眼睑出现了问题
3d·ue5
jndingxin18 小时前
OpenCV 图形API(62)特征检测-----在图像中查找最显著的角点函数goodFeaturesToTrack()
人工智能·opencv·计算机视觉
鸿蒙布道师21 小时前
AI硬件遭遇“关税风暴“:中国科技企业如何破局?
人工智能·科技·嵌入式硬件·深度学习·神经网络·opencv·机器人