详解Python中图像边缘检测算法的实现

作者:Mr.Winter` 时间:2021-02-08 09:18:27 

写在前面

从本节开始,计算机视觉教程进入第三章节——图像特征提取。在本章,你会见到一张简简单单的图片中蕴含着这么多你没注意到的细节特征,而这些特征将会在今后更高级的应用中发挥着极其重要的作用。本文讲解基础特征之一——图像边缘。

本文采用面向对象设计,定义了一个边缘检测类EdgeDetect,使图像边缘检测算法的应用更简洁,例如

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

Detector = EdgeDetect('1.jpg')
Prewitt = Detector.prewitt()
plt.imshow(Prewitt , 'gray')
plt.show()

这个类的构造函数为

class EdgeDetect:
   def __init__(self, img) -> None:
       self.src = cv2.imread(img)
       self.gray = cv2.cvtColor(self.src, cv2.COLOR_BGR2GRAY)

读取的是图像的基本信息。

1.一阶微分算子

图像边缘是数字图像的高频成分,对应图像梯度的极值。在二维离散数字图像上,某个方向上图像强度函数微分使用有限差分法来近似,即:

详解Python中图像边缘检测算法的实现

因此图像边缘检测即是对图像的差分运算。

1.1 Prewitt算子

Prewitt算子本质上就是x或y方向上相邻像素的差分。

详解Python中图像边缘检测算法的实现

那我们常说的图像梯度是什么意思呢?

其实就是用x与y方向上相邻像素的差分为方向的向量

详解Python中图像边缘检测算法的实现

在编程实现上,就是构造上图的两个方向的滤波算子,然后将x xx、y yy两个方向的边缘合成就是整张图各方向的边缘检测结果

def prewitt(self):
   # 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(self.gray, cv2.CV_16S, kernelX)
   y = cv2.filter2D(self.gray, cv2.CV_16S, kernelY)
   # 转 uint8 ,图像融合
   absX = cv2.convertScaleAbs(x)
   absY = cv2.convertScaleAbs(y)
   return cv2.addWeighted(absX, 0.5, absY, 0.5, 0)

详解Python中图像边缘检测算法的实现

1.2 Sobel算子

对高斯核函数x、y方向求导,并将其模板化即得Sobel算子。Sobel算子相比于Prewitt算子有更强的抗噪能力,因为其结合了高斯滤波的效果。

详解Python中图像边缘检测算法的实现

在编程实现上,就是构造上图的两个方向的滤波算子,然后将x、y两个方向的边缘合成就是整张图各方向的边缘检测结果

def sobel(self):
   # Sobel 算子
   kernelX = np.array([[1, 2, 1],[0, 0, 0],[-1, -2, -1]],dtype=int)
   kernelY = np.array([[-1, -2, -1],[0, 0, 0],[1, 2, 1]],dtype=int)
   # 对图像滤波
   x = cv2.filter2D(self.gray, cv2.CV_16S, kernelX)
   y = cv2.filter2D(self.gray, cv2.CV_16S, kernelY)
   # 转 uint8 ,图像融合
   absX = cv2.convertScaleAbs(x)
   absY = cv2.convertScaleAbs(y)
   return cv2.addWeighted(absX, 0.5, absY, 0.5, 0)

详解Python中图像边缘检测算法的实现

2.二阶微分算子

2.1 Laplace算子

将Laplace算子

详解Python中图像边缘检测算法的实现

写成差分方程形式为

详解Python中图像边缘检测算法的实现

将差分方程进一步写成卷积核形式如图(a),可将其扩展为图(b)使之具有各向同性。微分算子属于高通滤波,在锐化边缘的同时也增强了噪点,因此Laplace算子抗噪能力弱,且不能检测边缘方向。

详解Python中图像边缘检测算法的实现

在编程实现上,就是构造上图的滤波算子

# Laplace 算子
def laplace(self):
   kernel = np.array([[0, -1, 0], [-1, 4, -1], [0, -1, 0]], dtype=int)
   img = cv2.filter2D(self.gray, cv2.CV_16S, kernel)
   return cv2.convertScaleAbs(img)

详解Python中图像边缘检测算法的实现

2.2 LoG算子

为克服Laplace算子抗噪能力弱这一问题,引入高斯-拉普拉斯算子(LoG, Laplace of Gaussian),即先低通滤除噪声,再高通强化边缘,LoG算子本质上是带通滤波器。

详解Python中图像边缘检测算法的实现

在编程实现上,就是构造上图的滤波算子

# LoG算子
def LoG(self):
   kernel = np.array([[0, 0, 1, 0, 0], [0, 1, 2, 1, 0], [1, 2, -16, 2, 1], [0, 1, 2, 1, 0], [0, 0, 1, 0, 0]], dtype=int)
   img = cv2.filter2D(self.gray, cv2.CV_16S, kernel)
   return cv2.convertScaleAbs(img)

详解Python中图像边缘检测算法的实现

3.Canny边缘检测

Canny边缘检测算法可以分为以下步骤。

  • 使用Sobel算子滤除原图像噪声,并得到梯度图;

  • 应用非极大值抑制(Non-Maximum Suppression, NMS)以消除边缘检测、目标检测带来的杂散响应,即对待测边缘或目标,应尽可能有唯一的准确响应

  • 应用双阈值(Double-Threshold)检测来确定真实的和潜在的边缘。

使用如下双阈值检测算法解决因噪声引起的杂散边缘响应。

详解Python中图像边缘检测算法的实现

阈值的选择取决于给定输入图像的内容。下面对弱边缘进一步审查,即

详解Python中图像边缘检测算法的实现

通常,由真实边缘引起的弱边缘像素将连接到强边缘像素,而噪声响应未连接。为了跟踪边缘连接,通过查看弱边缘像素的8个邻域像素是否存在强边缘像素,来决定是否滤除该弱边缘点。

下面是Canny边缘检测算法的效果。

详解Python中图像边缘检测算法的实现

来源:https://blog.csdn.net/FRIGIDWINTER/article/details/123956874

标签:Python,图像,边缘检测,算法
0
投稿

猜你喜欢

  • Python查找算法之插补查找算法的实现

    2021-03-12 08:16:57
  • Python中seaborn库之countplot的数据可视化使用

    2023-08-10 20:38:56
  • 1亿条数据在PHP中实现Mysql数据库分表100张

    2011-06-02 09:31:00
  • tkinter如何实现label超链接调用浏览器打开网址

    2023-04-05 15:08:20
  • 解决Python报错:ValueError:operands could not be broadcast together with shapes

    2021-05-14 12:04:53
  • [译]艺术和设计的差异 (1)

    2009-09-25 12:38:00
  • python生成每日报表数据(Excel)并邮件发送的实例

    2021-10-31 21:39:44
  • pytorch加载预训练模型与自己模型不匹配的解决方案

    2023-06-17 14:22:24
  • Oracle11.2.0.1如何升级到11.2.0.3 Oracle同版本升级

    2023-06-25 15:28:11
  • Python 闭包,函数分隔作用域,nonlocal声明非局部变量操作示例

    2023-07-29 00:03:51
  • 谈切图优化加速图片显示—淘宝实例

    2008-01-30 12:24:00
  • Python中方法的缺省参数问题解读

    2022-10-07 17:00:45
  • Python中 join() 函数的使用示例讲解

    2023-03-29 02:32:25
  • python操作小程序云数据库实现简单的增删改查功能

    2024-01-20 08:53:46
  • pycharm远程开发项目的实现步骤

    2023-07-17 06:01:54
  • ASP解析JSON

    2009-12-25 16:34:00
  • Python 的AES加密与解密实现

    2022-07-09 21:49:49
  • SQL Server数据库占用过多内存的解决方法

    2009-10-23 14:02:00
  • Python实现MySql数据库交互的示例

    2024-01-23 02:41:13
  • Python切片知识解析

    2022-06-07 06:31:58
  • asp之家 网络编程 m.aspxhome.com