m基于GRNN广义回归神经网络和LLE特征提取的人脸情绪识别matlab仿真

本文涉及的产品
视觉智能开放平台,分割抠图1万点
视觉智能开放平台,图像资源包5000点
视觉智能开放平台,视频资源包5000点
简介: m基于GRNN广义回归神经网络和LLE特征提取的人脸情绪识别matlab仿真

1.算法描述

    GRNN,即General Regression Neural Network,中文全称为广义回归神经网络,是由The Lockheed Palo Alto研究实验室在1991年提出的。GRNN是一种新型的基于非线性回归理论的神经网络模型。GRNN是建立在非参数核回归基础之上的,该神经网络是以测试样本为后验条件,并从观测样本中计算得到自变量和因变量之间的概率密度函数,然后在计算出因变量关于自变量的回归值。由于GRNN不需要规定模型的类型,只需要设置神经网络的光滑因子参数,GRNN神经网络的光滑因子参数的取值对神经网络的输出影响较大,当光滑因子参数较大的时候,其对应的神经元所覆盖的输入区域就越大;当光滑因子参数较小的时候,神经网络对应的径向基函数曲线较陡,因此神经网络输出结果更接近期望值,但此时光滑度越差。由于GRNN广义回归神经网络是基于非线性核回归分析的神经网络,因此,对于任意一个非独立变量y,其相对于独立变量x的回归分析的过程是计算具有最大概率值y。现假设随机变量x和y的联合概率密度函数为f (x ,y),已知x的观测值为X,则y相对于X的回归,即条件均值为:

408a4fb6bc9b5f89a578c4ed6ddb25da_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
78842477978085660cef62fa9410ef53_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
266590ac72e5be349a518c23fa08ecac_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

    从图3的结构图可知,GRNN神经网络的输入层神经元数目和输入样本的维度是相同的,即每一个神经元将输入信号直接传递给GRNN神经网络的隐含层中。GRNN神经网络的模式层的神经元数目和学习训练样本的数目相同,即每一个神经元都分别对应着一个不同的学习训练样本.

2.仿真效果预览
matlab2022a仿真结果如下:

794e005a274d15f59f062652a50a88c0_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png
25b11c8d38e20f6cd289ee48ae66dbee_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

对于测试集人脸样本的生气识别率为93.3333%

对于测试集人脸样本的厌恶识别率为96.6667%

对于测试集人脸样本的害怕识别率为93.3333%

对于测试集人脸样本的开心识别率为90%

对于测试集人脸样本的中性识别率为100%

对于测试集人脸样本的悲伤识别率为93.3333%

对于测试集人脸样本的惊讶识别率为100%

整体识别率为95.2381%

3.MATLAB核心程序

for flag = 1:3
flag
 
