我正在使用 opencv(版本 4.1.0,带有 Python 3.7)对二进制图像执行形态关闭。使用大的关闭内核时,我遇到了边界问题。
我的代码是:
close_size = 20
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (close_size, close_size))
result = cv2.morphologyEx(im, cv2.MORPH_CLOSE, kernel)
我读了这个问题和这个问题,还有文档,这导致我也尝试
像这样改变borderValue
论点morphologyEx()
result = cv2.morphologyEx(im, cv2.MORPH_CLOSE, kernel,borderValue=[cv2.BORDER_CONSTANT,0])
但是这两种方法都不会导致我想要的。我在下图中总结了他们的行为。
我的原始图像在顶部。我期望的行为是两个点对于小内核(例如,内核 = 1)保持分离,并为足够大的内核合并在一起。
如您所见,对于默认边界(图像的左列),当 kernel = 6 时合并是正确的,但是一旦它变大,点就开始与边界合并。
使用恒定的边界(图像的右列),可以使用更大的内核,但是对于非常大的内核(例如内核 = 20),仍然会发生意外行为,其中点消失。
关闭内核作为最终软件中的用户参数保留,以便能够合并可能非常远的点。所以理想情况下,我需要能够处理比对象和边界之间的距离更大的平滑内核。