主頁 > 後端開發 > Python從零到壹丨影像增強的頂帽運算和底帽運算

Python從零到壹丨影像增強的頂帽運算和底帽運算

2023-05-19 08:06:18 後端開發

摘要:這篇文章詳細介紹了頂帽運算和底帽運算,它們將為后續的影像分割和影像識別提供有效支撐,

本文分享自華為云社區《[Python從零到壹] 四十九.影像增強及運算篇之頂帽運算和底帽運算》,作者:eastmount,

數學形態學(Mathematical Morphology)是一種應用于影像處理和模式識別領域的新方法,數學形態學(也稱影像代數)表示以形態為基礎對影像進行分析的數學工具,其基本思想是用具有一定形態的結構元素去量度和提取影像中對應形狀以達到對影像分析和識別的目的,

一.影像頂帽運算

影像頂帽運算(top-hat transformation)又稱為影像禮帽運算,它是用原始影像減去影像開運算后的結果,常用于解決由于光照不均勻影像分割出錯的問題,其公式定義如下:

影像頂帽運算是用一個結構元通過開運算從一幅影像中洗掉物體,頂帽運算用于暗背景上的亮物體,它的一個重要用途是校正不均勻光照的影響,其效果圖如圖1所示,

在Python中,影像頂帽運算主要呼叫morphologyEx()實作,其中引數cv2.MORPH_TOPHAT表示頂帽處理,函式原型如下:

dst = cv2.morphologyEx(src, cv2.MORPH_TOPHAT, kernel)

  • src表示原始影像
  • cv2.MORPH_TOPHAT表示影像頂帽運算
  • kernel表示卷積核,可以用numpy.ones()函式構建

假設存在一張光照不均勻的米粒影像,如圖2所示,我們需要呼叫影像頂帽運算解決光照不均勻的問題,

影像頂帽運算的Python代碼如下所示:

# -*- coding: utf-8 -*-
# By:Eastmount
import cv2  
import numpy as np  
#讀取圖片
src = cv2.imread('test01.png', cv2.IMREAD_UNCHANGED)
#設定卷積核
kernel = np.ones((10,10), np.uint8)
#影像頂帽運算
result = cv2.morphologyEx(src, cv2.MORPH_TOPHAT, kernel)
#顯示影像
cv2.imshow("src", src)
cv2.imshow("result", result)
#等待顯示
cv2.waitKey(0)
cv2.destroyAllWindows()

其運行結果如圖3所示,

下圖展示了“米粒”頂帽運算的效果圖,可以看到頂帽運算后的影像洗掉了大部分非均勻背景,并將米粒與背景分離開來,

為什么影像頂帽運算會消除光照不均勻的效果呢?

通常可以利用灰度三維圖來進行解釋該演算法,灰度三維圖主要呼叫Axes3D包實作,對原圖繪制灰度三維圖的代碼如下:

# -*- coding: utf-8 -*-
# By:Eastmount
import numpy as np
import cv2 as cv
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
from matplotlib import cm
from matplotlib.ticker import LinearLocator, FormatStrFormatter
#讀取影像
img = cv.imread("test02.png")
img = cv.cvtColor(img,cv.COLOR_BGR2GRAY)
imgd = np.array(img) #image類轉numpy
#準備資料
sp = img.shape
h = int(sp[0]) #影像高度(rows)
w = int(sp[1]) #影像寬度(colums) of image
#繪圖初始處理
fig = plt.figure(figsize=(16,12))
ax = fig.gca(projection="3d")
x = np.arange(0, w, 1)
y = np.arange(0, h, 1)
x, y = np.meshgrid(x,y)
z = imgd
surf = ax.plot_surface(x, y, z, cmap=cm.coolwarm) 
#自定義z軸
ax.set_zlim(-10, 255)
ax.zaxis.set_major_locator(LinearLocator(10)) #設定z軸網格線的疏密
#將z的value字串轉為float并保留2位小數
ax.zaxis.set_major_formatter(FormatStrFormatter('%.02f')) 
# 設定坐標軸的label和標題
ax.set_xlabel('x', size=15)
ax.set_ylabel('y', size=15)
ax.set_zlabel('z', size=15)
ax.set_title("surface plot", weight='bold', size=20)
#添加右側的色卡條
fig.colorbar(surf, shrink=0.6, aspect=8) 
plt.show()

