ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:291.76KB ,
资源ID:5323989      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5323989.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(如何用OpenCV训练自己的分类器.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

如何用OpenCV训练自己的分类器.docx

1、如何用OpenCV训练自己的分类器如何用OpenCV训练自己的分类器2009-09-04 22:15最近要做一个性别识别的项目,在人脸检测与五官定位上我采用OPENCV的 haartraining进行定位,这里介绍下这两天我学习的如何用opencv训练自己的分类器。在这两天的学习里,我遇到了不少问题,不过我遇到了几 个好心的大侠帮我解决了不少问题,特别是无忌,在这里我再次感谢他的帮助。一、简介目标检测方法最初由Paul Viola Viola01提出,并由Rainer Lienhart Lienhart02对这一方法进行了改善。该方法的基本步骤为: 首先,利用样本(大约几百幅样本图片)的 ha

2、rr 特征进行分类器训练,得到一个级联的boosted分类器。分类器中的级联是指最终的分类器是由几个简单分类器级联组成。在图像检测中,被检窗口依次通过每一级分类器, 这样在前面几层的检测中大部分的候选区域就被排除了,全部通过每一级分类器检测的区域即为目标区域。分类器训练完以后,就可以应用于输入图像中的感兴趣区域的检测。检测到目标区域分类器输出为1,否则输出为0。为了检测整副图像,可以在图像中移动搜索窗 口,检测每一个位置来确定可能的目标。 为了搜索不同大小的目标物体,分类器被设计为可以进行尺寸改变,这样比改变待检图像的尺寸大小更为有效。所以,为了在图像中检测未知大小的目标物体,扫描 程序通常需

3、要用不同比例大小的搜索窗口对图片进行几次扫描。目前支持这种分类器的boosting技术有四种: Discrete Adaboost, Real Adaboost, Gentle Adaboost and Logitboost。boosted 即指级联分类器的每一层都可以从中选取一个boosting算法(权重投票),并利用基础分类器的自我训练得到。根据上面的分析,目标检测分为三个步骤:1、 样本的创建2、 训练分类器3、 利用训练好的分类器进行目标检测。二、样本创建训练样本分为正例样本和反例样本,其中正例样本是指待检目标样本,反例样本指其它任意图片。负样本负样本可以来自于任意的图片,但这些图片不

4、能包含目标特征。负样本由背景描述文件来描述。背景描述文件是一个文本文件,每一行包含了一个负样本图片的文件 名(基于描述文件的相对路径)。该文件创建方法如下:采用Dos命令生成样本描述文件。具体方法是在Dos下的进入你的图片目录,比如我 的图片放在D:faceposdata下,则:按Ctrl+R打开Windows运行程序,输入cmd打开DOS命令窗口,输入 d:回车,再输入cd D:facenegdata进入图片路径,再次输入dir /b negdata.dat,则会图片路径下生成一个negdata.dat文件,打开该文件将最后一行的negdata.dat删除,这样就生成了负样本描 述文件。do

5、s命令窗口结果如下图:正样本对于正样本,通常的做法是先把所有正样本裁切好,并对尺寸做规整(即缩放至指定大小),如下图所示:由于HaarTraining训练时输入的正样本是vec文件,所以需要使用OpenCV自带的CreateSamples程序(在你所按照的 opencvbin下,如果没有需要编译opencvappsHaarTrainingmake下的.dsw文件,注意要编译release版 的)将准备好的正样本转换为vec文件。转换的步骤如下:1) 制作一个正样本描述文件,用于描述正样本文件名(包括绝对路径或相对路径),正样本数目以及各正样本在图片中的位置和大小。典型的正样本描述文件如下:po

6、sdata/1(10).bmp 1 1 1 23 23posdata/1(11).bmp 1 1 1 23 23posdata/1(12).bmp 1 1 1 23 23不过你可以把描述文件放在你的posdata路径(即正样本路径)下,这样你就不需要加前面的相对路径了。同样它的生成方式可以用负样本描述文件的 生成方法,最后用txt的替换工具将“bmp”全部替换成“bmp 1 1 1 23 23”就可以了,如果你的样本图片多,用txt替换会导致程序未响应,你可以将内容拷到word下替换,然后再拷回来。bmp后面那五个数字分别表示图片个 数,目标的起始位置及其宽高。这样就生成了正样本描述文件pos

