亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

基于Python實(shí)現(xiàn)圖像的傅里葉變換

 更新時(shí)間:2021年12月17日 11:51:25   作者:一馬歸一碼  
傅里葉變換是一種函數(shù)在空間域和頻率域的變換,從空間域到頻率域的變換是傅里葉變換,而從頻率域到空間域是傅里葉的反變換。這篇文章主要為大家介紹的是通過(guò)Python實(shí)現(xiàn)圖像的傅里葉變換,感興趣的可以了解一下

前言

首先是本文總體代碼,改一下圖像的讀取路徑就可以運(yùn)行了,但我還是建議大家先看后面的步驟一行行敲代碼,這樣效果更好:

"""
Author:XiaoMa
date:2021/11/7
"""
import cv2
import matplotlib.pyplot as plt
import numpy as np
 
#讀取圖像信息
from numpy.fft import ifftshift
 
img0 = cv2.imread("E:\From Zhihu\For the desk\cvthirteen2.jpg")
img1 = cv2.resize(img0, dsize = None, fx = 0.5, fy = 0.5)
img2 = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)               #轉(zhuǎn)化為灰度圖
h, w = img1.shape[:2]
print(h, w)
cv2.namedWindow("W0")
cv2.imshow("W0", img2)
cv2.waitKey(delay = 0)
#將圖像轉(zhuǎn)化到頻域內(nèi)并繪制頻譜圖
##numpy實(shí)現(xiàn)
plt.rcParams['font.family'] = 'SimHei'       #將全局中文字體改為黑體
f = np.fft.fft2(img2)
fshift = np.fft.fftshift(f)   #將0頻率分量移動(dòng)到圖像的中心
magnitude_spectrum0 = 20*np.log(np.abs(fshift))
#傅里葉逆變換
#Numpy實(shí)現(xiàn)
ifshift = np.fft.ifftshift(fshift)
# 將復(fù)數(shù)轉(zhuǎn)為浮點(diǎn)數(shù)進(jìn)行傅里葉頻譜圖顯示
ifimg = np.log(np.abs(ifshift))
if_img = np.fft.ifft2(ifshift)
origin_img = np.abs(if_img)
imggroup = [img2, magnitude_spectrum0, ifimg, origin_img]
titles0 = ['原始圖像', '經(jīng)過(guò)移動(dòng)后的頻譜圖', '逆變換得到的頻譜圖', '逆變換得到的原圖']
for i in range(4):
    plt.subplot(2, 2, i + 1)
    plt.xticks([])                               #除去刻度線
    plt.yticks([])
    plt.title(titles0[i])
    plt.imshow(imggroup[i], cmap = 'gray')
plt.show()
##OpenCV實(shí)現(xiàn)
dft = cv2.dft(np.float32(img2), flags = cv2.DFT_COMPLEX_OUTPUT)
dft_shift = np.fft.fftshift(dft)
magnitude_spectrum1 = 20*np.log(cv2.magnitude(dft_shift[:, :, 0], dft_shift[:, :, 1]))
plt.subplot(121), plt.imshow(img2, cmap = 'gray')
plt.title('原圖'), plt.xticks([]), plt.yticks([])
plt.subplot(122), plt.imshow(magnitude_spectrum1, cmap = 'gray')
plt.title('頻譜圖'), plt.xticks([]), plt.yticks([])
plt.show()

(1)基本概念

一般我們觀察信號(hào)是直接在時(shí)域內(nèi)(聲音信號(hào))或者空間內(nèi)(圖像)對(duì)其進(jìn)行分析,這樣雖然符合常理,但信號(hào)中的一些有用的條件就不會(huì)被我們考慮進(jìn)去,從而達(dá)不到分析的效果,所以我們要將信號(hào)轉(zhuǎn)化到其他的一些變換域中進(jìn)行分析。

(2)讀取圖像信息

本系列文章經(jīng)典操作:

"""
Author:XiaoMa
date:2021/11/7
"""
import cv2
import matplotlib.pyplot as plt
import numpy as np
 
