转载 摄像机标定

http://blog.csdn.net/tiemaxiaosu/article/details/51728961

一、概述

1、摄像机标定内容

摄像机标定实际上是要求出6个外参数、5个内参数,即旋转和平移矩阵 R 和 T 中的三个坐标系旋转角度和坐标系平移量 (fu = f/Sx, fv = f/Sy, u0, v0, u),以及各种畸变系数 k1、k2、p1、p2、s1、s2 等。若不考虑离散后像素变形(不是矩形方块)或者成像平面不与光轴正交,则可以不考虑畸变因子u。一般情况下,畸变系数只考虑径向畸变系数,并设 k1 = k2 = k。

如果已知摄像机的内外参数,即矩阵M已知,对任何空间点W,知道它的世界坐标[X Y Z 1]T,就可以求出其图像像素坐标系中该图像点w的坐标(u, v)。反过来,如果已知空间某点的图像坐标,即使已知内外参数,空间坐标也不是唯一确定的,它对应空间的一条射线。

2、经典标定方法

经典标定方法主要包括透视变换法、张正友法、直接线性变换法、两步法和双平面法等。其中,直线线性变换是最优化算法,两步法进一步考虑了畸变补偿,双平面法合理运用了摄像机的成像模型。经典标定方法的标定流程如下:

1)布置标定点,固定摄像机进行拍摄。

2)测量各标定点的像平面坐标(u,v)。

3)将各标定点相应的像平面坐标(u,v)及世界空间坐标(X, Y, Z)代入摄像机模型式中,根据标定方法,求解摄像机内外参数。

二、摄像机标定的透视变换法

将透视变换矩阵和成像模型写为:

式中,[X Y Z 1]T 是空间三维的世界坐标矢量;[u v 1]T 为相应的图像坐标矢量;mij为透视变换矩阵M的元素。式(5.95)包含如下三个方程:

在三个方程中,用第三个方程分别去除第一个方程和第二方程,整理消去 z 后,得到如下关于 mij 的线性方程,即

式(5.97)描述了三维世界坐标点矢量[X Y Z 1]T 与相应图像点矢量[u v 1]T 之间的关系。如果已知三维世界坐标和相应图像坐标,将变换矩阵看作未知数,则共用12个未知数。对于每一个物体点,都有上述的两个方程。因此,取6个物体点,就可以得到12个方程,表示成矩阵形式为:

其中

M 矩阵乘以任何不为零的数,不影响(X, Y, Z) 与(u, v) 的关系,一般设m34 = 1。标定时M 取样点数为n,则共有2n 个方程,11个未知数,2n >= 11,方程没有准确解,所以采用最小二乘法估计求出11个参数。由最小二乘法可得:

求出系数矩阵M后,可根据式(5.65),解得摄像机的内外参数。求矩阵M时,设m34=1,所求矩阵M与实际矩阵M相差一个m34因子。因此有如下关系式:

设ax = f/Sx,ay = f/Sy,为水平方向和垂直方向的尺度因子,则有

式中,MiT(i=1~3)为M矩阵的第i行的前3个元素组成的行矢量;m14(i=1~3)为M矩阵第i行第4列元素;RiT(i=1~3)为旋转矩阵R的第i行;Tx,Ty,Tz,分别为平移矢量T的三个矢量。比较上式两边可知,m34M3 = R3,由于R3 是正交单位矩阵的第3行,且|R3| = 1(矢量的模),因此可以从m34|M3| = 1 求解

再由以下式子可以得出R3、u0、v0、ax、ay,有

式中,符合×表示矢量积运算符。由以上求出的参数可进一步求出以下参数:

以上介绍了摄像机标定的透视变换法的计算过程,在用真实数据进行实验时,需要注意以下问题:

1)矩阵M确定了空间点坐标与它的图像点坐标的关系。在许多应用场合,如立体视觉系统,计算矩阵M后,不必再分解出摄像机内外参数。

2)矩阵M由4个摄像机内部参数及R与T所确定。由矩阵R是正交单位矩阵可知,R和T的独立变量数为6,因此矩阵M由10个独立变量所确定

摄像机标定 matlab toolbox_calib工具箱