7、data.dat。2) 运行CreateSamples程序。如果直接在VC环境下运行,可以在ProjectSettingsDebug属性页的Program arguments栏设置运行参数。下面是一个运行参数示例:-info D:faceposdataposdata.dat -vec D:facepos.vec -num 50 -w 20 -h 20表示有50个样本,样本宽20,高20,正样本描述文件为posdata.dat,结果输出到pos.vec。或者在dos下输入:D:Program FilesOpenCVbincreatesamples.exe -info posdataposdata

8、.dat -vec datapos.vec -num 50 -w 20 -h 20 运行完了会d:facedata下生成一个*.vec的文件。该文件包含正样本数目,宽高以及所有样本图像数据。结果入下图:Createsamples程序的命令行参数:命令行参数:vec 训练好的正样本的输出文件名。img源目标图片(例如:一个公司图标)bg背景描述文件。num要产生的正样本的数量,和正样本图片数目相同。bgcolor背景色(假定当前图片为灰度图)。背景色制定了透明色。对于压缩图片,颜色方差量由bgthresh参数来指定。则在bgcolorbgthresh和 bgcolorbgthresh中间的像素被

9、认为是透明的。bgthreshinv如果指定,颜色会反色randinv如果指定,颜色会任意反色maxidev背景色最大的偏离度。maxangelmaxangle,maxzangle最大旋转角度,以弧度为单位。show如果指定,每个样本会被显示出来,按下esc会关闭这一开关,即不显示样本图片,而创建过程继续。这是个有用的debug选项。w输出样本的宽度(以像素为单位)hsample_height输出样本的高度,以像素为单位。到此第一步样本训练就完成了。恭喜你,你已经学会训练分类器的五成功力了,我自己学这个的时候花了我一天的时间,估计你几分钟就学会了吧。三、训练分类器样本创建之后,接下来要训练分类

10、器,这个过程是由haartraining程序来实现的。该程序源码由OpenCV自带,且可执行程序在OpenCV安装 目录的bin目录下。Haartraining的命令行参数如下:data存放训练好的分类器的路径名。vec正样本文件名(由trainingssamples程序或者由其他的方法创建的)bg背景描述文件。npos,nneg用来训练每一个分类器阶段的正/负样本。合理的值是:nPos = 7000;nNeg = 3000nstages训练的阶段数。nsplits决定用于阶段分类器的弱分类器。如果1,则一个简单的stump classifier被使用。如果是2或者更多,则带有number_o

11、f_splits个内部节点的CART分类器被使用。mem预先计算的以MB为单位的可用内存。内存越大则训练的速度越快。sym(default)nonsym指定训练的目标对象是否垂直对称。垂直对称提高目标的训练速度。例如,正面部是垂直对称的。minhitratemin_hit_rate每个阶段分类器需要的最小的命中率。总的命中率为min_hit_rate的number_of_stages次方。maxfalsealarm没有阶段分类器的最大错误报警率。总的错误警告率为max_false_alarm_rate的number_of_stages次方。weighttrimming指定是否使用权修正和使用多

12、大的权修正。一个基本的选择是0.9eqwmode选择用来训练的haar特征集的种类。basic仅仅使用垂直特征。all使用垂直和45度角旋转特征。wsample_widthhsample_height训练样本的尺寸,(以像素为单位)。必须和训练样本创建的尺寸相同。一个训练分类器的例子:D:Program FilesOpenCVbinhaartraining.exe -data datacascade -vec datapos.vec -bg negdatanegdata.dat -npos 49 -nneg 49 -mem 200 -mode ALL -w 20 -h 20训练结束后,会在目录

13、data下生成一些子目录,即为训练好的分类器。训练结果如下:恭喜你,你已经学会训练分类器的九成功力了。四:利用训练好的分类器进行目标检测。这一步需要用到performance.exe,该程序源码由OpenCV自带,且可执行程序在OpenCV安装目录的bin目录下。performance.exe -data data/cascade -info posdata/test.dat -w 20 -h 20 -rs 30performance的命令行参数如下:Usage: ./performance-data -info -maxSizeDiff -maxPosDiff -sf -ni-nos -rs

