PCA在人脸识别的应用

一、数据获取

代码示例:

import numpy as np
import matplotlib.pyplot as plt
from sklearn.datasets import fetch_lfw_people

faces = fetch_lfw_people()

faces.data.shape
#运行结果:(13233, 2914)

faces.images.shape
#运行结果:(13233, 62, 47)

ramdom_indexes = np.random.permutation(len(faces.data))  #获得随机排列
X = faces.data[ramdom_indexes]

example_faces = X[:36,:] #获得随机36张脸

#图形可视化
def plot_digits(faces):
    fig, axes = plt.subplots(6,6,figsize=(10,10),subplot_kw = {'xticks':[],'yticks':[]},
    gridspec_kw = dict(hspace=0.1,wspace=0.1))
    for i, ax in enumerate(axes.flat):
        ax.imshow(faces[i].reshape(62,47),cmap='bone')
    plt.show()
    
plot_digits(example_faces)

运行结果:

 

二、特征脸

代码示例:

from sklearn.decomposition import PCA 
pca = PCA(svd_solver='randomized')
pca.fit(X)

pca.components_.shape  #2914个主成分,对应2914个向量

plot_digits(pca.components_[:36,:])

运行结果:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值