吴恩达机器学习-使用PCA对二维数据降维

 代码:
 

import numpy as np
import scipy.io as sio
import matplotlib.pyplot as plt
mat=sio.loadmat('ex7data1.mat')
print(mat.keys())
X=mat['X']#(50,2)

# 初始数据可视化
plt.scatter(X[:,0],X[:,1])
plt.show()

# 1.X去均值化
X_demean=X-np.mean(X,axis=0)
# 绘制去均值化后的数据分布
plt.figure()
plt.scatter(X_demean[:,0],X_demean[:,1])
plt.show()

# 2.计算协方差矩阵
C=X_demean.T@X_demean/len(X)
print(C)

# 3.计算特征值和特征向量
U,S,V=np.linalg.svd(C)
# 要将二维转化为一维,所有我们取第一个特征值的特征向量
U1=U[:,0]

# 4.实现降维
X_reduction=X_demean@U1

# 绘制降维的那条直线
plt.figure()
plt.scatter(X_demean[:,0],X_demean[:,1])
plt.plot([0,U1[0]],[0,U1[1]],c='r')
plt.show()

# 5.还原数据
X_restore=X_
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值