系统参数标定

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

针孔成像模型

假设空间中物体任意一点在世界坐标系下为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);
相关推荐
YJlio6 小时前
1.7 通过 Sysinternals Live 在线运行工具:不下载也能用的“云端工具箱”
c语言·网络·python·数码相机·ios·django·iphone
光泽雨12 小时前
三维点云数据 平面度的数值含义
数码相机·smart3
格林威21 小时前
工业相机图像如何高速存入硬盘?5 种方法 + 海康/Basler/堡盟 C#/C++ 代码全解析!
c++·人工智能·数码相机·c#·视觉检测·工业相机·堡盟相机
YJlio21 小时前
1.6 使用 Streams 工具移除下载文件的 ADS 信息:把“来自互联网”的小尾巴剪掉
c语言·网络·python·数码相机·ios·django·iphone
bbbbbb4bayue2 天前
靠谱便携式条码打印机怎么选?这 3 点帮你快速锁定!
数码相机
YJlio2 天前
1.5 解压 Zip 压缩包与推荐目录结构:给 Sysinternals 找个长期“住所”
c语言·网络·python·数码相机·ios·django·iphone
YJlio2 天前
BSOD代码分析实战:从 Stop Code 到 Dump 一次定位驱动/硬件(附速查表+WinDbg+一键收集脚本
c语言·网络·stm32·单片机·嵌入式硬件·数码相机·iphone
搬砖者(视觉算法工程师)3 天前
知识科普:什么是正射影像?
人工智能·数码相机
格林威3 天前
工业相机图像一般保存为什么格式?附 海康/Basler/堡盟 C# & C++ 保存代码!
c++·人工智能·数码相机·opencv·算法·计算机视觉·c#