欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SVM基本概念及Python實現(xiàn)代碼

 更新時間:2017年12月27日 08:41:54   作者:傲慢灬  
這篇文章主要為大家詳細介紹了SVM基本概念及Python實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下

SVM(support vector machine)支持向量機:

注意:本文不準備提到數(shù)學證明的過程,一是因為有一篇非常好的文章解釋的非常好:支持向量機通俗導論(理解SVM的三層境界) ,另一方面是因為我只是個程序員,不是搞數(shù)學的(主要是因為數(shù)學不好。),主要目的是將SVM以最通俗易懂,簡單粗暴的方式解釋清楚。

線性分類:

先從線性可分的數(shù)據(jù)講起,如果需要分類的數(shù)據(jù)都是線性可分的,那么只需要一根直線f(x)=wx+b就可以分開了,類似這樣:

這種方法被稱為:線性分類器,一個線性分類器的學習目標便是要在n維的數(shù)據(jù)空間中找到一個超平面(hyper plane)。也就是說,數(shù)據(jù)不總是二維的,比如,三維的超平面是面。但是有個問題:

上述兩種超平面,都可以將數(shù)據(jù)進行分類,由此可推出,其實能有無數(shù)個超平面能將數(shù)據(jù)劃分,但是哪條最優(yōu)呢?

最大間隔分類器Maximum Margin Classifier:

簡稱MMH, 對一個數(shù)據(jù)點進行分類,當超平面離數(shù)據(jù)點的“間隔”越大,分類的確信度(confidence)也越大。所以,為了使得分類的確信度盡量高,需要讓所選擇的超平面能夠最大化這個“間隔”值。這個間隔就是下圖中的Gap的一半。

用以生成支持向量的點,如上圖XO,被稱為支持向量點,因此SVM有一個優(yōu)點,就是即使有大量的數(shù)據(jù),但是支持向量點是固定的,因此即使再次訓練大量數(shù)據(jù),這個超平面也可能不會變化。

非線性分類:

數(shù)據(jù)大多數(shù)情況都不可能是線性的,那如何分割非線性數(shù)據(jù)呢?

解決方法是將數(shù)據(jù)放到高維度上再進行分割,如下圖:

當f(x)=x時,這組數(shù)據(jù)是個直線,如上半部分,但是當我把這組數(shù)據(jù)變?yōu)閒(x)=x^2時,這組數(shù)據(jù)就變成了下半部分的樣子,也就可以被紅線所分割。

比如說,我這里有一組三維的數(shù)據(jù)X=(x1,x2,x3),線性不可分割,因此我需要將他轉換到六維空間去。因此我們可以假設六個維度分別是:x1,x2,x3,x1^2,x1*x2,x1*x3,當然還能繼續(xù)展開,但是六維的話這樣就足夠了。

新的決策超平面:d(Z)=WZ+b,解出W和b后帶入方程,因此這組數(shù)據(jù)的超平面應該是:d(Z)=w1x1+w2x2+w3x3+w4*x1^2+w5x1x2+w6x1x3+b但是又有個新問題,轉換高緯度一般是以內積(dot product)的方式進行的,但是內積的算法復雜度非常大。

核函數(shù)Kernel:

我們會經(jīng)常遇到線性不可分的樣例,此時,我們的常用做法是把樣例特征映射到高維空間中去。但進一步,如果凡是遇到線性不可分的樣例,一律映射到高維空間,那么這個維度大小是會高到可怕的,而且內積方式復雜度太大。此時,核函數(shù)就隆重登場了,核函數(shù)的價值在于它雖然也是講特征進行從低維到高維的轉換,但核函數(shù)絕就絕在它事先在低維上進行計算,而將實質上的分類效果表現(xiàn)在了高維上,也就如上文所說的避免了直接在高維空間中的復雜計算。

幾種常用核函數(shù):

h度多項式核函數(shù)(Polynomial Kernel of Degree h)

高斯徑向基和函數(shù)(Gaussian radial basis function Kernel)

S型核函數(shù)(Sigmoid function Kernel)

圖像分類,通常使用高斯徑向基和函數(shù),因為分類較為平滑,文字不適用高斯徑向基和函數(shù)。沒有標準的答案,可以嘗試各種核函數(shù),根據(jù)精確度判定。

松弛變量:

數(shù)據(jù)本身可能有噪點,會使得原本線性可分的數(shù)據(jù)需要映射到高維度去。對于這種偏離正常位置很遠的數(shù)據(jù)點,我們稱之為 outlier ,在我們原來的 SVM 模型里,outlier 的存在有可能造成很大的影響,因為超平面本身就是只有少數(shù)幾個 support vector 組成的,如果這些 support vector 里又存在 outlier 的話,其影響就很大了。

因此排除outlier點,可以相應的提高模型準確率和避免Overfitting的方式。

解決多分類問題:

經(jīng)典的SVM只給出了二類分類的算法,現(xiàn)實中數(shù)據(jù)可能需要解決多類的分類問題。因此可以多次運行SVM,產(chǎn)生多個超平面,如需要分類1-10種產(chǎn)品,首先找到1和2-10的超平面,再尋找2和1,3-10的超平面,以此類推,最后需要測試數(shù)據(jù)時,按照相應的距離或者分布判定。

