Сопоставление нескольких объектов с использованием OpenCV

Я пытаюсь сопоставить несколько объектов, используя только один шаблон. Но проблема в том, что моя программа сопоставляет множественные вхождения для каждого объекта во входном изображении. Как мне сопоставить несколько объектов и все объекты за один раз во входном изображении?

Это мой код

public void run(String inFile, String templateFile, String outFile, int match_method) {
    System.out.println("\nRunning Template Matching");

    Mat img = Imgcodecs.imread(inFile);
    Mat templ = Imgcodecs.imread(templateFile);

    // / Create the result matrix
    int result_cols = img.cols() - templ.cols() + 1;
    int result_rows = img.rows() - templ.rows() + 1;
    Mat result = new Mat(result_rows, result_cols, CvType.CV_32FC1);

    // / Do the Matching and Normalize
    Imgproc.matchTemplate(img, templ, result, match_method);
    Core.normalize(result, result, 0, 1, Core.NORM_MINMAX, -1, new Mat());

    while(true)
    {
    // / Localizing the best match with minMaxLoc
    Core.MinMaxLocResult mmr = Core.minMaxLoc(result);

    Point matchLoc;
    if (match_method == Imgproc.TM_SQDIFF || match_method == Imgproc.TM_SQDIFF_NORMED) {
        matchLoc = mmr.minLoc;
    } else {
        matchLoc = mmr.maxLoc;
    }      

        if(mmr.maxVal >=0.97)
         {
            // / Show me what you got
            Imgproc.rectangle(img, matchLoc, 
                new Point(matchLoc.x + templ.cols(),matchLoc.y + templ.rows()), 
                new    Scalar(0,255,0),2);
            //Imgproc.putText(img, "Edited by me",
              //  new Point(matchLoc.x + templ.cols(),matchLoc.y + templ.rows()),
                //Core.FONT_HERSHEY_PLAIN, 1.0 ,new  Scalar(0,255,255));
            Imgproc.rectangle(result, matchLoc, 
                new Point(matchLoc.x + templ.cols(),matchLoc.y + templ.rows()), 
                new    Scalar(0,255,0),-1);                 
         }
         else
         {
             break; //No more results within tolerance, break search
         }
    }

    // / Show me what you got
    //Imgproc.rectangle(img, matchLoc, new Point(matchLoc.x + templ.cols(), 
    //matchLoc.y + templ.rows()), new Scalar(0, 255, 0),2);

    // Save the visualized detection.
    System.out.println("Writing "+ outFile);
    Imgcodecs.imwrite(outFile, img);

}



public static void main(String[] args) {
    System.loadLibrary("opencv_java310");
    run("test.jpg", "temp.png",  "output.png", Imgproc.TM_CCOEFF_NORMED);
}

test.jpg

введите описание изображения здесьtemp.png

введите описание изображения здесь

результат введите описание изображения здесь

1 ответ

Вам нужен не максимальный шаг подавления.

Примерно так: NMS для python 1 или более быстрая версия NMS для python 2.

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