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语言中的按位运算符
Nov 26 Python
Python __setattr__、 __getattr__、 __delattr__、__call__用法示例
Mar 06 Python
浅析python中的分片与截断序列
Aug 09 Python
python 实现自动远程登陆scp文件实例代码
Mar 13 Python
python编程线性回归代码示例
Dec 07 Python
Python3实现的画图及加载图片动画效果示例
Jan 19 Python
python学习之hook钩子的原理和使用
Oct 25 Python
在python中利用GDAL对tif文件进行读写的方法
Nov 29 Python
pandas实现to_sql将DataFrame保存到数据库中
Jul 03 Python
python原类、类的创建过程与方法详解
Jul 19 Python
详解pandas中MultiIndex和对象实际索引不一致问题
Jul 23 Python
python基于Kivy写一个图形桌面时钟程序
Jan 28 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实现简单洗牌算法
2013/06/18 PHP
php一次性删除前台checkbox多选内容的方法
2013/09/22 PHP
使用php方法curl抓取AJAX异步内容思路分析及代码分享
2014/08/25 PHP
php使用正则表达式获取字符串中的URL
2016/12/29 PHP
php通过各种函数判断0和空
2020/07/04 PHP
php实现表单提交上传文件功能
2018/05/28 PHP
在jquery中处理带有命名空间的XML数据
2011/06/13 Javascript
Java 正则表达式学习总结和一些小例子
2012/09/13 Javascript
根据经纬度计算地球上两点之间的距离js实现代码
2013/03/05 Javascript
php is_numberic函数造成的SQL注入漏洞
2014/03/10 Javascript
jQuery 取值、赋值的基本方法整理
2014/03/31 Javascript
javascript操作excel生成报表示例
2014/05/08 Javascript
使用变量动态设置js的属性名
2014/10/19 Javascript
在JavaScript中使用对数Math.log()方法的教程
2015/06/15 Javascript
一步步教大家编写酷炫的导航栏js+css实现
2016/03/14 Javascript
浅谈js键盘事件全面控制
2016/12/01 Javascript
BootStrap select2 动态改变值的方法
2017/02/10 Javascript
Angular组件化管理实现方法分析
2017/03/17 Javascript
slideToggle+slideup实现手机端折叠菜单效果
2017/05/25 Javascript
微信小程序三级联动地址选择器的实例代码
2017/07/12 Javascript
详解Vue.js和layui日期控件冲突问题解决办法
2019/07/25 Javascript
[00:36]DOTA2勇士令状莱恩声望物品——冥晶之厄展示
2018/05/25 DOTA
python传递参数方式小结
2015/04/17 Python
Python实现在matplotlib中两个坐标轴之间画一条直线光标的方法
2015/05/20 Python
Selenium鼠标与键盘事件常用操作方法示例
2018/08/13 Python
详解python路径拼接os.path.join()函数的用法
2019/10/09 Python
Django 自定义分页器的实现代码
2019/11/24 Python
python多进程 主进程和子进程间共享和不共享全局变量实例
2020/04/25 Python
python 异步async库的使用说明
2020/05/04 Python
Python 高效编程技巧分享
2020/09/10 Python
大唐电信科技股份有限公司java工程师面试经历
2016/12/09 面试题
如何判断计算机可能已经中马
2013/03/22 面试题
什么是属性访问器
2015/10/26 面试题
信息技术专业大学生个人的自我评价
2013/10/05 职场文书
财会专业毕业生自荐信
2014/07/09 职场文书
如何利用JavaScript实现二叉搜索树
2021/04/02 Javascript