EmguCV - получить количество совпадений для определения сходства изображений
В настоящее время я использую алгоритм SURF (на EmguCV 3.1), чтобы проверить, могут ли два изображения соответствовать одному и тому же местоположению. Изображение 1 и его очень темная версия, что дает мне следующие 2 вопроса:
1-Считаете ли вы, что подсчет количества совпадений между двумя картинками является хорошей идеей для определения сходства изображений? Если нет, то есть другие предложения?
2-Предполагая, что подсчет количества совпадений является хорошим подходом. Как узнать количество матчей? В некоторых статьях рассказывается о подсчете количества ненулевых предметов. Однако результаты, похоже, не совпадают, как на этом рисунке, который показывает только 2 совпадения, но возвращает значение 30 (переменная noZeroCount). Код, который я использую, это:
public static void FindMatch(Mat modelImage, Mat observedImage, out long matchTime, out VectorOfKeyPoint modelKeyPoints, out VectorOfKeyPoint observedKeyPoints, VectorOfVectorOfDMatch matches, out Mat mask, out Mat homography)
{
int k = 2;
double uniquenessThreshold = 0.8;
double hessianThresh = 300;
Stopwatch watch;
homography = null;
modelKeyPoints = new VectorOfKeyPoint();
observedKeyPoints = new VectorOfKeyPoint();
using (UMat uModelImage = modelImage.ToUMat(AccessType.Read))
using (UMat uObservedImage = observedImage.ToUMat(AccessType.Read))
{
SURF surfCPU = new SURF(hessianThresh, 4 , 2, true, true);
//extract features from the object image
UMat modelDescriptors = new UMat();
surfCPU.DetectAndCompute(uModelImage, null, modelKeyPoints, modelDescriptors, false);
watch = Stopwatch.StartNew();
// extract features from the observed image
UMat observedDescriptors = new UMat();
surfCPU.DetectAndCompute(uObservedImage, null, observedKeyPoints, observedDescriptors, false);
BFMatcher matcher = new BFMatcher(DistanceType.L2);
matcher.Add(modelDescriptors);
matcher.KnnMatch(observedDescriptors, matches, k, null);
mask = new Mat(matches.Size, 1, DepthType.Cv8U, 1);
mask.SetTo(new MCvScalar(255));
Features2DToolbox.VoteForUniqueness(matches, uniquenessThreshold, mask);
int nonZeroCount = CvInvoke.CountNonZero(mask);
if (nonZeroCount >= 4)
{
nonZeroCount = Features2DToolbox.VoteForSizeAndOrientation(modelKeyPoints, observedKeyPoints,
matches, mask, 1.5, 20);
if (nonZeroCount >= 4)
homography = Features2DToolbox.GetHomographyMatrixFromMatchedFeatures(modelKeyPoints,
observedKeyPoints, matches, mask, 2);
}
watch.Stop();
matchTime = watch.ElapsedMilliseconds;
}
}
Высоко ценится за любые ваши усилия.
1 ответ
Используя nonZeroCount, чем больше это значение, тем больше сходство между двумя изображениями.