【图像处理 --- Sobel 边缘检测的详解】

Sobel 边缘检测的详解

目录

  • Sobel 边缘检测的详解
    • 1. 梯度计算
    • 2. 梯度大小
    • 3. 梯度方向
    • 4. 非极大值抑制
    • 5. 双阈值处理
    • 6. 在 MATLAB 中实现 Sobel 边缘检测
    • 7.运行结果展示
    • 8.关键参数解释
    • 9.实验与验证

Sobel 边缘检测是一种经典的图像处理算法,用于检测图像中的边缘。它通过计算图像中每个像素的梯度大小和方向,来判断该像素是否位于边缘上。以下是 Sobel 边缘检测的详细步骤和解释:

1. 梯度计算

Sobel 算子通过两个 3×3 的卷积核(水平和垂直)来计算图像在水平和垂直方向上的梯度。这两个核分别是:
• 水平方向核(检测垂直边缘) :
水平方向核

• 垂直方向核(检测水平边缘) :
垂直方向核

通过将这两个核分别与图像进行卷积运算,可以得到图像在水平和垂直方向上的梯度值 Gx​ 和 Gy​。

2. 梯度大小

梯度的大小表示了图像中亮度变化的剧烈程度,是判断边缘强度的重要依据。梯度大小的计算公式为:
在这里插入图片描述

为了简化计算,通常使用曼哈顿距离来代替平方根运算:
在这里插入图片描述

3. 梯度方向

梯度的方向表示了边缘的方向,计算公式为:
在这里插入图片描述

其中,θ 的范围通常在 −90∘ 到 90∘ 之间。

4. 非极大值抑制

为了细化边缘,减少噪声干扰,Sobel 边缘检测通常会使用非极大值抑制(Non-Maximum Suppression)。这一步骤会保留梯度方向上梯度值最大的像素,抑制其他像素,从而得到更清晰的边缘。

5. 双阈值处理

为了区分强边缘和弱边缘,Sobel 边缘检测通常会使用双阈值处理。设置一个低阈值和一个高阈值:
• 高于高阈值的点被认为是强边缘。
• 低于低阈值的点被抑制。
• 介于两者之间的点只有在与强边缘相连时才被视为边缘。

6. 在 MATLAB 中实现 Sobel 边缘检测

MATLAB 提供了 edge 函数,简化了 Sobel 边缘检测的实现过程。以下是详细的代码示例和解释:
matlab

% 读取图像
image = imread('test.jpg');
grayImage = rgb2gray(image);
% Sobel 边缘检测
edges = edge(grayImage, 'Sobel');
% 显示图像
figure;
imshow(grayImage);
title('Grayscale Image');
figure;
imshow(edges);
title('Sobel Edges');

代码解释:
1. 读取图像
matlab

image = imread('test.jpg');

这行代码读取名为 ‘test.jpg’ 的图像。确保图像文件存在于当前工作目录或提供完整的路径。
2. 转换为灰度图像
matlab

grayImage = rgb2gray(image);

将彩色图像转换为灰度图像,便于后续处理。
3. Sobel 边缘检测
matlab

edges = edge(grayImage, 'Sobel');

使用 edge 函数和 ‘Sobel’ 参数进行边缘检测。edge 函数会自动完成梯度计算、非极大值抑制和双阈值处理。
4. 显示图像
matlab

figure;
imshow(grayImage);
title('Grayscale Image');

创建一个新的图形窗口,显示灰度图像,并添加标题。
matlab

figure;
imshow(edges);
title('Sobel Edges');

创建另一个图形窗口,显示检测到的边缘图像,并添加标题。

7.运行结果展示

运行结果展示

8.关键参数解释

• 图像预处理
○ 在进行边缘检测之前,通常需要对图像进行预处理,如去噪、对比度调整等,以提高检测效果。
• Sobel算子的核大小
○ 默认情况下,edge 函数使用 3×3 的 Sobel 核。如果需要更大的核,可以通过调整参数实现。
• 阈值设置
○ 在 edge 函数中,默认使用自动计算的阈值。用户可以通过设置 LowThreshold 和 HighThreshold 参数手动调整阈值,以优化检测结果。

