基于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分解和伪逆矩阵的求解计算出偏差值,与初始值相加以后作为下一次迭代的初始值。


相关文章
|
1月前
|
缓存 前端开发 JavaScript
componentWillMount()方法有什么用
componentWillMount() 是 React 组件生命周期中的一个方法,在组件首次渲染之前调用。可以用来进行初始化操作,如设置状态或加载数据,但不建议在此方法中执行复杂的异步操作。注意,此方法在 React 16.3 版本后已被标记为不安全,建议使用替代方法。
|
3月前
|
机器学习/深度学习 自然语言处理 API
10-22|处理脏话其他方法
10-22|处理脏话其他方法
|
6月前
|
存储 缓存 Java
createTempFile方法详解
createTempFile方法详解
C#中的方法
C#中的方法
95 0
|
JavaScript 前端开发
getMonth() 方法
getMonth() 方法
187 0
|
存储 算法 搜索推荐
常用的外部排序方法
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_34173549/article/details/81158566 定义问题       外部排序指的是大文件的排序,即待排序的记录存储在外存储器上,待排序的文件无法一次装入内存,需要在内存和外部存储器之间进行多次数据交换,以达到排序整个文件的目的。
1856 0
|
测试技术 C#
分享几个实用的方法
  今天主要和大家分享的是本人总结的分页执行方法,也可以说就是分批执行;该篇采用java8新增的表达式来操作,希望能给各位带来好的帮助和在日常工作中提供便利;同样的操作流程和逻辑之前用C#代码写过一次,有需要的朋友可以看以前的博文; 分页方式拆分List为多个子集List方法 执行统一方法-无...
1212 0
|
数据库 Go
统计数据库大小的方法
原文:统计数据库大小的方法     一台服务器上所有数据库(也可能是部分数据库)的大小是我们经常需要了解的,它不仅能让我们知道目前数据库使用磁盘的比例, 而且定期搜集这些信息,还能了解数据库一段时间的数据增量,更为常用的是在做数据迁移和升级时,方便规划新服务器磁盘容量。
1321 0