FPGA的FIR抽取滤波器设计
FPGA的FIR抽取滤波器设计
FPGA的FIR抽取滤波器设计用FPGA实现抽取滤波器比较复杂,主要是因为在FPGA中缺乏实现乘法运算的有效结构,现在,FPGA中集成了硬件乘法器,使FPGA在数字信号处理方面有了长足的进步。
本文介绍了一种采用Xilinx公司的XC2V1000实现FIR抽取滤波器的设计方法。
具体实现结构设计基于抽取滤波器的工作原理,本文采用XC2V1000实现了一个抽取率为2、具有线性相位的3阶FIR抽取滤波器,利用原理图和VHDL共同完成源文件设计。
图1是抽取滤波器的顶层原理图。
其中,clock是工作时钟,reset是复位信号,enable是输入数据有效信号,data_in(17:0)是输入数据,data_out(17:0)是输出数据,valid是输出数据有效信号。
adder18是加法器模块,mult18是乘法器模块,acc36是累加器模块,signal_36to18是数据截位器模块,fir_controller是控制器模块。
控制器定时向加法器、乘法器和累加器发送数据或控制信号,实现流水线操作。
图1 抽取滤波器顶层原理图控制器控制器是抽取滤波器的核心模块,有两个功能:一是接收输入数据,二是向其它模块发送数据和控制信号。
它根据加法器、乘法器和累加器的时序特性,有规律地向加法器发送抽头数据,向乘法器发送系数,向累加器发送控制信号,让加法器、乘法器和累加器在每个时钟周期都完成指定的任务,从而实现流水线操作。
控制器用VHDL语言描述,用寄存器存放抽头和系数。
加法器加法器的输入和输出都是18 bit,用VHDL语言描述实现。
它有两个工作时钟的延迟,在输入数据准备好的情况下,第一个时钟得出相加结果,第二个时钟把相加结果锁存输出。
乘法器乘法器为18 bit输入,36bit输出,用库元件MULT18X18S和36 bit锁存器实现。
MULT18X18S是XC2V1000自带的18×18bit硬件乘法器,单个时钟就可完成乘法运算。
基于FPGA的FIR滤波器设计
该单元 实现 的功能是将输人数据 移位 存储到移位寄存器
中 。对 FR滤 波 器 进 行 分 析 可 知 : 于 每 次 采 样 , 需 要 利 用 I 对 都 本 次 采 样 之 前 的 N 1 采 样 值 ( 处 采样 值 N 1 9, 样 N 一个 此 一 为 )这
号 xt AD转换后 , 成数 字滤波 器 Hz的输入信 号 x )它 经 / ( ) 形 ( ) (, n
是 一 组 由模 拟 信 号 经过 取 样 和 量 化 的数 字 量 ,数 字 滤 波 器 的
1
输 出信号 y ) ( 经过 DA转换恢 复为去噪的模拟信号 y) yn n / (或 () t
r l a i f an m o ls o I I r ial , e ( h y tm i uat n a d v ii in o I ie s eai t z on o i due fF R t s Fn l w m e y 3 t e s se sm I i n er c o fF R ft r o o f at l a g i m ; srb t l r h l orh ditiu e ago i m t t
me t ot iesto hn) nsq o u ain h n i aya 30 1 n( rhUnvri f ia; i ,f ct , ax i n0 0 5 ) N y C Mi t Ed oS T u
摘 要: 数字 滤波 器在数 字信 号处理 中占有很 重要 的地位 , 该文介 绍 了 FR滤 波 器的两种 实 现算法 : I 乘累 加算 法和
Zh n a me,h o Do g- ,e g Ya j nYuSh ngs’ feadT cn lg nEe— a gXio- i a n eF n n-u , ua (( l n eh o y lc Z i c P o 0
基于FPGA的FIR滤波器设计
基于FPGA 的FIR 滤波器设计一 、设计目的为了帮助学生深入理解和消化基本理论、进一步提高综合应用能力并且锻炼独立解决问题的能力,我们将《数字信号处理》、《集成电路原理与应用》和《《FPGA 系统设计与应用》几门课程融合在一起开设的FPGA 综合实验课程设计。
本次完成的是利用FPGA 来完成FIR 滤波器的设计、程序设计和实验调试任务。
二、设计要求(1)基本要求利用所学知识,采用VHDL 语言完成FIR 滤波器的设计仿真。
要求用VHDL 编程设计底层文件,顶层文件可任意(可用原理图方式或文本方式);完成仿真文件(包括MATLAB 和QUARTUSII 两种仿真)并对其结果比较。
具体设计指标如下: (1)采样频率S F =80KHz ;(2)截止频率KHz F C 10=;(3)输入序列为10位(最高位为符号位); (4)窗口类型为kaiser 窗,β=0.5 ; (5)滤波器长度为16 ; (6)输出结果保留10位。
(2)提高部分根据所学知识,设计出一个具有频率控制功能DDS ,要求输出频率分别为10KHz 和100KHz ,将输出的两路数字信号进行叠加,并通过所设计的FIR 滤波器进行滤波,将滤波输出的数字信号通过D/A 转换电路输出波形,并用示波器观察输出波形,并完成测试结果分析。
结构框图如图1-1所示。
图2-1 整体结构框图三、设计原理3.1 FIR 滤波器由线性系统理论可知,在某种适度条件下,输入到线性系统的一个冲击完全可以表征系统。
当我们处理有限的离散数据时,线形系统的响应(包括对冲击的响应)也是有限的。
若线性系统仅是一个空间滤波器,则通过简单地观察它对冲击的响应,我们就可以完全确定该滤波器。
通过这种方式确定的滤波器称为有限冲击响应(FIR)滤波器。
3.2 线性FIR 滤波器原理FIR 滤波器响应(简称FIR )系统的单位脉冲响应()h n 为有限长序列,系统函数()H z 在有限z 平面上不存在极点,其运算结构中不存在反馈支路,即没有环路。
基于FPGA的高速FIR数字滤波器设计的开题报告
基于FPGA的高速FIR数字滤波器设计的开题报告一、选题意义数字信号处理是一种关键技术,广泛应用于通信、雷达、音视频处理等领域。
而数字滤波器是数字信号处理的重要组成部分之一,用于移除信号中的噪声、加强特定频率成分等。
FIR数字滤波器是一种广泛应用的数字滤波器,它具有运算速度快、实现简单等特点。
FPGA作为一种可编程逻辑器件,具有可重构性、高速度、低功耗、高可靠性等优点,在数字信号处理领域得到了广泛应用。
本课题旨在利用FPGA高性能特点,设计开发一种基于FPGA的高速FIR数字滤波器,满足在特定应用场景下对信号的快速处理需求,具有重要的理论意义和实际应用价值。
二、主要内容1. 对FIR数字滤波器的算法原理进行分析和设计,包括常见的窗函数设计、有限脉冲响应设计等,选择比较优的算法。
2. FPGA数字滤波器的硬件设计,包括数据的输入输出接口、滤波算法实现和时序控制器设计。
3. FPGA数字滤波器的仿真设计,包括基于MATLAB的算法仿真和基于ModelSim的硬件仿真等。
4. FPGA数字滤波器的实现与验证,包括采用相应工具对FPGA数字滤波器进行编译下载,将实验结果与仿真结果进行比较与分析。
5. 对设计的FPGA数字滤波器进行性能测试,包括运算速度、滤波效果等方面的测试,将其结果与已有的数字滤波器进行对比分析。
三、技术路线1. 确定常见的FIR数字滤波器设计算法,并选择较优的算法设计数字滤波器。
2. 设计FPGA数字滤波器的硬件结构,包括输入输出模块、滤波模块和时序控制模块等;并根据所选算法设计硬件逻辑。
3. 采用MATLAB进行设计算法的理论分析,从理论上验证算法的优越性。
4. 采用ModelSim进行硬件电路仿真,进行设计参数调整和错误修正,保证硬件逻辑的正确性和同步性。
5. 采用Quartus II进行编译下载,将设计的FPGA数字滤波器实现于FPGA芯片中,测试其性能。
四、研究难点1. 在设计算法时,需要充分了解各种滤波器设计算法的优缺点,并选择适合特定场景的算法。
基于FPGA的FIR滤波器设计与仿真
数字滤波器; 分布 式 算 法 ;P A FG 中图分 类 号 T 3 1 P 1 文 献标 志 码 A
滤波器需 要执行 无 限数量 卷 积 , 能得 到较 好 的 幅度特性 , 相位 特性 其 是非线性 的 ; I 波器 由有 限个 采样 值 组 成 , 构 成 的系 统总 是稳 FR滤 其 定 的 , 易于实现 线性相 位 …. 且 由于 在语音 信 号处 理 、 图像 处理 、 数字 通信等传 输过程 中不能有 明显 的相位失真 , FR滤波器在 满足一定 而 I 对称条件 下可 以实现 I I R滤波器 难 以实 现 的线 性相 位 , 因而得 到广泛
特 别适合如 FR、丌 等数 字信号处 理任务 . I F 利用 F G P A可 以重 复配置 高精 度的 FR滤波器 , 用 V D I 使 H L硬件 描述语 言改变滤 波器 的系数和
阶数 , 能实 现大 量 的卷 积运 算算 法 J 结合 M xls 具软 件 的辅 并 . apu 工
案速 度 快 、 时性 好 、 省 硬 件 资 源 , 实 节 具 有重 要 的 工程 应 用价 值 . 关 键 词
实 现数字化 是 控 制 系统 的重 要发 展 方 向 , 而数 字 信 号处 理 已在
通信 、 语音 、 图像 、 自动控 制 、 达 、 事 、 空 航 天等 领 域 广 泛应 用 . 雷 军 航 数 字信号 处 理 方 法 通 常 涉 及 变 换 、 波 、 谱 分 析 、 码 解 码 等 处 滤 频 编 理¨. 数字滤 波是数 字信号处 理重 要 环节 , 它能 满 足滤 波器 对幅度 和 相 位特性 的严格 要 求 , 克服 模 拟 滤 波器 所 无 法解 决 的 电压 和 温度 漂 移 以及噪声 等 问题 , 而有 限冲激 响应 FR滤 波器在设计 任意 幅频 特性 I 的同时能够保证 严格 的线性相 位特性 . 数 字滤波器 根 据其 冲激 响应 函数 的 时域 特性 , 分 为无 限 长 冲 可
fir数字滤波器的设计与实现
FIR数字滤波器的设计与实现介绍在数字信号处理中,滤波器是一种常用的工具,用于改变信号的频率响应。
FIR (Finite Impulse Response)数字滤波器是一种非递归的滤波器,具有线性相位响应和有限脉冲响应。
本文将探讨FIR数字滤波器的设计与实现,包括滤波器的原理、设计方法和实际应用。
原理FIR数字滤波器通过对输入信号的加权平均来实现滤波效果。
其原理可以简单描述为以下步骤: 1. 输入信号经过一个延迟线组成的信号延迟器。
2. 延迟后的信号与一组权重系数进行相乘。
3. 将相乘的结果进行加和得到输出信号。
FIR滤波器的特点是通过改变权重系数来改变滤波器的频率响应。
不同的权重系数可以实现低通滤波、高通滤波、带通滤波等不同的滤波效果。
设计方法FIR滤波器的设计主要有以下几种方法:窗函数法窗函数法是一种常用简单而直观的设计方法。
该方法通过选择一个窗函数,并将其与理想滤波器的频率响应进行卷积,得到FIR滤波器的频率响应。
常用的窗函数包括矩形窗、汉宁窗、哈密顿窗等。
不同的窗函数具有不同的特性,在设计滤波器时需要根据要求来选择合适的窗函数。
频率抽样法频率抽样法是一种基于频率抽样定理的设计方法。
该方法首先将所需的频率响应通过插值得到一个连续的函数,然后对该函数进行逆傅里叶变换,得到离散的权重系数。
频率抽样法的优点是可以设计出具有较小幅频纹波的滤波器,但需要进行频率上和频率下的补偿处理。
最优化方法最优化方法是一种基于优化理论的设计方法。
该方法通过优化某个性能指标来得到最优的滤波器权重系数。
常用的最优化方法包括Least Mean Square(LMS)法、Least Square(LS)法、Parks-McClellan法等。
这些方法可以根据设计要求,如通带波纹、阻带衰减等来得到最优的滤波器设计。
实现与应用FIR数字滤波器的实现可以通过硬件和软件两种方式。
硬件实现在硬件实现中,可以利用专门的FPGA(Field-Programmable Gate Array)等数字集成电路来实现FIR滤波器。
基于FPGA的异步FIR滤波器接口电路设计
be i gn
f ( 3 ; > =2 k= o k= 3 k r ; k一1 )
i k==2 a 2 <=dti; f ( )rm[ ] aa n es rm[ ]<= a k一1 ; l a k e rm[ ]
EN 1< = ~EN 1 S S :
e ndo
率 的情况下 , 可能少地使用硬件资源 , 口设计 尽 接
。
位 ) 累加 器完 成前 一 级乘 积 与后 一 级 乘积 的 累加 。 ( 定有符 号数 累加模 块 的累加 和输 出为 2 ) 设 1位 。 本设计 将 数据运 算模 块设 计 成 一个 以 E N S 1使
图 3 异 步 FR 滤 波 器 接 口设 计 原 理 框 图 I
能 的有 限状态 机 , 存在 4种状 态 。 共
D :0 3 6 /.sn 10 —8 4 2 1 . 1 0 1 OI 1 . 9 9 j i .0 13 2 .0 2 0 . 2 s
基 于 F GA 的异 步 F R 滤 波 器接 口电路 设 计 P I
李 鸿 , 叶 燕
( 湘潭 职业技术学 院, 湖南 湘潭 4 10 ) 1 12
摘
要 : 绍 了基 于 四相 单轨 握 手 协议 的 异 步 FR 滤 波 器接 1 介 I : 2电路 的设 计 。 分 析 了异 步 接 口 电路 互 联 模 型 及 原
理 , 出了一种基 于存储 器和状 态机 实现异步握 手接 口电路 的全新 方案 , 提 实现 了 FR滤波器功 能和异步接 口控 制 I 功 能。对设计进行 了波形仿真及结果分析 , 验证 了设 计方案的可行性。
表 1 F R 滤 波 器 系数 I
浮点形式 二进制形式 浮点形式 二进制形式
基于FPGA的FIR数字滤波器设计与仿真
a in ls p rto , so ai n o h p n . I l r i w d l s d b c u e o t t c h s itrin a d s a p c t o s s a e a ain r t r t rs a ig F R f t s i ey u e e a s fi s i tp a e d s t o n h r u — f g e o i e s r o
c a a trsi. h a i h o yo i i lf tra d t e meh d o a iai n a e r s a c e . h e i n o e rq i d d gt l h r c e i cT eb sc t e r fd gt le n h t o f e l t r e e r h dT e d sg ft e u r ii t a i r z o h e a i e sgv n u ig t e smu ae s f r fMAT AB.n h i l t r s l i ie . f tri ie sn h i lt o t a e o l w L a d t e smua e e u t sgv n Ke r sf t r d gt l c nr ls se / cl y i sal t n r v e d sr u e l oi m ; n o f n t n y wo d :i e ; ii ; o to y t msf i t n tl i e iw; it b t d ag rt l a a i ao i h wi d w c i u o
y∑c]2 + b2f = 【l ∑X ] n一 [ n
n = 0 L = 0 J
( 3 )
分 布 式 算 法 是 一 种 以 实 现 乘 加 运 算 为 目的 的运 算 方 法 。 它 与传 统 算 法 实 现 乘 加 运 算 的 不 同 在 于执 行 部 分 积 运 算 的先 后顺序。 该算 法 利 用一 个 查 找 表 (U ) 现 映射 , 用 一 个 2 L T实 即 字 宽 、 先 编 好 程 序 的 L T接 收 一个 Ⅳ 位 输 入 向 量 X= 】 预 U I 【 , x0 %[ , , [- l 映 射 , 查 找 表 的 查 找后 直接 输 出 部 分 积 。 1 … x N l】 】  ̄ 的 经 与传 统 算 法 相 比 , 布式 算 法 可 极 大 的 减 少 硬 件 电路 的规 模 , 分
基于FPGA的FIR滤波器的设计(毕业设计) 可用
目录摘要 (2)英文摘要 (3)1 引言 (3)1.1国内外研究现状 (4)1.2本论文的研究内容及主要工作 (6)2 FIR数字滤波器设计 (6)2.1数字滤波器基础 (6)2.1.1 数字滤波器简介 (6)2.1.2 FIR数字滤波器的结构 (7)2.2 FIR数字滤波器设计方法 (8)2.2.1 窗函数法 (8)2.2.2 频率采样法 (9)2.2.3 等波纹最佳逼近法 (11)2.2.4 三种设计方法的比较......................... 错误!未定义书签。
3 FPGA 设计优点以及分布式算法 (12)3.1 使用FPGA器件进行开发的优点 (13)3.2分布式算法 (14)3.2.1 分布式算法基础 (14)3.2.2 有符号的DA系统 (15)4 基于FPGA的FIR滤波器设计 (15)4.1基于M ATLAB的FIR数字低通滤波器抽头系数的提取 (16)4.1.1 滤波器的设计指标 (16)4.1.2 滤波器的具体设计方法 (16)4.1.3 参数提取与量化 (17)4.2FIR滤波器的FPGA实现 (19)4.2.1 模块划分 (19)4.2.2 FIR滤波器各模块的实现 (20)4.2.3 FIR滤波器的顶层设计 (30)4.3FIR滤波器的系统仿真验证 (32)4.4系统硬件 (36)4.4.1 系统框图 (36)4.4.2 部分芯片简介 (36)4.4.3 AD、DA电路原理图 (39)4.5测试波形及现场照片 (39)4.6数据误差分析 (40)结论 (41)参考文献 (41)附件 (42)基于FPGA的FIR滤波器的设计摘要:本文设计了一个基于FPGA的16阶FIR低通滤波器,使用分布式算法作为滤波器的硬件实现算法,并对其进行了详细的讨论。
针对分布式算法中LUT规模过大的缺点,采用多块查找表的方式减小硬件规模。
在设计中采用了自顶向下的层次化、模块化的设计思想,将整个滤波器划分为多个模块,利用VHDL语言的描述方法进行了各个功能模块的设计,最终完成了FIR数字滤波器的系统设计。
FIR滤波器设计与实现实验报告
FIR滤波器设计与实现实验报告目录一、实验概述 (2)1. 实验目的 (3)2. 实验原理 (3)3. 实验设备与工具 (4)4. 实验内容与步骤 (6)5. 实验数据与结果分析 (7)二、FIR滤波器设计 (8)1. 滤波器设计基本概念 (9)2. 系数求解方法 (10)频谱采样法 (11)最小均方误差法 (14)3. 常用FIR滤波器类型 (15)线性相位FIR滤波器 (16)非线性相位FIR滤波器 (18)4. 设计实例与比较 (19)三、FIR滤波器实现 (20)1. 硬件实现基础 (21)2. 软件实现方法 (22)3. 实现过程中的关键问题与解决方案 (23)4. 滤波器性能评估指标 (25)四、实验结果与分析 (26)1. 实验数据记录与处理 (27)2. 滤波器性能测试与分析 (29)通带波动 (30)虚部衰减 (31)相位失真 (32)3. 与其他设计方案的对比与讨论 (33)五、总结与展望 (34)1. 实验成果总结 (35)2. 存在问题与不足 (36)3. 未来发展方向与改进措施 (37)一、实验概述本次实验的主要目标是设计并实现一个有限脉冲响应(Finite Impulse Response,简称FIR)滤波器。
FIR滤波器是数字信号处理中常用的一种滤波器,具有线性相位响应和易于设计的优点。
本次实验旨在通过实践加深我们对FIR滤波器设计和实现过程的理解,提升我们的实践能力和问题解决能力。
在实验过程中,我们将首先理解FIR滤波器的基本原理和特性,包括其工作原理、设计方法和性能指标。
我们将选择合适的实验工具和环境,例如MATLAB或Python等编程环境,进行FIR滤波器的设计。
我们还将关注滤波器的实现过程,包括代码编写、性能测试和结果分析等步骤。
通过这次实验,我们期望能够深入理解FIR滤波器的设计和实现过程,并能够将理论知识应用到实践中,提高我们的工程实践能力。
本次实验报告将按照“设计原理设计方法实现过程实验结果与分析”的逻辑结构进行组织,让读者能够清晰地了解我们实验的全过程,以及我们从中获得的收获和启示。
FIR数字滤波器设计及其FPGA实现
中 图分 类 号 :T P T 1 3 文 献 标 识 码 :A 文 章 编 号 :1 6 7 4 — 7 7 2 0( 2 0 1 3 ) 1 9 — 0 0 2 2 — 0 3
FI R d i g i t a l f i l t e r d e s i g n a n d i mp l e me n t a t i o n o n FPGA
Ab s t r a c t :B a s e d o n t h e F P GA h a r d wa r e p l a t f o m ,t r h e d i g i t a l F I R f i l t e r mo d e l i s d e s i g n e d b y u s i n g DS P B u i l d e r o f F P GA t oቤተ መጻሕፍቲ ባይዱ
s i m u l a t e s y s t e m mo d e l a n d g e n e r a t e t h e V H D L p r o j e c t l f i e s ,o r g a n i z e t h e c o r r e s p o n d i n g t o p p r o g r a m t o i f t w i t h t h e h a r d w a r e s y s t e m
一种基于FPGA的分布式FIR数字滤波器设计
i m F R p s ii f t scr u t o x mp e t i e n i h o g f h U r h o I lw a sd gt l r ic i fre a l ,i lme t n t r u h o e L T,a d r n h h f rg s r F — t f o l ai e s mp o t d e dt e s i e it . i a t e n n h it b td a g rt m i lt d n h e ut h w t a e o t l tu t r al f ciey a p id i i l s a y t e d s u e l o h i s i r i s mu ae ,a d t e rs l s o h t h p i s t ma sr cu ec l ef t l p l n w r e s e v e e sain dg t in r c s ig mo u e tt ii s a p o e sn d l ,w i h h s u e il r g a o l a gl h c a s d o F ed P o r mma l t ra a d r e o r e f c iey f b e Gae A r y h r wae r s u c s ef t l e v
FIR数字滤波器设计实验_完整版
FIR数字滤波器设计实验_完整版FIR数字滤波器设计实验是一种以FIR(Finite Impulse Response)数字滤波器为主题的实验。
在这个实验中,我们将学习如何设计和实现一个FIR数字滤波器,以滤除特定频率范围内的噪声、增强信号或实现其他特定的信号处理功能。
以下是一个可能的FIR数字滤波器设计实验的完整版实验步骤和要求:实验目的:1.学习FIR数字滤波器的基本原理和设计方法。
2. 熟悉Matlab等数字信号处理软件的使用。
3.实践设计和实现一个FIR数字滤波器,以实现特定的信号处理功能。
实验步骤:1.确定实验所需的信号处理功能。
例如,设计一个低通滤波器以滤除高频噪声,或设计一个带通滤波器以增强特定频率范围内的信号。
2.确定数字滤波器的规格。
包括截止频率、滤波器阶数、滤波器类型(低通、高通、带通、带阻)等。
3. 使用Matlab等数字信号处理软件进行设计和仿真。
根据信号处理功能和滤波器规格,选择合适的设计方法(如窗函数法、频率采样法等),并设计出数字滤波器的系数。
4.对设计的数字滤波器进行性能评估。
通过模拟信号输入和滤波输出、频率响应曲线等方式,评估滤波器在实现信号处理功能方面的性能。
5.利用硬件平台(如DSP处理器、FPGA等)实现设计的FIR数字滤波器。
根据设计的滤波器系数,编程实现滤波器算法,并进行实时信号处理和输出。
同时,可以利用外部信号源输入不同类型的信号,进行滤波效果验证和性能测试。
6.对滤波器设计和实现进行综合分析。
根据实际效果和性能测试结果,分析滤波器设计中的优缺点,并提出改进方案。
实验要求:1.理解FIR数字滤波器的基本原理和设计方法。
2. 掌握Matlab等数字信号处理软件的使用。
3.能够根据信号处理要求和滤波器规格,选择合适的设计方法并设计出满足要求的滤波器。
4.能够通过模拟和实验验证滤波器的性能。
5.具备对滤波器设计和实现进行综合分析和改进的能力。
通过完成上述实验,学生可以深入理解FIR数字滤波器的原理和设计方法,掌握数字信号处理软件的使用,提升数字信号处理的实践能力,并了解数字滤波器在实际应用中的重要性和价值。
基于FPGA的FIR滤波器系统的设计
针对 F R滤 波器 电路 系 统 , 计 了一个 与 之 I 设 专 门配套 的 串 口通 信 软 件 , 软件 能 读 取 串 口数 该 据 , 把 串 口数 据保 存在 以 D T为 后 缀名 的文 件 并 A
个滤 波 系数 , 这些 滤波 系数 来 生成 FR低 通滤 用 I
波器 。
2 FR滤波器 系统硬 件设计 I
F r f r ,% 1. fn ,of) pi ( d ’ 60\ ’ce ; n i
FR滤波器 硬件 电路 主要 由 A D转换 器 、 P I / F—
F l e r ) c s( d ; o i
图 2 F a o 导 出 系数 窗 口 dt l o
在 图 2的 菜单 中 点击 E p r 这 样 就 可 以对 x ot , 系 数 进 行 量 化 。 在 窗 口 中 输 入 “ of ce f=ru d o n
1 2 FR滤波器 系数 的产 生 。 I
F A ol Fl r D s n & A a s ro )是 D T o ( ie ei t g nl i r 1 ys 0
正弦信号进行 A D转换 , / 然后送至 F G P A内部进
一
步处 理 。本 设 计 中采 用 了 A D公 司 的 高性 能
A D转 换 芯 片 A 7 9 , D 6 1每 秒 可 采 样 2 / D 6 1 A 79 5 万 次具有 1 bt 8 i的线性度 ,8位 的串行 数据 输 出 , l 采用 2 7 . V或 5 V单 电源 供 电。与 A I 司推 出 D公 l i 6b t和 1 i 单 端 到 差 分 A C 驱 动 器 8 bt的 D A A 9 11配 合 使 用 , D 4 4 — D 44 - A A 9 11与 A 7 9 D 6 1的 外 围电路连 接 如 图 4 5所 示 , D 4 4 — 、 A A 9 11是一 款 低功耗 、 噪声 差分 驱 动器 。它 采 用易 于 使用 的 低
基于FPGA的FIR数字滤波器的优化设计.
在图像处理、语音识别等数字信号处理中,数字滤波器占有重要的地位,其性能对系统有直接的影响。
随着系统在宽带、高速、实时信号处理上要求的提高,对滤波器的处理速度、性能等也提出更高的要求。
目前数字滤波器的硬件实现方法通常采用专用DSP芯片或FPGA,DSP特有的一些硬件结构和特性使其非常适合作数字滤波电路,但由于其软件算法在执行时的串行性,限制了它在高速和实时系统中的应。
FPGA最明显的优势在于其实现数字信号处理算法的并行性,可以显著提高滤波器的数据吞吐率,随着FPGA技术的不断发展,现在的FPGA不仅包含查找表、寄存器、多路复用器、分布式块存储器,而且还嵌入专用的快速加法器、乘法器和输入/输出设备,因而成为高性能数字信号处理的理想器件。
而在FPGA 中,数字滤波器不同的实现方法所消耗的FPGA资源是不同的,且对滤波器的性能影响也有较大差异。
基于此,本文从FIR滤波器的系数考虑,采用CSD编码,对FIR数字滤波器进行优化设计。
1 FIR滤波器的基本原理一个L阶的FIR数字滤波器的基本系统函数见式(1):式中:h(n)表示滤波器的系数;x(i)表示带有时间延迟的输入序列,此表达式对应的直接型实现结构可用图1来表示。
可以看出,FIR滤波器是由一个“抽头延迟线”加法器和乘法器的集合构成的。
传给每个乘法器的操作数就是一个FIR系数。
对每次采样x(n)要进行N次连续的乘法和(N-1)次加法操作,因实际中滤波器的阶数都很高,实现高数据吞吐率就需要很多的硬件乘法器,硬件实现时将占用大量的资源,同时也会因此影响滤波器的速度和性能。
为了解决这个问题,人们从多个角度寻求优化方法。
从数字滤波器表达式看,对它的优化操作,实际最终转换成两类改进。
一类是针对输入xi的DA操作的改进;另一类是针对系数hi编码的操作。
2 DA算法分布式算法(Distributed Arithmetic,DA)是为了解决乘法资源问题而提出的经典优化算法这种算法结构,可以有效地将乘法运算转换成基于查找表LUT(Look Up Table)的加法运算,利用查表方法快速得到部分积。
FIR数字滤波器设计思路
0≤n≤M。
w[n]=0
,
n 为其他值。
理想低通了滤波器的单位脉冲响应函数 hlp[n]为,
hlp[n] = [sin[wc*(n-M/2)]]/(PI*(n-M/2)) ,
n 为整数。
所以理想带通滤波器的单位脉冲响应函数 hbp[n]为,
hbp[n]=[sin[wc2*(n-M/2)]]/(PI*(n-M/2))-[sin[wc1*(n-M/2)]]/(PI*(n-M/2))
wc1= fc1*2*PI /fs = 0.75f*2*PI/fs; if(n>=0&&n<=M)
{ x0[n] = x[n]; while(n>=0) {
hbp[n]=[sin[wc2*(n-M/2)]]/(PI*(n-M/2))-[sin[wc1*(n-M/2)]]/(PI*(n-M/2)); w[n]=0.5*[1-cos[2*PI*n/M]]; h[n] = hbp[n]* w[n]; n --; }
这样可以将 800Hz 的高频干扰除去,
而后 y[0] ,y[1],……y[n-1], y[n] 再和电平基准值 a 比较,大于 a 为高电平,
小于 a 为低电平,从而输出 100Hz 的方波信号。
注:*为乘号
源代码
#define PI 3.1415926 float sin[101] = {0, 0.062790518, 0.125333231, 0.368124547, 0.425779285, 0.637423981, 0.684547097, 0.844327916, 0.876306671, 0.968583156, 0.982287246, 0.99802673, 0.992114705, 0.929776498, 0.904827067, 0.770513267, 0.728968655, 0.535826832, 0.481753714, 0.248689935, 0.187381364, -0.062790465, -0.125333178, -0.368124497, -0.425779236, -0.637423939, -0.684547057, -0.844327888, -0.876306645, -0.968583142, -0.982287236, -0.998026734, -0.992114712, -0.929776518, -0.90482709, -0.770513302, -0.728968691, -0.535826877, -0.481753761, -0.248689987, -0.187381417, };
基于FPGA的FIR数字滤波器设计的开题报告
1.2 FIR与IIR滤波器相比具有的优势
具有严格的线性相位又具有任意的幅度 FIR滤波器的单位采样响应是有限长的,因 而滤波器性能稳定 FIR滤波器由于单位冲击响应是有限长的, 因而可用快速傅里叶变换(FFT)算法来实 现过滤信号,可大大提高运算效率
1.3 使用FPGA器件进行研究的优点
基于FPGA的FIR数字 滤波器设计
摘要
目前,在数字信号处理和电子应用技术领域,滤波器作为 一个不可少的组成部分,处在一个十分重要的地位,已经 广泛应用于通信、语音、图像、自动控制、军事、航空、 航天、医疗和家用电器等众多领域,并日益显示出其巨大 的应用价值。 在经典滤波器采用的电路中,若要同时满足多个技术指标 或达到较高的精度,往往设计复杂、结构庞大、元件数量 多,并且还可能达不到要求。随着利用计算机技术解决滤 波器设计的不断深入,派生出了一个新的分支,即数字滤 波器,同模拟滤波器相比,它具有精度高、灵活性好、便 于大规模集成等突出优点。近二十年来,FPGA技术的飞速 发展为数字滤波器的设计和实现开辟了一条广阔的道路。
5.1 相关概念说明
数字滤波器(Digital filter) 是由数字乘法器、加法器和延时单元组成 的一种装置。其功能是对输入离散信号的 数字代码进行运算处理,以达到改变信号 频谱的目的。可认为是一个离散时间系统 按预定的算法,将输入离散时间信号转换 为所要求的输出离散时间信号的特定功能 装置
效能 上 市 时 间 成本 可靠性 长 期 维 护
-突破顺序执行 -用户的变更时间短 -跟随系统需求变化 -不需要使用作业系统 - 可 重 设 性 质
2.1 国内外研究现状概括
自从XilinX公司1985年推出第一片FPGA以来,由 于集成度高、方便易用、开发和上市周期短,使 得FPGA器件在数字设计和电子生产中得到迅速 普及和应用,发展潜力十分巨大。现在FPGA已 经发展到可以利用硬件乘加器、片内储存器、逻 辑单元、流水处理技术等特有的硬件结构,高速 完成FFT 、FIR 、复数乘加、卷积、三角函数以 及矩阵运算等数字信号处理。这样可以完成信号 处理的主要技术,如中频采样、参数估计、自适 应滤波、脉冲压缩、自适应波束形成和旁瓣对消 等。
基于FPGA技术的FIR数字滤波器的设计
通常一个长度为M的有 限冲激响应滤波器 由M个系数描述 , 并 静 且需要M个乘法器和( M—1个双输入加法器 来实现 。 ) 图l 中显示 了一个典型的直 接I 阶F R 型4 I 滤波器 , 其输出序列y 执 束瓣 一 ~ () 足 下 列 等 式 : n满
应 用 研 究
基于 F G P A技术的 F R数字滤波器的设计 I
李俊 ’刘淮霞 ,朱丹 ,贺曼2
(. 1 安徽理工大学电气与信息工程 学院 安徽淮南 22 0 ;2西安交通大学电气工程学院 陕西西安 70 4) 30 1 . 10 9
摘要 : 数 字化技 术在 各 个领 域得 到广 泛 运 用的今 天 , 字滤波 器是 数 字 系统 中信 号 处理 关键 的一 环 。 字滤 波器和 模拟 滤 波 器相 比具有 在 数 数 更 高的精 度 、 噪 比 , 及不 可 比拟 的 可 靠性 。 于在 性 能 、 信 以 由 成本 、 活性和 功耗 等方 面 的优 势 , 于F GA的信 号 处 理 器 已广泛 应 用 于各 种信 灵 基 P
: ;
yn ()=h O xn +h 1xn一1 h 2x n一2 +h S xn一3 () () ( ) ( )+ ( ) ( ) () ( )
图 2D ule 设 计 流 程 SP B i r d
在这个FR滤波器 中 , I 总共存 在3 个延时节,个乘法单元, 4 一个 4 入 的加 法 器 。 输
1 I 、FR数字滤波器设计原理
有 限长脉冲响 应( I 滤波器 的系统 函数 只有零点 , F R) 除原 点 外 , 有 极 点 , 而 FR滤 波 器 总 是 稳 定 的【 没 因 I 长度 为M的因果有 限冲激 响应滤波器 由传 输函数H() z 描述 :
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
FPGA的FIR抽取滤波器设计
用FPGA 实现抽取滤波器比较复杂,主要是因为在FPGA 中缺乏实现乘法运算的有效结构,现在,FPGA 中集成了硬件乘法器,使FPGA 在数字信号处理方面有了长足的进步。
本文介绍了一种采用Xilinx 公司的XC2V1000 实现FIR 抽取滤波器的设计方法。
具体实现
结构设计
基于抽取滤波器的工作原理,本文采用XC2V1000 实现了一个抽取率为2、具有线性相位的3 阶FIR 抽取滤波器,利用原理
控制器
控制器是抽取滤波器的核心模块,有两个功能:一是接收输入数据,二
是向其它模块发送数据和控制信号。
它根据加法器、乘法器和累加器的时序特性,有规律地向加法器发送抽头数据,向乘法器发送系数,向累加器发送控制信号,让加法器、乘法器和累加器在每个时钟周期都完成指定的任务,从而
实现流水线操作。
控制器用VHDL 语言描述,用寄存器存放抽头和系数。
加法器
加法器的输入和输出都是18 bit,用VHDL 语言描述实现。
它有两个工作时钟的延迟,在输入数据准备好的情况下,第一个时钟得出相加结果,第二
个时钟把相加结果锁存输出。
乘法器
乘法器为18 bit 输入,36bit 输出,用库元件MULT18X18S 和36 bit 锁存器实现。
MULT18X18S 是XC2V1000 自带的18 乘以18bit 硬件乘法器,单个时钟就可完成乘法运算。
36 bit 锁存器工作于时钟的上升沿,用VHDL 语言。