参考http://blog.csdn.net/kyjl888/article/details/71305573

摄像机定标

转载http://www.sigvc.org/why/book/3dp/chap6.3.1.htm

假设你现在已经拍摄了脚的多张各个角度的2D照片,那么如何将这些照片转化成一个3D数字化形状呢?首先第一步,你要对摄像机进行定标,比如确定摄像机的焦距、摆放位置和角度等。

我们先来看看摄像机的成像模型[1]。摄像机的成像模型一般采用针孔模型(Pin-Hole Model),与我们中学时学的小孔成像是一个原理,如图6-21所示。

图6-21  两千多年前,墨子和学生进行了世界上第一个小孔成像实验 (图片来源:大科技)

提示:其实两千多年前我国古代的大思想家墨子就和学生进行了世界上第一个小孔成像实验,并记录到“景到(即,倒),在午(即,交叉)有端(即,小孔),与景长,说在端”。因此墨子被西方称为“摄影光学理论和实践的开创者,探索光影成像的第一人”。

如图6-22左边所示,为了把成像模型解释清楚,我们来仔细看看摄像机的成像几何关系。同时我们把成像平面放到了小孔的前面,这样成像就是正立着的而不像上图那样倒立了。

图6-22  左:针孔成像模型;右:图像坐标系

—  O点称为摄像机的光心,由点OXcYcZc轴组成的直角坐标系称为摄像机坐标系。

—  I是成像平面(图像平面),我们把镜头对焦后,物体就成像在这个平面。图像平面构成了一个图像坐标系,横坐标为x纵坐标为y

—  Xc轴和Yc轴与图像的x轴与y轴平行,Zc轴为摄像机的光轴,它与图像平面垂直。光轴与图像平面的交点,即为图像坐标系的原点Oxy

—  OOxy的长度为摄像机焦距f

一下子冒出这么多术语,我们中场休息一下,给出本节的第1个公式来醒醒脑子。我们先仔细研究一下图像坐标系。如图6-22右边所示,图像坐标系以Oxy为原点,由xy轴组成,单位是mm。然而,在实际的相机中,并不是以物理单位(如mm)来表示某个成像点的位置的,而是用像素的索引。比如一台相机的像素是1600×1200,说明图像传感器(也就是以前的胶片)横向有1600个捕捉点,纵向有1200个,合计192万个。对于某个成像点,实际上都是这样表示的:横坐标第u个点,纵坐标第v个点(而不是横坐标mm,纵坐标y mm)。假设Oxyuv坐标系中的坐标为(),每一个像素在x轴与y轴方向上的物理尺寸为宽dx mm,高dy mm,则图像中任意一个像素的索引坐标与物理坐标满足下面的换算关系:

上面的这个方程组,分成了单独两个公式来写,让人感觉关联不够紧密(“本是一家人却说两家话”),因为实际上是要同时满足的,因此我们把两行合并成一个公式来写:

                                          (3)

上面的形式被称作为矩阵形式。形象地说,矩阵(Matrix,没错,电影《黑客帝国》的英文片名就是这个单词)就是将多个有关联的元素用个大括号括在一起成为一个整体,以便直接对整体进行运算以分析出各个元素之间的内在关系。一个m×n的矩阵是一个由mn列元素排列成的矩形阵列;当m=1或n=1时,则特称为向量。上式左边是个3×1的向量,右边表示了一个3×3矩阵和一个3×1向量之间的相乘。改成矩阵写法之后,将两个公式浓缩成了一个公式,整体感是不是提升了很多?从上面也可以看出,与普通代数(传统代数)不同,矩阵代数这种超凡代数描述的是多维而不仅是一维的代数;普通(一维)代数的乘法与乘子顺序无关,,而矩阵代数通常情况下,即一般不满足交换律;此外普通代数只有0没有逆(倒数),而矩阵代数中,很多矩阵都没有逆。

提示:有的读者可能会问,上面的矩阵为什么有3行呢?之前的公式不是只有2个吗?好问题!这是我偷偷塞了点料,把之前的坐标(u,v)和(x,y)都转成齐次坐标(u,v,1)和(x,y,1)了。齐次坐标(Homogeneous Coordinate)的好处是:即使乘个系数k(),仍对应于原来的同一个点,也即(u,v,1)与(k×u,k×v,k)对应于同一个点。同时,还便于几何变换(旋转、缩放、平移),只需用一个大一号的矩阵即可将变换矩阵的乘法(旋转、缩放)和加法(平移)合并到一块。此外,齐次坐标还可表示不同的无穷远点。

