DFT与IDFT

 

【转】https://blog.csdn.net/mingzhuo_126/article/details/88044390

二.编程实现
考滤到DFT和IDFT算法过程中有部分相似,可以把它们合成到一个算法。

/*
    x-存放要变换数据的实部
    y-存放要变换数据的虚部
    a-存放变换结果的实部
    b-存放变换结果的虚部
    n-数据长度
    sign-为1时执行DFT,为-1时执行IDFT
*/
#include "math.h"
void dft(x,y,a,b,n,sign)
int n, sign;
double x[],y[],a[],b[];
{
    int i,k;
    double c,d,q,w,s;
    q = 6.28318530718/n;
    for (k=0;k<n;k++)
    {
        w=k*q;
        a[k]=b[k]=0.0;
        for(i=0;i<n;i++)
        {
            d=i*w;
            c=cos(d);
            s=sin(d)*sign;
            a[k]+=c*x[i] + s*y[i];
            b[k]+=c*y[i] - s*x[i];
        }
    }
    if(sign == -1)
    {
        c=1.0/n;
        for (k=0;k<n;k++)
        {
            a[k]=c*a[k];
            b[k]=c*b[k];
        }
    }
}

下面验证此算法,对X(n)=(0,1,2,3,4,5,6,7),做DFT和IDFT算法

dft_d.c

#include "stdio.h"
#include "math.h"
#include "dft.c"
#define N 4
static double  x[N],y[N],a[N],b[N],c[N];
main(){
    int k;
    int i=0;
    for(i=0; i<N; i++)
    {
        x[i]=i;
        y[i]=0;
        
        
    }
    dft(x,y,a,b,N,1);    //DFT变换
    for(i=0; i<N; i++)
    {
        c[i]=sqrt(a[i]*a[i]+b[i]*b[i]);    //算出模
        printf("%lf + j  %lf 
",a[i],b[i]);//输出变换后结果                
        printf("%lf 
",c[i]); //输出模值
        printf("
");        
    }
    dft(a,b,x,y,N,-1); //IDFT变换
    for(i=0; i<N; i++)
    {
        printf("%lf 
",x[i]); //输出x(n)的实部
    }
    
}

运行结果:

原文地址:https://www.cnblogs.com/sggggr/p/11888674.html