Sobel 算子

news2024/10/7 2:17:58

1、简介

S o b e l Sobel Sobel 本质是基于图像空间域卷积,卷积的作用除了实现图像模糊或者去噪,还可以寻找一张图像上所有梯度信息,这些梯度信息是图像的最原始特征数据,进一步处理之后就可以生成一些比较高级的特征用来表示一张图像实现基于图像特征的匹配,图像分类等应用。

S o b e l Sobel Sobel 算子是一种很经典的图像梯度提取算子,其本质是基于图像空间域卷积,背后的思想是图像一阶导数算子的理论支持。

S o b e l Sobel Sobel 算子主要用于获得数字图像的一阶梯度,常见的应用和物理意义是边缘检测。( L a p l a c i a n Laplacian Laplacian 边缘检测并不局限于水平方向或垂直方向,这是 L a p l a c i a n Laplacian Laplacian S o b l e Soble Soble 的区别)

2、卷积

待处理的数字图像可以看做是一个大矩阵,图像的每个像素对应着矩阵的每个元素,假设我们的图像分辨率为 1024 × 768 1024\times768 1024×768,那么对应大矩阵的的行数则为 1024 1024 1024,列数为 768 768 768.

用于滤波(卷积核不止用于滤波)的小矩阵(也叫卷积核),一般是一个方阵,也就是行数和列数相同,比如常见的边缘检测 S o b e l Sobel Sobel 算子为 3 × 3 3 \times 3 3×3 的矩阵。

滤波就是对于大矩阵中的每个像素,计算它周围和滤波器矩阵对应位置元素的乘积,最后把乘积结果相加到一起,最终得到的值就作为该像素的新值。这样就对一个像素完成了一次滤波 。

3、Sobel 算子

该算子包含两组 3 × 3 3 \times 3 3×3 的矩阵,分别为横向及纵向,将之与图像作平面卷积,即可分别得出横向及纵向的亮度差分近似值。其公式如下:

Sobel 算子 X 方向:

G x = [ − 1 0 1 − 2 0 2 − 1 0 1 ] ∗ I G_x = \begin{bmatrix} -1 & 0 & 1 \\ -2 & 0 & 2 \\ -1 & 0 & 1 \end{bmatrix} * I Gx= 121000121 I

Sobel 算子 Y 方向:

G y = [ − 1 − 2 − 1 0 0 0 1 2 1 ] ∗ I G_y = \begin{bmatrix} -1 & -2 & -1 \\ 0 & 0 & 0 \\ 1 & 2 & 1 \end{bmatrix} * I Gy= 101202101 I

G = G x 2 + G y 2 G = \sqrt {G_{x}^2 + G_{y}^2} G=Gx2+Gy2

G = ∣ G x ∣ + ∣ G y ∣ G = |G_x| + |G_y| G=Gx+Gy

Scharr 算子:

G x = [ − 3 0 3 − 10 0 10 − 3 0 3 ] ∗ I G_x = \begin{bmatrix} -3 & 0 & 3 \\ -10 & 0 & 10 \\ -3 & 0 & 3 \end{bmatrix} * I Gx= 31030003103 I

G y = [ − 3 − 10 − 3 0 0 0 3 10 3 ] ∗ I G_y = \begin{bmatrix} -3 & -10 & -3 \\ 0 & 0 & 0 \\ 3 & 10 & 3 \end{bmatrix} * I Gy= 30310010303 I

其中:

  • I I I 代表原始图像。
  • G x G_x Gx G y G_y Gy 分别代表经横向及纵向边缘检测的图像灰度值。
  • G G G 表示图像的每一个像素的横向及纵向灰度值,有两种计算方式。
  • S c h a r r Scharr Scharr,比 S o b e l Sobel Sobel 算子的值更大,因此对于灰度变化更为敏感,会得到较强的边缘强度,但是也会损失一些细节。

如果想计算x方向梯度,我们就需要这样的一个卷积核:

G x = [ − 1 0 1 − 2 0 2 − 1 0 1 ] × [ P 1 P 2 P 3 P 4 P 5 P 6 P 7 P 8 P 9 ] G_x = \begin{bmatrix} -1 & 0 & 1 \\ -2 & 0 & 2 \\ -1 & 0 & 1 \end{bmatrix} \times \begin{bmatrix} P_1 & P_2 & P_3 \\ P_4 & P_5 & P_6 \\ P_7 & P_8 & P_9 \end{bmatrix} Gx= 121000121 × P1P4P7P2P5P8P3P6P9

4、Sobel 函数

O p e n C V OpenCV OpenCV 提供封装好的 S o b e l Sobel Sobel 算子函数:

cv2.Sobel(src, ddepth, dx, dy, ksize)

参数解释:

  • src: 原图。
  • ddepth: 处理结果图像深度,一般我们都填 − 1 -1 1,即与原图深度相同。但在这里我们需要填写 c v 2. C V _ 64 F cv2.CV\_64F cv2.CV_64F。简单来说就是如果填写 − 1 -1 1,我们在计算梯度时产生的负数就会被程序默认为 0 0 0,导致有一边的边缘出不来。而 c v 2. C V _ 64 F cv2.CV\_64F cv2.CV_64F 范围更大,可以保留负数。
  • d_x: 计算 x x x 方向的梯度。
  • d_y: 计算 y y y 方向的梯度。
  • ksize: 卷积核的尺寸。默认为 3 3 3,即 3 × 3 3 \times 3 3×3 的矩阵。

函数在使用时。如果我们想要计算 x x x 方向的梯度:

cv2.Sobel(src, ddepth, 1, 0, ksize)

反之,计算 y y y 方向的梯度

cv2.Sobel(src, ddepth, 0, 1, ksize)

当然,想要计算总梯度直接 d x = 1 , d y = 1 dx=1, dy=1 dx=1,dy=1 也是可以的,但是效果十分不好。不建议使用这种方法。
我们通常使用的方法是按权相加法。按权相加 x x x 方向梯度和 y y y 方向梯度。使用 c v 2. a d d W e i g h t ( ) cv2.addWeight() cv2.addWeight() 函数,该函数支持五个参数:

  • src1: 第一幅图像
  • weight1: 第一幅图像的权重
  • src2: 第二幅图像
  • weight2: 第二幅图像的权重
  • 偏置值

我们还要注意一件事。在我们分别计算完 x 、 y x、y xy 方向的权值时,里面是有负数的。我们需要对这些负数取绝对值,否则照样会被归为 0 0 0
取绝对值的函数是 c v 2. c o n v e r t S c a l e A b s ( i m g ) cv2.convertScaleAbs(img) cv2.convertScaleAbs(img)

import numpy as np
import cv2


img = cv2.imread('D://zopencv//qi.jpg', 0)
mask_x = cv2.Sobel(img,cv2.CV_64F, 1, 0)  # 计算x方向梯度
mask_y = cv2.Sobel(img,cv2.CV_64F, 0, 1)
img_x = cv2.convertScaleAbs(mask_x)  # 取绝对值
img_y = cv2.convertScaleAbs(mask_y)
mask = cv2.addWeighted(img_x, 0.5, img_y, 0.5, 0)  # 按权相加
# mask = cv2.Sobel(img,cv2.CV_64F,1,1)
Archie = cv2.resize(mask, None, fx=0.5, fy=0.5, interpolation=cv2.INTER_AREA)  # 图片太大了,缩小图片
cv2.imshow('Archie', Archie)
cv2.waitKey(0)
cv2.destroyAllWindows()

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

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

相关文章

快速搭建第一个SpringCloud程序

目录 1、Spring Boot项目脚手架快速搭建 1.1 生成工程基本配置 1.2 生成工程。 1.3 导入开发工具(此处为Idea) 1.4 运行代码 1.5 验证是否能访问 2、Spring Cloud环境搭建 2.1 版本匹配问题 2.2 Spring Cloud环境测试 3、引入Eureka Server 3…

《GPT-4技术报告》【中文版、英文版下载】

大预言模型时代已经到来,但是真正的智能之路还很长。 一、以下是连接,大家请自取。 英文原版:https://arxiv.org/pdf/2303.08774.pdfhttps://arxiv.org/pdf/2303.08774.pdf 中文翻译版本: 人工通用智能的星星之火:GPT-4的早期实…

【Linux】vi编辑器——命令模式

目录 行复制( "yy") 示例: 结果: 粘贴 多行复制("nyy") 示例: 结果: 行间跳转 1G或gg-------------------跳转到文本内容的第一行 示例: 结果: G-----------…

刷题日记①

day01 1. %m.ns 打印输出 以下程序的运行结果是&#xff08;&#xff09;_表示空格 #include <stdio.h> int main(void) {printf("%s , %5.3s\n", "computer", "computer");return 0; }A computer , puter B computer , __com C compute…

磁共振成像(MRI)连接组学的应用

前言 如何将磁共振成像(MRI)连接组学应用于研究典型的大脑结构和功能&#xff0c;并在临床环境中用于诊断、预后或治疗&#xff1f;本文将讨论MRI连接组学在评估功能和结构连接方面的可能应用。简而言之&#xff0c;功能连接是一种测量功能磁共振(fMRI)衍生的血氧水平依赖(BOL…

好兄弟离职了,一周面试了20多场,我直呼内行

好兄弟离职之后&#xff0c;一周面试了20多场&#xff0c;最后进了阿里&#xff0c;分享一些面试经历&#xff0c;希望能对大家有帮助&#xff01; 我的面试感受 先说一个字 是真的 “ 累 ” 安排的太满的后果可能就是经常一天只吃一顿饭&#xff0c;一直奔波在路上 不扯这个…

MybatisPlus <= 3.5.3.1 TenantPlugin 组件 存在 sql 注入漏洞(CVE-2023-25330)

漏洞描述 MyBatis-Plus TenantPlugin 是 MyBatis-Plus 的一个为多租户场景而设计的插件&#xff0c;可以在 SQL 中自动添加租户 ID 来实现数据隔离功能。 MyBatis-Plus TenantPlugin 3.5.3.1及之前版本由于 TenantHandler#getTenantId 方法在构造 SQL 表达式时默认情况下未对…

关键词数据分析-搜索词和关键词分析工具

要搜索热门关键词获取&#xff0c;可以采用以下几种方法&#xff1a; 使用百度指数&#xff1a;百度指数是一个实用的工具&#xff0c;可用于查看关键词的热度趋势、搜索量等数据。在百度指数中&#xff0c;您可以输入您要搜索的关键词&#xff0c;并查看近期的相关数据。这可以…

ServletAPI详解(四)-HttpServletResponse

我们来看第三个方法,HttpServletResponse 在servlet运行原理中提到,servlet代码中的doXXX方法的目的就是根据请求计算响应,然后将响应数据设置到HttpServletResponse对象中,然后 Tomcat 就会把这个 HttpServletResponse 对象按照 HTTP 协议的格式, 转成一个字符串, 并通过 Soc…

golang硬核技术(一)内存管理

目录前言tcmallocPageHeapCentralCacheThreadCache小对象分配中对象和大对象总结堆内存分配概念mheapheaparenamspanmcentralmcache微对象分配 tiny allocator小对象分配大对象分配栈内存分配分段栈连续栈栈在go中stackpoolstackLarge栈分配栈缩容前言 golang的内存分配&#…

QT学习笔记( APP 主界面开发项目\滑动界面的设计)

APP 主界面开发项目 本章与大家一起开发 APP 主界面。Qt C提供了像 QStackedWdget 与 QTableView 这种控 件可以方便的切换页面&#xff0c;但是这种切换页面的方法比较生硬&#xff0c;不能像手机一样滑动&#xff0c;往往这种 界面就会给用户较差的体验感。所以在传统的 Qt …

【GPT】让你事半功倍特别好用的5个GPT工具

文章目录前言一、现在还能开通ChatGPT4.0吗&#xff1f;二、推荐五款与ChatGPT的相关实用工具1.一款浏览器插件&#xff1a;ChatGPT for Google2.一款生成图片的AI工具&#xff1a;midjourney3.推荐两款AI自动生成PPT&#xff1a;闪击PPT、mindshow4.识别PFD文件内容对话&#…

信号与系统之《一文看懂傅里叶变换》

“傅里叶变换是一种非常有用的数学工具&#xff0c;它可以将一个复杂的信号分解成许多简单的频率成分。傅里叶变换在信号处理、图像处理、音乐、视频和通信等许多领域都有广泛的应用。相信大部分同学在毕业之后的一段时间之内都还没有理解到傅里叶变换的精髓&#xff0c;今天我…

【Java面试八股文宝典之MySQL篇】备战2023 查缺补漏 你越早准备 越早成功!!!——Day20

大家好&#xff0c;我是陶然同学&#xff0c;软件工程大三即将实习。认识我的朋友们知道&#xff0c;我是科班出身&#xff0c;学的还行&#xff0c;但是对面试掌握不够&#xff0c;所以我将用这100多天更新Java面试题&#x1f643;&#x1f643;。 不敢苟同&#xff0c;相信大…

(六)【软件设计师】计算机系统—原码反码补码移码

文章目录一、数据表示二、原码三、反码四、补码五、移码六、范围七、总结一、数据表示 各种数值在计算机中表示的形式称为机器数&#xff0c;其特点是采用二进制计数制&#xff0c;数的符号用0和1表示&#xff0c;小数点则隐含&#xff0c;表示不占位置。机器数对应的实际数值称…

使用zabbix监控avamar【二】

1、在“使用zabbix监控avamar【一】”中介绍了如何设置avamar端&#xff0c;并发送测试消息&#xff0c;本篇将介绍如何在zabbix server端进行配置。 2、在zabbix server的snmp trap日志文件中查找刚上传的报警信息 可以看到已经正常收到客户端信息。 3、在/etc/zabbix/snmpt…

2.0、Java继承与多态 - 方法重写与重载

2.0、Java继承与多态 - 方法重写与重载 重写&#xff08;Override&#xff09;&#xff1a;方法名一样&#xff0c;参数列表也一样 [ 重写也叫做覆写或者覆盖 ]&#xff1b; 重载&#xff08;Overload&#xff09;&#xff1a;方法名一样&#xff0c;但是参数列表不一样&#…

vue-cli 初始化工程

个人记录下vue-cli创建项目的步骤 卸载老版本的vue-cli (这不是必要的) npm uninstall vue-cli -g 如果本地使用 yarn的话,还需执行 yarn global remove vue-cli 安装全新的vue-cli npm install -g vue/cli 安装指定版本的vue-cli npm install -g vue/…

开源后台管理系统解决方案 boot-admin 简介

开源后台管理系统解决方案 boot-admin 简介介绍软件技术路线微服务架构图主要功能框图模块介绍介绍 boot-admin 是一款采用前后端分离架构模式的后台管理框架。系统提炼自实际项目&#xff0c;兼具RuoYi-Vue前端分离版和Ruoyi-Cloud微服务版功能与技术特点。 boot-admin 既有…

顶点程序经典案例——树木生长

返回目录 树木生长Shader一、介绍 大家好&#xff0c;我是阿赵。这次来做一个树木生长的Shader。 顶点程序作为整个渲染管线里面和片段程序并列的两大可控过程之一&#xff0c;一直存在感都比较低。我们平时制作的效果&#xff0c;很多都是在片段程序里面实现的计算&#xff0…