欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python?OpenCV實現(xiàn)圖像傅里葉變換

 更新時間:2022年01月23日 09:16:32   作者:小白YouCans  
傅里葉變換,也稱作傅立葉變換,表示能將滿足一定條件的某個函數(shù)表示成三角函數(shù)(正弦和/或余弦函數(shù))或者它們的積分的線性組合。本文將介紹如何通過OpenCV實現(xiàn)圖像的傅里葉變換,需要的可以參考一下

二維離散傅里葉變換(DFT)

對于二維圖像處理,通常使用 x , y x, yx,y 表示離散的空間域坐標變量,用 u , v u,vu,v 表示離散的頻率域變量。二維離散傅里葉變換(DFT)和反變換(IDFT)為:

二維離散傅里葉變換也可以用極坐標表示:

傅里葉頻譜(Fourier spectrum)為:

傅里葉相位譜(Fourier phase spectrum)為:

傅里葉功率譜(Fourier power spectrum)為:

空間取樣和頻率間隔是相互對應(yīng)的,頻率域所對應(yīng)的離散變量間的間隔為:Δu=1/MΔT, Δυ=1/NΔZ。即:頻域中樣本之間的間隔,與空間樣本之間的間隔及樣本數(shù)量的乘積成反比。

空間域濾波器和頻率域濾波器也是相互對應(yīng)的,二維卷積定理是在空間域和頻率域濾波之間建立等價關(guān)系的紐帶:

這表明 F 和 H 分別是 f 和 h 的傅里葉變換;f 和 h 的空間卷積的傅里葉變換,是它們的變換的乘積。

OpenCV 實現(xiàn)圖像傅里葉變換(cv.dft)

使用 OpenCV 中的 cv.dft() 函數(shù)也可以實現(xiàn)圖像的傅里葉變換,cv.idft() 函數(shù)實現(xiàn)圖像傅里葉逆變換。

函數(shù)說明:

cv.dft(src[, dst[, flags[, nonzeroRows]]]) → dst
cv.idft(src[, dst[, flags[, nonzeroRows]]]) → dst

參數(shù)說明:

src:輸入圖像,單通道灰度圖像,使用 np.float32 格式

dst:輸出圖像,圖像大小與 src 相同,數(shù)據(jù)類型由 flag 決定

flag:轉(zhuǎn)換標識符

cv.DFT_INVERSE:用一維或二維逆變換取代默認的正向變換

cv.DFT_SCALE:縮放比例標識,根據(jù)元素數(shù)量求出縮放結(jié)果,常與DFT_INVERSE搭配使用

cv.DFT_ROWS: 對輸入矩陣的每行進行正向或反向的傅里葉變換,常用于三維或高維變換等復(fù)雜操作

cv.DFT_COMPLEX_OUTPUT:對一維或二維實數(shù)數(shù)組進行正向變換,默認方法,結(jié)果是由 2個通道表示的復(fù)數(shù)陣列,第一通道是實數(shù)部分,第二通道是虛數(shù)部分

cv.DFT_REAL_OUTPUT:對一維或二維復(fù)數(shù)數(shù)組進行逆變換,結(jié)果通常是一個尺寸相同的復(fù)數(shù)矩陣

注意事項:

1.輸入圖像 src 是 np.float32 格式,如圖像使用 np.uint8 格式則必須先轉(zhuǎn)換 np.float32 格式。

2.默認方法 cv.DFT_COMPLEX_OUTPUT 時,輸入 src 是 np.float32 格式的單通道二維數(shù)組,輸出 dst 是 2個通道的二維數(shù)組,第一通道 dft[:,:,0] 是實數(shù)部分,第二通道 dft[:,:,1] 是虛數(shù)部分。

3.不能直接用于顯示圖像??梢允褂?cv.magnitude() 函數(shù)將傅里葉變換的結(jié)果轉(zhuǎn)換到灰度 [0,255]。

4.idft(src, dst, flags) 等價于 dft(src, dst, flags=DFT_INVERSE)。

5.OpenCV 實現(xiàn)傅里葉變換,計算速度比 Numpy 更快。

轉(zhuǎn)換標識符為 cv.DFT_COMPLEX_OUTPUT 時,cv.dft() 函數(shù)的輸出是 2個通道的二維數(shù)組,使用 cv.magnitude() 函數(shù)可以實現(xiàn)計算二維矢量的幅值 。

