色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

scikit-learn的操作流程幾一體化實現的優勢

lviY_AI_shequ ? 2017-12-08 13:40 ? 次閱讀

scikit-learn簡介

scikit-learn是Python最為流行的一個機器學習庫。它具有如下吸引人的特點:

簡單、高效且異常豐富的數據挖掘/數據分析算法實現;

基于NumPy,SciPy,以及matplotlib,從數據探索性分析,數據可視化到算法實現,整個過程一體化實現;

尤其是當我們要進行多種算法的效果對比評價,這種一體化實現的優勢就更加能夠凸顯出來了。

既然scikit-learn模塊如此重要,廢話不多說,下面馬上開搞!

項目組織及文件加載

項目組織

工作路徑:`D:\my_python_workfile\Thesis\sklearn_exercise` |--data:用于存放數據 |--20news-bydate:練習用數據集 |--20news-bydate-train:訓練集 |--20news-bydate-test:測試集

文件加載

假設我們需要加載的數據,組織結構如下:

container_folder/ category_1_folder/ file_1.txt file_2.txt ... file_42.txt category_2_folder/ file_43.txt file_44.txt ...

可以使用以下函數進行數據的加載:

sklearn.datasets.load_files(container_path, description=None, categories=None, load_content=True, shuffle=True, encoding=None, decode_error='strict', random_state=0)

參數解釋:

`container_path`:container_folder的路徑;

`load_content = True`:是否把文件中的內容加載到內存;

`encoding = None`:編碼方式。當前文本文件的編碼方式一般為“utf-8”,如果不指明編碼方式(encoding=None),那么文件內容將會按照bytes處理,而不是unicode處理。

返回值:Bunch Dictionary-like object.主要屬性有

data:原始數據;

filenames:每個文件的名字;

target:類別標簽(從0開始的整數索引);

target_names:類別標簽的具體含義(由子文件夾的名字`category_1_folder`等決定)。

下面,即采用這種方式,使用測試數據集[The 20 Newsgroups data set](Home Page for 20 Newsgroups Data Set:http://qwone.com/~jason/20Newsgroups/)進行實例演示。先從網上下載該數據集,再在本地進行數據的加載。

```python# 加載庫import osimport sys##配置utf-8輸出環境#reload(sys)#sys.setdefaultencoding("utf-8")# 設置當前工作路徑os.chdir("D:\\my_python_workfile\\Thesis\\sklearn_exercise")# 加載數據from sklearn import datasetstwenty_train = datasets.load_files("data/20news-bydate/20news-bydate-train")twenty_test = datasets.load_files("data/20news-bydate/20news-bydate-test")``````pythonlen(twenty_train.target_names),len(twenty_train.data),len(twenty_train.filenames),len(twenty_test.data)```

(20, 11314, 11314, 7532)

```python print("\n".join(twenty_train.data[0].split("\n")[:3])) ```

From: cubbie@garnet.berkeley.edu ( )

Subject: Re: Cubs behind Marlins? How?

Article-I.D.: agate.1pt592$f9a

```python print(twenty_train.target_names[twenty_train.target[0]]) ```

rec.sport.baseball

```python twenty_train.target[:10] ```

array([ 9, 4, 11, 4, 0, 4, 5, 5, 13, 12])

可見,文件已經被成功載入。

當然,作為入門的訓練,我們也可以使用`scikit-learn`自帶的`toy example`數據集進行測試、玩耍。下面,介紹一下如何加載自帶的數據集。

```python from sklearn.datasets import fetch_20newsgroups categories = ['alt.atheism', 'soc.religion.christian', 'comp.graphics', 'sci.med'] twenty_train = fetch_20newsgroups(subset='train', categories=categories, shuffle=True, random_state=42) ```文本特征提取

文本數據屬于非結構化的數據,一般要轉換成結構化的數據,方能進行實施機器學習算法實現文本分類。

常見的做法是將文本轉換成『文檔-詞項矩陣』。矩陣中的元素,可以使用詞頻,或者TF-IDF值等。

計算詞頻

```python from sklearn.feature_extraction.text import CountVectorizer count_vect = CountVectorizer(stop_words="english",decode_error='ignore') X_train_counts = count_vect.fit_transform(twenty_train.data) X_train_counts.shape ```

(11314, 129783)

使用TF-IDF進行特征提取

```python from sklearn.feature_extraction.text import TfidfTransformer tf_transformer = TfidfTransformer(use_idf = False).fit(X_train_counts) X_train_tf = tf_transformer.transform(X_train_counts) X_train_tf.shape ```

(11314, 129783)

以上程序使用了兩步進行文本的形式化表示:先用`fit()`方法使得模型適用數據;再用`transform()`方法把詞頻矩陣重新表述成TF-IDF.

如下所示,也可以一步到位進行設置。

```python tfidf_transformer = TfidfTransformer() X_train_tfidf = tfidf_transformer.fit_transform(X_train_counts) X_train_tfidf.shape ```

(11314, 129783)]

