系统参数标定

前言:通过该篇文章,重新梳理,理解系统标定参数的含义,及标定过程

针孔成像模型

假设空间中物体任意一点在世界坐标系下为p(x,y,z) ,在摄像机成像平面上的投影坐标为 (u,v),则实际上,这一转换过程可以描述为:

其中:K 为缩放因子;[R|t] 表示外部参数:

R是一个三行三列的旋转矩阵,而t代表了一个平移向量。它们共同表示了三维世界中点到相机坐标系统中的关系。接着,相机本身的内部参数矩阵A会将坐标映射到相机的二维成像平面上,最终得到世界相应的二维图像坐标。

其中,fu和 fv分别表示相机在 u 轴和v 轴方向上的有效焦距;(u,v)则是主点坐标,即相机光轴与图像平面的交点。

常见的系统参数标定方法是张正友方法,该方法利用多个不同角度拍摄的棋盘格图像,通过单应性矩阵(Homography Matrix)估计摄像机的内参、外参和畸变参数,并采用非线性优化方法提升精度。

系统标定用来确定系统的内外参数,其中内参描述相机内部属性的参数,包括焦距、主点(光学中心)坐标、畸变系数等。输出值有焦距(fu,fv),(u,v),径向畸变参数k1,k2,k3;切向畸变系数 p1,p2; 外参描述相机在世界坐标系中的位置和姿态的参数,通常包括旋转矩阵和平移向量。

标定板用来辅助系统标定,通常假设标定点平面z=0;以左上角第一个圆心为世界坐标系原点位置。系统外参确认了相机坐标系与世界坐标系的对应关系,其两个坐标系单位都还是mm。

坐标系转换

% 世界 -> 相机

points_cam = (R * points_world.' + t); % 3×N

从相机坐标系到像素坐标系:

在单目结构光系统中,当已知相机和投影仪在同一世界坐标系外参时,就可以通过下式代码得到两个设备的相对关系矩阵。

matlab 复制代码
% ================== 已知外参 ==================
% 相机外参 (world -> camera)
rvec_cam = [2.1719   , 2.1701 ,  -0.0352];
tvec_cam = [-72.6580;
 -125.2286;
  422.8802];  % mm

% 投影仪外参 (world -> projector)
rvec_proj = [   -2.0823  , -2.1271  ,  0.0308];
tvec_proj = [ -132.9652;
 -231.0133;
  502.7903]; % mm

% ================== 计算旋转矩阵 ==================
R_cam = vision.internal.calibration.rodriguesVectorToMatrix(rvec_cam);
R_proj = vision.internal.calibration.rodriguesVectorToMatrix(rvec_proj);

% ================== 计算 projector w.r.t camera ==================
% R_pc = R_proj * R_cam'
R_pc = R_proj * R_cam';

% T_pc = -R_pc * tvec_cam + tvec_proj
T_pc = -R_pc * tvec_cam + tvec_proj;

% ================== 计算 camera w.r.t projector ==================
% 旋转矩阵取转置
R_cp = R_pc';

% 平移向量逆变换
T_cp = -R_pc' * T_pc;

% Rodrigues 旋转向量
rvec_cp = vision.internal.calibration.rodriguesMatrixToVector(R_cp);

% ================== 输出 ==================
disp('R_ex (camera w.r.t projector):');
disp(R_cp);

disp('T_ex (mm):');
disp(T_cp);

disp('rvec_ex (rad):');
disp(rvec_cp);
相关推荐
dapei371 天前
Cameralink采集卡软件ESpeedGrab使用讲解:9直方图拉伸
数码相机·opencv·计算机视觉
番茄炒西红柿炒洋柿子1 天前
OpenCV实现相机畸变校准
人工智能·数码相机·opencv
搬砖者(视觉算法工程师)1 天前
计算机视觉与计算摄影测量学第二讲:相机基础与光的传播
数码相机·三维重建
等故意2 天前
C# 工业视觉上位机开发心得分享
开发语言·数码相机·c#·视觉检测
生活观察站2 天前
中星微端侧芯片,赋能多行业智能化转型落地
数码相机·学习
kyle~2 天前
机器视觉---九大照明方式
数码相机
2601_957418802 天前
Android 手机如何通过 PTP / MTP 连接单反相机?源码级方案分享
android·数码相机·智能手机
LingLong_roar3 天前
相机软件开发常问业务相关面试题
数码相机
线束线缆组件品替网3 天前
Amphenol ICC RJE1Y33610162401解析:工业网络线束为何越来越重要?
运维·服务器·网络·数码相机·智能路由器·电脑·智能音箱
爱滑雪的码农4 天前
详细说说Three.js三维坐标系和光源对物体表面影响
数码相机