python进行图像边缘检测的详细教程
作者:Love?_YourSelf_CS 发布时间:2023-08-10 04:53:40
边缘检测
图像边缘是指图像中表达物体的周围像素灰度发生阶跃变化的那些像素集合。
图像中两个灰度不同的相邻区域的交界处,必然存在灰度的快速过渡或称为跳变,它们与图像中各区域边缘的位置相对应,边缘蕴含了丰富的内在信息,如方向、阶跃性质、形状等,沿边缘走向的像素变化平缓,而垂直于边缘方向的像素变化剧烈。
图像的大部分信息都集中在边缘部分,边缘确定后实际上就实现了不同区域的分割。
边缘检测算子
求取边缘往往要借助一些边缘检测算子,这些算子有的是基于一阶导数的算子,有的是二阶微分算子
Roberts算子、Prewitt算子、Sobel算子它们包含x、y两个方向的模板,每种模板只对相应的方向敏感,对该方向上的方向有明显的输出,而对其他方向的变化响应不大。以下是一些常见的一阶微分算子及其特点:
算子名称 | 特点 |
---|---|
简单微分算子 | 对噪声敏感,对噪声具有一定放大作用 |
Roberts算子 | 去噪声作用小,边缘检测能力优于简单微分算子 |
Prewitt算子 | 能够有效抑制噪声的影响,同时能够检测边缘点 |
Sobel算子 | 得到的边缘较宽,噪声抑制效果更强 |
Canny算子 | 检测的边缘位置准确且边缘较窄 |
1、Roberts算子
2、Prewitt算子
3、Sobel算子
Sobel算子检测到的边缘相比于Roberts算子的检测结果要连续一些,并且对于图像的细节检测能力更好,且Sobel边缘检测器引入了局部平均,对噪声的影响比较小,效果较好。
4、Canny算子
Canny得到的检测结果优于Roberts、Sobel算子的检测结果,边缘细节更丰富,边缘定位准确连续性较好,虚假边缘少且边缘均具有单像素宽度。
其算法实现具体分为以下4步:
用高斯滤波器平滑图像
用一阶偏导的有限差分来计算梯度的幅度和方向
对梯度幅值进行非极大值抑制
用双阈值算法检测和连接边缘
5、拉普拉斯算子
常见的二阶微分算子包括拉普拉斯算子,它是一种二阶导师算子,对图像中的噪声相当敏感,而且检测出的边缘常常是双像素宽,没有方向信息,所以拉普拉斯算子很少直接用于检测边缘,而主要用于已知边缘像素后,确定该像素是在图像的暗区还是明区。另外,一阶差分算子会在较宽范围内形成较大的梯度值,因此不能准确定位,而利用二阶差分算子的过零点可以精确定位边缘。
Laplace算子的噪声明显比Sobel算子的噪声大,但其边缘比Sobel要细很多,且Laplace变换作为二阶微分算子对噪声特别敏感,并且会产生双边沿,不能检测边缘方向。
效果实验
1、 Roberts边缘检测
Prewitt 算子代码:
Roberts_kernel_x = np.array([[-1, 0], [0, 1]], dtype=int)
Roberts_kernel_y = np.array([[0, -1], [1, 0]], dtype=int)
2、Prewitt 边缘检测
Prewitt 算子代码:
Roberts_kernel_x = np.array([[-1, 0], [0, 1]], dtype=int)
Roberts_kernel_y = np.array([[0, -1], [1, 0]], dtype=int)
3、Sobel边缘检测
Sobel函数:
edges = cv2.Sobel(img, -1, 1, 1)
4、Canny边缘检测
Canny函数:
edges = cv2.Canny(img, 5, 100)
5、Laplacian 边缘检测
Laplacian 函数:
edges = cv2.Laplacian(img, -1)
总结
来源:https://blog.csdn.net/qq_48068259/article/details/127095080


猜你喜欢
- 摘要:下文讲述五种运行sql脚本的方法,如下所示:实验环境:sql server 2008 R2在一次会议讨论中,大家咨询我使用SSMS运行
- JavaScript中没有Trim函数,VBScript语言中才有这个函数,就是去掉字符串头和尾的空格。您可以访问这篇文章:《增加 java
- 本文实例讲述了python对url格式解析的方法。分享给大家供大家参考。具体分析如下:python针对url格式的解析,可根据指定的完整UR
- 开发工具Python版本:3.6.4相关模块:pygame模块;以及一些python自带的模块。环境搭建安装Python并添加到环境变量,p
- PHP _construct() 函数实例函数创建一个新的 SimpleXMLElement 对象,然后输出 body 节点的内容:<
- M2广义货币供应量:流通于银行体系之外的现金加上企业存款、居民储蓄存款以及其他存款,它包括了一切可能成为现实购买力的货币形式,通常反映的是社
- 代码如下:<% myDSN="DSN=xur;uid=xur;pwd=xur"mySQL="s
- 前言本文仅仅介绍了常见的一些JS加密,并记录了JS和Python的实现方式常见的加密算法基本分为这几类:(1)base64编码伪加密(2)线
- 概述 -------------------------------------------------------------------
- 1、jquery//获取value值$("#ddlSubmodel").val();//获取text值$("#
- 我们先来实现一个简单的例子,hello world。似乎每种语言教程的第一节都会讲这个,我们也不例外。首先我们先创建一个项目目录,目录可自己
- 方法一,用for循环来实现num=[];i=2for i in range(2,100): j=2 for j in
- #!/usr/bin/env python# -*- coding:utf-8 -*-#导入random和string模块import ra
- 在前面我们介绍了多种请求库,如 Requests、Urllib、Selenium 等。我们接下来首先贴近实战,了解一下代理怎么使用,为后面了
- CASE 表达式分为简单表达式与搜索表达式,其中搜索表达式可以覆盖简单表达式的全部能力,我也建议只写搜索表达式,而不要写简单表达式。简单表达
- 错误类型: Microsoft JET Database Engine (0x80040E10) 至少一个参数没有被指定值。 原因:在写SQ
- 首先,我们需要着重介绍一些概念,以给你提供一些使这个“奇迹”得以发生的组成部分。太轻易地泄露伏笔对于讲故事来说不是个好的形式,所以那些不愿意
- 本文实例讲述了CI框架教程之优化验证码机制。分享给大家供大家参考,具体如下:验证码机制在CI框架中是通过一个辅助函数captcha()进行实
- 设想这样一种情况,你在一个平台上操作你的工程,但你希望在另外一个平台上完善并运行它,这就是为什么Pycharm做了很多工作来支持远程调试。在
- 本文实例讲述了Python3搜索及替换文件中文本的方法。分享给大家供大家参考。具体实现方法如下:# 将文件中的某个字符串改变成另一个 # 下