QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2712|回复: 0
打印 上一主题 下一主题

偏最小二乘回归分析

[复制链接]
字体大小: 正常 放大

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-11-30 16:59 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
偏小二乘回归提供一种多对多线性回归建模的方法,特别当两组变量的个数很多,且都存在多重相关性,而观测数据的数量(样本量)又较少时,用偏小二乘回归建立的模型具有传统的经典回归分析等方法所没有的优点。9 l9 G  _0 ~5 C7 F& O! z
偏小二乘回归分析在建模过程中集中了主成分分析,典型相关分析和线性回归分析方法的特点,因此在分析结果中,除了可以提供一个更为合理的回归模型外,还可以同时完成一些类似于主成分分析和典型相关分析的研究内容,提供更丰富、深入的一些信息。
  1. import numpy as np
  2. ; [# n+ ~% {' h. e; {! A
  3. from sklearn.cross_decomposition import PLSRegression0 s$ ]! F& y3 Y8 Z2 c
  4. from sklearn.preprocessing import StandardScaler8 v  ~7 e0 K8 S6 I0 c) p
  5. import matplotlib.pyplot as plt
  6. 5 D\\" ^* C8 c\\" Z7 P
  7. & b; v& T, g% V1 `/ b8 Y  u
  8. # 原始数据,自变量X和因变量y; d& g* I9 n8 I
  9. X = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9], [10, 11, 12]])
  10. 7 ?& w/ `5 q! X& j9 ]
  11. y = np.array([1, 2, 3, 4])
  12. 9 H% E* ]& |3 b* c+ a6 d\\" _

  13. 8 ~, [7 I, n9 c+ D/ M7 r
  14. # 对自变量进行标准化处理
  15. ( _/ `, O9 n3 ?$ t9 T: N1 M2 j
  16. scaler = StandardScaler()
  17. , j( |& ]0 }# }/ G# h+ }/ S, m5 J
  18. X_scaled = scaler.fit_transform(X)
  19. 9 m6 }- C\\" [0 E5 X) s\\" g5 n6 ?! _6 Y

  20. - _5 ~' ~% }\\" K7 d2 V0 T2 B; S/ f) S
  21. # 创建PLSRegression对象,并指定主成分个数为2
  22. ' z2 O, x9 r0 H2 v. V
  23. pls = PLSRegression(n_components=2)/ y5 C. R. b' l' T

  24. 0 a2 y! ?  J5 A1 t
  25. # 进行偏最小二乘回归分析
  26. + r- E) T* I/ V8 k; a
  27. pls.fit(X_scaled, y)
  28. 5 }) Q6 Q- X8 P6 ^# N

  29. & w8 q& w  b7 y4 d  J
  30. # 获得预测值6 x' ~* L7 `# H: k6 k/ d
  31. y_pred = pls.predict(X_scaled)' O  z8 p( B9 h' u9 T& \  X( P2 V

  32. 4 q8 K; t$ {4 n6 a* D, _
  33. # 绘制原始数据和预测值6 t- G+ I: K4 Y3 P& n! T4 A
  34. plt.figure(figsize=(8, 6))  g( b! Z\\" P$ I& p3 o) Z1 l2 i\\" c
  35. plt.scatter(y, y_pred, c='b', label='Predicted vs. Observed'), o5 b\\" i1 Q1 r/ D9 P. j: I3 n: I6 E9 Z
  36. plt.plot([min(y), max(y)], [min(y), max(y)], 'k--', lw=2, label='Perfect Fit')4 U- a; i$ W6 Q
  37. plt.xlabel('Observed')
  38. # w\\" c9 g) m- A+ A5 ~( S- M
  39. plt.ylabel('Predicted')
  40. . b# a: ~+ J7 I6 o9 H0 ^
  41. plt.title('PLS Regression')
  42. ; e9 d) ~6 U# g6 Q, s8 }' _
  43. plt.legend()# r1 a# g& |$ v4 U0 V0 @* T! Z
  44. plt.grid(True)* j# B/ C* e( I4 Z  N9 W
  45. plt.show()
  46. ' T, J\\" ~4 y% }3 H/ n
  47. ! p! V: Q3 f# L4 U8 n$ H
在上述代码中,我们首先定义了原始数据矩阵X和因变量向量y,然后创建了一个PLSRegression对象并指定保留的主成分个数为2。接下来,使用fit()方法进行偏最小二乘回归分析,并使用coef_属性获取回归系数。最后,使用predict()方法对原始数据进行预测,并获得预测值y_pred。请根据实际情况调整原始数据和保留的主成分个数,并根据需要对结果进行解释和分析。
9 Z- @& }( H& b$ G运行上述代码,将绘制散点图来展示观察值(原始数据)与预测值之间的关系。如果模型拟合良好,散点图中的点应该基本落在对角线上。如果点主要集中在对角线上方,则预测值高估了观察值;如果点主要集中在对角线下方,则预测值低估了观察值。在理想情况下,所有点都应该在对角线上。( a4 Q! s& _0 Z. m1 P
VeryCapture_20231130164832.jpg
3 u6 S+ W) l- v( }2 t' l# Q; d# M  U+ g' t% c
; j. P$ y: K! w! ^3 a3 N/ R. r" p
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-10 15:06 , Processed in 0.389490 second(s), 54 queries .

回顶部