算法應用 | 機器學習python應用,初識機器學習是怎樣滴感受?

​ 本系列文章主要介紹機器學習在實踐中的應用,介紹利用 Python 的生態環境,使用機器學習的算法來解決工程實踐中的問題,而不是介紹算法本身。本系列文章參考了《機器學習Python實踐》,會通過例子一步一步地引導大家使用機器學習來處理和分類與迴歸模型相關的問題。每個算法模型都介紹其較爲通用且實用的建模過程,力爭使基礎較差的讀者也能無障礙利用python來使用機器學習算法。

1 初識機器學習

1.1 什麼是機器學習

機器學習流程

​ 機器學習(Machine Leaming , ML)是一門多領域的交叉學科,涉及概率論、統計學、線性代數、算法等多門學科。 它專門研究計算機如何模擬和學習人的行爲,以獲取新的知識或技能,重新組織已有的知識結構使之不斷完善自身的性能。

​ 機器學習已經有了十分廣泛的應用,例如:數據挖掘、計算機視覺、自然語言處理、生物特徵識別、搜索引擎、醫學診斷、檢測信用卡欺詐、證券市場分析、 DNA 序列測序、語音和手寫識別、戰略遊戲和機器人運用。

​ 機器學習的算法分爲兩大類 : 監督學習和無監督學習 。

​ 監督學習即在機器學習過程中提供對錯指示。一般是在數據組中包含最終結果(0 , 1),通過算法讓機器自己減少誤差。這一類學習主要應用於分類和預測(Regression &Classify) 。監督學習從給定的訓練數據集中學習出一個目標函數,當新的數據到來時,可以根據這個函數預測結果。監督學習的訓練集要求包括輸入和輸出,也可以說包括特徵和目標,訓練集中的目標是由人標註的。常見的監督學習算法包括迴歸分析和統計分類。非監督學習又稱歸納性學習(Clustering),利用 K 方式(KMean)建立中心( Centriole),通過循環和遞減運算(lteration&Descent)來減小誤差,達到分類的目的 。

​ 機器學習解決的問題:分類,迴歸,降維,聚類。其中有些算法適合多種問題,有些只適合解決一種問題,下面列出一些常見的一些機器學習算法。

  • 分類算法:邏輯迴歸,貝葉斯
  • 迴歸算法:線性迴歸,嶺迴歸,lasso,彈性網絡
  • 聚類:Kmeans,DBSCAN,層次聚類,光譜聚類
  • 分類&迴歸:KNN,決策樹,神經網絡,隨機森林,梯度提升樹、xgboost
  • 分類&迴歸&聚類:SVM
  • 降維:PCA

1.2 學習機器學習的誤區

​ 在學習機器學習之前,有一些理解和誤區需要先做好說明,防止大家在學習機器學習的過程中過於鑽牛角尖。對於通過Python來基本實現機器學習算法,有幾個誤區可能是比較廣泛存在的,應該儘量避免:

​ 1、必須非常熟悉Python的語法和擅長Python的編程。實際上並不需要,Python有scikit-learn模塊等可以直接進行建模的調用包,基本只需要學會python的各種基礎的知識和應用,熟悉scikit-learn的相關模型用法,以及包括numpy、pandas、matplotlib模塊在內的常用的數據處理和可視化包,就可以實現各種機器學習算法了。

​ 2、必須非常深入地學習和理解在scikit- learn中使用的機器學習的理論和算法。實際上也不需要,除非你是這一方向的碩士甚至博士學位的學習者。機器學習不同的算法涉及的知識點是非常廣闊的,要做到每一種算法的理論知識的學習都非常深入,是比較難的,實際上簡單的機器學習應用中,只需要瞭解不同算法的基礎知識就可以使用了。

​ 3、學習知識就行了,不需要做什麼項目。恰恰相反,機器學習的應用是需要大量的項目經驗積累,才能把機器學習用得更好。

​ 這些方式對一部分人可能會非常有效,但是這會降低掌握機器學習技能的速度和要達到通過機器學習來解決問題的目標。這也會浪費大量時間單獨學習機器學習算法,但卻不知如何利用機器學習來解決現實中遇到的問題。 實際上利用Python來實現機器學習算法的門檻並不高,在基本運用過程中,只需要瞭解機器學習各種算法的一些基礎知識,一些常用流程和不同算法,數據集的適用要求就可以了。

1.3 Python 中的機器學習

​ 本系列文章主要關注監督學習中的分類與迴歸問題處理的預測模型,這是在工業中應用非常廣泛的分類,也是scikit-leam擅長的一個領域。與統計學不同,機器學習的預測模型是用來理解數據、解決問題的;聚焦於如何創建一個更加精準的模型,而不是用來解釋模型是如何設置的。與大部分機器學習的領域不同的是,預測模型是使用表格格式的數據作爲模型的輸入的,因此數據的採集和整理是很重要的工作。