SVM與其他機器學習算法對比(圖):

Python實現(xiàn)方式:

線性,基礎:

from sklearn import svm 
 
x = [[2,0,1],[1,1,2],[2,3,3]] 
y = [0,0,1] #分類標記 
clf = svm.SVC(kernel = 'linear') #SVM模塊,svc,線性核函數(shù) 
clf.fit(x,y) 
 
print(clf) 
 
print(clf.support_vectors_) #支持向量點 
 
print(clf.support_) #支持向量點的索引 
 
print(clf.n_support_) #每個class有幾個支持向量點 
 
print(clf.predict([2,0,3])) #預測 

線性,展示圖:

from sklearn import svm 
import numpy as np 
import matplotlib.pyplot as plt 
 
np.random.seed(0) 
x = np.r_[np.random.randn(20,2)-[2,2],np.random.randn(20,2)+[2,2]] #正態(tài)分布來產(chǎn)生數(shù)字,20行2列*2 
y = [0]*20+[1]*20 #20個class0,20個class1 
 
clf = svm.SVC(kernel='linear') 
clf.fit(x,y) 
 
w = clf.coef_[0] #獲取w 
a = -w[0]/w[1] #斜率 
#畫圖劃線 
xx = np.linspace(-5,5) #(-5,5)之間x的值 
yy = a*xx-(clf.intercept_[0])/w[1] #xx帶入y,截距 
 
#畫出與點相切的線 
b = clf.support_vectors_[0] 
yy_down = a*xx+(b[1]-a*b[0]) 
b = clf.support_vectors_[-1] 
yy_up = a*xx+(b[1]-a*b[0]) 
 
print("W:",w) 
print("a:",a) 
 
print("support_vectors_:",clf.support_vectors_) 
print("clf.coef_:",clf.coef_) 
 
plt.figure(figsize=(8,4)) 
plt.plot(xx,yy) 
plt.plot(xx,yy_down) 
plt.plot(xx,yy_up) 
plt.scatter(clf.support_vectors_[:,0],clf.support_vectors_[:,1],s=80) 
plt.scatter(x[:,0],x[:,1],c=y,cmap=plt.cm.Paired) #[:,0]列切片,第0列 
 
plt.axis('tight') 
 
plt.show() 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Python基于matplotlib畫箱體圖檢驗異常值操作示例【附xls數(shù)據(jù)文件下載】

    Python基于matplotlib畫箱體圖檢驗異常值操作示例【附xls數(shù)據(jù)文件下載】

    這篇文章主要介紹了Python基于matplotlib畫箱體圖檢驗異常值操作,涉及Python針對xls格式數(shù)據(jù)文件的讀取、matplotlib圖形繪制等相關操作技巧,并附帶xls數(shù)據(jù)文件供讀者下載參考,需要的朋友可以參考下
    2019-01-01
  • django跳轉頁面?zhèn)鲄⒌膶崿F(xiàn)

    django跳轉頁面?zhèn)鲄⒌膶崿F(xiàn)

    這篇文章主要介紹了django跳轉頁面?zhèn)鲄⒌膶崿F(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Python3 Tkinkter + SQLite實現(xiàn)登錄和注冊界面

    Python3 Tkinkter + SQLite實現(xiàn)登錄和注冊界面

    這篇文章主要為大家詳細介紹了Python3 Tkinkter + SQLite實現(xiàn)登錄和注冊界面,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • 使用Pycharm為項目創(chuàng)建一個虛擬環(huán)境完整圖文教程

    使用Pycharm為項目創(chuàng)建一個虛擬環(huán)境完整圖文教程

    這篇文章主要給大家介紹了關于使用Pycharm為項目創(chuàng)建一個虛擬環(huán)境的相關資料,我們在使用pycharm做項目時,最好給每一個工程都創(chuàng)建一個虛擬環(huán)境,將對應的安裝包放在該虛擬環(huán)境中,避免項目與項目之間產(chǎn)生關系或沖突,便于管理,需要的朋友可以參考下
    2023-09-09
  • pycharm運行scrapy過程圖解

    pycharm運行scrapy過程圖解

    這篇文章主要介紹了pycharm運行scrapy過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • 解決安裝pyqt5之后無法打開spyder的問題

    解決安裝pyqt5之后無法打開spyder的問題

    今天小編就為大家分享一篇解決安裝pyqt5之后無法打開spyder的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • Python常用的json標準庫

    Python常用的json標準庫

    今天小編就為大家分享一篇關于Python常用的json標準庫,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • Python中的enumerate函數(shù)使用方法詳解

    Python中的enumerate函數(shù)使用方法詳解

    enumerate()是python的內置函數(shù),適用于python2.x和python3.x,這篇文章主要給大家介紹了關于Python中的enumerate函數(shù)使用方法的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-06-06
  • Python3.4 splinter(模擬填寫表單)使用方法

    Python3.4 splinter(模擬填寫表單)使用方法

    今天小編就為大家分享一篇Python3.4 splinter(模擬填寫表單)使用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • TensorFlow加載模型時出錯的解決方式

    TensorFlow加載模型時出錯的解決方式

    今天小編就為大家分享一篇TensorFlow加載模型時出錯的解決方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02

最新評論