当前位置:   article > 正文

OpenCV--cv2.Canny()边缘检测

cv2.canny

 在进行边缘之前需要对图像进行模糊处理。OpenCV提供的模糊滤波函数,如blur(),medianBlur()以及GaussianBlur(),其中GaussianBlur()在下面链接有介绍。

http://opencv-python-cv2.GaussianBlur()函数介绍_weixin_52012241的博客-CSDN博客

边缘检测

语法定义如下:

edge = cv2.Canny(image, threshold1, threshold2[, edges[, apertureSize[, L2gradient ]]]) 

image:要检测的图像
threshold1:阈值1(最小值)
threshold2:阈值2(最大值),使用此参数进行明显的边缘检测
edges:图像边缘信息
apertureSize:sobel算子(卷积核)大小
L2gradient :布尔值。
True: 使用更精确的L2范数进行计算(即两个方向的导数的平方和再开方)
False:使用L1范数(直接将两个方向导数的绝对值相加)

Canny边缘检测算法可以分为以下5个步骤:

1)        使用高斯滤波器,以平滑图像,滤除噪声。

2)        计算图像中每个像素点的梯度强度和方向。

3)        应用非极大值(Non-Maximum Suppression)抑制,以消除边缘检测带来的杂散响应。

4)        应用双阈值(Double-Threshold)检测来确定真实的和潜在的边缘。

5)        分析所有的边缘及其之间的连接,以保留真正的边缘并消除不明显的边缘。

目录

1、阈值对检测结果的影响

2、sobel算子对检测结果的影响

3、范数对检测结果的影响

原始图像

1、阈值对检测结果的影响

  1. img=cv2.imread('./12.jpg')
  2. img = cv2.resize(img, None, fx=0.5, fy=0.5,
  3. interpolation=cv2.INTER_CUBIC)#调整图片大小
  4. r1=cv2.Canny(img,128,200)
  5. r2=cv2.Canny(img,0, 50)
  6. cv2.imshow("original",img)
  7. cv2.imshow("result1",r1)
  8. cv2.imshow("result2",r2)
  9. cv2.imwrite("result1.jpg",r1)
  10. cv2.imwrite("result2.jpg",r2)
  11. cv2.waitKey()
  12. cv2.destroyAllWindows()

 左边是原图,中间是result1,右边是result2,如图的结果可知:阈值越小会获得更多的细节,提取图像更多边缘。

2、sobel算子对检测结果的影响

  1. img=cv2.imread('./12.jpg')
  2. img = cv2.resize(img, None, fx=0.5, fy=0.5,
  3. interpolation=cv2.INTER_CUBIC)#调整图片大小
  4. r1=cv2.Canny(img,128,200,apertureSize=3)
  5. r2=cv2.Canny(img,128,200,apertureSize=5)
  6. cv2.imshow("original",img)
  7. cv2.imshow("result1",r1)
  8. cv2.imshow("result2",r2)
  9. cv2.imwrite("result1.jpg",r1)
  10. cv2.imwrite("result2.jpg",r2)
  11. cv2.waitKey()
  12. cv2.destroyAllWindows()

左边是原图,中间是result1,右边是result2,如图的结果可知:增大算子,会获得更多的细节,提取图像更多边缘。

3、范数对检测结果的影响

  1. img=cv2.imread('./12.jpg')
  2. img = cv2.resize(img, None, fx=0.5, fy=0.5,
  3. interpolation=cv2.INTER_CUBIC)#调整图片大小
  4. r1=cv2.Canny(img,128,200,L2gradient=False)
  5. r2=cv2.Canny(img,128,200,L2gradient=True)
  6. cv2.imshow("original",img)
  7. cv2.imshow("result1",r1)
  8. cv2.imshow("result2",r2)
  9. cv2.imwrite("result1.jpg",r1)
  10. cv2.imwrite("result2.jpg",r2)
  11. cv2.waitKey()
  12. cv2.destroyAllWindows()

左边是原图,中间是result1,右边是result2,如图的结果可知:L2gradient=True时,检测出的边缘减少了

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/173438
推荐阅读
相关标签
  

闽ICP备14008679号