返回顶部
首页 > 资讯 > 后端开发 > Python >Python Sobel与Laplacian算子怎么使用
  • 431
分享到

Python Sobel与Laplacian算子怎么使用

2023-07-04 20:07:25 431人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要介绍“python Sobel与Laplacian算子怎么使用”,在日常操作中,相信很多人在Python Sobel与Laplacian算子怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”P

这篇文章主要介绍“python Sobel与Laplacian算子怎么使用”,在日常操作中,相信很多人在Python Sobel与Laplacian算子怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python Sobel与Laplacian算子怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一.Sobel算子

Sobel算子是一种用于边缘检测的离散微分算子,它结合了高斯平滑和微分求导。该算子用于计算图像明暗程度近似值,根据图像边缘旁边明暗程度把该区域内超过某个数的特定点记为边缘。Sobel算子在Prewitt算子的基础上增加了权重的概念,认为相邻点的距离远近对当前像素点的影响是不同的,距离越近的像素点对应当前像素的影响越大,从而实现图像锐化并突出边缘轮廓[1-4]。

Sobel算子的边缘定位更准确,常用于噪声较多、灰度渐变的图像。其算法模板如公式(1)所示,其中dx表示水平方向,dy表示垂直方向[3]。

Python Sobel与Laplacian算子怎么使用

其像素计算公式如下:

Python Sobel与Laplacian算子怎么使用

Sobel算子像素的最终计算公式如下:

Python Sobel与Laplacian算子怎么使用

Sobel算子根据像素点上下、左右邻点灰度加权差,在边缘处达到极值这一现象检测边缘。对噪声具有平滑作用,提供较为精确的边缘方向信息。因为Sobel算子结合了高斯平滑和微分求导(分化),因此结果会具有更多的抗噪性,当对精度要求不是很高时,Sobel算子是一种较为常用的边缘检测方法。

Python和OpenCV将Sobel算子封装在Sobel()函数中,其函数原型如下所示:

dst = Sobel(src, ddepth, dx, dy[, dst[, ksize[, scale[, delta[, borderType]]]]])

  • – src表示输入图像

  • – dst表示输出的边缘图,其大小和通道数与输入图像相同

  • – ddepth表示目标图像所需的深度,针对不同的输入图像,输出目标图像有不同的深度

  • – dx表示x方向上的差分阶数,取值1或 0

  • – dy表示y方向上的差分阶数,取值1或0

  • – ksize表示Sobel算子的大小,其值必须是正数和奇数

  • – scale表示缩放导数的比例常数,默认情况下没有伸缩系数

  • – delta表示将结果存入目标图像之前,添加到结果中的可选增量值

  • – borderType表示边框模式,更多详细信息查阅BorderTypes

注意,在进行Sobel算子处理之后,还需要调用convertScaleAbs()函数计算绝对值,并将图像转换为8位图进行显示。其算法原型如下:

dst = convertScaleAbs(src[, dst[, alpha[, beta]]])

  • – src表示原数组

  • – dst表示输出数组,深度为8位

  • – alpha表示比例因子

  • – beta表示原数组元素按比例缩放后添加的值

Sobel算子的实现代码如下所示。

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  import matplotlib.pyplot as plt #读取图像img = cv2.imread('luo.png')lenna_img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)#灰度化处理图像grayImage = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) #Sobel算子x = cv2.Sobel(grayImage, cv2.CV_16S, 1, 0) #对x求一阶导y = cv2.Sobel(grayImage, cv2.CV_16S, 0, 1) #对y求一阶导absX = cv2.convertScaleAbs(x)      absY = cv2.convertScaleAbs(y)    Sobel = cv2.addWeighted(absX, 0.5, absY, 0.5, 0)#用来正常显示中文标签plt.rcParams['font.sans-serif']=['SimHei']#显示图形titles = ['原始图像', 'Sobel算子']images = [lenna_img, Sobel]for i in range(2):   plt.subplot(1,2,i+1), plt.imshow(images[i], 'gray')   plt.title(titles[i])   plt.xticks([]),plt.yticks([])plt.show()

二.Laplacian算子

