您现在的位置:首页 >> 机器学习 >> 内容

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

时间:2023/1/4 21:10:13 点击:

  核心提示:05_045_m,包括程序操作录像+参考文献...

1.完整项目描述和程序获取

>面包多安全交易平台:https://mbd.pub/o/bread/Y52cmJ1q

>如果链接失效,可以直接打开本站店铺搜索相关店铺:

点击店铺

>如果链接失效,程序调试报错或者项目合作可以加微信或者QQ联系。

2.部分仿真图预览



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

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

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

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

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

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

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

整体识别率为95.2381%

3.算法概述

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

4.部分源码

..............................................................

SET = [];

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

05_045_m

作者:我爱C编程 来源:我爱C编程
本站最新成功开发工程项目案例
相关文章
  • 没有相关文章
相关评论
发表我的评论
  • 大名:
  • 内容:
本类固顶
  • 没有
  • FPGA/MATLAB商业/科研类项目合作(www.store718.com) © 2025 版权所有 All Rights Reserved.
  • Email:1480526168@qq.com 站长QQ: 1480526168