仿射变换原理
仿射变换是一种线性变换,可以包括平移、旋转、缩放和剪切等操作。其一般公式可以表示为:
$$\mathbf{x’} = A \mathbf{x} + \mathbf{b} ]
其中:
- (\mathbf{x}) 是输入向量,通常表示一个点在二维或三维空间中的坐标。
- (\mathbf{x’}) 是输出向量,表示经过仿射变换后的点。
- (A) 是一个矩阵,称为仿射变换矩阵,它包含了线性变换的部分。
- (\mathbf{b}) 是一个向量,称为平移向量,它包含了平移的部分。
具体来说,对于二维空间中的点 ((x, y)),仿射变换可以表示为:
( x ′ y ′ ) = ( a b c d ) ( x y ) + ( e f ) \begin{pmatrix} x' \\ y' \end{pmatrix} = \begin{pmatrix} a & b \\ c & d \end{pmatrix} \begin{pmatrix} x \\ y \end{pmatrix} + \begin{pmatrix} e \\ f \end{pmatrix} (x′y′)=(acbd)(xy)+(ef)
其中:
- (a, b, c, d) 是仿射变换矩阵 (A) 的元素。
- (e, f) 是平移向量 (\mathbf{b}) 的元素。
齐次坐标下:
( x ′ y ′ 1 ) = ( a b e c d f 0 0 1 ) ( x y 1 ) \begin{pmatrix} x' \\ y' \\ 1 \end{pmatrix} = \begin{pmatrix} a & b & e \\ c & d & f \\ 0 & 0 & 1 \end{pmatrix} \begin{pmatrix} x \\ y \\ 1 \end{pmatrix} x′y′1 = ac0bd0ef1 xy1
仿射变换是一种在二维或三维空间中保持点之间相对位置的几何变换。它包括平移、旋转、缩放和剪切等基本变换。仿射变换可以用矩阵表示,并且可以通过矩阵乘法进行组合。在计算机图形学和图像处理中,仿射变换是常用的技术。
齐次坐标
齐次坐标是一种将二维或三维坐标扩展到更高维度的方法,以便于表示平移变换。在二维空间中,齐次坐标是将 ( x , y ) (x, y) (x,y) 扩展为 ( x , y , 1 ) (x, y, 1) (x,y,1)。这使得平移、旋转、缩放等变换都可以用矩阵乘法表示,从而简化了变换的组合和计算。
例如,二维平移的齐次坐标表示为:
[ x ′ y ′ 1 ] = [ 1 0 t x 0 1 t y 0 0 1 ] [ x y 1 ] \begin{bmatrix} x' \\ y' \\ 1 \end{bmatrix}=\begin{bmatrix} 1 & 0 & t_x \\ 0 & 1 & t_y \\ 0 & 0 & 1 \end{bmatrix}\begin{bmatrix} x \\ y \\ 1 \end{bmatrix} x′y′1 = 100010txty1 xy1
通过使用齐次坐标,我们可以将所有的仿射变换统一表示为矩阵乘法,从而简化了变换的组合和计算。
基本变换
仿射变换的公式可以通过线性代数的基本原理推导出来。例如,旋转矩阵的推导基于三角函数和线性组合。
组合所有基本仿射变换(平移、旋转、缩放和剪切)的总变换可以通过矩阵乘法来实现。为了简化计算,我们使用齐次坐标。在二维空间中,每个变换都可以表示为一个 3x3 矩阵。组合这些变换时,我们需要按照特定的顺序应用这些矩阵。
假设我们有一个点 P ( x , y ) P(x, y) P(x,y),我们想要先对其进行缩放,然后旋转,接着平移,最后进行剪切。变换的顺序很重要,因为它会影响最终结果。
-
缩放矩阵 S S S:
S = [ s x 0 0 0 s y 0 0 0 1 ] S = \begin{bmatrix} s_x & 0 & 0 \\ 0 & s_y & 0 \\ 0 & 0 & 1 \end{bmatrix} S= sx000sy0001 -
旋转矩阵 R R R:
R = [ cos θ − sin θ 0 sin θ cos θ 0 0 0 1 ] R = \begin{bmatrix} \cos\theta & -\sin\theta & 0 \\ \sin\theta & \cos\theta & 0 \\ 0 & 0 & 1 \end{bmatrix} R= cosθsinθ0−sinθcosθ0001 -
平移矩阵 T T T:
T = [ 1 0 t x 0 1 t y 0 0 1 ] T = \begin{bmatrix} 1 & 0 & t_x \\ 0 & 1 & t_y \\ 0 & 0 & 1 \end{bmatrix} T= 100010txty1 -
斜切矩阵 H H H: