当前位置: 首页 > article >正文

【数字图像处理+MATLAB】基于 Sobel 算子计算图像梯度并进行边缘增强:使用 imgradientxy 函数

引言

在图像处理中,边缘通常是图像中像素强度变化最大的地方,这种变化可以通过计算图像的梯度来量化。梯度是一个向量,它的方向指向像素强度增加最快的方向,它的大小(或者说幅度)表示像素强度增加的速度。因此,梯度的幅度可以用来检测图像中的边缘:梯度的幅度大的地方就是边缘。

Sobel算子是一种用于计算图像梯度的算子。它通过计算图像在水平方向和垂直方向上的差分来估计图像的梯度。Sobel算子会分别计算图像在x方向和y方向上的差分,这两个差分就构成了梯度的两个分量。

计算出梯度后,可以通过计算梯度的幅度来检测边缘。梯度的幅度是通过下面的公式计算的:

G m a g = G x 2 + G y 2 Gmag = \sqrt{Gx^2 + Gy^2} Gmag=Gx2+Gy2

在这里, G x Gx Gx G y Gy Gy是梯度在x方向和y方向上的分量。这个公式来自于向量的幅度的定义。


函数详解

imgradientxy 是 MATLAB 的一个函数,用于计算图像的梯度。这个函数会分别计算图像在 x 方向和 y 方向上的梯度。

基本语法:

[Gx, Gy] = imgradientxy(I)
[Gx, Gy] = imgradientxy(I, method)

参数详解:

  • I:这是一个二维的图像矩阵,需要计算梯度的图像。

  • method:这是一个可选参数,用于指定计算梯度的方法。可以是 ‘sobel’(使用 Sobel 滤波器),‘prewitt’(使用 Prewitt 滤波器),‘central’(使用中心差分),‘intermediate’(使用中间差分)等。如果省略此参数,那么默认的方法是 ‘sobel’。

返回值详解:

  • Gx:这是一个与输入图像 I 同样大小的矩阵,表示图像在 x 方向上的梯度。

  • Gy:这是一个与输入图像 I 同样大小的矩阵,表示图像在 y 方向上的梯度。


应用案例

% 读取图像
img1 = imread("Fig0342(a)(contact_lens_original).tif");

% 显示原始图像
figure;
subplot(1, 2, 1);
imshow(img1, []);

% 使用Sobel算子计算图像的x方向和y方向的梯度
[Gx, Gy] = imgradientxy(img1, "sobel");

% 计算梯度幅度
img2 = sqrt(Gx.^2 + Gy.^2);

% 显示梯度幅度图像
subplot(1, 2, 2);
imshow(img2, []);


http://www.kler.cn/a/395305.html

相关文章:

  • 使用 Vision 插件让 GitHub Copilot 识图问答
  • 三周精通FastAPI:37 包含 WSGI - Flask,Django,Pyramid 以及其它
  • llama factory lora 微调 qwen2.5 7B Instruct模型
  • python 2小时学会八股文-数据结构
  • SpringBoot实战(三十一)集成iText5,实现RSA签署PDF
  • 量化交易系统开发-实时行情自动化交易-3.4.1.2.A股交易数据
  • 《Java核心技术 卷I》Swing处理2D图形
  • 探索 Python HTTP 的瑞士军刀:Requests 库
  • JavaScript逆向爬虫教程-------基础篇之深入JavaScript运行原理以及内存管理
  • openwebui二改界面环境搭建
  • Ubuntu网络(prot)连通性检测
  • 当使用key-value方式进行参数传递时,若key对应的是一个对象或数组结构,如何利用API Post工具进行模拟操作。
  • thinkphp6 --数据库操作 增删改查
  • Flutter:使用Future发送网络请求
  • unity3d————插值运算补充点
  • 使用 Spring Security 实现基于角色的权限管理
  • ssm111基于MVC的舞蹈网站的设计与实现+vue(论文+源码)_kaic
  • C#笔记(3)
  • 解决Spring Boot整合Redis时的连接问题
  • 【Python · PyTorch】卷积神经网络(基础概念)
  • 长连接配置以及断线重连
  • Ubuntu 20.04配置ollama并下载安装调用本地大语言模型
  • 低光增强常用的损失函数pytorch实现
  • 「QT」高阶篇 之 d-指针 的用法
  • javascript用来干嘛的?赋予网站灵魂的语言
  • axios平替!用浏览器自带的fetch处理AJAX(兼容表单/JSON/文件上传)