系统参数标定

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

针孔成像模型

假设空间中物体任意一点在世界坐标系下为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);
相关推荐
私人珍藏库1 分钟前
[Android] 红妆相机-拍照美颜图片美化工具
android·数码相机·app·软件·多功能
疯狂的维修1 天前
2.5D双目全景相机引导抓取调试
数码相机
2601_957418801 天前
相机USB有线连接技术讨论:PTP与MTP协议的原理与选择困境
数码相机
尤老师FPGA2 天前
威三学社-全新课程发布直播6月16日晚8点,B站直播间
数码相机
伶俜662 天前
鸿蒙实战(二) ArkUI AI 相机:从零实现实时滤镜与人脸贴纸
人工智能·数码相机
暂未成功人士!2 天前
雷达的标定 --- 雷达到相机(Lidar2Cam)标定 和 雷达到本体(Lidar2Baselink)标定的相关原理以及实现步骤
数码相机·雷达·坐标转换·标定·外参
互联网散修3 天前
鸿蒙实战:从零实现自定义相机(下)——填平预览拉伸、比例错乱、缩略图消失的六大坑
数码相机·华为·harmonyos
初级炼丹师(爱说实话版)3 天前
RealSense D435i 驱动安装梳理(Jetson Orin + JetPack 6.1)
数码相机
苏映视官方账号3 天前
精品案例丨方寸之间,“微” 毫毕现 —— 圆刀机高精度检测工艺优化实例
人工智能·数码相机·视觉检测·制造
互联网散修3 天前
鸿蒙实战:从零实现自定义相机(上)——架构设计与核心实现
数码相机·华为·harmonyos·自定义相机