Я использую ORB из OpenCV на Python 3.6.2, чтобы найти координаты центра фигуры на другом изображении (оба показаны на прикрепленном изображении здесь).Я не хочу неправильных матчей и не хочу пропустить матч.Совпадения, показанные на изображении, не эффективны.
Мой код выглядит следующим образом:
import numpy as np
import cv2 as cv
import matplotlib.pyplot as plt
img1 = cv.imread('target2.jpg',0)
img2 = cv.imread('geo50.jpg',0) # trainImage
orb = cv.ORB_create(edgeThreshold=14, nfeatures=100,
scoreType=cv.ORB_FAST_SCORE,scaleFactor=1)
kp1, des1 = orb.detectAndCompute(img1,None)
kp2, des2 = orb.detectAndCompute(img2,None)
bf = cv.BFMatcher(cv.NORM_HAMMING, crossCheck=True)
matches = bf.match(des1,des2)
matches = sorted(matches, key = lambda x:x.distance)
img3 = img3 = cv.drawMatches(img1,kp1,img2,kp2,matches[:100],None,flags = 2)
plt.imshow(img3),plt.show()