#讀取圖像信息
img0 = cv2.imread("E:\From Zhihu\For the desk\cvthirteen2.jpg")
img1 = cv2.resize(img0, dsize = None, fx = 0.5, fy = 0.5)
img2 = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)               #轉(zhuǎn)化為灰度圖
h, w = img1.shape[:2]
print(h, w)
cv2.namedWindow("W0")
cv2.imshow("W0", img1)
cv2.waitKey(delay = 0)

得到圖像信息如下:

540 960?

1. 傅里葉變換

代碼參考:OpenCV官網(wǎng)

(1)基本概念

當(dāng)我們描述一段聲音時(shí),我們不僅會(huì)說(shuō)它的音量的大小如何,還有可能會(huì)說(shuō)它的頻率是高的還是低的,那么我們?cè)撛趺蠢斫忸l率這個(gè)概念呢?以前學(xué)習(xí)三角函數(shù)時(shí)我們被告知每一個(gè)正弦信號(hào)有它的固定的頻率,就是它的周期的倒數(shù)。那么什么是頻域呢?我們也接觸過(guò)其他形狀的波形,比如方波、三角波等等,而這些不同形狀的波呢,就是用一個(gè)個(gè)頻率不相同的正弦波組成的,如果我們將那些不同頻率的正弦波按照它們的頻率大小排列起來(lái),就得到了一個(gè)頻率軸(這是一維的),然后我們將各個(gè)頻率對(duì)應(yīng)的幅度值給它們對(duì)應(yīng)起來(lái)(就像xoy平面一樣)得到的二維的平面,就是頻域了。傅里葉變換就是將信號(hào)從時(shí)域轉(zhuǎn)化到頻域的一個(gè)工具。對(duì)于傅里葉變換中的的理解可以參考下面的圖片:

當(dāng)然如果你想更加深入的了解傅里葉變換,你可以按照?qǐng)D片上的水印去搜索,他那里講的非常清晰。?

(2)numpy實(shí)現(xiàn)

#將圖像轉(zhuǎn)化到頻域內(nèi)并繪制頻譜圖
plt.rcParams['font.family'] = 'SimHei'       #將全局中文字體改為黑體
f = np.fft.fft2(img2)
fshift = np.fft.fftshift(f)       #將0頻率分量移動(dòng)到中心
magnitude_spectrum = 20*np.log(np.abs(fshift))
plt.xticks([])                               #除去刻度線
plt.yticks([])
plt.title("頻譜圖")
plt.imshow(magnitude_spectrum, cmap = 'gray')
plt.show()

(3)OpevCV實(shí)現(xiàn)?

#OpenCV實(shí)現(xiàn)
dft = cv2.dft(np.float32(img2), flags = cv2.DFT_COMPLEX_OUTPUT)
dft_shift = np.fft.fftshift(dft)
magnitude_spectrum1 = 20*np.log(cv2.magnitude(dft_shift[:, :, 0], dft_shift[:, :, 1]))
plt.subplot(121), plt.imshow(img2, cmap = 'gray')
plt.title('原圖'), plt.xticks([]), plt.yticks([])
plt.subplot(122), plt.imshow(magnitude_spectrum1, cmap = 'gray')
plt.title('頻譜圖'), plt.xticks([]), plt.yticks([])
plt.show()

2. 傅里葉逆變換

(1)基本概念

前面提到,經(jīng)過(guò)傅里葉變換圖像可以轉(zhuǎn)化到頻域內(nèi),那么經(jīng)過(guò)傅里葉逆變換,圖像肯定能從頻域內(nèi)轉(zhuǎn)化到時(shí)域中,所以傅里葉逆變換就是將信號(hào)從頻域轉(zhuǎn)化到時(shí)域的工具。

(2)代碼實(shí)現(xiàn)

此處的代碼接上面的使用 Numpy 進(jìn)行傅里葉變換