函數(shù)說明:

cv.magnitude(x, y[, magnitude]) → dst

參數(shù)說明:

x:一維或多維數(shù)組,也表示復(fù)數(shù)的實部,浮點型

y:一維或多維數(shù)組,也表示復(fù)數(shù)的虛部,浮點型,數(shù)組大小必須與 x 相同

dst:輸出數(shù)組,數(shù)組大小和數(shù)據(jù)類型與 x 相同,運算公式為:

傅里葉變換及相關(guān)操作的取值范圍可能不適于圖像顯示,需要進行歸一化處理。 OpenCV 中的 cv.normalize() 函數(shù)可以實現(xiàn)圖像的歸一化。

函數(shù)說明:

cv.normalize(src, dst[, alpha[, beta[, norm_type[, dtype[, mask]]]]]) → dst

參數(shù)說明:

src:輸入圖像

dst:輸出結(jié)果,與輸入圖像同尺寸同類型

alpha:歸一化后的最小值,可選項,默認值為0

beta:歸一化后的最大值,可選項,默認值為1

norm_type:歸一化類型

  • NORM_INF:Linf 范數(shù)(絕對值的最大值)
  • NORM_L1:L1 范數(shù)(絕對值的和)
  • NORM_L2:L2 范數(shù)(歐幾里德距離),默認類型
  • NORM_MINMAX:線性縮放,常用類型

dtype:可選項,默認值 -1,表示輸出矩陣與輸入圖像類型相同

mask:掩模遮罩,可選項,默認無遮罩

傅里葉變換在理論上需要O(MN)²次運算,非常耗時;快速傅里葉變換只需要O(MN㏒(MN)) 次運算就可以完成。

OpenCV 中的傅里葉變換函數(shù) cv.dft() 對于行數(shù)和列數(shù)都可以分解為2^p*3^q*5^r的矩陣的計算性能最好。為了提高運算性能,可以對原矩陣的右側(cè)和下方補 0,以滿足該分解條件。OpenCV 中的 cv.getOptimalDFTSize() 函數(shù)可以實現(xiàn)圖像的最優(yōu) DFT 尺寸擴充,適用于 cv.dft() 和 np.fft.fft2()。

函數(shù)說明:

cv.getOptimalDFTSize(versize) → retval

參數(shù)說明:

versize:數(shù)組大小

retval:DFT 擴充的最優(yōu)數(shù)組大小

示例代碼

    # 8.11:OpenCV 實現(xiàn)二維圖像的離散傅里葉變換
    imgGray = cv2.imread("../images/Fig0424a.tif", flags=0)  # flags=0 讀取為灰度圖像

    # cv2.dft 實現(xiàn)圖像的傅里葉變換
    imgFloat32 = np.float32(imgGray)  # 將圖像轉(zhuǎn)換成 float32
    dft = cv2.dft(imgFloat32, flags=cv2.DFT_COMPLEX_OUTPUT)  # 傅里葉變換
    dftShift = np.fft.fftshift(dft)  # 將低頻分量移動到頻域圖像的中心

    # 幅度譜
    # ampSpe = np.sqrt(np.power(dft[:,:,0], 2) + np.power(dftShift[:,:,1], 2))
    dftAmp = cv2.magnitude(dft[:,:,0], dft[:,:,1])  # 幅度譜,未中心化
    dftShiftAmp = cv2.magnitude(dftShift[:,:,0], dftShift[:,:,1])  # 幅度譜,中心化
    dftAmpLog = np.log(1 + dftShiftAmp)  # 幅度譜對數(shù)變換,以便于顯示
    # 相位譜
    phase = np.arctan2(dftShift[:,:,1], dftShift[:,:,0])  # 計算相位角(弧度制)
    dftPhi = phase / np.pi*180  # 將相位角轉(zhuǎn)換為 [-180, 180]

    print("dftMag max={}, min={}".format(dftAmp.max(), dftAmp.min()))
    print("dftPhi max={}, min={}".format(dftPhi.max(), dftPhi.min()))
    print("dftAmpLog max={}, min={}".format(dftAmpLog.max(), dftAmpLog.min()))

    # cv2.idft 實現(xiàn)圖像的逆傅里葉變換
    invShift = np.fft.ifftshift(dftShift)  # 將低頻逆轉(zhuǎn)換回圖像四角
    imgIdft = cv2.idft(invShift)  # 逆傅里葉變換
    imgRebuild = cv2.magnitude(imgIdft[:,:,0], imgIdft[:,:,1])  # 重建圖像

    plt.figure(figsize=(9, 6))
    plt.subplot(231), plt.title("Original image"), plt.axis('off')
    plt.imshow(imgGray, cmap='gray')
    plt.subplot(232), plt.title("DFT Phase"), plt.axis('off')
    plt.imshow(dftPhi, cmap='gray')
    plt.subplot(233), plt.title("Rebuild image with IDFT"), plt.axis('off')
    plt.imshow(imgRebuild, cmap='gray')
    plt.subplot(234), plt.title("DFT amplitude spectrum"), plt.axis('off')
    plt.imshow(dftAmp, cmap='gray')
    plt.subplot(235), plt.title("DFT-shift amplitude"), plt.axis('off')
    plt.imshow(dftShiftAmp, cmap='gray')
    plt.subplot(236), plt.title("Log-trans of DFT amp"), plt.axis('off')
    plt.imshow(dftAmpLog, cmap='gray')
    plt.tight_layout()
    plt.show()

