因为最近看了一部美剧《Person of Interest》,想起了当时弃坑很久的EmguCV,加上C#的功力日渐深厚,决定重新拿来研究研究。
这次还是继续沿用Emgu.CV,2.4.10版本,进攻方向:HOG+SVM
没想到问题颇多,耗时三个星期,在SVM这个环节上卡了一把。
————————————————————————————————————————————————————————————————————
一开始,调用HOGDescriptor,加载了HOGDescriptor.GetDefaultPeopleDetector(),全程行云流水,顺利获取20+个摄像头的样本,共20+G,1W+图片。
人工审核的过程中,发现误报率实在是高,于是网上了解了一下,说是用SVM可以解决这个问题,于是开刀继续尝试。
将样本一点一点采集,挑出了几百张正样本和负样本,但采集完后发现根本不知道怎么加载到SVM,
publicbool Train(Matrix<float> trainData, Matrix<float> responses, Matrix<byte> varIdx, Matrix<byte> sampleIdx, SVMParams parameters);
这段代码看得我是一脸懵逼,Matrix是什么鬼,float又是什么鬼。
感叹C#还是学不精之余,继续研究相关解决方案。
但网上基本没有C#的相关资料,唯一能找到的资料也只有http://www.cnblogs.com/KC-Mei/p/4553024.html的文章,但他也没有明说train怎么实现。
于是只能自己想办法:硬啃Emgu的源:OpenCV
当然,本人不懂C++,硬是看了三天三夜的代码,翻遍了OpenCV官网、EmguCV官网、stackoverflow等翻了一遍,总算理解了大概的思路,就是说将图片加载到矩阵中,然后将图片矩阵的定义的label矩阵交给svm识别。
然而在写了那么长的代码后,脑子一片混乱,调试的过程中一直出现“XXX已停止工作”