基于2D标靶的摄像机标定方法

简介: 基于2D标靶的摄像机标定方法

1摄像机标定步骤

基于2D标靶的平面标定方法,标定过程分为以下三步:①计算标靶平面与图像平面之间的映射矩阵②求解摄像机参数矩阵3求解左右两摄像机之间的相对位置关系,即求解旋转矩阵和平移矩阵

2 各标定步骤实现方法

计算标靶平面与图像平面之间的映射矩阵,计算映射矩阵时不考虑摄像机的成像模型,只是根据平面标靶坐标点和对应的图像坐标点的数据,利用最小二乘方法计算得到

2.1求解摄像机参数矩阵

由计算得到的标靶平面和图像平面的映射矩阵得到与摄像机内部参数相关的基本方程关系,求解方程得到摄像机内部参数,考虑镜头的畸变模型,将上述解方程获

得的内部参数作为初值,进行非线性优化搜索,从而计算出所有参数的准确值

2.3 求解左右两摄像机之间的相对位置关系

设双目视觉系统左右摄像机的外部参数分别为Rl,Tl,与Rr, Tr,,即Rl, Tl表示左摄像机与世界坐标系的相对位置,Rr, Tr表示右摄像机与世界坐标系的相对位置。因此,对于空间任意一点,如果在世界坐标系、左摄像机坐标系和右摄像机坐标系中的坐标分别为Xw,, Xl , Xr,则有:Xl=RlXw+Tl ;Xr=RrXw+Tr.因此,两台摄像机之间的相对几何关系可以由下式表示R=RrRl-1;T=Tr- RrRl-1Tl

在实际标定过程中,由标定靶对两台摄像机同时进行摄像标定,以分别获得两台摄像机的内、外参数,从而不仅可以标定出摄像机的内部参数,还可以同时标定出双目视觉系统的结构参数。由单摄像机标定过程可以知道,标定靶每变换一个位置就可以得到一组摄像机外参数:Rr,Tr,与Rl, Tl,因此,由公式R=RrRl-1 ;T=Tr- RrRl-1Tl,可以得到一组结构参数R和T

3 cvCalibrateCamera2函数的内部过程


1求出内参数矩阵:

(1)使用cvFindHomography函数计算出每一张图像得到的单应性矩阵;将图像的中心像素坐标作为初始的u0和v0,利用M-TM-1=B求出含有fx和fy的b向量。

(2)对于每一个单应性矩阵H先进行归一化处理,然后利用 和 两个条件列出等式,最后列出2 N(N为图像的个数)个等式。

(3)利用最小一乘原理,采用求SVD奇异值分解和伪逆矩阵的方法(cvSVD和cvSVB kSb函数)求解参数.fx和.fy,最终得到包含4个参数的摄像机内部参数矩阵M.


2对每一幅图像求出外部参数矩阵

(1)先通过己经求出的内参数矩阵和己知的像点坐标(在像素坐标系下),利用(2),(3)两式求出考虑了畸变因素的物理坐标系下的像点坐标xp和yp、

(2)通过 的关系,因为均为己知,利用求单应性矩阵的方法从而

求出旋转向量和平移向量的初始值俐用正交的性质进行推导)。

(3)通过高斯一牛顿迭代法迭代次数为20次)对旋转向量和平移向量进行精炼。每次迭代的时候,先通过投影函数cvProjectPoints2,将所有的物理世界坐标在考虑畸变、内部参数、外部参数的情况下进行 再投影,同时求出图像上关于旋转向量和平移向量部分的雅可比导数矩阵,再通过SVD分解和伪逆矩阵的求解计算出偏差值,与初始值相加以后作为下一次迭代的初始值。


3对所有的参数进行全局的优化

对所有的参数进行全局的优化,同样采用迭代法对所有的参数进行精炼褪代次数为30次),每次迭代的时候,先通过投影函数cvProjectPoints2,将所有的物理世界坐标在考虑畸变、内部参数、外部参数的情况下进行再投影,同时求出图像上关于旋转向量、平移向量、 ,  ,  , 和所有畸变系数k1,k2,p1,p,的雅可比导数矩阵,再通过SVD分解和伪逆矩阵的求解计算出偏差值,与初始值相加以后作为下一次迭代的初始值。


相关文章
|
3月前
|
自然语言处理 算法 数据挖掘
长绳方法
进一步提高语言模型(LLM)的性能,通过扩展其上下文窗口至超过200万个标记,从而实现更深入的语境理解。本文将对这一成果进行深入解读,探讨其意义和潜在应用。
23 2
|
3月前
|
Java 编译器 C语言
方法的使用
方法的使用
32 1
是的方法
第三份阿发顺大丰阿萨德
|
Java C语言
|
SQL 数据库
SqlCommand.ExecuteNonQuery 方法
SqlCommand的一个类,用于包含update、insert、delete、select的Transact-sql 语句中来修改数据库中的数据,并返回结果。
C#中的方法
C#中的方法
67 0
|
C语言 C++
求公因数的方法(C/C++)
求公因数的方法(C/C++)
289 0
求公因数的方法(C/C++)
|
存储 算法 搜索推荐
常用的外部排序方法
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_34173549/article/details/81158566 定义问题       外部排序指的是大文件的排序,即待排序的记录存储在外存储器上,待排序的文件无法一次装入内存,需要在内存和外部存储器之间进行多次数据交换,以达到排序整个文件的目的。
1790 0
|
数据库 Go
统计数据库大小的方法
原文:统计数据库大小的方法     一台服务器上所有数据库(也可能是部分数据库)的大小是我们经常需要了解的,它不仅能让我们知道目前数据库使用磁盘的比例, 而且定期搜集这些信息,还能了解数据库一段时间的数据增量,更为常用的是在做数据迁移和升级时,方便规划新服务器磁盘容量。
1288 0