- 在线时间
- 479 小时
- 最后登录
- 2026-5-9
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7813 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2931
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1173
- 主题
- 1188
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
岭回归是一种用于处理多重共线性数据的线性回归技术,它通过对系数施加惩罚来限制模型的复杂性。这个惩罚项是通过添加一个正则化参数(通常表示为 λ 或 alpha)与系数向量的 L2 范数的平方成比例来实现的。岭回归的优化目标是最小化残差平方和和正则化项之和。
Z H9 X6 M7 H( K) k下面是岭回归的关键特点:8 h% j' E& v' x5 A+ V. g8 W8 W
, D( r1 S' Z5 y2 u1.正则化项: 岭回归通过添加一个惩罚项来约束模型的系数,使其不要过大,从而避免过拟合。这个惩罚项由正则化参数控制,它越大,惩罚效果越强,系数越趋向于零。
@& b X) ?6 v! Q g, f* `6 ^2.解决多重共线性: 当特征之间存在高度相关性时,普通的线性回归模型可能会变得不稳定,导致系数估计不准确。岭回归通过对系数的大小进行限制,能够更好地应对多重共线性问题。
2 m; J* S1 Z# c3.超参数调优: 岭回归有一个关键的超参数,即正则化参数(λ 或 alpha)。这个参数需要根据数据集进行调优,通常使用交叉验证来选择最佳的正则化参数,以在训练数据上获得最佳的模型性能。6 H0 j" ?5 j6 [" h
4.稳定性: 与普通的线性回归相比,岭回归对数据中的噪声更加稳健,能够产生更加稳定和可靠的系数估计。5 e0 L" s8 o% ]
5.不可解性: 与普通的线性回归不同,岭回归没有封闭形式的解析解,需要使用数值优化方法来求解。
) P, {5 u/ ~3 B1 O. V: C) R* X7 Z; C3 {4 H1 q. }/ ~" R
总的来说,岭回归是一种强大的线性回归技术,特别适用于处理高维数据集或存在多重共线性的数据。
; e4 G/ i: E% V M2 U6 ]. h5 l. N' @. Y% v
, t# u( C& a9 k0 W9 [这段代码执行了以下操作:, ?* S1 q$ A; r0 W4 C
, L1 C5 L( v. X9 a7 ? H9 { H$ n1.导入所需库:- import numpy as np
1 r\" r\" d/ b- y& \! Z - import pandas as pd- }5 D1 O1 |8 w' @+ ?3 b, g
- from sklearn.linear_model import LogisticRegression
复制代码 2.定义源数据:- df = pd.DataFrame({\" U6 N+ Z3 x% G
- 'good': [1, 1, 0, 0, 0, 1, 1],7 N5 H9 {: q1 T
- 'sweet': [.95, .76, .82, .57, .69, .77, .89],9 C) m+ j; h1 i/ x, @8 ^& z
- 'density': [.876, .978, .691, .745, .512, .856, 1.297],7 C' b4 `3 L! \& ]2 G% T
- 'volume': [1.85, 2.14, 1.34, 1.38, 0.67, 2.35, 1.69],
! L# l9 h6 F/ {4 G3 f3 |% @# ?. } - 'quality': [2.51, 2.45, 1.34, 1.15, 1.23, 3.95, 2.67],
3 k. X: `0 |# Z( d& `\" k\" D - })
复制代码 创建了一个包含特征和标签的 DataFrame,其中 good 列是标签,表示样本是否好。8 I: ^% i4 W) [/ \
3 v: |9 E* e, @# m6 B8 ?& x3.将数据转换为数组格式:- X = np.array(df[df.columns[1:]]) # 特征集
3 y5 q4 E5 B- k - y = np.array(df['good']) # 标签集
复制代码 4.建立逻辑回归模型并拟合数据:- model = LogisticRegression()% {; _; V: ^ q. y& D6 `8 ^/ C T
- model.fit(X, y)
复制代码 使用 LogisticRegression 创建了逻辑回归模型,并使用 fit() 方法拟合了数据。$ b( [$ N6 y {/ e* U
% ?1 [) U8 }2 w; n S6 e
5.提取模型参数:- b0 = model.intercept_[0] # 截距
1 R( e# c6 q2 D1 M5 {4 F1 Y - b1, b2, b3, b4 = model.coef_[0][0], model.coef_[0][1], model.coef_[0][2], model.coef_[0][3] # 系数
复制代码 6.进行预测:- df2 = pd.DataFrame({5 T4 Q9 T2 t( p1 D
- 'sweet': [.5, 1],
9 f- q. I% K3 Q - 'density': [.5, 1],
! Q, }( t- ]. z2 u, q6 _1 }1 M - 'volume': [.5, 2],\" E2 K5 o' d( ]8 P
- 'quality': [.5, 2],& W2 ^\" ]\" Y+ A9 h' P* r
- })' N5 ]1 k( \\" a
- model.predict(np.array(df2))
复制代码 使用训练好的模型进行预测,预测了两个新样本的好坏标签。4 _: y) q2 Q( U" e' W; z
通过这段代码,你可以使用逻辑回归模型对给定的数据进行分类,并进行新样本的预测。8 q9 y' j$ U5 _. Q5 t4 H, A
1 i4 r# }% A- b3 A
! @1 r6 f- T4 d* n3 J' g. Y
|
zan
|