100天搞定機器學習|Day13-14 SVM的實現

来源:https://www.cnblogs.com/jpld/archive/2019/07/10/11166990.html
-Advertisement-
Play Games

機器學習100天|Day1數據預處理 100天搞定機器學習|Day2簡單線性回歸分析 100天搞定機器學習|Day3多元線性回歸 100天搞定機器學習|Day4-6 邏輯回歸 100天搞定機器學習|Day7 K-NN 100天搞定機器學習|Day8 邏輯回歸的數學原理 100天搞定機器學習|Day9 ...


機器學習100天|Day1數據預處理

100天搞定機器學習|Day2簡單線性回歸分析

100天搞定機器學習|Day3多元線性回歸

100天搞定機器學習|Day4-6 邏輯回歸

100天搞定機器學習|Day7 K-NN

100天搞定機器學習|Day8 邏輯回歸的數學原理

100天搞定機器學習|Day9-12 支持向量機

100天搞定機器學習|Day11 實現KNN

昨天我們學習了支持向量機基本概念,重申數學推導原理的重要性並向大家介紹了一篇非常不錯的文章。今天,我們使用Scikit-Learn中的SVC分類器實現SVM。我們將在day16使用kernel-trick實現SVM。   導入庫  
import numpy as np 
import matplotlib.pyplot as plt 
import pandas as pd

   

導入數據 數據集依然是Social_Network_Ads,下載鏈接: https://pan.baidu.com/s/1cPBt2DAF2NraOMhbk5-_pQ 提取碼:vl2g
dataset = pd.read_csv('Social_Network_Ads.csv') X = dataset.iloc[:, [2, 3]].values y = dataset.iloc[:, 4].values
拆分數據集為訓練集合和測試集合  
from sklearn.model_selection import train_test_split X_train, X_test, y_train, y_test = train_test_split(X, y, test_size = 0.25, random_state = 0)

   

特征量化  
from sklearn.preprocessing import StandardScaler sc = StandardScaler() X_train = sc.fit_transform(X_train) X_test = sc.fit_transform(X_test)

   

適配SVM到訓練集合  
from sklearn.svm import SVC classifier = SVC(kernel = 'linear', random_state = 0) classifier.fit(X_train, y_train)

   

預測測試集合結果  
y_pred = classifier.predict(X_test) 
創建混淆矩陣  
from sklearn.metrics import confusion_matrix cm = confusion_matrix(y_test, y_pred)
     訓練集合結果可視化  
from matplotlib.colors import ListedColormap
X_set, y_set = X_train, y_train
X1, X2 = np.meshgrid(np.arange(start = X_set[:, 0].min() - 1, stop = X_set[:, 0].max() + 1, step = 0.01),
                     np.arange(start = X_set[:, 1].min() - 1, stop = X_set[:, 1].max() + 1, step = 0.01))
plt.contourf(X1, X2, classifier.predict(np.array([X1.ravel(), X2.ravel()]).T).reshape(X1.shape),
             alpha = 0.75, cmap = ListedColormap(('red', 'green')))
plt.xlim(X1.min(), X1.max())
plt.ylim(X2.min(), X2.max())
for i, j in enumerate(np.unique(y_set)):
    plt.scatter(X_set[y_set == j, 0], X_set[y_set == j, 1],
                c = ListedColormap(('red', 'green'))(i), label = j)
plt.title('SVM (Training set)')
plt.xlabel('Age')
plt.ylabel('Estimated Salary')
plt.legend()
plt.show()

 

測試集合結果可視化  
from matplotlib.colors import ListedColormap
X_set, y_set = X_test, y_test
X1, X2 = np.meshgrid(np.arange(start = X_set[:, 0].min() - 1, stop = X_set[:, 0].max() + 1, step = 0.01),
                     np.arange(start = X_set[:, 1].min() - 1, stop = X_set[:, 1].max() + 1, step = 0.01))
plt.contourf(X1, X2, classifier.predict(np.array([X1.ravel(), X2.ravel()]).T).reshape(X1.shape),
             alpha = 0.75, cmap = ListedColormap(('red', 'green')))
plt.xlim(X1.min(), X1.max())
plt.ylim(X2.min(), X2.max())
for i, j in enumerate(np.unique(y_set)):
    plt.scatter(X_set[y_set == j, 0], X_set[y_set == j, 1],
                c = ListedColormap(('red', 'green'))(i), label = j)
plt.title('SVM (Test set)')
plt.xlabel('Age')
plt.ylabel('Estimated Salary')
plt.legend()
plt.show()

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、Java註釋 1.作用:不會編譯倒.class文件之中;增強可讀性 2.分類: (1)單行註釋(只註釋當前行):// (2)多行註釋: (3)javadoc註釋 註意: 這種註釋可以被一個工具提取解析生成一個幫助文檔,這個工具在C:\Program Files\Java\jdk1.8.0_211 ...
  • 以下是以項目的的形式就行運行驗證五個消息的運行順序及調用鏈的原理,裡面主要用到了遞歸調用。 本篇博客先給大家展示代碼,後面進行文字及圖片講解執行的順序 一、創建java項目springAOPModule 二、創建項目包結構如下: 三、創建目標方法UserService 四、創建執行介面及方法(Met ...
  • 三四百的併發量的防止超賣問題可以用資料庫的悲觀鎖和樂觀鎖。 悲觀鎖比樂觀鎖(失敗重試)效率更高。因為這和響應速度 衝突頻率 重試代價有關。。樂觀鎖的衝突頻率和重試太多。 ...
  • 一 Number(數字) 1.1 數字類型的創建 1.2 Number 類型轉換 python內置數學函數 #abs(x) 返回數字的絕對值,如abs(-10) 返回 10 # ceil(x) 返回數字的上入整數,如math.ceil(4.1) 返回 5 # cmp(x, y) 如果 x < y 返 ...
  • 至於為什麼要創建虛擬環境以及創建虛擬環境的好處,這裡就不過多的描述了。相信沒有踩過坑估計也不會想要創建虛擬環境! 現在python版本主要有python2.x 和python3.x,並且python3.x現在是不向下相容的,但是,大部分都沒什麼變化的,最重要的是python2.x已經不再更新,所以, ...
  • 問題描述: pip instal MySQL-python 出現如下錯誤: 運行環境: python 2.7.10 setuptools 41.0.1 pip 19.1 操作系統:Windows7 64位 解決辦法: 1) 安裝mysql connector, 可根據系統版本選擇安裝32位或64位的 ...
  • A:迴圈結構while語句的格式: B:執行流程: a:執行初始化語句 b:執行判斷條件語句,看其返回值是true還是false 如果是true,就繼續執行 如果是false,就結束迴圈 c:執行迴圈體語句; d:執行控制條件語句 e:回到B繼續。 a:執行初始化語句 b:執行判斷條件語句,看其返回 ...
  • 漢諾塔:漢諾塔(又稱河內塔)問題是源於印度一個古老傳說的益智玩具。大梵天創造世界的時候做了三根金剛石柱子,在一根柱子上從下往上按照大小順序摞著64片黃金圓盤。大梵天命令婆羅門把圓盤從下麵開始按大小順序重新擺放在另一根柱子上。並且規定,在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動一個圓盤。 關鍵 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...