#傅里葉逆變換
#Numpy實(shí)現(xiàn)
ifshift = np.fft.ifftshift(fshift)
# 將復(fù)數(shù)轉(zhuǎn)為浮點(diǎn)數(shù)進(jìn)行傅里葉頻譜圖顯示
ifimg = np.log(np.abs(ifshift))
if_img = np.fft.ifft2(ifshift)
origin_img = np.abs(if_img)
imggroup = [img2, magnitude_spectrum0, ifimg, origin_img]
titles0 = ['原始圖像', '經(jīng)過(guò)移動(dòng)后的頻譜圖', '逆變換得到的頻譜圖', '逆變換得到的原圖']
for i in range(4):
    plt.subplot(2, 2, i + 1)
    plt.xticks([])                               #除去刻度線
    plt.yticks([])
    plt.title(titles0[i])
    plt.imshow(imggroup[i], cmap = 'gray')
plt.show()

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

相關(guān)文章

  • TF-IDF與余弦相似性的應(yīng)用(二) 找出相似文章

    TF-IDF與余弦相似性的應(yīng)用(二) 找出相似文章

    這篇文章主要為大家詳細(xì)介紹了TF-IDF與余弦相似性的應(yīng)用,找出相似文章,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • python實(shí)現(xiàn)隨機(jī)調(diào)用一個(gè)瀏覽器打開網(wǎng)頁(yè)

    python實(shí)現(xiàn)隨機(jī)調(diào)用一個(gè)瀏覽器打開網(wǎng)頁(yè)

    下面小編就為大家分享一篇python實(shí)現(xiàn)隨機(jī)調(diào)用一個(gè)瀏覽器打開網(wǎng)頁(yè),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • pytorch實(shí)現(xiàn)seq2seq時(shí)對(duì)loss進(jìn)行mask的方式

    pytorch實(shí)現(xiàn)seq2seq時(shí)對(duì)loss進(jìn)行mask的方式

    今天小編就為大家分享一篇pytorch實(shí)現(xiàn)seq2seq時(shí)對(duì)loss進(jìn)行mask的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-02-02
  • pandas如何靈活增加新的空字段

    pandas如何靈活增加新的空字段

    這篇文章主要介紹了pandas如何靈活增加新的空字段問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • python并發(fā)和異步編程實(shí)例

    python并發(fā)和異步編程實(shí)例

    這篇文章主要為大家詳細(xì)介紹了python并發(fā)和異步編程實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • Python實(shí)現(xiàn)使用request模塊下載圖片demo示例

    Python實(shí)現(xiàn)使用request模塊下載圖片demo示例

    這篇文章主要介紹了Python實(shí)現(xiàn)使用request模塊下載圖片,結(jié)合完整實(shí)例形式分析了Python基于requests模塊的流傳輸文件下載操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-05-05
  • Python正則表達(dá)式基本原理

    Python正則表達(dá)式基本原理

    正則表達(dá)式是一個(gè)特殊的符號(hào)系列,它可以幫助我們檢查某個(gè)字符串和某種模式匹配。在python中,re庫(kù)擁有全部的正則表達(dá)式的功能。想了解更多的小伙伴可以參考閱讀本文
    2023-04-04
  • 利用Python的turtle庫(kù)繪制玫瑰教程

    利用Python的turtle庫(kù)繪制玫瑰教程

    今天小編就為大家分享一篇利用Python的turtle庫(kù)繪制玫瑰教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • Python 文件讀寫操作實(shí)例詳解

    Python 文件讀寫操作實(shí)例詳解

    Python提供了必要的函數(shù)和方法進(jìn)行默認(rèn)情況下的文件基本操作。你可以用file對(duì)象做大部分的文件操作
    2014-03-03
  • Python 使用with上下文實(shí)現(xiàn)計(jì)時(shí)功能

    Python 使用with上下文實(shí)現(xiàn)計(jì)時(shí)功能

    with 語(yǔ)句適用于對(duì)資源進(jìn)行訪問(wèn)的場(chǎng)合,確保不管使用過(guò)程中是否發(fā)生異常都會(huì)執(zhí)行必要的“清理”操作,釋放資源,比如文件使用后自動(dòng)關(guān)閉、線程中鎖的自動(dòng)獲取和釋放等。這篇文章主要介紹了Python 使用with上下文實(shí)現(xiàn)計(jì)時(shí),需要的朋友可以參考下
    2018-03-03

最新評(píng)論