《DSP-快速傅立叶变换(FFT)算法实验》由会员分享,可在线阅读,更多相关《DSP-快速傅立叶变换(FFT)算法实验(10页珍藏版)》请在人人文库网上搜索。

1、中 南 大 学DSP技术实验报告 实验名称:快速傅立叶变换(FFT)算法实验专业班级: 信息0602学生姓名: 张倩曦 (学号:24)指导老师: 陈宁完成日期: 2009年12月2日中南大学信息科学与工程学院快速傅立叶变换(FFT)算法实验一实验目的1掌握用窗函数法设计FFT 快速傅里叶的原理和方法;2熟悉FFT 快速傅里叶特性;3了解各种窗函数对快速傅里叶特性的影响。二实验设备PC 兼容机一台,操作系统为Windows2000(或Windows98,WindowsXP,以下默认为Windows2000),安装Code Composer Studio 2.0 软件。三实验原理1FFT 的原理和。

2、参数生成公式:公式(1)FFT 运算公式FFT 并不是一种新的变换,它是离散傅立叶变换(DFT)的一种快速算法。由于我们在计算DFT 时一次复数乘法需用四次实数乘法和二次实数加法;一次复数加法则需二次实数加法。每运算一个X(k)需要4N 次复数乘法及2N+2(N-1)=2(2N-1)次实数加法。所以整个DFT运算总共需要4N2 次实数乘法和N*2(2N-1)=2N(2N-1)次实数加法。如此一来,计算时乘法次数和加法次数都是和N2 成正比的,当N 很大时,运算量是可观的,因而需要改进对DFT 的算法减少运算速度。根据傅立叶变换的对称性和周期性,我们可以将DFT 运算中有些项合并。我们先设序列长。

3、度为N=2L,L 为整数。将N=2L 的序列x(n)(n=0,1,,N-1),按N的奇偶分成两组,也就是说我们将一个N 点的DFT 分解成两个N/2 点的DFT,他们又重新组合成一个如下式所表达的N 点DFT:一般来说,输入被假定为连续的。当输入为纯粹的实数的时候,我们就可以利用左右对称的特性更好的计算DFT。我们称这样的RFFT 优化算法是包装算法:首先2N 点实数的连续输入称为“进包”。其次N 点的FFT 被连续运行。最后作为结果产生的N 点的合成输出是“打开”成为最初的与DFT 相符合的2N 点输入。使用这一思想,我们可以划分FFT 的大小,它有一半花费在包装输入O(N)的操作和打开输出。

4、上。这样的RFFT 算法和一般的FFT 算法同样迅速,计算速度几乎都达到了两次DFT的连续输入。下列一部分将描述更多的在TMS320C55x 上算法和运行的细节。5程序流程图:四实验步骤(一)第一部分1实验准备:-设置软件仿真模式。-启动CCS。2打开工程。浏览程序,工程目录为C:ICETEK-VC5509-EDULabLab0503-FFTFFT.pjt。3编译并下载程序。4打开观察窗口选择菜单View-Graph-Time/Frequency5清除显示在以上打开的窗口中单击鼠标右键,选择弹出式菜单中“Clear Display”功能。6设置断点在程序FFT.c 中有注释“break poi。

5、nt”的语句上设置软件断点。7运行并观察结果。选择“Debug”菜单的“Animate”项,或按F12 键运行程序。观察“Test Wave”窗口中时域图形;在“Test Wave”窗口中点击右键,选择属性,更改图形显示为FFT。观察频域图形。观察“FFT”窗口中的由CCS 计算出的正弦波的FFT。8退出CCS。9. 实验结果10.源代码(C语言)#include myapp.h#include ICETEK-VC5509-EDU.h#include scancode.h#include #define PI 3.#define SAMPLENUMBER 128void InitForFFT(。