分類器訓練

```python from sklearn.naive_bayes import MultinomialNB clf = MultinomialNB().fit(X_train_tfidf,twenty_train.target) ``````python # 對新的樣本進行預測 docs_new = ['God is love','OpenGL on the GPU is fast'] X_new_counts = count_vect.transform(docs_new) X_new_tfidf = tfidf_transformer.transform(X_new_counts) predicted = clf.predict(X_new_tfidf) for doc,category in zip(docs_new,predicted): print("%r => %s") %(doc,twenty_train.target_names[category]) ```

'God is love' => soc.religion.christian

'OpenGL on the GPU is fast' => comp.graphics

分類效果評價

建立管道

```python from sklearn.pipeline import Pipeline text_clf = Pipeline([('vect',CountVectorizer(stop_words="english",decode_error='ignore')), ('tfidf',TfidfTransformer()), ('clf',MultinomialNB()), ]) text_clf = text_clf.fit(twenty_train.data,twenty_train.target) ```

測試集分類準確率

```python import numpy as np docs_test = twenty_test.data predicted = text_clf.predict(docs_test) np.mean(predicted == twenty_test.target) ```

0.81691449814126393

使用樸素貝葉斯分類器,得到的測試集分類準確率為81.7%,效果還不錯!

下面,使用線性核支持向量機看看效果如何。

```python from sklearn.linear_model import SGDClassifier text_clf_2 = Pipeline([('vect',CountVectorizer(stop_words='english',decode_error='ignore')), ('tfidf',TfidfTransformer()), ('clf',SGDClassifier(loss = 'hinge',penalty = 'l2', alpha = 1e-3,n_iter = 5, random_state = 42)), ]) _ = text_clf_2.fit(twenty_train.data,twenty_train.target) predicted = text_clf_2.predict(docs_test) np.mean(predicted == twenty_test.target) ```

0.82355284121083383

支持向量機的分類準確率有所提升。

`scikit-learn`中提供了更精細化的評價指標,如:各類別的精確度,召回率,F值等。

下面,我們來看看更詳細的指標表現如何。

```python from sklearn import metrics print(metrics.classification_report(twenty_test.target,predicted, target_names = twenty_test.target_names)) ```

precision recall f1-score support

alt.atheism 0.71 0.71 0.71 319

comp.graphics 0.81 0.69 0.74 389

comp.os.ms-windows.misc 0.72 0.79 0.75 394

comp.sys.ibm.pc.hardware 0.73 0.66 0.69 392

comp.sys.mac.hardware 0.82 0.83 0.82 385

comp.windows.x 0.86 0.77 0.81 395

misc.forsale 0.80 0.87 0.84 390

rec.autos 0.91 0.90 0.90 396

rec.motorcycles 0.93 0.97 0.95 398

rec.sport.baseball 0.88 0.91 0.90 397

rec.sport.hockey 0.87 0.98 0.92 399

sci.crypt 0.85 0.96 0.90 396

sci.electronics 0.80 0.62 0.70 393

sci.med 0.90 0.87 0.88 396

sci.space 0.84 0.96 0.90 394

soc.religion.christian 0.75 0.93 0.83 398

talk.politics.guns 0.70 0.93 0.80 364

talk.politics.mideast 0.92 0.92 0.92 376

