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

Opencv實(shí)現(xiàn)傅里葉變換

 更新時(shí)間:2021年10月11日 10:26:04   作者:Ethan_Lei_Pro  
這篇文章主要為大家詳細(xì)介紹了Opencv實(shí)現(xiàn)傅里葉變換的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

傅里葉變換將圖像分解成其正弦和余弦分量,它將圖像由空域轉(zhuǎn)換為時(shí)域。任何函數(shù)都可以近似的表示為無(wú)數(shù)正弦和余弦函數(shù)的和,傅里葉變換就是實(shí)現(xiàn)這一步的,數(shù)學(xué)上一個(gè)二維圖像的傅里葉變換為:

公式中,f是圖像在空域的值,F(xiàn)是頻域的值。轉(zhuǎn)換的結(jié)果是復(fù)數(shù),但是不可能通過(guò)一個(gè)真實(shí)圖像和一個(gè)復(fù)雜的圖像或通過(guò)大小和相位圖像去顯示這樣的一個(gè)圖像。然而,在整個(gè)圖像處理算法只對(duì)大小圖像是感興趣的,因?yàn)檫@包含了所有我們需要的圖像幾何結(jié)構(gòu)的信息。

可通過(guò)以下幾步顯示一副傅里葉變換后的圖像

1、將圖像擴(kuò)展到它的最佳尺寸,DFT(直接傅里葉變換)的性能依賴(lài)于圖片的尺寸,當(dāng)圖像是2,3,5的倍數(shù)時(shí)往往是最快的。因此,為了達(dá)到最優(yōu)性能通常采用墊邊界值的方法,得到一個(gè)最佳的尺寸。

2、為傅立葉變換結(jié)果的實(shí)部和虛部分配存儲(chǔ)空間。傅里葉變換的結(jié)果是一個(gè)復(fù)數(shù),這意味著每幅圖的結(jié)果都有一個(gè)實(shí)部和虛部,此外,頻域范圍遠(yuǎn)遠(yuǎn)大于它對(duì)應(yīng)的空間范圍。因此,我們這些通常至少以一個(gè)浮點(diǎn)數(shù)格式存儲(chǔ)這些數(shù)值。因此,我們會(huì)將我們的輸入圖像轉(zhuǎn)換為這種類(lèi)型并且擴(kuò)展它與另一通道存放復(fù)數(shù)值

3、進(jìn)行傅里葉變換。

4、將復(fù)數(shù)轉(zhuǎn)換為幅值,DFT的幅值由以下公式得出:

5、切換到對(duì)數(shù)刻度。對(duì)圖像進(jìn)行對(duì)數(shù)尺度的縮放,結(jié)果證明,傅立葉系數(shù)矩陣的動(dòng)態(tài)范圍太大,無(wú)法顯示在屏幕上,我們無(wú)法通過(guò)這樣去觀(guān)察一些小的和高的變化值。因此那些高的數(shù)值將轉(zhuǎn)化成白點(diǎn)而小的數(shù)值會(huì)變成黑點(diǎn),使用灰度值進(jìn)行可視化,我們可以將線(xiàn)性刻度轉(zhuǎn)換為對(duì)數(shù)刻度,以便于觀(guān)察。

6、剪切和重分布幅度圖象,第一步我們擴(kuò)展了圖像,這里我們?nèi)サ魯U(kuò)展的那部分值,基于可視化的目的,我們還可以重新排列結(jié)果的象限,使原點(diǎn)(0,0)對(duì)應(yīng)于與圖像中心

7、歸一化。目前得到的幅值圖像仍然太大,超出了顯示的范圍,歸一化這范圍內(nèi)的值,可以進(jìn)一步達(dá)到可視化的目的

實(shí)現(xiàn)程序

void _DFT(){
 //1以灰度模式讀取原圖像并顯示
 Mat srcImage = imread("miFan.jpg",0);
 if (!srcImage.data){ cout << "Error\n"; }
 imshow("原圖像", srcImage);

 //2將輸入圖像擴(kuò)展到最佳尺寸,邊界用0補(bǔ)充
 int m = getOptimalDFTSize(srcImage.rows);
 int n = getOptimalDFTSize(srcImage.cols);

 //將添加的像素初始化為0
 Mat padded;
 copyMakeBorder(srcImage, padded, 0, m - srcImage.rows,
  0, n - srcImage.cols, BORDER_CONSTANT, Scalar::all(0));

 //3為傅里葉變換的結(jié)果(實(shí)部和虛部)分配存儲(chǔ)空間
 //將數(shù)組組合合并為一個(gè)多通道數(shù)組
 Mat planes[] = { Mat_<float>(padded), Mat::zeros(padded.size(), CV_32F) };
 Mat complexI;
 merge(planes, 2, complexI);

 //4進(jìn)行傅里葉變換
 dft(complexI, complexI);

 //5將復(fù)數(shù)轉(zhuǎn)換為幅值,即=> log(1 + sqrt(Re(DFT(I))^2 + Im(DFT(I))^2))
 //將多通道數(shù)組分離為幾個(gè)單通道數(shù)組
 split(complexI, planes);//planes[0] = Re(DFT(I), planes[1] = Im(DFT(I))
 magnitude(planes[0], planes[1], planes[0]);
 Mat magImage = planes[0];

 //6進(jìn)行對(duì)數(shù)尺度縮放
 magImage += Scalar::all(1);
 log(magImage, magImage);//求自然對(duì)數(shù)

 //7剪切和重分布幅度圖象限
 //若有奇數(shù)行或奇數(shù)列,進(jìn)行頻譜剪裁
 magImage = magImage(Rect(0, 0, magImage.cols&-2, magImage.rows&-2));
 //重新排列傅立葉圖像中的象限,使得原點(diǎn)位于圖像中心 
 int cx = magImage.cols / 2;
 int cy = magImage.rows / 2;
 Mat q0(magImage, Rect(0, 0, cx, cy));
 Mat q1(magImage, Rect(cx, 0, cx, cy));
 Mat q2(magImage, Rect(0,cy,cx,cy));
 Mat q3(magImage, Rect(cx,cy,cx,cy));
 //交換象限(左上與右下進(jìn)行交換)
 Mat tmp;
 q0.copyTo(tmp);
 q3.copyTo(q0);
 tmp.copyTo(q3);
 //交換象限(右上與左下進(jìn)行交換)
 q1.copyTo(tmp);
 q2.copyTo(q1);
 tmp.copyTo(q2);

 //8歸一化,用0到1的浮點(diǎn)值將矩陣變換為可視的圖像格式
 normalize(magImage, magImage, 0, 1, CV_MINMAX);

 //9顯示
 imshow("頻譜增幅", magImage);

 waitKey();
}

