基于BP神经网络的人脸识别

10 篇文章 0 订阅
4 篇文章 0 订阅

一、实验要求

采用三层前馈BP神经网络实现标准人脸YALE数据库的识别,编程语言为C系列语言。

二、BP神经网络的结构和学习算法

实验中建议采用如下最简单的三层BP神经网络,输入层为,有n个神经元节点,输出层具有m个神经元,网络输出为,隐含层具有k个神经元,采用BP学习算法训练神经网络。

BP神经网络的结构

BP网络在本质上是一种输入到输出的映射,它能够学习大量的输入与输出之间的映射关系,而不需要任何输入和输出之间的精确的数学表达式,只要用已知的模式对BP网络加以训练,网络就具有输入输出对之间的映射能力。

BP网络执行的是有教师训练,其样本集是由形如(输入向量,期望输出向量)的向量对构成的。在开始训练前,所有的权值和阈值都应该用一些不同的小随机数进行初始化。

BP算法主要包括两个阶段:

(1) 向前传播阶段

①从样本集中取一个样本(Xp,Yp),将Xp输入网络,其中Xp为输入向量,Yp为期望输出向量。

②计算相应的实际输出Op

在此阶段,信息从输入层经过逐级的变换,传送到输出层。这个过程也是网络在完成训练后正常运行时执行的过程。在此过程中,网络执行的是下列运算:

                   

(2) 向后传播阶段

①计算实际输出Op与相应的理想输出Yp的差;

②按极小化误差的方法调整权矩阵。

这两个阶段的工作一般应受到精度要求的控制,定义

                                             (1)

作为网络关于第p个样本的误差测度(误差函数)。而将网络关于整个样本集的误差测度定义为

                                                      (2)

如前所述,之所以将此阶段称为向后传播阶段,是对应于输入信号的正常传播而言的,也称之为误差传播阶段。

为了更清楚地说明本文所使用的BP网络的训练过程,首先假设输入层、中间层和输出层的单元数分别是N、L和M。X=(x0,x1,…,xN-1)是加到网络的输入矢量,H=(h0,h1,…,hL-1)是中间层输出矢量,Y=(y0,y1,…,yM-1)是网络的实际输出矢量,并且用D=(d0,d1,…,dM-1)来表示训练组中各模式的目标输出矢量。输出单元i到隐单元j的权值是Vij,而隐单元j到输出单元k的权值是Wjk。另外用θk和Φj来分别表示输出单元和隐单元的阈值。

于是,中间层各单元的输出为:

                                 (3)            

而输出层各单元的输出是:

                                             (4)

其中f(*)是激励函数,采用S型函数: 

                                                 (5)

在上述条件下,网络的训练过程如下:

(1) 选定训练集。由相应的训练策略选择样本图像作为训练集。

(2) 初始化各权值Vij,Wjk和阈值Φj,θk,将其设置为接近于0的随机值,并初始化精度控制参数ε和学习率α。

(3) 从训练集中取一个输入向量X加到网络,并给定它的目标输出向量D。

(4) 利用式(3)计算出一个中间层输出H,再用式(4)计算出网络的实际输出Y。

(5) 将输出矢量中的元素yk与目标矢量中的元素dk进行比较,计算出M个输出误差项:对中间层的隐单元也计算出L个误差项:

(6) 依次计算出各权值和阈值的调整量:

      

(8) 当k每经历1至M后,判断指标是否满足精度要求:E≤ε,其中E是总误差函数,且。如果不满足,就返回(3),继续迭代。如果满足,就进入下一步。

(9) 训练结束,将权值和阈值保存在文件中。这时可以认为各个权值已经达到稳定,分类器形成。再一次进行训练时,直接从文件导出权值和阈值进行训练,不需要进行初始化。

YALE数据库是由耶鲁大学计算视觉与扼制中心创立,包括15位志愿者,每个人有11张不同姿势、光照和表情的图片,共计165张图片,图片均为80*100像素的BMP格式图像。我们将整个数据库分为两个部分,每个人的前5幅图片作为网络的训练使用,后6副图片作为测试使用。


测试样例:


输入输出:


资源链接:https://download.csdn.net/download/qq_35685675/10420470



源码资源链接:https://download.csdn.net/download/qq_35685675/10420470

  • 14
    点赞
  • 135
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: BP神经网络是一种常用的人工神经网络模型,可以对非线性问题进行识别与分类。而MATLAB则是一种流行的数学计算工具,它可以用来进行BP神经网络模型的训练和实现。 使用MATLAB进行BP神经网络识别时,需要先确定网络的结构和参数设置。用户需要确定输入层、输出层和隐层的节点数,并选择激活函数、学习率、最大迭代次数等参数。然后,使用训练集对网络进行训练,得到网络的权值和偏置值。接下来,用测试集对网络进行测试,计算预测结果和实际结果之间的误差。 在实际应用中,BP神经网络可以用于识别图像、语音、文本等多种数据类型。例如,可以用BP神经网络识别手写数字图像,识别语音信号中的音频特征,或对文本进行情感分析等。此外,BP神经网络还可以用于推荐系统、医学诊断和金融风险分析等领域。 总之,利用MATLAB进行BP神经网络识别是一种有效的方法,可以应用于多种实际问题中。但需要注意的是,网络的结构和参数设置对预测结果的影响非常大,应该根据具体的数据和问题进行调整和优化。 ### 回答2: BP神经网络是一种常用的人工神经网络,它可以通过学习和训练来识别和分类各种数据。Matlab是一种流行的科学计算软件,也具有实现BP神经网络的功能。 Matlab中的BP神经网络识别遵循以下步骤:首先需要收集和准备好要训练和测试的数据集。然后,将这些数据集导入Matlab的神经网络工具箱中。接下来,在训练集数据上对BP神经网络进行训练,并使用测试集数据对其进行测试。在训练过程中,可以指定不同的参数来控制网络的学习和优化过程。训练完成后,可以使用模型来对新数据进行分类和预测。 使用BP神经网络进行识别通常需要对网络进行多次训练和调整,以达到最佳的准确性和性能。此外,在训练过程中需要注意过拟合和欠拟合的问题,以及对数据进行适当的预处理和特征提取等问题。总的来说,在Matlab中使用BP神经网络进行识别可以快速准确地实现数据分类和预测,适用于各种应用领域,如图像识别、语音识别、自然语言处理等。 ### 回答3: BP神经网络是一种广泛应用于模式识别和预测等领域的神经网络算法。Matlab作为一款常用的科学计算软件,具备较高的图形化编程界面和丰富的工具箱,可以便捷地实现BP神经网络的识别模型。 Matlab实现BP神经网络识别的主要步骤包括数据预处理、网络结构设计、训练算法选择、参数设置、训练、测试和模型优化等。其中,数据预处理包括数据的清洗、转换和标准化等操作,网络结构设计需要考虑隐层节点和输出节点的数量、激活函数、权重和偏置等因素,训练算法选择包括基于梯度下降、牛顿法、拟牛顿法等多种算法,参数设置需要根据实际数据情况进行调整。 在训练过程中,Matlab提供了多种训练函数,如trainlm、trainbfg、trainrp等。同时,Matlab还提供了强大的可视化界面,可以实时监控训练误差和测试误差的变化,并可视化显示BP神经网络的结构和拓扑。 最后,在模型优化方面,Matlab还提供了多种方法,如反向传播权重修正、正则化、dropout等方法,可以提高BP神经网络的精度和稳定性。 总之,Matlab具有较高的灵活性和可调性,适合于实现复杂BP神经网络的识别任务,并可通过多种方法进行模型优化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值