PCA主成分分析基本原理及案例
发布于 2024-10-26


版权声明
我们非常重视原创文章,为尊重知识产权并避免潜在的版权问题,我们在此提供文章的摘要供您初步了解。如果您想要查阅更为详尽的内容,访问作者的公众号页面获取完整文章。


Python学习杂记
扫码关注公众号
扫码阅读
手机扫码阅读
主成分分析(PCA)摘要
基本原理
主成分分析(PCA)是一种在保留数据主要特征信息的前提下减少数据维度的技术。它通过将数据转换到新坐标系统来实现,其中新坐标的基是由数据集协方差矩阵的特征向量组成。这些特征向量称为主成分,第一主成分具有最大方差,依次类推。选择前几个主成分可以用更少的维度描述原始数据。
实现步骤
- 标准化:对数据进行去中心化处理,将每个特征的均值变为0,标准差变为1。
- 计算协方差矩阵:在标准化数据的基础上计算特征之间的协方差矩阵。
- 特征值和特征向量:计算协方差矩阵的特征值和特征向量,确定新坐标系的投影方向和长度。
- 选择主成分:根据特征值的大小选择前k个特征向量作为主成分。
- 数据转换:使用选定的主成分将原始数据转换到新坐标系。
详细案例
案例使用Python对鸢尾花数据集进行PCA降维。首先导入必要的库,包括numpy, matplotlib, seaborn, PCA和StandardScaler。数据集加载后,使用StandardScaler进行标准化。然后初始化PCA,将数据降维到2维。通过可视化,我们可以看到降维后不同类别的鸢尾花在二维空间中被清晰区分。
# 导入库
import numpy as np
import matplotlib.pyplot as plt
import seaborn as sns
from sklearn.decomposition import PCA
from sklearn.datasets import load_iris
from sklearn.preprocessing import StandardScaler
sns.set()
# 数据处理
iris = load_iris()
X = iris.data
y = iris.target
scaler = StandardScaler()
X_scaled = scaler.fit_transform(X)
# PCA降维
pca = PCA(n_components=2)
X_pca = pca.fit_transform(X_scaled)
# 结果可视化
plt.figure(figsize=(8, 6))
for i, target_name in enumerate(iris.target_names):
plt.scatter(X_pca[y == i, 0], X_pca[y == i, 1], label=target_name)
plt.xlabel('Principal Component 1')
plt.ylabel('Principal Component 2')
plt.legend()
plt.title('PCA of IRIS dataset')
plt.show()
Python学习杂记


Python学习杂记
扫码关注公众号
Python学习杂记的其他文章
Python制作精美的环形图
pycirclize库是一个用于创建和可视化环形图的工具,它提供了丰富的特性和功能。
遗传算法解决经典运输问题
遗传算法是优化求解常用的一种启发式算法,其原理是模拟进化的过程,包括交叉遗传、突变、选择等方式繁衍后代,计算机通过模拟这些算子,优中选优,通过一次次迭代、繁衍,这些过程的目的就是搜索最优解。
SciPy工具包基本使用介绍
SciPy是科学计算工具库之一。它提供了很多最常用且最有效的算法和函数。傅里
谷歌gemma:先进的轻量级开源大模型
2月21日,谷歌宣布正式发布了一款名为Gemma的开源大模型。而令人吃惊的是,这一发布距离谷歌上一次发布大模型Gemini1.5还不到一周时间。
Mosek求解器在Python中安装、配置及使用
本文将详细介绍如何在Python中安装、配置和使用高性能求解器Mosek。
加入社区微信群
与行业大咖零距离交流学习


PMO实践白皮书
白皮书上线
白皮书上线