opencv3.0训练自己的级联分类器(traincascade),将已经生成的stage.xml合成最终的分类器xml

最近一段在用opencv自带的分类器训练函数训练分类器,遇到了一点问题:
分类器预设的stage=20太深,当训练到第6层时,已经收敛,而由于训练数据非常多,再往下训练非常耗时(已经卡住三天了),因此我就想,如何把目前生成的6层弱分类器连接起来,当做最终的分类器(精度已经达到要求)。然后就查询网络,得到了下面的解决方法:

1.直接根据最终分类器.xml的格式要求,将stagei.xml拼接起来。

这个方法是最直接的,我仿照着opencv3.0自带的分类器haarcascade_eye.xml中的格式,将我生成的stage0.xml、stage1.xml、stage2.xml等依次复制替换进去,然后进行识别的测试,结果报错,分类器格式不对。
然后查阅文献,发现分类器的xml文件组成比较复杂,而关键的问题是stagei.xml中并没有存储每个节点对应的haar特征:字段缺失,所以当然无法直接拼接。 方法1错误。

2.opencv自带的convert_cascade.exe进行拼接。

这个方法是网上能查到的最常见的解决方法,我也进行了测试,
convert_cascade.exe –size=”20x20” D:\Training\cascade D:\CE-5\Training\cascade\haar_adaboost.xml
但依旧报错,因为该函数是opencv2.x对应的,其用的分类器训练函数是opencv_haartraining.exe,和我们3.0的方法不同,生成的stage文件当然不同。
随后我转到opencv3.0中查找opencv-3..0\modules\objdetect\src\cascadedetect_convert.cpp,进行测试,依旧错误。在网上查好像该函数并不是为了拼接用,好像是转换最终生成的分类器.xml文件的。方法2错误。

3.最后的方法。

折腾了有两三天都没搞出来,很无语。突然灵光一闪,我们可以终止原来的训练函数,然后将训练阶数设置成6(与目前训练分类器卡住的位置相同),然后opencv会自动读取之前训练的结果stagei.xml,生成最终的分类器:cascade.xml。
然后bingo,测试后效果也不错,终于搞定了!!!

PS. 想问题,往往容易陷入死角,这个时候应该跳出来,换个思路去做;国内网站可以搜到的东西很多都是重复无用的,学好英文多搜搜国外的网站,多Google

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python对于OpenCV级联分类器训练非常方便,可以通过几个简单的步骤,轻松地完成自己的XML文件训练。 第一步是准备训练数据集。训练集应该包括正面和负面的例子,正面的例子是要识别的目标,负面的例子则是不包含目标的图像。 第二步是进行数据预处理。这包括将图像转换为灰度图像,以及对其进行缩小和正规化。这样有助于提高分类器的准确性和效率。 第三步是使用OpenCV提供的Cascade Trainer GUI工具进行分类器训练。这个工具可以通过交互式界面来设置训练参数,例如正负样本的路径、级联深度、检测窗口大小等等。训练完成后,级联分类器就会在指定的.xml文件中保存。 第四步是使用训练好的分类器进行目标检测。可以使用OpenCV提供的Cascade Classifier类来加载分类器文件,并应用于图像或视频数据。这个类可以方便地进行级联分类器的检测和识别。 总的来说,Python对于OpenCV级联分类器训练和应用非常方便和灵活,可以应用于许多实际场景中,如人脸识别、车辆检测等。需要注意的是,训练过程需要耗费大量的计算资源和时间,因此应该选择适当的硬件设备和训练数据集,以获得更好的效果。 ### 回答2: Python对OpenCV级联分类器训练可以实现自己的XML文件。级联分类器是一种基于机器学习的图像识别技术,主要用于目标分类、物体检测等。OpenCV是一个开源的计算机视觉库,提供了丰富的图像和视频处理功能。Python是一种高级编程语言,通常用于数据分析和人工智能领域。 Python对OpenCV级联分类器训练可以通过以下步骤实现: 1. 收集样本数据:首先需要收集足够多的正负样本数据,正样本用于训练模型,负样本用于补充训练,提高模型准确率。 2. 特征提取:使用OpenCV中的Haar特征进行图像特征提取,以此确定图像中是否存在目标物体。Haar特征是基于图像亮度和对比度变化的一种特征表示方法。 3. 训练模型:使用Python对OpenCV中的级联分类器进行训练,根据样本数据和特征提取结果,训练模型,并反复迭代优化。 4. 测试模型:完成模型训练后,需要对模型进行测试,验证其在测试数据集中的准确率。 5. 生成XML文件:当训练好了模型后,需要将其保存为XML文件。XML文件包含了训练好的模型参数,可以通过OpenCVCascadeClassifier类进行加载和应用。 总的来说,Python对OpenCV级联分类器训练可以帮助用户创建自己的图像识别模型,并将其保存为XML文件,以便后续应用。该技术具有广泛的应用场景,例如人脸识别、车牌识别、物体检测等。 ### 回答3: Python对OpenCV级联分类器训练,可以通过利用分类器训练工具Cascade Trainer GUI和HaarTraining.exe,在windows或者Linux/Mac OS系统下进行相关操作,实现自己的级联分类器训练生成属于自己的xml文件。 通过一系列的步骤操作,可以在OpenCV中准确地训练一个线性分类器。首先,需要进行正样本的收集,这些正样本应该是需要被检测的目标,比如人脸等等。其次,需要进行负样本的收集,这些负样本应该是和目标无关的固定的图像。然后,需要根据正负样本进行训练,选择合适的参数和特征,应用级联分类器,并进行训练最终训练出一个能够准确判断图像中是否包含目标的级联分类器。最后,生成与自己训练级联分类器相匹配的XML文件,该XML文件中包含了训练好的特征和参数,可以被导入到其他项目中进行相似的目标检测。 利用级联分类器进行图像检测,可以帮助我们提高检测的准确度和效率。它在训练时,能够自动选择极具区分性的特征来提高处置速度,达到更好的检测效果。 总之,Python对OpenCV级联分类器训练,可以根据需要的检测目标,利用相应的工具和步骤,进行训练生成相应的XML文件。这种方法能够有效地解决图像目标检测的问题,提高识别的准确度和效率,并具有广泛的应用价值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值