對數據進行快速傅裡葉變換後,輸出數據是倒位序的。因此,我們可以在對數據進行快速傅裡葉變換之前,先用雷德算法,把原始數據變為倒位序的。這樣,再對數據進行快速傅裡葉變換,輸出數據就是自然順序的。
雷德算法:自然順序排列的二進制數,其下面一個數總比上面的數大1,而倒序二進制數的下面一個數是上面一個數在最高位加1並由高位向低位進位而得到的。
J都是從0開始,若已知某個倒位序數J,要求下一個倒位序數,則應先判斷J的最高位是否為0,這可與k=N/2相比較,因為N/2總是等於1000……的。如果K>J,則J的最高位為0,只要把該位變為1(J與K=N/2相加即可),就得到下一個倒位序數;如果K<=J,則J的最高位為1,可將最高位變為0(J與K=N/2相減即可)。然後還需判斷次高位,這可與K=N/4相比較,若次高位為0,則需將它變為1(加K=N/4即可),其他位不變,即得到下一個倒位序數;若次高位是1,則需將它也變為0。然後再判斷下一位。
舉例說明,當N= 8時:
倒位序 ——————–順序
0(000)———– 0(000)
4(100)———– 1(001)
2(010)———– 2(010)
6(110)———– 3(011)
1(001)———– 4(100)
5(101)———– 5(101)
3(011)———– 6(110)
7(111)————7(111)
代碼如下:
#include <iostream> #include <cstdio> using namespace std; int x[16] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}; int y[16] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; int N = 8; int main() { int i,j,k; int temp; for(j=0,i=0;i<N-1;i++) //這裡實現了奇偶前後分開排序 { if(i<j) //如果i<j,即進行變址 { temp = x[j]; x[j] = x[i]; x[i] = temp; } k = N/2; //求j的下一個倒位序 while(j >= k) //如果k<=j,表示j的最高位為1 { j = j-k; //把最高位變成0 k = k/2; //k/2,比較次高位,依次類推,逐個比較,直到某個位為0 } j = j+k; //更新j } for(i = 0 ; i < N ; ++ i) { printf("%2d %2d\n" , i , x[i]) ; } return 0 ; }