网易首页 > 网易号 > 正文 申请入驻

详解图像锐化的Sobel、Laplacian算子

0
分享至

来源 | OSCHINA 社区

作者 | 华为云开发者联盟-eastmount

原文链接:https://my.oschina.net/u/4526289/blog/10108642

一.Sobel 算子

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

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

其像素计算公式如下:

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

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:Eastmount

import 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()

其运行结果如图 1 所示:

二.Laplacian 算子

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

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

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

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

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

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

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

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

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

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 算子进行图像锐化处理,其代码如下:

# -*- coding: utf-8 -*-

# By:Eastmount

import 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()

其运行结果如图 2 所示:

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

# -*- coding: utf-8 -*-

# By:Eastmount

import 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 算子考虑了综合因素,对噪声较多的图像处理效果更好。

三、总结

本文主要介绍图像锐化和边缘检测知识,详细讲解了 Sobel 算子和 Laplacian 算子,并通过小珞珞图像进行边缘轮廓提取。图像锐化和边缘提取技术可以消除图像中的噪声,提取图像信息中用来表征图像的一些变量,为图像识别提供基础。

参考文献:

  • [1] 冈萨雷斯著,阮秋琦译。数字图像处理(第 3 版)[M]. 北京:电子工业出版社,2013.

  • [2] 阮秋琦。数字图像处理学(第 3 版)[M]. 北京:电子工业出版社,2008.

  • [3] 杨秀璋,于小民,范郁锋,李娜。基于苗族服饰的图像锐化和边缘提取技术研究 [J]. 现代计算机,2018-10.

  • [4] Eastmount. [Python 图像处理] 四。图像平滑之均值滤波、方框滤波、高斯滤波及中值滤波 [EB/OL]. (2018-09-02). https://blog.csdn.net/Eastmount/article/details/82216380.

  • [5] Eastmount. [数字图像处理] 七.MFC 图像增强之图像普通平滑、高斯平滑、Laplacian、Sobel、Prewitt 锐化详解 [EB/OL]. (2015-06-08). https://blog.csdn.net/eastmount/article/ details/46378783.

  • [6] DSQiu. 图像锐化(增强)和边缘检测 [EB/OL]. (2012-08-20). https://dsqiu.iteye.com/blog/1638589.https://blog.csdn.net/poem_qianmo/article/details/23184547.

  • [7] C. Tomasi, R Manduchi. Bilateral Filtering for Gray and Color images[C]. Proceedings of the IEEE International Conference on Computer Vision, Bombay, India. 1998:839-846.

当人类情感遇上国产AI

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
市民在上海街边看到“好东西”售价仅35元,最后竟被迫支付了8700!还是假货!果断报警

市民在上海街边看到“好东西”售价仅35元,最后竟被迫支付了8700!还是假货!果断报警

环球网资讯
2026-05-12 14:30:58
奥迪 E7X 开启预售 限时28.98万元起

奥迪 E7X 开启预售 限时28.98万元起

华西都市报
2026-05-13 02:15:07
胖虎:有一次巴西队半场出现争执,安帅抽完烟后讲话平复众人

胖虎:有一次巴西队半场出现争执,安帅抽完烟后讲话平复众人

懂球帝
2026-05-13 08:57:18
75岁大爷与保姆生下儿子,做亲子鉴定后,大爷却被子女们气得心梗

75岁大爷与保姆生下儿子,做亲子鉴定后,大爷却被子女们气得心梗

黄家湖的忧伤
2025-03-06 09:30:21
中国政府奖学金留学人员抵达平壤,正式开启在朝留学生活

中国政府奖学金留学人员抵达平壤,正式开启在朝留学生活

大风新闻
2026-05-11 08:36:09
A·史密斯认为尼克斯队,是勒布朗·詹姆斯5亿美元合同的最佳选择

A·史密斯认为尼克斯队,是勒布朗·詹姆斯5亿美元合同的最佳选择

好火子
2026-05-13 00:41:17
今天上海局部有雨,最高31℃

今天上海局部有雨,最高31℃

