C语言FFT实现C语言FFT实现.docx

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言FFT实现C语言FFT实现

一、头文件FFT.h#ifndef FFT_H #define FFT_H #include math.h //得到FFT结果宏定义#define FFT_RESULT(x) (sqrt(data_of_N_FFT[x].real*data_of_N_FFT[x].real+data_of_N_FFT[x].imag*data_of_N_FFT[x].imag)) //得到IFFT宏定义 #define IFFT_RESULT(x) (data_of_N_FFT[x].real/N_FFT) #define PI 3.14159265358979323846264338327950288419716939937510 //圆周率,50位小数 #define PI2 6.28318530717958647692528676655900576839433879875021 #define N_FFT 1024 //傅里叶变换的点数 #define M_of_N_FFT 10 //蝶形运算的级数,N = 2^M #define Npart2_of_N_FFT 512 //创建正弦函数表时取PI的1/2 #define Npart4_of_N_FFT 256 //创建正弦函数表时取PI的1/4 typedef float ElemType; //原始数据序列的数据类型,可以在这里设置 typedef struct //定义复数结构体 { ElemType real,imag; }complex_of_N_FFT,*ptr_complex_of_N_FFT; typedef struct //定义结构体,存储FFT变换后结果信息,复数结果及点所在位置,通过位置能够获得频率信息{complex_of_N_FFT comp; //FFT变换后复数ElemType mod; //复数模值int pos; //位置信息,FFT变换后点所在位置}point_Message; complex_of_N_FFT data_of_N_FFT[N_FFT]; //定义存储单元,原始数据与负数结果均使用之 ElemType SIN_TABLE_of_N_FFT[Npart4_of_N_FFT+1]; /*** 声明函数 *///创建正弦函数表void CREATE_SIN_TABLE(void);ElemType Sin_find(ElemType x); ElemType Cos_find(ElemType x);//变址 void ChangeSeat(complex_of_N_FFT *DataInput);//FFT运算函数 void FFT(void);//IFFT运算函数 void IFFT(void);//初始化FFT程序 void Init_FFT();//结束 FFT运算,释放相关内存 void Close_FFT(void);//产生模拟原始数据输入 ,在实际应用时替换为AD采样数据 void InputData(void);/********读取现有txt数据到数组*/void readtxt(char *str,int len);/*写数据到txtstr:txt文件路径(含文件名)len:读取长度*/ void writetxt(char *str,int len);/***********************************************************************************//* 取复数模函数 getMod() 功能:取复数 a+bi 的模:sqrt(a*a + b*b)输入:输入:complex_of_N_FFT结构体输出:ElemType (float) */ElemType getMod(complex_of_N_FFT data);/* 获得最大频率分量模值对应转换结果,含复数信息,复数模值,位置信息输入:complex_of_N_FFT 结构体,FFT转换后结果数组输出:point_Message 结构体,包含复数信息,点位置信息(FFT转换后点的位置) */point_Message getMaxMod(void); //直接使用数组:data_of_N_FFT #endif //FFT_H二、头文件中函数的具体实现:FFT.c#include stdio.h#include math.h#include FF

文档评论(0)

yxutcangfp + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档