opencv3/C++ 離散余弦變換DCT方式
離散余弦變換/Discrete cosine transform,
根據(jù)離散傅里葉變換的性質(zhì),實(shí)偶函數(shù)的傅里葉變換只含實(shí)的余弦項(xiàng),而數(shù)字圖像都是實(shí)數(shù)矩陣,因此構(gòu)造了一種實(shí)數(shù)域的變換——離散余弦變換(DCT)。
離散余弦變換具有很強(qiáng)的”能量集中”特性,左上方稱為低頻數(shù)據(jù),右下方稱為高頻數(shù)據(jù)。而大多數(shù)的自然信號(hào)(包括聲音和圖像)的能量都集中在離散余弦變換后的低頻部分。因此也可以在圖像壓縮算法中用來(lái)進(jìn)行有損壓縮。(如JPEG壓縮編碼)
OpenCV中dct()
在OpenCV中有專門進(jìn)行離散余弦變換的函數(shù)dct()。
dct()函數(shù)執(zhí)行1D或2D浮點(diǎn)數(shù)組的正向或反向離散余弦變換(DCT):
N個(gè)元素的一維向量的正余弦變換:
該函數(shù)通過查看輸入數(shù)組的標(biāo)志和大小來(lái)選擇操作模式:
如果(flags&DCT_INVERSE)== 0,則函數(shù)執(zhí)行向前的1D或2D變換。否則是一個(gè)逆1D或2D變換。
如果(flags&DCT_ROWS)!= 0,則函數(shù)執(zhí)行每行的一維變換。
如果數(shù)組是單列或單行,則該函數(shù)執(zhí)行一維變換。
如果以上都不是,則該函數(shù)執(zhí)行2D變換。
目前dct支持偶數(shù)大小的數(shù)組(2,4,6 …)。對(duì)于數(shù)據(jù)分析和逼近,可以在必要時(shí)填充數(shù)組。另外,函數(shù)性能對(duì)數(shù)組大小的依賴性非常大,而不是單調(diào)的。在當(dāng)前實(shí)現(xiàn)中,大小為N的矢量的DCT通過大小為N / 2的矢量的DFT來(lái)計(jì)算。因此,最佳DCT大小N1 > = N可以計(jì)算為:
size_t getOptimalDCTSize(size_t N){return 2 * getOptimalDFTSize((N + 1)/ 2); }
N1 = getOptimalDCTSize(N);
dct()參數(shù)
src 輸入浮點(diǎn)數(shù)組。
dst 輸出與src大小和類型相同的數(shù)組。
flags 轉(zhuǎn)換標(biāo)志
opencv示例
#include <opencv2\opencv.hpp> 
#include <opencv2\core\core.hpp>
#include <opencv2\core\mat.hpp>
#include <iostream> 
using namespace std; 
using namespace cv; 
int main()
{
 Mat src = imread("E:\\image\\sophie.jpg", 0); 
 if(src.empty())
 {
  cout << "the image is not exist" << endl; 
  return -1;
 }
 resize(src, src, Size(512, 512));
 src.convertTo(src, CV_32F, 1.0/255);
 Mat srcDCT; 
 dct(src, srcDCT);
 imshow("src", src);
 imshow("dct", srcDCT);
 waitKey();
 return 0;
}
可以看到因?yàn)榈谝环鶊D像的細(xì)節(jié)較少,因此DFT變換數(shù)據(jù)主要集中在左上方(低頻區(qū)域),高頻區(qū)域大部分為0:
而第二幅圖像相對(duì)而言具有較為豐富的細(xì)節(jié),因此相對(duì)于第一幅圖像中間區(qū)域出現(xiàn)了大量的非0值:
以上這篇opencv3/C++ 離散余弦變換DCT方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持我們。
您可能感興趣的文章
- 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
 - 01-10深入理解C++中常見的關(guān)鍵字含義
 - 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
 - 01-10c++中inline的用法分析
 - 01-10用C++實(shí)現(xiàn)DBSCAN聚類算法
 - 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
 - 01-10C++大數(shù)模板(推薦)
 - 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
 - 01-10深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式詳解
 - 01-10深入理解C/C++混合編程
 


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
 - 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
 - 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
 - 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
 - 5c語(yǔ)言計(jì)算三角形面積代碼
 - 6什么是 WSH(腳本宿主)的詳細(xì)解釋
 - 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
 - 8正則表達(dá)式匹配各種特殊字符
 - 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
 - 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
 
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
 - 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
 - 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
 - 04-02c語(yǔ)言用函數(shù)寫分段 用c語(yǔ)言表示分段
 - 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
 - 04-02c語(yǔ)言編寫函數(shù)冒泡排序 c語(yǔ)言冒泡排
 - 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
 - 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
 - 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
 - 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
 
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
 - 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
 - 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
 - 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 01-10C#中split用法實(shí)例總結(jié)
 - 01-10delphi制作wav文件的方法
 - 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
 - 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 04-02jquery與jsp,用jquery
 


