该作品为2007年全国电子设计大赛D题,题目要求如下:

  这个东西的目的就是做一个截止(中心)频率可调,通带类型可调(低通,高通)的程控滤波器,大二上学期用运放搭的状态变量滤波器实现过该功能,这次打算学习一下数字滤波器的实现,顺便把程控滤波器的题目再做一遍。
  实现数字滤波可以用单片机或者FPGA,一开始没有头绪,不知道用啥,所以打算边做边看。
  一开始就看中了IIR(无限冲激响应)滤波器,为啥呢,,因为有传递函数,设计方法和模拟滤波器差不多,,相对熟悉,,
  在网上找了两天资料,SystemView,DSPBuilder都看了下,,发现还是手写代码好,然后看了下matlab的simulink,打算先用simulink仿真下,看看效果、找找感觉,,折腾了两天,于是有了下面的东西。。。

图1,画的simulink仿真图,,串联型,并联型都试了下,,发现还是串联的好使

图2,仿真结果,完美的实现了预期要求,,
于是就开始用C语言按照这个simulink的结构图又仿真了下,,效果不错,于是开始写FPGA代码了

图3,modelsim仿真结果

图4,仿真的各种数据,调试的很大一部分工作量就是拿这里面的数据和C语言仿真的数据做对比,看哪一步出问题了,然后改,,最后改完了,几百万个仿真数据和C语言仿真数据一个不差,,这种感觉真舒服,,,

图5、quartus最后综合出来的模块图

图6,signalTab仿真,,同样,和C语言仿真结果一模一样的


图7,滤波器内部结构图,滤波器的系数全存放在RAM里面,FPGA滤波计算时从RAM中读取系数,单片机通过SPI接口修改RAM内数据,从而达到程控功能。

  FPGA完成了,再就是单片机部分了,FPGA实现了可以更改滤波器各级系数的功能,但是系数哪里来呢,刚开始是查表,,比如要实现低通,截止频率1Khz,2Khz的两种滤波器,就用matlab生成这两种滤波器的系数,然后存放到单片机里面,但这样显然不太方便,于是大二放寒假后写了一个IIR滤波器设计函数库,可以直接根据滤波器指标生成巴特沃斯、切比雪夫I型、切比雪夫II型滤波器的系数,这样就方便多了,这个函数库可以实现100阶以内的巴特沃斯、切比雪夫Ⅰ型、切比雪夫Ⅱ型滤波器系数生成,通带类型可实现高通、低通、带通、带阻。


图8、三个函数,分别可以生成巴特沃斯、切比雪夫I型、切比雪夫II型滤波器系数

图9、负责约束滤波器指标的结构体


图10、利用这个代码库和C# WPF模仿matlab的filter designer写了一个小工具,可以实现filter designer的部分功能,还可以生成matlab验证代码,图中右边部分即为小工具生成系数对应的数字滤波器的幅频特性和相频特性。

图11,部分代码

