当前位置: 首页 > news >正文

EmguCV学习笔记 C# 10.1 人脸检测 CascadeClassifier类

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。

教程VB.net版本请访问:EmguCV学习笔记 VB.Net 目录-CSDN博客

教程C#版本请访问:EmguCV学习笔记 C# 目录-CSDN博客

笔者的博客网址:https://blog.csdn.net/uruseibest

教程配套文件及相关说明以及如何获得pdf教程和代码,请移步:EmguCV学习笔记

学习VB.Net知识,请移步: vb.net 教程 目录_vb中如何用datagridview-CSDN博客

 学习C#知识,请移步:C# 教程 目录_c#教程目录-CSDN博客

 

10.1 人脸检测 CascadeClassifier类

CascadeClassifier类是EmguCV中用于人脸检测的一个重要类。它是基于Haar特征的级联分类器(Cascade Classifier,是一种基于Haar特征的目标检测算法),它具有较高的检测准确率,常用于人脸检测、行人检测等场景。

CascadeClassifier类的基本原理可以分为以下几个步骤:

1. 特征提取。首先,需要对图像进行特征提取,将图像转换为一组特征向量。Haar特征是一种基于图像亮度变化的特征,可以用于检测人脸的边缘、线段和区域等特征。

2. 训练分类器。根据特征向量,可以训练一个级联分类器,将人脸和非人脸区域进行分类。级联分类器由多个弱分类器组成,每个弱分类器可以检测特定的Haar特征。

3. 应用分类器。将分类器应用于图像中的每个窗口,检测其中是否包含人脸。由于Haar特征的计算量较大,可以采用图像金字塔的方法对图像进行缩放,以便在不同尺度的图像中进行人脸检测。

在实现中,CascadeClassifier类提供了一系列的接口函数,可以用于加载训练好的分类器、设置检测参数、进行人脸检测等操作。在使用时,需要调用CascadeClassifier类中的DetectMultiScale函数,传入待检测的图像和检测参数,可以得到检测结果,即图像中所有人脸的位置和大小。需要注意的是,级联分类器虽然在人脸检测等场景中表现良好,但在一些复杂场景下可能会出现漏检或误检的情况。

CascadeClassifier常用方法:

1. CascadeClassifier构造函数

该方法用于创建CascadeClassifier对象,并加载指定的级联分类器文件。其语法为:

public CascadeClassifier(

           string fileName

)

参数说明:

  1. fileName:要加载的级联分类器XML文件。常用的级联分类器XML文件有:
  1. haarcascade_frontalface_alt.xml:人脸检测器,使用的是Haar特征,能够检测正脸、侧脸、带眼镜等多种情况的人脸。
  2. haarcascade_eye.xml:眼睛检测器,能够检测人脸中的眼睛。
  3. haarcascade_fullbody.xml:行人检测器,能够检测整个行人的图像。
  4. haarcascade_upperbody.xml:上半身检测器,能够检测行人的上半身区域。
  5. haarcascade_car.xml:车辆检测器,能够检测汽车的前部和侧部。

2. DetectMultiScale方法

该方法用于对图像进行目标检测并返回检测结果。其声明如下:

public Rectangle[] DetectMultiScale(

                    IInputArray image,

                    double scaleFactor = 1.1,

                    int minNeighbors = 3,

                    Size minSize = default,

                    Size maxSize = default

)

参数说明:

  1. Image:待检测的图像。
  2. scaleFactor:缩放比例因子,缩放比例越小,检测时间越长,检测精度越高。
  3. minNeighbors:符合检测标记的个数,用于控制对象检测时候的误检率和漏检率,参数越大,检测结果越精确,但是漏检率也会增加。
  4. minSize:检测目标的最小尺寸,小于此尺寸的目标将被忽略。
  5. maxSize:检测目标的最大尺寸,大于此尺寸的目标将被忽略。

返回值:

返回一个矩形数组,表示图像中所有检测到的目标位置和大小。