好,我们接着进行术语教学。之前我们定义了摄像机坐标系,但由于摄像机可安放在环境中的任何位置,所以我们还要定义一个世界坐标系来描述摄像机在环境中的位置,由XwYwZw轴组成。摄像机坐标系与世界坐标系之间的关系可以用旋转矩阵R与平移向量t来描述,即:

                             (4)

矩阵和向量用黑斜体表示,其中R为3×3的矩阵;t为3×1的向量;Mb为4×4的矩阵,其也被称为摄像机外部参数矩阵。

知识点:你在高中学习的初等数学是研究常量、研究静态的数学;而在大学里学的高等数学是研究变量、研究运动的数学。下面我们再解释一下空间、向量、矩阵的关系。

空间(Space)是高等数学的基础概念,可被通俗地解释为“存在一个集合,在这个集合上定义某某概念,然后满足某些性质”。从拓扑空间开始,一步步可往上“升级”成更高级的空间。线性空间(又名向量空间,Vector Space)其实还是比较初级的,如果在里面定义了范数(“长度”),就成了赋范(Normed)线性空间。赋范线性空间满足完备性,就成了巴那赫(Banach)空间;若定义了角度,则为内积(Inner Product)空间。内积空间若同时满足完备性,就得到希尔伯特(Hilbert)空间(见下面的6.4.2节)。

以我们日常生活在其中的三维欧几里得(Euclidean)空间为例:1)由无穷多个位置点组成,2)这些点之间存在相对的关系,3)可在空间中定义长度、角度,4)这个空间可以容纳运动。这里我们所说的运动是从一个点到另一个点的“跃迁”跳跃式地运动(变换,Transform),而不是微积分意义上的“连续”性的运动。实际上,不管什么空间,都必须容纳和支持在其中发生的符合规则的运动(变换)。比如拓扑空间中有拓扑变换,线性空间中有线性变换,仿射空间中有仿射变换,其实这些变换都只不过是对应空间中允许的运动形式而已。

在线性空间中选定基(坐标系)之后,向量刻画对象,矩阵刻画对象的运动,也即用矩阵与向量的乘法来施加运动。矩阵的本质是运动(变换)的描述,比如在一个线性空间中,只要我们选定一组基,那么对于任何一个线性变换,都能够用一个确定的矩阵来加以描述。

若矩阵是同一个线性变换的两个不同的描述(之所以会不同,是因为选定了不同的基,也就是选定了不同的坐标系),则一定能找到一个非奇异矩阵,使得之间满足这样的关系:。这就是相似矩阵的定义,即这两个相似矩阵实际上描述的是同一个线性变换,因此特征值(Eigenvalue)相同。

从另一个角度来看,矩阵是由一组向量组成的,如果矩阵非奇异的话,那么这一组向量是线性无关的,于是它们组成了度量线性空间的一个坐标系。换言之,矩阵实际上描述了一个坐标系。之所以矩阵既是运动,又是坐标系,是因为对象的变换等价于坐标系的变换。

此外,n阶矩阵的行列式也有着明确的几何意义:为n个组成向量按照平行四边形法则所张成的一个n维立方体的体积(如果是2维,则为面积)。向量的线性相关性实际上表示了这些向量所张成的广义平行四边形面积(体积)为0,例如此时的向量共线(n=2情况下)或共面(n=3情况下)。反之,若线性无关,则体积(行列式)不为0。此外,我们也不难看出,行列式不为0的矩阵,是可逆的(非奇异),即可将一组线性无关的向量变换成另一组也保持无关性的向量。

如果一个n阶矩阵虽不能保持n个向量的线性无关性,但它能保持<n个向量的线性无关性,r就被称作矩阵的秩,表示了能保持非0体积的几何体的最大维数。

