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, чем больше это значение, тем больше сходство между двумя изображениями.

Другие вопросы по тегам