毕业设计论文通信类电子信息工程类专业毕业设计全文.doc
XXXX大学毕业设计(论文)摘 要在现代社会中,视频采集与检测被广泛应用于生活的方方面面,特别是现代监控、实时统计等领域,有着巨大的商业前景。本设计研究了广告效果评估系统中的人脸检测和识别技术。本系统是在C+环境下,调用DirectShow和OpenCV的库函数编译实现的。DirectShow是微软公司在ActiveMovie和Video for Windows的基础上推出的新一代基于COM的流媒体处理的开发包,OpenCV是英特尔公司软件开发中心开发的是面向应用程序开发者开发的计算机视觉库,它由一系列C函数和少量C+构成。另外本设计介绍了快速人脸检测算法,快速人脸检测是Viola提出了基于积分图像与AdaBoost训练的快速人脸检测方法,其中利用积分图像计算矩形特征,再用AdaBoost方法训练这些矩形特征组成强分类器,由于可以在积分图像上快速的计算这些矩形特征从而使分类器的速度大大提高。本设计的基本思想是安装摄像装置来拍摄动态场景,然后在视频中检测人脸信息,并跟踪其运动。该系统硬件结构简单实用,只需在普通PC上安装一块视频采集卡,与前端摄像头连接以获取视频输入。软件结构主要为视频信息的采集与检测,算法的核心是人脸快速检测检测。关键词: DirectShow,OpenCV,人脸检测,人脸跟踪,AdaBoostABSTRACTIn modern society, video capture and detection are widely used in all aspects of life, especially modern monitoring, real-time statistics and other fields, has great commercial prospects. The design study to assess the effect of the advertising system of face detection and recognition technology. The system is in C + + environment, called DirectShow and OpenCV to compile the library functions achieve. The design of the basic idea is to install the camera device to shoot dynamic scenes, and then detected in the Face video information, and track their movement. The system hardware structure is simple and practical, just in an ordinary PC to install a video capture card, with the front camera for video input connections. Software architecture of the main video information for the collection and testing, the core algorithm for rapid detection of human face detection.KEY WORDS: DirectShow,OpenCV Face Detection, Face Tracking, AdaBoostIIXXXX大学毕业设计(论文)目 录前 言1第1章 DirectShow视频采集原理31.1 DdiectX简介31.2 DirectX 9.0c41.3 DirectShow51.4 Directshow基本原理61.5系统环境及开发环境71.6 用DirectShow实现视频采集7第2章 开发平台OpenCV82.1 OpenCV简介82.2 OpenCV图像处理库82.3 OpenCV中的常用结构9第3章 快速人脸检测13第4章 人脸检测开发环境搭建164.1硬件安装164.2 DirectX SDK 开发包下载安装174.3 OpenCV下载与安装184.4 Microsoft Visual C+环境配置184.5 VC项目的建立18第5章 系统实现215.1系统组成215.2人脸检测的实现21第6章 总结与展望25致 谢26参考文献27附 录DirectShow视频采集函数28III 33前 言 近年来,随着平面广告的发展,对广告效果的评估越来越被企业重视。从功能上讲,建立一个这样的系统需要做视频采集与检测两方面工作。其核心是利用计算机视觉技术从视频图像中检测人脸并对其行为进行理解与描述,其中重要算法就是快速人脸检测。所谓人脸检测,指在给定的一幅静止图像或一段动态图像序列中,从背景未知的图像中分割、提取并确认可能存在的人脸,如果检测到人脸,则确定其位置与大小,并提取出人脸的特征。论文共分五章,主要内容概要如下:第1章首先介绍了DirectShow视频采集原理,DirectShow是微软公司在ActiveMovie和Video for Windows的基础上推出的新一代基于COM的流媒体处理的开发包,主要用于视频采集。第2章主要介绍了系统的一个开发平台OpenCV,OpenCV是英特尔公司开发的,是面向应用程序开发者开发的计算机视觉库,它由一系列C函数和少量C+构成,OpenCV函数库不仅对图像进行过滤,统计,分类等基本操作,而且现了图像处理和计算机视觉方面的很多通用算法,主要用于人脸的检测。第3章摘要介绍了快速人脸检测算法,本算法是Viola提出了基于积分图像与AdaBoost训练的快速人脸检测方法,其中利用积分图像计算矩形特征,再用AdaBoost方法训练这些矩形特征组成强分类器,由于可以在积分图像上快速的计算这些矩形特征从而使分类器的速度大大提高。第4章主要介绍了系统环境的搭建,主要包括软硬件两个部分以及C+库函数的路径配置。第5章主要介绍了系统的实现主要介绍了实现视频采集与人脸检测的一些重要函数。人脸检测所存在的主要问题:1.实时性问题,在实际应用中,特别是在数字视频监视系统中,人们往往对于系统的实时性要求更高,当有人走进监控器的监视范围之内时,要求能够实时、准确地检测到人脸的位置,并能跟踪它的运动轨迹及大小变化,直到离开所监控的范围。众所周知,在算法设计时,一方面为了提高实时性,需要减少目标特征的数量和复杂度;另一方面为了提高准确度,需要同时使用多个特征进行综合判断,实时性和准确度往往难以同时满足。此外,由于图像本身数据量大,仅仅为了计算某一个特征往往也需要花费大量的时间。在实时性与准确度之间寻找一个合理的折衷,是许多算法设计的一个主要目标。2.遮挡处理问题,目前,大部分人脸检测、运动跟踪系统都不能很好地解决目标之间互遮挡和人体自遮挡等问题,尤其是在拥挤状态下,多人脸检测和跟踪问题更是难于处理。遮挡时,人体只有部分是可见的,简单依赖于背景减除进行运动分割的技术此时将不再可靠,为了减少遮挡或深度所带来的歧义性问题,必须开发更好的模型来处理遮挡时特征与身体各部分之间的准确对应问题。本论文所做的主要工作:本设计的目的是在学习Visual C+的同时,熟悉VC的编程环境,了解和学习编程的相关知识,并熟悉了一个工程项目的实现过程。本设计对比了几种人脸检测算法,选择了实时性与准确度相对较好的快速人脸检测AdaBoost算法。本文所研究的主要是在DirectShow和OpenCV支持下的视频采集与检测。第1章 DirectShow视频采集原理1.1 DdiectX简介DirectX是一种应用程序接口,DirectX是由很多API组成的,按照性质分类,可以分为四大部分,显示部分、声音部分、输入部分和网络部分。 显示部分担任图形处理的关键,分为DirectDraw(DDraw)和Direct3D(D3D),前者主要负责2D图像加速。它包括很多方面:我们播放mp3、DVD电影、看图、玩小游戏等等都是用的DDraw,你可以把它理解成所有划线的部分都是用的DDraw。后者则主要负责3D效果的显示,比如CS中的场景和人物、FIFA中的人物等等,都是使用了DirectX的Direct3D。DirectX并不是一个单纯的图形API1,它是由微软公司开发的用途广泛的API,它包含有Direct Graphics(Direct 3D+Direct Draw)、Direct Input、Direct Play、Direct Sound、Direct Show、Direct Setup、Direct Media Objects等多个组件,它提供了一整套的多媒体接口方案。只是其在3D图形方面的优秀表现,让它的其它方面显得暗淡无光。DirectX开发之初是为了弥补Windows 3.1系统对图形、声音处理能力的不足,而今已发展成为对整个多媒体系统的各个方面都有决定性影响的接口。 DirectX 是一组低级“应用程序编程接口”,可为 Windows 程序提供高性能的硬件加速多媒体支持。Windows 支持 DirectX 8.0,它能增强计算机的多媒体功能。使用 DirectX 可访问显卡与声卡的功能,从而使程序可提供逼真的三维图形与令人如醉如痴的音乐与声音效果。 DirectX 使程序能够轻松确定计算机的硬件性能,然后设置与之匹配的程序参数。该程序使得多媒体软件程序能够在基于 Windows 的具有 DirectX 兼容硬件与驱动程序的计算机上运行,同时可确保多媒体程序能够充分利用高性能硬件。 DirectX 包含一组 API,通过它能访问高性能硬件的高级功能,如三维图形加速芯片和声卡。这些 API 控制低级功能、支持输入设备并控制着混音及声音输出。构成 DirectX 的下列组件支持低级功能: Microsoft DirectDraw Microsoft DirectDraw API 支持快速访问计算机视频适配器的加速硬件功能。它支持在所有视频适配器上显示图形的标准方法,并且使用加速驱动程序时可以更快更直接地访问。DirectDraw 为程序以及 Windows 系统组件提供了一种独立于设备之外的方法来访问特定显示设备的功能,而不要求用户提供设备功能的其它信息。 2002年底,微软发布DirectX9.0。DirectX 9中PS单元的渲染精度已达到浮点精度,传统的硬件T&L单元也被取消。全新的VertexShader编程将比以前复杂得多,新的VertexShader标准增加了流程控制,更多的常量,每个程序的着色指令增加到了1024条。 PS 2.0具备完全可编程的架构,能对纹理效果即时演算、动态纹理贴图,还不占用显存,理论上对材质贴图的分辨率的精度提高无限多;另外PS1.4只能支持28个硬件指令,同时操作6个材质,而PS2.0却可以支持160个硬件指令,同时操作16个材质数量,新的高精度浮点数据规格可以使用多重纹理贴图,可操作的指令数可以任意长,电影级别的显示效果轻而易举的实现。 VS 2.0通过增加Vertex程序的灵活性,显著的提高了老版本的VS性能,新的控制指令,可以用通用的程序代替以前专用的单独着色程序,效率提高许多倍;增加循环操作指令,减少工作时间,提高处理效率;扩展着色指令个数,从128个提升到256个。 增加对浮点数据的处理功能,以前只能对整数进行处理,这样提高渲染精度,使最终处理的色彩格式达到电影级别。突破了以前限制PC图形图像质量在数学上的精度障碍,它的每条渲染流水线都升级为128位浮点颜色,让游戏程序设计师们更容易更轻松的创造出更漂亮的效果,让程序员编程更容易。 1.2 DirectX 9.0c与过去的DirectX 9.0b和Shader Model 2.0相比较,DirectX 9.0c最大的改进,便是引入了对Shader Model 3.0(包括Pixel Shader 3.0 和Vertex Shader 3.0两个着色语言规范)的全面支持。举例来说,DirectX 9.0b的Shader Model 2.0所支持的Vertex Shader最大指令数仅为256个,Pixel Shader最大指令数更是只有96个。而在最新的Shader Model 3.0中,Vertex Shader和Pixel Shader的最大指令数都大幅上升至65535个,全新的动态程序流控制、 位移贴图、多渲染目标、次表面散射、柔和阴影、环境和地面阴影、全局照明等新技术特性,使得GeForce 6、GeForce7系列以及Radeon X1000系列立刻为新一代游戏以及具备无比真实感、幻想般的复杂的数字世界和逼真的角色在影视品质的环境中活动提供强大动力。因此DirectX 9.0c和Shader Model 3.0标准的推出,可以说是DirectX发展历程中的重要转折点。在DirectX 9.0c中,Shader Model 3.0除了取消指令数限制和加入位移贴图等新特性之外,更多的特性都是在解决游戏的执行效率和品质上下功夫,Shader Model 3.0诞生之后,人们对待游戏的态度也开始从过去单纯地追求速度,转变到游戏画质和运行速度两者兼顾。因此Shader Model 3.0对游戏产业的影响可谓深远。1.3 DirectShowDirectShow是微软公司在ActiveMovie和Video for Windows的基础上推出的新一代基于COM的流媒体处理的开发包2,与DirectX开发包一起发布。目前,DirectX最新版本为9.0。DirectShow为多媒体流的捕捉和回放提供了强有力的支持。运用DirectShow,我们可以很方便地从支持WDM驱动模型的采集卡上捕获数据,并且进行相应的后期处理乃至存储到文件中。这样使在多媒体数据库管理系统(MDBMS)中多媒体数据的存取变得更加方便。 DirectShow是微软公司提供的一套在Windows平台上进行流媒体处理的开发包,与DirectX开发包一起发布。 运用DirectShow,我们可以很方便地从支持WDM驱动模型的采集卡上捕获数据,并且进行相应的后期处理乃至存储到文件中。它广泛地支持各种媒体格式,包括Asf、Mpeg、Avi、Dv、Mp3、Wave等等,使得多媒体数据的回放变得轻而易举。另外,DirectShow还集成了DirectX其它部分的技术,直接支持DVD的播放,视频的非线性编辑,以及与数字摄像机的数据交换。更值得一提的是,DirectShow提供的是一种开放式的开发环境,我们可以根据自己的需要定制自己的组件。1.4 Directshow基本原理DirectShow的基本原理是多媒体数据在过滤器图表(Filter Graph)中流动,通过过滤器图表中各过滤器(Filter)实现在功能,最终实现多媒体数据在渲染过滤器(Vendering Filters)中的显示和回放。我们知道,一般过滤器可分为三类:源过滤器(Source Filters)、转换过滤器(Transform Filters)、渲染过滤器(Vendering Filters)。它们分别完成数据提供、数据格式转换(压缩编码等)和数据渲染和回放功能。所以,为了实现在WIN32系统下的视频采集,我们首先要构造出一个适当的过滤器图表,然后通过应用程序对过滤器图表的管理来完成视频采集的功能。 这里我们一般需要2至3个过滤器。为什么这个数字会不准确呢?那是因为一方面系统采集设备的驱动模型是不确定的(一般有WDM和VFW两种);另一方面同一采集设备它们的Filter会由于驱动程序的差异造成Filter中引脚(Pin)的不一致;还有就 是不同总线的采集设备(PCI、USB、AGP)它们的Filter也是不一致的。比如:同为USB摄像头,有些Filter有两个输出引脚(Capture和Preview);而有些Filter则只有一个输出引脚(Capture)。这里Preview引脚用来将做视频预览,Capture引脚用来将输入数据以供编码、保存等用处。这几个过滤器分别是:a.Video Capture Filter 采集设备Filterb.Smart Tee Filter 将没有Preview引脚Filter的Capture引脚分为两支数据流c.Video Venderer 视频渲染及回放Filter通过上面3个过滤器,我们可以构造出一个完整的视频采集过滤器图(如图1-1) 图1-1视频采集过滤器我们也可以对上面的过滤器图表稍做修改,将它变为一个既可以预览视频,又可以将视频保存为媒体文件的图(如图1-2)。 图1-2将视频保存为媒体图表构造出来后,接下来就午剩下具体的实现了,我们只需依次构造每个Filter,然后将各信Filter的Pin按序相连即可完成图表的构造。最后,我们通过应用程序向图表发送命令(通过图表管理器完成)来控制整个视频采集的流程。1.5系统环境及开发环境a.系统支持DirectXb.VC+ 6.0安装有DirectX SDK9.0c.视频采集设备天敏25001.6 用DirectShow实现视频采集DirectShow作为DirectX的一个子集,它为用户提供了强大、方便的多媒体开接口,并且它拥有直接操作硬件的能力,这使得它的效率远胜于用GDI等图形方式编写的多媒体程序。这里结合实践中运用DirectShow实现视频采(WIN32) 来加深对DirectShow的理解和操作能力。视频采集具体实现程序见附录。第2章 开发平台OpenCV2.1 OpenCV简介OpenCV(Intel Open Source Computer Vision Library)是英特尔公司1999年在俄罗斯设立的软件开发中心开发的,是面向应用程序开发者开发的计算机视觉库,它由一系列C函数和少量C+构成,OpenCV函数库不仅对图像进行过滤,统计,分类等基本操作,而且现了图像处理和计算机视觉方面的很多通用算法,例如运动分析和跟踪、人识别、目标识别、特征检测与跟踪、形状分析(几何形状处理)、3D重构,象分离与检测等3。OpenCV函数库定义了在图像处理领域中的特定的数据类和操作模型。它和对数字图像底层操作的IPL(Intel Image Processing Libra兼容。算法的是基于与IPL数据结构兼容的高度灵活的动态数据结构,超过半以上的函数都在使用Intel处理器的时候得到优化。相对于其它图像函数库,OpenCV是一种源码开放式的函数库,开发者以自由地调用函数库中的相关处理函数。OpenCV中包含300多个跨平台的中高层API函数,具备强大的图像和矩阵运算能力,可以大大减少开发者的程工作量,有效提高开发效率和程序运行的可靠性。另外,由于OpenCV有很好的移植性,开发者可以根据需要在MS-Windows和Linux两种平台进开发。OpenCV将以公开源码的方式提供,也就是接受方有权在修改之后另向第三方提供,对非商业用途和商业用途都是免费的。这个软件运行在使Intel架构处理器的计算机,而操作系统可以是widows95、2000、xp等。由于OpenCV的在图像处理方面的强大能力,本程序主要建立在OpenCV图像库的基础上的。 2.2 OpenCV图像处理库 OpenCV是英特尔公司于1999年在俄罗斯设立的软件开发中心“Software Development Center”开发的,该公司一直致力于基于个人电脑的计算机视觉应用的开发,可以实时追踪的视觉用户接口技术的普及为目标。初步拟定应用于Human-Computer Interaction (HCI,人机互动)、物体确定、面孔识别、表情识别,移动物体追踪、自主运动(Ego-motion)、移动机器人等领域。因此,将OpenCV图像处理库提供给玩具制造商及机器人制造商等从事计算机视觉相关技术的各类企业/团体(英特尔公司)。OpenCV是Intel公司开发的图像处理和计算机视觉函数库,它有以下特点: 1)开放C源码 2)基于Intel处理器指令集开发的优化代码 3)统一的结构和功能定义 4)强大的图像和矩阵运算能力 5)方便灵活的用户接口 6)同时支持MS-WINDOWS, LINUX平台 作为一个基本的计算机视觉、图像处理和模式识别的开源项目, OPENCV可以直接应用于很多领域,作为第二次开发的理想工具。速度更高的微处理器、廉价的数码相机以及USB 2等技术使高速视频捕获(Video Capture)成为可能,因此,基于普通个人电脑的实时计算机视觉将可以实现。而且OpenCV和Matlab类似,却比Matlab快n倍,并对Intel处理器进行优化。2.3 OpenCV中的常用结构 在OpenCV函数库4的编程过程中,常常需要用到一些常用的结构,了解这些结构能够很好地用OpenCV函数库,下面分别对CvSize和IplImage两个结构进行介绍。23.1 CvSize结构CvSize结构表示矩形尺寸的结构,结构体中分别定义了矩形的宽度和高度,具体定义如下:typedef struct CvSize int width;/*矩形宽度,单位为象素*/ int height;/*矩形高度,单位为象素*/ CvSize; 与CvSize结构相关的是其构造函数:inline CvSize cvSize( int width, int height );在定义CvSize结构变量时,可以按照如下方式定义:CvSize size=cvSize(400,300); /*定义宽为400象素,高为300象素的矩形*/CvSize结构用来设置矩形区域大小,在一些复杂高级的结构体常常能够看到它,如下面将要介绍的IplImage结构。23.2 IplImage结构由于OpenCV主要针对的是计算机视觉方面的处理,因此在函数库中,最重要的结构体是IplImage结构。IplImage结构来源于Intel的另外一个函数库Image Processing Library (IPL),该函数库主要是针对图像处理。IplImage结构具体定义如下:typedef struct_ IplImage int nSize; /* IplImage大小*/ int ID;/*版本(=0)*/ int nChannels;/*大多数OPENCV函数支持1,2,3或4个通道*/ int alphaChannel;/*被OpenCV忽略*/ int depth;/*像素的位深度,主要有以下支持格式: IPL DEPTH 8U, IPL DEPTHse 8S, IPLee DEPTH 16U,IPL_ DEPTH-16S, IPLes DEPTHee 32S,IPLee DEPTH 32F和IPL DEPTH 64F*/ char colorModel4;/*被OpenCV忽略*/ char channelSeq4;/*同上*/ int dataOrder; /* 0一交叉存取颜色通道,1一分开的颜色道.只有cvCreatelmage可以创建交叉存取图像*/ int origin;/*图像原点位置:0表示顶一左结构,,1表示底一左结构*/ int align;/*图像行排列方式(4 or 8),在OpenCV被忽略,使用widthStep代替*/ int width;/*图像宽像素数*/ int height;/*图像高像素数*/ struct一p1ROI *roi;/*图像感兴趣区域,当该值非空时,只对该区域进行处理*/ struct一lImage *maskROI; /*在OpenCV中必须为NULL */ void *imageld;/*同上*/ structJplTileInfo/*tilelnfo; /*同上*/ int imageSize;/*图像数据大小(在交叉存取格式下ImageSize=image-> height* image->widthStep ),单位字节*/ char *imageData;/*指向排列的图像数据*/ int widthStep;/*排列的图像行大小,以字节为单位*/ int BorderMode4;/*边际结束模式,在OpenCV被忽略*/ int BorderConst4; /*同上*/ char *imageDataOrigin; /*指针指向一个不同的图像数据结构(不是必须排列的),是为了纠正图像内存分配准备的*/ IplImage; IplImage结构体是整个OpenCV函数库的基础,在定义该结构变量时需要用到函数cvCreatImage,变量定义方法如下:IplImage* src -cvCreateImage(cvSize(400,300), IPL DEPTH 8U,3); 上句定义了一个IplImage指针变量src,图像的大小是400 X 300,图像颜色深度8位,3通道图像。下面就算法的流程进行讨论: 如流程图2-1所示,对每一帧图像,图像首先被转化为HSV颜色空间来描述,然后根据要被跟踪的目标的直方图模型求其色彩概率分布,目标的质心和大小通过CAMshift算法对色彩概率分布进行处理后被找到,虚线框为进行Meanshift的核心部分。当前的运动目标的位置和大小求得去调整下一帧的位置和大小,这样不停的重复达到对运动目标的跟踪。 图2-1基于OpenCV的自动跟踪算法流程图第3章 快速人脸检测Viola提出了基于积分图像与AdaBoost训练的快速人脸检测方法5,其中利用积分图像计算矩形特征,再用AdaBoost方法训练这些矩形特征组成强分类器,由于可以在积分图像上快速的计算这些矩形特征从而使分类器的速度大大提高。此外,构造层叠分类器,首先简单的强分类器排除大多数非人脸窗口,减轻复杂分类器的负担,进而提高速度;另外,层叠分类器训练时下一层分类器的训练在上一层分类器划分的子空间中进行。Viola的方法使在保留统计学习方法所具有的鲁棒性情况下使人脸检测的速度大大提高。该方法的分类器基于简单的矩形特征(Rectangle Feature),区别于传统学习方法是基于象素的。如图3-1就是Viola采用的4种矩形特征。图3-1Viola使用的4种矩形特征 特征值就是大矩形内阴影部分的灰度累加减去白色部分的灰度累加。这当中每个小矩形都是相同大小的。对于24×24的图像窗口,全部特征的数目超过180000个。通过引入积分图像,这些矩形特征可以在常数时间内快速计算。积分图像中对应每个点计算其积分图像值。在(x,y)的积分图像值就是在(x,y)左上角所有灰度的和,即: (3-1)其中是(x,y)点的积分图像值,是(x,y)的原始图像灰度值。矩形特征就是矩形区域象素灰度累加的差,而通过积分图像,任何矩形的象素灰度累加可以通过4个点积分图像值的加减计算完成(如图3-2),所以矩形特征可以用积分图像在参数时间内快速计算。 A B124C D3 图3-2矩形D的像素灰度累加为4+1-(2+3)Boosting算法是近几年中分类算法的发展中最重要的成果之一。Boosting算法是一种现代统计方法,理论上可以用来改进任何学习算法的性能。Schapire在PAC学习框架中开发了第一个简单的Boosting算法。Boosting在很多的计算机学习理论文献中都有所提及,并越来越受到关注。AdaBoost是一种自适应的boosting算法,主要用途是将若干个弱分类器整合为一个强分类器,其中弱分类器指的是那些性能比随机分类略好一点的分类器。Viola通过AdaBoost学习的方法选择少量有效的矩形特征构造强分类器。对于24×24的图像窗口有180000个矩形特征,现在的问题就是通过训练找到少量有效的特征构成一个有效的分类器。AdaBoost就是用于选择有效的特征、并训练分类器。AdaBoost通过组合弱分类器构成强分类器。所谓弱分类器,就是它不期望能很好的进行分类,只要达到大于50%的正确率就可以了(而这总是可以保证的)。在这里每个特征对应构造一个弱分类器。具体而言,特征jf对应的弱分类器如下: (3-2)其中,是在训练样本上最小错误分类的阈值,是表示不等式的方向。无论如何,总是可以保证正确分类率大于50%。人脸检测Viola的方法6的分类器的构造过程中的特征选取是自动进行的,在所有矩形特征中自动选取最有效分类的特征,不像基于特征的方法需要人为总结启发式规则。其次,其类似分阶段设计的层叠分类器构造时,是通过目标驱动自动构造的,不像一般的分阶段的分类器设计方法每个阶段(层次)的分类器都得人工设计。基于上面的两个优势,Viola的方法对一般模式分类问题具有普遍意义,更接近于人类的学习与分类模式。Viola通过实验表明,在700Mhz Pentium III中该检测算法能够以0.067秒的平均速度处理一幅384*288的图像。其检测效果如图3-3:图3-3人脸检测效果图第4章 人脸检测开发环境搭建视频采集与人脸实时检测系统主要包括两个方面:硬件的连接和软件环境的搭建。4.1硬件安装1摄像头:图4-1摄像头 IB-3535F制式:PAL/NTSC 视频输出:1.0Vp-p/75BNC 红外波长:850nm 红外距离:30M 2天敏VC4000卡:图4-2天敏VC4000卡-四路卡接口类型:PCI,支持一机多卡,一卡四路,支持PAL/NTSC,各通道同时工作互不干扰。支持Overlay多路同时预览,CPU占用率极低。提供MPEG4压缩引擎,可对多路视频图像进行压缩。支持压缩流/预览流叠加,提供动态AVI图像捕获。Windows会检测到四次新发现硬件,利用硬件所带光盘,或到其主页去下载驱动程序,选择SDK3000(这是个问题,尚未解决)继续安装。3SDK2500卡:图4-3天敏SDK2500卡-单路卡PCI总线,兼容Windows即插即用(PNP),安装简易,示画面流畅不间断,每秒可达30(NTSC)帧、25(PAL)帧,持NTSC和PAL .SECAM制式,示分辨率可达720x576(PAL),供动态AVI图像捕获。Windows自动检测,注意防止中断冲突,比较可靠的方法是拔掉所有非必要的卡,然后优先插入SDK2500卡,直到发生冲突(检查硬件资源)。4像头与电源:是有缘摄像头,通过同轴电缆与视频采集卡相连即可。5安装demo程序,即可观察到视频采集结果。6持DirectShow的标准视频输入:程序也可使用其他支持DirectShow的视频采集设备7。4.2 DirectX SDK 开发包下载安装1.DirectShow是基于Windows平台的流媒体处理开发包,它与DirectX一起发布。使用它可以在基于WDM驱动的采集卡上进行数据捕捉。2.下载DirectX9SDK,需要下载b版本的。这是DirectX的一个完整版本,一些教新的版本只有updating部分,不完整。3.双击安装到选定目录即可。4.3 OpenCV下载与安装1.OpenCV是Intel®开源计算机视觉库。它由一系列 C 函数和少量 C+ 类构成,实现了图像处理和计算机视觉方面的很多通用算法。2.下载地址:3.双击安装OpenCV,将得到相关的include文件、lib文件和dll及例子等。4.4 Microsoft Visual C+环境配置1.为了利用DirectShow和OpenCV提供的功能,需要配置其include文件和lib文件的路径8(以下$DX_HOME$代表DirectX的安装目录;$OPENCV_HOME$代表OpenCV的安装目录)2.Include文件路径:Tools | Options | Directories | “include files”i.$DX_HOME$includeii.$DX_HOME$samplesc+directshowbaseclassesiii.$OPENCV_HOME$cvincludeiv.$OPENCV_HOME$cxcoreincludev.$OPENCV_HOME$otherlibshighguic)Lib文件路径:Tools | Options | Directories | “library files”i.$DX_HOME$Libii.$OPENCV_HOME$Lib4.5 VC项目的建立1.建立一个基于对话框的MFC程序项目,设工程名为PeopleCount2.创建类CShowpic,它是CStatic的一个子类,这个类用于显示位图。i.Insert | New class ii.Class type = MFC class; Base Class = CStatic; Name=CShowpiciii.检查文件Showpic.cpp/h,看自动生成了哪些代码iv.参照我的文件修改Showpic.cpp/h,注意其中添加部分和注释3.添加两个Picture控件,用于显示视频采集结果和处理结果。将其Typ