外围的知识都介绍完了,好,我们现在正式开始介绍针孔模型。如图6-22左边所示,空间上任何一点P在图像上的投影位置p为光心OP点的连线OP与图像平面的交点,这种关系也被称为中心射影或透视投影。由几何比例关系可轻易得出(先看下面公式的左边):

  ó                           (5)

其中(x,y)为p的图像坐标,(Xc,Yc,Zc)为空间点P在摄像机坐标系下的坐标。同样,上式的箭头右边为左边的矩阵形式,左右两边是等价的。

我们将公式(3)和公式(4)代入公式(5),就可以得到P点在世界坐标系下的坐标(Xw,Yw,Zw)与其在图像平面的投影点p的坐标(u,v)的关系:

其中,M=MaMb为3×4矩阵,称为投影矩阵;Ma完全由决定的摄像机内部结构(如焦距、光心)有关,称为摄像机内部参数;Mb完全由摄像机相对于世界坐标系的方位(如摆放位置和拍摄角度)决定,称为摄像机外部参数。确定某一摄像机的内部和外部参数,就被称为摄像机定标/标定(Calibration)。注意,很多情况下的摄像机定标仅指确定摄像机的内部参数。

由上式可以看出,如果已知摄像机的内参数Ma和外参数Mb(即定标好了),两者直接一相乘就可得到投影矩阵M。投影矩阵M有什么作用呢?对任意空间点P,如果已知它的世界坐标系坐标,根据M,就可求出它的图像点p的位置(u,v)。

单台摄像机的定标

下面介绍一下摄像机定标的过程,如图6-23左边所示,我们在摄像机前放一个标定块。所谓标定块,就是每个特征点的空间位置都被事先测定的基准块,比如两个点的距离都被精确做成了1.0000 cm(精确到小数点后若干位)。用相机拍摄标定块的图像,就可以根据特征点的图像坐标(u,v)与真实三维空间坐标(Xw,Yw,Zw)之间的关系,来计算摄像机的内外参数了。我们需要6个或以上特征点,就可求解出投影矩阵M。但在实际应用中,我们通常使用了几十个特征点以减少可能的误差。此外,我们常用图6-23右边的平面标定块来进行标定[71],标定时先平放着拍一张正面照片,然后再用个小物件轮流把每边往空间上翘起来一点(即改变标定板的空间位置姿态),依次拍摄3幅以上照片即可。(不要小看了小小的标定板,比如一块选材做工精良的大理石标定板定价需要几千元,以保证工业级高精度、完全平面、不变形。选购时,比如要实现±10 mm的3D重建精度,可选择1 mm精度的标定板。)

 

图6-23  左:三维标定块;右:二维标定板

提示:如果在定标时,环境不允许放置标定块或标定板,或者经常需要改变摄像机的内参数(如调焦),这时就只能通过自标定(Self-Calibration)技术来获取摄像机内参数,能利用到的信息只有图像的空间对应点,并用数学上的绝对二次曲线(AC,Absolute Conic)作为虚拟标定物。绝对二次曲线是在射影空间中无穷远平面上、全部由虚点构成的一条二次曲线,它的重要特性是它在图像平面的成像(IAC)不随摄像机的位置姿态变化,即投影成像只与摄像机的内参数有关。自标定至少需要拍摄3幅图像。另外对于平面场景的自标定,可通过提取平行线段进行求解。由于自标定求解的非线性,所以一般适用于精度要求不高的场合。

如果摄像机内参数Ma已知,仅需要确定外参数(Rt),即由N个3D空间点与图像点的对应关系来确定世界坐标系与摄像机坐标系之间的欧氏变换,这个问题被称为PNP问题(Perspective-N-Points)。当N≥6时,可线性唯一确定;但N=3,4,5时,一般情况下也可把解限定在有限的几个候选上。

以上我们假设的都是线性摄像机模型,但如果使用广角镜头(或全向摄像机),在远离图像中心处会有较大的畸变,因此可能还需要进行非线性修正或建模,如对径向畸变、离心修正、薄棱镜畸变等非线性畸变进行修正。

两台摄像机的定标

