如何用matplotlib绘制图像分类任务的类别特征空间分布

python 复制代码
import matplotlib.pyplot as plt
import numpy as np
from sklearn.decomposition import PCA
from sklearn.datasets import load_iris
from mpl_toolkits.mplot3d import Axes3D

# 加载示例数据(Iris 数据集)
data = load_iris()
X = data.data
y = data.target
categories = data.target_names

# 使用PCA将数据降维到二维
pca_2d = PCA(n_components=2)
X_reduced_2d = pca_2d.fit_transform(X)

# 绘制二维特征空间分布
plt.figure(figsize=(10, 8))
for i, category in enumerate(categories):
    plt.scatter(X_reduced_2d[y == i, 0], X_reduced_2d[y == i, 1], label=category)
plt.xlabel('PCA 1')
plt.ylabel('PCA 2')
plt.title('类别特征空间分布(二维)')
plt.legend()
plt.savefig('2d_feature_space.png')
plt.show()

# 使用PCA将数据降维到三维
pca_3d = PCA(n_components=3)
X_reduced_3d = pca_3d.fit_transform(X)

# 绘制三维特征空间分布
fig = plt.figure(figsize=(12, 10))
ax = fig.add_subplot(111, projection='3d')
for i, category in enumerate(categories):
    ax.scatter(X_reduced_3d[y == i, 0], X_reduced_3d[y == i, 1], X_reduced_3d[y == i, 2], label=category)
ax.set_xlabel('PCA 1')
ax.set_ylabel('PCA 2')
ax.set_zlabel('PCA 3')
ax.set_title('类别特征空间分布(三维)')
ax.legend()
plt.savefig('3d_feature_space.png')
plt.show()
相关推荐
半吊子全栈工匠5 分钟前
数据分析中10种常见的可视化图例
数据挖掘·数据分析
东方佑1 小时前
使用tkinter 制作工作流ui
前端·windows·笔记·python·ui·分类
zhangbin_2372 小时前
【Python机器学习】处理文本数据——将文本数据表示为词袋
人工智能·python·算法·机器学习·分类
CS数模4 小时前
2024 年 亚太赛 APMCM (B题)中文赛道国际大学生数学建模挑战赛 |洪水灾害数据分析 | 数学建模完整代码+建模过程全解全析
数学建模·数据挖掘·数据分析
X在敲AI代码6 小时前
零基础入门 Ai 数据挖掘竞赛-速通 Baseline-1
人工智能·数据挖掘
Cindy辛蒂6 小时前
python自动化办公之matplotlib
python·自动化·matplotlib
xiandong2011 小时前
240629_昇思学习打卡-Day11-Vision Transformer中的self-Attention
图像处理·人工智能·深度学习·学习·算法·分类·transformer
GPT-4o16 小时前
什么是自然语言处理(NLP)?详细解读文本分类、情感分析和机器翻译的核心技术
自然语言处理·分类·机器翻译
阡之尘埃16 小时前
Python数据分析案例47——笔记本电脑价格影响因素分析
python·机器学习·数据挖掘·数据分析·pandas
Kerry_619 小时前
2024年第十四届亚太地区大学生数学建模竞赛(中文赛项)B题洪水灾害的数据分析与预测论文和代码分析
人工智能·python·机器学习·数学建模·数据挖掘·数据分析