運行結果如圖5所示,其中x表示原影像中的寬度坐標,y表示原影像中的高度坐標,z表示像素點(x, y)的灰度值,

從影像中的像素走勢顯示了該圖受各部分光照不均勻的影響,從而造成背景灰度不均現象,其中凹陷對應影像中灰度值比較小的區域,

通過影像白帽運算后的影像灰度三維圖如圖6所示,對應的灰度更集中于10至100區間,由此證明了不均勻的背景被大致消除了,有利于后續的閾值分割或影像分割,

繪制三維圖增加的頂帽運算核心代碼如下:

二.影像底帽運算

影像底帽運算(bottom-hat transformation)又稱為影像黑帽運算,它是用影像閉運算操作減去原始影像后的結果,從而獲取影像內部的小孔或前景色中黑點,也常用于解決由于光照不均勻影像分割出錯的問題,其公式定義如下:

影像底帽運算是用一個結構元通過閉運算從一幅影像中洗掉物體,常用于校正不均勻光照的影響,其效果圖如圖8所示,

在Python中,影像底帽運算主要呼叫morphologyEx()實作,其中引數cv2.MORPH_BLACKHAT表示底帽或黑帽處理,函式原型如下:

dst = cv2.morphologyEx(src, cv2.MORPH_BLACKHAT, kernel)

  • src表示原始影像
  • cv2.MORPH_BLACKHAT表示影像底帽或黑帽運算
  • kernel表示卷積核,可以用numpy.ones()函式構建

Python實作影像底帽運算的代碼如下所示:

# -*- coding: utf-8 -*-
# By:Eastmount
import cv2  
import numpy as np  
#讀取圖片
src = cv2.imread('test02.png', cv2.IMREAD_UNCHANGED)
#設定卷積核
kernel = np.ones((10, 10), np.uint8)
#影像黑帽運算
result = cv2.morphologyEx(src, cv2.MORPH_BLACKHAT, kernel)
#顯示影像
cv2.imshow("src", src)
cv2.imshow("result", result)
#等待顯示
cv2.waitKey(0)
cv2.destroyAllWindows()

其運行結果如圖9所示:

三.總結

該系列主要講解了影像數學形態學知識,結合原理和代碼詳細介紹了影像腐蝕、影像膨脹、影像開運算和閉運算、影像頂帽運算和影像底帽運算等操作,這篇文章詳細介紹了頂帽運算和底帽運算,它們將為后續的影像分割和影像識別提供有效支撐,

