亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++實現二維圖形的傅里葉變換

2020-01-26 15:22:20
字體:
來源:轉載
供稿:網友

本文實例講述了C++實現二維圖形的傅里葉變換的方法。有一定的借鑒價值。分享給大家供大家參考。

具體代碼如下:

// 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); //將圖片數據存入mat_R(實部) cvConvert(img,mat_R); //將虛部初始化為零 cvZero(mat_I); //合并實部、虛部 cvMerge(mat_R,mat_I,NULL,NULL,mat_SRC); //創建雙通道double類型數組 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); //為循環變量賦值 height=img->height; width=img->width; channels=2; step=channels*width; //局部變量,值為正一或負一 int check; //將輸入數據乘以(-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];  } } } //創建一個mat用于臨時存儲一行數據 CvMat mat_Header=cvMat(4,4,CV_64FC2); mat_Row=cvCreateMat(1,width,CV_64FC2); mat_Col=cvCreateMat(1,height,CV_64FC2); //創建一個dst用于臨時存儲一行數據 dst_Row=cvCreateMat(1,width,CV_64FC2); dst_Col=cvCreateMat(height,1,CV_64FC2); //為循環變量賦值 height=img->height; width=img->width; channels=2; step=channels*width; //行的傅里葉變換 for(j=0;j<height;j++) { //取得第j行數據 mat_Row=cvGetRow(mat_SRC,&mat_Header,j); //正向傅里葉變換 cvDFT(mat_Row,dst_Row,CV_DXT_FORWARD); //執行循環,賦值到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); //執行循環,賦值到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); //創建臨時指針指向dst_R,dst_I double *pR,*pI; pR=(double *)dst_R->data.ptr; pI=(double *)dst_I->data.ptr; //創建一張用于顯示的圖像 simg=cvCreateImage(cvGetSize(img),8,1); //為循環變量賦值 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;}

感興趣的朋友可以調試運行一下本文實例,程序美中不足的是會有內存泄漏,主要是mat_Row,mat_Col,dst_Row,dst_Col,有能力的讀者可以對此進行修改與完善。相信會有新的收獲。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美在线视频日韩欧美在线视频| 在线观看国产精品淫| 欧美国产日产韩国视频| 国产69精品久久久久99| 日韩电影在线观看免费| 亚洲国产一区二区三区四区| 国产91ⅴ在线精品免费观看| 色综合久久88色综合天天看泰| 欧美一区二区三区精品电影| 91久久在线视频| 在线播放日韩av| 亚洲人成网站色ww在线| 一区二区在线免费视频| 国产有码在线一区二区视频| 国产美女久久久| 国产+成+人+亚洲欧洲| 亚洲天堂视频在线观看| 亚洲欧洲国产伦综合| 国产精品成久久久久三级| 热99精品只有里视频精品| 精品国产精品自拍| 搡老女人一区二区三区视频tv| 国产视频福利一区| 精品久久中文字幕| 欧美精品电影免费在线观看| 成人性生交大片免费看小说| 97成人精品视频在线观看| 日本高清不卡的在线| 国产suv精品一区二区| 日韩国产欧美精品一区二区三区| 亚洲永久免费观看| 日韩欧美精品网站| 久久免费国产视频| 国产欧美韩国高清| 欧美亚洲国产视频| 91探花福利精品国产自产在线| 国产精品入口免费视| 亚洲欧美国产另类| 国内精品久久久久久久| 国产丝袜高跟一区| 中文一区二区视频| 成人综合网网址| 美女扒开尿口让男人操亚洲视频网站| 日韩av在线影院| 亚洲欧美日韩高清| 成人亚洲综合色就1024| 午夜精品久久久久久久男人的天堂| 欧美激情综合亚洲一二区| 亚洲最新视频在线| 最近2019免费中文字幕视频三| 国产精品88a∨| 欧美精品激情blacked18| 久久久久久网站| 亚洲视频日韩精品| 疯狂蹂躏欧美一区二区精品| 亚洲va欧美va国产综合剧情| 精品国产31久久久久久| 日韩欧美国产高清91| 日韩视频第一页| 亚洲色图激情小说| 日韩av123| 亚洲bt天天射| 日韩精品久久久久久久玫瑰园| 成人网址在线观看| 裸体女人亚洲精品一区| 亚洲free性xxxx护士hd| 欧美日本黄视频| 国产主播喷水一区二区| 成人亚洲欧美一区二区三区| 亚洲欧美日韩另类| 亚洲最新中文字幕| 欧美日韩在线视频观看| 欧美激情中文网| 色av中文字幕一区| 97精品久久久| 日韩av男人的天堂| 亚洲一区二区三区sesese| 欧美人与性动交a欧美精品| 欧美激情一区二区三级高清视频| 亚洲视频专区在线| 欧美激情亚洲自拍| 最新91在线视频| 日韩免费av一区二区| 欧美精品久久久久久久免费观看| 日韩免费观看av| 久久99精品久久久久久噜噜| 欧美性猛交xxxx乱大交3| 国产专区精品视频| 中文字幕九色91在线| 992tv成人免费视频| 欧美一级淫片aaaaaaa视频| 91精品国产高清久久久久久91| 欧美福利在线观看| 日韩有码在线播放| 欧美成人激情视频| 国内精品视频一区| 欧美床上激情在线观看| 九九精品视频在线观看| 美日韩精品免费视频| 中文欧美在线视频| 欧美午夜美女看片| 国产精品电影久久久久电影网| 国产精品爽黄69天堂a| 色综合久久天天综线观看| 91亚洲精品久久久久久久久久久久| 精品国产福利视频| 国产z一区二区三区| 91免费观看网站| 成人黄色免费看| 97视频在线观看免费| 日韩激情视频在线| 国产精品久久久久久久久久久久久| 欧美在线xxx| 韩国日本不卡在线| 欧美激情精品久久久久久大尺度| 91高清视频在线免费观看| 91中文在线视频| 欧美一级免费看| 久精品免费视频| 国产成人短视频| 亚洲天堂日韩电影| 最近日韩中文字幕中文| 精品国产自在精品国产浪潮| 国产成人精品免高潮在线观看| 韩日精品中文字幕| 欧美国产在线视频| 国产一区二区av| 欧美日韩加勒比精品一区| 亚洲国产高清福利视频| 美日韩在线视频| 欧美亚洲成人免费| 91中文字幕一区| 亚洲精品在线视频| 91亚洲精华国产精华| 亚洲国产天堂网精品网站| 亚洲精品av在线| 国产ts一区二区| 亚洲色图25p| 国产精品2018| 欧美专区第一页| 亚洲japanese制服美女| 68精品久久久久久欧美| 欧美夫妻性生活视频| 国产精品久久久av久久久| 亚洲一区二区少妇| 91亚洲国产成人精品性色| 中文字幕亚洲第一| 狠狠色香婷婷久久亚洲精品| 国产性猛交xxxx免费看久久| 亚洲精品99久久久久| 欧美日韩久久久久| 久久久久久亚洲| 一区二区三区国产视频| 久久亚洲精品一区二区| 国产欧美一区二区三区在线看| 欧美激情视频一区二区| 欧美性猛交xxxx| 91精品国产乱码久久久久久蜜臀| 亚洲欧美日韩爽爽影院| 日韩人在线观看| 欧美xxxx18性欧美| 久久精品国亚洲| 国产精品日韩精品| 最近2019中文字幕一页二页|