您好,欢迎访问三七文档
当前位置:首页 > 行业资料 > 国内外标准规范 > DSP技术原理及应用(课件)
DSP技术原理及应用目录•第1章绪论•第2章TMS320C54x的结构原理•第3章TMS320C54x硬件系统设计•第4章TMS320C54x指令系统•第5章DSP软件开发与设计•第6章TMS320C54x的开发应用教学目的1、理解数字信号处理及数字信号处理器的基本概念;2、了解数字信号处理器的发展现状、发展趋势及应用;3、了解TI公司三大系列DSP芯片的主要特点及应用;4、掌握定点DSP的数据格式。教学重点1、数字信号处理及数字信号处理器的基本概念;2、TI公司三大系列DSP芯片的主要特点及应用;3、定点DSP的数据格式。教学难点定点DSP的数据格式。第一章绪论课外作业1、课本P26作业1.2,1.42、若x=1.4,y=0.2(1)将x用Q14格式表示,将y用Q15格式表示;(2)再求x+y。3、y=-0.328,将其表示成Q15格式的定点数。4、已知7000H是定标为Q12的定点数。求其对应的浮点数。DSP有两种理解:一、广义的理解:digitalsignalprocessing—数字信号处理二、狭义的理解:digitalsignalprocessor—数字信号处理器1.1数字信号处理:他是利用计算机或专用处理设备,以数字形式对信号进行采集、变换、滤波、估值、增强、压缩、识别等处理,得到符合需要的信号形式。①在通用的计算机上用软件实现。②在通用计算机系统上加上专用的加速处理机实现。③用通用的单片机实现。④用通用的可编程DSP芯片实现。⑤用专用的DSP芯片实现。⑥用/CPLD/FPGA实现。数字信号处理的实现方法:TMS320VC5402管脚图数字信号处理系统的一般组成X(t)抗混叠滤波A/D转换DSP芯片D/A转换平滑滤波X(n)Y(n)Y(t)抗混叠滤波器将输入信号X(t)中比主要频率高的信号分量滤除,避免产生信号频谱的混叠现象。A/D——将输入的模拟信号转换为DSP芯片可接收的数字信号。DSP芯片——对A/D输出的信号进行某种形式的数字处理。D/A——经过DSP芯片处理的数字样值经D/A转换为模拟量,然后进行平滑滤波得到连续的模拟信号。数字信号处理系统的一般设计过程DSP应用要求定义系统性能指标选择DSP芯片软件编程硬件设计软件调试硬件调试系统集成系统测试和调试数字信号处理器—DSPDSP:是一种特别适合于进行数字信号处理运算的微处理器,其主要应用是实时快速地实现各种数字信号处理算法。DSP的主要特点:⑴哈佛结构:CPU存储器:指令和数据共用控制总线CPU程序存储器数据存储器数据地址总线控制总线程序总线数据总线数据总线地址总线程序地址总线程序/数据数据程序/数据数据高速缓存冯.诺依曼结构:将指令、数据存储在同一个存储器中,统一编址,译稿指令计数器提供的地址来区分是指令还是数据。取指令和取数据都访问统一存储器,数据吞吐率低。基本哈佛结构:程序和数据存储在不同的存储空间,程序存储空间和数据存储空间是两个相互独立的存储空间,每个存储空间独立编址,独立访问。冯诺曼结构基本哈佛结构改进哈佛结构⑵多总线结构对DSP来说,总线越多,可以完成的功能就越复杂。⑶流水线结构如四级流水线的操作图:DSP主要特点续时钟取指译码取操作数执行NN+1N+2N+3NNNN+1N+1N+2N-1N-1N-1N-2N-2N-3⑷多处理单元DSP内部一般都包括有多个处理单元,如算术逻辑运算单元(ALU)、辅助寄存器运算单元(ARAU)、累加器(ACC)以及硬件乘法器(MULT)单元等。它们可以在一个指令周期内同时进行运算。利用这种流水线结构,加上执行重复操作,保证了数字信号处理中用得最多的乘法累加运算可以在单个指令周期内完成。DSP主要特点续⑸特殊的DSP指令在DSP的指令系统中,设计了一些特殊的DSP指令。例如TMS320C54x中的FIRS和LMS指令,则专门用于系数对称的FIR滤波器和LMS算法。⑹指令周期短DSP广泛采用亚微米CMOS制造工艺,如TMS320C54x,其运行速度可达100MIPS。TMS320C6203的时钟为300MHz,运行速度达到2400MIPS。⑺运算精度高DSP的字长有16位、24位、32位。为防止运算过程中溢出,累加器达到40位。此外,一批浮点DSP,例如TMS320C3x、TMS320C4x、TMS320C67x、ADSP21020等,则提供了更大的动态范围。DSP主要特点续⑻硬件配置强新一代DSP的接口功能愈来愈强,片内具有定时器、串行口、主机接口(HPI)、DMA控制器、软件控制的等待状态产生器、锁相环时钟产生器以及实现在片仿真符合IEEE1149.1标准的测试仿真接口,使系统设计更易于完成。另外,许多DSP芯片都可以工作在省电方式,大大降低了系统功耗。DSP的分类⑴按基础特性分:DSP芯片的工作时钟(主频)和指令类型DSP的分类有三种方式:按基础特性分、按数据格式分、按用途分①静态DSP芯片:该类型在某时钟频率范围内都能正常工作,除计算速度有变化外,没有性能上的下降。如日本OKI电器公司的DSP和TI公司的TMS320C2XX系列;②一致性DSP:两种或更多的DSP芯片,其指令集、机器代码及管脚结构相互兼容。如美国TI公司的TMS320C54X。DSP的分类⑵按数据格式分:DSP对数据的处理有两种格式:定点数据格式和浮点数据格式。①定点DSP芯片:数据以定点格式参加运算。②浮点DSP芯片:数据以浮点格式参加运算。不同浮点DSP所采用的浮点格式可能不同。⑶按用途分:①通用型:适合普通的DSP应用。②专用型:为特定的功能、运算而设计的。如数字滤波、卷积、FFT等。如TMS320C24x适合自动控制;MOTOLORA公司的DSP56200专用于数字滤波。DSP的选择选择DSP芯片时应考虑如下几个因素:⑴DSP芯片的运算速度:运算速度可以用以下几种性能指标来衡量;①指令周期:即执行一条指令所需要的时间,通常以ns为单位。②MAC时间:即完成一次乘法和一次加法时间。③FFT执行时间:即运行一个N点FFT程序所需时间。④MIPS:每秒执行百万条指令。⑤MOPS:每秒执行百万次操作。⑥MFLOPS:每秒执行百万次浮点操作。⑦BOPS:每秒执行十亿次操作。⑵DSP芯片的硬件资源;⑶DSP芯片的运算精度:参加运算的数据字长越长精度越高。⑷DSP芯片的功耗;⑸DSP芯片的开发工具;⑹DSP芯片的价格;DSP芯片发展迅速,价格下降也很快。⑺其它。封装形式、质量标准、供货情况、生命周期等。1.3定点DSP的数据格式在定点处理器中,数据采用定点表示方法,定点表示并不意味着就一定是整数表示。它有两种基本表示方法:整数表示方法和小数表示方法。整数表示方法主要用于控制操作、地址计算和其他非信号处理的应用。小数表示方法则主要用于数字和各种信号处理算法的计算中。01010111S262524232221208位定点整数表示方法:01110000S2-12-22-32-42-52-62-78位定点小数表示方法:结果=2-1+2-2+2-3=0.875结果=26+24+22+21+20=87数的补码表示例:求-3.25的补码。用8位二进制数表示。解:[方法1]+3.25的二进制数为:0011.0100,这也就是+3.25的补码。则-3.25的原码为:1011.0100-3.25的反码为:1100.1011,最末位加1得补码1100.1100[方法2]将+3.25的补码0011.0100所有位取反得到1100.1011,最末位加1得补码1100.1100求一个数的补码的补码,就得到这上数的相反数的补码。定点数有两种表示法:(1)Q表示法;(2)S表示法。Q表示法的Qn表示小数点在数据第n位之后(也就是小数位数有n位),Qn中的n也称为Q值,写为Q=n。例如,Q0,表示小数点在第0位之后,即Q=0,显然,Q表示法的Q0实际上表示一个整数。Q15表示小数点在第15位之后,显然,Q15实际上表示一个纯小数。S表示法的Sm.n表示有m位整数,n位小数(即小数点在第n位之后),且m+n=15。显然,S表示法的Sm.n与Q表示法的Qn相同。例如,S0.15与Q15相同,S15.0与Q0相同。⒈定点数的表示法几种常用的Q表示法的格式:•Q0格式:Q0格式(S15.0)的字长为16位。位数1514131211109…….0值SI14I13I12I11I10I9….I0定点数的整数形式。最高位为符号S,接下来的Ix为15位2补码的整数,表示数的范围为(-215~215-1),最小的分辨率为1。Q12格式:Q12格式(S3.12)的字长为16位。最高位为符号S,接下来的3位为2补码的整数位,高位在前,后面的12位为2补码小数位。Q12格式表示数的大致范围为(-8,7),小数的最小分辨率为2-12。位数1514131211109…….0值SI3I2I1Q11Q10Q9….Q0Q15(或S0.15)格式Q15格式的字长为16位,其每位的具体表示如下:位数1514131211109…….0值SQ14Q13Q12Q11Q10Q9….Q0最高位为符号S,接下来的为2补码的15位小数位,小数点紧接着符号位,无整数位。Q15格式表示数的范围为(-1,1),小数的最小分辨率为2-15。对于16位的定点处理器TMS320C54x来说,Q15是在程序设计中最常用的格式。TI公司提供的数字信号处理应用程序库DSPLIB就主要采用这种数据格式。Q表示法S表示法十进制数表示的范围Q15S0.15-1≤x≤0.9999695Q14S1.14-2≤x≤1.9999390Q13S2.13-4≤x≤3.9998779Q12S3.12-8≤x≤7.9997559Q11S4.11-16≤x≤15.9995117Q10S5.10-32≤x≤31.9990234Q9S6.9-64≤x≤63.9980469Q8S7.8-128≤x≤127.9960938Q7S8.7-256≤x≤255.9921875Q6S9.6-512≤x≤511.9804375Q5S10.5-1024≤x≤1023.96875Q4S11.4-2048≤x≤2047.9375Q3S12.3-4096≤x≤4095.875Q2S13.2-8192≤x≤8191.75Q1S14.1-16384≤x≤16383.5Q0S15.0-32768≤x≤32767定点格式表示数的范围(动态范围)和数据的精度是确定的。表示数的范围越大,数据的精度越低,也就是说,数的范围与精度是一对矛盾。对16位的数据来说,动态范围最大的格式为整数Q0,精度(或分辨率)最高的格式为Q15。2.定点数和浮点数的转换关系•浮点数A转换成定点数B:B=(int)(A×2Q)•定点数A转换成浮点数B:B=A×2-Q例一:浮点数x=0.5,定标在Q15,则相应的定点数为Xq=0.5×215=0.5×32768=16384=4000H例二:一个Q15表示的定点数13107对应的浮点数为x=13107×2-15=0.3999939例三:y=-0.625,将其表示成Q15格式的定点数。解:Yq=-0.625×215=-20480=-5000H求-5000H的补码:将其绝对值5000H的所有位取反(得AFFFH)后加1得到补码为B000H。B000H就是-0.625的Q15格式表示的定点数。例四:已知6000H是定标为Q12的定点数。求其对应的浮点数。解:6000H=24576,对应的浮点数为x=24576×2-12=6⒊定点格式数据的转换若一个数已经是某种动态范围较小的Qn格式,为了与动态范围较大的Qn格式数进行(加、减)运算,要将其转换为动态范围较大的格式的数。动态范围小的格式就是整数位数较少,如果整数位数比动态范围大的格式少k位,则将动态范围小的数右移k位,右端移出去的k位去掉不要,左端进行符号位扩展(扩展k位),这样就把动态范围较小的格式的数转换为动态范围较大的格式的数例如,5.625+0.625=6.25,5.625和结果6.25需要采用Q12格式才能保证其动态范围,
本文标题:DSP技术原理及应用(课件)
链接地址:https://www.777doc.com/doc-3811771 .html