書籍介紹
內容簡介
本書通過通俗易懂的語言、豐富的圖示和生動的實例,撥開了籠罩在機器學習上方複雜的數學“烏雲”,讓讀者以較低的代價和門檻入門機器學習。
本書共分為11章,介紹了在Python環境下學習Scikit-learn機器學習框架的相關知識,涵蓋的主要內容有機器學習概述、Python機器學習軟體包、機器學習理論基礎、k-近鄰算法、線性回歸算法、邏輯回歸算法、決策樹、支持向量機、樸素貝葉斯算法、PCA算法和k-均值算法等。
本書適合有一定編程基礎的讀者閱讀,尤其適合想從事機器學習、人工智慧、深度學習及機器人相關技術的程式設計師和愛好者閱讀。另外,相關院校和培訓機構也可以將本書作為教材使用。
30秒極速了解本書精華內容
1. 理論基礎
機器學習的套用場景
機器學習編程的典型步驟
Python機器學習開發包:numpy、pandas和matplotlib
算法模型性能評估的指標和評估方法
2. 八大常用機器學習算法
k-近鄰算法
線性回歸算法
邏輯回歸算法
決策樹
支持向量機
樸素貝葉斯
PCA算法
k-均值算法
3. 七大實戰演練案例
糖尿病檢測
預測房價
乳腺癌檢測
鐵達尼號倖存者預測
文檔類別預測
人臉識別
文檔自動分類
本書特色
1.用通俗易懂的語言介紹機器學習算法的原理,符合初學者的認知規律
本書講解時首先會用通俗易懂的語言介紹常用的機器學習算法,幫助讀者直觀地理解每個算法的基本原理,然後用大量的圖示及實例介紹如何使用scikit-learn工具包解決現實生活中的機器學習問題。這種由淺入深、循序漸進的講授方式,完全遵循了初學者對機器學習算法的認知規律。
2.豐富的示例圖片,可以幫助讀者更加直觀地理解算法背後的原理
機器學習以其背後複雜的數學原理及異常複雜的算法推導和證明過程而嚇退了一大批讀者。一圖勝千言,本書給出了大量的圖示,用圖片的方式形象地介紹了算法的基本原理,讓讀者對算法有更加直觀的理解。這樣就把複雜的數學公式和冗長的文字描述濃縮到一張張圖片中,有效地降低了學習的門檻。
3.實例豐富,可以幫助讀者使用機器學習算法解決工程套用問題
手寫識別程式怎么做?怎么實現人臉識別系統?怎么過濾垃圾郵件?電子商務網站上猜你喜歡的商品是什麼原理?怎么實現的?電影網站怎樣去推薦符合用戶喜好的電影?怎么利用機器學習對消費者的特性進行細分,從而更好地服務好各細分市場的消費者?銀行怎樣去檢測用戶的信用卡可能被盜了?通過閱讀本書,讀者將了解到這些複雜問題背後的原理,甚至你都可以自己解決這些問題。
目錄
前言
第1章 機器學習介紹1
1.1 什麼是機器學習1
1.2 機器學習有什麼用2
1.3 機器學習的分類3
1.4 機器學習套用開發的典型步驟4
1.4.1 數據採集和標記4
1.4.2 數據清洗5
1.4.3 特徵選擇5
1.4.4 模型選擇5
1.4.5 模型訓練和測試5
1.4.6 模型性能評估和最佳化5
1.4.7 模型使用6
1.5 複習題6
第2章 Python機器學習軟體包7
2.1 開發環境搭建7
2.2 IPython簡介8
2.2.1 IPython基礎8
2.2.2 IPython圖形界面13
2.3 Numpy簡介15
2.3.1 Numpy數組15
2.3.2 Numpy運算19
2.4 Pandas簡介32
2.4.1 基本數據結構32
2.4.2 數據排序34
2.4.3 數據訪問34
2.4.4 時間序列36
2.4.5 數據可視化36
2.4.6 檔案讀寫38
2.5 Matplotlib簡介38
2.5.1 圖形樣式38
2.5.2 圖形對象40
2.5.3 畫圖操作46
2.6 scikit-learn簡介51
2.6.1 scikit-learn示例51
2.6.2 scikit-learn一般性原理和通用規則55
2.7 複習題56
2.8 拓展學習資源57
第3章 機器學習理論基礎58
3.1 過擬合和欠擬合58
3.2 成本函式59
3.3 模型準確性60
3.3.1 模型性能的不同表述方式61
3.3.2 交叉驗證數據集61
3.4 學習曲線62
3.4.1 實例:畫出學習曲線62
3.4.2 過擬合和欠擬合的特徵65
3.5 算法模型性能最佳化65
3.6 查準率和召回率66
3.7 F1 Score67
3.8 複習題67
第4章 k-近鄰算法69
4.1 算法原理69
4.1.1 算法優缺點69
4.1.2 算法參數70
4.1.3 算法的變種70
4.2 示例:使用k-近鄰算法進行分類70
4.3 示例:使用k-近鄰算法進行回歸擬合72
4.4 實例:糖尿病預測74
4.4.1 載入數據74
4.4.2 模型比較75
4.4.3 模型訓練及分析77
4.4.4 特徵選擇及數據可視化78
4.5 拓展閱讀80
4.5.1 如何提高k-近鄰算法的運算效率80
4.5.2 相關性測試80
4.6 複習題81
第5章 線性回歸算法83
5.1 算法原理83
5.1.1 預測函式83
5.1.2 成本函式84
9.3 機率分布154
9.3.1 機率統計的基本概念154
9.3.2 多項式分布155
9.3.3 高斯分布158
9.4 連續值的處理159
9.5 實例:文檔分類160
9.5.1 獲取數據集160
9.5.2 文檔的數學表達161
9.5.3 模型訓練163
9.5.4 模型評價165
9.6 複習題167
第10章 PCA算法168
10.1 算法原理168
10.1.1 數據歸一化和縮放169
10.1.2 計算協方差矩陣的特徵向量169
10.1.3 數據降維和恢復170
10.2 PCA 算法示例171
10.2.1 使用Numpy模擬PCA計算過程171
10.2.2 使用sklearn進行PCA降維運算173
10.2.3 PCA的物理含義174
10.3 PCA 的數據還原率及套用175
10.3.1 數據還原率175
10.3.2 加快監督機器學習算法的運算速度176
10.4 實例:人臉識別176
10.4.1 載入數據集176
10.4.2 一次失敗的嘗試179
10.4.3 使用PCA來處理數據集182
10.4.4 最終結果185
10.5 拓展閱讀189
10.6 複習題189
第11章 k-均值算法190
11.1 算法原理190
11.1.1 k-均值算法成本函式191
11.1.2 隨機初始化聚類中心點191
11.1.3 選擇聚類的個數192
11.2 scikit-learn里的k-均值算法192
11.3 使用k-均值對文檔進行聚類分析195
11.3.1 準備數據集195
11.3.2 載入數據集196
11.3.3 文本聚類分析197
11.4 聚類算法性能評估200
11.4.1 Adjust Rand Index200
11.4.2 齊次性和完整性201
11.4.3 輪廓係數203
11.5 複習題204
後記205