そこで、FAST 検出器と FREAK 記述子を使用してアプリケーションを作成しています。マッチングに関しては、BRUTEFORCE_HAMMING マッチングを使用したかったのですが、期待した結果が得られません (元の画像とは関係のない画像との一致が多くなり、次に似ている画像が得られます)。
次のコードを試しました
MatOfDMatch matches = new MatOfDMatch();
matcher = DescriptorMatcher.create(DescriptorMatcher.BRUTEFORCE_HAMMING);
matcher.match(descriptors,descriptors1,matches);
MatOfDMatch goedematches = new MatOfDMatch();
double max_dist = 0;
double min_dist = 100;
//if (descriptors.cols() == descriptors1.cols())
//{
for( int i = 0; i < descriptors.rows(); i++ )
{ double dist = matches.toArray()[i].distance;
if( dist < min_dist ) min_dist = dist;
if( dist > max_dist ) max_dist = dist;
}
// should only draw good matches
for( int i = 0; i < descriptors.rows(); i++ )
{ MatOfDMatch temp = new MatOfDMatch();
if( matches.toArray()[i].distance <= 2*min_dist )
{ temp.fromArray(matches.toArray()[i]);
goedematches.push_back(temp);
}
// }
}
Log.d("LOG!", "Number of good matches= " + goedematches.size());
しかし、それは「悪い」結果を返します。私の質問は、これを FREAK 記述子と一致させる他の方法はありますか? (私は OpenCV ライブラリ 2.4.4 と Java ラッパーを使用しているため、C コードはありません)