【圖像處理 --- 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.pswp.cn/bicheng/71829.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/71829.shtml
英文地址,請注明出處:http://en.pswp.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…