SVMでBOGを使用してデータをトレーニングしました。トレーニングしました。今はそれを開きたいだけです。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);
これはデータをクラスタリングしています。時間がかかりすぎるため、何度も実行したくありません。一度トレーニングすると、プログラムを高速化できるように、それを使用したいだけです。