本書面向初學者,比較全面的介紹了機器學習的基本方法,循序漸進的闡述了其中的數(shù)學原理,讓讀者能夠知其然,然后知其所以然。書中結合應用場景,列舉了大量編程實例幫助讀者開展動手實踐,理論與實踐相輔相成,對算法原理產生更加直觀和感性的認識。作者希望能夠通過本書幫助讀者揭開人工智能領域的神秘面紗,走進人工智能和機器學習的大門,了解其中的奧秘,甚至成為該領域的學習者、研究者和實踐者。
從發(fā)明計算機的天起,人們就試圖用計算機模擬自身智能。如今,計算機已經從只能完成四則運算的計算器,發(fā)展成為能勝任很多復雜任務的智能機器。在各種應用領域中,計算機已經成為人類大腦的延伸。人工智能的研究使計算機能夠模擬人類思維的感知、學習、解決問題和推理決策的能力,與此同時,也幫助我們對自身智能有了更加深入的理解。
人工智能的研究者把人工智能分為強人工智能和弱人工智能兩類。這種劃分既是技術層面的,也是哲學層面的。如果機器表現(xiàn)出像人一樣智能的行為,那么是否可以認為機器真的在像人一樣思考呢?計算機科學和神經生物科學尚不能回答這個問題,哲學家也沒有找到滿意的答案。強人工智能的觀點認為,人工智能應該像人一樣具有自主的意識、情感和心智,能夠理解和學習任何智能問題。弱人工智能的觀點則僅關注機器在特定任務上所表現(xiàn)出的智能性,并不關心機器是否能真正像人一樣自主思考。只要在特定領域能夠幫助我們解決一些實際的智能問題,這樣的機器都可以視作擁有弱人工智能。
強人工智能現(xiàn)在還是一種理論設想,它如同人一樣具有高度的自主性,不僅可以解決不同類型的問題,甚至具有自主選擇解決什么問題的能力。它有自己的意識和感情,但是它只存在于電影、小說等科學幻想作品中。
哲學家和科學家通過思想實驗,對強人工智能的觀點提出了各種懷疑,比如,中文屋子實驗和換腦實驗。
中文屋子實驗設想有一個英語母語者,對中文一竅不通。他被關在一間屋子里,屋子里有一本英文寫成的手冊來說明中文的語法規(guī)則,另外還有一大堆中文符號。屋子外面的人從窗口傳進用中文寫成的問題,屋子里的人按照手冊上的規(guī)則將中文符號組成答案傳遞出去。這個過程足以以假亂真,讓屋子外面的人誤以為屋子里的人懂得中文,然而事實上他壓根不懂中文。強人工智能就如同屋子里的人,如果我們只能看到他表現(xiàn)出智能,如何知道他是否真的在思考呢?
換腦實驗則更加科幻。假設我們的神經生理學和計算機硬件已經高度發(fā)達,完全了解大腦所有神經元的連接機制,并且能夠用微電路模擬大腦神經網絡的所有活動。設想我們把生物的大腦替換為電子的大腦,讓電子的大腦接管一切輸入的感官信號,并做出反應,輸出對身體肌肉的控制信號。從外界看來,所有智能行為和活動跟換腦之前并無差異,那么現(xiàn)在電子大腦具有自我意識嗎?或者意識還存在于那個生物大腦之中嗎?生物大腦中的意識會不會試圖吶喊我什么也看不到,卻無法控制發(fā)聲的肌肉呢?這個假想的實驗有些駭人聽聞,但是同樣讓我們懷疑外在表現(xiàn)出的智能是否等同于自主意識。
弱人工智能不再糾結于機器是否真的具有了自主意識,只關注表現(xiàn)出的智能。計算機科學家圖靈提出了圖靈測試,用來判斷機器是否具有智能。測試者通過屏幕和鍵盤分別與一個真實的人和一臺智能機器聊天,如果無法區(qū)分屏幕后面是人還是機器,那么就可以認為機器具有如同人一樣的智能。相比圖靈測試,弱人工智能的定義更加寬泛,它只要求機器能夠處理具體領域的特定任務。
在現(xiàn)實生活中,弱人工智能的應用比比皆是。手機可以聽懂我們的語音指令;攝像頭可以辨別電腦的主人、進出停車場的車輛號牌;電子監(jiān)控代替了交通警察,輔助查處違章的車輛;翻譯軟件幫助外國游客把路牌、標識、菜單等翻譯成他們熟悉的語言;自動駕駛系統(tǒng)甚至在受限的環(huán)境中也可以自主控制車輛,從而解放駕駛員的雙手。這些都是弱人工智能的應用。
弱人工智能關注于處理特定的任務,弱字用在這里并不完全合適,在限定領域或者特定任務中,弱人工智能其實并不弱,稱作窄人工智能更為恰當。相比存在于科學幻想中的強人工智能,人們對應用于各種受限場景的弱人工智能有更加成熟的研究。雖然它不像人的智能一樣具有理解、學習任何問題的能力,但是它通?梢栽谀硞領域做得很好,甚至比人做得更好,畢竟機器更準確,更穩(wěn)定,更迅速,而且不知疲倦。因此,弱人工智能得到了廣泛的應用,成為人們生活和工作的得力助手。弱人工智能是我們向強人工智能發(fā)起探索的階段性成果,人們不會放棄對更加通用智能的探索,會持續(xù)追尋理解和復現(xiàn)自身智能的夢想。只有逐步擴展弱人工智能的邊界,連接和打通各種不同的任務和信息通道,才能幫助我們實現(xiàn)更加復雜和通用的智能。
在人工智能研究并不很長的歷史上,研究者探索了很多種不同的方法和路徑。比如,符號主義的研究者認為,智能可以通過如同數(shù)學推導一樣的邏輯推演系統(tǒng)實現(xiàn),各種知識可以用符號表示出來,組織成計算機能夠處理的語言進行演算、分析和推理。再如,聯(lián)結主義的研究者認為,智能存在于神經元的連接中,采用電子裝置模擬生物大腦的神經元連接就可以實現(xiàn)智能。這些不同的學派在早期的人工智能研究中,在相當長的一段時間內占據(jù)了主導地位。而機器學習則是在這些研究的基礎上,利用統(tǒng)計學的原理取得成功的一類算法和模型。機器學習側重于從樣本或者經驗組成的數(shù)據(jù)中學習統(tǒng)計規(guī)律,通過自我修正的方式達到完成特定任務的目標。機器學習與一般計算機算法顯著的區(qū)別在于,完成任務的步驟中有一些不確定的參數(shù),人
序言
前言
部分
第 1 章 專家系統(tǒng) 2
1.1 早期的專家系統(tǒng) 2
1.2 正向推理 4
1.3 逆向推理 5
1.4 謂詞邏輯 6
1.5 專家系統(tǒng)的貢獻和困難 7
1.6 動手實踐 9
1.6.1 簡化的專家系統(tǒng) 10
1.6.2 正向推理 10
1.6.3 逆向推理 11
參考文獻 13
第 2 章 決策樹 14
2.1 分類問題 15
2.2 構造決策樹 16
2.3 ID3 算法 17
2.4 信息熵 19
2.5 基尼不純度 21
2.6 動手實踐 22
2.6.1 計算信息熵 22
2.6.2 構造決策樹 23
2.6.3 使用 scikit-learn軟件包 27
參考文獻 30
第 3 章 神經元和感知機 31
3.1 生物神經元 31
3.2 早期感知機模型 33
3.3 現(xiàn)代的模型 34
3.4 學習模型參數(shù) 36
3.4.1 梯度下降法 36
3.4.2 Delta 法則 37
3.5 動手實踐 38
3.5.1 實現(xiàn)感知機模型 38
3.5.2 識別手寫數(shù)字 43
參考文獻 48
第 4 章 線性回歸 49
4.1 線性回歸概述 49
4.2 小二乘法 51
4.3 矩陣形式 52
4.4 一般性的回歸問題 54
4.5 動手實踐 54
4.5.1 實現(xiàn)一維線性回歸 54
4.5.2 實現(xiàn)小二乘法 56
4.5.3 使用 numpy 軟件包 59
第 5 章 邏輯斯蒂回歸和分類器 64
5.1 分類問題 64
5.2 似然估計 66
5.3 交叉熵損失函數(shù) 67
5.4 多類別分類 68
5.4.1 多類別邏輯斯蒂回歸 69
5.4.2 歸一化指數(shù)函數(shù) 70
5.4.3 交叉熵誤差和均方誤差的比較 72
5.5 分類器的決策邊界 73
5.6 支持向量機 75
5.6.1 支持向量 77
5.6.2 拉格朗日乘子法 78
5.6.3 非線性分類與核函數(shù) 80
5.7 動手實踐 82
5.7.1 使用邏輯斯蒂回歸 82
5.7.2 觀察分類邊界 83
5.7.3 使用支持向量機 85
參考文獻 87
第二部分
第 6 章 人工神經網絡 90
6.1 異或問題和多層感知機 90
6.2 反向傳播算法 92
6.3 深度神經網絡 94
6.3.1 生物神經機制的啟示 94
6.3.2 解決深度神經網絡面臨的問題 95
6.4 卷積和池化 98
6.4.1 神經連接的局部性 98
6.4.2 平移不變性 99
6.4.3 卷積處理圖像的效果 99
6.4.4 簡單細胞和復雜細胞的仿生學 102
6.5 循環(huán)神經網絡 103
6.6 使用 PyTorch 軟件包 104
6.7 動手實踐 106
6.7.1 識別手寫數(shù)字 106
6.7.2 準備訓練數(shù)據(jù) 109
6.7.3 訓練神經網絡模型 110
6.8 物