支持向量機
此範例是展示如何使用 RBF Kernel 之非線性 SVC 去做二元分類,去預測出 XOR 的輸入分佈並用 Color Map 去繪製出分類的決策邊界及區域。
(一)引入函式庫
引入函式如下:
numpy: 產生陣列數值matplotlib.pyplot: 用來繪製影像sklearn.svm: SVM 支持向量機之演算法物件
import numpy as np
import matplotlib.pyplot as plt
from sklearn import svmxx, yy = np.meshgrid(np.linspace(-3, 3, 500),
np.linspace(-3, 3, 500))
np.random.seed(0)
X = np.random.randn(300, 2)
Y = np.logical_xor(X[:, 0] > 0, X[:, 1] > 0)利用np.meshgrid生成網格採樣點,再利用np.random.randn()產生隨機的資料點X,接著利用np.logical_xor對隨機生成之資料點做 xor 的分類產生Y。
(二)SVM Model
svm.NuSVC: 與 svm.SVC 類似,但是多了可以控制支持向量(Support Vector)個數之參數
最後繪製出非線性之決策邊界及資料點分布位置,繪圖方式可參考 EX7: SVM-Kernels 之解說。
下方為非線性分割之結果圖 :
(三)完整程式碼
Python source code: plot_svm_nonlinear.py
https://scikit-learn.org/stable/_downloads/plot_svm_nonlinear.py
iPython source code: plot_svm_nonlinear.ipynb
https://scikit-learn.org/stable/_downloads/plot_svm_nonlinear.ipynb
PreviousPlot Hierarchical Clustering DendrogramNext[EX 4: SVM_with _custom _kernel.md](SVM/EX4_SVM_with _custom _kernel.md)
Last updated