zoukankan      html  css  js  c++  java
  • 图像处理项目——基于机器视觉技术的人脸在线识别系统设计

    基于机器视觉技术的人脸在线识别系统设计

      本设计研究人脸检测与识别技术,在基于机器视觉技术上,构建了一套人脸在线检测识别系统,系统将由以下几个部分构成:计算机图像预处理、数据收集和预处理、

    人脸图像定位检测、人脸识别模型训练、人脸识别。经过实验,确定该系统可对本人的人脸进行快速并准确的检测与识别。

    关键词: 机器视觉; 图像处理; 人脸检测;人脸识别;OpenCV;人脸模型训练

    一、设计目标 

    1. 掌握人脸识别步骤;
    2. 熟悉条人脸识别的相关算法;
    3. 熟悉机器视觉系统设计的一般流程;
    4. 掌握常用图像处理技术与OpenCV的使用方法;

     设计内容与要求

    1.完成基于机器视觉技术的人脸在线识别系统算法设计;

    2.完成基于机器视觉技术的人脸在线识别系统上位机设计;

    3.人脸识别误差率≤2%;

    二、图片——人脸检测(https://www.cnblogs.com/fpzs/p/10522684.html)

    2.1、主要步骤

    1. 加载 Opencv 自带的人脸检测 haarcascade_frontalface.xml 分类器。
    2. 图像预处理 cvtColor(灰度化)
    3. 使用 detectMultiScale 函数进行识别。
    4. 使用 rectangle 函数绘制找到的目标矩形框。
    5. 在原图像上 ROI 截取彩色的人脸保存。

    2.2、detectMultiScale函数介绍

    cvHaarDetectObjects是opencv1中的函数,opencv2中人脸检测使用的是 detectMultiScale函数。它可以检测出图片中所有的人脸,

    并将人脸用vector保存各个人脸的坐标、大小(用矩形表示),函数由分类器对象调用: 

     
    1. void detectMultiScale(  
    2.     const Mat& image,  
    3.     CV_OUT vector<Rect>& objects,  
    4.     double scaleFactor = 1.1,  
    5.     int minNeighbors = 3,   
    6.     int flags = 0,  
    7.     Size minSize = Size(),  
    8.     Size maxSize = Size()  
    9. );  
     

    参数1:image--待检测图片,一般为灰度图像加快检测速度;

    参数2:objects--被检测物体的矩形框向量组;
    参数3:scaleFactor--表示在前后两次相继的扫描中,搜索窗口的比例系数。默认为1.1即每次搜索窗口依次扩大10%;
    参数4:minNeighbors--表示构成检测目标的相邻矩形的最小个数(默认为3个)。
            如果组成检测目标的小矩形的个数和小于 min_neighbors - 1 都会被排除。
            如果min_neighbors 为 0, 则函数不做任何操作就返回所有的被检候选矩形框,
            这种设定值一般用在用户自定义对检测结果的组合程序上;
    参数5:flags--要么使用默认值,要么使用CV_HAAR_DO_CANNY_PRUNING,如果设置为

            CV_HAAR_DO_CANNY_PRUNING,那么函数将会使用Canny边缘检测来排除边缘过多或过少的区域,

            因此这些区域通常不会是人脸所在区域;
    参数6、7:minSize和maxSize用来限制得到的目标区域的范围。

    2.3、检测结果

     

    三、视频——人脸检测(https://www.cnblogs.com/fpzs/p/10526219.html)

    3.1、主要步骤

    1.加载分类器,将人脸检测分类器和笑脸检测分类器放在项目目录中去
    2.调用detecMutiScale()函数检测,对函数中相关的参数进行修改调整,
     是检测的结果更加精确
    3.打开摄像头或者视频文件,把检测到的人脸用矩形画出来

    3.2、’检测结果

     四、制作自己的人脸数据集(https://www.cnblogs.com/fpzs/p/10533485.html)

    4.1、主要步骤

    1、加载人脸检测器
    2、打开电脑摄像头,载入视频流,抽取帧,进行灰度化处理
    3、识别人脸,采集20张保存到文件中

    4.2、制作结果

    4.3、参考数据集

      五、生成csv文件(https://www.cnblogs.com/fpzs/p/10535093.html)

     利用pyhton脚本生成csv文件,为训练自己的人脸识别模型做数据准备

    5.1、主要步骤
    1、载入对应路径
    2、提取每一张图片对应的位置与同一个人脸对应的标签
    3、写入存储文件夹data.txt

    5.2、生成结果

     六、训练模型(https://www.cnblogs.com/fpzs/p/10550305.html)

    6.1、主要步骤
    1.创建了一个特征脸模型用于人脸识别
    2.通过CSV文件face.txt读取的图像和标签训练它 
    3.创建一个PCA人脸分类器,T这里是一个完整的PCA变换
    4.调用其中的成员函数train()来完成分类器的训练

    6.2、训练结果

    生成了MyFaceModel.xml文件,可以直接使用进行人脸识别

    七、人脸识别(https://www.cnblogs.com/fpzs/p/10550450.html)
    7.1、主要步骤

    1.打开摄像头。
    2.加载人脸检测器,加载人脸模型。
    3.待识别图像预处理 resize cvtColor 等,人脸检测
    4.把检测到的人脸与人脸模型里面的对比,找出这是谁的脸。
    5.如果人脸是自己拍照的人脸,显示自己的名字“face_zsc”。

    7.2、识别结果
    成功检测出人脸,并且识别出是谁的人脸,给出对应标签

    八、代码见个人GitHub
    https://github.com/hhhvvvddd/face_recognition


    浅谈则止,深入理解AI大道理

    扫描下方“AI大道理”,选择“关注”公众号

     欢迎加入!



     
     


     

    
    
    萍水相逢逢萍水,浮萍之水水浮萍!
  • 相关阅读:
    [Canvas]RPG游戏雏形 (地图加载,英雄出现并移动)
    [Canvas]计时表/秒表
    [Canvas]新版箴言钟表
    [Canvas]用透明PNG图在背景上画前景能不遮挡背景
    [Canvas]动态背景
    [Canvas]更多的球
    [Canvas]碰撞球 增加小球间碰撞检测
    [Canvas]碰撞球
    [Canvas]越来越近的女孩
    [Canvas]走近的女孩
  • 原文地址:https://www.cnblogs.com/AIBigTruth/p/10550577.html
Copyright © 2011-2022 走看看