六、回归与聚类算法 - 岭回归

目录

1、带有L2正则化的线性回归 - 岭回归

1.1 API

2、正则化程度的变化对结果的影响

3、波士顿房价预测


  1. 线性回归
  2. 欠拟合与过拟合
  3. 线性回归的改进 - 岭回归
  4. 分类算法:逻辑回归
  5. 模型保存与加载
  6. 无监督学习:K-means算法

1、带有L2正则化的线性回归 - 岭回归

1.1 API

2、正则化程度的变化对结果的影响

  • 正则化力度越大,权重系数越小
  • 正则化力度越小,权重系数越大

3、波士顿房价预测

from sklearn.datasets import load_boston
from sklearn.metrics import mean_squared_error
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
from sklearn.linear_model import LinearRegression, SGDRegressor, Ridge


def linear1():
    # 正规方程的优化方法对波士顿房价进行预测
    # 1、获取数据
    boston = load_boston()
    # 2、划分数据集
    x_train,x_test,y_train,y_test=train_test_split(boston.data,boston.target,random_state=22)
    # 3、标准化
    transfer = StandardScaler()
    x_train=transfer.fit_transform(x_train)
    x_test = transfer.transform(x_test)
    # 4、预估器
    estimator = LinearRegression()
    estimator.fit(x_train,y_train)
    # 5、得出模型
    print("正规方程-权重系数为:\n",estimator.coef_)
    print("正规方程-偏置为:\n",estimator.intercept_)
    # 6、模型评估
    y_predict = estimator.predict(x_test)
    print("正规方程-预测房价:\n",y_predict)
    errror = mean_squared_error(y_test,y_predict)
    print("正规方程-均方差误差:\n",errror)
    return None


def linear2():
    # 梯度下降的优化方法对波士顿房价进行预测
    # 1、获取数据
    boston = load_boston()
    # 2、划分数据集
    x_train, x_test, y_train, y_test = train_test_split(boston.data, boston.target, random_state=22)
    # 3、标准化
    transfer = StandardScaler()
    x_train = transfer.fit_transform(x_train)
    x_test = transfer.transform(x_test)
    # 4、预估器
    estimator = SGDRegressor()
    estimator.fit(x_train, y_train)
    # 5、得出模型
    print("梯度下降-权重系数为:\n", estimator.coef_)
    print("梯度下降-偏置为:\n", estimator.intercept_)
    # 6、模型评估
    y_predict = estimator.predict(x_test)
    print("梯度下降-预测房价:\n", y_predict)
    errror = mean_squared_error(y_test, y_predict)
    print("梯度下降-均方差误差:\n", errror)
    return None


def linear3():
    # 岭回归对波士顿房价进行预测
    # 1、获取数据
    boston = load_boston()
    # 2、划分数据集
    x_train, x_test, y_train, y_test = train_test_split(boston.data, boston.target, random_state=22)
    # 3、标准化
    transfer = StandardScaler()
    x_train = transfer.fit_transform(x_train)
    x_test = transfer.transform(x_test)
    # 4、预估器
    estimator = Ridge()
    estimator.fit(x_train, y_train)
    # 5、得出模型
    print("岭回归-权重系数为:\n", estimator.coef_)
    print("岭回归-偏置为:\n", estimator.intercept_)
    # 6、模型评估
    y_predict = estimator.predict(x_test)
    print("岭回归-预测房价:\n", y_predict)
    errror = mean_squared_error(y_test, y_predict)
    print("岭回归-均方差误差:\n", errror)
    return None

if __name__ == "__main__":
    # 代码1 :正规方程的优化方法对波士顿房价进行预测
    linear1()
    # 代码2:梯度下降的优化方法对波士顿房价进行预测
    linear2()
    # 代码3:岭回归对波士顿房价进行预测
    linear3()

相关推荐

  1. 回归——模型保存加载(五)

    2024-02-23 21:50:02       31 阅读
  2. 零基础机器学习(6)之回归套索回归(正则化)

    2024-02-23 21:50:02       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-23 21:50:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-23 21:50:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-02-23 21:50:02       82 阅读
  4. Python语言-面向对象

    2024-02-23 21:50:02       91 阅读

热门阅读

  1. Qt应用软件【协议篇】GPIO控制LED灯

    2024-02-23 21:50:02       62 阅读
  2. 【小白友好】python leetcode 27 remove element

    2024-02-23 21:50:02       63 阅读
  3. 【GB28181】 SDP 报文内容(UDP、TCP主动、TCP被动)

    2024-02-23 21:50:02       52 阅读
  4. 设计模式-建造者模式(Builder Pattern)

    2024-02-23 21:50:02       52 阅读
  5. 数据结构与算法-队列

    2024-02-23 21:50:02       63 阅读
  6. 【selenium】WebElement、WebDriver、三种等待方式

    2024-02-23 21:50:02       58 阅读
  7. 00_C语言学习笔记

    2024-02-23 21:50:02       55 阅读
  8. 算法训练营day32,贪心算法6

    2024-02-23 21:50:02       63 阅读
  9. html开启严格模式

    2024-02-23 21:50:02       62 阅读
  10. MYSQL--触发器

    2024-02-23 21:50:02       57 阅读
  11. Linux(四)__用户和用户组管理

    2024-02-23 21:50:02       41 阅读
  12. C# 类型的默认值(C# 参考)

    2024-02-23 21:50:02       60 阅读