本人大四,保研生,研究生方向是计算机视觉,趁大四不忙学一下以后一定会用到Python以及机器学习、深度学习相关的知识。
#首先声明我是Python3.7版本
#第一步要做的是导入一些头文件
import importlib.util
import numpy as np
import struct
import sklearn
from sklearn import *
import matplotlib.pyplot as plt
from sklearn.datasets import make_moons
# 首先生成数据,并将其绘制出来 最后一句是用来绘制生成的数据集
np.random.seed(0)
X, y = sklearn.datasets.make_moons(200, noise=0.20)
plt.scatter(X[:, 0], X[:, 1], s=40, c=y, cmap=plt.cm.Spectral)
plt.show()
# 第二步 绘制决策边界
def plot_decision_boundary(pred_func):
x_min, x_max = X[:, 0].min() - .5, X[:, 0].max() + .5
y_min, y_max = X[:, 1].min() - .5, X[:, 1].max() + .5
h = 0.01
xx, yy = np.meshgrid(np.arange(x_min, x_max, h), np.arange(y_min, y_max, h))
# 用预测函数预测一下
Z = pred_func(np.c_[xx.ravel(), yy.ravel()])
Z = Z.reshape(xx.shape)
# 然后画出图
plt.contourf(xx, yy, Z, cmap=plt.cm.Spectral)
plt.scatter(X[:, 0], X[:, 1], c=y, cmap=plt.cm.Spectral)
from sklearn.linear_model import LogisticRegressionCV
# 训练逻辑回归分类器
clf = sklearn.linear_model.LogisticRegressionCV()
clf.fit(X, y)
# 画一下决策边界
plot_decision_boundary(lambda x: clf.predict(x))
plt.title("Logistic Regression")
plt.show()
第一步执行完 生成的数据集
训练出的决策边界: