当前位置:   article > 正文

使用MATLAB控制笔记本电脑的摄像头,并进行实时人脸检测和识别_matlab调用摄像头进行定位

matlab调用摄像头进行定位

FPGA教程目录

MATLAB教程目录

-----------------------------------------------------------------------

目录

一、理论基础

1.1 本系统概述

1.2 MATLAB控制摄像头介绍

1.3 基于GRNN神经网络的人脸识别理论概述

二、核心程序

三、仿真测试结果


一、理论基础

1.1 本系统概述

       使用MATLAB控制笔记本电脑的摄像头,并进行实时人脸检测和识别,需要利用计算机视觉和机器学习的技术。这个过程通常包括两个主要步骤:人脸检测(确定图像中是否有人脸,如果有,它们在哪里)和人脸识别(确定检测到的脸属于谁)。在MATLAB中实现这些算法需要使用到MATLAB的Image Processing Toolbox和Computer Vision Toolbox等工具箱。具体实现时,可能需要编写一些代码来读取和处理图像数据,以及对神经网络进行训练和预测等。具体的实现方式可以参考MATLAB的官方文档和相关的教程。

1.2 MATLAB控制摄像头介绍

        MATLAB可以通过使用Image Acquisition Toolbox来控制笔记本电脑的摄像头并进行实时人脸检测和识别。你需要确定你的摄像头是否支持MATLAB的VideoReader类。

  1. delete(imaqfind);
  2. %Set up video object. Note: to change to a different camera (or camera setup) change the following line:
  3. vid = videoinput('winvideo',1,'YUY2_640x480');
  4. %Set the video object to always return rgb images:
  5. set(vid, 'ReturnedColorSpace', 'rgb');
  6. triggerconfig(vid,'manual');
  7. start(vid)
  8. %Initialize frame Frm and fps variable
  9. Frm = 0;
  10. fps = 0;
  11. %Set the total runtime in seconds
  12. runtime = 100;
  13. h = figure(1);
  14. tic;
  15. timeTracker = toc;

1.3 基于GRNN神经网络的人脸识别理论概述

        人脸识别过程主要由四个阶段组成:人脸检测、图像预处理、面部特征提取和特征识别。首先系统从视频或者相机中捕获图像,检测并分割出其中的人脸区域;接下来通过归一化、对齐、滤波等方法改善图像的质量,这里的质量主要由最终的人脸识别率决定;特征提取(降维)环节尤为重要,其初衷是减少数据量从而减轻计算负担,但良好的特征选取可以降低噪音和不相关数据在识别中的贡献度,从而提高识别精度;特征识别阶段需要根据提取的特征训练一个分类器,对于给定的测试样本,根据训练器对其进行分类。

      当定位好人脸的时候,我们进行识别,识别的主要原理如下:

      GRNN广义回归神经网络的理论基础是非线性核回归分析,非独立变量y相对于独立变量x的回归分析实际上是计算具有最大概率值的y。设随机变量x和y的联合概率密度函数为f (x ,y),已知x的观测值为X,则y相对于X的回归,即条件均值为:

对于未知的概率密度函数f (x, y),可由x和y的观测样本经非参数估计得:

       GRNN通常被用来进行函数逼近。它具有一个径向基隐含层和一个特殊的线性层。第一层和第二层的神经元数目都与输入的样本向量对的数目相等。GRNN结构如图2-3所示,整个网络包括四层神经元:输入层、模式层、求和层与输出层。 

 

      GRNN广义回归神经网络进行映射学习达到了很好的效果.这些流形的方法都建立在一个假设上:同一个人不同姿态的图像是高维空间中的一个低维流形.基于这个假设,不同人在姿态变化下可以获得较好的识别效果。

在matlab中,通过如下的驱动程序控制笔记本电脑的摄像头:

  1. %Set up video object. Note: to change to a different camera (or camera setup) change the following line:
  2. vid = videoinput('winvideo',1,'YUY2_640x480');
  3. %Set the video object to always return rgb images:
  4. set(vid, 'ReturnedColorSpace', 'rgb');
  5. triggerconfig(vid,'manual');
  6. start(vid)
  7. %Initialize frame Frm and fps variable
  8. Frm = 0;
  9. fps = 0;
  10. %Set the total runtime in seconds
  11. runtime = 100;
  12. h = figure(1);
  13. tic;
  14. timeTracker = toc;

通过程序vid = videoinput('winvideo',1,'YUY2_640x480');完成摄像头图像的采集。

二、核心程序

  1. clc;
  2. clear;
  3. close all;
  4. warning off;
  5. addpath 'func\'
  6. addpath 'facebase\'
  7. delete(imaqfind);
  8. %Set up video object. Note: to change to a different camera (or camera setup) change the following line:
  9. vid = videoinput('winvideo',1,'YUY2_640x480');
  10. %Set the video object to always return rgb images:
  11. set(vid, 'ReturnedColorSpace', 'rgb');
  12. triggerconfig(vid,'manual');
  13. start(vid)
  14. %Initialize frame Frm and fps variable
  15. Frm = 0;
  16. fps = 0;
  17. %Set the total runtime in seconds
  18. runtime = 100;
  19. h = figure(1);
  20. tic;
  21. timeTracker = toc;
  22. load grnns.mat
  23. while toc < runtime
  24. toc
  25. Frm = Frm + 1;
  26. %获得摄像头图像
  27. I = getsnapshot(vid);
  28. %人脸跟踪
  29. [segment,f,R0,R1] = func_face_track(I);
  30. %获得人脸区域
  31. figure(1);
  32. subplot(221);
  33. imshow(uint8(I));
  34. title('摄像头视频获取');
  35. subplot(222);
  36. imshow(f);
  37. subplot(223);
  38. imshow(R1);
  39. title('脸部定位');
  40. %人脸识别(测试前需要加入自己所要测试的人脸的相关库。比如你要测试你自己的脸,那么需要加入你的脸道库中)
  41. R0re = imresize(R0,[220,160]);
  42. Ttest = func_yuchuli(R0re);%读入数字
  43. wordsss = sim(net,Ttest');
  44. [V,I] = max(wordsss);
  45. %显示识别结论
  46. Icheck = imread(['facebase\',num2str(I-1),'.jpg']);
  47. subplot(224);
  48. imshow(Icheck);
  49. title('识别结论');
  50. pause(0.5);
  51. end
  52. stop(vid)
  1. clc;
  2. clear;
  3. close all;
  4. warning off;
  5. addpath 'func\'
  6. addpath 'facebase\'
  7. I = imread('1.jpg');
  8. %%
  9. %人脸跟踪
  10. [segment,f,R0,R1] = func_face_track(I);
  11. %获得人脸区域
  12. figure
  13. subplot(221);
  14. imshow(I);
  15. subplot(222);
  16. imshow(f);
  17. subplot(223);
  18. imshow(R1);
  19. title('脸部定位');
  20. %%
  21. %人脸识别(测试前需要加入自己所要测试的人脸的相关库。比如你要测试你自己的脸,那么需要加入你的脸道库中)
  22. %人脸库的离线训练
  23. R0re = imresize(R0,[220,160]);
  24. Ttest = func_yuchuli(R0re);%读入数字
  25. load grnns.mat
  26. wordsss = sim(net,Ttest');
  27. [V,I] = max(wordsss);
  28. %显示识别结论
  29. Icheck = imread(['facebase\',num2str(I-1),'.jpg']);
  30. subplot(224);
  31. imshow(Icheck);
  32. title('识别结论');

三、仿真测试结果

       由此可以看出,当选择出学习样本之后,GRNN网络的结构与权值都是完全确定的,因而训练GRNN网络要比训练BP网络和RBF网络便捷得多。

 A10-26

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/94572
推荐阅读
相关标签
  

闽ICP备14008679号