仿射变换

来自testwiki
跳转到导航 跳转到搜索

Template:NoteTA

一個使用仿射变换所製造有自相似性的碎形

仿射变换(Affine transformation),又称仿射映射,是指在几何中,對一个向量空间进行一次线性变换并接上一个平移,变换为另一个向量空间。

一個對向量x平移b,與旋轉缩放A的仿射映射為

y=Ax+b

上式在齐次坐标上,等價於下面的式子

[y1]=[Ab 0,,01][x1]

分形的研究裡,收縮平移仿射映射可以製作具有自相似性分形

數學定義

一个于两仿射空间间定义的仿射变换 f:𝒜 是一个点集映射,线性地作用于向量(即空间中的点之间的向量)。形式化表述是,f 决定一线性变换 φ,使得对于任意 𝒜 中的点对 P,Q,有:

f(P)f(Q)=φ(PQ)

或记

f(Q)f(P)=φ(QP).

我们可以以其他一些方式解释这一定义,以下进行说明:

若于 𝒜 中选定一原點 O,记其于 中的像为 f(O),那么就意味着,对于任意向量 𝒙𝒜 ,有

f:(O+𝒙)(B+φ(𝒙)).

而若于 中选定一原点 O,则其可分解为一将 O 映到 O 的仿射变换 g:𝒜,换言之,遵从向量 𝒃=OB 之变换,

g:(O+𝒙)(O+φ(𝒙)).

以上可以直观地总结为,仿射变换包含一个线性映射与一个变换

等价定义

给定相同域上的两仿射空间 𝒜,称一映射 f:𝒜 为仿射变换,当且仅当对于任意 𝒜 上满足 iIλi=1 的权重点簇 {(ai,λi)}iI[1]

f(iIλiai)=iIλif(ai).

换言之,f 保持了原相的质心

表示

如上所示,仿射變換為兩函數的複合平移線性映射。普通向量代數用矩陣乘法呈現線性映射, 用向量加法表示平移。正式言之,於有限維度之例中,假如該線性映射被表示為一矩陣「A」,平移被表示為向量 b,一仿射映射 f可被表示為

y=f(x)=Ax+b.

增廣矩陣

File:Affine transformations.ogv

使用一增廣矩陣與一增廣向量,用一矩陣乘法同時表示平移與線性映射是有可能的。此技術需要所有向量在其末端擴長“1”且所有矩陣都於底部添加一排零,右邊擴長一列轉換向量,及右下角添加一個“1”。

[y1]=[Ab 001][x1]

等價於

y=Ax+b.

以上所言之擴長矩陣被稱為“仿射變換矩陣”,又或稱為“投射變換矩陣”(其可應用於投影轉換)。

此表示法以Kn半直積與GL(n, k)展示了 所有可逆仿射變換的集合。此為一個於眾函數集結下進行的一個,被稱為仿射群

普通矩陣向量乘法總將原點映射至原點,因此無法呈現平移(原點必須映射至其他點)。藉由於所有向量上擴增一座標“1”,我們將原空間映至更高維空間的一個子集合以進行變換。在該空間中,原本之空間佔有了擴長座標一的1的子集合。因此原空間的原點可在(0,0, ... 0, 1)。原空間的平移可藉由更高維度空間的線性轉換來達成(即為錯切變換)。在高維度中的座標即為齊次座標的一例。假如原空間為歐幾里德,則更高維空間為實射影空間

使用齊次座標的優點為,藉由相對應矩陣之乘積,可將任意數目的仿射變換結合為一。此性質被大量運用於計算機圖形計算機視覺機器人學

性質

仿射變換保留了:

  1. 點之間的Template:Link-en:在同一条直线上的三个或更多的点(称为共线点)在变换后依然在同一条直线上(共线);
  2. 直线的平行性:两条或以上的平行直线,在变换后依然平行;
  3. 集合的凸性:凸集合变换后依然是凸集合。并且,最初的极值点被映射到变换后的极值点集[2]
  4. 平行线段的长度的比例:两条由点 p1,p2,p3,p4 定义的平行线段,p1p2p3p4的长度的比例等于f(p1)f(p2)f(p3)f(p4)的长度的比例;
  5. 不同質量的點组成集合的质心

仿射變換為可逆的当且仅当A為可逆的。用矩陣表示,其逆元為:

[A1A1b 0,,01]

可逆仿射變換組成Template:Link-en,其中包含具n階的一般線性群為子群,且自身亦為一 n+1 階的一般線性群之子群。 當A為常數乘以正交矩陣時,此子集合構成一子群,稱之為相似變換。舉例而言,假如仿射變換於一平面上且假如 A行列式11 ,那麼該變換即為Template:Link-en。此類變換組成被稱為等仿射群的子群。一同時為等面積變換與相似變換的變換,即為一平面上保持歐幾里德距離不變的保距映射

這些群都有一保留了原定向的子群,也就是其對應之 A 的行列式大於零。最後一个例子,即三維空间中剛體的運動组成的群(旋轉和平移),刚体的运动在机器人学中尤为常用[3]

如果有一固定點,我們可以將其當成原點,則仿射變換被縮還到一線性變換。這使得變換更易於分類與理解。舉例而言,將一變換敘述為特定軸的旋轉,相較於將其形容為平移與旋轉的結合,更能提供變換行為清楚的解釋。只是,這取決於應用與內容。

實例

實數之仿射變換

函數Template:Nowrap, Template:Nowrap ,其中mc為常數,此即為一般之仿射變換。

有限體的仿射變換

以下等式表示了有限體(28)中的仿射變換:

{a}=M{a}{v},

此處[M]為矩陣 且 {v} 為向量 :

:M{a}=[1000111111000111111000111111000111111000011111000011111000011111]  :{v}=[11000110].

舉例來講,將以大端序二進位表示的元素{a} = y7 + y6 + y3 + y = {11001010}轉換成大端序十六進位,計算如下:

a0=a0a4a5a6a71=000111=1
a1=a0a1a5a6a71=010111=0
a2=a0a1a2a6a70=010110=1
a3=a0a1a2a3a70=010110=1
a4=a0a1a2a3a40=010100=0
a5=a1a2a3a4a51=101001=1
a6=a2a3a4a5a61=010011=1
a7=a3a4a5a6a70=100110=1.


于是, {a′} = y7 + y6 + y5 + y3 + y2 + 1 = {11101101} = {ED}。

平面幾何之仿射變換

一個實數平面上的簡單仿射變換

在 ℝ2,左方所示之變換即為以下映射:

[xy][0121][xy]+[100100]

將原紅色三角形之三個頂點作變換後給出了新藍色三角形的三個頂點。事實上,所有三角形皆可由仿射變換來達成,所有平行四邊形也可以,但一般四邊形不行。

参看

Template:分形