機器學習演算法筆記之6:資料預處理
一、概述
在工程實踐中,我們得到的資料會存在有缺失值、重複值等,在使用之前需要進行資料預處理。資料預處理沒有標準的流程,通常針對不同的任務和資料集屬性的不同而不同。資料預處理的常用流程為:去除唯一屬性、處理缺失值、屬性編碼、資料標準化正則化、特徵選擇、主成分分析。
二、資料預處理方法
1. 去除唯一屬性
唯一屬性通常是一些id屬性,這些屬性並不能刻畫樣本自身的分佈規律,所以簡單地刪除這些屬性即可。
2. 處理缺失值
缺失值處理的三種方法:直接使用含有缺失值的特徵;刪除含有缺失值的特徵(該方法在包含缺失值的屬性含有大量缺失值而僅僅包含極少量有效值時是有效的);缺失值補全。
常見的缺失值補全方法:均值插補、同類均值插補、建模預測、高維對映、多重插補、極大似然估計、壓縮感知和矩陣補全。
(1)均值插補
如果樣本屬性的距離是可度量的,則使用該屬性有效值的平均值來插補缺失的值;如果的距離是不可度量的,則使用該屬性有效值的眾數來插補缺失的值。
(2)同類均值插補
首先將樣本進行分類,然後以該類中樣本的均值來插補缺失值。
(3)建模預測
將缺失的屬性作為預測目標來預測,將資料集按照是否含有特定屬性的缺失值分為兩類,利用現有的機器學習演算法對待預測資料集的缺失值進行預測。
該方法的根本的缺陷是如果其他屬性和缺失屬性無關,則預測的結果毫無意義,但是若預測結果相當準確,則說明這個缺失屬性是沒必要納入資料集中的,一般的情況是介於兩者之間。
(4)高維對映
將屬性對映到高維空間,採用獨熱碼編碼(one-hot)技術。將包含K個離散取值範圍的屬性值擴充套件為K+1個屬性值,若該屬性值缺失,則擴充套件後的第K+1個屬性值置為1。
這種做法是最精確的做法,保留了所有的資訊,也未新增任何額外資訊,若預處理時把所有的變數都這樣處理,會大大增加資料的維度。這樣做的好處是完整保留了原始資料的全部資訊、不用考慮缺失值;缺點是計算量大大提升,且只有在樣本量非常大的時候效果才好。
(5)多重插補(MultipleImputation,MI)
多重插補認為待插補的值是隨機的,實踐上通常是估計出待插補的值,再加上不同的噪聲,形成多組可選插補值,根據某種選擇依據,選取最合適的插補值。
(6)壓縮感知和矩陣補全
(7)小結
插補處理只是將未知值補以我們的主觀估計值,不一定完全符合客觀事實。在許多情況下,根據對所在領域的理解,手動對缺失值進行插補的效果會更好。
3. 特徵編碼
(1)特徵二元化
特徵二元化的過程是將數值型的屬性轉換為布林值的屬性,設定一個閾值作為劃分屬性值為0和1的分隔點。
(2)獨熱編碼(One-HotEncoding)
獨熱編碼採用N位狀態暫存器來對N個可能的取值進行編碼,每個狀態都由獨立的暫存器來表示,並且在任意時刻只有其中一位有效。
獨熱編碼的優點:能夠處理非數值屬性;在一定程度上擴充了特徵;編碼後的屬性是稀疏的,存在大量的零元分量。
4. 資料標準化、正則化
資料標準化
資料標準化是將樣本的屬性縮放到某個指定的範圍。
資料標準化的原因:
某些演算法要求樣本具有零均值和單位方差;
需要消除樣本不同屬性具有不同量級時的影響:①數量級的差異將導致量級較大的屬性佔據主導地位;②數量級的差異將導致迭代收斂速度減慢;③依賴於樣本距離的演算法對於資料的數量級非常敏感。
min-max標準化:對於每個屬性,設minA和maxA分別為屬性A的最小值和最大值,將A的一個原始值x通過min-max標準化對映成在區間[0,1]中的值x',其公式為:新資料=(原資料 - 最小值)/(最大值 - 最小值)
z-score標準化:基於原始資料的均值(mean)和標準差(standarddeviation)進行資料的標準化。將A的原始值x使用z-score標準化到x'。z-score標準化方法適用於屬性A的最大值和最小值未知的情況,或有超出取值範圍的離群資料的情況。新資料=(原資料- 均值)/ 標準差
均值和標準差都是在樣本集上定義的,而不是在單個樣本上定義的。標準化是針對某個屬性的,需要用到所有樣本在該屬性上的值。
資料正則化
資料正則化是將樣本的某個範數(如L1範數)縮放到到位1,正則化的過程是針對單個樣本的,對於每個樣本將樣本縮放到單位範數。
設資料集。對樣本首先計算Lp範數:
正則化後的結果為:每個屬性值除以其Lp範數:
5. 特徵選擇
從給定的特徵集合中選出相關特徵子集的過程稱為特徵選擇,進行特徵選擇的兩個主要原因是:減輕維數災難問題;降低學習任務的難度。
進行特徵選擇必須確保不丟失重要特徵。常見的特徵選擇方法分為三類:過濾式(filter)、包裹式(wrapper)、嵌入式(embedding)。
過濾式選擇:該方法先對資料集進行特徵選擇,然後再訓練學習器。特徵選擇過程與後續學習器無關。Relief是一種著名的過濾式特徵選擇方法。
包裹式選擇:該方法直接把最終將要使用的學習器的效能作為特徵子集的評價原則。其優點是直接針對特定學習器進行優化,因此通常包裹式特徵選擇比過濾式特徵選擇更好,缺點是由於特徵選擇過程需要多次訓練學習器,故計算開銷要比過濾式特徵選擇要大得多。
嵌入式選擇。
6. 稀疏表示和字典學習
字典學習:學習一個字典,通過該字典將樣本轉化為合適的稀疏表示形式。
稀疏編碼:獲取樣本的稀疏表達。
相關文章
- 機器學習筆記---資料預處理機器學習筆記
- 機器學習一:資料預處理機器學習
- 機器學習:探索資料和資料預處理機器學習
- YOLOv3學習筆記之資料處理YOLO筆記
- 機器學習 第2篇:資料預處理(缺失值)機器學習
- Python深度學習(處理文字資料)--學習筆記(十二)Python深度學習筆記
- 100天搞定機器學習|Day1資料預處理機器學習
- 深度學習--資料預處理深度學習
- 機器學習學習筆記之——演算法鏈與管道機器學習筆記演算法
- 機器學習 第3篇:資料預處理(使用插補法處理缺失值)機器學習
- 機器學習演算法學習筆記機器學習演算法筆記
- swoft 學習筆記之異常處理筆記
- 深度學習(6)——預處理Preprocessing深度學習
- 深度學習——資料預處理篇深度學習
- 機器學習筆記——資料集分割機器學習筆記
- 機器學習演算法筆記之5:支援向量機SVM機器學習演算法筆記
- 【Pandas學習筆記02】-資料處理高階用法筆記
- 【Pandas學習筆記02】處理資料實用操作筆記
- 機器學習 第4篇:資料預處理(sklearn 插補缺失值)機器學習
- [PyTorch 學習筆記] 2.2 圖片預處理 transforms 模組機制PyTorch筆記ORM
- 機器學習演算法筆記之8:聚類演算法機器學習演算法筆記聚類
- 機器學習導圖系列(1):資料處理機器學習
- 機器學習演算法筆記之3:線性模型機器學習演算法筆記模型
- 機器學習筆記(KNN演算法)機器學習筆記KNN演算法
- 6種方式處理機器學習中不平衡的資料集 - svpino機器學習
- 《Python機器學習手冊:從資料預處理到深度學習》Python機器學習深度學習
- React學習筆記-事件處理React筆記事件
- 【機器學習演算法】KNN鳶尾花種類預測案例和特徵預處理。全md文件筆記(已分享,附程式碼)機器學習演算法KNN特徵筆記
- python機器學習筆記:EM演算法Python機器學習筆記演算法
- 機器學習演算法:Logistic迴歸學習筆記機器學習演算法筆記
- SpringMVC學習筆記6-指定處理請求型別SpringMVC筆記型別
- 機器學習演算法筆記之4:貝葉斯分類器機器學習演算法筆記
- 機器學習學習筆記機器學習筆記
- 菜鳥學習筆記:Java提升篇6(IO流2——資料型別處理流、列印流、隨機流)筆記Java資料型別隨機
- 機器學習中資料缺失的處理及建模方法機器學習
- Dotnetty學習筆記——自定義初始化處理器Netty筆記
- 機器學習筆記機器學習筆記
- Vue學習筆記之事件處理Vue筆記事件