基于PCA的人脸识别

基于PCA的人脸识别

一、算法描述

这次项目人脸识别只要靠PCA算法实现,算法的主要步骤如下:

1.首先,应题目要求,对于所有的Faces集里的40个人,各随机取出其10张图像中的7张用作训练集,剩余3张用作后续的测试。

2.然后,将280张train_imgs都拉伸成列向量并将所有列拼在一起,由于每张图像的总像素数都为10304,这样就得到了10304*280的矩阵X。

3.X的每列再减去均值向量,从而中心化。

4.求出X的转置和X的矩阵乘积,并求出乘积40*40矩阵的特征向量,这里用的是matlab的eig函数。

5.滤出前K大的特征值对应的特征向量W,再将X乘上W映射得到V,将V的每一列向量作为后续映射关系的一组基向量,共有K个基向量,也可以称为K个特征脸。

6.将X每一列都通过基向量矩阵V映射到对应的特征空间中。这样相当于将每张图像train_imgs都在新的空间中找到了对应的位置。

7.对于每个测试图像,也进行类似上述的变换:转成列向量,减去均值向量而中心化,然后用基向量矩阵映射到特征空间中。

8.要判断测试图像和40张train_imgs的哪张最匹配,只需对比测试图像在特征空间的新坐标和40张train_imgs在特征空间的坐标直接的欧几里得距离(或二范数)的大小,找到二范数最小的对应的train_img,就找到了最匹配训练图像了。

9.综上所述,这种算法的主要思想就是,去除部分无关的或者关系较小的向量,保留影响较大的向量作基,这样即减少了基向量的数目从而减少了运算量,同时又减少了图像细节,能避免无关的向量和测试图像主人公的表情、脸朝向和配饰等变化对测试准确性产生不良干扰。

二.Matlab代码

函数Get_Training_Set.m(用来随机读取40*7张图像并分别作平均产生训练集):

function [ imgs ] = Get_Training_Set( input_path, index, height, width, output_path )     
    imgs = zeros(length(index), height, width);     
    for i = 1 : length(index)         
        imgs(i, :, :) = uint8(imread([input_path '/' num2str(index(i)) '.pgm']
  • 2
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
基于范数PCA人脸识别代码主要是指使用了范数正则化来优化PCA人脸识别的模型,以提高识别率和鲁棒性。具体实现时,可以将PCA中的特征向量用L1或L2范数进行正则化,使得这些特征向量的大小和方向分布更加合理。然后可以利用这些经过正则化的特征向量进行训练和测试,得到更加准确和鲁棒的人脸识别结果。 实现基于范数PCA人脸识别的代码需要以下步骤: 1. 数据预处理:对输入图像进行了尺寸的归一化和灰度化处理,提高处理的效率和准确性。 2. 利用PCA进行降维:选取一定数量的特征向量,通过奇异值分解(SVD)的计算方法,将初始高维的数据降维到低维空间。 3. 进行范数正则化:利用L1或L2范数正则化方法对PCA中的特征向量进行处理,使得这些特征向量的规范化程度更高,并且方向更加准确。 4. 训练分类器:使用支持向量机(SVM)或其他机器学习算法来训练分类器,分类器将输入的低维向量映射到相应的人脸类别上。 5. 进行测试:对于一个新的输入图像,将其进行预处理、PCA降维、范数正则化和分类器判别等步骤,得到最终的人脸识别结果。 基于范数PCA人脸识别代码可以有效地提高人脸识别的准确性和鲁棒性,广泛应用于人脸识别领域。其中的特征提取、降维和正则化方法等也可以应用于其他图像处理和机器学习领域。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值