《基于VHDL的PWM信号发生器的设计毕业论文1.doc》由会员分享,可在线阅读,更多相关《基于VHDL的PWM信号发生器的设计毕业论文1.doc(19页珍藏版)》请在三一办公上搜索。
1、 Yi bin UniversityEDA技术及应用课程设计报告 题 目 基于VHDL的PWM信号发生器系 别 物理与电子工程学院 专 业 电子信息科学与技术 摘要本次课程设计是基于VHDL的PWM信号发生器,PWM信号发生器应用所学的数字电路和模拟电路的知识进行设计。在设计过程中,所有电路仿真均基于Quartus II 9.1仿真软件。本课程设计介绍了PWM信号发生器的设计方案及其基本原理,并着重介绍了PWM信号发生器各单元电路的设计思路,原理及仿真,整体电路的的工作原理,控制器件的工作情况。设计共有三大组成部分:一是原理电路的设计,本部分详细讲解了电路的理论实现,是关键部分;二是性能测试,
2、这部分用于测试设计是否符合任务要求。三是是对本次课程设计的总结。关键词: PWM信号发生器 仿真 设计 目录第1章 绪论 1.1 EDA 和Quartus的简介及起源1 1.2 EDA的优势及发展趋势1第2章 系统设计思路3第3章 可自加载加法计数器的设计4第4章 信号发生器设计过程6第5章 软件仿真 5.1 Quartus 软件简介8 5.2 用Quartus 的仿真步骤和图像9 5.3 逻辑综合结果12第6章 设计总结13第7章 参考文献15附 录 设计程序 16 第1章 绪论1.1 EDA和Quartus的简介及起源EDA是英文“electronic design automation”
3、(电子自动化设计)的缩写,EDA技术是20世纪90年代迅速发展起来的,是现代电子设计的最新技术潮流,是综合现代电子技术和计算机技术的最新研究成果,是电子线路设计与分析的一门技术。EDA包括电子线路的设计、计算机模拟仿真和电路分析及印制电路板的自动化设计三个方面的内容。随着可编程逻辑器件迅速发展,出现了功能强大的全新的EDA工具。具有较强描述能力的硬件描述语言(VHDL、Verilog、HDL)及高性能综合工具的使用,使过去单功能电子产品开发转向系统级电子产品开发。Quartus是Altera提供的FPGA/CPLD开发集成环境,Altera是世界上最大的可编程逻辑器件供应商之一。Quartus
4、是在21世纪初推出,是Altera前一代FPGA/CPLD集成开发环境MAX+plus 的更新换代产品,其界面友好,使用环境便捷。它提供了一种与结构无关的设计环境,使设计者能方便地进行设计输入、快速处理和器件编程。Quartus设计工具完全支持VHDL、Verilog的设计流程,其内部嵌有VHDL、Verlog逻辑综合器。Quartus包括模块化的编译器。编译器包括 的功能模块有分析/综合器(Analysis & Synthesis)、适配器(Fitter)、装配器(Assembler)、时序分析器(Timing Analyzer)、设计辅助模块(Design Assistant)、EDA网表
5、文件生成器(EDA Netlist Writer)、编辑数据接口(Compiler Database Interface)等。可以通过选择Start Compilation来运行所有的编译器模块,也可以通过选择Start来单独运行各个模块。还可以通过选择Compiler Tool,在Compiler Tool窗口中运行该模块来启动编译器模块。在Compile Tool窗口中,可以打开该模块的设置文件或报告文件,或打开其它相关窗口。1.2 EDA的优势及其发展趋势EDA技术的优势体现在:l 用HDL对数字系统进行抽象的行为与功能描述到具体的内部线路结构,从而可以在电子设计的各个阶段、各个层次进行
6、计算机模拟验证,保证设计过程的正确性,可以大大降低设计成本,缩短设计周期。l EDA工具之所以能够完成各种自动设计过程,关键是有种类库的支持,如逻辑仿真时的模拟库、逻辑综合时的综合库、版图综合时的版图库、测试综合时的测试库等。l 某些HDL本身也是文档型的语言(如VHDL),极大地简化了设计文档的管理。l EDA中最为瞩目的功能,最具现代化电子设计技术特征的功能,是日益强大的逻辑设计仿真测试技术。极大地提高了大规模系统电子设计的自动化程度。EDA的发展趋势,表现在以下几个方面:l 超大规模集成电路的集成度和工艺水平不断提高,深亚微米(Deep-Submicron)工艺,如0.13um、90nm
7、已经走向成熟,在一个芯片上完成的系统级的集成已经成为可能。l 由于工艺不断减小,在半导体材料上的许多寄生效应已经不能简单地补码忽略,这就对EDA工具提出了更高的要求。同时,也使得IC生产线的投资更为巨大。l 高性能的EDA工具得到长足的发展,其自动化和智能化程度不断提高,为嵌入式系统设计提供了功能强大的开发环境。l 市场对电子产品提出了更高的要求,从而也对系统的集成度不断提出更高的要求。同时,设计的效率也成了一个产品能否成功的因素,促使EDA工具应用更为广泛。第2章 系统设计思路PWM即脉冲宽度调制,就是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术。PWM从处理器到被控制系统
8、信号都是数字式的,无需进行数/模转换。让信号保持为数字形式可将噪声影响降到最小,因此广泛应用在测量、通信和功率控制与变换的许多领域中。下图是一种PWM信号发生器的逻辑图,此信号发生器是由两个完全相同的可自加载加法计数器LCNT8组成的,它的输出信号的高、低电平脉宽可分别由两组8位预置数进行控制。 图一 脉宽数控调制信号发生器逻辑图如果将初始值可预置的加法计数器的溢出信号作为本计数器的初始预置值加载信号LD,则可构成计数器初始值自加载方式的加法计数器,从而构成数控分频器。图中D触发器的一个重要功能就是均匀输出信号的占空比, 提高驱动能力,这对驱动,诸如扬声器或电动机十分重要。第3章 可自加载加法
9、计数器的设计取计数器的端口为:脉冲输入端CLK、加载使能输入端LD(高电平有效)、预置输入端D、计数进位输出端DOVE。当脉冲CLK上升沿到来之时,若加载使能端LD有效,则通过预置端D可对计数器进行预置数。之后,计数器就以此预置数为始,一直加1计数。至计数到255时,输出端DOVE输出1。框图如图二。其VHDL程序如下:LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY LCNT8 ISPORT (CLK, LD: IN STD_LOGIC; D: IN INTEGER RANGE 0 TO 255; DOVE: OUT STD_LOGIC);END
10、 LCNT8;ARCHITECTURE ART OF LCNT8 ISSIGNAL COUNT: INTEGER RANGE 0 TO 255; BEGIN PROCESS (CLK) IS BEGIN IF CLKEVENT AND CLK=1 THEN IF LD=1 THEN COUNT=D; ELSE COUNT= COUNT+1; END IF; END IF; END PROCESS; PROCESS (COUNT) IS BEGIN IF COUNT=255 THEN DOVE=1; ELSE DOVECLK, LD=LD1, D=A, DOVE=DOVE1); U2: LCNT
11、8 PORT MAP (CLK=CLK, LD=LD2, D=B, DOVE=DOVE2); PROCESS (DOVE1, DOVE2) IS BEGIN IF DOVE1=1 THEN SPWM=0; ELSIF DOVE2EVENT AND DOVE2=1 THEN SPWM=1; END IF;END PROCESS; LD1=NOT SPWM; LD2=SPWM; YPWM=SPWM;END ARCHITECTURE ART;第5章 软件仿真5.1 Quartus 软件简介Quartus 软件是美国Altera公司为SOPC(System on a Programmable Chip
12、,系统级可编程芯片)提供最全面的设计平台。比起其他的编译软件,它具有以下的优点:1】 开放的界面Quartus 软件可与其他EDA厂家的设计输入、综合、验证工具相连接。设计人员可使用Quartus 编译器(Compiler)对ALTERA的器件进行编译,然后使用ALTERA或其他标准EDA验证工具进行验证。目前,Quartus 支持Cadence、Exemplarlogic、Mentor Graphics、Synopsys、Synplicity、Viewlogic等公司的EDA工具接口。2】 与结构无关Quartus 系统的核心编译器(Compiler)支持ALTERA公司的FLEX10K,F
13、LEX8000,FLEX6000,MAX9000,MAX7000,MAX5000和Classic等可编程逻辑器件系列,处理Maxplus以外唯一真正与结构无关的可编程逻辑设计环境。Quartus 的编译器还提供了强大的逻辑综合与优化功能,使设计人员能比较容易地将其设计集成到可编程逻辑器件中。3】 多平台Quartus 软件可在多种PC机和工作站的操作系统中运行。4】 完全集成化Quartus 的设计输入、处理、验证、器件编程等功能全部集成在统一的开发环境下,可以使用户进行动态调试,加快开发进程。5】 丰富的设计库Quartus 提供丰富的库单元供设计者使用,其中包括74系列的全部器件和多种特殊
14、的逻辑宏功能(MacroFunction)以及新型的参数化兆功能(MegaFunction)。6】 接受高级描述语言Quartus 接受多种硬件描述语言,包括VHDL、AHDL、C、C+等语言。7】 良好的人机界面Quartus 具有比Maxplus更加人性化的人机界面,方便工程人员的操作,基于上述特点,本文采用Quartus 软件对DDS频率合成器仿真验证。5.2用Quartus 的仿真步骤和图像主要步骤:第一步:建立工程 图四 建立工程图第二步:建立VHDL文件 图五 建立VHDL文件图第三步:写入VHDL文件 图六 部分VHDL文件截图第四步:建立模块文件 图七 建立模块文件图第五步:连
15、接各模块形成总体原理图S 图八 模块总体结构逻辑图第六步:编译做好的文件 图九 编译成功图第七步:建立波形文件 图十 建立波形文件图第八步:仿真输入取s,y。仿真波形,如下图: 图十一 PWM的时序仿真结果5.3 逻辑综合结果 图十二 逻辑综合结果图第6章 设计总结在传统的数字电子系统或IC设计中,手工设计占了较大的比例。一般都是先按电子系统的具体功能要求进行功能划分,然后对每个子模块画出真值表,用卡诺图进行手工逻辑简化,写出布尔表达式,画出相应的逻辑线路图,再据此选择元器件,设计电路板,最后进行实测与调试。显然,手工设计的缺点让人越来越不可接受。故而,EDA技术变得越来越重要,作为当代大学生
16、,要与时俱进,更要掌握这种电子自动化设计。通过EDA的模拟编译、适配、仿真,可以大大缩短设计周期,降低设计成本。EDA仿真测试技术只需通过计算机就能对所设计的电子系统从各种不同层次的系统性能特点完成一系列准确的测试与仿真操作,在完成实际系统的安装后,还能对系统的目标器件进行所谓边界扫描测试、嵌入式逻辑分析仪的应用,这一切都极大地提高了大规模系统电子设计的自动化程度。通过对本设计基于VHDL的PWM信号发生器的设计的学习和研究,让我对硬件系统有了更深入的理解,扩展了很多的知识。做这个设计包含了很多的知识和内容,如EDA、FPGA、VHDL、Quartus 、Word、等知识,让我受益匪浅。在做这
17、个之前,坦白说对于EDA真的没有深入地学习研究,对于Quartus 软件也是完全不懂。老师开学就说了要做这个设计,我也没有放在心上,一直到期末才重视起来,各种知识的补充学习,最后就是一团乱麻,什么也没弄好。后面在班上同学的指导下,才开始安装Quartus 软件,然后再去翻阅书籍,百度百科,咨询同学,一点一点地去摸索这个软件是怎么运用的,最主要是上面全是英文,对于英语非常差的我来说,彻底熟悉这个软件就用了很长后一段时间。后面开始想要把书上的程序改编一下,虽然不是很懂,但是后来我实在不知道怎么去改了,就只是改变了一下输入输出和其他的一些代号而已。程序解决了就开始编译执行,结果就卡在这儿弄不了啦,因
18、为错误实在太多,最让我疑惑的是,明明就是书上的程序改变了一下名字而已,为什么会有那么多错误呢?后面仔仔细细地去检查了一下,才发现,都是粗心惹的祸,其实,编程也是要耐心和细心的。最后终于编译仿真出波形来,除了输入输出代号被改变了,波形和书上是一样的。在做论文的时候,也遇到很多问题,首先就是资料太少啦,只有一些仿真过程图,程序。对于原理基本不是很懂,还有VHDL语言、Quartus 等都不了解,真正是书到用时方恨少。然后又是各种查资料,百度,咨询同学来学习了解。这也让我深刻的体会到实践和理论的差距,更何况我自己之前还没有努力去学习,实践就更是寸步难行。至于课设报告中涉及到的WORD排版知识,随着一
19、次次练习,一点点积累,现在可以说是得心应手。至少在排版时不会遇到障碍。总之本次课设,让我熟悉了Quartus、WORD两个常用软件,也复习了一遍VHDL语言的相关知识,又熟悉了一遍用VHDL语言进行编程的过程。但是就我本次实践练习来说,我看到了自己在这方面的劣势,虽然已经决定以后不从事这方面的工作,但是作为本专业的学生,为了不愧对我的大学生活,以后,我会努力的去学习,扩充我的专业知识。在此,感谢那些热情帮助指导我的同学们,谢谢。第7章 参考文献1潘松,黄继业. EDA技术与VHDL(第2版).北京:清华大学出版社,2007.2孟庆辉,刘辉,程继航,石静苑. EDA技术实用教程.北京:国防工业出版社,2008.3刘江海. EDA技术.武汉:华中科技大学出版社,2009.4杨跃. FPGA应用开发实战技巧精粹.北京:人民邮电出版社,2009.5王辉,殷颖,陈婷,俞一鸣等. X+plus II和Quartus II应用与开发技巧.北京:机械工业出版社,2007.6 谭会生、张昌凡编著,EDA技术及应用第三版,西安电子科技大学出版社出版7 李国洪、胡辉、沈明山编著,EDA技术与实验,机械工业出版社出版附录 设计程序8位可自加载加法计数器LCNT8.VHDPWM信号发生器源程序PWM.VHD
链接地址:https://www.31ppt.com/p-4144792.html