4.弹性网络( Elastic Net)
ElasticNet 是一种使用L1和L2先验作为正则化矩阵的线性回归模型.这种组合用于只有很少的权重非零的稀疏模型,比如:class:Lasso, 但是又能保持:class:Ridge 的正则化属性.我们可以使用 l1_ratio 参数来调节L1和L2的凸组合(一类特殊的线性组合)。
当多个特征和另一个特征相关的时候弹性网络非常有用。Lasso 倾向于随机选择其中一个,而弹性网络更倾向于选择两个.
在实践中,Lasso 和 Ridge 之间权衡的一个优势是它允许在循环过程(Under rotate)中继承 Ridge 的稳定性.
弹性网络的目标函数是最小化:

ElasticNetCV 可以通过交叉验证来用来设置参数 alpha (
) 和 l1_ratio (
)
- print(__doc__)
- import numpy as np
- import matplotlib.pyplot as plt
- from sklearn.linear_model import lasso_path, enet_path
- from sklearn import datasets
- diabetes = datasets.load_diabetes()
- X = diabetes.data
- y = diabetes.target
- X /= X.std(axis=0) # Standardize data (easier to set the l1_ratio parameter)
- # Compute paths
- eps = 5e-3 # the smaller it is the longer is the path
- print("Computing regularization path using the lasso...")
- alphas_lasso, coefs_lasso, _ = lasso_path(X, y, eps, fit_intercept=False)
- print("Computing regularization path using the positive lasso...")
- alphas_positive_lasso, coefs_positive_lasso, _ = lasso_path(
- X, y, eps, positive=True, fit_intercept=False)
- print("Computing regularization path using the elastic net...")
- alphas_enet, coefs_enet, _ = enet_path(
- X, y, eps=eps, l1_ratio=0.8, fit_intercept=False)
- print("Computing regularization path using the positve elastic net...")
- alphas_positive_enet, coefs_positive_enet, _ = enet_path(
- X, y, eps=eps, l1_ratio=0.8, positive=True, fit_intercept=False)
- # Display results
- plt.figure(1)
- ax = plt.gca()
- ax.set_color_cycle(2 * ['b', 'r', 'g', 'c', 'k'])
- l1 = plt.plot(-np.log10(alphas_lasso), coefs_lasso.T)
- l2 = plt.plot(-np.log10(alphas_enet), coefs_enet.T, linestyle='--')
- plt.xlabel('-Log(alpha)')
- plt.ylabel('coefficients')
- plt.title('Lasso and Elastic-Net Paths')
- plt.legend((l1[-1], l2[-1]), ('Lasso', 'Elastic-Net'), loc='lower left')
- plt.axis('tight')
- plt.figure(2)
- ax = plt.gca()
- ax.set_color_cycle(2 * ['b', 'r', 'g', 'c', 'k'])
- l1 = plt.plot(-np.log10(alphas_lasso), coefs_lasso.T)
- l2 = plt.plot(-np.log10(alphas_positive_lasso), coefs_positive_lasso.T,
- linestyle='--')
- plt.xlabel('-Log(alpha)')
- plt.ylabel('coefficients')
- plt.title('Lasso and positive Lasso')
- plt.legend((l1[-1], l2[-1]), ('Lasso', 'positive Lasso'), loc='lower left')
- plt.axis('tight')
- plt.figure(3)
- ax = plt.gca()
- ax.set_color_cycle(2 * ['b', 'r', 'g', 'c', 'k'])
- l1 = plt.plot(-np.log10(alphas_enet), coefs_enet.T)
- l2 = plt.plot(-np.log10(alphas_positive_enet), coefs_positive_enet.T,
- linestyle='--')
- plt.xlabel('-Log(alpha)')
- plt.ylabel('coefficients')
- plt.title('Elastic-Net and positive Elastic-Net')
- plt.legend((l1[-1], l2[-1]), ('Elastic-Net', 'positive Elastic-Net'),
- loc='lower left')
- plt.axis('tight')
- plt.show()
4.弹性网络( Elastic Net)的更多相关文章
- 【笔记】简谈L1正则项L2正则和弹性网络
L1,L2,以及弹性网络 前情提要: 模型泛化与岭回归与LASSO 正则 ridge和lasso的后面添加的式子的格式上其实和MSE,MAE,以及欧拉距离和曼哈顿距离是非常像的 虽然应用场景不同,但是 ...
- 机器学习:模型泛化(L1、L2 和弹性网络)
一.岭回归和 LASSO 回归的推导过程 1)岭回归和LASSO回归都是解决模型训练过程中的过拟合问题 具体操作:在原始的损失函数后添加正则项,来尽量的减小模型学习到的 θ 的大小,使得模型的泛化能力 ...
- 机器学习算法--Elastic Net
1) alpha : float, optional Constant that multiplies the penalty terms. Defaults to 1.0. See the note ...
- [源码解析] 深度学习分布式训练框架 horovod (20) --- Elastic Training Operator
[源码解析] 深度学习分布式训练框架 horovod (20) --- Elastic Training Operator 目录 [源码解析] 深度学习分布式训练框架 horovod (20) --- ...
- 基于C#的机器学习--颜色混合-自组织映射和弹性神经网络
自组织映射和弹性神经网络 自组织映射(SOM),或者你们可能听说过的Kohonen映射,是自组织神经网络的基本类型之一.自组织的能力提供了对以前不可见的输入数据的适应性.它被理论化为最自然的学习方式之 ...
- 阿里云弹性裸金属服务器-神龙架构(X-Dragon)揭秘
在5月16日的飞天技术会新品直播中,特别邀请了业界知名大咖狒哥以及阿里云虚拟化资深专家旭卿作为现场直播的嘉宾.本次直播主要从产品背景到“X-Dragon架构”,从硬件设备到软件应用来深度的剖析“X-D ...
- [Machine Learning] 机器学习常见算法分类汇总
声明:本篇博文根据http://www.ctocio.com/hotnews/15919.html整理,原作者张萌,尊重原创. 机器学习无疑是当前数据分析领域的一个热点内容.很多人在平时的工作中都或多 ...
- Spark入门实战系列--8.Spark MLlib(上)--机器学习及SparkMLlib简介
[注]该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取 .机器学习概念 1.1 机器学习的定义 在维基百科上对机器学习提出以下几种定义: l“机器学 ...
- 转:netflix推荐系统竞赛
原文链接:Netflix recommendations: beyond the 5 stars (Part 1), (Part 2) 原文作者:Xavier Amatriain and Justin ...
随机推荐
- conda升级TensorFlow
1.打开Anaconda prompt,查看tensorflow各个版本 anaconda search -t conda tensorflow 2.选择自己系统的版本:运行以下命令 anaconda ...
- SQL SERVER-数据库备份及记录
--完整备份 BACKUP DATABASE JINWEI TO DISK='D:\BAK\JINWEIFULL.bak' --日志备份 BACKUP LOG JINWEI TO DISK='D:\B ...
- Hbase Region in transition问题解决
1 hbase hbck -repair 强制修复 如果ok就可以 2 不ok,找到hdfs上对应的该表位置,删除,之后在使用hbase hbck -repair 解决过程: 第一次,使用了方法二, ...
- queue模块笔记
queue被称为消息队列,数据不会混乱,也可以用于复杂业务传递元素,队列是多线程的利器,其内部有锁的机制可以控制数据的统一且安全 queue.Queue()按照先进先出原则 queue.LifoQue ...
- Linq 中 Join 的用法
Linq中连接主要有组连接.内连接.左外连接.交叉连接四种.各个用法如下. 注:本文内容主要来自<Linq实战>,本例中用到的对象请见文章底部. 1. 组连接 组连接是与分组查询是一样的. ...
- 【Java】聚合和组合的区别
组合:部分与整体是与生俱来的,部分的存在依赖于整体.比如人与人的某个器官,人一出生,器官就在,人死亡,器官也就没了意义. 聚合:你与你的电脑(或者其它物品),电脑是属于你的吧,但是你是一出生就拥有了电 ...
- 【xsy1301】 原题的价值 组合数+斯特林数+FFT
题目大意:求$n\times2^{\frac{(n-1)(n-2)/2}{2}}\sum\limits_{i=0}^{n-1}\dbinom{n-1}{i}i^k$ 数据范围:$n≤10^9$,$k≤ ...
- 进程与线程与GIL的总结
- [SDOI2015][bzoj 3994][Luogu P3327] 约数个数和 (莫比乌斯反演)
题目描述 设d(x)d(x)d(x)为xxx的约数个数,给定NNN.MMM,求 ∑i=1N∑j=1Md(ij)\sum^{N}_{i=1}\sum^{M}_{j=1} d(ij)i=1∑Nj=1∑M ...
- sysobjects统计数据库的各类结构数据
概要: 查询表.以及表中的行数 SELECT a.name,b.rows FROM sysobjects a INNER JOIN sysindexes b ON a.id=b.id WHERE a. ...