光谱PCA——Python实现

import pandas as pd
from sklearn.decomposition import PCA
import matplotlib.pyplot as plt

# 加载CSV数据
df = pd.read_csv('你的数据路径')

# Separate features and labels
features = df.iloc[:, :-1]  # data features (excluding the last column)
labels = df.iloc[:, -1]  # labels (the last column)

# Label names
classes = ['class1', 'class2', 'class3', 'class4', 'class5']
unique_labels = df['label'].unique()  # Get unique labels to use in visualization

# Perform PCA on the data
pca = PCA(n_components=3)  # Reduce to 3D for visualization
pca_result = pca.fit_transform(features)

# Visualization of PCA result
plt.figure(figsize=(10, 7))

# Since the labels are integers, we can use them directly in the loop
for i, day in enumerate(classes):
    plt.scatter(pca_result[labels==unique_labels[i], 0], pca_result[labels==unique_labels[i], 1], label=day)

plt.xticks(fontsize=20)  # Set the font size for the x-axis tick labels
plt.yticks(fontsize=20)  # Set the font size for the y-axis tick labels
plt.legend(fontsize=18)

# Display the explained variance ratio for each principal component
explained_variance_ratio = pca.explained_variance_ratio_
plt.xlabel(f'PC-1 ({explained_variance_ratio[0]*100:.2f}%)', size=20)
plt.ylabel(f'PC-2 ({explained_variance_ratio[1]*100:.2f}%)', size=20)
# plt.ylabel(f'PC-3 ({explained_variance_ratio[2]*100:.2f}%)', size=20)

plt.title('PCA Result', fontsize=24)

plt.show()

# Get and visualize the loadings
loadings = pca.components_
loadings_df = pd.DataFrame(loadings.T, columns=['PC-1', 'PC-2', 'PC-3'])

# Visualization of loadings as waveforms
plt.figure(figsize=(10, 7))
plt.plot(loadings[0], label='PC-1', color='blue')
plt.plot(loadings[1], label='PC-2', color='red')
plt.plot(loadings[2], label='PC-3', color='green')
plt.xlabel('Feature Index', fontsize=14)
plt.ylabel('Loading Value', fontsize=14)
plt.title('Loading Waveforms', fontsize=16)
plt.legend(fontsize=12)
plt.grid(True)
plt.show()

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

书奇真的苟@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值