Python-OpenCV图像梯度算子

Sobel算子和Scharr算子

Sobel是高斯平滑与微分操作的结合体,所以它的抗噪声能力很好。OpenCV中提供:
cv2.Sobel(src,ddepth,dx,dy,dst=None,ksize=None,scale=None,delta=None,borderType=None)
注意:可以设定求导的方向(xorder或yorder),以及设定使用的卷积核的大小(ksize)。同时,如果ksize=-1,会默认使用Scharr滤波器,它的效果比你3×3的Sobel滤波器好(而且速度相同,所以在使用3×3滤波器时应该尽量使用Scharr滤波器)。

Laplacian算子

拉普拉斯算子可以用二阶导数的形式定义,假设其离散实现类似于二阶Sobel导数,事实上,OpenCV在计算拉普拉斯算子时直接调用Sobel算子。

实例:

import cv2
import numpy as np
import matplotlib.pyplot as plt

img=cv2.imread('pitt1.jpg',0)

laplacian=cv2.Laplacian(img,cv2.CV_64F,ksize=11)

sobelx=cv2.Sobel(img,cv2.CV_64F,1,0,ksize=11)
sobely=cv2.Sobel(img,cv2.CV_64F,0,1,ksize=11)


plt.subplot(2,2,1),plt.imshow(img,cmap = 'gray')
plt.title('Original'), plt.xticks([]), plt.yticks([])
plt.subplot(2,2,2),plt.imshow(laplacian,cmap = 'gray')
plt.title('Laplacian'), plt.xticks([]), plt.yticks([])
plt.subplot(2,2,3),plt.imshow(sobelx,cmap = 'gray')
plt.title('Sobel X'), plt.xticks([]), plt.yticks([])
plt.subplot(2,2,4),plt.imshow(sobely,cmap = 'gray')
plt.title('Sobel Y'), plt.xticks([]), plt.yticks([])
plt.show()

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值