栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

python CV学习6:边缘检测

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

python CV学习6:边缘检测

1 什么是边缘?

边缘是图像强度函数快速变化的地方

2 如何检测边缘?

为了检测边缘,我们需要检测图像中的不连续性,可以使用导数来检测不连续性。

3 图像梯度

 梯度就是X方向的箭头和Y方向的箭头的和。假设某一点上,x的偏导数为3,y的偏导数为-1,则该点的梯度就是(3,-1)

 4 Sobel算子

x和y方向的Sobel算子分别为:

 拿下图举例

img=cv2.imread('src/noise0.jpg',cv2.IMREAD_GRAYSCALE)


sobel_x1=cv2.Sobel(img,cv2.CV_64F,1,0,ksize=3)
sobel_x2=cv2.convertScaleAbs(sobel_x1)

sobel_y1=cv2.Sobel(img,cv2.CV_64F,0,1,ksize=3)
sobel_y2=cv2.convertScaleAbs(sobel_y1)

sobel_xy1=cv2.addWeighted(sobel_x2,0.5,sobel_y2,0.5,0)
sobel_xy2=cv2.convertScaleAbs(sobel_xy1)

cv2.imshow('origin',img) 

cv2.imshow('sobel_x',sobel_x1)    
cv2.imshow('sobel_x & ScaleAbs',sobel_x2) 

cv2.imshow('sobel_y',sobel_y1)  
cv2.imshow('sobel_y & ScaleAbs',sobel_y2)    

cv2.imshow('sobel_xy',sobel_xy1) 
cv2.imshow('sobel_xy & ScaleAbs',sobel_xy2) 

cv2.waitKey(0)        
cv2.destroyAllWindows()

 

5 Canny边缘检测

在目前常用的边缘检测方法中,Canny边缘检测算法是具有严格定义的,可以提供良好可靠检测的方法之一。由于它具有满足边缘检测的三个标准和实现过程简单的优势,成为边缘检测最流行的算法之一。

完成一个Canny边缘检测算法可以分为以下四步:

高斯滤波目的
1.高斯滤波去噪声降低错误率
2.计算梯度幅值和方向估计每一点处的边缘强度与方向
3.非极大值抑制(NMS)对Sobel、Prewitt等算子的结果进一步细化
4应用双阈值(Double-Threshold)检测确定真实的和可能的边缘。

 还是使用上图

img = cv2.imread("src/noise0.jpg", 0)  # 由于Canny只能处理灰度图,所以将读取的图像转成灰度图
 
img1 = cv2.GaussianBlur(img,(3,3),0) # 用高斯平滑处理原图像降噪。若效果不好可调节高斯核大小
 
canny = cv2.Canny(img1, 80, 100)     # 调用Canny函数,指定最大和最小阈值,其中apertureSize默认为3。
 
cv2.imshow('Canny', canny)
 
cv2.waitKey(0)
 
cv2.destroyAllWindows()

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/268917.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号