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

首頁 > 編程 > C > 正文

C語言數據結構算法之實現快速傅立葉變換

2020-01-26 14:03:31
字體:
來源:轉載
供稿:網友

C語言數據結構算法之實現快速傅立葉變換

本實例將實現二維快速傅立葉變換,同時也將借此實例學習用c語言實現矩陣的基本操作、復數的基本掾作,復習所學過的動態內存分配、文件操作、結構指針的函數調用等內容。 

很久以來,傅立葉變換一直是許多領域,如線性系統、光學、概率論、量子物理、天線、數字圖像處理和信號分析等的一個基本分析工具,但是即便使用計算速度驚人的計算機計算離散傅立葉變換所花費的時間也常常是難以接受的,因此導致了快速傅立葉變換(FFT)的產生。 

本實例將對一個二維數組進行正、反快速傅立葉變換。正傅立葉變換時dfft()函數先調用fft()按行對數組進行變換,再對結果調用fft()按列進行變換,此時完成了快速傅立葉變換,再調用rdfft()函數進行傅立葉逆變換。如果程序設計正確的話,變換的結果應與原數組相同。

實例代碼:

#include <stdio.h>#include <stdlib.h>#include <math.h>#define PI 3.14159265358979323846 struct COMPLEX{  float re;  float im;} cplx , * Hfield , * S , * R , * w; int n , m;int ln , lm; void initiate ();void dfft ();void rdfft ();void showresult (); void fft (int l , int k);int reverse (int t , int k);void W (int l);int loop (int l);void conjugate (); void add (struct COMPLEX * x , struct COMPLEX * y , struct COMPLEX * z);void sub (struct COMPLEX * x , struct COMPLEX * y , struct COMPLEX * z);void mul (struct COMPLEX * x , struct COMPLEX * y , struct COMPLEX * z);struct COMPLEX * Hread(int i , int j);void Hwrite (int i , int j , struct COMPLEX x); void main (){  initiate ();  printf("/n原始數據:/n");  showresult();  getchar ();  dfft ();  printf("/n快速復利葉變換后的結果:/n");  showresult ();  getchar ();  rdfft ();  printf("/n快速復利葉逆變換后的結果:/n");  showresult ();  getchar ();  free (Hfield);} void initiate (){//程序初始化操作,包括分配內存、讀入要處理的數據、進行顯示等  FILE * df;     df = fopen ("data.txt" , "r");  fscanf (df , "%5d" , &n);  fscanf (df , "%5d" , &m);  if ((ln = loop (n)) == -1)  {    printf (" 列數不是2的整數次冪 ");    exit (1);  }  if ((lm = loop (m)) == -1)  {    printf (" 行數不是2的整數次冪 ");    exit (1);  }  Hfield = (struct COMPLEX *) malloc (n * m * sizeof (cplx));  if (fread (Hfield , sizeof (cplx) , m * n , df) != (unsigned) (m * n))  {    if (feof (df)) printf (" Premature end of file ");    else printf (" File read error ");  }  fclose (df);} void dfft (){//進行二維快速復利葉變換  int i , j;   int l , k;     l = n;  k = ln;  w = (struct COMPLEX *) calloc (l , sizeof (cplx));  R = (struct COMPLEX *) calloc (l , sizeof (cplx));  S = (struct COMPLEX *) calloc (l , sizeof(cplx));  W (l);  for ( i = 0 ; i < m ; i++ )  {//按行進行快速復利葉變換    for (j = 0 ; j < n ; j++)    {            S[j].re = Hread (i , j)->re;      S[j].im = Hread (i , j)->im;    }    fft(l , k);    for (j = 0 ; j < n ; j++)      Hwrite (i , j , R[j]);  }  free (R);  free (S);  free (w);     l = m;  k = lm;  w = (struct COMPLEX *) calloc (l , sizeof (cplx));  R = (struct COMPLEX *) calloc (l , sizeof (cplx));  S = (struct COMPLEX *) calloc (l , sizeof (cplx));  W (l);  for (i = 0 ; i < n ; i++)  {//按列進行快速復利葉變換    for(j = 0 ; j < m ; j++)    {      S[j].re = Hread(j , i)->re;      S[j].im = Hread(j , i)->im;    }    fft(l , k);    for (j = 0 ; j < m ; j++)      Hwrite (j , i , R[j]);  }  free (R);  free (S);  free (w);} void rdfft (){  conjugate ();  dfft ();  conjugate ();} void showresult (){  int i , j;  for (i = 0 ; i < m ; i++)  {    printf ( " /n第%d行/n " , i);    for (j = 0 ; j < n ; j++)    {      if (j % 4 == 0) printf (" /n ");      printf(" (%5.2f,%5.2fi) " , Hread (i , j)->re , Hread (i , j)->im);    }  }} void fft (int l , int k){  int i , j , s , nv , t;  float c;  struct COMPLEX mp , r;  nv = l;  c = (float) l;  c = pow (c , 0.5);  for (i = 0 ; i < k ; i++)  {    for (t = 0 ; t < l ; t += nv)    {      for (j = 0 ; j < nv / 2 ; j++)      {        s = (t + j) >> (k - i -1);        s = reverse(s , k);        r.re = S[t + j].re;        r.im = S[t + j].im;        mul (&w[s] , &S[t + j + nv / 2] , &mp);/////////講解傳遞結構指針和結構本身的區別        add (&r , &mp , &S[t + j]);        sub (&r , &mp , &S[t + j + nv / 2]);              }    }    nv = nv >> 1;     }   for (i = 0 ; i < l ; i++)  {    j = reverse(i , k);    R[j].re = S[i].re / c;    R[j].im = S[i].im / c;  }} int reverse (int t , int k){  int i , x , y;  y = 0;  for (i = 0 ; i < k ; i++)  {    x = t & 1;    t = t >> 1;    y = (y << 1) + x;     }  return y;} void W (int l){  int i;  float c , a;  c = (float) l;  c = 2 * PI / c;  for (i = 0 ; i < l ; i++)  {        a = (float) i;    w[i].re = (float) cos(a * c);         w[i].im = -(float) sin(a * c);  }} int loop (int l){//檢驗輸入數據是否為2的整數次冪,如果是返回用2進制表示時的位數  int i , m;  if (l != 0)  {    for (i = 1 ; i < 32 ; i++)    {      m = l >> i;      if (m == 0)        break;    }    if (l == (1 << (i - 1)))      return i - 1;  }  return -1;} void conjugate (){//求復數矩陣的共軛矩陣  int i , j;  for (i = 0 ; i < m ; i++)  {    for (j = 0 ; j < n ; j++)    {      Hread (i , j)->im *= -1;    }  }} struct COMPLEX * Hread (int i , int j){//按讀矩陣方式返回Hfield中指定位置的指針  return (Hfield + i * n + j);} void Hwrite (int i , int j , struct COMPLEX x){//按寫矩陣方式將復數結構x寫到指定的Hfield位置上  (Hfield + i * n + j)->re = x.re;  (Hfield + i * n + j)->im = x.im;} void add (struct COMPLEX * x , struct COMPLEX * y , struct COMPLEX * z){//定義復數加法  z->re = x->re + y->re;  z->im = x->im + y->im; } void sub (struct COMPLEX * x , struct COMPLEX * y , struct COMPLEX * z){//定義復數減法  z->re = x->re - y->re;  z->im = x->im - y->im;} void mul (struct COMPLEX * x , struct COMPLEX * y , struct COMPLEX * z){//定義復數乘法  z->re = (x->re) * (y->re) - (x->im) * (y->im);  z->im = (x->im) * (y->re) + (x->re) * (y->im);}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲人成网站在线播| 欧美黑人巨大xxx极品| 亚洲午夜精品久久久久久性色| 久久频这里精品99香蕉| 91系列在线播放| xx视频.9999.com| 国产精品第三页| 一区三区二区视频| 国产成人一区二区在线| 国内伊人久久久久久网站视频| 国产成人91久久精品| 国产在线精品播放| 欧美国产第二页| 亚洲乱码一区二区| 欧美日韩亚洲一区二区| 97涩涩爰在线观看亚洲| 亚洲欧美中文在线视频| 欧美成人剧情片在线观看| 久久免费国产视频| 91精品啪aⅴ在线观看国产| 欧美精品videosex极品1| 国产精品美女视频网站| 久久av.com| 综合久久五月天| 成人a视频在线观看| 国产精品久在线观看| 国产精品中文在线| 91日本在线视频| 羞羞色国产精品| 欧美在线性爱视频| 午夜精品一区二区三区视频免费看| 91热福利电影| 国产欧美一区二区三区久久人妖| 国产啪精品视频| 亚洲国产精品va在线看黑人动漫| 亚洲精品在线看| 青草成人免费视频| 在线观看不卡av| 亚洲国产成人精品女人久久久| 亚洲精品久久久久久下一站| 国产精品丝袜高跟| 国产精品一区久久| 98视频在线噜噜噜国产| 亚洲国产精品久久久久秋霞不卡| 国产在线观看不卡| 一区二区三区视频在线| 久久久久免费精品国产| 午夜免费日韩视频| 蜜月aⅴ免费一区二区三区| 亚州精品天堂中文字幕| 久久亚洲精品小早川怜子66| 狠狠操狠狠色综合网| 精品福利在线视频| 国产精品观看在线亚洲人成网| 亚洲国产成人精品电影| 国产精品丝袜久久久久久不卡| 欧美激情视频一区| 欧美日韩国产影院| 国产精品福利片| 成人激情视频网| 欧美激情亚洲另类| 欧美激情一区二区三区成人| 成人免费自拍视频| 91高潮精品免费porn| 欧美日韩xxxxx| 九九精品在线视频| 亚洲高清福利视频| 黄网站色欧美视频| 久久天堂电影网| 亚洲精品视频二区| 亚洲国产精品热久久| 欧美激情va永久在线播放| 久久久在线观看| 久久国产精品久久精品| 久久久久久91| 日韩精品中文字幕有码专区| 精品久久久999| 亚洲午夜未删减在线观看| 亚洲国产小视频在线观看| 日韩电视剧在线观看免费网站| 欧洲精品久久久| 91精品免费看| www日韩中文字幕在线看| 欧美激情极品视频| 日韩av在线不卡| 成人免费视频在线观看超级碰| 日韩av黄色在线观看| 日韩在线视频免费观看| 日韩av在线免费看| 国产日韩欧美在线看| 欧美日韩国产综合视频在线观看中文| 最新国产精品亚洲| 欧美一区二区色| 亚洲wwwav| 亚洲图片欧洲图片av| 国产99视频精品免视看7| 亚洲国产精品字幕| 国产中文字幕日韩| 精品人伦一区二区三区蜜桃免费| 成人免费视频97| 久久久久久久久网站| 91丝袜美腿美女视频网站| 久久久久久亚洲精品不卡| 91经典在线视频| 国产精品人人做人人爽| 成人福利网站在线观看11| 97国产在线观看| 亚洲欧美在线x视频| 亚洲精品视频二区| 色综合久久悠悠| 欧美精品一二区| 午夜精品99久久免费| 国产乱肥老妇国产一区二| 亚洲老板91色精品久久| 国产精品美女主播在线观看纯欲| 国产精品久久久久久久av大片| 亚洲va久久久噜噜噜久久天堂| 国产精品视频网| 亚洲视频国产视频| 亚洲成人中文字幕| 日韩在线视频免费观看高清中文| 宅男66日本亚洲欧美视频| 丝袜美腿亚洲一区二区| 国产欧美精品xxxx另类| 九色精品免费永久在线| 国产一区二区动漫| 日韩欧美aⅴ综合网站发布| 国产精品视频一| 欧美丝袜一区二区| 久久久国产一区二区| 在线观看日韩欧美| 国产精品va在线播放| 亚洲精品国产品国语在线| 亚洲高清在线观看| 国产主播在线一区| 国产精品丝袜高跟| 日韩中文在线视频| 亚洲xxxxx性| 91久久国产婷婷一区二区| 欧美肥婆姓交大片| 91久久久久久久久| 黄网站色欧美视频| 国产精品视频精品| 日韩av手机在线看| 久久中文精品视频| 欧美成人性色生活仑片| 裸体女人亚洲精品一区| 91精品国产色综合久久不卡98口| 亚洲一区二区免费| 精品国产乱码久久久久酒店| 91中文字幕在线| 亚洲精品成人av| 国产美女直播视频一区| 国产一区二区三区18| 亚洲综合小说区| 欧美一级在线播放| 欧美视频专区一二在线观看| 欧美极品xxxx| 2019中文字幕在线观看| 精品国产1区2区| 欧美在线视频在线播放完整版免费观看| 午夜精品蜜臀一区二区三区免费| 久久久久成人精品| 夜夜狂射影院欧美极品|