十大最受歡迎的機器學習和數據科學Python庫
2018年將會是人工智能和機器學習快速發展的一年,有專家表示:相較之下Python比Java更加接地氣,也自然而然地成為機器學習的首選語言
在數據科學方面,Python的語法與數學語法最為接近,因此是數學家或經濟學家等專業人士最容易理解和學習的語言。本文將羅列機器學習和數據科學應用程序中最有用的十大Python工具。
機器學習工具
1、Shogun
SHOGUN是一個機器學習工具箱,專注于支持向量機(SVM)的學習工具箱。它是用C++編寫的,早在1999年就已經創建,是最古老的機器學習工具之一,它提供了廣泛的統一機器學習方法,旨在為機器學習提供透明和可訪問的算法,并為任何對此領域感興趣的人提供免費的機器學習工具。
Shogun提供了一個記錄完善的Python界面用于統一的大規模學習,并提供高性能速度。不過,Shogun的缺點就是它的API很難使用。(項目地址:https://github.com/shogun-toolbox/shogun)
2、Keras
Keras是一個高級神經網絡API,提供了一個Python深度學習庫。對于任何初學者來說,這是機器學習的最佳選擇,因為與其他庫相比,它提供了一種更簡單的表達神經網絡的方法。Keras由純Python編寫而成并基Tensorflow、Theano以及CNTK后端。
據官方網站稱,Keras側重于4個主要指導原則,即用戶友好性,模塊化,易擴展性和與Python協作。然而,就速度而言,Keras 相對還是比較弱的。(項目地址:https://github.com/keras-team/keras)
3、scikit-learn
scikit-learn 是一個 Python 的機器學習項目。是一個簡單高效的數據挖掘和數據分析工具?;?NumPy、SciPy 和 matplotlib 構建。Scikit-Learn提供了一致且易于使用的API網格以及隨機搜索。其主要優勢算法簡單而且速度快。Scikit-learn的基本功能主要被分為六大部分:分類,回歸,聚類,數據降維,模型選擇和數據預處理(項目地址:https://github.com/scikit-learn/scikit-learn)
4、Pattern
Pattern是一個Web挖掘模塊,為數據挖掘,自然語言處理,機器學習,網絡分析和網絡分析提供工具。它還附帶完善的文檔,有50多個示例以及通過350多個單元測試。最重要的是,它是免費的!(項目地址:https://github.com/clips/pattern)
5、Theano
Theano可以說是最成熟的Python深度學習庫之一,Theano是以以為希臘畢達哥拉斯哲學家和數學家畢達哥拉斯的妻子的名字命名,Theano的主要功能:與NumPy緊密集成,用符號式語言定義你想要的結果,該框架會對你的程序進行編譯,來高效運行于 GPU 或 CPU。
它還提供了定義,優化和評估數學表達式的工具,并且可以在Theano上構建大量其他庫,以探索其數據結構。盡管如此,使用Theano還是有一些缺點的; 比如學習它的API可能需要很長時間,而另一些人則認為Theano大模型的編譯時間顯的它不夠高效(項目地址:https://github.com/Theano/Theano)
數據科學工具
1、SciPy
SciPy (pronounced "Sigh Pie") 是一個開源的數學、科學和工程計算包。SciPy使用NumPy,IPython或Pandas等各種軟件包為常用的數學和科學編程任務提供庫。當你想操縱計算機上的數字并顯示或發布結果時,此工具是一個很好的選擇,并且它也是免費的。(項目地址:https://github.com/scipy/scipy)
2、Dask
Dask 是一個用于分析計算的靈活的并行計算庫。同樣,通過更改只有幾行代碼,你可以快速對現有代碼進行并行處理,因為它的DataFrame與Pandas庫中的相同,它的Array對象的工作方式類似于NumPy能夠并行化以純Python編寫。(項目地址:https://github.com/dask/dask)
3、Numba
此工具是一種開源優化編譯器,它使用LLVM編譯器基礎結構將Python語法編譯為機器碼。在數據科學應用中使用Numba的主要優勢在于它使用NumPy數組來加速應用程序的能力,因為Numba是一個支持NumPy的編譯器。就像Scikit-Learn一樣,Numba也適用于機器學習應用。(項目地址:https://github.com/numba/numba)
4、HPAT
高性能分析工具包(HPAT)是一個基于編譯器的大數據框架。它將Python中的分析/機器學習代碼自動擴展到群集/云環境中的大數據分析和機器學習,并可以使用@jit裝飾器優化特定功能。(項目地址:https://github.com/IntelLabs/hpat)
5、Cython
使用數學密碼或密碼循環運行的代碼時,Cython是您的最佳選擇。Cython是一款基于Pyrex的源代碼翻譯器,可快速生成Python擴展模塊(extention module)的工具。Cython語言非常接近Python語言,但是Cython還支持調用C函數并在變量和類屬性上聲明C類型。這允許編譯器從Cython代碼生成非常高效的C代碼。(項目地址:https://github.com/cython/cython)