talk.politics.misc 0.89 0.56 0.69 310

talk.religion.misc 0.81 0.39 0.53 251

avg / total 0.83 0.82 0.82 7532

測試集的精確度和召回率的表現均不錯.

下面看看『混淆矩陣』的結果。

```python metrics.confusion_matrix(twenty_test.target,predicted) ```使用網格搜索進行參數優化

我們使用分類器進行文本分類的過程中,有些參數需要預先給定。如前面`TfidfTransformer()`中的`use_idf`;`MultinomialNB()`中的平滑參數`alpha`;`SGClassifier()`中的懲罰系數`alpha`。然而,參數設置為多少,并不能直接拍腦袋決定。因為參數的設置可能會導致結果天差地別。

為了不淪落為一個『調參狗』,我們來看看如何使用暴力的『網格搜索算法』讓計算機幫我們進行參數尋優。

```python from sklearn.grid_search import GridSearchCV parameters = { 'vect__ngram_range':[(1,1),(1,2)], 'tfidf__use_idf':(True,False), 'clf__alpha':(1e-2,1e-3) } ```

如果要窮盡所有參數的組合,那勢必要花費很多時間來等待結果。有的『土豪』同學可能會想:我能不能用金錢來換時間?

答案是肯定的。如果你有一臺8核的電腦,那就把所有的核都用上吧!

```python gs_clf = GridSearchCV(text_clf_2,parameters,n_jobs = -1) ``` ```python gs_clf = gs_clf.fit(twenty_train.data,twenty_train.target) ```

設置`n_jobs = -1`,計算機就會幫你自動檢測并用上你所有的核進行并行計算。

```python best_parameters,score,_ = max(gs_clf.grid_scores_,key = lambda x:x[1]) for param_name in sorted(parameters.keys()): print("%s: %r" %(param_name,best_parameters[param_name])) ```

clf__alpha: 0.01

tfidf__use_idf: True

vect__ngram_range: (1, 1)

```python score ```

0.90516174650875025

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 機器學習
    +關注

    關注

    66

    文章

    8414

    瀏覽量

    132612
  • 數據可視化
    +關注

    關注

    0

    文章

    466

    瀏覽量

    10252
  • 算法實現
    +關注

    關注

    1

    文章

    3

    瀏覽量

    1848