鲁中晨报
2026-05-13 07:26:05
“不签20%分成协议,就不让招生、不给宣传”,深圳红立方被曝向商户索要利润分成

“不签20%分成协议,就不让招生、不给宣传”,深圳红立方被曝向商户索要利润分成

小陆搞笑日常
2026-05-13 00:12:34
1980年钟伟直呼毛主席大名,黄克诚举拐怒斥:你老小子真是忘了本

1980年钟伟直呼毛主席大名,黄克诚举拐怒斥:你老小子真是忘了本

史之铭
2026-05-12 20:53:20
死里逃生!U17国足时隔21年重返世界大赛,圆满晋级世少赛!

死里逃生!U17国足时隔21年重返世界大赛,圆满晋级世少赛!

田先生篮球
2026-05-13 09:29:30
奥巴梅扬拿灭火器狂喷高层遭弃用!马赛封闭集训变派对

奥巴梅扬拿灭火器狂喷高层遭弃用!马赛封闭集训变派对

仰卧撑FTUer
2026-05-12 18:18:06
伊朗北部发生地震 德黑兰震感明显

伊朗北部发生地震 德黑兰震感明显

财联社
2026-05-13 04:35:10
曾发涉港不当言论!NBA名记Shams:76人队解雇总经理莫雷

曾发涉港不当言论!NBA名记Shams:76人队解雇总经理莫雷

全景体育V
2026-05-13 08:14:35
法总统候选人梅朗雄放话:如果成功当选总统,法国将退出北约

法总统候选人梅朗雄放话:如果成功当选总统,法国将退出北约

上观新闻
2026-05-12 13:58:15
真怕黑色3分钟!国少最后阶段踢得太乱了 球迷:日本教练非蠢即坏

真怕黑色3分钟!国少最后阶段踢得太乱了 球迷:日本教练非蠢即坏

刀锋体育
2026-05-13 09:02:55
谁,在为俞浩的“表演”埋单?

谁,在为俞浩的“表演”埋单?

小蜜情感说
2026-05-12 16:06:53
皇马内乱不断,曼联酝酿重磅挖角巴尔韦德,夏窗强势出手

皇马内乱不断,曼联酝酿重磅挖角巴尔韦德,夏窗强势出手

夜白侃球
2026-05-13 09:35:03
手机号要变了:中国移动开了个头

手机号要变了:中国移动开了个头

林子说事
2026-05-12 18:37:55
看是御姐,脸还能打,肉却 “软趴趴” 了

看是御姐,脸还能打,肉却 “软趴趴” 了

飛娱日记
2026-03-13 11:31:29
十年前,易建联花1000万在洛杉矶买下豪宅,如今出售市值多少?

十年前,易建联花1000万在洛杉矶买下豪宅,如今出售市值多少?

小兰聊历史
2026-04-26 08:44:22
2026-05-13 10:04:49
开源中国 incentive-icons
开源中国
每天为开发者推送最新技术资讯
7731文章数 34540关注度
往期回顾 全部

科技要闻

谷歌剧透安卓重大升级 Gemini深度集成底层

头条要闻

牛弹琴:印度的大麻烦来了 CNN的报道更是触目惊心

头条要闻

牛弹琴:印度的大麻烦来了 CNN的报道更是触目惊心

体育要闻

骑士终于玩明白了?

娱乐要闻

白鹿风波升级!掉粉20万评论区沦陷

财经要闻

深圳夫妻囤芯片,身家飙涨320亿

汽车要闻

吉利银河“TT”申报图曝光 电动尾翼+激光雷达

态度原创

数码
本地
艺术
房产
公开课

数码要闻

三星电子计划在第四季度量产CXL 3.1内存模块

本地新闻

用苏绣的方式,打开江西婺源

艺术要闻

这位女摄影师的航拍风景照片,简直太美了!

房产要闻

穗八条引爆楼市!万博宝藏红盘,五一劲销出圈

公开课

李玫瑾:为什么性格比能力更重要?

无障碍浏览 进入关怀版