




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、VLSI电路和系统设计 设计题2:CMOS数字集成电路设计用VHDL语言实现十六位全加器姓名:托列吾别克马杰尼班级:电路与系统01班学号:2012210201412013/11/24基于VHDL的16位全加器的设计1.1设计题目的内容及要求1.1.1目的: CMOS数字集成电路设计流程及数字集成电路自动化设计,包括功能验证、VHDL/Verlog建模、同步电路设计、异步数据获取、能耗与散热、信号完整性、物理设计、设计验证等技术1.1.2内容: 主要实验内容是用0.18m数字CMOS工艺,VHDL或Verlog设计一个16位全加器,用Synthesis 仿真工具验证功能,电路合成,及性能检测。1
2、.1.3主要测试参数及指标范围: 16位的全加器主要的设计指标是高于1GHz的频率,功耗,物理面积大小等参数。1.2全加器的组成和原理分析全加器是常用的组合逻辑模块中的一种,对全加器的分析和对组合逻辑电路的分析一样。组合逻辑电路的分析,就是找出给定电路输入和输出之间的逻辑关系,从而了解给定逻辑电路的逻辑功能。组合逻辑电路的分析方法通常采用代数法,一般按下列步骤进行:(1)根据所需要的功能,列出真值表。(2)根据真值表,写出相应的逻辑函数表达式。(3)根据真值表或逻辑函数表达式,画出相应的组合逻辑电路的逻辑图 1。(4)用VHDL编写程序在QUARTUS上进行模拟,并分析结果的正确性。1.3 全
3、加器简介全加器是组合逻辑电路中最常见也最实用的一种,考虑低位进位的加法运算就是全加运算,实现全加运算的电路称为全加器。它主要实现加法的运算,其中分为并行全加器和串行全加器,所谓并行就是指向高位进位时是并行执行的,而串行就是从低位到高位按顺序执行,为了提高运算,必须设法减小或消除由于进位信号逐级传递所消耗的时间,为了提高运算速度,制成了超前进位加法器,这是对全加器的一种创新2。1.3.1半加器的基本原理如果不考虑有来自低位的进位将两个1位二进制数相加,称为半加。实现半加运算的电路称为半加器。按照二进制加法运算规则可以列出如表2所示的半加器真值表,其中A、B是两个加数,S是相加的和,CO是向高位的
4、进位。将S、CO和A、B的关系写成逻辑表达式则得到S=A B+A B=A+BCO=AB输 入输 出ABSCO0000011010101101表1 半加器的真值表因此,半加器是由一个异或门和一个与门组成的,如图1所示。图 1 半加器原理图1.3.2 一位全加器的原理全加器执行加数,被减数和低位来的进位信号相加,并根据求和结果给出该进位信号。(1)根据全加器所需要的功能,我们可以设计出一位全加器的组合逻辑框图。如图2所示。 &=11=1& 图2 一位全加器的逻辑图(2)根据逻辑图我们可以写出各个器件的逻辑功能。Ci = Xi Y i Ci-1+X i Y i C i-1+X i Y i C i-1
5、+X i Y i C i-1 = (X i Y i)C i-1+X i Y iFi = XiYiC i-1 + XiYiC i-1 +XiYiC i-1 + XiYiC i-1 = XiYiC i-1(3)由上面可得。Xi和Yi为两个输入的一位二进制书,Ci-1为低位二进制数相加的进位输出到本位的输入,则Fi为本位二进制数Xi、Yi和低位进位输入Ci-1的相加之和,Ci为Xi、Yi和低位进位输入Ci-1相加向高位的进位输出。因此,该电路可以完成一位二进制数全加的功能,称为全加器。此电路的真值表如表2所示。XiYiCi-1FiCi000000101010010110010011001101101
6、0111111表2 一位全加器真值表1.4 十六位全加器的设计设计16位的全加器思路非常简单且清晰,第一种方法就是先设计一个半加器和一个或门,然后两个半加器合并成一个一位的全加器,最后用16个一位的全加器组合成为一个16位的全加器;第二种方法就是先设计一个一位的全加器,然后在用16个串联或并联就组成了一个16位的全加器,而本次设计采用采用的是第一种方法。 图3 一位全加器的级联原理图十六位全加器有十六个一位全加器的级联组成的,最低位的借位信号时整个全加器的借位信号Cin,最高位的进位信号是十六位全加器的进位信号,每位之间通过进位信号链接,两个十六位加数的每一位并联输入,和数SUM的每一位并联输
7、出,完成两个十六位的数的加法。1.5用VHDL编写代码实现16位全加器本次实验使用 Altera FPGA/CPLD 的开发工具 Quartus ,利用编写VHDL代码设计方法设计一个16位加法器,并用Quartus的综合仿真工具实现电路的综合,电路功能的验证,并最后查看综合后的RLT电路框图来验证设计与原逻辑设计符不符合要求,我们还可以借用powerplay功率分析工具对设计后的电路进行功耗分析。本次设计有一个顶层模块(16位全加器)和三个底层模块,它们分别为一位全加器和组成一位全加器的半加器模块和或门模块。因此我们要用从底层到顶层的设计思路,以半加器+或门 一位全加器16位全加器的为设计顺
8、序。以下为半加器和活门的VHDL程序代码(1) 半加器的VHDL代码 library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity h_adder is port(a,b:in std_logic; co:out std_logic; so:out std_logic );end h_adder;architecture one of h_adder isbegin so=a xor b; co=a and b;end one;(2) 或门
9、的VHDL代码library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity or2a is port(a,b:in std_logic; c:out std_logic ); end or2a;architecture one of or2a isbegin cain,b=bin,co=d,so=e); u2:h_adder port map(a=e,b=cin,co=f,so=sumf); u3:or2a port map(a=d,b=f
10、,c=coutf);end one;从上述的设计思路中和全加器的级联设计方案中看到,实现16位全加器的关键是实现每级全加器到下一级全加器的信号的控制,以此实现模块之间的协调和整个系统的稳定性。在实现16加法器中我们同样用上述的component语句,在顶层中调用底层的模块,并巧妙地实现每个模块之间的级联。以下为一种设计法方案。(4)16位加法器的VHDL代码library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity new_adder16 is port(a:in std_logic_vecto
11、r(15 downto 0); b:in std_logic_vector(15 downto 0); cin:in std_logic; sum:out std_logic_vector(15 downto 0); cout:out std_logic ); end; architecture one of new_adder16 is component f_adder port(ain:in std_logic; bin:in std_logic; cin:in std_logic; coutf:out std_logic; sumf:out std_logic ); end compo
12、nent; signal temp:std_logic_vector(16 downto 0); begin temp(0)a(i), bin=b(i), cin=temp(i), coutf=temp(i+1), sumf=sum(i) ); end generate add; coutRTL Viewer,即可看到所对应的原理图,本次设计的RTL电路图如图7所示图7 RLT电路图上图中,可以看到16个一位全加器级联,最后组成16为全加器,这个结果跟我们设计要求相符合。用RLD 还可以看到底层模块的电路逻辑图,以下为通过RLT viewer全加器,半加器,和或门看到的各级模块的逻辑电路图。图
13、8一位全加器电路图一位全加器有两个半加器和一个或门组成。以下为上图中h_adder和or2a的详细电路框图。图9半加器h_adder图10或门or2a2.4 通过powerplay 功率分析仪分析功耗Quartus II Powerplay功耗分析工具提供的界面使用者能够在设计过程中,估计静态和动态功耗。Powerplay Power Analyzer 进行适配后功率分析,产生高亮的功耗报告,显示模块类型和实体,以及消耗的功率本次设计的电路通过Powerplay分析后的功耗报告如图11所示图11功耗分析结果图中显示了总热功耗为203.54mW,核心动态热功耗为23.27mW,核心统计热功耗为3
14、9.61mW,I/O 热功耗为140.65mW。这个对电路在硬件实现之前的预功率分析,有助于设计员根据结果调整设计方案,以此实现电路在功耗方面达到全面优化。2.5总结通过此次设计对全加器器的设计和实现,确实积累和总结了不少的经验,锻炼了我的独立工作和实际动手能力,加深了对计算机中的全加器工作原理的认识,提高了对复杂的综合性实践环节具有分析问题、解决问题、概括总结的实际工作能力,对涉及全加器项目的开发、设计过程有初步认识。经过调试和综合,用门电路设计的16位全加器基本设计完毕。其功能基本符合项目需求,能够完成16位进位加法的运算。但是由于本人在数字电路设计和VHDL语言方面的知识不够深,还有许多不尽如人意的地方,其中最大的缺憾就是没有建立16位全加器的真值表,由于工作量太过庞大,无法完成,所以还有待于进一步完善其功能。但我从中学到了不少的道理,真正的理解到,理论与实践之间还是有很大的距离,这必将有利于我们以后的学习。使我明白,在以后的学习中,要不断的完善自己的知识体系结构,注意理论与实践的结合,学知识关键是要学活,而不能死记死搬书本上的知识
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论