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,有能力的讀者可以對此進行修改與完善。相信會有新的收獲。
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設計-用棧實現(xiàn)表達式求值的方法詳解
- 01-10使用OpenGL實現(xiàn)3D立體顯示的程序代碼
- 01-10深入理解C++中常見的關鍵字含義
- 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)方法


閱讀排行
本欄相關
- 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)境設置
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什


