训练后如何使用群集文件
How to use clustering file after training
我用 BOG 和 SVM 训练了数据,我训练了它,现在我只想通过 xml
打开它,我不想在每次运行时一次又一次地训练它,我训练了 svm,现在使用其加载功能加载它
CvSVM svm;
svm.load( "trainsvm.xml" );
但是如何使用 BOG 算法对我用于聚类的词汇文件做同样的事情,下面是我的代码,它正在训练数据,但我现在想像svm
一样打开它
for (i = all_names.begin(); i != all_names.end(); ++i)
{
Dir=( (count < files.size() ) ? YourImagesDirectory : YourImagesDirectory_2);
Mat row_img = cv::imread( Dir +*i, 0 );
detector.detect( row_img, keypoints);
RetainBestKeypoints(keypoints, 20);
extractor->compute( row_img, keypoints, descriptors_1);
descriptors_1.reshape(1,1);
bow.add(descriptors_1);
++count;
}
vector<string>::const_iterator k;
cout<<"CLUSTERING"<<endl;
Mat vocabulary = bow.cluster();
dextract.setVocabulary(vocabulary);
cv::Mat training_mat(num_img , dictionarySize,CV_32FC1);
cv::Mat labels(num_img,1,CV_32FC1);
这是对数据进行聚类,现在我不想一遍又一遍地运行它,因为它需要太多的时间,当它训练一次时,我只想使用它,这样我就可以加快我的程序
您可以将
此问题简化为"如何保存不是图像的自定义 Mat 对象?
您可以使用 cv::FileStorage。您可以在此处关注此文档,在此处关注此帖子。
相关文章:
- .cpp和.h文件中的模板专用化声明
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 文本文件中的单词链表
- CMake-按正确顺序将项目与C运行时对象文件链接
- 使用新行和不使用新行读取文件
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 挂起和取消挂起一个文件DLL
- 如何确定我已使用非编码文件到达 EOF?
- 命名空间中具有.h和.cpp文件的类
- 如何使用ndk-build.cmd构建Android.so文件
- 从包含m行的文件中提取n行,必要时(惰性地)重复该文件
- 读取文件并输入到矢量中
- 在C++中查找文件
- c++库的公共头文件中应该包含什么
- 用c++从输入文件中读取另一行
- Cppcheck生成xml转储文件
- 读取文件的最后一行并输入到链接列表时出错
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- 编码的MKV文件群集大小
- 训练后如何使用群集文件