我正在研究一个物体检测和跟踪系统,输入是一个rgb网络摄像头流。我的代码没有问题来检测黄色,绿色和蓝色的几何物体,如球,但是当谈到红球时,我正在挑战一个问题。OpenCV + python红球检测和跟踪
# converting the input stream into HSV color space
hsv_conv_img = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
# because hue wraps up and to extract as many "red objects" as possible, I define lower and upper boundaries for brighter and for darker red shades
bright_red_lower_bounds = (0, 100, 100)
bright_red_upper_bounds = (10, 255, 255)
bright_red_mask = cv2.inRange(hsv_conv_img, bright_red_lower_bounds, bright_red_upper_bounds)
dark_red_lower_bounds = (160, 100, 100)
dark_red_upper_bounds = (179, 255, 255)
dark_red_mask = cv2.inRange(hsv_conv_img, dark_red_lower_bounds, dark_red_upper_bounds)
# after masking the red shades out, I add the two images
weighted_mask = cv2.addWeighted(bright_red_mask, 1.0, dark_red_mask, 1.0, 0.0)
# then the result is blurred
blurred_mask = cv2.GaussianBlur(weighted_mask,(9,9),3,3)
# some morphological operations (closing) to remove small blobs
erode_element = cv2.getStructuringElement(cv2.MORPH_RECT, (3, 3))
dilate_element = cv2.getStructuringElement(cv2.MORPH_RECT, (8, 8))
eroded_mask = cv2.erode(blurred_mask,erode_element)
dilated_mask = cv2.dilate(eroded_mask,dilate_element)
# on the color-masked, blurred and morphed image I apply the cv2.HoughCircles-method to detect circle-shaped objects
detected_circles = cv2.HoughCircles(dilated_mask, cv2.HOUGH_GRADIENT, 1, 150, param1=100, param2=20, minRadius=20, maxRadius=200)
if detected_circles is not None:
for circle in detected_circles[0, :]:
circled_orig = cv2.circle(frame, (circle[0], circle[1]), circle[2], (0,255,0),thickness=3)
cv2.imshow("original", circled_orig)
else:
cv2.imshow("original", frame)
问题:通过限定范围广泛的“红色”,从HSV提取,我的手和我的脸(在镜头前站立时,保持球)的部分被提取了。 后来HoughCircles方法检测到我手和脸上剩余区域的小圆圈。
我玩了一些cv2.HoughCircles的参数(不太容易调整),例如,一个小的param2值会比一个更大的值检测更多(错误)的圆圈。
有没有人有一个想法如何克服这个问题,并消除错误检测到的圈子?要求:系统对球的大小一无所知,它应该检测很多。所以我无法定义最小或最大圆半径以消除误报。
非常感谢提前。 问候, 克里斯
PS:这段代码是对this one
提供图像将有所帮助。 – m3h0w