9.实验与验证

为了更好地理解 Sobel 边缘检测的效果,可以进行以下实验:
1. 改变图像
• 使用不同的图像进行边缘检测,观察Sobel算子的检测效果。
2. 调整阈值
• 设置不同的低阈值和高阈值,观察边缘检测结果的变化。
• 例如:
matlab

edges = edge(grayImage, 'Sobel', [0.1, 0.3]);
  1. 对比其他边缘检测算法
    • 使用 Canny、Prewitt 等其他边缘检测算法,比较它们的检测效果。
    • 例如:
    matlab
edges_canny = edge(grayImage, 'Canny');
figure; imshow(edges_canny);title('Canny Edges');

在这里插入图片描述

  1. 添加噪声
    • 在图像中添加噪声(如高斯噪声、椒盐噪声),观察 Sobel 边缘检测对噪声的鲁棒性。
    • 例如:
    matlab
noisyImage = imnoise(grayImage, 'gaussian', 0, 0.01);
edges_noisy = edge(noisyImage, 'Sobel');
figure; imshow(edges_noisy); title('Edges with Noise');

在这里插入图片描述

10.总结
Sobel 边缘检测是一种基于梯度的边缘检测方法,通过计算图像中每个像素的梯度大小和方向,来检测边缘。在 MATLAB 中,使用 edge 函数可以方便地实现 Sobel 边缘检测。通过调整阈值和其他参数,可以进一步优化边缘检测的效果,满足不同的应用需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/71829.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 热题100 15. 三数之和

LeetCode 热题100 | 15. 三数之和 大家好,今天我们来解决一道经典的算法题——三数之和。这道题在 LeetCode 上被标记为中等难度,要求我们从一个整数数组中找到所有不重复的三元组,使得三元组的和为 0。下面我将详细讲解解题思路&#xff0c…

基因组组装中的术语1——from HGP

Initial sequencing and analysis of the human genome | Nature 1,分层鸟枪法测序hierarchical shotgun sequencing

安全开发-环境选择

文章目录 个人心得虚拟机选择ubuntu 22.04python环境选择conda下载使用: 个人心得 在做开发时配置一个专门的环境可以使我们在开发中的效率显著提升,可以避免掉很多环境冲突的报错。尤其是python各种版本冲突,还有做渗透工具不要选择windows…

数字体验驱动用户参与增效路径

内容概要 在数字化转型深化的当下,数字内容体验已成为企业与用户建立深度连接的核心切入点。通过个性化推荐引擎与智能数据分析系统的协同运作,企业能够实时捕捉用户行为轨迹,构建精准的用户行为深度洞察模型。这一模型不仅支撑内容分发的动…

Python 字符串(str)全方位剖析:从基础入门、方法详解到跨语言对比与知识拓展

Python 字符串(str)全方位剖析:从基础入门、方法详解到跨语言对比与知识拓展 本文将深入探讨 Python 中字符串(str)的相关知识,涵盖字符串的定义、创建、基本操作、格式化等内容。同时,会将 Py…

使用C++实现简单的TCP服务器和客户端

使用C实现简单的TCP服务器和客户端 介绍准备工作1. TCP服务器实现代码结构解释 2. TCP客户端实现代码结构解释 3. 测试1.编译:2.运行 结语 介绍 本文将通过一个简单的例子,介绍如何使用C实现一个基本的TCP服务器和客户端。这个例子展示了如何创建服务器…

Java Web开发实战与项目——Spring Boot与Spring Cloud微服务项目实战

企业级应用中,微服务架构已经成为一种常见的开发模式。Spring Boot与Spring Cloud提供了丰富的工具和组件,帮助开发者快速构建、管理和扩展微服务应用。本文将通过一个实际的微服务项目,展示如何使用Spring Boot与Spring Cloud构建微服务架构…

VMware建立linux虚拟机

