C++實現(xiàn)二維圖形的傅里葉變換
本文實例講述了C++實現(xiàn)二維圖形的傅里葉變換的方法。有一定的借鑒價值。分享給大家供大家參考。
具體代碼如下:
// Fourier.cpp : Defines the entry point for the console application. // #include "stdafx.h" #include "stdio.h" #include "math.h" #include <cv.h> #include <highgui.h> #include "cxcore.h" int main(int argc, char* argv[]) { IplImage *img; IplImage *simg; CvMat *mat_R; CvMat *mat_I; CvMat *mat_SRC; CvMat *mat_Row; CvMat *mat_Col; CvMat *dst; CvMat *dst_R; CvMat *dst_I; CvMat *dst_Row; CvMat *dst_Col; int i,j,k; double temp; int height,width,step,channels; //載入一幅圖片 img=cvLoadImage("c:\\1.bmp",0); //mat_R初始化 mat_R=cvCreateMat(img->height,img->width,CV_64FC1); //mat_I初始化 mat_I=cvCreateMat(img->height,img->width,CV_64FC1); //mat_SRC初始化 mat_SRC=cvCreateMat(img->height,img->width,CV_64FC2); //將圖片數(shù)據(jù)存入mat_R(實部) cvConvert(img,mat_R); //將虛部初始化為零 cvZero(mat_I); //合并實部、虛部 cvMerge(mat_R,mat_I,NULL,NULL,mat_SRC); //創(chuàng)建雙通道double類型數(shù)組 dst=cvCreateMat(img->height,img->width,CV_64FC2); dst_R=cvCreateMat(img->height,img->width,CV_64FC1); dst_I=cvCreateMat(img->height,img->width,CV_64FC1); //為循環(huán)變量賦值 height=img->height; width=img->width; channels=2; step=channels*width; //局部變量,值為正一或負一 int check; //將輸入數(shù)據(jù)乘以(-1)^(i+j),用于中心化 for(j=0;j<height;j++) { for(i=0;i<width;i++) { check=(i+j)%2>0?1:-1; for(k=0;k<channels;k++) { mat_SRC->data.db[j*step+i*channels+k]=check*mat_SRC->data.db[j*step+i*channels+k]; } } } //創(chuàng)建一個mat用于臨時存儲一行數(shù)據(jù) CvMat mat_Header=cvMat(4,4,CV_64FC2); mat_Row=cvCreateMat(1,width,CV_64FC2); mat_Col=cvCreateMat(1,height,CV_64FC2); //創(chuàng)建一個dst用于臨時存儲一行數(shù)據(jù) dst_Row=cvCreateMat(1,width,CV_64FC2); dst_Col=cvCreateMat(height,1,CV_64FC2); //為循環(huán)變量賦值 height=img->height; width=img->width; channels=2; step=channels*width; //行的傅里葉變換 for(j=0;j<height;j++) { //取得第j行數(shù)據(jù) mat_Row=cvGetRow(mat_SRC,&mat_Header,j); //正向傅里葉變換 cvDFT(mat_Row,dst_Row,CV_DXT_FORWARD); //執(zhí)行循環(huán),賦值到dst for(i=0;i<width;i++) { for(k=0;k<channels;k++) { dst->data.db[j*step+i*channels+k]=dst_Row->data.db[i*channels+k]; } } } //列的傅里葉變換 for(i=0;i<width;i++) { //取得第i列 mat_Col=cvGetCol(dst,&mat_Header,i); //正向傅里葉變換 cvDFT(mat_Col,dst_Col,CV_DXT_FORWARD); //執(zhí)行循環(huán),賦值到dst for(j=0;j<height;j++) { for(k=0;k<channels;k++) { dst->data.db[j*step+i*channels+k]=dst_Col->data.db[j*channels+k]; } } } //分成兩個矩陣 cvSplit(dst,dst_R,dst_I,NULL,NULL); //創(chuàng)建臨時指針指向dst_R,dst_I double *pR,*pI; pR=(double *)dst_R->data.ptr; pI=(double *)dst_I->data.ptr; //創(chuàng)建一張用于顯示的圖像 simg=cvCreateImage(cvGetSize(img),8,1); //為循環(huán)變量賦值 height=simg->height; width=simg->width; channels=1; step=channels*width; for(j=0;j<height;j++) { for(i=0;i<width;i++) { for(k=0;k<channels;k++) { temp=pR[j*step+i*channels+k]*pR[j*step+i*channels+k]+pI[j*step+i*channels+k]*pI[j*step+i*channels+k]; temp=temp/(height*width); simg->imageData[j*step+i*channels+k]=sqrt(temp); } } } cvNamedWindow("Mar",CV_WINDOW_AUTOSIZE); cvShowImage("Mar",simg); cvWaitKey(0); cvReleaseMat(&mat_R); cvReleaseMat(&mat_I); cvReleaseMat(&mat_SRC); //cvReleaseMat(&mat_Row);//這里無法正常釋放,有待解決 //cvReleaseMat(&mat_Col); cvReleaseMat(&dst); cvReleaseMat(&dst_R); cvReleaseMat(&dst_I); cvReleaseImage(&img); cvReleaseImage(&simg); return 0; }
感興趣的朋友可以調(diào)試運行一下本文實例,程序美中不足的是會有內(nèi)存泄漏,主要是mat_Row,mat_Col,dst_Row,dst_Col,有能力的讀者可以對此進行修改與完善。相信會有新的收獲。
欄 目:C語言
下一篇:C語言入門之指針用法教程
本文標(biāo)題:C++實現(xiàn)二維圖形的傅里葉變換
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/3428.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-用棧實現(xiàn)表達式求值的方法詳解
- 01-10使用OpenGL實現(xiàn)3D立體顯示的程序代碼
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10求斐波那契(Fibonacci)數(shù)列通項的七種實現(xiàn)方法
- 01-10C語言 解決不用+、-、&#215;、&#247;數(shù)字運算符做加法
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10用C++實現(xiàn)DBSCAN聚類算法
- 01-10深入全排列算法及其實現(xiàn)方法


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 04-02jquery與jsp,用jquery
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結(jié)
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什