




已阅读5页,还剩44页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
I 基于 FPGA 的调制信号发生器设计研究 摘 要 直接数字频率合成技术在通信系统中被广泛采用。在研究直接数字频率合 成技术的基本原理的基础上,利用 FPGA 的 DSP 开发工具 DSP Builder 对直接 数字频率合成器进行了建模设计,仿真结果显示该 DDS 频率及相位可灵活调整, 具有较高的频率分辨率,能够实现频率及相位的快速切换,并将其应用在模拟 调制和数字调制系统中。通过仿真分析证明设计方法的正确性和实用性。 本文对通信信号中的 AM 信号、FM 信号、ASK 信号、FSK 信号、PSK 信号等 根据 DDS 的基本原理,利用 Matlab/DSP Builder 进行建模,然后用 Altera 公 司提供的 Signal Compiler 工具对其进行编译,产生 Quartus II 能够识别的 VHDL 源程序,并且给出了采用 Altera 公司的 Cyclone 系统的 FGPA 芯片 EP1C3T144C8 进行仿真,并用 ModelSim 进行功能仿真及用 Quartus II 进行时 序仿真,以验证所设计的信号满足要求,通过仿真分析设计方法的正确性和实 用性,并用 EDA 实验设备实现,在示波器上观测所设计的信号。文中还简单应 用了 DSP Builder 设计中的层次化设计来完成调制集成系统的研究,有助于设 计复杂的 DSP Builder 模型。 关键字 现场可编程门阵列,直接数字频率合成,模拟调制,数字调制, DSP Builder II II ABSTRACT Direct digital synthesizer technology is widely applied in communication system. Based on studying the basic theory of direct digital synthesizer technology, this passage makes model design of DDS with DSP Builder of FPGA and applies DDS to digital modulation system. This DDSs parameters can be adjusted flexibly, simulation result shows DDS has high resolution and fast setting time. The correctness and feasibility of DDS will be proved through simulation analysis. This article to signals in the signal corresponds which is AM、 FM、ASK 、 FSK、PSK signal is according to the DDS basic principle, established the DDS basic model using Matlab/DSP Builder, then the Signal Compiler tool which provided using the Altera Corporation to it carries on the translation, has VHDL source program which Quartus II could distinguish and produce uses Altera Corporation cyclone series FPGA chip EP1C3T144C8 carries the simulation. Using ModelSim makes the simulation of function, and using Quartus II makes the simulation of order when carries on verify the signal design meet the requirement. Correctness and practicality to design method is analyzed by the simulation And test with EDA the equipment realize and observe and analyze on the oscilloscope signal design. In the article also simply applied DSP Builder design hierarchical design to complete the modulation integrative systems research. it was helpful in design complex DSP the Builder model. Keywords FPGA, DDS,Analog Modulation,Digital Modulation, DSP Builder 1 目 录 摘要 .I ABSTRACTII 1 绪论 1 1.1 课题背景 1 1.2 设计要求 2 2 DDS 的基本原理 .4 3 设计工具 7 3.1 FPGA 性能结构 .7 3.2 基于 EDA 工具的 FPGA 设计流程 .9 3.2.1 EDA 技术 .9 3.2.2 基于 EDA 的 FPGA 开发流程 10 3.3 基于 FPGA 的 DSP 系统设计流程 12 3.4 DSP Builder 及其设计流程 .12 3.4.1 DSP Builder 概述 .12 3.4.2 现代 DSP Builder 设计流程 .13 3.5 QuartusII 简述 .16 4 模拟调制信号发生器设计 18 4.1 DDS 模块设计 .18 4.2 幅度调制(AM)信号发生器的设计 .19 4.2.1 AM 的调制原理 .19 4.2.2 AM 设计模型 .20 4.2.3 Simulink 仿真 .20 4.2.4 使用 Modelsim 实现功能仿真 21 4.2.5 使用 QuartusII 实现时序仿真 22 4.3 频率调制信号(FM)的设计 22 4.3.1 调频信号(FM)的原理 22 4.3.2 FM 设计模型 .23 4.3.3 仿真 23 5 数字调制信号发生器设计 25 5.1 振幅键控(ASK)信号发生器的设计 .25 2 5.1.1 振幅键控(ASK)的基本原理 25 5.1.2 ASK 设计模型 .26 5.1.3 仿真图 26 5.2 频移键控(FSK)信号发生器的设计 27 5.2.1 FSK 调制基本原理 .27 5.2.2 FSK 设计模型 .28 5.2.3 仿真结果 28 5.3 相移键控(PSK)信号发生器设计 29 5.3.1 PSK 调制基本原理 .29 5.3.2 PSK 设计模型 .30 5.3.3 仿真 30 6 调制集成设计 .33 6.1 DSP Builder 的子系统 .33 6.1.1 模拟调制集成系统 33 6.1.2 数字调制集成系统 34 6.2 调制集成系统 34 7 结束语 .35 参 考 文 献 36 致谢 38 1 1 绪 论 1.1 课题背景 无线电技术进行信息传输在现代电子应用中占有及其重要的地位,无线电 通信,电视,雷达,遥控遥测等,都是利用无线电技术传输各种不同信息的方式。 在这些信息的传递过程中,都要用到调制技术。所谓调制是在传送信号的一方 将所要传送的信号“附加”在高频振荡波上,再由发送装置进行传送。本设计 对通信信号中的 AM 信号、FM 信号、ASK 信号、FSK 信号、PSK 信号、正交幅 度调制电路等进行设计,在设计中选用 ALTERA 公司现场可编程门阵列 CYCLONE 系列的器件。通过近 20 年的发展,通信己成为市场最活跃、份额最 高的产业,也成为国际上市场竞争最激烈的部分。 随着调制技术在仪表和通信系统中的广泛应用,一种从参考频率源生成 多种频率的数字控制方法应运而生,这种技术就是 DDS (即直接数字合成)。 DDS 技术是一种从相位概念出发直接合成所需波形的一种新的全数字频率合 成技术。目前, 各大芯片制造厂商都相继推出采用先进 CMOS 工艺生产的 高性能、多功能 DDS 芯片,为电路设计者提供了多种选择。然而在某些场合, 专用 DDS 芯片在控制方式、置频速率等方面与系统的实际要求存在很大差距, 这时可以采用高性能 FPGA 来设计符合具体需要的 DDS 电路。DDS (直接数 字合成) 是近年来迅速发展起来的一种新的频率合成方法。这种方法简单可 靠、控制方便,且具有很高的频率分辨率和转换速度,非常适合快速跳频通 信的要求。 目前不断发展的数字信号处理(DSP,Digital Signal Processing)技术 迅速地扩展到了其应用领域,如 3 G 移动通信、网络会议、多媒体系统、雷 达卫星系统、医学仪器、实时图像识别与处理、联合战术无线电系统、智能 基站以及民用电器等。所有这一切在功能实现、性能指标与成本方面都在不 断增加其要求。 在过去很长一段时间,DSP 处理器(如 TI 的 TMS320 系列)是 DSP 应用系统 核心器件的惟一选择。尽管 DSP 处理器具有通过软件设计能适用于实现不同功 能的灵活性,但面对当今迅速变化的 DSP 应用市场,特别是面对现代通信技术 的发展,DSP 处理器早已显得力不从心。例如其硬件结构的不可变性导致了其 总线的不可改变性,而固定的数据总线宽度,已成为 DSP 处理器一个难以突破 的瓶颈。DSP 处理器的这种固定的硬件结构特别不适合于当前许多要求能进行 结构特性随时变更的应用场合,即所谓面向用户型的 DSP 系统,或者说是用户 可定制型,或可重配置型的 DSP 应用系统(Customized DSP 或 Reconfigurable 2 DSP 等),如软件无线电、医用设备、导航、工业控制等方面。至于在满足速度 要求方面,由于采用了顺序执行的 CPU 架构,DSP 处理器则更加不堪重负。 FPGA 器件集成度高、体积小,具有通过用户编程实现专门应用的功能。使 用 FPGA 器件可以大大缩短系统的研制周期,减少资金投入,更吸引人的是,采 用 FPGA 器件可以将原来的电路板级产品集成为芯片级产品,从而降低了功耗, 提高了可靠性,同时还可以很方便地对设计进行在线修改,因此有时人们也把 FPGA 称为可编程的 ASIC 在这些 FPGA 中,一般都内嵌有可配置的高速 RAM、PLL、LVDS、LVTTL 以及硬件乘法累加器等 DSP 模块。今天大容量、高速 度的 FPGA 的出现,克服了上述方案的诸多不足。它允许电路设计者利用基于计 算机的开发平台,经过设计输入、仿真、测试和校验,知道达到预期的结果。 用 FPGA 来实现数字信号处理可以很好地解决并行性和速度问题,而且其灵活的 可配置特性,使得 FPGA 构成的 DSP 系统非常易于修改、易于测试及硬件升级。 在利用 FPGA 进行 DSP 系统的开发应用上,已有了全新的设计工具和设计流程。 DSP Builder 就是 Altera 公司推出的一个面向 DSP 开发的系统级工具。它 是作为 MATLAB 的一个 Simulink 工具箱(Tool Box)出现的。MATLAB 是功能强大 的数学分析工具,广泛应用于科学计算和工程计算,可以进行复杂的数字信号 处理系统的建模、参数估计、性能分析。Simulink 是 MATLAB 的一个组成部分, 用于图形化建模仿真。 随着数字技术在仪表和通信系统中的广泛应用,一种从参考频率源生成多 种频率的数字控制方法应运而生,这种技术就是DDS(即直接数字合成)。DDS技 术是一种从相位概念出发直接合成所需波形的一种新的全数字频率合成技术。 目前,各大芯片制造厂商都相继推出采用先进CMOS工艺生产的高性能、多功能 DDS芯片,为电路设计者提供了多种选择。然而在某些场合,专用DDS芯片在控 制方式、置频速率等方面与系统的实际要求存在很大差距,这时可以采用高性 能FPGA来设计符合具体需要的DDS电路。 现场可编程门阵列(FPGA)设计无线电和调制解调器与 DSP 芯片比较,虽然 FPGA 可轻而易举地实现如卷积编码器等复杂逻辑功能,但在实现大量复杂计算 方面却有很大的缺陷。FPGA 在通信领域的应用,大大改善了现代通信系统的性 能,FPGA 的应用也极大的推动了 SOC 的发展,随着 DSP 和 FPGA 技术的不断发 展,无线电技术必将成为移动通信中的主流技术,其发展远景非常可观。 1.2 设计要求 课题根据直接数字频率合成原理对通信信号中的 AM 信号、FM 信号、ASK 信号、FSK 信号、PSK 信号、用 DSP Builder 进行建摸,并用 ModelSim 进行功 3 能仿真及用 Quartus II 进行时序仿真,以验证所设计的信号满足要求,并用 EDA 实验设备实现,在示波器上观测所设计的信号。 基于 FPGA 的调制信号发生器的设计主要采用了 FPGA 的硬件设计和 DSP Builder 系统级(或算法级)设计工具来实现。利用 DSP Builder 进行建摸, 同时又通过 Signal Compiler 可以把 Matlab/Simulink 的设计文件(.mdl)转成 相应的硬件描述语言 VHDL 设计文件(.vhd),以及用于控制综合与编译的 TCL 脚本,而对后者的处理可以由 FPGA/CPLD 开发工具 QuartusII 来完成。这样我 们就可以用 ModelSim 进行功能仿真及用 QuartusII 进行时序仿真,以验证所设 计的信号满足要求。并用 EDA 实验设备实现,在示波器上观测所设计的信号。 4 5 2 DDS 的基本原理 实现调幅调频信号的核心是正弦波信号的产生。频率控制、模拟幅度调制 信号、模拟频率调制信号等功能都是围绕该信号展开的。在设计中采用 DDS 技 术产 生不同频率的正弦波,以实现调幅调频信号。 DDS(Direct Digital Synthesizer)即直接数字合成器,是一种新型频率 合成技术,具有较高的频率分辨率,可以实现快速的频率切换,并且在频率改 变 时能够保持相位的连续,很容易实现频率、相位和幅度的数控调制。以正弦信 号发生器为例进行讨论,它的输出可以用下式来描述: 式 (2.1) 其中 是指该信号发生器的输出信号波形, 指输出信号对应的频率。outS outf 上式的表述对于时间 t 是连续的,为了用数字逻辑实现该表达式,必须进行离 散化处理。用基准时钟 进行抽样,令正弦信号的相位:clkf 式 (2.2) 在一个 周期 内,相位的变化量为:clkfclkT 式 (2.3) 其中 指基准时钟频率,对于 ,可以理解成“满”相位。为了 对进clkf 2 行数字量化,把切割成 2N 份,由此,每个 周期的相位增量可用量化值来表clkf 述为: 式 (2.4) 且 为整数,可得:B 式 (2.5) 信号发生器的输出可描述为: out outsini(2).Atfout2foutoutclkclffT2 NBoutclk2NfB 6 式 (2.6) 其中, 指前一个 clk 周期的相位值,同样可以得出:1k 式 (2.7) 由上面的推导可以看出,只要对相位的量化值进行简单的累加运算,就可 以得到正弦信号的当前相位值,而用于累加的相位增量量化值 决定了信号B 的输出频率 ,并呈现简单的线性关系。直接数字合成器 DDS 就是根据上述原outf 理而设计的数字控制频率合成器。 DDS 是以数控的方式产生频率、相位和幅度可以控制的正弦波,图 2.1 所示 是一个基本的 DDS 结构,主要由相位累加器、相位调制器、正弦 ROM 查找表和 D/A 构成。图中的相位累加器、相位调制器、正弦 ROM 查找表是 DDS 结构中的 数字部分,由于具有数控频率合成的功能,又合称为 NCO(Numerically Controlled Oscillators)。 频 率 控 制 字 相 位 控 制 字 同 步 寄 存 器 相 位 累 加 器 寄 存 器 相 位 调 制 器 正 弦 R O M 查 找 表 同 步 寄 存 器 D / A 信 号 输 出 图 2.1 基本 DDS 结构 DDS 系统的核心是相位累加器,它由一个累加器和一个 N 位相位寄存器组 成。每来一个时钟脉冲 fr,相位寄存器以步长 M 增加。相位寄存器的输出与相 位控制字相加,其结果作为正(余)弦查找表地址。当相位累加器累加满量程, 就会产生一次溢出,完成一个周期性的动作,这个周期就合成信号的一个周期, 累加器的溢出频率也就是 DDS 的合成信号频率。在原理框图中,正(余)弦查找 表由 ROM 构成,内部存有一个完整周期正(余)弦波的数字幅度信息,每个查找 表的地址对应正(余)弦波幅度信号,同时输出到数模转换器(DAC)输入端,DAC 输出的模拟信号经过低通滤波器(LPF)可以得到一个频谱纯净的正(余)弦波。 相位累加器是整个 DDS 的核心,在这里完成上文原理推导中的相位累加功 能。相位累加器的输入是相位增量 ,又由于与输出频率 是简单的线性关Boutf 1 1out1 sin2sin()sink kkNSAABAfB 12kN 7 系: 式 (2.8) 故相位累加器的输入又可称为频率字输入,事实上,当系统基准时钟 是clkf 时, 就等于 。频率字输入还经过了一组同步寄存器,使得当频率字改2NBoutf 变时不会干扰相位累加器的正常工作。 相位调制器接收相位累加器的相位输出,在这里加上一个相位偏移值,主 要用于信号的相位调制,如 PSK(相移键控)等。在不使用时可以去掉该部分, 或者加一个固定的相位字输入。相位字输入也需要用同步寄存器保持同步。需 要注意的是,相位字输入的数据宽度 M 与频率字输入 N 往往是不相等的,一般 MN。 正弦 ROM 查找表完成 的查表转换,也可以理解成相位到幅度的转换,sin()fB 它的输入是相位调制器的输出,事实上就是 ROM 的地址值,输出送往 D/A,转 化成模拟信号。由于相位调制器的输出数据位宽 M 也是 ROM 的地址位宽,因此 在实际的 DDS 结构中 N 往往很大,而 M 总为 10 位左右。 M 太大会导致 ROM 容量 的成倍上升,而输出精度受 D/A 位数的限制未有很大改善。因此,在实际应用 中,对于 ROM 容量的缩小,人们提出了很多解决方法。 基本 DDS 结构的常用参量计算。 1) DDS的输出频率 由 DDS 工作原理推导的公式中很容易得出输出频率的计算: 式(2.9) 是频率输入字, 是系统基准时钟的频率值, N 是相位累加器的数据Bclkf 位宽,也是频率输入字的数据位宽。 2) DDS 的频率分辨率 或称频率最小步进值,即 为时,可用频率输入值步进一个最小间隔B 对应的频率输出变化量来衡量。 式 (2.10) 3) DDS的频率输入字的计算 的计算公式如下: B 式 (2.11) outclk2/NBf outclk2NBffclkout2Nf outclk2NfB 8 7 3 设计工具 3.1 FPGA 性能结构 随着微电子技术的飞速发展,可编程逻辑器件的发展取得了长足的进步, FPGA(现场可编程门阵列)与CPLD(复杂可编程逻辑器件)都是可编程逻辑器件。 CPLD(Complex Programmable Logic Device)和FPGA (Field Programmable Gate Array)已成为目前在电子系统设计中应用最广泛的可编程逻辑器件。它们 都具有体系结构和逻辑单元灵活、集成度高以及适用范围宽等特点。与同门阵 列等其它ASIC(Application Specific Integrated Circuit)相比,它们又具有 设计开发周期短、设计制造成本低、开发工具先进、可实时在线检验等优点, 因此被广泛应用于产品的原型设计和产品生产之中。本文的设计中用到了 Altera公司的FPGA芯片,因此以下将主要介绍FPGA的结构、原理及设计。 FPGA 器件是由大量逻辑宏单元构成的。通过配置可以使这些逻辑宏单元形 成不同的硬件结构,从而构成不同的电子系统,完成不同的功能。正是 FPGA 的 这种硬件重构的灵活性,使得设计者能够将硬件描述语言(如 VHDL 或 Verilog) 描述的电路在 FPGA 中实现。这样以来,同一块 FPGA 能实现许多完全不同的电 路结构和功能。如 DSL 布线器、数字调制解调器、JPEG 编码器、数字通信系统 以及网络接口等等。 简化的FPGA的结构由4部分组成:输入/输出模块、二维逻辑阵列模块、连 线资源和内嵌存储器模块。输入/输出模块是芯片与外界的接口,完成不同电气 特性下的输入输出功能要求。二维逻辑阵列模块是可编程逻辑的主体,可以根 据设计灵活地改变连接与配置,以完成不同的逻辑功能,FPGA的二维逻辑阵列 模块是基于可编程的查找表(Look Up Table, LUT)结构的,LUT是可编程的最小 逻辑构成单元,连线资源连接所有的二维阵列模块和输入输出模块线长度和工 艺决定着信号在连线上驱动能力和传输速度。内嵌存储器结构可以在芯片内部 存储数据。 现场可编程门阵列(FPGA)是由掩膜可编程门阵列(MPGA)和可编程逻辑器件 二者演变而来的,将它们的特性结合在一起,既有门阵列的高逻辑和通用性, 又 有可编程逻辑器件的用户可编程特性。FPGA 通常由布线资料分隔的可编程逻辑 单元(或宏单元)构成阵列,又由可编程 YO 单元围绕阵列构成整个芯片。其内部 资源是分段互连的,因而延时是不可预测的,只有编程完毕后才能实际测量。 FPGA 建立内部可编程逻辑连接关系的编程技术有三种: 8 1)基于反熔丝技术的器件只允许对器件编程一次, 编程后不能修改。 其 优点是集成度、工作频率和可靠性都很高,适用于电磁辐射干扰比较强的恶劣 环境。 2)基于 EEPROM 存储器技术的可编程逻辑芯片能够重复编程 100 次以上,系 统掉电后编程信息也不会丢失,编程方法分为在编程器上编程和用下载电缆编 程。用下载电缆编程的器件,只要先将器件装焊在印刷电路板上,通过 PC、SUN 工作站、ATE(自动测试仪)或嵌入式微处理系统,就能产生编程所用的 标准 5V、3.3V 或 2.5V 的逻辑电平信号,也称为 ISP(In System Programmable)方 式编程,其调试和维护也很方便。 3)基于 SRAM 技术的器件编程数据存储于器件的 RAM 中,具有用户设计的功 能。在系统不加电时,编程数据存储在 EPROM、硬盘或软盘中;系统加电时将 这些编程数据即时写入可编程器件中,从而实现板级或系统级的动态配置。 FPGA作为新一代的可编程逻辑器件,由于其基本原理的特殊性,除了具有 一般可编程逻辑器件的特点之外,在电子系统设计中还具有一些自己的特点: 1)编程方式简便灵活。对于基于SRAM LUT结构的FPGA器件由于SRAM 的掉 电易失性, 其编程采用ICR方式即在线可重配置方式。对于ICR方式的实现有多 种选择,在调试时可使用PC机并行口实现,在实际应用中可使用专用配置器件 或者微处理器等来实现ICR。 2)开发工具和设计语言标准化,开发周期短。由于EDA开发工具的通用性、 设计语言的标准化以及设计过程几乎与所用的FPGA器件的硬件结构没有关系, 所以从而使得片上系统的产品设计效率大幅度提高,开发周期大大缩短。 3)功能强大,应用广阔。目前,FPGA可供选择范围很大,可根据不同的应 用选用不同容量的芯片。利用它们可实现几乎任何形式的数字电路或数字系统 得设计。 随着达数百万门高密度的 FPGA 的出现,FPGA 在原有的高密度的逻辑宏单 元的基础上嵌入了许多面向 DSP 的专用硬核模块,结合大量可配置于 FPGA 硬件 结构中的参数化的 DSP IP 软核,DSP 开发者能十分容易地将整个 DSP 应用系统 实现在一片 FPGA 中,从而实现了所谓的可编程 SOC 系统,即 SOPC。 现代大容量、高速度的 FPGA 的出现,克服了上述方案的诸多不足。FPGA 器件集成度高、体积小,具有通过用户编程实现专门应用的功能。它允许电路 设计者利用基于计算机的开发平台,经过设计输入、仿真、测试和校验,知道 达到预期的结果。使用 FPGA 器件可以大大缩短系统的研制周期,减少资金投入。 更吸引人的是,采用 FPGA 器件可以将原来的电路板级产品集成为芯片级产品, 从而降低了功耗,提高了可靠性,同时还可以很方便地对设计进行在线修改, 9 因此有时人们也把 FPGA 称为可编程的 ASIC 在这些 FPGA 中,一般都内嵌有可配 置的高速 RAM、PLL、LVDS、LVTTL 以及硬件乘法累加器等 DSP 模块。用 FPGA 来 实现数字信号处理可以很好地解决并行性和速度问题,而且其灵活的可配置特 性,使得 FPGA 构成的 DSP 系统非常易于修改、易于测试及硬件升级。 在利用 FPGA 进行 DSP 系统的开发应用上,已有了全新的设计工具和设计 流程。DSP Builder 就是美国 Altera 公司推出的一个面向 DSP 开发的系统级 工具。它是作为 MATLAB 的一个 Simulink 工具箱(Tool Box)出现的。MATLAB 是功能强大的数学分析工具,广泛应用于科学计算和工程计算,可以进行复 杂的数字信号处理系统的建模、参数估计、性能分析。Simulink 是 MATLAB 的一个组成部分,用于图形化建模仿真。 现场可编程门阵列(FPGA)设计无线电和调制解调器与 DSP 芯片比 较,虽然 FPGA 可轻而易举地实现如卷积编码器等复杂逻辑功能,但在实现大量 复杂计算方面却有很大的缺陷。FPGA 在通信领域的应用,大大改善了现代通信 系统的性能,FPGA 的应用也极大的推动了 SOC 的发展,随着 DSP 和 FPGA 技术 的不断发展,无线电技术必将成为移动通信中的主流技术。FPGA 在通信领域的 应用,大大改善了现代通信系统的性能,FPGA 的应用也极大的推动了 SOC 的发 展。FPGA 在通信领域的应用,大大改善了现代通信系统的性能,FPGA 的应用也 极大的推动了 SOC 的发展。 FPGA 中的面向 DSP 的嵌入式模块有可配置 RAM、DSP 乘加模块和嵌入式处 理器等,使 FPGA 能很好地适用于 DSP 功能的实现。乘法器的带宽决定了整个 DSP 的带宽,而 FPGA 的 DSP 带宽比 DSP 处理器要宽得多。此外,绝大部分的 DSP 处理器应用系统是用外部存储器来解决大数据量的处理的。然而 FPGA 的嵌 入式高速可配置存储器在大多数情况下都能满足相类似的数据处理要求。FPGA 中的嵌入式处理器进一步提高了 FPGA 的系统集成和灵活性,使之成为一个软件 与硬件联合开发和灵活定制的结合体,可使设计者既能在嵌入式处理器中完成 系统软件模块的开发和利用,也能利用 FPGA 的通用逻辑宏单元完成硬件功能模 块的开发。Altera 的 FPGA 器件还为用户提供了嵌入式处理器软核与硬核的选 择。现代的 FPGA 中含有十分灵活的、针对特定算法的加速器模块。与传统的 DSP 处理器中的加速器模块不同,FPGA 中实现的硬件加速器是可以针对不同应 用的,这可以使设计者针对不同的 DSP 任务实现硬件功能。 3.2 基于 EDA 工具的 FPGA 设计流程 3.2.1 EDA技术 现代电子技术的核心是EDA (Electronic Design Automation电子设计自动 10 化)技术。 EDA技术就是依赖功能强大的计算机,在EDA工具软件平台上,对以 硬件描述语言HDL(Hardware Description Language)为系统逻辑描述手段完成 的设计文件,自动地完成逻辑编译、逻辑化简、逻辑分割、逻辑综合、结构综 合(布局布线)以及逻辑优化和仿真测试,直至实现既定的电子线路系统功能。 EDA技术使得设计者的工作仅限于利用软件的方式,即利用硬件描述语言和EDA 软件来完成对系统硬件功能的实现。 EDA技术在硬件实现方面融合了大规模集成电路制造技术:IC版图设计技术、 ASIC测试和封装技术、FPGA/CPLD编程下载技术、自动测试技术等。在计算机辅 助工程方面融合了计算机辅助设计(CAD),计算机辅助制造(CAM)、计算机辅助测 试(CAT)、计算机辅助工程(CAE)技术以及多种计算机语言的设计概念,而在现 代电子学方面则容纳了更多的内容,如电子线路设计理论、数字信号处理技术、 数字系统建模和优化技术及长线技术理论等等。因此EDA技术为现代电子理论和 设计的表达与实现提供了可能性。当然,这里的所谓EDA主要是指数字系统的自 动化设计,因为这一领域的软硬件方面的技术已比较成熟,应用的普及程度也 比较高。而模拟电子系统的EDA正在进入实用,其初期的EDA工具不一定需要硬 件描述语言。此外,从应用的广度和深度来说,由于电子信息领域的全面数字 化,基于EDA的数字系统的设计技术具有更大的应用市场和更紧迫的需求性。 EDA技术的发展历程同天规模集成电路设计技术、计算机辅助工程、可编程 逻辑器件以及电子设计技术和工艺的发展是同步的。20世纪80年代,集成电路 设计进入了CMOS(互补场效应管)时代,复杂可编程逻辑器件已进入商用阶段, 而在80年代末,出现了FPGA(Field programmable Gate Array现场可编程门阵 列)和CPLD(Complex Programmable Logic Device复杂可编程逻辑器件),其特 点是直接面向用户,具有极大的灵活性和通用性,使用方便,硬件测试和实现 快捷,开发效率高,电子系统设计工程师可以在实验室中设计出专用的IC, 实 现系统的集成,从而大大缩短了产品上市时间,降低了开发成本。进入20世纪 90年代,集成电路设计工艺步入了超深亚微米阶段,百万门以上的大规模可编 程逻辑器件陆续面世,促进了FDA技术的形成。更为重要的是各EDA公司致力于 推出兼容各种硬件实现方案和支持标准硬件描述语言的EDA工具软件的研究,这 些都有效地将EDA技术推向成熟。 3.2.2 基于 EDA 的 FPGA 开发流程 图 3.1 基于 EDA 工具的 FPGA 开发流程框图,对于目前流行的 EDA 工具软件, 其设计流程具有一般性,以下将依次各部分的功能。 11 图3.1 基于EDA的FPGA设计流程 设计输入是设计者将所要设计的电路以开发软件要求的某种形式表达出来, 并输入到相应软件中的过程。设计输入有多种表达方式,最常用的是图形输入 中的原理图输入方式和HDL文本输入方式两种。原理图输入方式的特点是适合描 述连接关系和接口关系,而描述逻辑功能则比较繁琐;而用HDL文本来描述设计, 其逻辑描述能力强,但描述接口和连接关系则不如图形方式直观。目前有些EDA 输入工具可以把图形的直观与HDL的优势结合起来。但总体上看,纯粹的HDL文 本输入设计仍然是最基本、最有效和最通用的输入方法。 综合(Synthesis)指的是将行为和功能层次表达的电子系统转换为低层次的 便于具体实现的模块组合装配而成的过程。整个综合过程就是将设计者在EDA平 台上编辑输入的HDL文本、原理图描述,依据给定的硬件结构组件和约束控制条 件进行编译、优化、转换和综合,最终获得门级电路甚至更底层的电路描述网 表文件。 适配器也称为结构综合器,它的功能是将由综合器产生的网表文件配置于 指定的目标器件中,使之产生最终的下载文件,如对FPGA器件,产生Bit stream位流数据文件。通常,EDA软件中的综合器可由专业的第三方EDA公司提 供,而适配器则需由FPGA供应商提供。 仿真就是让计算机根据一定的算法和一定的仿真库对EDA设计进行模拟,以 验证设计,排除错误。仿真是在EDA设计过程中的重要步骤,它包括功能仿真和 时序仿真。不考虑信号时延等因素、不涉及任何具体器件的硬件特性的仿真称 12 为功能仿真,又叫前仿真;时序仿真又称后仿真,它是在选择了具体器件并完 成了布局布线后进行的包含定时关系的仿真。 把适配后生成的下载或配置文件,通过编程器或编程电缆装入FPGA中的过 程称为下载。通常将对基于SRAM工艺结构的FPGA器件的下载称为配置 (Configure)。如上一小节所述,FPGA器件的配置方式灵活,有多种的方式可供 选择。 3.3 基于 FPGA 的 DSP 系统设计流程 在早些时候,DSP 开发者只能直接使用 VHDL 或 Verilog HDL 语言进行 FPGA 的 DSP 系统设计,难度比较大。现在已经出现了许多新的基于 FPGA 的 DSP 开发工具。如 DSP Builder、SOPC Builder、System Generator 等,以及完整 的软件开发平台。从而使得设计者能遵循一条类似于软件设计流程的开发方法 进行 FPGA 的 DSP 设计,设计效率大为提高。 图 3.2 所示的流程则表明基于 FPGA 的 DSP 开发流程中,顶层的开发工具就 是 MATLAB /Simulink,整个开发流程几乎完全可以在同一环境中完成。真正实 现了自顶向下的设计流程,包括 DSP 系统的建模、系统级仿真、设计模型向 VHDL 硬件描述语言代码的转换、RTL 级功能仿真测试、编译适配和布局布线、 时序实时仿真,直至对 DSP 目标器件的编程配置。整个设计流程一气呵成地将 系统描述和硬件实现有机地融为一体,充分显示了现代电子设计自动化开发的 特点与优势。 图 3.2 基于 FPGA 的系统级开发流程 MATLB/Simulink建 模 /仿 真VHD转 换 逻 辑 综 合 功 能 仿 真 /编 译 适 配 /时 序 实 时 仿 真 /硬 件 配 置DSP系 统 建 模DSP Buildet 综 合 、 适 配布 线 、 布 局( Quarts )基 于 IP核 的DS库FPGADS系 统 实 现 13 3.4 DSP Builder 及其设计流程 3.4.1 DSP Builder 概述 DSP Builder 是一个系统级(或算法级)设计工具,它架构在多个软件工具 之上,并把系统级和 RTL 级两个设计领域的设计工具连接起来,最大程度地发 挥了两种工具的优势。DSP Builder 依赖于 Math Works 公司的数学分析工具 MATLAB/Simulink,以 Simulink 的 Blockset 出现,可以在 Simulink 中进行图 形化设计和仿真,同时又通过 Signal Compiler 可以把 MATLAB/Simulink 的设 计文件(.mdl)转成相应的硬件描述语言 VHDL 设计文件(.vhd),以及用于控制综 合与编译的 TCL 脚本。而对后者的处理可以由 FPGA/CPLD 开发工具 QuartusII 来完成。 由于在 FPGA 上设计一个 DSP 模块的复杂性,设计的性能(包括面积、速度、 可靠性、设计周期)对于不同的应用目标将有不同的要求,涉及的软件工具也不 仅仅是 Simulink 和 Quartus II。DSP Builder 针对不同情况提供了两套设计流 程,即自动流程和手动流程。 DSP Builder 设计流程的第一步是在 MATLAB/Simulink 中进行设计输入, 即在 MATLAB 的 Simulink 环境中建立一个.mdl 模型文件,用图形方式调用 Altera DSP Builder 和其它 Simulink 库中的图形模块(Block),构成系统级或 算法级设计框图(或称 Simulink 设计模型)。 第二步是利用 Simulink 强大的图形化仿真、分析功能,分析此设计模型的 正确性,完成模型仿真。 在这两步中,与一般的 MATLAB Simulink 建模过程几乎没有什么区别,所 不同的是设计模型库采用 Altera DSP Builder 的 Simulink 库,也不涉及到其 它 EDA 软件,没有自动流程和手动流程的区别。 第三步是 DSP Builder 设计实现的关键一步,通过 Signal Compiler 把 Simulink 的模型文件(后缀为.mdl)转化成通用的硬件描述语言 VHDL 文件(后缀 为.vhd)。由于 EDA 工具软件(诸如 QuartusII、ModelSim)不能直接处理 MATLAB 的.mdl 文件,这就需要一个转换过程。转换获得的 HDL 文件是基于 RTL 级(寄 存器传输级)的 VHDL 描述。 3.4.2 现代 DSP Builder 设计流程 设计流程从利用 MATLAB 建立 DSP 电路模型开始。电路模型的建立可以是图 形化的,可以方便地利用 Simulink 与 DSP Builder 中提供的丰富的功能块和 IP 核进行设计。DSP Builder 包括比特和周期精度的 Simulink 模块,还涵盖了 诸如算术和存储功能的基本设计模块以及 IP 库中的许多复杂的功能模块。电路 中的功能块和 IP 的技术参数、数据格式、数据类型和总线宽度等都可以直接设 14 置。电路模型设计完成后,可以进行系统级的模型仿真,属于系统功能仿真, 与目标器件和硬件系统没有关系,是基于算法的仿真。 接下去是利用置于 Simulink 电路模型界面的 DSP Builder 的 Signal Compiler,将电路模型文件即 Simulink 模块文件转换成 RTL 级的 VHDL 代码表 述和 Tcl 脚本。这种转换是基于 Simulink 模型的结构化分析的。RTL 级 VHDL 代码通俗的解释就是在 FPGA 中完成硬件电路实现的 VHDL 程序。Tcl 脚本主要 是用于对后续的 VHDL 综合与仿真的控制与规范。 一旦获得了转换好的 VHDL 描述,在 Simulink 中即可调用 VHDL 综合器了。 目前可选择的综合器主要有 Quartus II、Synplify 和 Leonardo Spectrum。由 它们生成底层网表文件。注意,只有在此时才能真正确定 DSP 硬件实现的目标 器件的选择,包括 FPGA 器件的系列和型号。因为对 RTL 级的 VHDL 综合,必须 确定底层元件的工艺特性和结构特性,但不必了解硬件时序特性,只有在适配 时才需要时序信息。 下一步是调用 Quartus II 中的编译器,根据网表文件及设置的优化约束条 件进行布线布局和优化设计的适配操作。最后生成编程文件和仿真文件,即生 成 POF 和 SOF FPGA 配置文件,可用于对目标器件的编程配置和硬件实现;同时 生成可分别用于 Quartus II 的门级仿真文件和 ModelSim 的 VHDL 时序仿真文件, 以及配套的 VHDL 仿真激励文件,可用于实时测试 DSP 系统的工作性能。 上面的 Signal Compiler 生成的 VHDL,在进入 ModelSim 仿真流程获得的 结果与硬件时序没有关系,属于功能仿真结果;而当由 Quartus II 生成的 VHDL 仿真文件,进入 ModelSim 仿真流程后获得的仿真结果属于时序仿真,即 是对系统的实时测试结果。图 3.3 是 DSP Builder 的设计流程图: M a t l a b S i m u l i n k 建立模型 S i m u l i n k 模型仿真 m d l 转成 v h d l H D L 仿真 ( M o d e l S i m ) 综合 ( Q u a r t u s , L e o n a r d o S p e c t r u m , S y n p l i f y ) 综合 ( Q u a r t u s , L e o n a r d o S p e c t r u m , S y n p l i f y ) A T O M N e t l i s t 产生 Q u a r t u s Q u a r t u s 生成编程文 件 ( . p o f , . s o f ) 下载至硬件 自动流程 15 图 3.3 DSP Builder 设计流程 再接下来的几个步骤是对以上设计产生的 VHDL 的 RTL 代码和仿真文件进行 综合、编译适配以及仿真。为了针对不同用户的设计目的和设计要求,DSP Builder 提供了两种不同的设计流程,主要可以分为自动流程和手动流程。 如果采用 DSP Builder 的自动流程,几乎可以忽略硬件的具体实现过程, 可以选择让 DSP Builder 自动调用 Quartus II 等 EDA 设计软件,完成综合 (Synthesis)、网表(ATOM Netlist)生成和 Quartus II 适配,甚至在 Matlab 中 完成 FPGA 的配置下载过程。 如果希望使用其它第三方的 VHDL 综合器和仿真器(除 Synplify、Leonardo Spectrum 和 Quartus II 综合器及 ModelSim 外) ,或是希望完成特定的适配设 置,如逻辑锁定、时序驱动编译、ESB 特定功能应用等,可以选用手动流程设 计。 在手动流程中,设计者可以灵活地指定综合、适配条件。不过,需要手动 地调用 VHDL 综合器进行综合,调用 Quartus II 进行适配,调用 ModelSim 或者 Quartus II 进行仿真,最后用 Quartus II 产生相应的编程文件用于 FPGA 的配 置。 采用手动流程时,除了行为级仿真验证和设计输入外,其它过程与标准的 基于 VHDL 的 EDA 设计流程是完全一致的。由上一步 DSP Builder 设计流程得到 VHDL 文件(由 Simulink 模型文件*.mdl 通过 Signal Compilder 转换而成),送 入综合器进行综合。综合器可以是 Synplify Pro,也可以是 Leonardo Spectrum,或者采用 Altera 自己的 Quartus II。在综合时,可能需要对综合 器进行配置或者提供综合的约束条件。由于这个过程操作可能比较繁琐,所以 DSP Builder 的 Signal Compiler 相应提供了一个接口,针对设计,自动产生 一个 TCL 脚本与综合器 Synplify 或者 Leonardo Spectrum 相接。 综合器在综合操作后会产生一个网表文件,以供下一个流程使用。这里产 生的网表文件称为 ATOM 网表文件(如图 3.3 所示),主要是 EDIF 网表文件(.edf 电子设计交换格式文件)或 VQM
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 市场推广和广告宣传合同协议
- 时间的脚印教学课件
- 雨霖铃:宋词鉴赏与写作手法教学教案
- 水果简介100字(12篇)
- 早期食道癌造影表现
- 早期教育剪刀效应课件
- 期末考试作文第一次炒米花700字(7篇)
- 广告代理发布业务协议
- 早教托育营养知识培训课件
- 2025年南宁市事业单位招聘考试综合类专业能力测试试卷(文秘类)备考指南
- 项目部安全管理组织机构网络图GDAQ20102
- 卫生部《病历书写基本规范》解读(73页)
- 南方332全站仪简易使用手册
- 分汽缸安装施工方案1
- 人民调解员培训讲稿村级人民调解员培训.doc
- 高低压配电安装工程-技术标部分(共41页)
- 开业筹备(西餐厅采购物品)
- 日产700吨平板玻璃电助熔窑炉设计本科毕业论文
- 光缆熔接光纤熔接
- 图画捉迷藏-A4打印版
- 受限空间作业票
评论
0/150
提交评论