收藏 人收藏

    評論

    相關推薦

    Python機器學習庫談Scikit-learn技術

    Scikit-learn API內置了各種toy和real-world數據集[1]。這些可以便捷地通過行代碼訪問,如果你正在學習或只是想快速嘗試新功能,這會非常有用。
    的頭像 發表于 08-27 17:34 ?3135次閱讀
    Python機器學習庫談<b class='flag-5'>Scikit-learn</b>技術

    什么是機電一體化

    像人類那樣會思考判斷。4) 機電一體化的例子機電一體化產品中定有運動機械,并且采用了電子技術使運動機械實現柔性和智能
    發表于 08-29 09:06

    機電一體化系統

    如圖1.1所示,機電一體化系統與靈活性和智能型最強的人體相對應,由如下5個要素構成;1) 機械裝置:能夠實現某種運動的機構(相當于人類的骨骼)。2) 執行裝置:驅動機械裝置運動的部分(相當于人類
    發表于 08-29 09:11

    一體化模塊貼片機概述

    集成到個機器平臺系統中,實現了電子裝配設備的一體化。臺這樣的設備就可以完成電子裝配生產線上多個工藝流程,代替了傳統上的組合式生產線?! ?/div>
    發表于 09-04 15:43

    如何實現機電一體化設計?

    用戶總是要求我們提高所設計的機械的性能,同時減少資金成本。為了達到這兩個矛盾的目標,我們將注意力放到在機械設計方面有巨大潛力的機電一體化上。本文著重展示了使用嵌入式分析工具的現代計算機輔助設計(CAD)系統,告訴大家,如何才能實現機電
    發表于 08-07 06:48

    通用Python機器學習庫scikit-learn

    《利用Python進行數據分析》 134 scikit-learn介紹
    發表于 10-25 07:58

    如何實現一體化芯片-封裝協同設計系統的設計?

    如何實現一體化芯片-封裝協同設計系統的設計?如何優化封裝和芯片接口設計?
    發表于 04-21 07:01

    一體化伺服電機如何保存當前參數

    本文僅適用于立邁勝PMM系列一體化伺服電機出現的常見問題。如您的伺服電機是其他型號的請謹慎操作。解決方法如下:一體化伺服電機如何保存當前參數?在H1010-01寫0x65766173
    發表于 06-28 07:18

    一體化步進電機的優勢有哪些?為什么選一體化步進電機?

    一體化閉環步進電機具有哪些優點?參數是什么?
    發表于 10-13 06:34

    測控一體化閘門系統

    測控一體化閘門系統關鍵字:測控一體化閘門系統 智能一體化閘門 灌區水閘自動控制云傳物聯測控一體化閘門系統集閘門遠程/自動控制、渠道水位流量
    發表于 08-25 14:34

    基于Python的scikit-learn編程實例

    scikit-learn 是機器學習領域非常熱門的個開源庫,基于Python 語言寫成??梢悦赓M使用。 網址: 上面有很多的教程,編程實例。而且還做了很好的總結,下面這張圖基本概括了傳統機器學習
    發表于 11-15 19:39 ?1676次閱讀

    詳細解析scikit-learn進行文本分類

    而多類別分類指的是y的可能取值大于2,但是y所屬類別是唯的。它與多標簽分類問題是有嚴格區別的。所有的scikit-learn分類器都是默認支持多類別分類的。但是,當你需要自己修改算法的時候,也是可以使用scikit-learn
    的頭像 發表于 12-27 08:36 ?4745次閱讀
    詳細解析<b class='flag-5'>scikit-learn</b>進行文本分類

    scikit-learn K近鄰法類庫使用的經驗總結

    本文對scikit-learn中KNN相關的類庫使用做了個總結,主要關注于類庫調參時的個經驗總結,且非常詳細地介紹了類庫的參數含義。
    的頭像 發表于 01-13 11:49 ?3229次閱讀
    <b class='flag-5'>scikit-learn</b> K近鄰法類庫使用的經驗總結

    基于Python的scikit-learn實現機器學習

    基于Python的scikit-learn實現機器學習。
    發表于 03-26 09:42 ?11次下載
    基于Python的<b class='flag-5'>scikit-learn</b>包<b class='flag-5'>實現</b>機器學習

    Scikit-learn機器學習庫的概念及工作原理

    作為個適用于 Python 編程語言的機器學習 (ML) 庫,Scikit-learn 擁有大量算法,可供程序員和數據科學家在機器學習模型中輕松部署。
    的頭像 發表于 09-30 11:00 ?1458次閱讀
    主站蜘蛛池模板: 红杏俱乐部| 欧美动物交ideos| 国产精品麻豆AV| 国产精品一区二区欧美视频| 国产伦子沙发午休系列资源曝光 | 女神被调教成了精盆| 青青草原成人| 我的奶头被客人吸的又肿又红| 亚洲激情网站| 中俄两军在日本海等上空战略巡航| 69成人免费视频| 俄罗斯14一18处交| 护士WC女子撒尿| 男生jj插入女生jj| 无码乱人伦一区二区亚洲| 亚洲综合色五月久久婷婷| 67194免费入口| 国产白丝精品爽爽久久蜜臀| 娇妻在床上迎合男人| 嗯啊哈啊好棒用力插啊| 色综合五月激情综合色一区| 亚洲午夜精品A片久久WWW软件| 97超在线视频| 国产成人a一在线观看| 精品一产品大全| 破苞流血哭泣 magnet| 香港成人社区| 97色伦亚洲自偷| 国产精品热久久高潮AV袁孑怡| 久久中文字幕免费高清| 乳巨揉みま痴汉电车中文字幕动漫| 亚洲国产黄色| 99久久99久久久精品久久| 国产福利视频一区二区| 日韩精品真人荷官无码| 善良的小峓子2在钱免费中文字 | 美娇妻的性奴史1一4| 双性被疯狂灌满精NP| 中文字幕天堂久久精品| 国产精品成人不卡在线观看| 老师你奶真大下面水真多|