• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

sklearn例程:保序回归

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

保序回归简介

本示例是对保序回归处理生成数据的说明。保序回归发现函数的非递减近似,同时使训练数据的均方误差最小。这种模型的好处是它不会为目标函数采用任何形式的假设,例如线性。为了比较,示例中还给出了线性回归。

代码实现[Python]


# -*- coding: utf-8 -*- 
print(__doc__)

# 码农: Nelle Varoquaux 
#         Alexandre Gramfort 
# 协议: BSD

import numpy as np
import matplotlib.pyplot as plt
from matplotlib.collections import LineCollection

from sklearn.linear_model import LinearRegression
from sklearn.isotonic import IsotonicRegression
from sklearn.utils import check_random_state

n = 100
x = np.arange(n)
rs = check_random_state(0)
y = rs.randint(-50, 50, size=(n,)) + 50. * np.log1p(np.arange(n))

# #############################################################################
# 拟合IsotonicRegression和LinearRegression models模型

ir = IsotonicRegression()

y_ = ir.fit_transform(x, y)

lr = LinearRegression()
lr.fit(x[:, np.newaxis], y)  # x needs to be 2d for LinearRegression

# #############################################################################
# 绘图展示结果

segments = [[[i, y[i]], [i, y_[i]]] for i in range(n)]
lc = LineCollection(segments, zorder=0)
lc.set_array(np.ones(len(y)))
lc.set_linewidths(np.full(n, 0.5))

fig = plt.figure()
plt.plot(x, y, 'r.', markersize=12)
plt.plot(x, y_, 'b.-', markersize=12)
plt.plot(x, lr.predict(x[:, np.newaxis]), 'b-')
plt.gca().add_collection(lc)
plt.legend(('Data', 'Isotonic Fit', 'Linear Fit'), loc='lower right')
plt.title('Isotonic regression')
plt.show()

代码执行

代码运行时间大约:0分0.056秒。
运行代码输出的图片内容如下:

源码下载

  • Python版源码文件: plot_isotonic_regression.py
  • Jupyter Notebook版源码文件: plot_isotonic_regression.ipynb

参考资料

  • Isotonic Regression

鲜花

握手

雷人

路过

鸡蛋
专题导读
上一篇:
sklearn例程:简化打印模型时的输出发布时间:2022-05-14
下一篇:
在Python中使用图像过滤器/滤镜发布时间:2022-05-14
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap