6.边缘检测:梯度——索贝尔算子(Sobel)、Matlab梯度(Sobel)实战_4

2024-02-29 07:18

本文主要是介绍6.边缘检测:梯度——索贝尔算子(Sobel)、Matlab梯度(Sobel)实战_4,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

索贝尔算子(Sobel)

Matlab梯度(Sobel)实战


索贝尔算子(Sobel

人们其实做导数和边的时间已经很长了。最经典的是Sobel运算,它是以一个叫索贝尔的人的名字命名的。

Sobel运算就像我给你们看的上面的图片一样。但不是 \frac{1}{2} 和 -\frac{1}{2},它很奇怪的是它在乘以\frac{1}{8}

可以看到,它不仅是-2 +2 ,然后除以4得到相同的值。如图:

但它在我上面的行上也有-1  +1 ,在我下面的行上也有-1  +1 。如图:

(还记得我们之前说过的吗?我们假设我们的图像是局部的这种平滑,它们的变化相似吗?)

这里的想法:如果我要计算一个像素点的导数,我不会只看左边,右边,还要附近。

然后要使它标准化,你需要把它除以8。

MATLAB有一个内建函数叫做imgradientxy。他们说,我们可以用这个函数来计算梯度吗?

因为这是一个更高级的问题集的一部分而且他们已经做了梯度,我说当然。

突然间,人们有了各种各样的问题。原因是,如果你查imgradientxy,它会告诉你它默认应用了Sobel运算。

这是Sobel运算。看起来不错,但你知道吗? 它不除以8。(也就是不标准化)

所以他们所有的梯度被缩放了8倍,它把整个班级都搞砸了。

现在我们告诉他们你可以使用imgradientxy,但你最好除以8。

顺便说一下,y也在这里,在这里y是正向上的。如图:

那么Sobel梯度就是由Sx和Sy的应用组成来得到这些值。

大小就是各自的平方和的平方根。

我应该说gx是Sx的应用,gy是Sy的应用。如图:

大小就是我们之前做的。

这是arctan2,为了得到梯度,我们讨论过的atan2。如图:

这是一个古老的例子。

我知道它很古老,因为它是X窗口,甚至比你们大多数人出生的时间还要早。

这里是一个梯度,所以你只需应用Sobel算子,取平方和的平方根。

顺便说一下,你可以取临界值。如图:

你会注意到两件事。

一,它不是一个可怕的边缘图像;

二,它不是一个伟大的边缘图像;

我们可以在一定程度上要做到这一点。

Matlab梯度(Sobel)实战

有很多著名的边缘运算。

这是Sobel、Prewitt和Roberts,你们可以看到他们用了不同的方法。

实际上,在Matlab中有一个很酷的小函数叫做fspecial,它会根据你的名字为你做过滤器,

可能只在imfilter工具箱里或者基本的Matlab中。但是你可以给它高斯函数,你可以给它一些东西,你可以给它Sobel。

>> filt = fspecial('sobel');

如果你给它Sobel,它会做的是它会回复这个运算。如图:

在这种情况下,顺便说一下,在Matlab中把所有东西都翻倍,如果我把它应用到某个图像上。如下:

>> outim = imfilter(double(im), filt);

这是我的图像的两倍,我应用滤镜,然后我显示它,我使用一个灰色的颜色。如下:

>> imagesc(outim);
>> colormap gray;

运行代码,如下:

你可以看到它给了我一个梯度图像,这是 y 梯度,它还会返回 x 梯度。

小测验:

最好使用梯度计算是哪一种?

A、选择卷积,因为这是建模过滤的正确方法,所以你不会得到轻率的结果。

B、选择相关性,因为比较容易,知道哪个方向是导数的计算方向。

C、都可以。

D、因为我可以写一个for循环它会计算导数。

这是一个很困难的问题。答案是B或者C。

只要你知道发生了什么,你可以做任何你想做的事,当这种情况下就是C。

所以我认为当你做梯度过滤时,做相关性可能对你更好。

顺便说一下,在过去,我们在Matlab中需要明确地调用相关或卷积。

现在我们倾向于使用imfilter,正如我们之前讨论过的。imfilter过滤器默认做相关。


——学会编写自己的代码,才能练出真功夫。

这篇关于6.边缘检测:梯度——索贝尔算子(Sobel)、Matlab梯度(Sobel)实战_4的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/757967

相关文章

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页

Oracle Scheduler任务故障诊断方法实战指南

《OracleScheduler任务故障诊断方法实战指南》Oracle数据库作为企业级应用中最常用的关系型数据库管理系统之一,偶尔会遇到各种故障和问题,:本文主要介绍OracleSchedul... 目录前言一、故障场景:当定时任务突然“消失”二、基础环境诊断:搭建“全局视角”1. 数据库实例与PDB状态2

Git进行版本控制的实战指南

《Git进行版本控制的实战指南》Git是一种分布式版本控制系统,广泛应用于软件开发中,它可以记录和管理项目的历史修改,并支持多人协作开发,通过Git,开发者可以轻松地跟踪代码变更、合并分支、回退版本等... 目录一、Git核心概念解析二、环境搭建与配置1. 安装Git(Windows示例)2. 基础配置(必

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