traincascade.cpp
2015-11-23 23:24
579 查看
int main( int argc, char* argv[] ) { CvCascadeClassifier classifier; string cascadeDirName, vecName, bgName; int numPos = 2000; int numNeg = 1000; int numStages = 20; int precalcValBufSize = 256, precalcIdxBufSize = 256; bool baseFormatSave = false; CvCascadeParams cascadeParams;//stage type,featuretype,windowsize CvCascadeBoostParams stageParams;//minHitRate,maxFalseAlarm,boost-type(real,gentle),weak_count,split_criteria,weight_trim_rate,cv_folds,max_depth Ptr<CvFeatureParams> featureParams[] = { Ptr<CvFeatureParams>(new CvHaarFeatureParams), Ptr<CvFeatureParams>(new CvLBPFeatureParams), Ptr<CvFeatureParams>(new CvHOGFeatureParams) }; int fc = sizeof(featureParams)/sizeof(featureParams[0]); if( argc == 1 ) { cout << "Usage: " << argv[0] << endl; cout << " -data <cascade_dir_name>" << endl; cout << " -vec <vec_file_name>" << endl; cout << " -bg <background_file_name>" << endl; cout << " [-numPos <number_of_positive_samples = " << numPos << ">]" << endl; cout << " [-numNeg <number_of_negative_samples = " << numNeg << ">]" << endl; cout << " [-numStages <number_of_stages = " << numStages << ">]" << endl; cout << " [-precalcValBufSize <precalculated_vals_buffer_size_in_Mb = " << precalcValBufSize << ">]" << endl; cout << " [-precalcIdxBufSize <precalculated_idxs_buffer_size_in_Mb = " << precalcIdxBufSize << ">]" << endl; cout << " [-baseFormatSave]" << endl; cascadeParams.printDefaults(); stageParams.printDefaults(); for( int fi = 0; fi < fc; fi++ ) featureParams[fi]->printDefaults(); return 0; } for( int i = 1; i < argc; i++ ) { bool set = false; if( !strcmp( argv[i], "-data" ) ) { cascadeDirName = argv[++i]; } else if( !strcmp( argv[i], "-vec" ) ) { vecName = argv[++i]; } else if( !strcmp( argv[i], "-bg" ) ) { bgName = argv[++i]; } else if( !strcmp( argv[i], "-numPos" ) ) { numPos = atoi( argv[++i] ); } else if( !strcmp( argv[i], "-numNeg" ) ) { numNeg = atoi( argv[++i] ); } else if( !strcmp( argv[i], "-numStages" ) ) { numStages = atoi( argv[++i] ); } else if( !strcmp( argv[i], "-precalcValBufSize" ) ) { precalcValBufSize = atoi( argv[++i] ); } else if( !strcmp( argv[i], "-precalcIdxBufSize" ) ) { precalcIdxBufSize = atoi( argv[++i] ); } else if( !strcmp( argv[i], "-baseFormatSave" ) ) { baseFormatSave = true; } else if ( cascadeParams.scanAttr( argv[i], argv[i+1] ) ) { i++; } else if ( stageParams.scanAttr( argv[i], argv[i+1] ) ) { i++; } else if ( !set ) { for( int fi = 0; fi < fc; fi++ ) { set = featureParams[fi]->scanAttr(argv[i], argv[i+1]); if ( !set ) { i++; break; } } } } classifier.train( cascadeDirName, vecName, bgName, numPos, numNeg, precalcValBufSize, precalcIdxBufSize, numStages, cascadeParams, *featureParams[cascadeParams.featureType], stageParams, baseFormatSave ); return 0; }
相关文章推荐
- c语言:在屏幕上输出单引号和双引号
- c语言:枚举常量的用法举例
- TLD学习(2)-调试lk.cpp
- C#中调用c++的dll
- c语言:求字符串的字节数,strlen
- C++引用的探究
- paip.提升用户体验---c++ qt 悬浮窗实现
- C++学习笔记28——泛型算法之iostream迭代器
- 待排序的最短子数组长度(C++版)
- OC 语言的特性和OC/C/C++ 比较
- 【C语言】 检测大小端存储
- c++栈之括号匹配问题
- c++之链表实现栈
- C语言段与内存的理解
- C++开发中一个解决方案里,两个项目的相互引用,相互依赖的实现方法(解决方法)
- strcpy,strncpy函数实现——string.h库函数
- 有序矩阵查找的快速算法(C++版)
- 【C++】非递归求二叉树的前序和中序序列
- c++类模板之间友元函数调用
- 《C++ primer》英文第五版阅读笔记(十六)——赋值运算符