14、 -w -h 也可以用opencv的cvHaarDetectObjects函数进行检测:CvSeq* faces = cvHaarDetectObjects( img, cascade, storage, 1.1, 2, CV_HAAR_DO_CANNY_PRUNING, cvSize(40, 40) ); /3. 检测人脸注:OpenCv的某些版本可以将这些目录中的分类器直接转换成xml文件。但在实际的操作中,haartraining程序却好像永远不会停止,而且没 有生成xml文件,后来在OpenCV的yahoo论坛上找到一个haarconv的程序,才将分类器转换为xml文件,其中的原因尚待

15、研究。我的问题:有了opencv自带的那些xml人脸检测文档,我们 就可以用cvLoad()这个函数加载他们,让他们对我们的人脸进行检测,但是,现在生活中的计算机视觉并不远远是检测人脸,还有很多物品需要识别,所 以,能不能自己做个xml的检测文档,用它来检测自己需要的东西呢?例如,检测一个可乐瓶!问题解决:首先了解下,目标检测分为三个步骤:1、 样本的创建2、 训练分类器3、 利用训练好的分类器进行目标检测。一,样本的创建:训练样本分为正例样本和反例样本,其中正例样本是指待检目标样本(例如可乐瓶,人脸等),反例样本指其它任意图片,所有的样本图片都被归一化为同样的尺寸 大小(例如,20x20)。

16、1 负样本(反例样本)可以来自于任意的图片,但这些图片不能包含目标特征。负样本由背景描述文件来描述。背景描述文件是一个文本文件,每一行包含了一个负样 本图片的文件名(基于描述文件的相对路径)。该文件必须手工创建。例如,假定目录下有 bg1.bmp bg2.bmp 这2个负样本的图片,这2个图片放在img目录下,所以其背景描述文件 bg.txt 的内容为_img/bg1.bmp 1 0 0 24 28_ing/bg2.bmp 1 0 0 24 28_img/bg3.bmp 1 0 0 24 28_ing/bg4.bmp 1 0 0 24 28_img/bg5.bmp 1 0 0 24 28_in

17、g/bg6.bmp 1 0 0 24 28_img/bg7.bmp 1 0 0 24 28_ing/bg8.bmp 1 0 0 24 28_img/bg9.bmp 1 0 0 24 28_ing/bg10.bmp 1 0 0 24 28这样负样本建立完毕,先保存!等会用!2,正样本现在,我们来看正样本的创建步骤:正样本由程序createsample 程序来创建。该程序的源代码由OpenCV 给出,并且在bin 目录下包含了这 个可执行的程序。例如你opencv安装目录为 c: 既C:OpenCVbin,你找找就有正样本可以由单个的目标图片或者一系列的事先标记好的图片来创建!2-2在用creat

18、esamples.exe 这个程序前,先来了解下这个程序的一些命令组合模式Createsamples 程序的命令行参数:命令行参数:vec 训练好的正样本的输出文件名。img源目标图片(例如:一个公司图标)bg背景描述文件。num要产生的正样本的数量,和正样本图片数目相同。bgcolor背景色(假定当前图片为灰度图)。背景色制定了透明色。对于压缩图片,颜色方差量由bgthresh参数来指定。则在bgcolorbgthresh 和bgcolorbgthresh 中间的像素被认为是透明的。bgthreshinv如果指定,颜色会反色randinv如果指定,颜色会任意反色maxidev背景色最大的偏离

19、度。maxangelmaxangle,maxzangle最大旋转角度,以弧度为单位。show如果指定,每个样本会被显示出来,按下esc会关闭这一开关,即不显示样本图片,而创建过程继续。这是个有用的debug 选项。w输出样本的宽度(以像素为单位)hsample_height输出样本的高度,以像素为单位。注:正样本也可以从一个预先标记好的图像集合中获取。这个集合由一个文本文件来描述,类似于背景描述文件。每一个文本行对应一个图片。每行的第一个元素是图片文件名,第二个元素是对象实体的个数。后面紧跟着的是与之匹配的矩形框(x, y, 宽度,高度)。了解了创建函数的命令行参数现在我们对正样本举个例子:假

