主頁 > 後端開發 > Python從0到1丨了解影像形態學運算中腐蝕和膨脹

Python從0到1丨了解影像形態學運算中腐蝕和膨脹

2023-05-25 07:54:06 後端開發

摘要:這篇文章將詳細講解影像形態學知識,主要介紹影像腐蝕處理和膨脹處理,

本文分享自華為云社區《[Python從零到壹] 四十七.影像增強及運算篇之腐蝕和膨脹詳解》,作者: eastmount ,

一.形態學理論知識

數學形態學的應用可以簡化影像資料,保持它們基本的形狀特征,并出去不相干的結構,數學形態學的演算法有天然的并行實作的結構,主要針對的是二值影像(0或1),在影像處理方面,二值形態學經常應用到對影像進行分割、細化、抽取骨架、邊緣提取、形狀分析、角點檢測,分水嶺演算法等,由于其演算法簡單,演算法能夠并行運算所以經常應用到硬體中[1-2],

常見的影像形態學運算包括:

  • 腐蝕
  • 膨脹
  • 開運算
  • 閉運算
  • 梯度運算
  • 頂帽運算
  • 底帽運算

這些運算在OpenCV中主要通過MorphologyEx()函式實作,它能利用基本的膨脹和腐蝕技術,來執行更加高級形態學變換,如開閉運算、形態學梯度、頂帽、黑帽等,也可以實作最基本的影像膨脹和腐蝕,其函式原型如下:

  • dst = cv2.morphologyEx(src, model, kernel)
    – src表示原始影像
    – model表示影像進行形態學處理,包括:
    (1)cv2.MORPH_OPEN:開運算(Opening Operation)
    (2)cv2.MORPH_CLOSE:閉運算(Closing Operation)
    (3)cv2.MORPH_GRADIENT:形態學梯度(Morphological Gradient)
    (4)cv2.MORPH_TOPHAT:頂帽運算(Top Hat)
    (5)cv2.MORPH_BLACKHAT:黑帽運算(Black Hat)
  • kernel表示卷積核,可以用numpy.ones()函式構建

二.影像腐蝕

影像的腐蝕(Erosion)和膨脹(Dilation)是兩種基本的形態學運算,主要用來尋找影像中的極小區域和極大區域,影像腐蝕類似于“領域被蠶食”,它將影像中的高亮區域或白色部分進行縮減細化,其運行結果比原圖的高亮區域更小,

設A,B為集合,A被B的腐蝕,記為A-B,其定義為:

該公式表示影像A用卷積模板B來進行腐蝕處理,通過模板B與影像A進行卷積計算,得出B覆寫區域的像素點最小值,并用這個最小值來替代參考點的像素值,如圖1所示,將左邊的原始影像A腐蝕處理為右邊的效果圖A-B,

影像腐蝕主要包括二值影像和卷積核兩個輸入物件,卷積核是腐蝕中的關鍵陣列,采用Numpy庫可以生成,卷積核的中心點逐個像素掃描原始影像,被掃描到的原始影像中的像素點,只有當卷積核對應的元素值均為1時,其值才為1,否則將其像素值修改為0,在Python中,主要呼叫OpenCV的erode()函式實作影像腐蝕,

其函式原型如下:

  • dst = cv2.erode(src, kernel, iterations)
    – src表示原始影像
    – kernel表示卷積核
    – iterations表示迭代次數,默認值為1,表示進行一次腐蝕操作

可以采用函式numpy.ones((5,5), numpy.uint8)創建5×5的卷積核,如下:

影像腐蝕操作的代碼如下所示:

# -*- coding: utf-8 -*-
# By:Eastmount
import cv2  
import numpy as np  
#讀取圖片
src = cv2.imread('test01.jpg', cv2.IMREAD_UNCHANGED)
#設定卷積核
kernel = np.ones((5,5), np.uint8)
#影像腐蝕處理
erosion = cv2.erode(src, kernel)
#顯示影像
cv2.imshow("src", src)
cv2.imshow("result", erosion)
#等待顯示
cv2.waitKey(0)
cv2.destroyAllWindows()

