MultiTaskElasticNetCV#
- class sklearn.linear_model.MultiTaskElasticNetCV(*, l1_ratio=0.5, eps=0.001, n_alphas=100, alphas=None, fit_intercept=True, max_iter=1000, tol=0.0001, cv=None, copy_X=True, verbose=0, n_jobs=None, random_state=None, selection='cyclic')[源代码]#
多任务L1/L2 ElasticNet,内置交叉验证。
请参阅术语表条目 cross-validation estimator .
MultiTaskElasticNet的优化目标是::
(1 / (2 * n_samples)) * ||Y - XW||^Fro_2 + alpha * l1_ratio * ||W||_21 + 0.5 * alpha * (1 - l1_ratio) * ||W||_Fro^2
地点::
||W||_21 = \sum_i \sqrt{\sum_j w_{ij}^2}
即每一行的规范之和。
阅读更多的 User Guide .
Added in version 0.15.
- 参数:
- l1_ratiofloat或float列表,默认=0.5
ElasticNet混合参数,0 < l1_ratio <= 1。对于l1_ratio = 1,罚分是L1/L2罚分。对于l1_ratio = 0,这是L2罚分。为
0 < l1_ratio < 1
,处罚是L1/L2和L2的组合。该参数可以是一个列表,在这种情况下,通过交叉验证来测试不同的值,并使用给出最佳预测分数的值。请注意,l1_ratio值列表的一个好选择通常是将更多的值接近1(即Lasso),而不太接近0(即Ridge),如[.1, .5, .7, .9, .95, .99, 1]
.- eps浮点数,默认值= 1 e-3
路径的长度。
eps=1e-3
意味着alpha_min / alpha_max = 1e-3
.- n_alphasint,默认=100
正规化路径上阿尔法的数量。
- alphas类数组,默认=无
在哪里计算模型的阿尔法列表。如果未提供,则自动设置。
- fit_intercept布尔,默认=True
是否计算此模型的拦截。如果设置为假,则计算中不会使用任何拦截(即数据预计居中)。
- max_iterint,默认=1000
最大迭代次数。
- tolfloat,默认= 1 e-4
优化的容差:如果更新小于
tol
,优化代码检查双重差距的最佳性并继续,直到它小于tol
.- cvint,交叉验证生成器或可迭代,默认=无
确定交叉验证拆分策略。简历的可能输入包括:
无,若要使用默认的5重交叉验证,
int,指定折叠次数。
可迭代产出(训练、测试)分裂为索引数组。
对于int/No输入,
KFold
采用了指 User Guide 这里可以使用的各种交叉验证策略。
在 0.22 版本发生变更:
cv
如果无从3倍更改为5倍,则默认值。- copy_X布尔,默认=True
如果
True
,X将被复制;否则,可能会被覆盖。- verbosebool或int,默认=0
冗长的数量。
- n_jobsint,默认=无
交叉验证期间使用的处理器数量。请注意,只有在给出l1_ratio的多个值时才使用此选项。
None
意思是1,除非在a中joblib.parallel_backend
上下文-1
意味着使用所有处理器。看到 Glossary 了解更多详细信息。- random_stateint,RandomState实例,默认=无
选择要更新的随机要素的伪随机数生成器的种子。时使用
selection
==“随机”。传递int以获得跨多个函数调用的可重复输出。看到 Glossary .- selection'循环',',默认='循环'
如果设置为“随机”,则随机系数会在每次迭代中更新,而不是默认情况下顺序循环特征。这(设置为“随机”)通常会导致明显更快的收敛,尤其是当tol高于1 e-4时。
- 属性:
- intercept_ndarray of shape (n_targets,)
Independent term in decision function.
- coef_形状的nd数组(n_targets,n_features)
参数向量(成本函数公式中的W)。注意
coef_
存储的转置W
,W.T
.- alpha_浮子
通过交叉验证选择的处罚金额。
- mse_path_形状的nd数组(n_alphas,n_folds)或 (n_l1_ratio,n_alphas,n_folds)
每次折叠上测试集的均方误差,不同的阿尔法。
- alphas_形状的nd数组(n_alphas,)或(n_l1_ratio,n_alphas)
用于拟合的阿尔法网格,针对每个l1_ratio。
- l1_ratio_浮子
通过交叉验证获得的最佳l1_比率。
- n_iter_int
坐标下降解算器为达到最佳Alpha的指定容差而运行的迭代次数。
- dual_gap_浮子
优化最佳Alpha结束时的双重差距。
- n_features_in_int
期间看到的功能数量 fit .
Added in version 0.24.
- feature_names_in_ :nd形状数组 (
n_features_in_
,)nd数组形状( Names of features seen during fit. Defined only when
X
has feature names that are all strings.Added in version 1.0.
参见
MultiTaskElasticNet
多任务L1/L2 ElasticNet,内置交叉验证。
ElasticNetCV
弹性网络模型,通过交叉验证选择最佳模型。
MultiTaskLassoCV
使用L1范数作为正则化器和内置交叉验证训练的多任务Lasso模型。
注意到
用于匹配模型的算法是坐标下降。
在
fit
,曾经的最佳参数l1_ratio
和alpha
通过交叉验证找到,则使用整个训练集再次匹配模型。为了避免不必要的内存重复,
X
和y
论点fit
方法应该直接作为Forrester连续的numpy数组传递。示例
>>> from sklearn import linear_model >>> clf = linear_model.MultiTaskElasticNetCV(cv=3) >>> clf.fit([[0,0], [1, 1], [2, 2]], ... [[0, 0], [1, 1], [2, 2]]) MultiTaskElasticNetCV(cv=3) >>> print(clf.coef_) [[0.52875032 0.46958558] [0.52875032 0.46958558]] >>> print(clf.intercept_) [0.00166409 0.00166409]
- fit(X, y, **params)[源代码]#
使用坐标下降来适应MultiTaskElasticNet模型。
Fit位于阿尔法网格上,通过交叉验证估计的最佳阿尔法网格上。
- 参数:
- X形状的nd数组(n_samples,n_features)
训练数据。
- y形状的nd数组(n_samples,n_targets)
训练目标变量。如有必要,将被转换为X的d类型。
- **paramsdict,默认=无
要传递给CV拆分器的参数。
Added in version 1.4: 仅在以下情况下可用
enable_metadata_routing=True
,可以使用sklearn.set_config(enable_metadata_routing=True)
.看到 Metadata Routing User Guide 了解更多详细信息。
- 返回:
- self对象
返回MultiTaskElasticNet实例。
- get_metadata_routing()[源代码]#
获取此对象的元数据路由。
请检查 User Guide 关于路由机制如何工作。
Added in version 1.4.
- 返回:
- routingMetadataRouter
A
MetadataRouter
封装路由信息。
- get_params(deep=True)[源代码]#
获取此估计器的参数。
- 参数:
- deep布尔,默认=True
如果为True,将返回此估计量和包含的作为估计量的子对象的参数。
- 返回:
- paramsdict
参数名称映射到其值。
- static path(X, y, *, l1_ratio=0.5, eps=0.001, n_alphas=100, alphas=None, precompute='auto', Xy=None, copy_X=True, coef_init=None, verbose=False, return_n_iter=False, positive=False, check_input=True, **params)[源代码]#
通过坐标下降计算弹性净路径。
弹性网络优化函数针对单输出和多输出而变化。
对于单输出任务,它是::
1 / (2 * n_samples) * ||y - Xw||^2_2 + alpha * l1_ratio * ||w||_1 + 0.5 * alpha * (1 - l1_ratio) * ||w||^2_2
对于多输出任务,它是::
(1 / (2 * n_samples)) * ||Y - XW||_Fro^2 + alpha * l1_ratio * ||W||_21 + 0.5 * alpha * (1 - l1_ratio) * ||W||_Fro^2
地点::
||W||_21 = \sum_i \sqrt{\sum_j w_{ij}^2}
即每一行的规范之和。
阅读更多的 User Guide .
- 参数:
- X形状(n_samples,n_features)的{类数组,稀疏矩阵}
训练数据。作为Forrester连续数据直接传递,以避免不必要的内存重复。如果
y
那么是单输出X
可以是稀疏的。- y形状(n_samples,)的{类数组,稀疏矩阵}或 (n_样本,n_目标)
目标值。
- l1_ratio浮点数,默认值=0.5
0和1之间的数字传递到弹性网(在l1和l2罚分之间缩放)。
l1_ratio=1
对应于套索。- eps浮点数,默认值= 1 e-3
路径的长度。
eps=1e-3
意味着alpha_min / alpha_max = 1e-3
.- n_alphasint,默认=100
正规化路径上阿尔法的数量。
- alphas类数组,默认=无
在哪里计算模型的阿尔法列表。如果无,则自动设置alpha。
- precompute“自动”、布尔或阵列状的形状 (n_features,n_features),默认='自动'
是否使用预先计算的Gram矩阵来加速计算。如果设置为
'auto'
让我们决定。Gram矩阵也可以作为参数传递。- Xy形状类似阵列(n_features,)或(n_features,n_targets), 默认值=无
Xy = np.dot(X.T,y),可以预先计算。只有在预先计算Gram矩阵时,它才有用。
- copy_X布尔,默认=True
如果
True
,X将被复制;否则,可能会被覆盖。- coef_init形状类似阵列(n_features,),默认=无
系数的初始值。
- verbosebool或int,默认=False
冗长的数量。
- return_n_iter布尔,默认=假
是否返回迭代次数。
- positive布尔,默认=假
如果设置为True,则强制系数为正。(Only前容
y.ndim == 1
).- check_input布尔,默认=True
如果设置为False,则跳过输入验证检查(包括提供的Gram矩阵)。假设它们由呼叫者处理。
- **paramskwargs
关键字参数传递给坐标下降求解器。
- 返回:
- alphas形状的nd数组(n_alphas,)
沿着模型计算路径的阿尔法。
- coefs形状的nd数组(n_features,n_alphas)或 (n_targets,n_features,n_alphas)
沿着路径的系数。
- dual_gaps形状的nd数组(n_alphas,)
每个Alpha优化结束时的双重差距。
- n_itersint列表
The number of iterations taken by the coordinate descent optimizer to reach the specified tolerance for each alpha. (Is returned when
return_n_iter
is set to True).
参见
MultiTaskElasticNet
使用L1/L2混合范数训练的多任务ElasticNet模型 作为正则化器
MultiTaskElasticNetCV
多任务L1/L2 ElasticNet,内置交叉验证。
ElasticNet
以L1和L2先验组合作为正规化器的线性回归。
ElasticNetCV
弹性网络模型,沿着规则化路径迭代匹配。
注意到
有关示例,请参阅 examples/linear_model/plot_lasso_lasso_lars_elasticnet_path.py .
示例
>>> from sklearn.linear_model import enet_path >>> from sklearn.datasets import make_regression >>> X, y, true_coef = make_regression( ... n_samples=100, n_features=5, n_informative=2, coef=True, random_state=0 ... ) >>> true_coef array([ 0. , 0. , 0. , 97.9..., 45.7...]) >>> alphas, estimated_coef, _ = enet_path(X, y, n_alphas=3) >>> alphas.shape (3,) >>> estimated_coef array([[ 0. , 0.78..., 0.56...], [ 0. , 1.12..., 0.61...], [-0. , -2.12..., -1.12...], [ 0. , 23.04..., 88.93...], [ 0. , 10.63..., 41.56...]])
- predict(X)[源代码]#
Predict using the linear model.
- 参数:
- X类阵列或稀疏矩阵,形状(n_samples,n_features)
样品
- 返回:
- C数组,形状(n_samples,)
返回预测值。
- score(X, y, sample_weight=None)[源代码]#
返回预测的决定系数。
决定系数 \(R^2\) 被定义为 \((1 - \frac{u}{v})\) ,在哪里 \(u\) 是残差平方和
((y_true - y_pred)** 2).sum()
和 \(v\) 是平方总和((y_true - y_true.mean()) ** 2).sum()
.最好的可能分数是1.0,并且可以是负的(因为模型可以任意更差)。始终预测的期望值的恒定模型y
如果不考虑输入功能,就会得到 \(R^2\) 评分0.0。- 参数:
- X形状类似阵列(n_samples,n_features)
Test samples. For some estimators this may be a precomputed kernel matrix or a list of generic objects instead with shape
(n_samples, n_samples_fitted)
, wheren_samples_fitted
is the number of samples used in the fitting for the estimator.- y形状的类似阵列(n_samples,)或(n_samples,n_outputs)
真正的价值观
X
.- sample_weight形状类似数组(n_samples,),默认=无
样本重量。
- 返回:
- score浮子
\(R^2\) 的
self.predict(X)
w.r.t.y
.
注意到
的 \(R^2\) 呼叫时使用的分数
score
在回归器上使用multioutput='uniform_average'
从0.23版本开始,与默认值保持一致r2_score
.这影响了score
所有多输出回归器的方法(除了MultiOutputRegressor
).
- set_fit_request(*, sample_weight: bool | None | str = '$UNCHANGED$') MultiTaskElasticNetCV [源代码]#
请求元数据传递给
fit
法请注意,此方法仅适用于以下情况
enable_metadata_routing=True
(见sklearn.set_config
).请参阅 User Guide 关于路由机制如何工作。The options for each parameter are:
True
:元数据被请求并传递给fit
如果提供的话。如果未提供元数据,则会忽略请求。False
:未请求元数据,元估计器不会将其传递给fit
.None
:不请求元数据,如果用户提供元估计器,则元估计器将引发错误。str
:元数据应通过此给定别名而不是原始名称传递给元估计器。
默认 (
sklearn.utils.metadata_routing.UNCHANGED
)保留现有请求。这允许您更改某些参数的请求,而不是其他参数。Added in version 1.3.
备注
只有当该估计器用作元估计器的子估计器时,该方法才相关,例如在
Pipeline
.否则就没有效果了。- 参数:
- sample_weight字符串、真、假或无, 默认=sklearn.utils. metalics_Routing.UNChanged
元数据路由
sample_weight
参数fit
.
- 返回:
- self对象
更新的对象。
- set_params(**params)[源代码]#
设置此估计器的参数。
该方法适用于简单估计器以及嵌套对象(例如
Pipeline
).后者具有以下形式的参数<component>__<parameter>
以便可以更新嵌套对象的每个组件。- 参数:
- **paramsdict
估计参数。
- 返回:
- self估计器实例
估计实例。
- set_score_request(*, sample_weight: bool | None | str = '$UNCHANGED$') MultiTaskElasticNetCV [源代码]#
请求元数据传递给
score
法请注意,此方法仅适用于以下情况
enable_metadata_routing=True
(见sklearn.set_config
).请参阅 User Guide 关于路由机制如何工作。The options for each parameter are:
True
:元数据被请求并传递给score
如果提供的话。如果未提供元数据,则会忽略请求。False
:未请求元数据,元估计器不会将其传递给score
.None
:不请求元数据,如果用户提供元估计器,则元估计器将引发错误。str
:元数据应通过此给定别名而不是原始名称传递给元估计器。
默认 (
sklearn.utils.metadata_routing.UNCHANGED
)保留现有请求。这允许您更改某些参数的请求,而不是其他参数。Added in version 1.3.
备注
只有当该估计器用作元估计器的子估计器时,该方法才相关,例如在
Pipeline
.否则就没有效果了。- 参数:
- sample_weight字符串、真、假或无, 默认=sklearn.utils. metalics_Routing.UNChanged
元数据路由
sample_weight
参数score
.
- 返回:
- self对象
更新的对象。