三維座標要建一個4*4的矩陣?
怎麼平移一個三維空間中的點
我們應該怎麼平移一個三維空間中的點呢?答案很簡單,我們只需要對這個點的座標中的每個分量(x,y,z)和對應軸上的平移距離相加即可。
例如,點p1(x1,y1,z1)在X軸Y軸以及Z軸上分別平移Δx,Δy,Δz到新的點p2(x2,y2,z2),那麼我們只需在座標對應的分量上加上這些增量就可以確定點p2的座標了。
x2 = x1 + Δx
y2 = y1 + Δy
z2 = z1 + Δz
很簡單是嗎?那麼接下來再讓我們來看一看另一種變換:旋轉。
再來旋轉一個點
旋轉相比較平移來說,會略顯複雜一些。因為我們需要指明以下幾個方面來描述一個旋轉:
旋轉軸
旋轉方向
旋轉角度
在這裡,我們假設點p需要繞Z軸順時針旋轉β度。如這個很難看的圖所示,我們的點P1(x1,y1,z1)以Z軸位軸順時針旋轉β度之後來到了點P2(x2,y2,z2)。接下來,讓我們假設原點到P1的距離位L,且P1和Y軸之間的夾角位α,那麼根據三角函式公式我們就可以計算出P1點的具體座標了:
x1 = L·sinα
y1 = L·cosα
由於是繞Z軸旋轉,因此z座標不變,因此此處不考慮。
同樣根據三角函式公式,我們可以繼續計算出P2的具體座標:
x2 = L·sin(α + β)
y2 = L·cos(α + β)
再讓我們回憶一下中學時代的幾何數學的內容,對青春的回憶又把我們帶回了課堂上老師聲嘶力竭向我們傳授的內容——兩角和與差:
cos(α+β)=cosα·cosβ-sinα·sinβcos(α-β)=cosα·cosβ+sinα·sinβsin(α+β)=sinα·cosβ+cosα·sinβsin(α-β)=sinα·cosβ-cosα·sinβ
回憶起老師傳授給我們的知識之後,接下來結合P1的座標表示形式我們就可以把P2的座標換一個表示形式了。
x2 = L·(sinα·cosβ+cosα·sinβ) = cosβ·x1 + sinβ·y1
y2 = L·(cosα·cosβ-sinα·sinβ) = cosβ·y1 - sinβ·x1
z2 = z1
因此,在已知P1點座標以及旋轉角度β的情況下,我們就可以根據以上公式分別求出P2點座標的各個分量。如果再結合上一小節中平移一個點的公式來看,我們可以發現似乎並不需要矩陣,而僅僅通過兩組表示式就能實現座標的變換。但是……
帶來便捷的矩陣
當然,從理論上講我們的確可以只通過數學公式就能實現變換,但實際的情況卻是在變換十分複雜時,直接使用數學表示式來進行運算也是相當繁複的。因此,在現實中常常使用矩陣(由m × n個標量組成的長方形陣列)來表示諸如平移、旋轉以及縮放等線性變換。而另一個更有趣的事實是,當兩個變換矩陣A和B的積為P=AB時,則變換矩陣P相當於A和B所代表的變換。舉一個例子,若A為旋轉矩陣,B為平移矩陣,則矩陣P就能夠實現旋轉和平移變換。不過需要注意的是,矩陣乘法不符合交換律,因此AB和BA並不相等。說了這麼多,我們似乎還是沒有回答為什麼三維空間需要一個4×4矩陣來實現變換呢?下面我們就帶著這個問題,分別看看3×3矩陣和4×4矩陣的使用吧。
矩陣和旋轉
首先,我們先來看一個矩陣乘以一個三維向量的算式:可以看到該矩陣為一個3×3的矩陣,矩陣的右側是點P1的座標,而矩陣的左側則是點P2的座標。根據這個表示式,我們可以求出x2、y2、z2的值:
x2 = a·x1 + b·y1 + c·z1
y2 = d·x1 + e·y1 + f·z1
z2 = g·x1 + h·y1 + i·z1
為了將矩陣等式和之前小節的數學表示式聯絡起來,下面我們就將旋轉表示式和該矩陣等式做一個對比。
x2 = a·x1 + b·y1 + c·z1x2 = cosβ·x1 + sinβ·y1
y2 = d·x1 + e·y1 + f·z1y2 = cosβ·y1 - sinβ·x1
z2 = g·x1 + h·y1 + i·z1z2 = z1
通過對比x2,我們可以發現a=cosβ,b=sinβ,c=0;對比y2,也可以發現d=-sinβ,e=cosβ,f=0;最後對比z2,可以確定g=0,h=0,i=1;將這個結果帶入到之前的矩陣中,我們的等式就可以變成下面這個樣子:也就是說,通過這個3×3的變換矩陣,我們就已經實現了三維空間的旋轉變換。那麼為什麼還需要使用4×4矩陣呢?
搞不定的平移,4×4矩陣來救場
我們已經通過一個3×3矩陣搞定了旋轉變換,顯然如果這個3×3矩陣真的是完美的解決變換的方案的話,那麼它顯然也必須要適合於其他的變換,例如平移。但是它到底能否滿足平移的需求呢?下面我們還是通過對比矩陣等式和數學表示式的方式,來尋找答案。
x2 = a·x1 + b·y1 + c·z1x2 = x1 + Δx
y2 = d·x1 + e·y1 + f·z1y2 = y1 + Δy
z2 = g·x1 + h·y1 + i·z1z2 = z1 + Δz
通過對比,我們發現平移和旋轉之間很有趣的一個區別,那就是平移的表示式中帶有常量Δx,而無論是旋轉的表示式還是矩陣等式中都不存在這樣一個常量能夠與之對應。那麼問題就來,我們沒有辦法使用3×3的矩陣來表示平移。這個問題該如何解決呢?答案其實很簡單,那就是使用4×4矩陣來實現。但是隨之而來的一個問題就是如何讓一個三維座標和一個4×4的矩陣相乘呢?
齊次座標
為了解決三維向量和4×4矩陣相乘的問題,我們機智的為三維向量新增了第四個分量,這樣之前的三維向量(x,y,z)就變成了四維的(x,y,z,w),這樣由4個分量組成的向量便被稱為齊次座標。需要說明的是,齊次座標(x,y,z,w)等價於三維座標(x/w,y/w,z/w),因此只要w分量的值是1,那麼這個齊次座標就可以被當作三維座標來使用,而且所表示的座標就是以x,y,z這3個值為座標值的點。因此,為了和4×4矩陣相乘,我們的P1點座標就變成了(x1,y1,z1,1)。而矩陣等式也變成了下面這個樣子:我們再將這個新的矩陣等式和平移的數學表示式做一番對比:
x2 = a·x1 + b·y1 + c·z1 + dx2 = x1 + Δx
y2 = e·x1 + f·y1 + g·z1 + hy2 = y1 + Δy
z2 = i·x1 + j·y1 + k·z1 + lz2 = z1 + Δz
1 = m·x1 + n·y1 + o·z1 + p
通過對比x2,我們可以發現a=1,b=0,c=0,d=Δx;對比y2,也可以發現e=0,f=1,g=0,h=Δy;再對比z2,可以確定i=0,j=0,k=1,l=Δz;最後還可以根據表示式求出m=0,n=0,o=0,p=1;這樣,我們就求出了我們的4×4的平移矩陣:
總結
寫到這裡,不知各位是否還記得之前在介紹矩陣乘法的時候我有提到過兩個變換矩陣A和B的積P=AB,相當於A和B所代表的變換。事實上在遊戲程式設計中,常常需要把一連串的變換預先通過計算成為單一矩陣,所以就不能即存在3×3的矩陣又存在4×4的矩陣。而將3×3矩陣擴充成4×4矩陣還是相對更加容易的。這樣,就通過一個4×4矩陣整合了平移矩陣、旋轉矩陣。
相關文章
- 列主序儲存的4x4座標變換矩陣矩陣
- 三維空間座標系變換-旋轉矩陣矩陣
- 三維旋轉矩陣的推導過程(以右手座標系為例)矩陣
- 三維座標系旋轉——旋轉矩陣到旋轉角之間的換算矩陣
- 向量和矩陣的座標變換7矩陣
- Threejs的三維座標系JS
- OpenGL入門第三課--矩陣變換與座標系統矩陣
- 向量和矩陣的座標變換(下標記法)7矩陣
- Tensorflow快餐教程(4) - 矩陣矩陣
- C語言:將一個4X4的矩陣賦值,矩陣元素的值為其行數與列數的乘積C語言矩陣賦值
- 世界座標系到攝像機座標系的矩陣變換推導過程矩陣
- c語言中實現4行3列矩陣和3行4列矩陣的運算C語言矩陣
- 三維旋轉矩陣推導矩陣
- 線性變換和矩陣的橋樑篇2——像的座標標示矩陣
- [轉]旋轉矩陣:點旋轉和座標系旋轉矩陣
- 【教程】4步教你在思維導圖工具XMind中插入矩陣表矩陣
- gps wgs4座標與高德gcj02座標互轉GC
- C語言:求4x4矩陣外圍元素之和C語言矩陣
- Matlab三維空間座標圖繪製Matlab
- 指標-矩陣下三角元素之和指標矩陣
- python兩個三階矩陣相乘Python矩陣
- flutter佈局-5-Matrix4矩陣變換Flutter矩陣
- 生成一個掃雷矩陣矩陣
- 三維旋轉矩陣 左乘和右乘分析矩陣
- 利用齊次座標進行二維座標轉換
- 240. 搜尋二維矩陣 II 和74. 搜尋二維矩陣矩陣
- 已知一個矩陣,將矩陣中和值最大的一行元素與首行互換矩陣
- 第四章:多維陣列和矩陣 ------------- 4.8 子矩陣的最大累加和陣列矩陣
- 資料結構之陣列和矩陣--矩陣&不規則二維陣列資料結構陣列矩陣
- 巨大的矩陣(矩陣加速)矩陣
- stm32 F103C8T6 4x4矩陣鍵盤使用矩陣
- LeetCode 74——搜尋二維矩陣LeetCode矩陣
- 二維旋轉矩陣推導矩陣
- 74_搜尋二維矩陣矩陣
- 74. 搜尋二維矩陣矩陣
- DL4J實戰之五:矩陣操作基本功矩陣
- 二維座標離散化模板
- 資料結構:陣列,稀疏矩陣,矩陣的壓縮。應用:矩陣的轉置,矩陣相乘資料結構陣列矩陣