輸出結果如圖2所示,左邊表示原圖,右邊是腐蝕處理后的影像,可以發現影像中的干擾細線(噪聲)被清洗干凈,

如果腐蝕之后的影像仍然存在噪聲,可以設定迭代次數進行多次腐蝕操作,比如進行9次腐蝕操作的核心代碼如下:

  • erosion = cv2.erode(src, kernel,iterations=9)

最終經過9次腐蝕處理的輸出影像如圖3所示,

三.影像膨脹

影像膨脹是腐蝕操作的逆操作,類似于“領域擴張”,它將影像中的高亮區域或白色部分進行擴張,其運行結果比原圖的高亮區域更大,

設A,B為集合,?為空集,A被B的膨脹,記為A⊕B,其中⊕為膨脹算子,膨脹定義為:

該公式表示用B來對影像A進行膨脹處理,其中B是一個卷積模板,其形狀可以為正方形或圓形,通過模板B與影像A進行卷積計算,掃描影像中的每一個像素點,用模板元素與二值影像元素做“與”運算,如果都為0,那么目標像素點為0,否則為1,從而計算B覆寫區域的像素點最大值,并用該值替換參考點的像素值實作影像膨脹,圖4是將左邊的原始影像A膨脹處理為右邊的效果圖A⊕B,

影像被腐蝕處理后,它將去除噪聲,但同時會壓縮影像,而影像膨脹操作可以去除噪聲并保持原有形狀,如圖5所示,

在Python中,主要呼叫OpenCV的dilate()函式實作影像腐蝕,函式原型如下:

  • dst = cv2.dilate(src, kernel, iterations)
    – src表示原始影像
    – kernel表示卷積核,可以用numpy.ones()函式構建
    – iterations表示迭代次數,默認值為1,表示進行一次膨脹操作

影像膨脹操作的代碼如下所示:

# -*- coding: utf-8 -*-
# By:Eastmount
import cv2  
import numpy as np  
#讀取圖片
src = cv2.imread('zhiwen.png', cv2.IMREAD_UNCHANGED)
#設定卷積核
kernel = np.ones((5,5), np.uint8)
#影像膨脹處理
erosion = cv2.dilate(src, kernel)
#顯示影像
cv2.imshow("src", src)
cv2.imshow("result", erosion)
#等待顯示
cv2.waitKey(0)
cv2.destroyAllWindows()

輸出結果如圖6所示:

四.總結

本文主要介紹影像形態學處理,詳細講解了影像腐蝕處理和膨脹處理,數學形態學是一種應用于影像處理和模式識別領域的新方法,其基本思想是用具有一定形態的結構元素去量度和提取影像中對應形狀以達到對影像分析和識別目的,

參考文獻:

  • [1]岡薩雷斯著,阮秋琦譯. 數字影像處理(第3版)[M]. 北京:電子工業出版社,2013.
  • [2]阮秋琦. 數字影像處理學(第3版)[M]. 北京:電子工業出版社,2008.
  • [3]毛星云,冷雪飛. OpenCV3編程入門[M]. 北京:電子工業出版社,2015.
  • [4]Eastmount. [Python影像處理] 八.影像腐蝕與影像膨脹[EB/OL]. (2018-10-31). https://blog.csdn.net/Eastmount/article/details/83581277.

 

 

點擊關注,第一時間了解華為云新鮮技術~

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/553280.html

標籤:其他

上一篇:minikub linux安裝

下一篇:返回列表

