《DSPBuilder设计.ppt》由会员分享,可在线阅读,更多相关《DSPBuilder设计.ppt(93页珍藏版)》请在三一办公上搜索。
1、DSP Builder工具及设计流程,DSP Builder是Altera公司提供的一种DSP系统设计工具,是Matlab/Simulink设计工具和QuartusII设计工具之间的一个桥梁,把Matlab/Simulink中的系统设计转化为文件,在QuartusII工具中实现到具体的器件中。产生于MatlabDSP BuilderQuartus II流程的DSP模块或其他功能模块可以成为单片FPGA电路系统中的一个组成部分,担任某个局部电路的功能;通过MatlabDSP Builder,可以直接为Nios II嵌入式处理器设计各类加速器,成为Nios II系统的一个接口设备,与整个片内嵌入式
2、系统融为一体。,DSP Builder是一个系统级(或算法级)设计工具,它架构在多个软件工具之上,并把系统级和RTL级两个设计领域的设计工具连接起来,最大程度地发挥了两种工具的优势。,DSP Builder及其设计流程,DSP Builder以Simulink的Blockset出现,可以在Simulink中进行图形化设计和仿真,通过SignalCompiler把Matlab/Simulink的设计文件(.mdl)转成相应的硬件描述语言VHDL设计文件(.vhd),以及用于控制综合与编译的TCL脚本。而对后者的处理可以由FPGA/CPLD开发工具Quartus II来完成。,在Simulink中
3、搭建系统的模型进行仿真,并可从该模型自动生成可综合的VHDL代码,两者的逻辑功能一一对应。得到可综合的VHDL代码之后,可以按传统的FPGA开发流程那样手工对代码进行综合和适配,在不需要对代码进行修改时,可以使用DSP Builder提供的自动流程,在Simulink集成环境中直接调用特定的综合器和适配器执行生成的相应脚本在后台进行综合和适配。,DSP Builder还可以输出Simulink中使用的仿真激励,并生成测试平台和在Model Sim中使用的脚本,只需要在Model Sim中执行此脚本就可以使用所输出的Simulink中使用的仿真激励对实现代码的逻辑功能进行测试。,利用DSP Bu
4、ilder进行DSP设计的流程框图。,DSP Builder设计流程,第一步是在Matlab的Simulink环境中建立一个mdl模型文件,调用Altera DSP Builder和其它Simulink库中的图形模块(Block),构成设计框图(或称Simulink设计模型)。第二步是利用Simulink强大的图形化仿真、分析功能,分析此设计模型的正确性,完成模型仿真。在这两步中,与一般的Matlab Simulink建模过程几乎没有什么区别,所不同的是设计模型库采用Altera DSP Builder的Simulink库。,DSP Builder设计流程,第三步是DSP Builder设计实
5、现的关键一步,通过SignalCompiler把Simulink的模型文件(后缀为.mdl)转化成通用的硬件描述语言VHDL文件(后缀为.vhd)。由于EDA工具软件(诸如Quartus II、ModelSim)不能直接处理Matlab的.mdl文件,这就需要一个转换过程。转换获得的HDL文件是基于RTL级(寄存器传输级)的VHDL描述。,再接下来的几个步骤是对以上设计产生的VHDL的RTL代码和仿真文件进行综合、编译适配以及仿真。为了针对不同用户的设计目的和设计要求,DSP Builder提供了两种不同的设计流程,主要可以分为自动流程和手动流程。,如果采用DSP Builder的自动流程,几
6、乎可以忽略硬件的具体实现过程,DSP Builder自动调用Quartus II等EDA设计软件,完成综合(Synthesis)、网表(ATOM Netlist)生成和Quartus II适配,甚至在Matlab中完成FPGA的配置下载过程。,如果希望使用其它第三方的VHDL综合器和仿真器(除Synplify、LeonardoSpectrum和 Quartus II综合器及ModelSim外),或是希望完成特定的适配设置,如逻辑锁定、时序驱动编译、ESB特定功能应用等,可以选用手动流程设计。,在手动流程中,可以灵活地指定综合、适配条件。不过,需要手动地调用VHDL综合器进行综合,调用Quart
7、us II进行适配,调用ModelSim或者Quartus II进行仿真,最后用Quartus II产生相应的编程文件用于FPGA的配置。,采用手动流程时,除了行为级仿真验证和设计输入外,其它过程与标准的基于VHDL的EDA设计流程是完全一致的。由上一步DSP Builder设计流程得到VHDL文件(由Simulink模型文件*.mdl通过SignalCompilder转换而成),送入综合器进行综合。综合器可以是Synplify Pro,也可以是LeonardoSpectrum,或者采用Altera自己的Quartus II。在综合时,可能需要对综合器进行配置或者提供综合的约束条件。由于这个过
8、程操作可能比较繁琐,所以DSP Builder的SignalCompiler相应提供了一个接口,针对设计,自动产生一个TCL脚本与综合器Synplify或者LeonardoSpectrum相接。,综合器在综合操作后会产生一个网表文件,以供下一个流程使用。这里产生的网表文件称为ATOM网表文件,主要是EDIF网表文件(.edf 电子设计交换格式文件)或VQM(.vqm Verilog Quartus Mapping File),它们是一种参数可设置的,并含有具体器件系列硬件特征(如逻辑宏单元LCs、I/O单元、乘积项、嵌入式系统块ESB等)的网表文件。Quartus II可以利用这些ATOM网表
9、文件针对选定的具体器件进行适配,包括布线、布局、结构优化等操作,最后产生时序仿真文件和FPGA目标器件的编程与配置文件。在这一步,设计者可以在Quartus II中完成对Pin(引脚)的锁定,更改一些约束条件。,如果用DSP Builder产生的DSP模型只是庞大设计中的一个子模块,则可以在设计中调用DSP Builder产生的VHDL文件,以构成完整的设计。在DSP Builder设计流程的最后一步,可以在DSP Builder中直接下载到FPGA用户开发板上,或者通过Quartus II完成硬件的下载、测试。,DSP Builder在生成VHDL代码时,可以同时生成用于测试DSP模块的Te
10、stBench(测试平台)文件,DSP Builder生成的TestBench文件采用VHDL语言,测试向量与该DSP模块在Simulink中的仿真激励相一致。通过ModelSim仿真生成的TestBench可以验证生成的VHDL代码与Simulink中DSP模型的一致性。另外,DSP Builder在产生TestBench的同时,还产生了针对ModelSim仿真的Tcl脚本来简化用户的操作,掩盖ModelSim仿真时的复杂性。,在大部分情况下,Quartus II对DSP模块适配后,需要再次验证适配后网表与Simulink中建立的DSP模型的一致性。这就需要再次使用ModelSim进行仿真,
11、这时仿真采用Quartus II适配后带延时信息的网表文件(EDIF格式或者VHDL、Verilog格式)。,DSP Builder设计向导,以一个简单的可控正弦波发生模块的设计为例,详细介绍DSP Builder的使用方法。在利用DSP Builder进行DSP系统相关设计时,关键的设计过程大都在Matlab的图形仿真环境Simulink中进行。,一个简单的正弦波发生器,主要由四个部分构成。InCount是阶梯信号发生模块,产生一个按时钟线性递增的地址信号,送往SinLUT。SinLUT是一个sin(正弦函数)值的查找表(LUT:Look Up Table)模块,由递增的地址获得正弦波的量化
12、值输出,输出的8位正弦波数据经延时模块Delay后送往Product乘法模块,与SinCtrl相乘。SinCtrl是1 bit输入,SinCtrl通过Product就完成了对有无正弦波输出的控制。SinOut是整个正弦波发生器模块的输出,送往D/A即可获得正弦波的输出(模拟信号)。,正弦波发生模块原理图,建立一个新的模型(Model),设计时首先需要建立一个新的设计模型,步骤如下:建立工作库:在建立一个新的设计模型前,最好先建立一个新的文件夹,作为work(工作)目录,并把Matlab当前的work目录切换到新建的文件夹下。在Matlab主窗口中的命令窗口中键入:cd e:/mkdir/myp
13、rj/sinwave cd/myprj/sinwave,其中e:/myprj/sinwave是新建的文件夹,是用来为Matlab建立工作目录的。kdir是一个建立新目录的Matlab命令,cd是切换工作目录的Matlab命令。通过改变Matlab主界面中的“Current Directory”的制定,同样可以改变Matlab的当前工作目录。,当成功地把Matlab当前目录切换到新建的设计目录后,可以在Matlab命令窗口键入“Simulink”命令,以开启Matlab的图形化建模仿真环境Simulink。当安装完DSP Builder后,在Simulink的库浏览器中可以看到“Altera D
14、SP Builder Blockset”字样出现在Libraries列表中,其中包括一些基本的算术单元和一些Altera的DSP类的IP核。在DSP Builder应用中,主要是使用该库中的组件、子模型来完成各项设计,再使用Simulink库来完成模型的仿真验证。,Simulink库浏览器,Simulink的模型文件,在打开Simulink库浏览器后,需要新建一个Simulink的模型文件(后缀为mdl),在Simulink的库浏览器中选择“File”菜单,在出现的菜单项中选择“New”,在弹出的子菜单项中选择新建模型“Model”。,放置SignalCompiler,点击Simulink库浏
15、览器左侧的库内树形列表中的Altera DSP Builder Blockset条,使之展开DSP Builder库,这时会出现一长串树形列表,对DSP Builder库的子模块(Block)进行了分组。点击其中的AltLab项,展开AltLab,选中库浏览器右侧的SignalCompiler组件,按住鼠标右键拖动SignalCompiler到新模型窗口中,放置SignalCompiler,放置Increment Decrement,将Increment Decrement模块放置到新模型中。选中Altera DSP Builder Blockset库中的Arithmetic(算术)条,则在库
16、浏览器的右侧,可以看到Increment Decrement模块。把Increment Decrement模块拖到新建模型窗口中。,设置IncCount,用鼠标点击在新建模型窗口中的Increment Decrement模块下面的文字“Increment Decrement”,将模块名字修改为“IncCount”。,要把IncCount模块做成一个线性递增(顺序加1)的地址发生器,就需要对IncCount模块的参数进行相应的设置。双击新建模型中的IncCount模块,打开IncCount的模块参数设置对话框。在参数设置对话框的上半部分是该模块的功能描述和使用说明;对话框的下半部分是参数设置部分
17、。,对于Increment Decrement模块,共有下面几种参数可以设置:总线类型(Bus Type)输出位宽(Number Of Bits)增减方向(Direction)开始值(Starting Value)时钟相位选择(Clock Phase Selection)对于总线类型(Bus Type),在其下拉列表框中共有三种选择:有符号整数(Signed Integer)有符号小数(Signed Fractional)无符号整数(Unsigned Integer),设置IncDec,一般的D/A器件的输入数据都是无符号的正数。因此,为了能在硬件系统上D/A的输出也能观察到此波形,设置所有模
18、块的数据类型为无符号。Bus Type选择“Unsigned Integer”,即无符号整数。对于输出位宽,由于在后面接着的正弦查找表(Sin LUT)的地址为6位,所以输出位宽设为6。,IncCount是一个按时钟增1的计数器,Direction设为Increment(增量方式)。Clock Phase Selection可设置为1(二进制)。Specify Clock不选,通常在simulink图中的原件的复位端和时钟端(如果存在的话)是分别默认接于低电平和与全局时钟相连的。对于其它设置,仍采用Increment Decrement模块的默认设置。然后点击“OK”按钮确认。,注意:若对DS
19、P Builder库中的模块设置参数值不了解,可以在相应模块的参数设置对话框中点击“Help”按钮(或按F1键),调出DSP Builder的相应帮助,以便了解详细的模块参数说明。,放置正弦查找表(SinLUT),在Altera DSP Builder Blockset库的Storage库中找到查找表模块LUT。把LUT拖到新建模型窗口,将LUT模块的名字修改成“SinLUT”。双击SinLUT模块,打开模块参数设置对话框。把输出位宽(Number Of Bits)改为10,查找表地址线位宽(Address Width)设为6。,设置SinLUT,在“MATLAB Array”编辑框中输入计算
20、查找表内容的计算式。在此可以直接使用sin(正弦)函数。此处sin函数的调用格式为:sin(起始值:步进值:结束值)SinLUT是一个输入地址为6位、输出值位宽为10的正弦查找表模块,且输入地址总线为无符号数,可以设置起始值为0、结束值为2、步进值为2/26。计算式可写成:511*sin(0:2*pi/(26):2*pi)+512其中pi即为常数。,LUT中的公式实现的功能是在原输出的有符号数据上加上了511。原理是将乘法器输出的8位有符号数的最高位取反并以无符号数输出。如果改变地址线宽,如8,以上的2的6次方要改成2的8次方。在“Use LPM”处选择打勾,表示允许QuartusII利用目标
21、器件中的嵌入式 RAM(在EAB、ESB或 M4K模块中)来构成 SinLUT,即将生成的正弦波数据放在嵌入式RAM构成的ROM中,这样可以节省大量逻辑资源。否则只能用芯片中的LCs来构成,放置Delay模块,在Simulink库浏览器的Altera DSP Builder Blockset库中,选中Storage库下的Delay模块,放置到新建模型窗口。,Delay模块,Delay模块是一个延时环节,在这里可以不修改其默认参数设置。在Delay模块的参数设置对话框中,Optional Ports标签下的Clock Phase Selection参数是控制采样的,设置为1时表示每一主频脉冲后,
22、数据都能通过。,放置端口SinCtrl,在Simulink库浏览器的Altera DSP Builder Blockset库中,选中IO&Bus库,找到Input模块,放置在新建模型窗口中。,Input模块,放置端口SinCtrl,修改Input模块的名字为SinCtrl。SinCtrl是一个1位输入端口,双击SinCtrl模块,打开模块参数设置对话框,设置SinCtrl的Bus Type参数为“Single Bit”。,设置SinCtrl,放置Product(乘法)模块,在Simulink库浏览器的Altera DSP Builder Blockset库中,选中Arithmentic库,找到
23、Product模块,用鼠标拖放到新建模型窗口中。,Product模块,Product的两个输入中,一个是经过一个Delay的SinLUT查表的输出,另一个是外部的一位端口SinCtrl。按算法逻辑来看,实现了SinCtrl对SinLUT查找表输出的控制。双击Product模块,打开参数设置对话框,设置Product的参数。“Use Dedicated Circuitry”选项用于对FPGA中的专用模块的选择。,放置输出端口SinOut,在Simulink库浏览器的Altera DSP Builder Blockset库中,选中IO&Bus库,找到Output模块,将其放置在新建模型窗口中。,修
24、改Output模块的名字为SinOut。SinOut是一个10位输出端口,接向FPGA的输出端口,与外面的10位高速D/A转换器相接,通过D/A把10位数据转换成1路模拟信号。双击SinOut模块,打开模块参数设置对话框,设置SinOut的Bus Type参数为“Unsigned Integer”,修改“Number Of Bits”参数为10。,设置SinOut,设计文件存盘,放置完SinOut模块后,把新建模型窗口中的DSP Builder模块连接起来,这样就完成了一个正弦波发生器的DSP Builder模型设计。在进行仿真验证和SignalCompiler编译之前,先对设计进行存盘操作。
25、,Simulink模型仿真,用DSP Builder Blockset模块设计好一个新的模型后,可以直接在Simulink中进行算法级、系统级仿真验证。对一个模型进行仿真,需要施加合适的激励、一定的仿真步进和仿真周期,并添加合适的观察点和观察方式。,Simulink模型仿真,加入仿真步进模块首先加入一个Step模块,以模拟SinCtrl的按键使能操作。在库浏览器中,展开Simulink库,选中Sources,把Sources库中的Step模块拖放到模型窗口中。把step模块与SinCtrl输入端口相接。注意:凡是来自Altera DSP Builder库以外的模块,SignalCompiler
26、都不能将其变成硬件电路,即不会影响生成的VHDL程序,但在启动Simulink仿真后能影响后面产生的仿真记录文件。,Step模块,Simulink模型仿真,添加波形观察模块在库浏览器中,展开Simulink库,选中其中的Sinks库,把Scope(示波器)模块拖放到模型窗口中。双击该Scope模块,打开的是一个Scope(示波器)窗口。只有一个信号的波形观察窗口,而若希望可以多观察几路信号,可以通过调用多个Scope模块的方法来实现,也可以通过修改Scope模块参数来在同一个Scope模块中增加观察窗。,Simulink模型仿真,Scope参数设置用鼠标点击Scope模块窗口上侧工具栏的第二个
27、工具按钮:“Parameters”参数设置,打开Scope参数设置对话框。在Scope参数设置对话框中共有两个选项页:“Gerneral”(通用)和“Data history”(数据历史)。在“Gerneral”选项页中将“Number of axes”参数改为3。在点击“OK”按钮确认后,可以看到Scope窗口增加了两个波形观察窗。每个观察窗都可以分别观察信号波形,而且相对独立。,将SinCtrl的信号接向Scope的另一端,以作信号比较。此路信号在生成的VHDL文件中不会有相应语句,因为没有接上输出端口模块,Scope初始显示,设置Scope参数,Simulink模型仿真,设置Mux模块如
28、果需要对某些信号进行对比观察,希望放置在同一个波形观察窗中,以便更好地观察信号之间的异同点,可以使用Mux模块来辅助完成。在Simulink库浏览器中,选中Simulink库,找到Signal Routing库下的Mux模块,拖放到sinout模型窗口。设置Mux模块,把“Number of inputs”(输入数目)参数设定为2。,Mux模块,设置Mux,Simulink模型仿真,设置仿真激励连接sinwaveout模型的全图,准备开始仿真。在仿真前还需要设置一下与仿真相关的参数。先设置模型的仿真激励。在sinwaveout模型图中只有一个输入端口SinCtrl,需要设置与此相连的Step模
29、块。,sinout全图,双击放置在sinwaveout模型窗口中的Step模块,设置对输入端口SinCtrl施加的激励。在打开的Step模块参数设置对话框中,可以看到一些参数,这些参数值的含义如下:Step time:步进间隔Initial value:初始值Final value:终值Sample time:采样时间,设置Step,在此设置“Step time”为500;“Initial value”为0,即初始时不输出正弦波;“Final value”为1;“Sample time”为1。把最后两项选择:“Interpret vector parameters as 1-D”和“Enabl
30、e zero crossing dectection”都设为打勾。在sinwaveout模型窗口中,点击“Simulation”菜单,在下拉菜单中选择“Configuration Parameters”菜单项。随后,将弹出sinwaveout模型的仿真参数设置对话框中,可设置“Start time”为0.0,“Stop time”为1000。其它设置取默认值。,为了能更好得在波形观察窗中区分不同信号,可以在sinwaveout模型中对连接线进行命名:双击对应的连接线,就会出现一个可以输入文本的小框,在框中输入信号的名称。,启动仿真在sinwaveout模型窗口中选择“Simulation”菜单
31、,再选“Start”项开始仿真。待仿真结束,双击Scope模块,打开Scope观察窗。观察仿真结果,SinOut信号是sinwaveout模型的输出(Scope观察窗中模拟了D/A的输出波形),SinCtrl信号是sinwaveout模型的输入。可以看出SinOut受到了SinCtrl的控制。当SinCtrl为1时,SinOut波形是正弦波;当SinCtrl为0时,输出为0。SinTemp是sinwaveout模型内部的连接信号,用来观察sinwaveout模型内部的情况。,Scope波形,在Scope观察窗中,可以使用工具栏中的按钮来放大/缩小波形,也可以在波形上单击右键使用“Autosca
32、le”,使波形自动适配波形观察窗。用鼠标左键可以放大波形。,把SinTemp信号波形放大一些可以看到两个波形,一个波形比另一个波形延时了一个周期。,波形延时,SignalCompiler的使用,在Simulink中完成仿真验证后,就需要把设计转到硬件上加以实现。这是整个DSP Builder设计流程中最为关键的一步,在这一步,可以获得针对特定FPGA芯片的VHDL代码。,Signal Compiler,双击sinwaveout模型中的Signal Compiler模块,会出现”DSPBuilder-Signal Compiler”对话框。,双击SignalCompiler后的对话框,设置Sig
33、nal Compiler,在“Family”(器件系列)下拉选择框中选择需要的器件系列,默认为Stratix系列器件,对此可以修改。在此选为Cyclone II。在“Device”中默认为Auto,即由Quartus II自动决定使用该器件系列中的某一个具体型号的器件。在此输入EP2C35F672C6。点击Simple标签页中的Compile按钮,等待编译完后点OK。,点击“Compile”(编译)按钮后,Signal Compiler首先对sinwaveout模型进行分析,检查模型有无错误,并在Matlab命令窗口中给出相关信息。若有错误(Error)存在,Signal Compiler就会
34、停止分析过程,并把错误信息显示在信息框“Message”中。如果有警告(Warning)存在,同错误一样把警告信息显示在信息框“Message”中。,把模型文件MDL转换成VHDL完成Simulink文件(*.mdl)到VHDL文件的转换后,在“Messages”信息提示框中会显示“Generating HDL”,即顶层文件sinwaveout.vhd完成转换。Sinwaveout模型生成的VHDL文件“sinwaveout.vhd”可以在文件夹sinwaveout中找到。若有错误,在“Messages”信息提示框中会显示简短的出错提示。,出现MDL to VHDL信息,综合调用Quartus
35、II完成综合过程。综合后生成原子网表供适配器使用,并自动生成QuartusII可调用的工程。QuartusII适配调用QuartusII完成编译适配过程,生成编程文件:pof文件和sof文件。编程文件可以直接用于FPGA的编程配置。,Signal Compiler窗口,“Message”信息框中提示信息Info:Generating HDLInfo:Analyzing Simulink modelInfo:Analysis was successfulInfo:Running Quartus II Analysis&SynthesisInfo:Quartus II Analysis&Synth
36、esis was successful.0 errors,7 warningsInfo:Running Quartus II FitterInfo:Quartus II Fitter was successful.0 errors,2 warningsInfo:Running Quartus II TimeQuest Timing AnalyzerInfo:Quartus II TimeQuest Timing Analyzer was successful.0 errors,2 warningsInfo:Running Quartus II AssemblerInfo:Quartus II
37、Assembler was successful.0 errors,0 warnings,在Advance标签页,可手动进行分析、综合、布线和适配过程。,Simulink具有较为强大的错误定位能力,对许多错误可以在Simulink模型中直接定位,用不同的颜色提示有错误的Simulink模块(Block)。当Signal Compiler分析当前DSP模型有错误时,必须去除错误才能继续DSP Builder流程,即不会出现Signal Compiler窗口。,“SignalTap II”标签页是嵌入式逻辑分析仪SignalTap的设置。,若要导出VHDL文件,选择Export标签页,进行门级的时
38、序仿真仍然是十分重要的,SignalCompiler已将MATLAB上的仿真信息转变成了可用于QuartusII进行时序仿真的激励信息及相关仿真文件:,因此能容易地完成此项任务。,打开QuartusII环境,选择“File”“Open Project”,定位到sinwaveout模型所在路径目录,打开DSP Builder建立的QuartusII工程文件:sinwaveout.quartus,在Quartus II中打开sinout quartus,选择器件型号。选择菜单“Assignments”“Device.”,在相应的对话框中选择合适的器件,如EP1K100QC208-3(或者EP20K
39、E系列的器件)。首先打开sinwaveout.vhd,了解端口情况,确定引脚。锁定管脚(Pin),选择菜单“Assignments”“Assign Pins.”,对应FPGA开发板上的硬件连接,锁定Pin。接着进行编译,完成适配过程。选择菜单“Processing”“Start Compilation.”,等待Quartus II编译完成。,硬件测试,最后是进行硬件的下载,连接好FPGA开发板。下载完毕后,就可以对硬件进行测试。加上clcok信号,用示波器检测D/A的输出。把键控SinCtrl设置为有效,在示波器上观察产生的正弦波。将实测结果与在计算机上进行的时序仿真结果进行比较。,若再想改动
40、Simulink中的sinwaveout.mdl图,应注意两点:内部电路结构和设置可以改,但端口信号名不要改,如输入的SinCtrl,SinOut,因为此信号的引脚已被锁定,不便改变;改动sinwaveout.mdl图后只宜作系统仿真和VHDL文件转换,不宜作综合,否则将把原来设定好的引脚全部冲掉。为了保存引脚信息,综合与适配两项操作必须在进入QuartusII后进行。,建立完成设计后,还可以利用Quartus II对DSP Builder设计的电路系统建立一个元件模块,以便用于更大的系统设计的调用。,实验,在simulink中设计一个32阶低通滤波器,采样频率5K,截止频率0.1K。然后用0.1k和0.5k正弦波叠加,得到滤波结果。要求:(1)在Simulink中建立数学模型并仿真。生成.vhd文件。(2)提交纸质设计报告和程序的电子版。(2)报告要求:原理,参数设置,模型图截图,输入和结果波形图。(3)提交日期:2014年4月30日。,