拉普拉斯(Laplacian)算子是n维欧几里德空间中的一个二阶微分算子,常用于图像增强领域和边缘提取。它通过灰度差分计算邻域内的像素,基本流程是:

  • 判断图像中心像素灰度值与它周围其他像素的灰度值;

  • 如果中心像素的灰度更高,则提升中心像素的灰度;

  • 反之降低中心像素的灰度,从而实现图像锐化操作。

在算法实现过程中,Laplacian算子通过对邻域中心像素的四方向或八方向求梯度,再将梯度相加起来判断中心像素灰度与邻域内其他像素灰度的关系,最后通过梯度运算的结果对像素灰度进行调整[2]。

一个连续的二元函数f(x,y),其拉普拉斯运算定义为:

Python Sobel与Laplacian算子怎么使用

Laplacian算子分为四邻域和八邻域,四邻域是对邻域中心像素的四方向求梯度,八邻域是对八方向求梯度。其中,四邻域模板如公式(5)所示:

Python Sobel与Laplacian算子怎么使用

其像素的计算公式可以简化为:

Python Sobel与Laplacian算子怎么使用

通过模板可以发现,当邻域内像素灰度相同时,模板的卷积运算结果为0;当中心像素灰度高于邻域内其他像素的平均灰度时,模板的卷积运算结果为正数;当中心像素的灰度低于邻域内其他像素的平均灰度时,模板的卷积为负数。对卷积运算的结果用适当的衰弱因子处理并加在原中心像素上,就可以实现图像的锐化处理。

Laplacian算子的八邻域模板如下:

Python Sobel与Laplacian算子怎么使用

其像素的计算公式可以简化为:

Python Sobel与Laplacian算子怎么使用

Python和OpenCV将Laplacian算子封装在Laplacian()函数中,其函数原型如下所示:

dst = Laplacian(src, ddepth[, dst[, ksize[, scale[, delta[, borderType]]]]])

  • – src表示输入图像

  • – dst表示输出的边缘图,其大小和通道数与输入图像相同

  • – ddepth表示目标图像所需的深度

  • – ksize表示用于计算二阶导数的滤波器的孔径大小,其值必须是正数和奇数,且默认值为1,更多详细信息查阅getDerivKernels

  • – scale表示计算拉普拉斯算子值的可选比例因子。默认值为1,更多详细信息查阅getDerivKernels

  • – delta表示将结果存入目标图像之前,添加到结果中的可选增量值,默认值为0

  • – borderType表示边框模式,更多详细信息查阅BorderTypes

注意,Laplacian算子其实主要是利用Sobel算子的运算,通过加上Sobel算子运算出的图像x方向和y方向上的导数,得到输入图像的图像锐化结果。

同时,在进行Laplacian算子处理之后,还需要调用convertScaleAbs()函数计算绝对值,并将图像转换为8位图进行显示。其算法原型如下:

dst = convertScaleAbs(src[, dst[, alpha[, beta]]])

  • – src表示原数组

  • – dst表示输出数组,深度为8位

  • – alpha表示比例因子

  • – beta表示原数组元素按比例缩放后添加的值

当ksize=1时,Laplacian()函数采用3×3的孔径(四邻域模板)进行变换处理。下面的代码是采用ksize=3的Laplacian算子进行图像锐化处理,其代码如下:

其运行结果如图2所示:

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  import matplotlib.pyplot as plt #读取图像img = cv2.imread('luo.png')lenna_img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)#灰度化处理图像grayImage = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) #拉普拉斯算法dst = cv2.Laplacian(grayImage, cv2.CV_16S, ksize = 3)Laplacian = cv2.convertScaleAbs(dst) #用来正常显示中文标签plt.rcParams['font.sans-serif']=['SimHei']#显示图形titles = ['原始图像', 'Laplacian算子']  images = [lenna_img, Laplacian]  for i in range(2):     plt.subplot(1,2,i+1), plt.imshow(images[i], 'gray')     plt.title(titles[i])     plt.xticks([]),plt.yticks([])  plt.show()