6、);void MakeWave();int INPUTSAMPLENUMBER,DATASAMPLENUMBER;float fWaveRSAMPLENUMBER,fWaveISAMPLENUMBER,wSAMPLENUMBER;float sin_tabSAMPLENUMBER,cos_tabSAMPLENUMBER;main()int i;InitForFFT();MakeWave();for ( i=0;i0 ) b=b*2; i-; /* b= 2(L-1) */for ( j=0;j0 ) /* p=pow(2,7-L)*j; */p=p*2; i-;p=p*j;for ( k=j;。

7、k128;k=k+2*b ) /* for (3) */TR=dataRk; TI=dataIk; temp=dataRk+b;dataRk=dataRk+dataRk+b*cos_tabp+dataIk+b*sin_tabp;dataIk=dataIk-dataRk+b*sin_tabp+dataIk+b*cos_tabp;dataRk+b=TR-dataRk+b*cos_tabp-dataIk+b*sin_tabp;dataIk+b=TI+temp*sin_tabp-dataIk+b*cos_tabp; /* END for (3) */ /* END for (2) */ /* END 。

8、for (1) */for ( i=0;iSAMPLENUMBER/2;i+ ) wi=sqrt(dataRi*dataRi+dataIi*dataIi); /* END FFT */void InitForFFT()int i;for ( i=0;iSAMPLENUMBER;i+ )sin_tabi=sin(PI*2*i/SAMPLENUMBER);cos_tabi=cos(PI*2*i/SAMPLENUMBER);void MakeWave()int i;for ( i=0;iSAMPLENUMBER;i+ )INPUTi=sin(PI*2*i/SAMPLENUMBER*3)*1024;(。

9、二)第二部分1.程序参数说明extern void InitC5402(void)extern void OpenMcBSP(void)extern void CloseMcBSP(void)extern void READAD50(void)extern void WRITEAD50(void)void kfft(pr,pi,n,k,fr,fi,l,il):基2快速傅立叶变换子程序,n为变换点数,应满足2的整数次幂,k为幂次(正整数);数组x :输入信号数组,数据存放于地址为3000H307FH存储 器中,转为浮点型后,生成x数组,长度128;数组mo:FFT变换输出数组,长度128,浮点型。

10、,整型后,写入存储器中。2.子程序流程图:3.启动CCS 2.0,用Project/Open打开“ExpFFT01.pjt”工程文件双击“ExpFFT01.pjt” 及“Source”可查看各源程序;加载“ExpFFT01.out”;4.在主程序中,k+处设置断点5.单击“Run”运行程序或按F5运行程序;程序将运行至断点处停止;6.用View / Graph / Time/Frequency打开一个图形观察窗口;7.单击“Animate”运行程序。或按F10运行,调整观察窗口并观察变换结果。五.实验总结这次DSP技术的实验是在我们学习了数字信号处理、C语言程序设计的先修课程和DSP技术,以及。

11、熟悉了CCS软件之后完成的。实验一我们首先熟悉要用的各种软硬件环境,接下来的实验二和三我们完成了有限冲击响应滤波器(FIR)算法实验和快速傅里叶变换(FFT)算法实验。这次实验我个人认为在以下几个方面收获最大:1. 首先是实验前对自己过去几个学期已学理论知识的巩固加深、综合应用以及对实验相关资料的收集能力的提高。2. 实验中各个部分的要求要理解掌握,认真对待。实验锻炼了我们认真的态度和严谨的精神。3. 当遇到问题和困难的时候,一定要保持冷静,慢慢检查,自己多思考、多尝试,才能获得最终的成功。4. 实验中遇到问题无法解决的时候要主动向同学请教,同时也要乐于帮助同学。我认识到,在实验的过程中要互相信任、互相帮助。通过实验,我们加深了相互间的友情。总之,这次实验让我得到了很多平时理论学习中不能获得的收获,加深了我们对DSP特别是FIR滤波器和FFT算法的原理的理解,并且逐步开始应用于实际。而在个别程序和分析方面存在的不足还需要在今后的学习中慢慢进步。