好了,我们刚才对一台摄像机的内外参数进行了标定。然而,对于从2D图像到3D形状的重建,一台摄像机(或仅拍一个角度的照片)是不够的。从图6-22中可以看出,已知图像点p的位置(u,v),即使知道摄像机的内外参数,空间坐标(Xw,Yw,Zw)也不是能唯一确定的,实际上任何位于射线OP上的空间点的图像点都是p点。怎么办?再加一台摄像机(或者用同一台摄像机拍两次)!用左右两个摄像机进行立体视觉重建。

我们分别对左右两台摄像机单独进行了定标,就得到了它们的内参数。我们在6.3.2节可以知道,在一般的立体视觉方法中,只需知道摄像机的内参数,以及用极线(Epipolar Line)描述的双摄像机相对位置就足够了。

下面我们对极线进行介绍。如图6-24所示,用两个摄像机同时获得两张图像I1I2。如果p1p2是空间同一点P在两张图像上的投影点,我们称p2p1的对应点,反之亦然。我们指出,p1点的对应点p2不需要在I2整幅图像中搜索,它必然只位于I2的某一条直线上,该直线(图中的l2)称为图像I2上对应于p1点的极线。

图6-24  用两台摄像机拍摄空间点

那么如何找到极线呢?其实很简单,它满足一个几何约束。如图6-24所示,O1为左摄像机的光心,O2为右摄像机的光心,两者的连线O1O2经过左右两个图像平面时相交于两个极点e1e2。可以证明,I1(或I2)图像上的所有极线都相交于同一点e1(或e2),也即极线必然经过e1(或e2)。经推导可知,给定投影矩阵M1M2,对于左摄影机的一个图像投影点坐标p1,则它的对应点坐标p2所在的极线是完全确定的,满足如下方程:

                                                   (6)

其中,;反对称矩阵,其秩为2。注意F是一个仅为3×3的矩阵,具有7个自由度,由投影矩阵M1M2组合运算得到,这是立体视觉很重要的一个矩阵,称为基本矩阵(Fundamental Matrix),其只与两个摄像机的内参数和空间相对位姿有关,与外参数无关。

通过上式(6)还可以看出,无须费劲地求解出两个摄像机的所有内外参数(即M1M2),很多应用场合下这是不必要的,因为只需一个基本矩阵F就可以得到立体视觉的极线几何约束关系。为了求解出基本矩阵F,我们至少需要两幅图像中的7或8个对应点。

更广义地,我们介绍图像平面间的单应矩阵(Homography Matrix)H的概念,具有8个自由度(实际上,前面提到的F由平面单应矩阵与极点唯一确定,即)。所谓单应可理解为:空间平面在两个摄像机各自的射影变换(Projective Transformation,也被称为直射变换Collineatory Transformation)下所生成的图像点具有一一对应的关系,即。单应矩阵H的一个典型应用就是对射影变换导致的图像变形进行矫正:我们只需先从变形图像中指定共面的4个点,对其手工矫正后得到4个新的点,于是就可求解出单应矩阵H了,最后对变形图像的所有点应用单应变换H进行自动矫正,整个过程无需求解摄像机的任何参数。

提示:空间点P不仅可以通过在左右两张图像上的投影点p1p2来重建(这称之为双视图几何),类似地,还可通过同时拍3张图像来重建点P,这就被称为三视图几何。其中三焦张量(Trifocal Tensor)等同于双视图几何中基本矩阵的地位,类推还有四视图几何的四焦张量。3视图及以上的几何重建统称为多视图立体重建(MVS,Multi-View Stereo)。