本文适用于初学者,帮助初学者学习如何创建虚拟机,了解在创建过程中各个选项的含义。 环境如下: CentOS版本: CentOS 7.9(2009) 软件: VMware Workstation 17 Pro 17.5.0 build-22583795 1.配…

Linux8-互斥锁、信号量

一、前情回顾 void perror(const char *s);功能:参数: 二、资源竞争 1.多线程访问临界资源时存在资源竞争(存在资源竞争、造成数据错乱) 临界资源:多个线程可以同时操作的资源空间(全局变量、共享内存&a…

LD_PRELOAD 绕过 disable_function 学习

借助这位师傅的文章来学习通过LD_PRELOAD来绕过disable_function的原理 【PHP绕过】LD_PRELOAD bypass disable_functions_phpid绕过-CSDN博客 感谢这位师傅的贡献 介绍 静态链接: (1)举个情景来帮助理解: 假设你要搬家&#x…

【无人集群系列---无人机集群编队算法】

【无人集群系列---无人机集群编队算法】 一、核心目标二、主流编队控制方法1. 领航-跟随法(Leader-Follower)2. 虚拟结构法(Virtual Structure)3. 行为法(Behavior-Based)4. 人工势场法(Artific…

Oracle Fusion Middleware更改weblogic密码

前言 当用户忘记weblogic密码时,且无法登录到web界面中,需要使用服务器命令更改密码 更改方式 1、备份 首先进入 weblogic 安装目录,备份三个文件:boot.properties,DefaultAuthenticatorInit.ldift,Def…

MongoDB 复制(副本集)

MongoDB 复制(副本集) 引言 MongoDB是一个高性能、可扩展、易于使用的文档存储系统。它以JSON-like的文档存储结构,支持灵活的数据模型。在分布式系统中,为了提高数据可用性和系统稳定性,常常需要实现数据的备份和冗余。MongoDB提供了副本集…

【Erdas实验教程】009:非监督分类及分类后评价

文章目录 一、分类过程二、分类评价ERDAS 的 ISODATA 算法是基于最小光谱距离来进行的非监督分类,聚类过程始于任意聚类平均值或一个已有分类模板的平均值;聚类每重复一次,聚类的平均值就更新一次,新聚类的均值再用于下次聚类循环。这个过程不断重复,直到最大的循环次数已…

一周学会Flask3 Python Web开发-Jinja2模板访问对象

锋哥原创的Flask3 Python Web开发 Flask3视频教程: 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 如果渲染模板传的是对象,如果如何来访问呢? 我们看下下面示例: 定义一个Student类 cla…

git 命令 设置别名

在Git中,您可以通过以下命令查看所有的alias(别名): git config --get-regexp alias 这个命令会列出所有配置的alias,例如: alias.st.status alias.co.checkout alias.br.branch ... 如果您想查看某个特定a…

React Router v5 vs v6 路由配置对比

React Router v5 vs v6 路由配置对比 React Router 是 React 中最常用的路由库,从 v5 到 v6 版本,发生了较大变化。本文对比 React Router v5 和 React Router v6 的配置方式,帮助开发者顺利迁移。 1. 安装依赖 React Router v5 npm inst…

机器学习,我们主要学习什么?

机器学习的发展历程 机器学习的发展历程,大致分为以下几个阶段: 1. 起源与早期探索(20世纪40年代-60年代) 1949年:Hebb提出了基于神经心理学的学习机制,开启了机器学习的先河1950年代:机器学习的…

全面理解-深拷贝与浅拷贝

在 C 中,深拷贝(Deep Copy) 和 浅拷贝(Shallow Copy) 是两种完全不同的对象拷贝策略,主要区别在于对指针和动态分配资源的处理方式。正确理解二者的区别是避免内存泄漏、悬空指针和程序崩溃的关键。 一、核…

蓝桥杯第十六届嵌入式模拟编程题解析

由硬件框图可以知道我们要配置LED 和按键 LED 先配置LED的八个引脚为GPIO_OutPut,锁存器PD2也是,然后都设置为起始高电平,生成代码时还要去解决引脚冲突问题 按键 按键配置,由原理图按键所对引脚要GPIO_Input 生成代码&#xf…