參考文獻:

  • [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/552815.html

標籤:其他

上一篇:35基于java的校園二手交易系統或跳蚤市場設計與實作

下一篇:返回列表

標籤雲
其他(159273) Python(38156) JavaScript(25435) Java(18070) C(15228) 區塊鏈(8267) C#(7972) AI(7469) 爪哇(7425) MySQL(7197) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5871) 数组(5741) R(5409) Linux(5340) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4573) 数据框(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技术(1975) 功能(1967) Web開發(1951) HtmlCss(1938) python-3.x(1918) C++(1917) 弹簧靴(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從零到壹丨影像增強的頂帽運算和底帽運算

    摘要:這篇文章詳細介紹了頂帽運算和底帽運算,它們將為后續的影像分割和影像識別提供有效支撐。 本文分享自華為云社區《[Python從零到壹] 四十九.影像增強及運算篇之頂帽運算和底帽運算》,作者:eastmount。 數學形態學(Mathematical Morphology)是一種應用于影像處理和模 ......

    uj5u.com 2023-05-19 08:06:18 more
  • 35基于java的校園二手交易系統或跳蚤市場設計與實作

    基于java的校園二手交易系統或跳蚤市場設計與實作,java二手交易平臺,二手商城,交易商城,大學生交易平臺,springboot二手交易系統,二手交易平臺,購物平臺,大學生跳蚤平臺設計與實作,閑置物品交易平臺,校園閑置二手。 ......

    uj5u.com 2023-05-19 08:06:10 more
  • 這10個Lambda運算式必須掌握,簡化你的代碼,提高生產力

    Lambda 運算式(lambda expression)是一個匿名函式,Lambda運算式基于數學中的λ演算得名,直接對應于其中的lambda抽象(lambda abstraction),是一個匿名函式,即沒有函式名的函式。Lambda運算式可以表示閉包,和傳統數學上的意義有區別。 文末有本文重點 ......

    uj5u.com 2023-05-19 08:06:06 more
  • 【GiraKoo】Java Native Interface(JNI)的空間(參考)管理

    Java是通過垃圾回識訓制回收記憶體,C/C++是通過malloc,free,new,delete手動管理空間。那么在JNI層,同時存在Java和C/C++的空間時,該如何進行空間的管理呢?本文參考Oracle的官方檔案,對JNI層中空間的管理進行說明。明確哪些內容需要手動呼叫Delete,哪些不需要... ......

    uj5u.com 2023-05-19 08:06:01 more
  • 【pandas基礎】--資料拆分與合并

    資料集拆分是將一個大型的資料集拆分為多個較小的資料集,可以讓資料更加清晰易懂,也方便對單個資料集進行分析和處理。 同時,分開的資料集也可以分別應用不同的資料分析方法進行處理,更加高效和專業。 資料集合并則是將多個資料集合并成一個大的資料集,可以提供更全面的資訊,也可以進行更綜合的資料分析。 同時,數 ......

    uj5u.com 2023-05-19 08:05:56 more
  • 實驗三 Java類的繼承與派生

    ###第1關 類的繼承 package step1; import java.util.Scanner; class Person { /********** Begin **********/ // 自行設計類的實作 //姓名 private String name; //性別 private S ......

    uj5u.com 2023-05-19 08:05:52 more
  • < Python全景系列-4 > 史上最全檔案型別讀寫庫大盤點!什么?還包括

    介紹史上最全PYTHON檔案型別讀寫庫大盤點!包含常用和不常用的大量檔案格式!文本、音頻、視頻應有盡有!廢話不多說!走起來! ......

    uj5u.com 2023-05-19 08:05:47 more
  • 重慶高校平臺刷課軟體(小魚高校平臺助手)相關說明

    ###很久沒有更新博客了,最近忙著接一些js的腳本外包,忙著背各種面經八股文,今天把剛剛更新了的小魚高校平臺助手相關的一些東西說明一下吧 如圖目前掛在github下的軟體的官網被bing給收錄了,github內的原始碼地址也同樣被收錄其中,這讓我有一些驚喜 那么言歸正傳關于軟體出現的一些問題進行一下答 ......

    uj5u.com 2023-05-19 08:05:00 more
  • python包管理工具:Conda和pip比較

    Conda和pip通常被認為幾乎完全相同。雖然這兩個工具的某些功能重疊,但它們設計用于不同的目的。 Pip是Python Packaging Authority推薦的用于從Python Package Index安裝包的工具。 Pip安裝打包為wheels或源代碼分發的Python軟體。后者可能要求 ......

    uj5u.com 2023-05-19 08:04:51 more
  • python標準模塊介紹 -Base64: Base64, Base85等資料編碼

    簡介 功能:RFC 3548: Base16, Base32, Base64 資料編碼。轉換二進制資料為適合明文協議傳輸的 ASCII 序列。轉換 8bits 為每個位元組包含 6,5 或 4bits 的有效資料,比如 SMTP, URL 的一部分或者 HTTP POST 的一部分。參考: RFC 3 ......

    uj5u.com 2023-05-19 08:04:05 more