Scikit-learn(sklearn)基本操作(三)

下面完整代码在github仓库:传送门


一、核邻回归

import numpy as np
from sklearn.kernel_ridge import KernelRidge
import matplotlib.pyplot as plt
from sklearn.model_selection import GridSearchCV

rng = np.random.RandomState(0)
# print(rng)

X = 5 * rng.rand(100, 1)  # 随机化状态的数据不会变化

y = np.sin(X).ravel()  # 将二维数据变成一维数据
# print(X)
# print(np.sin(X))
# print(y)

# 给标签加噪声
# print(y[::5])  # 每隔五个数据取一个
# y[::5] += 3 * (0.5 - rng.rand(X.shape[0] // 5))
# print(3 * (0.5-rng.rand(X.shape[0] // 5)))

y[::5] += 3 * (0.5 - rng.rand(20, 1).ravel())  # 每隔五个数据改变对应的值进去,范围在-1.5~1.5之间
# print(rng.rand(20, 1))

# 核邻回归
# kr = KernelRidge(kernel='sigmoid', alpha=0.3, gamma=0.3)
# kr = KernelRidge(kernel='linear', alpha=0.5, gamma=0.5)
# kr = KernelRidge(kernel='rbf', alpha=0.5, gamma=0.5)
# kr = KernelRidge(kernel='polynomial', alpha=0.5, gamma=0.5)
kr = GridSearchCV(KernelRidge(),  # 表格搜索(超级调参方法)
                  param_grid={"kernel": ['rbf', 'laplacian', 'polynomial', 'sigmoid'],
                              "alpha": [1e0, 0.1, 1e-2, 1e-3],
                              "gamma": np.logspace(-2, 2, 5)})

# print(np.logspace(-2, 2, 5))  # [1.e-02 1.e-01 1.e+00 1.e+01 1.e+02]
kr.fit(X, y)
print(kr.best_score_, kr.best_params_)

X_plot = np.linspace(0, 5, 100)
# print(X_plot)

y_kr = kr.predict(X_plot[:, None])
# print(X_plot[:, None])  # 增加一个维度,变成形状为(100,1)的数据
# y_kr = kr.predict(np.expand_dims(X_plot, 1))
# print(y_kr)

plt.scatter(X, y)
plt.plot(X_plot, y_kr, color="red")
plt.show()

二、随机数状态固定

import numpy as np

'''
numpy.random.RandomState()是一个伪随机数生成器。那么伪随机数是什么呢?

伪随机数是用确定性的算法计算出来的是来自[0,1]均匀分布的随机数序列。
并不真正的随机,但具有类似于随机数的统计特征,如均匀性、独立性等。
'''
a = np.random.RandomState(0)  # 将随机数状态固定下来
print(type(a), np.shape(a))  # <class 'mtrand.RandomState'>  ()
print(a.randn(1, 10))

b = np.random.randn(1, 1000)
print(b)
print(b.mean(), b.var())  

三:多个核岭回归

import numpy as np
from sklearn.kernel_ridge import KernelRidge
import matplotlib.pyplot as plt
from sklearn.model_selection import GridSearchCV

rng = np.random.RandomState(0)
# print(rng)

X = 5 * rng.randn(100, 1)  # 随机化状态的数据不会变化
y1 = np.sin(X).ravel()  # 将二维数据变成一维数据

# y1 = ((1 - np.exp(-X)) / (1 + np.exp(-X))).ravel()

# y2 = np.cos(X).ravel()
y2 = 1 / (1 + np.exp(-X)).ravel()

# 给标签加噪声
# print(y[::5])  # 每隔五个数据取一个
# y[::5] += 3 * (0.5 - rng.rand(X.shape[0] // 5))
# print(3 * (0.5-rng.rand(X.shape[0] // 5)))

y1[::5] += 3 * (0.5 - rng.rand(20, 1).ravel())  # 每隔五个数据加一个噪声进去
y2[::5] += 3 * (0.5 - rng.rand(20, 1).ravel())
# print(rng.rand(20, 1))

# 核邻回归
# kr = KernelRidge(kernel='sigmoid', alpha=0.3, gamma=0.3)
# kr = KernelRidge(kernel='linear', alpha=0.5, gamma=0.5)
# kr = KernelRidge(kernel='rbf', alpha=0.5, gamma=0.5)
# kr = KernelRidge(kernel='polynomial', alpha=0.5, gamma=0.5)
kr1 = GridSearchCV(KernelRidge(),  # 表格搜索(超级调参方法)
                  param_grid={"kernel": ['rbf', 'laplacian', 'polynomial', 'sigmoid'],
                              "alpha": [1e0, 0.1, 1e-2, 1e-3],
                              "gamma": np.logspace(-2, 2, 5)})

kr2 = GridSearchCV(KernelRidge(),  # 表格搜索(超级调参方法)
                  param_grid={"kernel": ['rbf', 'laplacian', 'polynomial', 'sigmoid'],
                              "alpha": [1e0, 0.1, 1e-2, 1e-3],
                              "gamma": np.logspace(-2, 2, 5)})

# print(np.logspace(-2, 2, 5))  # [1.e-02 1.e-01 1.e+00 1.e+01 1.e+02]
kr1.fit(X, y1)
kr2.fit(X, y2)
print(kr1.best_score_, kr1.best_params_)
print(kr2.best_score_, kr2.best_params_)

X_plot = np.linspace(-10, 10, 100)
# print(X_plot)

y1_kr = kr1.predict(X_plot[:, None])
y2_kr = kr2.predict(X_plot[:, None])
# print(X_plot[:, None])  # 增加一个维度,变成形状为(100,1)的数据
# y1_kr = kr1.predict(np.expand_dims(X_plot, 1))
# y2_kr = kr2.predict(np.expand_dims(X_plot, 1))
# print(y1_kr)

plt.scatter(X, y1)
plt.scatter(X, y2)
plt.plot(X_plot, y1_kr)
plt.plot(X_plot, y2_kr)
plt.show()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值