边缘检测算法主要是基于图像强度的一阶和二阶导数,但导数通常对噪声很敏感,因此需要采用滤波器来过滤噪声,并调用图像增强或阈值化算法进行处理,最后再进行边缘检测。下面是采用高斯滤波去噪和阈值化处理之后,再进行边缘检测的过程,并对比了四种常见的边缘提取算法。

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  import matplotlib.pyplot as plt#读取图像img = cv2.imread('luo.png')lenna_img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)#灰度化处理图像grayImage = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)#高斯滤波gaussianBlur = cv2.GaussianBlur(grayImage, (3,3), 0)#阈值处理ret, binary = cv2.threshold(gaussianBlur, 127, 255, cv2.THRESH_BINARY)#Roberts算子kernelx = np.array([[-1,0],[0,1]], dtype=int)kernely = np.array([[0,-1],[1,0]], dtype=int)x = cv2.filter2D(binary, cv2.CV_16S, kernelx)y = cv2.filter2D(binary, cv2.CV_16S, kernely)absX = cv2.convertScaleAbs(x)     absY = cv2.convertScaleAbs(y)    Roberts = cv2.addWeighted(absX, 0.5, absY, 0.5, 0)#Prewitt算子kernelx = np.array([[1,1,1],[0,0,0],[-1,-1,-1]], dtype=int)kernely = np.array([[-1,0,1],[-1,0,1],[-1,0,1]], dtype=int)x = cv2.filter2D(binary, cv2.CV_16S, kernelx)y = cv2.filter2D(binary, cv2.CV_16S, kernely)absX = cv2.convertScaleAbs(x)  absY = cv2.convertScaleAbs(y)    Prewitt = cv2.addWeighted(absX,0.5,absY,0.5,0)#Sobel算子x = cv2.Sobel(binary, cv2.CV_16S, 1, 0)y = cv2.Sobel(binary, cv2.CV_16S, 0, 1)    absX = cv2.convertScaleAbs(x)   absY = cv2.convertScaleAbs(y)    Sobel = cv2.addWeighted(absX, 0.5, absY, 0.5, 0)#拉普拉斯算法dst = cv2.Laplacian(binary, cv2.CV_16S, ksize = 3)Laplacian = cv2.convertScaleAbs(dst) #效果图titles = ['Source Image', 'Binary Image', 'Roberts Image',          'Prewitt Image','Sobel Image', 'Laplacian Image']images = [lenna_img, binary, Roberts, Prewitt, Sobel, Laplacian]for i in np.arange(6):   plt.subplot(2,3,i+1),plt.imshow(images[i],'gray')   plt.title(titles[i])   plt.xticks([]),plt.yticks([])plt.show()

输出结果如图3所示。其中,Laplacian算子对噪声比较敏感,由于其算法可能会出现双像素边界,常用来判断边缘像素位于图像的明区或暗区,很少用于边缘检测;Robert算子对陡峭的低噪声图像效果较好,尤其是边缘正负45度较多的图像,但定位准确率较差;Prewitt算子对灰度渐变的图像边缘提取效果较好,而没有考虑相邻点的距离远近对当前像素点的影响;Sobel算子考虑了综合因素,对噪声较多的图像处理效果更好。

Python Sobel与Laplacian算子怎么使用

到此,关于“Python Sobel与Laplacian算子怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: Python Sobel与Laplacian算子怎么使用