IIR数字程控滤波器相关推荐

  1. 通用的一阶IIR数字高通滤波器的实现

    通用的一阶IIR 数字高通滤波器的实现 书接上回 开始推算 浮点转定点 最后 书接上回 上一篇讲述了一阶IIR滤波器的一些特点,并设计了一个高通的IIR.实际应用中往往需要动态调整滤波器的参数满足不同 ...

  2. 如何利用CIC滤波器、CIC补偿滤波器和半带滤波器设计一个高频数字抽取滤波器

    设计了采样频率为640 MHz.过采样率为64的高频数字抽取滤波器.该数字抽取滤波器由CIC(Cascaded Integrator Comb)滤波器(降16倍).CIC补偿滤波器(降2倍)和半带滤波 ...

  3. 数字形态学滤波matlab,数字形态学滤波器与智能车路径记忆

    引言本文引用地址:http://www.eepw.com.cn/article/95469.htm "飞思卡尔"杯全国大学生智能车竞赛规则明确指出,智能车在赛道上连续跑两圈,并记录 ...

  4. 国威WS824(5D)数字程控用户交换机的简单PK

    国威WS824(5D)数字程控用户交换机的简单PK 三种类型主机结构区分: WS824(5D)-1 型安装结构示意图: 分机板:分机板分为三种008C.008A.008L. 008C分机板上的分机端口 ...

  5. 基于Matlab App Designer的语音信号分析与处理(二):IIR和FIR滤波器的设计,语音信号的滤波

    接上文:https://blog.csdn.net/weixin_53877178/article/details/122470759 目录 一.课题的任务 二.内容.步骤和要求 (1)语音信号的采集 ...

  6. 关于FPGA实时数字FIR滤波器的实现

    数字信号处理小白,请教个问题:使用K7实现数字信号低通滤波,信号采样率10KHz,每秒10k数据,进行在线FIR滤波时,数据是如何作为输入给滤波器的?比如128阶滤波器,128个信号是先入先出?新的信 ...

  7. IIR数字低通滤波器

    即令Ha(s)->H(z),两种要求: 1.因果转换后仍是因果稳定的 2.数字滤波器的频率响应模仿模拟滤波器的频响 两种方法: 1.脉冲响应不变法:数字频率与模拟频率成线性关系 2.双线性变换法 ...

  8. 基于LTC1068的程控滤波器

    一 项目功能介绍 该装置包括放大器增益可调和滤波器工作模式及工作频率可调.此装置可广泛应用于信号处理.仪器仪表和工业控制等方面.以下为详细功能介绍: (1)放大器输入正弦信号电压峰峰值为20mV,电压 ...

  9. iir陷波滤波器 matlab,IIR数字滤波器设计50Hz陷波器(MATLAB代码)

    %% IIR陷波器设计 % 目的:设计一个陷波器阻带在50±1.5Hz以内,采样频率为400Hz的滤波器, % 并要求通带最大衰减为0.1dB,阻带最小衰减为60dB. clc; clear;clos ...

  10. 【CIC滤波器】基于MATLAB/FPGA的数字CIC滤波器的设计

    FPGA代码: module down(i_clk,//输入时钟i_rst,//输入复位信号i_M, //抽取值i_data,//输入信号o_data,//输出信号r_clk);input i_clk ...

最新文章

  1. msf 启动报[-] * WARNING: No database support: No database YAML file解决方法
  2. macbook pro 识别不到外接显示器
  3. python语言实例-Python语言实现百度语音识别API的使用实例
  4. 这是我看过最好的Java编程入门视频教程!
  5. 智力+贪心的过河问题
  6. 抽奖系统的流量削峰方案
  7. layui Form内容重置清空
  8. yum yum doesn‘t match version of Python 终极解决方案
  9. python实现将文件下内每张图片按顺序命名为txt文本文件中的内容
  10. dubbo和zookeper使用_Dubbox与Zookeeper简介及入门小案例
  11. 学习笔记:CentOS7学习之十八:Linux系统启动原理及故障排除
  12. c51单片机时钟程序汇编语言,51单片机数字钟汇编程序精选.docx
  13. html + css 实现淘宝首页(静态页面)
  14. 网页导出的excel无法计算机,网页上不能导出excel表格数据-如何将网页表格导出到excel...
  15. 系统设计:API 接口的最佳实践
  16. java代理模式的应用场景
  17. 中标麒麟桌面系统自定义屏保
  18. 为你的博客引入——今日诗词、每日一言(js插件分享)
  19. uniapp中进行地图定位
  20. 微信小程序开发语言和“前端三件套”的异同点

热门文章

  1. 高频课程实验:无线传输系统设计
  2. 风险管理-输入、输出、工具和技术
  3. .jpg .png .jpeg图片转.eps矢量图的python脚本
  4. android多个单选框超格,福昕PDF阅读器打印时提示“打印机被意外删除了”怎么处理?...
  5. 课程设计 - 运动控制卡(云服务器)
  6. HashMap底层原理与扩容机制
  7. 蔡勒星期算法 c语言,C/C++根据年月日计算星期几(蔡勒公式篇)
  8. hivesql 列转行,并用逗号分隔
  9. cad在哪里设置图幅大小_CAD新建图纸怎么设置视图范围太小?
  10. AHRS互补滤波(Mahony)算法及开源代码