傅里葉變換后的圖片

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文詳解QDialog中exec與open的區(qū)別

    一文詳解QDialog中exec與open的區(qū)別

    這篇文章主要為大家詳細(xì)介紹了QDialog中exec與open的區(qū)別,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Qt有一定的幫助,需要的可以參考一下
    2023-03-03
  • 詳解C++的JSON靜態(tài)鏈接庫(kù)JsonCpp的使用方法

    詳解C++的JSON靜態(tài)鏈接庫(kù)JsonCpp的使用方法

    這篇文章主要介紹了C++的JSON靜態(tài)鏈接庫(kù)JsonCpp的使用方法,演示了使用JsonCpp生成和解析JSON的方法,以及C++通過(guò)JSON方式的socket通信示例,需要的朋友可以參考下
    2016-03-03
  • 深入了解C++智能指針的使用

    深入了解C++智能指針的使用

    智能指針的本質(zhì)就是使用一個(gè)對(duì)象來(lái)接管一段開(kāi)辟的空間,在該對(duì)象在銷(xiāo)毀的時(shí)候,自動(dòng)調(diào)用析構(gòu)函數(shù)來(lái)釋放這段內(nèi)存。本文就來(lái)和大家詳細(xì)聊聊智能指針的使用,需要的可以參考一下
    2022-10-10
  • 深入解析C++程序中激發(fā)事件和COM中的事件處理

    深入解析C++程序中激發(fā)事件和COM中的事件處理

    這篇文章主要介紹了深入解析C++程序中激發(fā)事件和COM中的事件處理,是C++事件操作的基礎(chǔ),需要的朋友可以參考下
    2016-01-01
  • C++?smart?pointer全面深入講解

    C++?smart?pointer全面深入講解

    一般在C/C++中,如果我們使用了pointer來(lái)指向某塊heap區(qū)域,當(dāng)不再需要這塊區(qū)域的時(shí)候,我們需要手動(dòng)刪除它。如果忘了的話(huà),就會(huì)產(chǎn)生memory?leak
    2022-08-08
  • Qt創(chuàng)建項(xiàng)目實(shí)戰(zhàn)之手把手創(chuàng)建第一個(gè)Qt項(xiàng)目

    Qt創(chuàng)建項(xiàng)目實(shí)戰(zhàn)之手把手創(chuàng)建第一個(gè)Qt項(xiàng)目

    我們?cè)谶M(jìn)行軟件開(kāi)發(fā)學(xué)習(xí)時(shí),有時(shí)候需要qt軟件進(jìn)行代碼的敲寫(xiě),下面這篇文章主要給大家介紹了關(guān)于Qt創(chuàng)建項(xiàng)目實(shí)戰(zhàn)之手把手創(chuàng)建第一個(gè)Qt項(xiàng)目的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • C++實(shí)現(xiàn)LeetCode(141.單鏈表中的環(huán))

    C++實(shí)現(xiàn)LeetCode(141.單鏈表中的環(huán))

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(141.單鏈表中的環(huán)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++解析wav文件方法介紹

    C++解析wav文件方法介紹

    最近將項(xiàng)目改為跨平臺(tái),于是音頻模塊從微軟的XAudio2改用OpenAL庫(kù)。之前使用MSDN的代碼,所以現(xiàn)在改為了C++標(biāo)準(zhǔn)的寫(xiě)法,適用性更廣
    2022-09-09
  • C++編輯距離(動(dòng)態(tài)規(guī)劃)

    C++編輯距離(動(dòng)態(tài)規(guī)劃)

    這篇文章主要介紹了C++編輯距離(動(dòng)態(tài)規(guī)劃),編輯距離是指兩個(gè)字符串之間,由一個(gè)轉(zhuǎn)成另一個(gè)所需的最少編輯操作次數(shù),限免詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-01-01
  • QT實(shí)現(xiàn)TCP網(wǎng)絡(luò)聊天室

    QT實(shí)現(xiàn)TCP網(wǎng)絡(luò)聊天室

    這篇文章主要為大家詳細(xì)介紹了QT實(shí)現(xiàn)TCP網(wǎng)絡(luò)聊天室,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08

最新評(píng)論