if  SEL == 1
    display('读入训练集合...');
    
    if TEST_DATA == 1
       %第一组样本
       TrainData  = readfaceFeature(nExpressionPerPerson, nPerson,0,130);
       trainLabel = [1,1,2,2,3,3,3,4,4,4,5,5,6,6,7,7,1,1,2,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,3,3,4,4,4,5,5,6,6,6,7,7,1,1,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,4,4,4,5,5,6,6,7,1,1,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,3,4,4,5,5,6,6,7,7]';
       %降低维度
       %pcaFaces     = fastPCA(TrainData,DIM); % 主成分分析PCA
       pcaFaces   = lle(TrainData',12,DIM);
    end
    if TEST_DATA == 2
       %第二组样本jaffe
       TrainData0  = readfaceFeature2(nExpressionPerPerson, nPerson,0,140,flag);
       trainLabel1 = [1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7,...
                    1,2,3,4,5,6,7]';
                 
       trainLabel = [trainLabel1;trainLabel1];          
       %降低维度
       %pcaFaces     = fastPCA(TrainData,DIM); % 主成分分析PCA
       pcaFaces   = lle(TrainData0',12,DIM);
    end
    X          = pcaFaces; 
    TrainData  = X;
    [X,A0,B0]  = scaling(X);
    %替换算法,使用GRNN神经网络,否则原来的SVM我仔细研究下来,缺陷太大,几次改下来,性能也没到50%,所以选择pass
    %但为了你方便写论文,我在文档中将GRNN神经网络的理论都给你写了,然后测试大概也写了,
    net        = multiGRNNTrain(TrainData',trainLabel',0.0015);
    
    save NN_model.mat net A0 B0
    display('..............................');
    display('训练结束。');
end
 
 
 
display('读入测试集合...');
%降低维度
load NN_model.mat
load PCA.mat
load LLE.mat
if TEST_DATA == 1
   %第一组样本
   TestData0  = readfaceFeature(nExpressionPerPerson, nPerson,1,130);
   TestLabel  = [1,1,2,2,3,3,3,4,4,4,5,5,6,6,7,7,1,1,2,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,3,3,4,4,4,5,5,6,6,6,7,7,1,1,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,4,4,4,5,5,6,6,7,1,1,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,4,4,5,5,6,6,7,7,1,1,2,2,3,3,3,4,4,5,5,6,6,7,7]';
   [m,n]      = size(TestData0);
   TestData   = (TestData0-repmat(meanVec, m, 1))*V; % 经过pca变换降维
end
if TEST_DATA == 2
   %第二组样本jaffe
   TestData0  = readfaceFeature2(nExpressionPerPerson, nPerson,1,70,flag);
   TestLabel = [1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7,...
                1,2,3,4,5,6,7]';
   [m,n]      = size(TestData0);
   TestData   = (TestData0-repmat(meanVec, m, 1))*V; % 经过pca变换降维
end
..............................................
 
end
相关文章
|
4天前
|
算法 5G 数据安全/隐私保护
3D-MIMO信道模型的MATLAB模拟与仿真
该研究利用MATLAB 2022a进行了3D-MIMO技术的仿真,结果显示了不同场景下的LOS概率曲线。3D-MIMO作为5G关键技术之一,通过三维天线阵列增强了系统容量和覆盖范围。其信道模型涵盖UMa、UMi、RMa等场景,并分析了LOS/NLOS传播条件下的路径损耗、多径效应及空间相关性。仿真代码展示了三种典型场景下的LOS概率分布。
15 1
|
2天前
|
算法 5G 数据安全/隐私保护
SCM信道模型和SCME信道模型的matlab特性仿真,对比空间相关性,时间相关性,频率相关性
该简介展示了使用MATLAB 2022a进行无线通信信道仿真的结果,仿真表明信道的时间、频率和空间相关性随间隔增加而减弱,并且宏小区与微小区间的相关性相似。文中介绍了SCM和SCME模型,分别用于WCDMA和LTE/5G系统仿真,重点在于其空间、时间和频率相关性的建模。SCME模型在SCM的基础上进行了扩展,提供了更精细的参数化,增强了模型的真实性和复杂度。最后附上了MATLAB核心程序,用于计算不同天线间距下的空间互相关性。
7 0
|
2天前
|
算法
基于极大似然算法的系统参数辨识matlab仿真
本程序基于极大似然算法实现系统参数辨识,对参数a1、b1、a2、b2进行估计,并计算估计误差及收敛曲线,对比不同信噪比下的误差表现。在MATLAB2022a版本中运行,展示了参数估计值及其误差曲线。极大似然估计方法通过最大化观测数据的似然函数来估计未知参数,适用于多种系统模型。
|
2天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于NSCT非采样轮廓波变换和CNN网络人脸识别matlab仿真
本项目展示了一种结合非采样轮廓波变换(NSCT)与卷积神经网络(CNN)的人脸识别系统。通过NSCT提取多尺度、多方向特征,并利用CNN的强大分类能力实现高效识别。项目包括ORL人脸库的训练结果对比,提供Matlab 2022a版本下的完整代码及详细中文注释,另有操作步骤视频指导。
|
4天前
|
机器学习/深度学习 算法
基于小波神经网络的数据分类算法matlab仿真
该程序基于小波神经网络实现数据分类,输入为5个特征值,输出为“是”或“否”。使用MATLAB 2022a版本,50组数据训练,30组数据验证。通过小波函数捕捉数据局部特征,提高分类性能。训练误差和识别结果通过图表展示。
|
1天前
|
存储 SQL 安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
【9月更文挑战第14天】本文将深入探讨网络安全与信息安全的重要性,包括网络安全漏洞、加密技术以及安全意识等方面。我们将通过实例和代码示例,帮助读者更好地理解网络安全的基本概念和应用,以及如何提高自己的网络安全意识和技能。
|
2天前
|
SQL 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
【8月更文挑战第45天】在数字时代,网络安全和信息安全已成为我们生活中不可或缺的一部分。本文将介绍网络安全漏洞、加密技术和安全意识等方面的内容,并提供一些实用的技巧和方法来保护我们的网络安全和信息安全。通过了解这些知识,我们可以更好地保护自己的个人信息和数据安全。
40 20
|
1天前
|
SQL 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
【9月更文挑战第14天】在数字化时代,网络安全和信息安全已经成为了我们生活中不可或缺的一部分。本文将介绍网络安全的基本概念,包括网络攻击者的动机和常见类型,以及如何通过加密技术和提高安全意识来保护我们的信息。我们还将探讨一些常见的网络安全漏洞,并提供一些实用的防护措施。无论你是个人用户还是企业,都可以从中获得有价值的信息。
19 12
|
1天前
|
SQL 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
【9月更文挑战第14天】在数字化时代,网络安全和信息安全已成为我们生活中不可或缺的一部分。本文将探讨网络安全漏洞、加密技术和安全意识等方面的内容,以帮助读者更好地了解如何保护自己的网络安全和信息安全。我们将从网络安全漏洞的定义和类型开始,介绍一些常见的网络安全漏洞及其危害。然后,我们将讨论加密技术的重要性以及如何使用它来保护数据的安全性。最后,我们将强调安全意识的重要性,并提供一些实用的建议来提高个人和组织的网络安全水平。
|
1天前
|
存储 SQL 安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
【9月更文挑战第14天】随着互联网的普及,网络安全问题日益突出。本文将从网络安全漏洞、加密技术、安全意识等方面进行探讨,旨在帮助读者更好地了解和应对网络安全挑战。通过分析常见的网络攻击手段和防御策略,以及介绍加密技术和安全意识的重要性,我们希望提高读者对网络安全的认识和防范能力。

热门文章

最新文章