Halcon仿射变换的基本原理是什么?
摘要:仿射变换 Affine Transformation 仿射变换:由一个平面立体图形变换到另一个平面立体图形的一种变换。在改变的过程中,保持直线和平行线不变(平行线映射为平行线),任何放射变换都可以分解为缩放、旋转、平移和切变的组合。 仿
仿射变换 Affine Transformation
仿射变换:由一个平面/立体图形变换到另一个平面/立体图形的一种变换。在改变的过程中,保持直线和平行线不变(平行线映射为平行线),任何放射变换都可以分解为缩放、旋转、平移和切变的组合。
仿射变换矩阵:
\[\begin{bmatrix}
x' \\
y' \\
1
\end{bmatrix} =
\begin{bmatrix}
a & b & c \\
d & e & f \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
x \\
y \\
1
\end{bmatrix}
\]
指定变换矩阵的参数(a,b,c,d,e,f)
使用一个简单的输入点(x,y) = (2,3)在齐次坐标中表示为(2,3,1)
计算得到输出点(x',y') = (a*2+b*3+c,d*2+e*3+f)
1.平移(Translation)
标准定义:平移由平移向量(Tx,Ty)定义,矩阵为:
\[\begin{bmatrix}
1 & 0 & Tx \\
0 & 1 & Ty \\
0 & 0 & 1
\end{bmatrix}
\]
示例:取平移向量(Tx,Ty) = (4,5)
变换矩阵:
\[\begin{bmatrix}
1 & 0 & 4 \\
0 & 1 & 5 \\
0 & 0 & 1
\end{bmatrix}
\]
计算过程:
\[\begin{bmatrix}
1 & 0 & 4 \\
0 & 1 & 5 \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
2 \\
3 \\
1
\end{bmatrix}
=
\begin{bmatrix}
6 \\
8 \\
1
\end{bmatrix}
\]
结果:点(2,3)变换到点(6,8)
解释:点沿 x 轴移动 4 单位,沿 y 轴移动 5 单位。
Halcons算子:hom_mat2d_translate在现有变换矩阵基础上添加平移分量。
参数:
HomMat2D:输入变换矩阵(若从零开始,需先初始化单位矩阵)
Tx, Ty:X/Y方向的平移量
HomMat2DTranslate:输出变换矩阵
* 初始化单位矩阵
hom_mat2d_identity(HomMat2DIdentity)
* 添加平移 (Tx=100, Ty=50)
hom_mat2d_translate(HomMat2DIdentity, 100, 50, HomMat2DTranslate)
2.缩放(Scaling)
标准定义:缩放由缩放因子Sx(x方向)和Sy(y方向)定义,矩阵为:
\[\begin{bmatrix}
Sx & 0 & 0 \\
0 & Sy & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
示例:取缩放因子Sx=2和Sy=3
变换矩阵:
\[\begin{bmatrix}
2 & 0 & 0 \\
0 & 3 & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
计算过程:
\[\begin{bmatrix}
2 & 0 & 0 \\
0 & 3 & 0 \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
2 \\
3 \\
1
\end{bmatrix}
=
\begin{bmatrix}
4 \\
9 \\
1
\end{bmatrix}
\]
结果:点(2,3)变换到点(4,9)
解释:点沿 x 轴缩放 2 倍,沿 y 轴缩放 3 倍。
Halcons算子:hom_mat2d_scale以指定中心点缩放。
参数:
HomMat2D:输入变换矩阵(若从零开始,需先初始化单位矩阵)
Sx, Sy:X/Y方向的缩放因子
Px, Py:缩放中心坐标(图像坐标系)
HomMat2DScale:输出变换矩阵
* 初始化单位矩阵
hom_mat2d_identity(HomMat2DIdentity)
* 以点 (Px=300, Py=300) 为中心,X方向放大2倍,Y方向缩小0.5倍
hom_mat2d_scale(HomMat2DIdentity, 2, 0.5, 300, 300, HomMat2DScale)
3.旋转(Rotation)
标准定义:旋转由旋转角度θ(逆时针为正)定义,矩阵为:
\[\begin{bmatrix}
\cos(\theta) & -\sin(\theta) & 0 \\
\sin(\theta) & \cos(\theta) & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
示例:取旋转角度θ=90°(π/2弧度),则sin 90° = 1, cos 90° = 0
变换矩阵:
\[\begin{bmatrix}
0 & -1 & 0 \\
1 & 0 & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
计算过程:
\[\begin{bmatrix}
0 & -1 & 0 \\
1 & 0 & 0 \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
2 \\
3 \\
1
\end{bmatrix}
=
\begin{bmatrix}
-3 \\
2 \\
1
\end{bmatrix}
\]
结果:点(2,3)变换到点(-3,2)
解释:点沿 x 轴旋转 90°,即逆时针旋转 90°。
Halcons算子:hom_mat2d_rotate绕指定中心点旋转。
参数:
HomMat2D:输入变换矩阵(若从零开始,需先初始化单位矩阵)
Angle: 旋转角度(弧度制)
Px, Py:旋转中心坐标(图像坐标系)
HomMat2DRotate:输出变换矩阵
* 初始化单位矩阵
hom_mat2d_identity(HomMat2DIdentity)
* 绕点 (Px=200, Py=200) 旋转 30°(弧度 ≈0.5236)
AngleRad := 30 * 3.1415926 / 180
hom_mat2d_rotate(HomMat2DIdentity, AngleRad, 200, 200, HomMat2DRotate)
4.错切(Shearing)
标准定义:错切由错切系数Sx(x方向)和Sy(y方向)定义,矩阵为:
\[\begin{bmatrix}
1 & Sx & 0 \\
Sy & 1 & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
示例:取错切系数Sx=0.5和Sy=0.2
变换矩阵:
\[\begin{bmatrix}
1 & 0.5 & 0 \\
0.2 & 1 & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
计算过程:
\[\begin{bmatrix}
1 & 0.5 & 0 \\
0.2 & 1 & 0 \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
2 \\
3 \\
1
\end{bmatrix}
=
\begin{bmatrix}
1.5 \\
2.6 \\
1
\end{bmatrix}
\]
结果:点(2,3)变换到点(1.5,2.6)
解释:点沿 x 轴错切 0.5 单位,沿 y 轴错切 0.2 单位。
注意:错切矩阵的逆矩阵是:
\[\begin{bmatrix}
1 & -0.5 & 0 \\
-0.2 & 1 & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
5.复合变换(Composition)
多个仿射变换可以组合成一个复合变换,矩阵的乘积表示。
示例:先平移再缩放再旋转,平移向量(Tx,Ty)=(4,5),缩放因子Sx=2和Sy=3,旋转角度θ=90°(π/2弧度)
变换矩阵:
\[\begin{bmatrix}
2 & 0 & 0 \\
0 & 3 & 0 \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
1 & 0 & 4 \\
0 & 1 & 5 \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
0 & -1 & 0 \\
1 & 0 & 0 \\
0 & 0 & 1
\end{bmatrix}
\]
合并后的复合变换矩阵:
\[ \begin{bmatrix}
0 & -2 & 8 \\
3 & 0 & 15 \\
0 & 0 & 1
\end{bmatrix}
\]
计算过程:
\[\begin{bmatrix}
0 & -2 & 8 \\
3 & 0 & 15 \\
0 & 0 & 1
\end{bmatrix}
\begin{bmatrix}
2 \\
3 \\
1
\end{bmatrix}
=
\begin{bmatrix}
-1 \\
6 \\
1
\end{bmatrix}
\]
结果:点(2,3)变换到点(-1,6)