【计算机视觉】摄像机标定2 原理篇相关推荐

  1. 摄像机标定2 原理篇

    转载 摄像机标定 http://blog.csdn.net/tiemaxiaosu/article/details/51728961 一.概述 1.摄像机标定内容 摄像机标定实际上是要求出6个外参数. ...

  2. 计算机视觉(相机标定)-2.1 摄像机标定

    计算机视觉(相机标定)- 2.1 摄像机标定 学习前言 一. 摄像机标定是啥?为什么要进行摄像机标定? 二.求MMM 问题一:求解投影矩阵需要多少对应点? 问题二:怎么算? 二.求MMM中的摄像机的内 ...

  3. 【Halcon笔记1】基于Halcon软件的【摄像机标定】以及【内部参数】和【外部参数】的求解过程【原理细节详解】

    [1]具体请看Learning OpenCv[摄像机标定] [2]马颂德[摄像机定标] [3]<基于Halcon软件的摄像机标定>论文

  4. 【计算机视觉】 摄像机标定

    摄像机标定 齐次坐标 齐次坐标,将欧氏空间的无穷远点,与投影空间中有实际意义的消失点,建立起映射关系. 把齐次坐标转化为笛卡尔坐标的方法:是前面n-1个坐标分量分别除以最后一个分量即可 一些解释和性质 ...

  5. 张正友摄像机标定的研究(MATLAB+OpenCV)

    张正友 本科浙大,本来以为是中国人论文是中文呢,哎 张正友的主页: http://research.microsoft.com/en-us/um/people/zhang/Calib/ 不过里面的棋盘 ...

  6. matlab张正友摄像机标定算法应用,张正友摄像机标定的研究(MATLAB+OpenCV)

    张正友 本科浙大,本来以为是中国人论文是中文呢,哎 不过里面的棋盘格跟我的不一样啊,why???,我决定先看看中文的论文吧,我的首要任务是弄清楚输入输出,流程,怎么用吧 matlab 跟 opencv ...

  7. 计算机视觉----相机标定模型

    简介 提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.相机标定简介 二.张友正黑白棋盘标定 1.思想 2.原理 3.模型求解 三.实验内容及过程 3.1 实验要求 ...

  8. 基于opencv的摄像机标定

    原理简述: 三维世界中的点的位置与其对应的二维投影,遵从以下公式:   其中,  M表示三维世界中的点:  [R|T]表示欧氏变换,是一个3*4矩阵  A表示相机参数矩阵,存放相机内部参数  P表示M ...

  9. 机器视觉学习笔记(4)——单目摄像机标定参数说明

    机器视觉学习笔记(4)--单目摄像机标定参数说明 标签: 机器视觉 1.针孔摄像机模型 在介绍摄像机标定参数之前,需要先简单说一下针孔摄像机的原理.投影平面到小孔的距离为焦距f,物体到小孔的距离为Z, ...

最新文章

  1. shell /dev/null
  2. 关于EXCEL超级链接被禁止的解决方法
  3. 电脑上同时安装了tensorflow和tensorflow-gpu,如何默认使用tensorflow-gpu
  4. 九宫怎么排列和使用_什么是九宫飞星,九宫飞星在生活中的应用
  5. mac 电脑连接不上github_Mac版爱思助手【手机投屏直播】工具使用教程
  6. 织梦根目录感染abc.php,织梦SEO优化:织梦dedecms根目录下robots.txt文件设置详解! - 张俊SEO...
  7. oracle查询显示小写,oracle查询区分大小写
  8. Win10 安装IE11失败错误代码0x80070490(未解决)
  9. 七彩虹SL500固态硬盘,慧荣SM2258XT主控成功开卡成MLC模式。上教程和软件链接
  10. 【转】宽带路由器应用(三)—ARP欺骗防护功能的使用
  11. 试图加载格式不正确的程序。 (Exception from HRESULT: 0x8007000B)
  12. 南阳理工题目---218Dinner
  13. OneDrive不能上了?DNS被污染,解决方法很简单
  14. 计算机重装系统后无法连接网络连接,电脑用一键重装后不能连宽带解决方法
  15. Unity中手动压缩图片 修改图片分辨率
  16. 【NOIP模拟】行走
  17. electron-vue+electron-updater实现自动更新
  18. 软件测试开发和软件测试的区别
  19. 实验二+087+饶慧敏
  20. idea log 不输出error_Python之log

热门文章

  1. 蛇形矩阵python
  2. EBS开发_费用类采购订单退货
  3. 我做一键WIFI要用到的API
  4. 当技术人成长为 CEO,应该修改哪些“Bug”?
  5. Semi-Supervised Semantic Image Segmentation with Self-correcting Networks_CVPR2020
  6. android app换肤Android-skin-support的简单使用
  7. 为什么坐飞机可以玩荣耀刷抖音?可见光通信LiFi告诉你!
  8. FastDFS环境安装及使用
  9. 关于buffer pool里的三大法宝
  10. 8. maven test