opencv python图像梯度实例详解
这篇文章主要介绍了opencvpython图像梯度实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
一阶导数与Soble算子
二阶导数与拉普拉斯算子
图像边缘:
Soble算子:
二阶导数:
拉普拉斯算子:
importcv2ascv importnumpyasnp #图像梯度(由x,y方向上的偏导数和偏移构成),有一阶导数(sobel算子)和二阶导数(Laplace算子) #用于求解图像边缘,一阶的极大值,二阶的零点 #一阶偏导在图像中为一阶差分,再变成算子(即权值)与图像像素值乘积相加,二阶同理 defsobel_demo(image): grad_x=cv.Sobel(image,cv.CV_32F,1,0)#采用Scharr边缘更突出 grad_y=cv.Sobel(image,cv.CV_32F,0,1) gradx=cv.convertScaleAbs(grad_x)#由于算完的图像有正有负,所以对其取绝对值 grady=cv.convertScaleAbs(grad_y) #计算两个图像的权值和,dst=src1*alpha+src2*beta+gamma gradxy=cv.addWeighted(gradx,0.5,grady,0.5,0) cv.imshow("gradx",gradx) cv.imshow("grady",grady) cv.imshow("gradient",gradxy) deflaplace_demo(image):#二阶导数,边缘更细 dst=cv.Laplacian(image,cv.CV_32F) lpls=cv.convertScaleAbs(dst) cv.imshow("laplace_demo",lpls) defcustom_laplace(image): #以下算子与上面的Laplace_demo()是一样的,增强采用np.array([[1,1,1],[1,-8,1],[1,1,1]]) kernel=np.array([[1,1,1],[1,-8,1],[1,1,1]]) dst=cv.filter2D(image,cv.CV_32F,kernel=kernel) lpls=cv.convertScaleAbs(dst) cv.imshow("custom_laplace",lpls) defmain(): src=cv.imread("../images/lena.jpg") cv.imshow("lena",src) #sobel_demo(src) laplace_demo(src) custom_laplace(src) cv.waitKey(0)#等有键输入或者1000ms后自动将窗口消除,0表示只用键输入结束窗口 cv.destroyAllWindows()#关闭所有窗口 if__name__=='__main__': main()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。