特征臉(Eigenface)理論基礎之PCA主成分分析法
在之前的博客 人臉識別經(jīng)典算法一:特征臉方法(Eigenface)里面介紹了特征臉方法的原理,但是并沒有對它用到的理論基礎PCA做介紹,現(xiàn)在做補充。請將這兩篇博文結合起來閱讀。以下內容大部分參考自斯坦福機器學習課程:http://cs229.stanford.edu/materials.html
假設我們有一個關于機動車屬性的數(shù)據(jù)集{x(i);i=1,...,m}(m代表機動車的屬性個數(shù)),例如最大速度,最大轉彎半徑等。假設x(i)本質上是n維的空間的一個元素,其中n<<m,但是n對我們來說是未知的。假設xi和xj分別代表車以英里和公里為單位的最大速度。顯然這兩個屬性是冗余的,因為它們兩個是有線性關系而且可以相互轉化的。因此如果僅以xi和xj來考慮的話,這個數(shù)據(jù)集是屬于m-1維而不是m維空間的,所以n=m-1。推廣之,我們該用什么方法降低數(shù)據(jù)冗余性呢?
首先考慮一個例子,假設有一份對遙控直升機操作員的調查,用x(i)1(1是下標,原諒我這操蛋的排版吧)表示飛行員i的飛行技能,x(i)2表示飛行員i喜歡飛行的程度。通常遙控直升飛機是很難操作的,只有那些非常堅持而且真正喜歡駕駛的人才能熟練操作。所以這兩個屬性x(i)1和x(i)2相關性是非常強的。我們可以假設兩者的關系是按正比關系變化的,如下圖里的u1所示,數(shù)據(jù)散布在u1兩側是因為有少許噪聲。
接下來就是如何計算u1的方向了。首先我們需要預處理數(shù)據(jù)。
1.令
2.用x(i)-μ替代x(i)
3.求
4.用x(i)j/σj替代x(i)j
步驟1-2其實是將數(shù)據(jù)集的均值歸零,也就是只取數(shù)據(jù)的偏差部分,對于本身均值為零的數(shù)據(jù)可以忽略這兩步。步驟3-4是按照每個屬性的方差將數(shù)據(jù)重新度量,也可以理解為歸一化。因為對于不同的屬性(比如車的速度和車座數(shù)目)如果不歸一化是不具有比較性的,兩者不在一個量級上。如果將pca應用到圖像上的話是不需要步驟3-4的,因為每個像素(相當于不同的屬性)的取值范圍都是一樣的。
數(shù)據(jù)經(jīng)過如上處理之后,接下來就是尋找數(shù)據(jù)大致的走向了。一種方法是找到一個單位向量u,使所有數(shù)據(jù)在u上的投影之和最大,當然數(shù)據(jù)并不是嚴格按照u的方向分布的,而是分布在其周圍。考慮下圖的數(shù)據(jù)分布(這些數(shù)據(jù)已經(jīng)做了前期的預處理)。
下圖中,星號代表數(shù)據(jù),原點代表數(shù)據(jù)在單位向量u上的投影(|x||u|cosΘ)
從上圖可以看到,投影得到的數(shù)據(jù)仍然有很大的方差,而且投影點離原點很遠。如果采取與上圖u垂直的方向,則可以得到下圖:
這里得到的投影方差比較小,而且離原點也更近。
上述u的方向只是感性的選擇出來的,為了將選擇u的步驟正式確定下來,可以假定在給定單位向量u和數(shù)據(jù)點x的情況下,投影的長度是xTu。舉個例子,如果x(i)是數(shù)據(jù)集中的一個點(上圖中的一個星號),那它在u上的投影xTu就是圓點到原點的距離(是標量哦)。所以,為了最大化投影的方差,我們需要選擇一個單位向量u來最大化下式:
明顯,按照||u||2=1(確保u是單位向量)來最大化上式就是求的主特征向量。而
其實是數(shù)據(jù)集的協(xié)方差矩陣。
做個總結,如果我們要找數(shù)據(jù)集分布的一維子空間(就是將m維的數(shù)據(jù)用一維數(shù)據(jù)來表示),我們要選擇協(xié)方差矩陣的主特征向量。推廣之,如果要找k維的子空間,那就應該選擇協(xié)方差矩陣的k個特征向量u1,u2,...,uk。ui(i=1,2,...,k)就是用來表征數(shù)據(jù)集的新坐標系。
為了在u1,u2,...,uk的基礎上表示x(i),我們只需要計算
其中x(i)是屬于n維空間的向量,而y(i)給出了基于k維空間的表示。因此說,PCA是一個數(shù)據(jù)降維算法。u1,u2,...,uk稱為數(shù)據(jù)的k個主成分。
介紹到這里,還需要注意一些為題:
1、為什么u要選擇單位向量
選擇單位向量是為了統(tǒng)一表示數(shù)據(jù),不選成單位的也可以,但各個向量長度必須統(tǒng)一,比如統(tǒng)一長度為2、3等等。
2、各個u要相互正交
如果u不正交,那么在各個u上的投影將含有冗余成分
2、為什么要最大化投影的方差
舉個例子,如果在某個u上的投影方差為0,那這個u顯然無法表示原數(shù)據(jù),降維就沒有意義了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
windows+vscode安裝paddleOCR運行環(huán)境的步驟
這篇文章主要介紹了windows+vscode安裝paddleOCR運行環(huán)境,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11快速實現(xiàn)基于Python的微信聊天機器人示例代碼
本篇文章主要介紹了快速實現(xiàn)基于Python的微信聊天機器人示例代碼,基于itchat開發(fā),可以用它做一個微信聊天機器人,有興趣的可以了解一下。2017-03-03Python調用OpenCV實現(xiàn)圖像平滑代碼實例
這篇文章主要介紹了Python調用OpenCV實現(xiàn)圖像平滑代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-06-06