网站大量收购闲置独家精品文档,联系QQ:2885784924

常用组合逻辑电路设计(比较电路).docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验报告2 常用组合逻辑电路设计(比较电路) 一、VHDL文件 1、实验方案 原理说明: VHDL是一种全方位、多层次的硬件描述语言。VHDL既满足硬件设计、验证、综合和测试各个过程,又能从系统级到门级精确描述数字系统的结构和行为。系统的VHDL设计通常采用层次化的设计方法,自上向下划分系统功能并逐层细化逻辑描述。层次关系中的每一个模块可以是VHDL描述的实体。上层VHDL代码中实例化出各个下层子模块。 VHDL主要用于描述数字系统的结构,行为,功能和接口。除了含有许多具有硬件特征的语句外,VHDL的语言形式和描述风格与句法是十分类似于一般的计算机高级语言。VHDL的程序结构特点是将一项工程设计,或称设计实体(可以是一个元件,一个电路模块或一个系统)分成外部(或称可视部分,及端口)和内部(或称不可视部分),既涉及实体的内部功能和算法完成部分。在对一个设计实体定义了外部界面后,一旦其内部开发完成后,其他的设计就可以直接调用这个实体。这种将设计实体分成内外部分的概念是VHDL系统设计的基本点。 实验截图: 比较电路用来比较两个无符号二进制数a,b的大小,用f1,f2,f3输出结果。 2、波形图 A1,a2和B1,b2是输入数a,b的两个数位(以下标1、2区分),f1,f2,f3是如vhdl所示算式的结果(f1,f2,f3分别表示大于,小于,等于)。 以分组二进制显示信号以及结果。 当a1,a2,b1,b2分别输入不同的值时,算式f1,f2,f3的结果将以“0”、“1”的波形表现出来,若为“1”则为对应项的逻辑关系。 3、管脚分配及验证结论 在用电平脉冲信号控制a1,a2的值时,输出端f1,f2,f3分别用灯亮、灯灭表示“1”,“0”。 f1、f2、f3输出表示两数、、=三种关系比较结果。 二、利用LPM元件实现 参数化模块库(LPM)提供了一系列可以参数化定制的逻辑功能模块。采用LPM设计方法的主要优势在于设计文件与器件结构无关、高效布线和通用性三方面。Altera的lpm_components程序包提供了包括逻辑门、算术组件、存储组件等参数化器件。 1、实验方案 利用LPM元件定制实现两个二位数大小比较电路,包括、、=、=、=、(不等于)。 2、实验流程截图 仿真波形: 对上述电路进行波形仿真,得到上图所示的仿真结果。从仿真结果可看出,该电路运行良好,性能稳定,达到设计目标。 上图含义同QuartusII波形图。 三、实验总结及日志 在编写VHDL文件时,我体会到VHDL语言灵活易懂,结构严谨。但是如果不细心,也不容易编译成功,如同C++。 在利用LPM元件定制比较电路时,它可以自动赋值快速生成波形图,完成2位无符号数值的比较操作。但需要十分熟悉操作过程,应该多加练习。 思考题: 2、VHDL中如何调用用户自定义元件、旧式74系列元件、参数化元件? 要实现调用元件需要保证底层文件和顶层文件放在同一目录下。 Altera公司提供的VHDL库包括了maxplus2和megacore程序包。Maxplus2定义了基本逻辑元件和74系列元件。所以调用时可以直接在Libraries列表中找到。 此库类调用时需要声明,例如maxplus2程序包声明如下: Library ALTERA; Use ALTERA. maxplus2.all; 参数化模块库(LPM)提供了一系列可以参数化定制的逻辑功能模块。Altera的lpm_components程序包提供了包括逻辑门、算术组件、存储组件等参数化器件。此库类调用时声明如下: Library LPM; Use LPM.lpm_components.all; 3、比较VHDL中的signal与variable? 对变量的赋值时立即生效的,不存在延时;而任何信号赋值时存在延时的。 在一个进程中,如果对一个信号多次赋值,那么,只有最后一个值才是有效的。如果对变量多次赋值,那么每次赋值都是有效的,并且,变量的值在再次赋值之前一直保持不变。信号跟硬件有点类似,并且是在进程结束的时候才更新;变量是立即更新的,因此可以影响程序的功能,但变量的好处是仿真速度更快。 4、VHDL中如何设计电路反馈信号? 当VHDL设计但路反馈时,应将端口声明为buffer端口,而不是out端口。若out端口需要反馈至电路内部时,常使用signal去实现反馈。 5、举例说明常用的VHDL顺序执行和并行执行语句? 顺序执行语句:用来实现模型的算法描述。顺序语句只出现在进程、过程、函数中,其他都是并行语句。 常见的有Begin\process\function 并行执行语句:用来表示各模型算法描述之间的连接关系。 常见的有:赋值语句(信号、变量赋值)、等待语句(WAIT语句) 7、说明VHDL描述组合逻辑电路时signal的作用是什么?

文档评论(0)

baoyue + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档