​ 在接下來的一系列文章中,致力於讓大家能夠學習在項目中如何將機器學習的任務和Python有機地結合在一起,以便實現每一個機器學習問題的最佳實踐。通過各種實例來理解學到的預測模型的知識。儘量完善一套較爲通用的機器學習建模過程,通過python的一系列方法,力求只是進行簡單的複製粘貼操作就可以啓動一個新的機器學習項目。

​ 我們將通過項目來介紹基於Python的生態環境如何完成機器學習的相關工作。一旦明白瞭如何使用Python平臺來完成機器學習的任務,就可以在不同的項目中重複使用這種方法解決問題。利用機器學習的預測模型來解決問題共有六個基本步驟。

機器學習流程

  • 定義問題: 研究和提煉問題的特徵,以幫助我們更好地理解項目的目標。
  • 數據理解: 通過描述性統計和可視化來分析現有的數據。
  • 數據準備: 對數據進行格式化,以便於構建一個預測模型 。
  • 評估算法: 通過一定的方法分離一部分數據,用來評估算法模型,並選取一部分代表數據進行分析,以改善模型。
  • 優化模型: 通過調參和集成算法提升預測結果的準確度。
  • 結果部署: 完成模型,並執行模型來預測結果和展示。

1.4 學習機器學習的原則和技巧

​ 學習機器學習是一段旅程。需要知道自己具備的技能、目前所掌握的知識,以及明確要達到的目標。要實現自己的目標需要付出時間和辛勤的工作 ,但是在目標的實現過程中 ,有很多工具可以幫助你快速達成目標。

​ 1、創建半正式的工作產品。以博客文章、技術報告和代碼存儲的形式記下學習和發現的內容,快速地爲自己和他人提供一系列可以展示的技能、知識及反思。

​ 2、實時學習。不能僅在需要的時候才學習複雜的主題,例如,應該實時學習足夠的概率和線性代數的知識來幫助理解正在處理的算法。在開始進入機器學習領域之前,不需要花費太多的時間來專門學習統計和數學方面的知識,而是要在平時的使用和參與過程中不斷地進行實時學習,積累知識。

​ 3、利用現有的技能。如果可以編碼,那麼通過實現算法來理解它們,而不是研究數學理論。使用自己熟悉的編程語言,讓自己專注於正在學習的一件事情上,不要同時學習一種新的語言、工具或類庫,這樣會使學習過程複雜化。
​ 掌握是理想。掌握機器學習需要持續不斷的學習。也許你永遠不可能實現掌握機器學習的目標,只能持續不斷地學習和改進所掌握的知識。

下面三個技巧可以有效地幫助你快速提高學習機器學習的能力。

  • 啓動一個可以在一個小時內完成的小項目。
  • 通過每週完成一個項目來保持你的學習勢頭,並建立積累自己的項目工作區。
  • 在微博、微信、博客、 Github 等社交工具上分享自己的成果,或者隨時隨地地展示自己的興趣,增加技能、知識,並獲得反饋。

1.5 總結

​ 這一系列的文章主要是寫給對機器學習感興趣和立志學習機器學習,但只有機器學習基礎知識的甚至沒多少了解人羣,主要是介紹關於機器學習實踐的內容,而不是關於機器學習的理論知識。 這裏只會簡單介紹機器學習的基本原理和算法。在這裏假設你已經掌握了機器學習的基礎知識,或者有能力自己來完成機器學習的基礎知識的學習。

​ 有一些人可能只是對機器學習的理論知識比較瞭解,但是沒有多少項目實踐應用,對於機器學習的應用實踐可能不怎麼了解;有一些人則可能只是對機器學習有一個大概的瞭解,不知道能通過什麼樣的工具和方法來使用,該如何使用。而在本系列文章中,將會引導讀者如何通過Python實踐機器學習算法。

2 Python機器學習的生態圈

​ 隨着 Python 生態圈的發展,在機器學習領域,Python 已經發展成爲機器學習方面最主要的語言。Python 爲什麼能夠成爲機器學習的主流語言?這是因爲 Python 不僅可以應用在R&D科研部門,也可以應用在實際的生產當中。本段將主要介紹Python在機器學習方面的生態圈。

2.1 Python

機器學習流程

