OpenCV中的渐变方向

时间:2018-08-03 07:36:08

标签: python opencv

通过Sobel算符,我已经能够确定图像的梯度幅度。我在下面显示此内容:

GradMag

现在,我希望确定梯度方向。为此,我正在关注this帖子,该帖子使用了功能cv2.phase。然后,根据函数的返回角度,对角度进行硬编码为特定颜色。我的问题是此函数为我返回的值在0到90度之间。因此,我得到的图像仅包含红色和青色。

我的代码如下:

# where gray_blur is a grayscale image of dimension 512 by 512

# 3x3 sobel filters for edge detection
sobel_x = np.array([[ -1, 0, 1], 
                   [ -2, 0, 2], 
                   [ -1, 0, 1]])


sobel_y = np.array([[ -1, -2, -1], 
                   [ 0, 0, 0], 
                   [ 1, 2, 1]])


# Filter the blurred grayscale images using filter2D

filtered_blurred_x = cv2.filter2D(gray_blur, -1, sobel_x)  
filtered_blurred_y = cv2.filter2D(gray_blur, -1, sobel_y)

# Compute the orientation of the image
orien = cv2.phase(np.array(filtered_blurred_x, np.float32), np.array(filtered_blurred_y, dtype=np.float32), angleInDegrees=True)

image_map = np.zeros((orien.shape[0], orien.shape[1], 3), dtype=np.int16)

# Define RGB colours
red = np.array([255, 0, 0])
cyan = np.array([0, 255, 255])
green = np.array([0, 255, 0])
yellow = np.array([255, 255, 0])

# Set colours corresponding to angles
for i in range(0, image_map.shape[0]):
    for j in range(0, image_map.shape[1]):
        if orien[i][j] < 90.0:
            image_map[i, j, :] = red
        elif orien[i][j] >= 90.0 and orien[i][j] < 180.0:
            image_map[i, j, :] = cyan
        elif orien[i][j] >= 180.0 and orien[i][j] < 270.0:
            image_map[i, j, :] = green
        elif orien[i][j] >= 270.0 and orien[i][j] < 360.0:
            image_map[i, j, :] = yellow

# Display gradient orientation
f, ax1 = plt.subplots(1, 1, figsize=(20,10))

ax1.set_title('gradient orientation')
ax1.imshow(image_map)

哪个显示图片:

Orien

先谢谢了。

1 个答案:

答案 0 :(得分:1)

ddepth的{​​{1}}参数很重要。将其设置为-1,这意味着过滤后的图像将具有与输入相同的深度。 cv2.filter2D似乎是无符号整数(可能是uint8),因此过滤器输出也是如此。

由于您的过滤器可能会产生负值,因此它们会覆盖uint8。设置深度以从过滤器接收整个值范围:

gray_blur

现在,您过滤后的图像将编码一个方向,该方向将映射整个360度。

相关问题