通用范例 General Examples - Ex 3: Isotonic Regression

优质
小牛编辑
132浏览
2023-12-01

http://scikit-learn.org/stable/auto_examples/plot_isotonic_regression.html

迴归函数採用递增函数。

  • y[] are inputs (real numbers)
  • y_[] are fitted

这个范例的主要目的:

比较

  • Isotonic Fit
  • Linear Fit

(一) Regression「迴归」

「迴归」就是找一个函数,尽量符合手边的一堆数据。此函数称作「迴归函数」。

(二) Linear Regression「线性迴归」

迴归函数採用线性函数。误差採用平方误差。

class sklearn.linear_model.LinearRegression

二维数据,迴归函数是直线。

Ex 3: Isotonic Regression - 图1

(三) Isotonic Regression「保序迴归」

具有分段迴归的效果。迴归函数採用递增函数。

class sklearn.isotonic.IsotonicRegression

採用平方误差,时间复杂度 O(N) 。

Ex 3: Isotonic Regression - 图2

(四) 完整程式码

Python source code: plot_isotonic_regression.py

http://scikit-learn.org/stable/auto_examples/plot_isotonic_regression.html

  1. print(__doc__)
  2. # Author: Nelle Varoquaux <nelle.varoquaux@gmail.com>
  3. # Alexandre Gramfort <alexandre.gramfort@inria.fr>
  4. # Licence: BSD
  5. import numpy as np
  6. import matplotlib.pyplot as plt
  7. from matplotlib.collections import LineCollection
  8. from sklearn.linear_model import LinearRegression
  9. from sklearn.isotonic import IsotonicRegression
  10. from sklearn.utils import check_random_state
  11. n = 100
  12. x = np.arange(n)
  13. rs = check_random_state(0)
  14. y = rs.randint(-50, 50, size=(n,)) + 50. * np.log(1 + np.arange(n))
  15. ###############################################################################
  16. # Fit IsotonicRegression and LinearRegression models
  17. ir = IsotonicRegression()
  18. y_ = ir.fit_transform(x, y)
  19. lr = LinearRegression()
  20. lr.fit(x[:, np.newaxis], y) # x needs to be 2d for LinearRegression
  21. ###############################################################################
  22. # plot result
  23. segments = [[[i, y[i]], [i, y_[i]]] for i in range(n)]
  24. lc = LineCollection(segments, zorder=0)
  25. lc.set_array(np.ones(len(y)))
  26. lc.set_linewidths(0.5 * np.ones(n))
  27. fig = plt.figure()
  28. plt.plot(x, y, 'r.', markersize=12)
  29. plt.plot(x, y_, 'g.-', markersize=12)
  30. plt.plot(x, lr.predict(x[:, np.newaxis]), 'b-')
  31. plt.gca().add_collection(lc)
  32. plt.legend(('Data', 'Isotonic Fit', 'Linear Fit'), loc='lower right')
  33. plt.title('Isotonic regression')
  34. plt.show()

Ex 3: Isotonic Regression - 图3