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

2021-01-11 CDA數據分析師

本系列文章主要介紹機器學習在實踐中的應用,介紹利用 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降維:PCA1.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月程式語言排名位列第三,用戶使用率穩居前三。

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

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 從來不採用未經廣泛驗證的算法。比方說,神經網絡不見得比決策樹好,同樣反過來也不成立。最後的結果是有很多因素在起作用的,比方說數據集的大小以及組成。

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

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

數據的數量、質量、本質可供計算的時間這個任務的緊急程度你用這個數據想做什麼。要知道,即使是老司機,也無法閉著眼睛說哪個算法能拿到最好的結果。還是得動手試。

相關焦點

  • 算法應用|機器學習python應用,簡單機器學習項目實踐
    上一篇文章中介紹了機器學習的簡單知識,還有python中進行機器學習實踐需要的生態環境,接下來將會通過鳶尾花分類這個例子對機器學習做一個簡要的介紹。通過一步一步地實現這個項目來介紹以下內容。導入和使用python中機器學習的各個方面的類庫。
  • 機器學習、深度學習算法原理與案例實踐暨Python大數據綜合應用...
    原標題:機器學習、深度學習算法原理與案例實踐暨Python大數據綜合應用高級研修班通信和信息技術創新人才培養工程項目辦公室 通人辦〔2018〕 第5號 機器學習、深度學習算法原理與案例實踐暨Python
  • 63種機器學習算法
    但是有一個問題,機器學習是複雜的,對於剛進入該領域的人來說,這是第一次在B學校中學習它,似乎很難將這些概念與繁忙的日程一起掌握。 以前沒有編碼經驗的B-school學生,機器學習很困難,一個人會迷失在監督學習與無監督學習的所有不同算法和分支中。 它們背後的數學很難理解並且學習曲線陡峭。 對於開始,python或R本身似乎是一個波濤洶湧的大海,需要一些專門的實踐。
  • 機器學習庫Scikit-learn的算法分類及其應用場景
    機器學習庫擁有豐富的開源實現,從單機的Scikit-learn到分布式的MLLib,它們各有特色,被廣泛應用在各種數據處理的場景。本文將介紹機器學習庫Scikit-learn的算法分類及其應用場景。Scikit-learn是構建在Python基礎上的機器學習庫,由於其簡單且高效,而備受開發者歡迎。Scikit-learn將算法分為六個類別,如下圖所示:
  • 學習python應用,初識python怎樣的感受?
    線性回歸可能是最常見的算法之一,線性回歸是機器學習實踐者必須知道的。這通常是初學者第一次接觸的機器學習算法,了解它的操作方式對於更好地理解它至關重要。所以,簡單地說,讓我們來分解一下真正的問題:什麼是線性回歸?
  • 深度學習:機器學習算法及其在人工智慧領域的應用
    人工智慧時代,掌握機器學習算法對於未來職業發展至關重要,推薦這門由ViaX打造的機器學習算法應用課程。與其他機器學習課程不同,該課程由全球頂校頂級AI專家設計並指導學習,課程採用根據學生的能力、基礎和興趣,採用分小組、分方向方式學習;還可以發表1篇Scopus或同等級國際英文會議,值得學習。
  • 盤點:機器學習的十大應用案例
    準確地診斷和治療病人,零售商使用機器學習在正確的時間把商品送到指定商店,研究人員利用這項技術開發新藥。這些只是實際應用的一小部分,從能源、公用事業到旅行酒店,再到製造、物流等行業,各種組織和職能都在越來越多地使用機器學習。
  • ...旨在加速Google的機器學習算法並提高Google Assistant應用的...
    該處理器包含八個Arm內核和一些其他矽晶片,旨在加速Google的機器學習算法並提高Google Assistant應用的性能。據報導,該晶片使用三星的5LPE工藝技術製造。該處理器包含八個Arm內核和一些其他矽晶片,旨在加速Google的機器學習算法並提高Google Assistant應用的性能。據報導,該晶片使用三星的5LPE工藝技術製造。
  • python機器學習之使用scikit-learn庫
    scikit-learning庫python庫scikit-learn整合了多種機器學習算法。2007年,Cournapeu開始開發這個庫,但是直到2010年才發布它的第一個版本。這個庫是SciPy(scientific Python,python科學計算)工具集的一部分,該工具集包含多個為科學計算尤其是數據分析而開發的庫。
  • Python機器學習教程
    可以用於機器學習應用程式的其他程式語言是R,C ++,JavaScript,Java,C#,Julia,Shell,TypeScript和Scala。R還是一種非常好的機器學習入門語言。與其他程式語言相比,Python以其可讀性和相對較低的複雜性而聞名。機器學習應用程式涉及複雜的概念,例如微積分和線性代數,這些實現需要花費很多精力和時間。
  • 跟著吳恩達老師學習機器學習,Python筆記分享!
    純手擼python線性回歸算法:逐步版上面這篇文章只在單個變量的數據集上有用。但是在現實生活中絕大多數數據集有多個變量。使用同一個簡單公式你可以開發出多變量的算法。python多元線性回歸算法逐步演示多項式回歸這個是線性回歸的姊妹。
  • Python 機器學習庫 Top 10,你值得擁有!
    原文:https://hackernoon.com/top-10-libraries-in-python-to-implement-machine-learning-12602cf5dc61隨著人工智慧技術的發展與普及,Python 超越了許多其他程式語言,成為了機器學習領域中最熱門最常用的程式語言之一。
  • Minitab中的機器學習和Python集成
    Minitab 在上一版的基礎上,採用一種快捷易用的界面,提供了一個應用範圍最廣、同時也是最實用的預測工具。更快的效率分析海量數據,更快的模型構建和驗證意味著更快的發現洞察力。通過單擊、而不是代碼、Minitab的協助菜單以及Python集成和改進的圖形等新特性,讓一切在您組織裡共享成果前所未有的簡單。
  • 機器學習的七大應用領域
    但在目前,對於算法和技術的認識與開發還存在局限。因此,科學家從方法論、技術開發、多學科融合等方面不斷探索機器學習在各個領域應用的可能。概要機器學習 · 計算機體系結構算法軟硬體的交融,將促進新一代計算系統的到來。機器學習 · 物理科學基礎科學與前沿機器學習將會碰出怎樣的火花?
  • 學了這麼久,你知道Python機器學習全流程是怎樣的麼?
    幸運的是,Python 是當前普遍使用的流行語言,並納入了科學計算和機器學習的內容,所以找到入門教程並不困難。在選擇起點時,很大程度上要取決於你之前的 Python 經驗和編程經驗。這裡推薦幾本python入門必讀書籍:別再說你不知道怎麼學習Python了,13本書給你安排的明明白白!
  • 流行的機器學習算法總結,幫助你開啟機器學習算法學習之旅
    AI的ML領域是為實現非常精確的目標而創建的,它引入了多種算法,從而可以更順暢地進行數據處理和決策。什麼是機器學習算法?機器學習算法是任何模型背後的大腦,可讓機器學習並使其更智能。這些算法的工作方式是,為它們提供第一批數據,並且隨著時間的流逝和算法的準確性的提高,額外的數據也被引入到算法中。
  • 你了解機器學習知識體系嗎
    1.初識人工智慧人工智慧(Artificial Intelligence),英文縮寫為AI。它是研究、開發用於模擬、延伸和擴展人工智慧的理論、方法、技術及應用系統的一門新的技術科學。本文將結合自身多年開發經驗和對人工智慧的認識,帶領大家對人工智慧領域的一個小分支--機器學習進行深入研究,深度理解機器學習中的常用算法。雖然機器學習是人工智慧中的一小部分內容,但是確實人工智慧中的核心部分。
  • Python機器學習教程詳解
    通過構建這種精確的機器學習模型,企業可以利用有利可圖的機會並避免未知的風險。圖像識別,文本生成和許多其他用例正在現實世界中找到應用。這擴大了機器學習專家成為受追捧的專業人員的視野。機器學習算法這可能是您機器學習過程中最耗時且最困難的過程。機器學習中有很多算法,您不需要完全了解它們就可以入門。
  • python機器學習之k-means聚類算法(1)
    k-means算法是一種無監督的機器學習算法,雖然是機器學習,但它簡單易於實現。本篇採用python語言,自主編程實現k-menas算法,當然python用專門的庫函數來實現該算法,但本次主要使用該算法闡述編程思想,所以不採用內置函數。採用自主編寫的程序的方式。
  • 隱藏在機器視覺中的6種常見機器學習應用
    無論是電子商務還是醫療保健,幾乎所有行業都在廣泛使用機器學習來製作未來派解決方案和產品。機器學習在很大程度上取決於幫助機器進行自我學習而無需明確指示的程序和算法。機器學習幾乎決定了我們的日常生活-您想知道如何?讓我們看一下機器學習的頂級應用,以了解它如何塑造數字經濟。