Почему OpenCV SimpleBlobDetector не обнаруживает капли на этом изображении? - PullRequest
0 голосов
/ 28 января 2019

Я пытаюсь обнаружить капли в изображениях, подобных следующему:

The image after color inversion

Тем не менее, ни одна капля не обнаружена.Я проверил некоторые тестовые изображения, и следующий код работает нормально.Я также пытался настроить параметры, но безуспешно.Есть идеи, что я делаю не так?

Это код, который я использую:

procpred = cv2.bitwise_not(procpred)
blur = cv2.blur(procpred, (15,15), 0)

params = cv2.SimpleBlobDetector_Params() 
# Change thresholds
params.minThreshold = 10
params.maxThreshold = 200

# Filter by Area.
params.filterByArea = False
params.minArea = 10

# Filter by Circularity
params.filterByCircularity = False
params.minCircularity = 0.1

# Filter by Convexity
params.filterByConvexity = False
params.minConvexity = 0.87

# Filter by Inertia
params.filterByInertia = False
params.minInertiaRatio = 0.01

# Create a detector with the parameters
ver = (cv2.__version__).split('.')
if int(ver[0]) < 3 :
    detector = cv2.SimpleBlobDetector(params)
else: 
    detector = cv2.SimpleBlobDetector_create(params)

# Detect blobs.
keypoints = detector.detect(blur)
print(keypoints)

#Draw detected blobs as red circles.
#cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS ensures the size of the circle corresponds to the size of blob
im_with_keypoints = cv2.drawKeypoints(procpred, keypoints, np.array([]), (0,0,255), cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)

plt.imshow(im_with_keypoints)

1 Ответ

0 голосов
/ 28 января 2019

Не уверен, что вы делаете в начале вашего кода, но я сделал это, и, кажется, работает нормально:

#!/usr/bin/env python3

import cv2
import numpy as np

# Read image
im = cv2.imread("blobs.png", cv2.IMREAD_GRAYSCALE)

params = cv2.SimpleBlobDetector_Params() 
# Change thresholds
params.minThreshold = 10
params.maxThreshold = 200

# Filter by Area.
params.filterByArea = False
params.minArea = 10

# Filter by Circularity
params.filterByCircularity = False
params.minCircularity = 0.1

# Filter by Convexity
params.filterByConvexity = False
params.minConvexity = 0.87

# Filter by Inertia
params.filterByInertia = False
params.minInertiaRatio = 0.01

# Create a detector with the parameters
ver = (cv2.__version__).split('.')
if int(ver[0]) < 3 :
    detector = cv2.SimpleBlobDetector(params)
else: 
    detector = cv2.SimpleBlobDetector_create(params)

# Detect blobs.
keypoints = detector.detect(im)
print(keypoints)
im_with_keypoints = cv2.drawKeypoints(im, keypoints, np.array([]), (0,0,255), cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)
cv2.imwrite("result.png",im_with_keypoints)

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...