本文链接: https://lsjlt.com/news/347230.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python Sobel与Laplacian算子怎么使用
    这篇文章主要介绍“Python Sobel与Laplacian算子怎么使用”,在日常操作中,相信很多人在Python Sobel与Laplacian算子怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”P...
    99+
    2023-07-04
  • python中Laplacian算子怎么使用
    本篇内容介绍了“python中Laplacian算子怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!说明Laplacian算子通过对邻...
    99+
    2023-06-20
  • Python图像锐化与边缘检测之Sobel与Laplacian算子详解
    目录一.Sobel算子二.Laplacian算子三.总结一.Sobel算子 Sobel算子是一种用于边缘检测的离散微分算子,它结合了高斯平滑和微分求导。该算子用于计算图像明暗程度近似...
    99+
    2022-12-19
    Python Sobel Laplacian Python Sobel Python Laplacian Python图像锐化 Python边缘检测
  • python中的Sobel算子如何使用
    本篇内容主要讲解“python中的Sobel算子如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python中的Sobel算子如何使用”吧!说明Sobel算子根据像素点的上下、左右相邻点的...
    99+
    2023-06-20
  • python中什么是Laplacian算子
    这期内容当中小编将会给大家带来有关python中什么是Laplacian算子,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。说明Laplacian算子是n维欧几里德空间的二阶微分算子,常用于图像增强领域和边...
    99+
    2023-06-20
  • python中什么是Sobel算子
    python中什么是Sobel算子,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。说明Sobel算子的中文名称是索贝尔算子,是一种用于边缘检测的离散微分算子,它结合了高斯平滑和微...
    99+
    2023-06-20
  • Python量化因子测算与绘图的代码怎么写
    这篇“Python量化因子测算与绘图的代码怎么写”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python量化因子测算与绘图...
    99+
    2023-07-05
  • python怎么实现五子棋算法
    本文小编为大家详细介绍“python怎么实现五子棋算法”,内容详细,步骤清晰,细节处理妥当,希望这篇“python怎么实现五子棋算法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。if (j+4<n...
    99+
    2023-06-30
  • OpenCV图像梯度算子方法怎么使用
    本篇内容介绍了“OpenCV图像梯度算子方法怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.Sobel算子Sobel算子是一种图像...
    99+
    2023-07-05
  • 怎么使用Python运算符
    本篇内容介绍了“怎么使用Python运算符”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Python语言支持很多种运算符,我们先用一个表格为...
    99+
    2023-06-01
  • 怎么使用Python位运算
    本篇内容主要讲解“怎么使用Python位运算”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用Python位运算”吧!判断奇数还是偶数通常判断奇数还是偶数我们想到的办法就是除以2,看余数是否...
    99+
    2023-06-02
  • Python dHash算法怎么使用
    这篇文章主要介绍“Python dHash算法怎么使用”,在日常操作中,相信很多人在Python dHash算法怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python dHash算法怎么使用”的疑...
    99+
    2023-06-30
  • python使用ProjectQ生成量子算法指令集
    目录输出算法操作封装的操作含时演化算符的分解QFT的分解总结概要输出算法操作 首先介绍一个最基本的使用方法,就是使用ProjectQ来打印量子算法中所输入的量子门操作,这里使用到了ProjectQ中的DummyEn...
    99+
    2022-06-02
    python ProjectQ python 量子算法指令集
  • 怎么使用Python贪心算法
    这篇文章主要介绍“怎么使用Python贪心算法”,在日常操作中,相信很多人在怎么使用Python贪心算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Python贪心算法”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-16
  • 怎么使用Python退火算法
    本篇内容介绍了“怎么使用Python退火算法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  一、简介  退火算法不言而喻,就是钢铁在淬炼过...
    99+
    2023-06-01
  • 怎么使用Python的运算符
    这篇文章主要介绍“怎么使用Python的运算符”,在日常操作中,相信很多人在怎么使用Python的运算符问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Python的运算符”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-01
  • python比较运算怎么使用
    这篇文章主要介绍“python比较运算怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python比较运算怎么使用”文章能帮助大家解决问题。说明除数值操作外,整数型和浮点型还可以进行比较操作,...
    99+
    2023-06-30
  • Python中的鸭子类型和猴子补丁怎么使用
    本篇内容主要讲解“Python中的鸭子类型和猴子补丁怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python中的鸭子类型和猴子补丁怎么使用”吧!鸭子类型引用维基百科中的一段解释:鸭子类...
    99+
    2023-07-06
  • python的运算符与表达式怎么用
    这篇文章主要为大家展示了“python的运算符与表达式怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python的运算符与表达式怎么用”这篇文章吧。表达式什么是表达式?# •&n...
    99+
    2023-06-26
  • 怎么在Python中使用dHash算法
    这篇文章将为大家详细讲解有关怎么在Python中使用dHash算法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python主要应用领域有哪些1、云计算,典型应用OpenStack。2、WE...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作