Основываясь на ответе Sun Yi, вы можете использовать пример кода из здесь. Например, у вас нет всех точек в вашем data.csv
в вашем вопросе, но мы можем построить график с границей принятия решения следующим образом:
import pandas as pd
import numpy as np
from matplotlib.colors import ListedColormap
from sklearn.svm import SVC
import matplotlib.pyplot as plt
# load the data
data = pd.read_csv('data/data.csv')
X = data[['x1','x2']]
y = data['y']
# fit the classifier
classifier = SVC(kernel='rbf')
classifier.fit(X,y)
# first we determine the grid of points -- i.e. the min and max for each of
# the axises and then build a grid
resolution=0.02
x1_min, x1_max = X["x1"].min() - 1, X["x1"].max() + 1
x2_min, x2_max = X["x2"].min() - 1, X["x2"].max() + 1
xx1, xx2 = np.meshgrid(np.arange(x1_min, x1_max, resolution),
np.arange(x2_min, x2_max, resolution))
# setup marker generator and color map
markers = ('s', 'x', 'o', '^', 'v')
colors = ('red', 'blue', 'lightgreen', 'gray', 'cyan')
cmap = ListedColormap(colors[:len(np.unique(y))])
# plot the classifier decision boundaries
Z = classifier.predict(np.array([xx1.ravel(), xx2.ravel()]).T)
Z = Z.reshape(xx1.shape)
plt.contourf(xx1, xx2, Z, alpha=0.4, cmap=cmap)
plt.xlim(xx1.min(), xx1.max())
plt.ylim(xx2.min(), xx2.max())
# plot the data points
for idx, cl in enumerate(np.unique(y)):
plt.scatter(x=X["x1"][y == cl].values,
y=X["x2"][y == cl].values,
alpha=0.6,
c=cmap(idx),
edgecolor='black',
marker=markers[idx],
label=cl)
plt.show()
Это в значительной степени взято из примера кода в приведенной выше ссылке. Я попытался включить только то, что было необходимо, чтобы было проще. Вот изображение на выходе:
Вы заметите, что я явно использовал ядро rbf
, поскольку полные данные в вашем примере нельзя разделить линейно. Этот ответ хорош для хорошего, более общего, чем у меня, ответа на эти контуры.
person
Paul
schedule
29.08.2017
y
-значение1
, я полагаю), почему бы просто не отфильтровать данные поy
-значению и вычислить выпуклая оболочка вокруг них? - person Thomas Kühn   schedule 29.08.2017