​ Python是一門面向對象的動態解釋語言,簡單易學,並且具有很好的可讀性。Python語法簡潔清晰,特色之一是強制用空白符(White Space)作爲語句縮進。Python 具有豐富和強大的類庫,它常被稱爲“膠水語言”,能夠很輕鬆地把用其他語言製作的各種模塊(尤其是C/C++)聯結在一起。常見的一種應用情形是,先使用 Python 快速生成程序的原型(有時甚至是程序的最終界面),然後對其中有特別要求的部分用更合適的語言改寫, 比如 3D遊戲對圖形渲染模塊的性能要求特別高,就可以用 C/C++重寫,而後封裝爲 Python可以調用的擴展類庫。目前,在 Python 的生態圈中存在大量的第三方擴展類庫,可以藉助這些類庫輕鬆實現項目需求。需要注意的是,在使用擴展類庫時可能需要考慮平臺問題,某些擴展類庫可能不提供跨平臺的實現。Python 目前是一門非常流行的語言,在 TIOBE最新推出的2020年1月編程語言排名位列第三,用戶使用率穩居前三。

TIOBE排名

在PYPL各種編程語言的流行程度的統計中,最新一期2020年1月Python的排名遙遙領先。

PYPL排行榜

​ Python 是一門動態語言,非常適合於交互性開發和大型項目的快速原型開發。由於Python 具有豐富的類庫支持,因此被廣泛應用於機器學習和數據科學方面。從這個方面來說,利用 Python 可以將研究項目和生產項目用統一的語言來實現,這就有效地降低了將研究項目轉化成生產項目的成本。

2.2 SciPy

​ SciPy 是在數學運算、科學和工程學方面被廣泛應用的Python 類庫。它包括統計、優化、整合、線性代數模塊、傅里葉變換、信號和圖像處理、常微分方程求解器等,因此被廣泛地應用在機器學習項目中 。 SciPy 依賴以下幾個與機器學習相關的類庫。

​ NumPy:是 Python 的一種開源數值計算擴展。它可用來存儲和處理大型矩陣,提供了許多高級的數值編程工具, 如矩陣數據類型、矢量處理、精密的運算庫。

​ Pandas:是基於 NumPy 的一種工具,是爲了解決數據分析任務而創建的 。 Pandas 納入了大量庫和一些標準的數據模型,提供了高效地操作大型數據集所需的工具,也提供了大量能使我們快速、便捷地處理數據的函數和方法 。

​ Matplotlib:Python中最著名的20繪圖庫,十分適合交互式地進行製圖;也可以方便地將它作爲繪圖控件,嵌入GUI應用程序中 。

​ 熟悉 SciPy 是提高機器學習實踐的有效手段,尤其是在以下幾個方面:

  • 可以利用 NumPy 數組來準備機器學習算法的數據 。
  • 通過 Pandas 導入、展示數據,以便增強對數據的理解和數據清洗、轉換等工作。
  • 可以使用 Matplotlib 來創建圖表,展示數據。

2.3 scikit-learn

機器學習流程

​ scikit-leam是Python中開發和實踐機器學習的著名類庫之一,依賴於SciPy及其相關類庫來運行。scikit-leam的基本功能主要分爲六大部分:分類、迴歸、聚類、數據降維、模型選擇和數據預處理。需要指出的是,由於scikit-leam本身不支持深度學習,也不支持GPU加速,因此 scikit-leam對於多層感知器(MLP)神經網絡的實現並不適合處理大規模問題。(scikit-leam對MLP 的支持在 0.18 版之後增加)

​ scikit-leam是一個開源項目,遵守BSD協議,可以將項目應用於商業開發。目前主要由社區成員自發進行維護。可能是由於維護成本的限制,scikit-leam相比其他項目要顯得更爲保守,這主要體現在兩個方面 :

  • scikit-leam 從來不做除機器學習領域之外的其他擴展。
  • scikit-leam 從來不採用未經廣泛驗證的算法。

​ 比方說,神經網絡不見得比決策樹好,同樣反過來也不成立。最後的結果是有很多因素在起作用的,比方說數據集的大小以及組成。

​ 所以,針對你要解決的問題,最好是嘗試多種不同的算法。並借一個測試集來評估不同算法之間的表現,最後選出一個結果最好的。當然,你要選適合解決你問題的算法來嘗試。比方說,要打掃房子,你會用真空吸塵器,掃把,拖把;你絕對不會翻出一把鏟子來開始挖坑,對吧。

​ 面對海量的機器學習算法,萌新最愛問的是:“我該選什麼算法?” 在回答這個問題之前,要先想清楚:

  • 數據的數量、質量、本質

  • 可供計算的時間

  • 這個任務的緊急程度

  • 你用這個數據想做什麼。

    要知道,即使是老司機,也無法閉着眼睛說哪個算法能拿到最好的結果。還是得動手試。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章