下面将提供多个代码来说明级联分类器的使用。

【代码位置:frmChapter10】Button1_Click

        //级联分类器检测人脸

        private void Button1_Click(object sender, EventArgs e)

        {

            //使用训练好的某个识别文件

            CascadeClassifier face = new CascadeClassifier("C:\\learnEmgucv\\haarcascade\\haarcascade_frontalface_alt2.xml");

            Mat m = new Mat("C:\\learnEmgucv\\hy.jpg", ImreadModes.Color);

            Rectangle[] rects;

            //使用级联分类器进行检测

            rects = face.DetectMultiScale(m);

            //输出矩形框

            for (int i = 0; i < rects.Length; i++)

                CvInvoke.Rectangle(m, rects[i], new MCvScalar(0, 0, 255), 2);

            ImageBox1.Image = m;

        }

输出结果如下图所示:

 

图10-1 多个人脸检测

两个级联分类器联合使用来检测鼻子:

【代码位置:frmChapter10】Button2_Click

       //两个级联分类器联合使用来检测鼻子

        private void Button2_Click(object sender, EventArgs e)

        {

            //级联分类器,训练好的人脸文件

            CascadeClassifier face = new CascadeClassifier("C:\\learnEmgucv\\haarcascade\\haarcascade_frontalface_alt2.xml");

            //级联分类器,训练好的鼻子文件

            CascadeClassifier nose = new CascadeClassifier("C:\\learnEmgucv\\haarcascade\\haarcascade_mcs_nose.xml");

            Mat m = new Mat("C:\\learnEmgucv\\hy1.jpg", ImreadModes.Color);

            Rectangle[] rectfaces = face.DetectMultiScale(m);

            for (int i = 0; i < rectfaces.Length; i++)

            {

                CvInvoke.Rectangle(m, rectfaces[i], new MCvScalar(0, 0, 255), 2);

                //获得已经取得的人脸区域图像,将在此区域内进行检测

                Mat mFace = new Mat(m, rectfaces[i]);

                Rectangle[] rectnoses = nose.DetectMultiScale(mFace);

                //绘制出检测到的鼻子区域矩形框

                for (int j = 0; j < rectnoses.Length; j++)

                    CvInvoke.Rectangle(mFace, rectnoses[j], new MCvScalar(0, 255, 0), 2);

            }

            ImageBox1.Image = m;

        }

输出结果如下图所示:

 

图10-2 检测鼻子

检测并标识视频中的人脸:

【代码位置:frmChapter10】Button3_Click、vcCascade_ImageGrabbed、Button4_Click

        VideoCapture vcCascade;

        CascadeClassifier vcface;

        //是否停止视频标记

        Boolean stopVC;

        //检测并标识视频中的人脸

        //具体检测代码在vcCascade_ImageGrabbed

        private void Button3_Click(object sender, EventArgs e)

        {

            vcCascade = new VideoCapture(0);

            if (vcCascade.IsOpened == false)

            {

                MessageBox.Show("打开文件失败");

                return;

            }

            stopVC = false;

            //添加ImageGrabbed事件

            vcCascade.ImageGrabbed += vcCascade_ImageGrabbed;

            vcCascade.Start();

            vcface = new CascadeClassifier("C:\\learnEmgucv\\haarcascade\\haarcascade_frontalface_alt2.xml");

        }

        //检测人脸

        private void vcCascade_ImageGrabbed(object sender, EventArgs e)

        {

            if (stopVC == true)

            {

                //停止

                vcCascade.Stop();

                //释放资源

                vcCascade.Dispose();

                //取消事件

                vcCascade.ImageGrabbed -= vcCascade_ImageGrabbed;

                return;

            }

            Mat nextframe = new Mat();

            vcCascade.Retrieve(nextframe);

            //检测人脸

            Rectangle[] rectfaces = vcface.DetectMultiScale(nextframe);

            for (int i = 0; i < rectfaces.Length; i++)

                //绘制人脸矩形框

                CvInvoke.Rectangle(nextframe, rectfaces[i], new MCvScalar(0, 0, 255), 2);

            ImageBox1.Image = nextframe;

            System.Threading.Thread.Sleep(40);

        }

        //停止视频

        private void Button4_Click(object sender, EventArgs e)

        {

            stopVC = true;

        }

