我正在尝试使用 perwit 内核进行边缘检测。
我的问题是,当我尝试将水平渐变与垂直渐变“合并”时,因为之后我在 cv2.imshow() 函数中收到错误,看起来图像有变形。
这是我的代码
imgx = filter_image(img,kx,3)
imgy = filter_image(img,ky,3)
img_edge = np.sqrt(np.power(imgx, 2) + np.power(imgy, 2))
img_edge = (img_edge / np.max(img_edge)) * 255
print(np.shape(img_edge))
print(np.min(img_edge))
print(np.max(img_edge))
cv2.imshow('imagey',img_edge)
这是我的输出
(256, 256)
0.0
255.0
Traceback (most recent call last):
File "<ipython-input-17-c200db56adba>", line 1, in <module>
runfile('C:/Users/giorg/Desktop/Elte/Image Analysis/Lab 1/filter.py', wdir='C:/Users/giorg/Desktop/Elte/Image Analysis/Lab 1')
File "C:\Users\giorg\Anaconda3\lib\site-packages\spyder_kernels\customize\spydercustomize.py", line 827, in runfile
execfile(filename, namespace)
File "C:\Users\giorg\Anaconda3\lib\site-packages\spyder_kernels\customize\spydercustomize.py", line 110, in execfile
exec(compile(f.read(), filename, 'exec'), namespace)
File "C:/Users/giorg/Desktop/Elte/Image Analysis/Lab 1/filter.py", line 58, in <module>
cv2.imshow('imagey',img_edge)
TypeError: Expected Ptr<cv::UMat> for argument 'mat'
我不知道为什么,但我认为问题出在 np.sqrt() 上。如果我对 imgy 和 imgx 进行简单的求和,它就会起作用。
精慕HU
相关分类