Sobel算子详解及例程
Sobel算子是一种经典的边缘检测算子,被广泛应用于图像处理领域。它基于图像亮度的变化率来检测边缘的位置,主要通过计算图像中像素点的梯度来实现。
Sobel算子分为水平和垂直两个方向的算子,记作Gx和Gy。它们分别对图像进行水平和垂直方向的卷积运算,得到对应方向上的梯度值。
具体而言,Sobel算子使用一个3x3的卷积核对图像进行卷积操作,如下所示:
Gx = | -1 0 1 | | -2 0 2 | | -1 0 1 |
Gy = | -1 -2 -1 | | 0 0 0 | | 1 2 1 |
卷积操作后,可以通过以下公式计算图像的梯度幅值和方向:
梯度幅值 G = sqrt(Gx^2 + Gy^2)
梯度方向 θ = arctan(Gy / Gx)
其中,G表示梯度幅值,θ表示梯度方向。
Sobel算子的工作原理是,当图像中存在边缘时,像素点的亮度会发生明显的变化,从而导致梯度值较大。在边缘的两侧,梯度方向会垂直于边缘线,可以通过梯度的方向来判断边缘的方向。
Sobel算子具有以下特点:
- 简单且易于实现。
- 对噪声具有一定的平滑效果,能够抑制细小的波动。
- 在边缘检测中不仅考虑了水平方向的边缘,还考虑了垂直方向的边缘,提供了更全面的信息。
在实际应用中,常将水平和垂直方向上的梯度幅值进行组合,得到综合的边缘强度。这可以通过计算梯度幅值的平方根来实现,即 G = sqrt(Gx^2 + Gy^2)。
总结起来,Sobel算子是一种用于图像边缘检测的经典算子,通过计算图像的梯度来寻找边缘的位置。它简单而有效,是许多图像处理任务的基础。
以下是一个简单的Python例程,演示了如何使用Sobel算子进行边缘检测:
import cv2
import numpy as np# 读取图像
img = cv2.imread('input.jpg', 0) # 以灰度模式读取图像# 对图像进行Sobel边缘检测
gradient_x = cv2.Sobel(img, cv2.CV_64F, 1, 0, ksize=3)
gradient_y = cv2.Sobel(img, cv2.CV_64F, 0, 1, ksize=3)# 计算梯度幅值和方向
gradient_magnitude = np.sqrt(gradient_x**2 + gradient_y**2)
gradient_direction = np.arctan2(gradient_y, gradient_x)# 将梯度幅值和方向转换为0-255之间的整数
gradient_magnitude = cv2.normalize(gradient_magnitude, None, 0, 255, cv2.NORM_MINMAX, dtype=cv2.CV_8U)
gradient_direction = cv2.normalize(gradient_direction, None, 0, 255, cv2.NORM_MINMAX, dtype=cv2.CV_8U)# 显示结果
cv2.imshow('Sobel Magnitude', gradient_magnitude)
cv2.imshow('Sobel Direction', gradient_direction)
cv2.waitKey(0)
cv2.destroyAllWindows()
在这个例程中,首先使用OpenCV的cv2.imread函数读取输入图像,并以灰度模式读取。然后,通过cv2.Sobel函数分别对图像在水平和垂直方向进行卷积操作,得到梯度值。接下来,使用NumPy库计算梯度幅值和方向,并将其归一化到0-255的范围。最后,使用cv2.imshow函数显示边缘检测结果。
希望这个例程能够帮助你理解和运用Sobel算子进行边缘检测。
相关文章:
Sobel算子详解及例程
Sobel算子是一种经典的边缘检测算子,被广泛应用于图像处理领域。它基于图像亮度的变化率来检测边缘的位置,主要通过计算图像中像素点的梯度来实现。 Sobel算子分为水平和垂直两个方向的算子,记作Gx和Gy。它们分别对图像进行水平和垂直方向的…...
ScrapeKit 和 Swift 编写程序
以下是一个使用 ScrapeKit 和 Swift 编写的爬虫程序,用于爬取 图片。同时,我们使用了proxy 这段代码来获取代理。 import ScrapeKit class PeopleImageCrawler: NSObject, ScrapeKit.Crawler {let url: URLlet proxyUrl: URL init(url: URL, proxy…...
Java基础面试题知识点总结(上篇)
大家好,我是栗筝i,从 2022 年 10 月份开始,我持续梳理出了全面的 Java 技术栈内容,一方面是对自己学习内容进行整合梳理,另一方面是希望对大家有所帮助,使我们一同进步。得到了很多读者的正面反馈。 而在 2…...
STM32进行LVGL裸机移植
本文的移植参考的是正点原子的课程《手把手教你学LVGL图形界面编程》 基于该课程和《LVGL开发指南_V1.3》“第二章 LVGL 无操作系统移植”,然后结合自身的实际情况进行整理。 先根据自己的习惯,创建基础的单片机工程,然后在APP业务层和DRIVE…...
python解析robot framework的output.xml并生成html
一、用pyh模块解析stat结点数据(output.py) #codingutf-8import xml.dom.minidom import xml.etree.ElementTree#打开xml文档 dom xml.dom.minidom.parse(./ui/output.xml);root2 xml.etree.ElementTree.parse(./ui/output.xml) #得到文档元素对象 ro…...
【RuoYi移动端】uni-app中的单击和双击事件
1、单击事件: click"enterpriseSelect" 2、双击事件: touchend"userinfo"...
使用 conda 在 Ubuntu 16.04 上安装 Python 3.9 的步骤:和 VSCode配置
一、使用conda在 Ubuntu 16.04 上安装 Python 3.9 的步骤: 当然可以,conda 是一个非常强大的包管理器,它可以方便地管理不同版本的 Python 和各种库包。以下是使用 conda 在 Ubuntu 16.04 上安装 Python 3.9 的步骤: 1. 安装 Miniconda Miniconda 是 Anaconda 的轻量级版…...
spring6-国际化:i18n | 数据校验:Validation
文章目录 1、国际化:i18n1.1、i18n概述1.2、Java国际化1.3、Spring6国际化1.3.1、MessageSource接口1.3.2、使用Spring6国际化 2、数据校验:Validation2.1、Spring Validation概述2.2、实验一:通过Validator接口实现2.3、实验二:B…...
【MicroSoft Edge】格式化的显示JSON格式的数据
当我们没有进行任何操作的时候,默认浏览器给我们展示的JSON的数据是这样的: 看着十分不便。 解决方案: 首先点击 MicroSoft Edge 浏览器右上角的三点,如何选择扩展 点击 获取Microsoft Edge 扩展 搜索 JSONView,第一…...
【c++】跟webrtc学std array 2:TaskExecutorMap单例用法
D:\XTRANS\m98_rtc\ndrtc-webrtc\src\base\task\task_executor.ccstd array实现的map:TaskExecutorMap // Maps TaskTraits extension IDs to registered TaskExecutors. Index |n| // corresponds to id |n - 1|. using TaskExecutorMap =std::array<TaskExecutor*, Task…...
力扣每日一题59:螺旋矩阵||
题目描述: 给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。 示例 1: 输入:n 3 输出:[[1,2,3],[8,9,4],[7,6,5]]示例 2: 输入&am…...
codeforces (C++ In Love )
题目: 翻译: 思路: 1、在一个集合中有多组线段,如果有不相交的两组线段,则输出YES,否则输出NO。 2、每次操纵可以选择增加一组线段或者删除一组线段后,输出YES或者NO。 3、用flag标记该线段是否…...
【python】py文件全自动打包成spec文件
说明: 自动获取当前根目录下所有py文件生成spec文件,直接运行pyinstaller进行打包即可。直接打包成单执行文件。 直接上代码 import ospathex []def recursion(path, main):if path[:1] ! /:path /listpath os.listdir(path)for item in listpath:if…...
YOLOv5-调用官方权重进行检验(目标检测)
🍨 本文为[🔗365天深度学习训练营学习记录博客 🍦 参考文章:365天深度学习训练营-第7周:咖啡豆识别(训练营内部成员可读) 🍖 原作者:[K同学啊 | 接辅导、项目定制](https…...
springMVC中统一异常处理@ControllerAdvice
1.在DispatcherServlet中初始化HandlerExceptionResolver 2.controller执行完成后执行processDispatchResult(processedRequest,response,mappedHandler,mv,dispatchException),有异常则处理异常 3.ExcepitonHandlerExceptionResolver中执行方法doResolveHandlerMethodExceptio…...
【Java】<泛型>,在编译阶段约束操作的数据结构,并进行检查。
个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ JAVA泛型 泛型介绍: ①泛型&#…...
解决谷歌学术bib信息不全的问题
在我们撰写学术论文时,经常需要引用参考文献。如果用latex撰写论文,势必会用到文献的bib信息,大部分的教程都会告诉我们去google scholar上去搜索。 一、问题描述 搜索一篇文章,然后选择cite,再选择bib。 很明显&…...
初始Redis 分布式结构的发展演变
目录 Redis的特点和使用场景 分布式系统的引入 单机系统 分布式系统 应用服务器的增多(处理更多的请求) 数据库读写分离(数据服务器的增多) 引入缓存 应对更大的数据量 业务拆分:微服务 Redis的特点和使用场景 我们先来…...
关于动态内存管理中的常见练习题
文章目录 前言练习1:练习2:练习3:练习4: 前言 学习完C语言中的动态内存管理,大家开始利用动态内存管理来去开辟空间,经过一顿狂敲代码后,发现了问题,程序要么崩掉,要么运…...
冒泡排序、插入排序、选择排序和快速排序的原理
下面是对冒泡排序、插入排序、选择排序和快速排序的原理的简要解释: 冒泡排序(Bubble Sort):冒泡排序是一种简单的排序算法。它通过多次迭代比较相邻的元素,并交换它们的位置,使得较大(或较小&…...
跨平台音乐歌词智能提取工具:让每首歌都有故事
跨平台音乐歌词智能提取工具:让每首歌都有故事 【免费下载链接】163MusicLyrics 云音乐歌词获取处理工具【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 在数字化音乐时代,歌词不仅是歌曲的文字表达&#…...
ESP32内存不够用?别急着换芯片,试试在menuconfig里关掉这两个WiFi选项
ESP32内存优化实战:关闭WiFi加速选项释放IRAM空间 当你在开发一个集成了WiFi和蓝牙功能的ESP32智能网关时,突然遭遇这样的编译错误:"IRAM0 segment data does not fit. region iram0_0_seg overflowed by 3924 bytes",这…...
PPTist:重新定义浏览器端演示文稿编辑的技术架构与商业价值
PPTist:重新定义浏览器端演示文稿编辑的技术架构与商业价值 【免费下载链接】PPTist PowerPoint-ist(/pauəpɔintist/), An online presentation application that replicates most of the commonly used features of MS PowerPoint, allowi…...
iOSDeviceSupport终极指南:快速解决Xcode调试兼容性问题
iOSDeviceSupport终极指南:快速解决Xcode调试兼容性问题 【免费下载链接】iOSDeviceSupport All versions of iOS Device Support 项目地址: https://gitcode.com/gh_mirrors/ios/iOSDeviceSupport 你是否曾经遇到过Xcode无法识别最新iOS设备的问题ÿ…...
终极指南:novel-plus安全框架双保险配置,Spring Security与Apache Shiro完美融合
终极指南:novel-plus安全框架双保险配置,Spring Security与Apache Shiro完美融合 【免费下载链接】novel-plus novel-plus 是一个多端(PC、WAP)阅读 、功能完善的小说 CMS 系统。包括小说推荐、小说检索、小说排行、小说阅读、小说…...
利用candas高效解析与可视化BLF文件:Python数据处理新选择
1. 为什么选择candas处理BLF文件 第一次接触汽车CAN总线数据分析时,我被BLF文件的解析过程折磨得够呛。传统方法需要先加载DBC文件,再用python-can逐帧解析BLF,整个过程就像在玩俄罗斯套娃。直到发现candas这个宝藏库,我的工作效率…...
终极BT下载加速方案:trackerslist项目完整配置指南
终极BT下载加速方案:trackerslist项目完整配置指南 【免费下载链接】trackerslist Updated list of public BitTorrent trackers 项目地址: https://gitcode.com/GitHub_Trending/tr/trackerslist 还在为BT下载速度慢而烦恼吗?trackerslist项目为…...
终极艾尔登法环帧率解锁与游戏增强完整指南:如何彻底释放高刷新率显示器潜力
终极艾尔登法环帧率解锁与游戏增强完整指南:如何彻底释放高刷新率显示器潜力 【免费下载链接】EldenRingFpsUnlockAndMore A small utility to remove frame rate limit, change FOV, add widescreen support and more for Elden Ring 项目地址: https://gitcode.…...
山石网科WAF漏洞深度解析:从captcha页面到服务器沦陷的全过程
山石网科WAF命令注入漏洞的技术深潜与防御实践 在Web应用安全防护领域,WAF(Web Application Firewall)作为企业防御体系的重要屏障,其自身的安全性往往被过度信任。近期曝光的山石网科WAF命令执行漏洞,恰恰揭示了即便是…...
棉花叶子病虫害检测数据集 叶片病虫害识别图像数据集 棉花蚜虫识别 植物灰霉病与卷叶病识别
棉花计算机视觉数据集 README一、数据集核心信息项目详情类别数量及中文名称8 类(蚜虫、粘虫、细菌性枯萎病、枯萎镰刀菌、灰霉病、健康、卷叶病、叶斑病)数据数量(向下取整)5400 张图片数据集格式YOLO 格式核心应用价值1. 支撑棉…...
