C语言实现DFT计算

简介: 本文主要介绍了利用C语言实现DFT计算的思路并给出了程序设计

一、DFT计算公式

这里就不对DFT概念进行叙述,直接上计算公式
39aeaa49c4bbbb23c216e40fc5c6e495_de463496991e41189ac1c99dfc57b71e.png

其中N为DFT点数。

公式如此,但是在程序中并非如此运算,而是利用欧拉公式对DFT的计算公式进行了转化
607515e78679f67849c953c8dfb5fecc_be6eff85961f41edb6f838d86150769f.png

转换后公式变为
ac70d22d833a997540619f0546196667_3215f9009e1a40df95a7df76c15e1d9c.png

利用转化后的公式进行程序编写就变得思路清晰起来。

在进行频谱分析时有一个概念叫做频谱分辨率,其计算公式如下:
1f146ab3a0166271ff7bfabb75036c21_42d9abb0376042319c01ee9f11657811.png

∆f为频谱分辨率,N为采样点数,Ts为采样时间间隔,fs为采样频率

比如频谱分辨率为50Hz,那么计算结果中第一个频点(k=1)时对应为50Hz分量,第二个频点(k=2)时对应为100Hz分量,依此类推。k=0时为直流分量。

二、DFT程序实现

按照惯例,直接上程序

#define Pi   3.1416   // DFT计算时的Π值
/*
 *==============================================================================
 *函数名称:Dft_Calculate
 *函数功能:计算DFT
 *输入参数:Input:数据数组   N:DFT点数,Num:获取前Num个频点
 *输出:前Num频点的幅值
 *返回值:无
 *============================================================================*/
void Dft_Calculate(int Input[],int N,int Num)
{
    int n = 0;   // 计算单个点DFT的循环变量
    int k = 0;   // 计算全部点DFT的循环变量
    double Real[N],Imag[N];
    double Real_Sum = 0;   // 存储实部的和
    double Imag_Sum = 0;   // 存储虚部的和

    double Dft_Result[N];   // 存储DFT结果
    // 测试一下int和double的误差

    for (k = 0;k < Num;k ++)
    {
        for (n = 0;n < N;n ++)
        {
            Real[n] = cos(((2*Pi)/N)*n*k)*Input[n];
            Imag[n] = -sin(((2*Pi)/N)*n*k)*Input[n];

            Real_Sum = Real_Sum + Real[n];   // 实部求和
            Imag_Sum = Imag_Sum + Imag[n];   // 虚部求和
        }
        Dft_Result[k] = sqrt(Real_Sum * Real_Sum + Imag_Sum * Imag_Sum);
        Real_Sum = 0;
        Imag_Sum = 0;   // 初始化计算值
    }
}

该函数逻辑简单,注释明确,这里就不再赘述了。主要功能是输入需要求DFT的数组Input后,输入DFT点数以及想获取的结果长度,即可计算DFT结果值。

值得注意的是该函数计算结果是一个局部变量,在计算完成后会被释放。如果在计算完成后需要对计算结果进行进一步操作,可以将存储计算结果的数组定义放在函数外面。

相关文章
|
7月前
|
存储 C语言
C语言中的级数求和
C语言中的级数求和
|
7月前
|
存储 C语言 开发者
C语言:圆的基础计算
C语言:圆的基础计算
|
C语言
C语言之根据公式计算圆周率的近似值
C语言之根据公式计算圆周率的近似值
274 0
|
4月前
|
C语言
C语言实现拉格朗日插值法
C语言实现拉格朗日插值法
|
6月前
|
C语言
C语言--矩阵转置
C语言--矩阵转置
|
7月前
|
存储 人工智能 算法
C语言实现矩阵转置
C语言实现矩阵转置
523 0
|
编译器 C语言
【级数求和】C语言解析
【级数求和】C语言解析
134 0
|
C语言
C语言-利用指针实现3*4矩置阵的转置
C语言-利用指针实现3*4矩置阵的转置
401 0
|
7月前
|
C语言
C语言一元多项式的表示及相加讲解及相关代码
C语言一元多项式的表示及相加讲解及相关代码
243 0
|
BI C语言
重数和众数问题——C语言实现
重数和众数问题——C语言实现