输出结果由于笔者比较丑而显示空白。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 微软发布Phi-3.5 SLM,附免费申请试用
  • HUAWEI华为MateBook B5-420 i5 集显(KLCZ-WXX9,KLCZ-WDH9)原装出厂Windows10系统文件下载
  • MySQL中日期和时间戳的转换:字符到DATE和TIMESTAMP的相互转换
  • Codeforces Round 920 (Div. 3)(A,B,C,D)
  • FreeRTOS学习笔记—③RTOS内存管理篇(正在更新中)
  • 图像边缘检测技术详解:利用OpenCV实现Sobel算子
  • 016 交换网络的弹性设计与高可用性
  • 出现 TypeError: Cannot read properties of undefined (reading ‘getUserMedia‘) 解决方法
  • 12、Django Admin在列表视图页面上显示计算字段
  • 计算机毕业设计 半成品配菜平台 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试
  • 串行总线舵机
  • C#数组中的Rank,GetUpperBound(), GetLength()
  • 云计算和传统IT相比,有哪些优势?
  • 爬虫练习(js逆向解密)
  • 操作系统体系结构分类
  • [ JavaScript ] 数据结构与算法 —— 链表
  • CentOS7简单部署NFS
  • es6
  • FineReport中如何实现自动滚屏效果
  • JavaScript学习总结——原型
  • js数组之filter
  • Laravel 中的一个后期静态绑定
  • LeetCode刷题——29. Divide Two Integers(Part 1靠自己)
  • Map集合、散列表、红黑树介绍
  • python 装饰器(一)
  • Python进阶细节
  • 工作踩坑系列——https访问遇到“已阻止载入混合活动内容”
  • 聊聊directory traversal attack
  • 区块链技术特点之去中心化特性
  • 实战:基于Spring Boot快速开发RESTful风格API接口
  • 使用docker-compose进行多节点部署
  • 手机app有了短信验证码还有没必要有图片验证码?
  • 树莓派 - 使用须知
  • 远离DoS攻击 Windows Server 2016发布DNS政策
  • 继 XDL 之后,阿里妈妈开源大规模分布式图表征学习框架 Euler ...
  • ​​​​​​​​​​​​​​Γ函数
  • #{}和${}的区别?
  • #我与Java虚拟机的故事#连载02:“小蓝”陪伴的日日夜夜
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (zt)最盛行的警世狂言(爆笑)
  • (转)Linux下编译安装log4cxx
  • ***检测工具之RKHunter AIDE
  • ../depcomp: line 571: exec: g++: not found
  • .net core 客户端缓存、服务器端响应缓存、服务器内存缓存
  • .NET Framework、.NET Core 、 .NET 5、.NET 6和.NET 7 和.NET8 简介及区别
  • .NET Remoting Basic(10)-创建不同宿主的客户端与服务器端
  • .NET 中各种混淆(Obfuscation)的含义、原理、实际效果和不同级别的差异(使用 SmartAssembly)
  • .NET/C# 判断某个类是否是泛型类型或泛型接口的子类型
  • .netcore 如何获取系统中所有session_如何把百度推广中获取的线索(基木鱼,电话,百度商桥等)同步到企业微信或者企业CRM等企业营销系统中...
  • .net遍历html中全部的中文,ASP.NET中遍历页面的所有button控件
  • .Net转Java自学之路—基础巩固篇十三(集合)
  • @RequestParam详解
  • [ 转载 ] SharePoint 资料
  • [] 与 [[]], -gt 与 > 的比较
  • [51nod1610]路径计数