DSP与FPGA实时信号处理系统介绍.doc
《DSP与FPGA实时信号处理系统介绍.doc》由会员分享,可在线阅读,更多相关《DSP与FPGA实时信号处理系统介绍.doc(52页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、51 / 52FPGA应用文章实时信号处理系统 摘要:简要叙述了常用的信号处理系统的类型与处理机结构,介绍了正逐步得到广泛应用的处理机结构,在此基础上提出了一种实时信号处理的线性流水阵列,并举例说明了该结构的具体实现,最后分析说明了此结构的优越性。 关键词:实时信号处理 处理机结构 线性流水阵列 实时信号处理系统要求必须具有处理大数据量的能力,以保证系统的实时性;其次对系统的体积、功耗、稳定性等也有较严格的要求。实时信号处理算法中经常用到对图象的求和、求差运算,二维梯度运算,图象分割与区域特征提取等不同层次、不同种类的处理。其中有的运算本身结构比较简单,但是数据量大,计算速度要求高;有些处理对
2、速度并没有特殊的要求,但计算方式和控制结构比较复杂,难以用纯硬件实现。因此,实时信号处理系统是对运算速度要求高、运算种类多的综合性信息处理系统。 信号处理系统的类型与常用处理机结构 根据信号处理系统在构成、处理能力以与计算问题到硬件结构映射方法的不同,将现代信号处理系统分为三大类: 指令集结构()系统。在由各种微处理器、处理器或专用指令集处理器等组成的信号处理系统中,都需要通过系统中的处理器所提供的指令系统(或微代码)来描述各种算法,并在指令部件的控制下完成对各种可计算问题的求解。 硬连线结构系统。主要是指由专用集成电路()构成的系统,其基本特征是功能固定、通常用于完成特定的算法,这种系统适合
3、于实现功能固定和数据结构明确的计算问题。不足之处主要在于:设计周期长、成本高,且没有可编程性,可扩展性差。 可重构系统。基本特征是系统中有一个或多个可重构器件(如),可重构处理器之间或可重构处理器与结构处理器之间通过互连结构构成一个完整的计算系统。 从系统信号处理系统的构成方式来看,常用的处理机结构有下面几种:单指令流单数据流()、单指令流多数据流()、多指令流多数据流()。 结构通常由一个处理器和一个存贮器组成,它通过执行单一的指令流对单一的数据流进行操作,指令按顺序读取,数据在每一时刻也只能读取一个。弱点是单片处理器处理能力有限,同时,这种结构也没有发挥数据处理中的并行性潜力,所以在实时系
4、统或高速系统中,很少采用结构。 结构系统由一个控制器、多个处理器、多个存贮模块和一个互连网络组成。所有“活动的”处理器在同一时刻执行同一条指令,但每个处理器执行这条指令时所用的数据是从它本身的存储模块中读取的。对操作种类多的算法,当要求存取全局数据或对于不同的数据要求做不同的处理时,它是无法独立胜任的。另外, 一般都要求有较多的处理单元和极高的吞吐率,如果系统中没有足够多的适合 处理的任务,采用 是不合算的。 结构就是通常所指的多处理机,典型的系统由多台处理机、多个存储模块和一个互连网络组成,每台处理机执行自己的指令,操作数也是各取各的。结构中每个处理器都可以单独编程,因而这种结构的可编程能力
5、是最强的。但由于要用大量的硬件资源解决可编程问题,硬件利用率不高。 结构 随着大规模可编程器件的发展,采用结构的信号处理系统显示出了其优越性,正逐步得到重视。与通用集成电路相比,芯片具有体积小、重量轻、功耗低、可靠性高等几个方面的优势,而且在大批量应用时,可降低成本。 现场可编程门阵列()是在专用的基础上发展出来的,它克服了专用不够灵活的缺点。与其他中小规模集成电路相比,其优点主要在于它有很强的灵活性,即其部的具体逻辑功能可以根据需要配置,对电路的修改和维护很方便。目前,的容量已经跨过了百万门级,使得成为解决系统级设计的重要选择方案之一。 结构最大的特点是结构灵活,有较强的通用性,适于模块化设
6、计,从而能够提高算法效率;同时其开发周期较短,系统易于维护和扩展,适合于实时信号处理。 实时信号处理系统中,低层的信号预处理算法处理的数据量大,对处理速度的要求高,但运算结构相对比较简单,适于用进行硬件实现,这样能同时兼顾速度与灵活性。高层处理算法的特点是所处理的数据量较低层算法少,但算法的控制结构复杂,适于用运算速度高、寻址方式灵活、通信机制强大的芯片来实现。 线性流水阵列结构 在我们的工作中,设计并实现了一种实时信号处理结构。它采用模块化设计和线性流水阵列结构(图)。 这种线性流水阵列结构具有如下特点: 接口简单。各处理单元()之间采用统一的外部接口。 易于扩充和维护。各个的部结构完全一样
7、,而且外部接口统一,所以系统很容易根据需要进行硬件的配置和扩充。当某个模块出现故障时,也易于更换。 处理模块的规结构能够支持多种处理模式,可以适应不同的处理算法。 每个的核心由芯片和可重构器件组成,另外还包括一些外围的辅助电路,如存储器、先进先出()器件与 等(图)。可重构器件电路与处理器相连,利用处理器强大的功能实现单元电路部和各个单元之间的通信。从的角度来看,可重构器件相当于它的宏功能协处理器()。 中的其他电路辅助核心电路进行工作。和各自带有,用于存放处理过程所需要的数据与中间结果。 中存储了的执行程序和的配置数据。先进先出()器件则用于实现信号处理中常用到的一些操作,如延时线、顺序存储
8、等。每个单独做成一块,各级之间通过插座与底板相连。底板的结构很简单,主要由几个串连的插座构成,其作用是向各个提供通信通道和电源供应。可以根据需要安排底板上插座的个数,组成多级线性阵列结构。这种模块化设计的突出优点在于,它使得对系统的功能扩充和维护变得非常简单。需要时,只要插上或更换电路板,就可以实现系统的扩展和故障的排除。每一级中的都有通信端口与前级和后级电路板相连,可以很方便地控制和协调它们之间的工作。 应用实例 我们应用上述线性流水阵列结构实现了一个实时目标检测系统,该系统的任务主要是接收摄像头输出的灰度图象,经预处理、编码、直线拟合和目标识别后,输出结果到机显示。在这个任务中,预处理模块
9、包括抽样、卷积和编码等步骤,属于低层的处理,其运算数据量大,但运算结构较规则,适于用进行纯硬件实现;而直线拟合与目标识别等高层图象处理算法,所处理的数据量相对较少,但要用到多种数据结构,其控制也复杂得多,我们用编程来实现。 重构处理模块采用的是公司的系列芯片。这是一种基于的现场可编程门阵列。表给出了 系列的一些参数。表1 XC5200系列FPGA的一些参数器件XC5204XC5206XC5210XC5215逻辑单元48078412961936最大逻辑门6000100001600023000多功能块1012141418182222CLB120196324484触发器48078412961936I
10、/O124148196244 系列逻辑功能的实现由部规则排列的逻辑单元阵列()来完成,它是的主要部分。的核心是可重构逻辑块(),四周是一些输入输出块()。和之间通过片的布线资源相连接。由配置代码驱动,和的具体逻辑功能与它们的互联关系由配置数据决定。整个模块的设计实现在公司的 开发平台上完成。该系统支持设计输入、逻辑仿真、设计实现(设计综合)和时序仿真等系统开发全过程。 在选用芯片时,主要应考虑性能能否满足快速判读算法的要求,具体说就是要求选择那些指令周期短、数据吞吐率高、通信能力强、指令集功能完备的处理器,同时也要兼顾功耗和开发支持环境等因素。表列出了一些常用微处理器的性能参数。 我们选择的是
11、应用广泛、性价比较高的芯片。它是美国公司推出的为满足并行处理需求的位浮点。主要特性如下:表2 常用微处理器对照表处理器类型DSP(Motorola)ADSPTMS3209600256156210202101C30C40C50字长/bit32163216323216指令周期/ns505050603325501024浮点FFT时间/ms1.042.330.962.072.361.933.42 外部时钟,部时钟,所有指令均单周期完成,处理器部采用高度并行机制,可同时进行多达项各类操作。 两套一样的外部数据、地址总线,支持局部存储器和全局共享存储器。 个高速并行通信口,采用异步传输方式,最大速率可达。
12、通过令牌传递可灵活实现数据双向传输,这种结构很适合之间的互连。 个通道,每个通道的最大速率可达。部总线与的地址、数据、指令总线完全分开,避开了总线使用上的瓶颈。 从结构和功能上看,很适合与可重构器件互相配合起来构成高速、高精度的实时信息处理系统,并完全可以胜任图像信息的实时处理任务;此外,的开发系统也比较完备,支持语言和汇编语言编程,能够方便地进行算法移植和软硬件的协同设计。 衡量系统的整体性能不仅要看所使用的器件和所能完成的功能,还要看器件之间采用怎样的互连结构。可以完成模块级的任务,起到的协处理器的作用。它的可编程性使它既具有专用集成电路的速度,又具有很高的灵活性。部结构的主要优势是:所有
13、指令的执行时间都是单周期,指令采用流水线,部的数据、地址、指令与总线分开,有较多的寄存器。这些特征使它有较高的处理速度。具有硬件的高速性,而具有软件的灵活性,从器件上考察,能够满足处理复杂算法的要求。同时,的个通信口和个通道使其能够在不被中断的情况下比较从容地应付与外界大量的数据交换。 从部互连来看,使用了专用的通信口完成与的互连,能够保证在任何情况下与的数据通道的畅通。另外,和各自都有输入端口,使得系统的处理结构多样化。比如,可以作为处理流程中的一个模块,独立完成某项功能,也可以作为的协处理器,通过的调用来完成特定的子函数。底板将互连性延伸到之间,使得多个电路板能够组成多处理机系统。前级的既
14、可以与下一级的通信,也可以将数据发送到下一级的。 综上所述,本文提出的基于的线性流水阵列结构,为设计中如何处理软硬件的关系提供了一个较好的解决方案。同时,该系统具有灵活的处理结构,对不同结构的算法都有较强的适应能力,尤其适合实时信号处理任务。在测控系统中用IP核实现D/A转换 摘要:采用数字化技术、在测控系统中用IP核实现D/A转换,并且在1片可编程逻辑器件中实现。它不受温度的影响,既可保持高分辨率,又可降低对电路精度和稳定度的要求,并减少元件的数量。 关键词:IP D/A VHDL 可编程逻辑器件在各类电子系统中,数字电路所占比重越来越大。这主要是因为数字电路相对于模拟电路有一些突出的优点,
15、例如:*数字电路中的有源器件工作在饱和区与截止区,工作状态稳定;*数字电路处理的是二值信号,易于存储和再生;*数字电路是由大量一样的基本单元,如门、触发器等所组成,易于大规模集成,易于自动化设计工具的应用等。由于数字电路的以上特点,再加上数字计算机和数字信号处理技术的迅速发展,使得数字电路从集成规模、应用围与设计自动化程度等方面大大超过了模拟电路,越来越多的由模拟电路实现的功能转由数字电路实现,进入了电子系统数字化的时代。在测控系统采用数字化技术,将原来由模拟电路实现的D/A由数字电路实现。1 IP核介绍IP(知识产权)核将一些在数字电路中常用,但比较复杂的功能块,如FIR滤波器、SDRAM控
16、制器、PCI接口等设计成可修改参数的模块。IP核的重用是设计人员赢得迅速上市时间的主要策略。随着CPLD/FPGA的规模越来越大,设计越来越复杂(IC的复杂度以每年55%的速率递增,而设计能力每年仅提高21%),设计者的主要任务是在规定的时间周期完成复杂的设计。调用IP核能避免重复劳动,大大减轻工程师的负担,因此使用IP核是一个发展趋势。IP核包括硬IP与软IP。可配置IP是参数化后的可重定目标IP,其优点是可以对功能加以裁剪,以符合特定的应用。这些参数包括总线宽度、存储器容量、使能或禁止功能块。硬IP最大的优点是确保性能,如速度、功耗等。然而,硬IP难以转移到新工艺或集成到新结构中,是不可重
17、配置的。软IP是以综合形式交付的,因而必须在目标工艺中实现,并由系统设计者验证。其优点是源代码灵活,可重定目标于多种制作工艺,在新功能级中重新配置。不过目前大多数库是收费的,但也可以从网上下载一些免费的IP核。2 用IP核实现的D/A转换器的功能与特点数字到模拟转换器(DACs)将一个二进制数转换为与之对应的电压值,目前常用的D/A转换器都是由电阻或电容加权网络、受码元控制的开关和基准电压或电流源组成。当D/A转换器需要转换的信号每次取样字长很长时,对这些电路的精度要求很高,并且还必须在整个温度围和整个使用寿命期间保持电路参数的稳定。例如,一个16位的D/A转换器,其MSB的精度必须在1/2
18、16以,这是很困难的。所以,需寻求一种中保持高分辨率又可降低对电路精度和稳定度要求的方法。可综合的Delta-Sigma DAC(术语Delta-Sigma分别指算术差与和,即-DAC),是Xilinx公司提供的免费IP核,可从网上下载得到。Delta-Sigma DAC使用数字技术,因而它不温度的影响,并且能在一片可编程逻辑器件中实现。避免在D/A转换器中使用匹配电阻,不仅能更便宜,而且,其转换是线性的。Delta-Sigma DAC实际上是高速单个位的DAC,用数字反馈技术,在输出端产生一串脉冲。脉冲串号为高电平的时间部分与二进制输入成比例,当这个脉冲串通过一个模拟低通滤波器后就得到一个模
19、拟输出信号。图1是一个典型的可编程逻辑器件实现的DAC的顶层电路图,输入信号有复位信号、时钟信号以与二进制数据总线。输出DACoutDrvr驱动一个外部的低通滤波器Vout能从0VVcco。这里Vcco是FPGA I/O块的供电电压。输入/输出详细说明如表1所列。表1 输入输出描述表信 号方 向描 述DACOUT输出驱动外部低通滤波器的脉冲串(通过一个输出驱动器)DACIN输入数字输入总线,值必须设置成钟的正沿clk输入正沿有效Reset输入复位信号初始化SigmaLatch和输出D触发器 DAC的二进制输入是一个无符号数。“0”代表最低电压,输出的模拟电压也只有正的。“0”输入产生0V输出,
20、输入端全“1”,则输出近似达到Vcco。图2是Delta-Sigma DAC的原理框图,二进制输入的位宽是可变的。为简单起见,电路原理图描述了一个8位二进制输入的DAC。在这个器件中,二进制加法器用来产生和,也用来产生差。尽管Delta Adder的输入是无符号数,两个加法器的输出却都是有符号数。Delta Adder计算DAC输入和当前DAC输出的差,并用一个二进制数表示。因为DAC的输出是一个单个的位,因此它不是1就是0。如图2所示,当输入加上由Sigma Latch的输出的两个拷贝与0构成的10位数,就产生差值,这也补偿了DACIN是无符号数的事实。Sigma Adder将它原来的输出(
21、保存在Sigma Latch中)与当前的Delta Adder的输出相加。图1中输出电压与输入电压的关系为VOUT=(DACIN/(2MSBI+1)VCCO式中单位为V。例如,对于一个8位DAC(MSBI=7),最后的输出是这样:DACIN输入是0,则输出也是0;DACIN输入是十六进制数FF时,输出值为最大(255/256)Vcco。阻容低通滤波器适合多数应用需要,一个简单的阻容低通滤波器就能工作得很好。Vs的定义是:DAC输入增加或减少时,在Vout端产生变化的绝对值。对一个8位DAC,Vs等于(1/256)Vcco。Vout能够产生在0VVcco之间可变的电压,具体的值由DACIN的位宽
22、和输入的数值决定。Delta-Sigma DAC适合需要相对高精度的低频应用。在这种应用中,电压不会很快地变化,因此,RC的时间常数可以很大,以减小噪声。这种DAC最广泛的应用就是产生通常直流电压。这包括电压控制振荡器、电压控制运算放大器、I/O参数电压、可编程电压源、波形发生器(正弦、三角等)、A/D转换中的参考电压等。Delta-Sigma DAC是一个例子,说明高速可编程逻辑器件能用于混合信号系统,以减少元件的数量。可编程逻辑器件的速度和密度使它们成为模拟信号产生和处理方面理想的元件。3 用VHDL语言编写的程序library ieee;use ieeestd_logic_1164.al
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- DSP FPGA 实时 信号 处理 系统 介绍
限制150内