python实现Lasso回归

python实现Lasso回归Lasso原理Lasso与弹性拟合比较python实现importnumpyasnpimportmatplotlib.pyplotaspltfromsklearn.metricsimportr2_score#defmain():#产生一些稀疏数据np.random.seed(42)n_samples,n_features=50,200X=np…

大家好,又见面了,我是你们的朋友全栈君。

Lasso原理

在这里插入图片描述

Lasso与弹性拟合比较python实现

import numpy as np
import matplotlib.pyplot as plt
from sklearn.metrics import r2_score

#def main():
# 产生一些稀疏数据
np.random.seed(42)
n_samples, n_features = 50, 200
X = np.random.randn(n_samples, n_features) # randn(...)产生的是正态分布的数据
coef = 3 * np.random.randn(n_features)     # 每个特征对应一个系数
inds = np.arange(n_features)
np.random.shuffle(inds)
coef[inds[10:]] = 0  # 稀疏化系数--随机的把系数向量1x200的其中10个值变为0
y = np.dot(X, coef)  # 线性运算 -- y = X.*w
# 添加噪声:零均值,标准差为 0.01 的高斯噪声
y += 0.01 * np.random.normal(size=n_samples)

# 把数据划分成训练集和测试集
n_samples = X.shape[0]
X_train, y_train = X[:n_samples // 2], y[:n_samples // 2]
X_test, y_test = X[n_samples // 2:], y[n_samples // 2:]

# 训练 Lasso 模型
from sklearn.linear_model import Lasso
alpha = 0.1
lasso = Lasso(alpha=alpha)
y_pred_lasso = lasso.fit(X_train, y_train).predict(X_test)
r2_score_lasso = r2_score(y_test, y_pred_lasso)
print(lasso)
print("r^2 on test data : %f" % r2_score_lasso)

# 训练 ElasticNet 模型
from sklearn.linear_model import ElasticNet
enet = ElasticNet(alpha=alpha, l1_ratio=0.7)
y_pred_enet = enet.fit(X_train, y_train).predict(X_test)
r2_score_enet = r2_score(y_test, y_pred_enet)
print(enet)
print("r^2 on test data : %f" % r2_score_enet)

plt.plot(enet.coef_, color='lightgreen', linewidth=2,
         label='Elastic net coefficients')
plt.plot(lasso.coef_, color='gold', linewidth=2,
         label='Lasso coefficients')
plt.plot(coef, '--', color='navy', label='original coefficients')
plt.legend(loc='best')
plt.title("Lasso R^2: %f, Elastic Net R^2: %f"
          % (r2_score_lasso, r2_score_enet))
plt.show()

运行结果

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/133562.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月8日 上午10:16
下一篇 2022年6月8日 上午10:16


相关推荐

  • 可赎回债券「建议收藏」

    可赎回债券「建议收藏」可赎回债券的价格可赎回债券(callablebonds):发行人有权赎回的债券。为什么发行可赎回债券?通常有赎回保护期(callprotectionperiod),有相对较高的收益率补偿赎

    2022年8月4日
    9
  • PMD【 Java 代码检查工具】入门使用教程(超详细)

    PMD【 Java 代码检查工具】入门使用教程(超详细)PMD Java 代码检查工具 介绍使用方式 1 使用插件的方式 2 maven 项目引入依赖的方式 3 pmd 命令行的方式 4 JavaAPI 的方式 项目结构测试代码 pmdArgs 方式 PMDConfigura 方式 Programmatic 拓展 分析结果图形界面检测自定义规则介绍 nbsp nbsp nbsp nbsp nbsp nbsp PMD 是一个静态源代码分析器 它发现了常见的编程缺陷 如未使用的变量 空捕获块 不必要的对象创建等等 官网 点这里官方文档 点这里使用方

    2026年3月20日
    2
  • JS取整数、取余数的方法[通俗易懂]

    JS取整数、取余数的方法[通俗易懂]1.丢弃小数部分,保留整数部分parseInt(5/2)2.向上取整,有小数就整数部分加1Math.ceil(5/2)3,四舍五入.Math.round(5/2)4,取余6%45,向下取整Math.floor(5/2)Math对象的方法FF:Firefox,N:Netscape,IE:InternetExplorer方法描述FF…

    2022年6月29日
    38
  • 因果图和判定表_因果判定法

    因果图和判定表_因果判定法 上一篇文章中介绍了等价类和边界值,接下来我们就来学习一下因果图和判定表,这两种方法在软件测试中是非常重要的工具,这两个东西理论也是很绕口,特别是因果图,砖家给的方法我看起来也很困,所以我们就不要按照砖家的思路来。定义因果图法是一种利用图解法分析输入的各种组合情况,从而设计测试用例的方法,它适合于检查程序输入条件的各种组合情况。 特点:a考虑输入条件的相互制约及组合关系b考虑输出条件对输…

    2022年8月14日
    9
  • css修改导航条样式

    css修改导航条样式css 修改导航条样式近期由于工作需要要修改 table 表格导航条样式 本人特整理出相关代码 以及最后效果 供各位小伙伴参考 具体代码如下 xp table content webkit scrollbar width 8px height 8px xp table content webkit scrollbar thumb horizontal border radius 10px background rgba 0 0 0 0

    2026年3月17日
    2
  • 阿里云DDNS服务

    阿里云DDNS服务提示 文章写完后 目录可以自动生成 如何生成可参考右边的帮助文档搭建自己的 aliyunDDNS 服务 Java 前言由于运营商分配的公网 ip 经常变化 需要域名绑定 而不喜欢向日葵的 DDNS 服务 然后跟据官网 demo 自己写了一个记录一下一 DDNS 是什么 域名动态解析服务二 使用步骤 1 引入依赖代码如下 示例 dependency groupId com aliyun groupId amp dependency

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号