標籤雲
其他(159598) Python(38169) JavaScript(25446) Java(18123) C(15231) 區塊鏈(8268) C#(7972) AI(7469) 爪哇(7425) MySQL(7208) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5340) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4576) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2433) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1976) 功能(1967) Web開發(1951) HtmlCss(1942) C++(1922) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1878) .NETCore(1861) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Python從0到1丨了解影像形態學運算中腐蝕和膨脹

    摘要:這篇文章將詳細講解影像形態學知識,主要介紹影像腐蝕處理和膨脹處理。 本文分享自華為云社區《[Python從零到壹] 四十七.影像增強及運算篇之腐蝕和膨脹詳解》,作者: eastmount 。 一.形態學理論知識 數學形態學的應用可以簡化影像資料,保持它們基本的形狀特征,并出去不相干的結構。數學 ......

    uj5u.com 2023-05-25 07:54:06 more
  • minikub linux安裝

    親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安裝方式親測好使的安 ......

    uj5u.com 2023-05-25 07:53:59 more
  • Java如何生成亂數?要不要了解一下!

    我們在學習 Java 基礎時就知道可以生成亂數,可以為我們枯燥的學習增加那么一丟丟的樂趣。本文就來介紹 Java 亂數。 ......

    uj5u.com 2023-05-25 07:53:55 more
  • Ruby教程_編程入門自學教程_菜鳥教程-免費教程分享

    ## 教程簡介 Ruby,一種簡單快捷的面向物件(面向物件程式設計)腳本語言,在20世紀90年代由日本人松本行弘(Yukihiro Matsumoto)開發,遵守GPL協議和Ruby License。它的靈感與特性來自于 Perl、Smalltalk、Eiffel、Ada以及 Lisp 語言。由 R ......

    uj5u.com 2023-05-25 07:53:51 more
  • Java配置執行緒池

    # 一、Java配置執行緒池 ## 1、執行緒池==分類==、其他 ### 1.1、分類 ==IO密集型 和 CPU密集型== 任務的特點不同,因此針對不同型別的任務,選擇不同型別的執行緒池可以獲得更好的性能表現。 #### 1.1. IO密集型任務 ? IO密集型任務的特點是需要頻繁讀寫磁盤、網路或者其 ......

    uj5u.com 2023-05-25 07:53:47 more
  • Spring Boot 我隨手封裝了一個萬能的 Excel 匯出工具,傳什么都能

    ## 前言 如題,這個小玩意,就是不限制你查的是哪張表,用的是什么類。 我直接一把梭,嘎嘎給你一頓匯出。 我知道,這是很多人都想過的, 至少我就收到很多人問過我這個類似的問題。 我也跟他們說了,但是他們就是不動手,其實真的很簡單。 不動手怎么辦? 我出手唄。 不多說開搞 。 ## 正文 玩法很簡單。 ......

    uj5u.com 2023-05-25 07:52:22 more
  • springboot~mybatis-plus的DynamicTableNameInnerInterceptor實

    # 超輕量級 DynamicTableNameInnerInterceptor是mybatis-plug的一個攔截器插件,可以自己定義需要攔截的表單,然后對它進行加工,這時mybatis-plus就會把SQL代碼的表名加上你的這個裝飾。 # 封裝的思想 我們通常把mybatis做成一個包,公司其它同 ......

    uj5u.com 2023-05-25 07:52:00 more
  • Markdown標題自動添加編號

    用`markdown`寫檔案很方便,但是有個困擾的地方,就是標題的編號問題。 寫檔案的時候,經常會在中間插入新的標題和內容,所以手動管理編號的話,如果新的標題插在前面,則要調整后面所有的編號。 如果在檔案完成后再手動加上編號的話,不僅容易忘記, 而且有時候我們是在其他編輯器里編輯檔案再匯出`mark ......

    uj5u.com 2023-05-25 07:51:54 more
  • Netty實戰(二)

    # 一、環境準備 Netty需要的運行環境很簡單,只有2個。 - JDK 1.8+ - Apache Maven 3.3.9+ # 二、Netty 客戶端/服務器概覽 ![在這里插入圖片描述](https://img-blog.csdnimg.cn/c49191e6ee6e448f8c525b450 ......

    uj5u.com 2023-05-25 07:51:50 more
  • springboot~sharding-jdbc實作分庫分表

    # 原因 當mysql資料庫單表大于1千萬以后,查詢的性能就不能保證了,我們必須考慮分庫,分表的方案了,還好,sharding-jdbc可以很優雅的與springboot對接,完成對mysql的分庫和分表。 # 依賴整理 > 為了不影響其它小容量的表,所有添加了動態資料源,只對需要分庫分表的進行配置 ......

    uj5u.com 2023-05-25 07:51:43 more