20、设有5 个正样本图片文件img1.bmp,img5.bmp;创建一个正样本的txt文本文档,名字为 info.txt正样本描述文件info.txt 的内容如下positive/image1.bmp 1 0 0 24 28positive/image2.bmp 1 0 0 24 28positive/image3.bmp 1 0 0 24 28positive/image4.bmp 1 0 0 24 28positive/image5.bmp 1 0 0 24 28positive/image6.bmp 1 0 0 24 28图片img1.bmp 包含了单个目标对象实体,矩形为(0,0,24,2

21、8)。注意:要从图片集中创建正样本,要用info 参数而不是用img 参数。info 标记特征的图片集合的描述文件。背景(负样本)描述文件的内容如下:_img/bg1.bmp 1 0 0 24 28_ing/bg2.bmp 1 0 0 24 28_img/bg3.bmp 1 0 0 24 28_ing/bg4.bmp 1 0 0 24 28_img/bg5.bmp 1 0 0 24 28_ing/bg6.bmp 1 0 0 24 28_img/bg7.bmp 1 0 0 24 28_ing/bg8.bmp 1 0 0 24 28_img/bg9.bmp 1 0 0 24 28_ing/bg10

22、.bmp 1 0 0 24 28这几个文件的位置在同个文件夹下,哎,看图,一目了然:现在说了这么多废话,现在开始干了:首先,打开,DOS,(开始-运行-输入cmd)缺换到刚那个文件放的文件夹下,如图,dos命令的缺换用cd,不详说。如图:输入的命令如图:然后按回车键,会出现生成正样本文件的信息:如图三、训练分类器样本创建之后,接下来要训练分类器,这个过程是由haartraining 程序来实现的。Haartraining 的命令行参数如下:data存放训练好的分类器的路径名。vec正样本文件名(由trainingssamples 程序或者由其他的方法创建的)bg背景描述文件。npos,nneg

23、用来训练每一个分类器阶段的正/负样本。合理的值是:nPos = 7000;nNeg = 3000nstages训练的阶段数。nsplits决定用于阶段分类器的弱分类器。如果1,则一个简单的stump classifier 被使用。如果是2 或者更多,则带有number_of_splits 个内部节点的CART 分类器被使用。mem预先计算的以MB 为单位的可用内存。内存越大则训练的速度越快。sym(default)nonsym指定训练的目标对象是否垂直对称。垂直对称提高目标的训练速度。例如,正面部是垂直对称的。minhitratemin_hit_rate每个阶段分类器需要的最小的命中率。总的命

24、中率为min_hit_rate 的number_of_stages 次方。maxfalsealarm没有阶段分类器的最大错误报警率。总的错误警告率为max_false_alarm_rate 的number_of_stages 次方。weighttrimming指定是否使用权修正和使用多大的权修正。一个基本的选择是0.9eqwmode选择用来训练的haar 特征集的种类。basic 仅仅使用垂直特征。all 使用垂直和45 度角旋转特征。wsample_widthhsample_height训练样本的尺寸,(以像素为单位)。必须和训练样本创建的尺寸相同然后,同样在dos命令行输入harr这个函数

25、的命令具体如图:然后,按回车,会出现下面的“成果”界面:到目前为止,你自己需要的分类器的xml文档就生成了,你自个找下你当前那个目录,会发现,多了几个文件夹,请看图:到目前为止,就告一段落了,快一点了,还真冷,脚冰了!(这里就只有几个图片,所以,很快训练完,不过,要想训练出检测率高的xml,图片的张数的很多,那时候, 会训练几个小时到1天,时间几天的时间,那时候,你只求你的电脑不要断电!)1、OpenCV自带的HaarTraining中的 cvCreateTreeCascadeClassifier(.)函数最后出来的结果就是一个xml文件。而且为自己也亲自实验了,结果就是一个xml文件。在使用

26、 haartraining.exe的时候,注意到第一个参数是dirname。假设dirname = D:/haartraining/cascade,那么在整个训练结束的时候,会在D:/haartraining/cascade路径下产生 nstages个子文件夹。dirname 的另一个作用就是用它来产生xml文件的存放路径以及名字,像这样的dirname就会在 D:/haartraining路径下生成cascade.xml。2、HaarTraining训练过程: (1)、 要训练一个HaarTraining,总体上要分为3步:1)、准备正负样本;2)、用CreateSamples程序建正样本集;3)、用HaarTraining程序训 练,得到最终的分类器模型(xml文件)。 (2)、主要步骤说明:1)、 样本准备正样本:对于 正样本,通常的做法是先把所有正样本裁切好,并对尺寸做规整(即缩放至指定大小)。(这里我们直接从网上下载)由于HaarTraining训练时输入的正样本是vec文件,所以需要使用OpenCV自带的CreateSamples程序将准备好的正样本转换为vec文

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1