Python 实现3种回归模型(Linear Regression,Lasso,Ridge)的示例


Posted in Python onOctober 15, 2020

公共的抽象基类

import numpy as np
from abc import ABCMeta, abstractmethod


class LinearModel(metaclass=ABCMeta):
 """
 Abstract base class of Linear Model.
 """

 def __init__(self):
  # Before fit or predict, please transform samples' mean to 0, var to 1.
  self.scaler = StandardScaler()

 @abstractmethod
 def fit(self, X, y):
  """fit func"""

 def predict(self, X):
  # before predict, you must run fit func.
  if not hasattr(self, 'coef_'):
   raise Exception('Please run `fit` before predict')

  X = self.scaler.transform(X)
  X = np.c_[np.ones(X.shape[0]), X]

  # `x @ y` == `np.dot(x, y)`
  return X @ self.coef_

Linear Regression

class LinearRegression(LinearModel):
 """
 Linear Regression.
 """

 def __init__(self):
  super().__init__()

 def fit(self, X, y):
  """
  :param X_: shape = (n_samples + 1, n_features)
  :param y: shape = (n_samples])
  :return: self
  """
  self.scaler.fit(X)
  X = self.scaler.transform(X)
  X = np.c_[np.ones(X.shape[0]), X]
  self.coef_ = np.linalg.inv(X.T @ X) @ X.T @ y
  return self

Lasso

class Lasso(LinearModel):
 """
 Lasso Regression, training by Coordinate Descent.
 cost = ||X @ coef_||^2 + alpha * ||coef_||_1
 """
 def __init__(self, alpha=1.0, n_iter=1000, e=0.1):
  self.alpha = alpha
  self.n_iter = n_iter
  self.e = e
  super().__init__()

 def fit(self, X, y):
  self.scaler.fit(X)
  X = self.scaler.transform(X)
  X = np.c_[np.ones(X.shape[0]), X]
  self.coef_ = np.zeros(X.shape[1])
  for _ in range(self.n_iter):
   z = np.sum(X * X, axis=0)
   tmp = np.zeros(X.shape[1])
   for k in range(X.shape[1]):
    wk = self.coef_[k]
    self.coef_[k] = 0
    p_k = X[:, k] @ (y - X @ self.coef_)
    if p_k < -self.alpha / 2:
     w_k = (p_k + self.alpha / 2) / z[k]
    elif p_k > self.alpha / 2:
     w_k = (p_k - self.alpha / 2) / z[k]
    else:
     w_k = 0
    tmp[k] = w_k
    self.coef_[k] = wk
   if np.linalg.norm(self.coef_ - tmp) < self.e:
    break
   self.coef_ = tmp
  return self

Ridge

class Ridge(LinearModel):
 """
 Ridge Regression.
 """

 def __init__(self, alpha=1.0):
  self.alpha = alpha
  super().__init__()

 def fit(self, X, y):
  """
  :param X_: shape = (n_samples + 1, n_features)
  :param y: shape = (n_samples])
  :return: self
  """
  self.scaler.fit(X)
  X = self.scaler.transform(X)
  X = np.c_[np.ones(X.shape[0]), X]
  self.coef_ = np.linalg.inv(
   X.T @ X + self.alpha * np.eye(X.shape[1])) @ X.T @ y
  return self

测试代码

import matplotlib.pyplot as plt
import numpy as np

def gen_reg_data():
 X = np.arange(0, 45, 0.1)
 X = X + np.random.random(size=X.shape[0]) * 20
 y = 2 * X + np.random.random(size=X.shape[0]) * 20 + 10
 return X, y

def test_linear_regression():
 clf = LinearRegression()
 X, y = gen_reg_data()
 clf.fit(X, y)
 plt.plot(X, y, '.')
 X_axis = np.arange(-5, 75, 0.1)
 plt.plot(X_axis, clf.predict(X_axis))
 plt.title("Linear Regression")
 plt.show()

def test_lasso():
 clf = Lasso()
 X, y = gen_reg_data()
 clf.fit(X, y)
 plt.plot(X, y, '.')
 X_axis = np.arange(-5, 75, 0.1)
 plt.plot(X_axis, clf.predict(X_axis))
 plt.title("Lasso")
 plt.show()

def test_ridge():
 clf = Ridge()
 X, y = gen_reg_data()
 clf.fit(X, y)
 plt.plot(X, y, '.')
 X_axis = np.arange(-5, 75, 0.1)
 plt.plot(X_axis, clf.predict(X_axis))
 plt.title("Ridge")
 plt.show()

测试效果