dsp实现快速傅里叶的C语言程序,DSP-快速傅立叶变换(FFT)算法实验相关推荐

  1. c语言二维图像傅立叶变换,C语言数据结构算法之实现快速傅立叶变换.pdf

    C语语言言数数据据结结构构算算法法之之实实现现快快速速傅傅立立叶叶变变换换 C语语言言数数据据结结构构算算法法之之实实现现快快速速傅傅立立叶叶变变换换 本实例将实现二维快速傅立叶变换,同时也将借此实例 ...

  2. 快速傅立叶变换的C语言实现方法

    转自:http://www.beamsky.com/fft-c-language/ 傅立叶变换的重要性不用我说,想必大家也很清楚,有了傅立叶变换,我们就可以从信号的频域特征去分析信号.尤其在无线通信系 ...

  3. c语言分治法求众数重数_算法实验二 分治法 众数问题.pdf

    算法实验二 分治法 众数问题 算法分析与设计实验二 分治法 主要内容 • 实验目的 • 主要实验仪器设备和环境 • 实验内容 • 实验要求 • 注意点 实验目的 • 理解分治法的基本思想 • 针对特定 ...

  4. 单片机数字滤波c语言程序,单片机系统中数字滤波的算法【C程序整理】

    声明:此内容经本人整理,供大家交流使用.不妥之处,敬请指出.QQ:779589211 吾生有涯 随机误差是有随机干搅引起的,其特点是在相同条件下测量同一个量时,其大小和符号做无规则变化而无法预测,但多 ...

  5. io口控制实验c语言程序,51汇编单片机IO口控制实验

    实验内容 1)  编写程序,用P1.0~P1.2口连LED,查询拨盘开关SW1的状态来控制LED的亮和灭(P1.7口接SW1). 2)  编写程序,用P1.0~P1.2口连LED ,用按键开关KEY1 ...

  6. c语言实现1024点fft程序,C语言1024点快速傅里叶变换(FFT)程序,最好经过优化,执行速度快...

    voidfft(){intnn,n1,n2,i,j,k,l,m,s,l1;floatar[1024],ai[1024];//实部虚部floata[2050];floatt1,t2,x,y;floatw ...

  7. 怎么样把c语言和单片机融合,求助怎么把两个单片机c语言程序结合在一起?大一期末实验...

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 /* DS18B20数字温度传感器 (温度控制) 实验连线 单片机的P3.3连接DS18B20单元的 DQ 单片机的P3.2连接继电器单元的 JIN 继电 ...

  8. 并行DA实验c语言程序,求助怎么把两个单片机c语言程序结合在一起?大一期末实验...

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 /* DS18B20数字温度传感器 (温度控制) 实验连线 单片机的P3.3连接DS18B20单元的 DQ 单片机的P3.2连接继电器单元的 JIN 继电 ...

  9. c代码实现 ifft运算_fft算法c语言_matlab fft算法_ifft c语言

    FFT快速算法C程序_工学_高等教育_教育专区.电子信息工程综合课程设计报告书 DSP 课程设计 报告 题学 目: 院: FFT 快速算法 C 程序 计算机与信息工程学院 09 ... fft算法代码 ...

最新文章

  1. 3ds max 把模型放置到坐标系中心(原点)
  2. C#生成CHM文件(外篇使用hha.dll)
  3. 文件操作:fread()和fwrite()
  4. JS向对象中添加和删除属性
  5. AMQP Connection 127.0.0.1:5672] ERROR [o.s.a.rabbit.connection.CachingConnectionFactory] CachingConn
  6. linux阻止程序,Linux:阻止某些应用程序/主机名的IPv6
  7. 如何安装Vmware ESXi 6.7(图文介绍)
  8. 红茶三杯的博客-一个IE的博客
  9. CCF推荐+SCI二区期刊征收AI方向特刊|确定3个月出录用结果
  10. 世界已进入第四次产业革命——大数据时代
  11. 计算机辅助设计基础试题,CAD基础试题「附答案」
  12. PLC模拟量传输过程
  13. paper fast review :Deep Residual Shrinkage....
  14. 计算机控制的节能路灯系统,路灯与PLC自动控制系统
  15. 计算机组成原理-唐朔飞 学习指导与习题解答 第2版
  16. imx6 kernel boog log
  17. 一文读懂Java 垃圾回收机制
  18. JAVA Spring 事务管理事务不回滚问题
  19. 编程习题练习记录--台球碰撞
  20. linux的wq 与wq的区别,Linux ESC :wq 和:wq!的区别

热门文章

  1. springboot 启动退出终端不停止
  2. Easyui动态加载后台数据的例子
  3. JSON中的JSON.parseArray()、JSON.parseObject()、JSON.tojsonString()
  4. 使用Collections.emptyList()生成的List不支持add方法___Java Collections.emptyList方法的使用及注意事项
  5. Java后端 + 百度SDK实现人脸识别
  6. .某学校的学生公寓有14栋楼,用A~N这14个大写字母的其中一个代表楼号,每栋楼的层数为6层,用1~6六个数字表示。每层楼有40个房间,编号为01~40。具体表示一个宿舍房间时,用1个字母加3位数字表
  7. redis发布订阅c接口_Redis 发布/订阅机制原理分析
  8. php分列显示,【杂谈】PHP数组怎样按键名完成降序分列
  9. 网站服务器怎么用手机登录不了怎么办,怎么打不开服务器列表了?
  10. mysql锿法_MySQL基本用法