python-opencv-图像边缘检测Sobel算子

Sobel算子对噪声具有平滑作用,提供较为精确的边缘方向信息,边缘定位精度不够高。当对精度要求不是很高时,是一种较为常用的边缘检测方法。 

import cv2

image = cv2.imread("wuhuan.jpg",1)
cv2.imshow('yuan',image)
image_x=cv2.Sobel(image,cv2.CV_64F,1,0,ksize=3)  #X方向Sobel
'''
参数2 ddepth:必选参数。表示输出图像的深度,-1表示采用的是与原图像相同的深度。目标图像的深度必须大于等于原图像的深度
参数3和参数4 dx和dy表示的是求导的阶数,0表示这个方向上没有求导,一般为0、1、2
参数6 ksize:可选参数。用于设置内核大小,即Sobel算子的矩阵大小,值必须是1、3、5、7,默认为3。
'''
absX=cv2.convertScaleAbs(image_x)   # 转回uint8
cv2.imshow("absX",absX)

image_y=cv2.Sobel(image,cv2.CV_64F,0,1,ksize=3)  #Y方向Sobel
absY=cv2.convertScaleAbs(image_y)
cv2.imshow('absY',absY)

#进行权重融合
dst=cv2.addWeighted(absX,0.5,absY,0.5,0)
cv2.imshow('dst',dst)

#cv2.imshow("dst",dst)
cv2.waitKey()

 

 

 

 

posted @ 2020-01-31 09:37  天子骄龙  阅读(4042)  评论(0编辑  收藏  举报