Python 实现3种回归模型(Linear Regression,Lasso,Ridge)的示例

Python 实现3种回归模型(Linear Regression,Lasso,Ridge)的示例

Python 实现3种回归模型(Linear Regression,Lasso,Ridge)的示例

更多机器学习代码,请访问 https://github.com/WiseDoge/plume

以上就是Python 实现 3 种回归模型(Linear Regression,Lasso,Ridge)的示例的详细内容,更多关于Python 实现 回归模型的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python基类函数的重载与调用实例分析
Jan 12 Python
Python中解析JSON并同时进行自定义编码处理实例
Feb 08 Python
使用python实现rsa算法代码
Feb 17 Python
python+pandas生成指定日期和重采样的方法
Apr 11 Python
在PyCharm环境中使用Jupyter Notebook的两种方法总结
May 24 Python
python+numpy按行求一个二维数组的最大值方法
Jul 09 Python
Python pip安装模块提示错误解决方案
May 22 Python
Python第三方包PrettyTable安装及用法解析
Jul 08 Python
Python 字典一个键对应多个值的方法
Sep 29 Python
python-地图可视化组件folium的操作
Dec 14 Python
python正则表达式re.match()匹配多个字符方法的实现
Jan 27 Python
Python采集爬取京东商品信息和评论并存入MySQL
Apr 12 Python
Python在centos7.6上安装python3.9的详细教程(默认python版本为2.7.5)
Oct 15 #Python
Pycharm编辑器功能之代码折叠效果的实现代码
Oct 15 #Python
如何用Python 实现全连接神经网络(Multi-layer Perceptron)
Oct 15 #Python
python 实现非极大值抑制算法(Non-maximum suppression, NMS)
Oct 15 #Python
解决pip安装的第三方包在PyCharm无法导入的问题
Oct 15 #Python
python实现粒子群算法
Oct 15 #Python
如何将anaconda安装配置的mmdetection环境离线拷贝到另一台电脑
Oct 15 #Python
You might like
PHP数组及条件,循环语句学习
2012/11/11 PHP
php操作mongoDB实例分析
2014/12/29 PHP
PHP打印输出函数汇总
2016/08/28 PHP
thinkPHP中U方法加密传递参数功能示例
2018/05/29 PHP
基于PHP实现邮箱验证激活过程详解
2020/10/28 PHP
用JTrackBar实现的模拟苹果风格的滚动条
2007/08/06 Javascript
css图片自适应大小
2007/11/28 Javascript
始终在屏幕中间显示Div的代码(css+js)
2011/03/10 Javascript
jquery ajax学习笔记2 使用XMLHttpRequest对象的responseXML
2011/10/16 Javascript
javascript题目,重写函数让其无限相加
2012/02/15 Javascript
jQuery增加自定义函数的方法
2015/07/18 Javascript
jquery实现的V字形显示效果代码
2015/10/27 Javascript
盘点javascript 正则表达式中 中括号的【坑】
2016/03/16 Javascript
微信公众号 客服接口的开发实例详解
2016/09/28 Javascript
详解ES7 Decorator 入门解析
2019/02/18 Javascript
vue 实现LED数字时钟效果(开箱即用)
2019/12/08 Javascript
vue简单封装axios插件和接口的统一管理操作示例
2020/02/02 Javascript
Vue-resource安装过程及使用方法解析
2020/07/21 Javascript
Python的地形三维可视化Matplotlib和gdal使用实例
2017/12/09 Python
python kmeans聚类简单介绍和实现代码
2018/02/23 Python
Python递归实现汉诺塔算法示例
2018/03/19 Python
详解Django的CSRF认证实现
2018/10/09 Python
Python 从相对路径下import的方法
2018/12/04 Python
在python带权重的列表中随机取值的方法
2019/01/23 Python
python将字符串list写入excel和txt的实例
2019/07/20 Python
Python学习笔记之For循环用法详解
2019/08/14 Python
英国在线自行车商店:Evans Cycles
2016/09/26 全球购物
巴基斯坦购物网站:Goto
2019/03/11 全球购物
办公室文员工作职责
2014/01/31 职场文书
医科大学毕业生自荐信
2014/02/03 职场文书
渡河少年教学反思
2014/02/12 职场文书
实习生评语
2014/04/26 职场文书
中学生旷课检讨书模板
2014/10/08 职场文书
转正申请报告格式
2015/05/15 职场文书
MySQL高速缓存启动方法及参数详解(query_cache_size)
2021/07/01 MySQL
ssh服务器拒绝了密码 请再试一次已解决(亲测有效)
2022/08/14 Servers