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

来源:https://www.cnblogs.com/huaweiyun/archive/2023/05/24/17428608.html
-Advertisement-
Play Games

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


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

本文分享自華為雲社區《[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.

 

 

點擊關註,第一時間瞭解華為雲新鮮技術~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 汽車之家電商系統誕生在2014年,成長於2016~2019年,並經歷多年雙11、818晚會的洪峰考驗,沉澱了穩定可靠、性能卓越的線上交易能力。隨著業務中台的建設浪潮興起,2019年進入中台化建設階段,輸出其在汽車電商領域五年沉澱的能力,助力汽車電商行業發展,加速企業數字化轉型! ...
  • ## 初步瞭解 ### 總體架構設計 Mybatis 整體框架如下: ![img](https://zhangjiahao-blog.oss-cn-beijing.aliyuncs.com/picgo/202305161021323.png) ##### 介面層 MyBatis 和資料庫的交互有兩種 ...
  • # Java語法基礎 ## 註釋 註釋是對代碼的解釋和說明文字,可以提高程式的可讀性,因此在程式中添加必要的註釋文字十分重要。Java中的註釋分為三種: 單行註釋。單行註釋的格式是使用//,從//開始至本行結尾的文字將作為註釋文字。 ~~~java // 這是單行註釋文字 ~~~ 多行註釋。多行註釋 ...
  • ## 教程簡介 Apache Kafka由Scala寫成。Kafka最初是由LinkedIn開發,並於2011年初開源。2012年10月從Apache Incubator畢業。該項目的目標是為處理實時數據提供一個統一、高通量、低等待的平臺。 Kafka是一個分散式的、分區的、多複本的日誌提交服務。它 ...
  • 最近在壓測一批介面,發現介面處理速度慢的有點超出預期,感覺很奇怪,後面定位發現是資料庫批量保存這塊很慢。 這個項目用的是 mybatis-plus,批量保存直接用的是 mybatis-plus 提供的 saveBatch。 我點進去看了下源碼,感覺有點不太對勁: 繼續追蹤了下,從這個代碼來看,確實是 ...
  • # 圖紙管理系統 ## 一、初步構建後端項目 ### 1、打開已經創建好的虛擬環境:激活activate(推薦使用虛擬環境)並創建項目 ![](https://img2023.cnblogs.com/blog/2240937/202305/2240937-20230524164953360-1300 ...
  • ### StringIO和BytesIO 很多時候,數據讀寫不一定是文件,也可以在記憶體中讀寫。StringIO就是在記憶體中讀寫str。 要把str寫入StringIO,我們需要先創建一個StringIO,然後,像文件一樣寫入即可: ```python >>> from io import Strin ...
  • # 二、Java開啟非同步的兩種方式 ## 1、註解開啟:==@Async== ### 1.1、配置非同步的線程池 - 必須配置非同步線程池,否則非同步不會生效。 - @EnableAsync 註解:指定非同步線程池。不指定預設使用:SimpleAsyncTaskExecutor線程池 - SimpleAsy ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...