- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
- 2.研制报告模板2.研制报告模板.doc
- 20 5s全套教程20 5s全套教程.doc
- 2.快捷键训练2.快捷键训练.doc
- 2007建造师管理2007建造师管理.doc
- 17万平米水源热泵17万平米水源热泵.doc
- 1联亚物资公司1联亚物资公司.doc
- 2007模拟题2007模拟题.doc
- 2008起搏指南2008起搏指南.ppt
- 2008调研报告2008调研报告.doc
- 2.1_受体学说2.1_受体学说.pdf
- 第十一章 电流和电路专题特训二 实物图与电路图的互画 教学设计 2024-2025学年鲁科版物理九年级上册.docx
- 人教版七年级上册信息技术6.3加工音频素材 教学设计.docx
- 5.1自然地理环境的整体性 说课教案 (1).docx
- 4.1 夯实法治基础 教学设计-2023-2024学年统编版九年级道德与法治上册.docx
- 3.1 光的色彩 颜色 电子教案 2023-2024学年苏科版为了八年级上学期.docx
- 小学体育与健康 四年级下册健康教育 教案.docx
- 2024-2025学年初中数学九年级下册北京课改版(2024)教学设计合集.docx
- 2024-2025学年初中科学七年级下册浙教版(2024)教学设计合集.docx
- 2024-2025学年小学信息技术(信息科技)六年级下册浙摄影版(2013)教学设计合集.docx
- 2024-2025学年小学美术二年级下册人美版(常锐伦、欧京海)教学设计合集.docx
文档评论(0)