【发布时间】:2021-10-18 13:41:10
【问题描述】:
背景
因此,我目前正在开展一个项目,该项目是编码火车傅立叶变换系列的扩展。非常感谢他启发了这个项目!
在观看了他关于编码火车徽标的傅立叶变换的视频后,我认为尝试为任何图像实现这一点会很有趣。我的目标是能够将任何图像中的主体轮廓作为 DFT 算法的连续路径输入,这样我就可以可视化所述路径的傅里叶变换。
编码火车视频链接:https://www.youtube.com/watch?v=MY4luNgGfms
我的进步
到目前为止,在 python 中使用 opencv,我已经实现了一种算法,可以从任何图像中检测主体的轮廓并显示出来。我附上了一个示例输出。
我的问题和预期结果
现在我已经完成了边缘,我希望能够将该边缘提取为由 (x,y) 坐标表示的连续路径。我需要它作为连续路径的原因是我要在这条路径上执行 DFT,如果它不连续,我的 DFT 可视化就会失败。
我不知道如何对点进行排序,以便它们不会从左到右或从上到下跳跃,而是从左到右遵循平滑的连续路径,反之亦然。
我是计算机视觉的初学者,我真的希望有人可以帮助我!如果我在某个地方搞砸了,或者我是否可以让我的代码变得更好,请随时告诉我。我真的很想学习。
代码
这是我目前的代码
img = cv2.imread("Images/selfietest.jpeg")
# convert image to gray scale
gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
height, width = gray_img.shape
# white_padding = np.zeros((50, width, 3))
# white_padding[:, :] = [255, 255, 255]
# rgb_img = np.row_stack((white_padding, imgOut))
gray_img = 255 - gray_img
gray_img[gray_img > 100] = 255
gray_img[gray_img <= 100] = 0
# black_padding = np.zeros((50, width))
# gray_img = np.row_stack((black_padding, gray_img))
kernel = np.ones((30, 30), np.uint8)
# fill inside of image
filledImage = cv2.morphologyEx(gray_img, cv2.MORPH_CLOSE, kernel)
filledImageNormalized = np.uint8(filledImage)
#Canny edge detection
edges = cv2.Canny(filledImageNormalized, 100, 200)
title = ['edges']
images = [edges]
for i in range(1):
plt.subplot(1, 1, i + 1), plt.imshow(images[i], 'gray')
plt.title(title[i])
plt.xticks([])
plt.yticks([])
plt.show()```
【问题讨论】:
标签: python opencv path dft canny-operator