到此這篇關(guān)于Python OpenCV實現(xiàn)圖像傅里葉變換的文章就介紹到這了,更多相關(guān)Python OpenCV傅里葉變換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解python中字典的循環(huán)遍歷的兩種方式

    詳解python中字典的循環(huán)遍歷的兩種方式

    本篇文章主要介紹了python中字典的循環(huán)遍歷的兩種方式 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • python 文件操作api(文件操作函數(shù))

    python 文件操作api(文件操作函數(shù))

    總是記不住API。昨晚寫的時候用到了這些,但是沒記住,于是就索性整理一下吧,方便需要的朋友
    2016-08-08
  • Python批量刪除mysql中千萬級大量數(shù)據(jù)的腳本分享

    Python批量刪除mysql中千萬級大量數(shù)據(jù)的腳本分享

    這篇文章主要介紹了Python批量刪除mysql中千萬級大量數(shù)據(jù)的示例代碼,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-12-12
  • python+requests+unittest API接口測試實例(詳解)

    python+requests+unittest API接口測試實例(詳解)

    下面小編就為大家?guī)硪黄猵ython+requests+unittest API接口測試實例(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 如何通過Python收集MySQL MHA 部署及運行狀態(tài)信息的功能

    如何通過Python收集MySQL MHA 部署及運行狀態(tài)信息的功能

    本篇幅主要介紹如何通過Python實現(xiàn)收集MHA 集群 節(jié)點信息 和 運行狀態(tài)的功能。這些信息將是CMDB信息的重要組成部分,感興趣的朋友一起看看吧
    2021-10-10
  • Python+PyQt5實現(xiàn)美劇爬蟲可視工具的方法

    Python+PyQt5實現(xiàn)美劇爬蟲可視工具的方法

    這篇文章主要介紹了Python+PyQt5實現(xiàn)美劇爬蟲可視工具的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2019-04-04
  • Python+OpenCV 圖像邊緣檢測四種實現(xiàn)方法

    Python+OpenCV 圖像邊緣檢測四種實現(xiàn)方法

    本文主要介紹了通過OpenCV中Sobel算子、Schaar算子、Laplacian算子以及Canny分別實現(xiàn)圖像邊緣檢測并總結(jié)了四者的優(yōu)缺點,感興趣的同學(xué)可以參考一下
    2021-11-11
  • python通過post提交數(shù)據(jù)的方法

    python通過post提交數(shù)據(jù)的方法

    這篇文章主要介紹了python通過post提交數(shù)據(jù)的方法,涉及Python使用post方式傳遞數(shù)據(jù)的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • Python List remove()實例用法詳解

    Python List remove()實例用法詳解

    在本篇內(nèi)容里小編給大家整理了一篇關(guān)于Python List remove()方法及實例,有需要的朋友們跟著學(xué)習下。
    2021-08-08
  • python中requests小技巧

    python中requests小技巧

    Requests 使用的是 urllib3,因此繼承了它的所有特性。Requests 支持 HTTP 連接保持和連接池,支持使用 cookie 保持會話,支持文件上傳,支持自動確定響應(yīng)內(nèi)容的編碼,支持國際化的 URL 和 POST 數(shù)據(jù)自動編碼。現(xiàn)代、國際化、人性化。
    2017-05-05

最新評論