在线时间 479 小时 最后登录 2026-4-13 注册时间 2023-7-11 听众数 4 收听数 0 能力 0 分 体力 7789 点 威望 0 点 阅读权限 255 积分 2922 相册 0 日志 0 记录 0 帖子 1171 主题 1186 精华 0 分享 0 好友 1
该用户从未签到
偏小二乘回归提供一种多对多线性回归建模的方法,特别当两组变量的个数很多,且都存在多重相关性,而观测数据的数量(样本量)又较少时,用偏小二乘回归建立的模型具有传统的经典回归分析等方法所没有的优点。
$ Q1 |" |* F1 Z0 m5 e; S4 r# g, \' ] 偏小二乘回归分析在建模过程中集中了主成分分析,典型相关分析和线性回归分析方法的特点,因此在分析结果中,除了可以提供一个更为合理的回归模型外,还可以同时完成一些类似于主成分分析和典型相关分析的研究内容,提供更丰富、深入的一些信息。import numpy as np. ]8 y\\" R2 g8 {' ?' T& d( r% r( I
from sklearn.cross_decomposition import PLSRegression
% ]% u- z2 Z2 o3 Z from sklearn.preprocessing import StandardScaler4 B7 D$ d }. s1 F9 r* F4 A
import matplotlib.pyplot as plt
U1 n( A, [/ U9 N
5 q# R+ ^\\" {; I$ \ # 原始数据,自变量X和因变量y/ t7 u; x4 I7 I1 {0 `. {
X = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9], [10, 11, 12]])
! W, I' B* E1 V9 u% E! z y = np.array([1, 2, 3, 4])1 S, ~; A6 e! r/ D
' I' i4 v* X* g/ H
# 对自变量进行标准化处理5 ?6 k; c2 u) L7 L
scaler = StandardScaler()
1 Z* {\\" o- T* E5 g$ L( s X_scaled = scaler.fit_transform(X)
) D1 |; c\\" e+ r, Z/ a
8 i: @3 M% I- d\\" G& ]4 k # 创建PLSRegression对象,并指定主成分个数为2/ b- n' {: U1 B
pls = PLSRegression(n_components=2)! V) {: g3 m6 l
+ k% E( s$ s3 \! ?' t* U
# 进行偏最小二乘回归分析1 {* _$ ?8 m/ v: B& y
pls.fit(X_scaled, y)6 V/ n `! A G2 s+ R I
$ l' m+ a4 I. S0 R # 获得预测值
# f2 A9 X) c, g; X; `0 b# S7 Z9 ? y_pred = pls.predict(X_scaled)
: t6 ~6 Y o0 {1 e* W6 i: K- { 1 _7 m, ], {! a% m1 U4 H- C: `) D
# 绘制原始数据和预测值\\" A% W0 y8 l/ E
plt.figure(figsize=(8, 6))2 `, l8 K5 p& ?8 i4 @: ]
plt.scatter(y, y_pred, c='b', label='Predicted vs. Observed')2 G' n2 j9 W8 x( I/ Q
plt.plot([min(y), max(y)], [min(y), max(y)], 'k--', lw=2, label='Perfect Fit')/ C$ T+ x8 h3 Z: H
plt.xlabel('Observed')
7 K2 k1 Y) W2 ^6 j8 W% X$ t( C plt.ylabel('Predicted')
1 [4 }. f1 {. a# ~$ L) D9 F plt.title('PLS Regression')
! N' i. P1 T6 n( B5 g8 A plt.legend()3 H+ v6 x/ W# j) ], E/ M
plt.grid(True)
/ F8 n5 }5 |5 ]1 J& S1 T0 c plt.show()
6 v% v* y$ u\\" `$ S2 H; Q
0 w' Y9 }) h7 s9 S, ~
在上述代码中,我们首先定义了原始数据矩阵X和因变量向量y,然后创建了一个PLSRegression对象并指定保留的主成分个数为2。接下来,使用fit()方法进行偏最小二乘回归分析,并使用coef_属性获取回归系数。最后,使用predict()方法对原始数据进行预测,并获得预测值y_pred。请根据实际情况调整原始数据和保留的主成分个数,并根据需要对结果进行解释和分析。+ z: R f! V! ^. s9 _
运行上述代码,将绘制散点图来展示观察值(原始数据)与预测值之间的关系。如果模型拟合良好,散点图中的点应该基本落在对角线上。如果点主要集中在对角线上方,则预测值高估了观察值;如果点主要集中在对角线下方,则预测值低估了观察值。在理想情况下,所有点都应该在对角线上。
6 D. q. i- K' ]$ g, ^, U
, C& T/ V: M, Q/ D5 }' i4 D " z9 A8 B- k: S2 \% Q7 d, t
( q; E) b( {5 r$ G4 ~, V
zan