VHDL实现16位全加器
[键入公司名称]
[键入文档标题]
[键入文档副标题]
姓名:托列吾别克?马杰尼
班级:电路与系统01班
学号:201221020141
[键入公司名称]
2013/11/24
基于VHDL的16位全加器的设计
1.1设计题目的内容及要求
i.i.i 目的:
CMOS数字集成电路设计流程及数字集成电路自动化设计,包括功能验证、VHDL/Verlog建模、同步电路设计、异步数据获取、能耗与散热、信号完整性、物理设计、设计验证等技术
1.1.2内容:
主要实验内容是用0.18阿数字CMOS工艺,VHDL或Verlog设计-
个16位全加器,用Synthesis仿真工具验证功能,电路合成,及性能检测。
1.1.3主要测试参数及指标范围:
16位的全加器主要的设计指标是高于1GHz的频率,功耗,物理面积大小等参数。
1.2全加器的组成和原理分析
全加器是常用的组合逻辑模块中的一种,对全加器的分析和对组合逻辑电路的分析一样。组合逻辑电路的分析,就是找出给定电路输入和输出之间的逻辑关系,从而了解给定逻辑电路的逻辑功能。组合逻辑电路的分析方法通常采用代数法,一般按下列步骤进行:
(1)根据所需要的功能,列出真值表。
(2)根据真值表,写出相应的逻辑函数表达式。
(3)根据真值表或逻辑函数表达式,画出相应的组合逻辑电路的逻辑图
(4)用VHDL编写程序在QUARTUS U上进行模拟,并分析结果的正确性。
1.3全加器简介
全加器是组合逻辑电路中最常见也最实用的一种,考虑低位进位的加法运
算就是全加运算,实现全加运算的电路称为全加器。它主要实现加法的运算,
其中分为并行全加器和串行全加器,所谓并行就是指向高位进位时是并行执行
的,而串行就是从低位到高位按顺序执行,为了提高运算,必须设法减小或消除由于进位信号逐级传递所消耗的时间,为了提高运算速度,制成了超前进位加法器,这是对全加器的一种创新[2]。
1.3.1半加器的基本原理
如果不考虑有来自低位的进位将两个1位二进制数相加,称为半加。实现
半加运算的电路称为半加器。
按照二进制加法运算规则可以列出如表2所示的半加器真值表,其中A、B 是两个加数,S是相加的和,CO是向咼位的进位。将S、CO和A、B的关系写成逻辑表达式则得到
S=A B+A B=A+B
CO=AB
因此,半加器是由一个异或门和一个与门组成的,如图1所示。
图1半加器原理图
1.3.2 一位全加器的原理
全加器执行加数,被减数和低位来的进位信号相加,并根据求和结果给出该进位信号。
(1)根据全加器所需要的功能,我们可以设计出一位全加器的组合逻辑框图。如图2所示。
G H
Xi柠G
图2一位全加器的逻辑图
(2根据逻辑图我们可以写出各个器件的逻辑功能。
C i = X i 丫i C i-i +X i 丫i C i-i +X i 丫i C i-i +X i 丫i C i-i = (X i ①丫i)C i-i +X i 丫i
F i = XY C / + X i YC M +XY C / + XY C / = X i?Y i?C M
(3)由上面可得。X i和Y i为两个输入的一位二进制书,C i-i为低位二进制数相加的进位输出到本位的输入,则F i为本位二进制数X i、Y i和低位进位输入C i-i
的相加之和,C i为X i、Y i和低位进位输入C M相加向高位的进位输出。因此,该电路可以完成一位二进制数全加的功能,称为全加器。此电路的真值表如表2
所示。
表2 一位全加器真值表
1.4十六位全加器的设计
设计16位的全加器思路非常简单且清晰,第一种方法就是先设计一个半加
器和一个或门,然后两个半加器合并成一个一位的全加器,最后用16个一位的全加器组合成为一个16位的全加器;第二种方法就是先设计一个一位的全加器, 然后在用16
个串联或并联就组成了一个16位的全加器,而本次设计采用采用的是第一种方法。
十六位全加器有十六个一位全加器的级联组成的,最低位的借位信号时整个全加器的借位信号Ci n,最高位的进位信号是十六位全加器的进位信号,每位之间通过进位信号链接,两个十六位加数的每一位并联输入,和数SUM的每-
位并联输出,完成两个十六位的数的加法。
1.5用VHDL编写代码实现16位全加器
本次实验使用Altera FPGA/CPLD 的开发工具Quartus U,利用编写VHDL代码设计方法设计一个16位加法器,并用Quartus的综合仿真工具实现电路的综合,电路功能的验证,并最后查看综合后的RLT电路框图来验证设计与原逻辑设计符不符合要求,我们还可以借用powerplay功率分析工具对设计后的电路进行功耗分析。
本次设计有一个顶层模块(16位全加器)和三个底层模块,它们分别为一位全加器和组成一位全加器的半加器模块和或门模块。因此我们要用从底层到顶层的设计思路,以半加器+或门一一>一位全加器一一>16位全加器的为设计顺序。
以下为半加器和活门的VHDL程序代码
(1)半加器的VHDL代码
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_ un sig ned.all;
en tity h_adder is
port(a,b:in std」o gic;
co:out std_logic;
so:out std_logic );
end h_adder;
architecture one of h_adder is
begi n
so<=a xor b;
co<=a and b;
end one;
(2) 或门的VHDL代码
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_ un sig ned.all;
en tity or2a is
port(a,b:in std」o gic;
c:out std」o gic );
end or2a;
architecture one of or2a is
begi n
c<=a or b;
end one;
由全加器的逻辑图可以看出,全加器由两个半加器和一个或门组成。在
VHDL语言中我们可以在一个模块的代码中用component语句调用低层的模块
这样可以避免写更多的繁琐的代码,也可以提高程序的可读性,也有利于实际电路在延时等关键技术性问题上的优越性。
(3) —位全加器的VHDL代码
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_ un sig ned.all;
en tity f_adder is
port(ai n:in std」o gic;
bin:in std_logic;
cin:in std_logic;
coutf:out std」o gic;
sumf:out std_logic );
end f_adder;
architecture one of f adder is
comp onent h_adder
port(a:in std」ogic;
b:in std」o gic
);
end comp onent;
comp onent or2a
port(a:in std _lo gic;
b:in std_logic
);
end comp onent;
sig nal d,e,f:std」o gic;
begi n
u1:h_adder port map(a=>a in, b=>b in, co=>d,so=>e);
u2:h_adder port map(a=>e,b=>c in, co=>f,so=>sumf);
u3:or2a port map(a=>d,b=>f,c=>coutf);
end one;
从上述的设计思路中和全加器的级联设计方案中看到,实现16位全加器的关键是实现每级全加器到下一级全加器的信号的控制,以此实现模块之间的协
调和整个系统的稳定性。在实现16加法器中我们同样用上述的comp on e nt语句, 在顶层中调用底层的模块,并巧妙地实现每个模块之间的级联。以下为一种设
(4) 16位加法器的VHDL代码
library ieee;
use ieee.std_logic_ un sig ned.all;
en tity n ew_adder16 is
port(a:in std」ogic_vector(15 downto 0);
b:in std_logic_vector(15 downto 0);
cin:in std_logic;
sum:out std_logic_vector(15 downto 0);
);
end;
architecture one of n ew_adder16 is comp onent f_adder
port(ain:in std」ogic;
bin:in std_logic;
cin:in std_logic coutf:out std」o gic;
sumf:out std_logic );
end comp onent;
sig nal temp:std_logic_vector(16 dow nto 0);
beg in
temp(0)<=ci n;
add:for i in 0 to 15 gen erate loopadd:f_adder port map(a in=>a(i).
bin=>b(i).
cin=>temp(i).
coutf=>temp(i+1).
sumf=>sum(i)
);
end gen erate add;
cout<=temp(16);
end one;
上述代码中用for…gen erate循环语句和compo ne nt语句的调用语句实现15 位信号的加法。因为for…generate不像for….loop那样顺序执行而是并行执行的,使用了
for...loop,所以对应RTL Viewer就比较复杂,所以for…gen erate语句更有效。
2.1用QuartusII实现16位全加器电路的综合仿真
1) 以new_adder16为工程名新建一个工程,我们可以预先设置硬件的选择,本次设计用MAX系列芯片。
2) 新建四个VHDL文件,分别编写进上四个模块的VHDL代码。顶层模块的文件名要工程名一致,在此为n ew_adder16.vhd其余的文件名跟模块名要一致,以便于以后的综合和验证过程的调试。
3) 实现编译和综合,若无误则可以仿真了,综合后Quartus软件给出设计
中所用到的逻辑单元,弓I脚等信息,如图4所示。
Flai Status Successful - Tue ffov 26 1941:56 2013
Quartus II Yersian9.1 Build 222 10/21/2009 SJ Full Version
Ee?i iio& lime M_addferl6
Top-level Entity Home netf_adder 16
Family MAX II
Net timing requirements I SE
Total l?(ic cUmenti32 I57Ci ( 6 紀
Total pins50 / 160 O1 ?)
Total virtual lins0
Vffl Uocki0 I1 w % )
Device IFM5T0F36C3
Tuning Models Final
图4综合后的元素和管脚使用情况
本次设计中我们用到32个逻辑元素和50个管脚。
4) Quartus II内置波形编辑程序(Waveform Editor)可以生成和编辑波形
设计文件,从而设计者可观察和分析模拟结果。Quartus II中的仿真包括功能仿
真和时序仿真,功能仿真检查逻辑功能是否正确,不含器件内的实际延时分析;时序仿真检查实际电路能否达到设计指标,含器件内的实际延时分析。两种仿真操作类似,只需在Tools菜单中选择Simulater Too,在其Simulater mode中进行选择即可在功能仿真之前我们需要生成功能仿真网表( fun ctio nal simulatio n netlist),否则仿真中会报错。本次设计用随机信号进行仿真,输入输出信号都用16进制
数表示。还有,在仿真前要建立波形文件VWF文件,该文件全称是矢量波形
文件(Vector Waveform File)是Quartus II中仿真输入、计算、输出数据的载体。
首先要对电路进行功能仿真,以此验证设计是否符合要求。功能仿真的结
果如图5所示
从结果可以看出,本次设计在功能上能实现16为数的相加,进位信号Cout也能正常实现进位。在此设计信号的周期为16ns。
通过功能仿真我们可以初步了解电路的功能,并验证设计结果与实际要求是否符合。因为设计出来的电路要通过硬件实现相应的功能,而实际硬件中模块的延时时间比较大,所以验证电路的功能往往不够的,我们还要验证电路在有延时的条件下能否正常工作,这是eda电路设计过程的重要技术指标之一,
所以我们要以严格的实际条件下考验我们的设计方案,以此求得比较符合设计要求的设计方案。
这次设计的时序仿真结果如图6所示
图6时序仿真的结果
由图可以看到,相邻输出信号之间的延时比较大,此延时引起的信号失真 也比较大,我们可以调大信号的周期来减少信号失真引起的干扰。
2.2 RLT viewer 工具的使用
RTL View 也就是通常所讲的能够查看 VHDL 或者Verilog HDL 对应的电路 原理
图。这个功能对于使用 HDL 进行逻辑设计的人员还是很有用的,一方面可 以充分理解
HDL 和硬件电路的对应关系,另一方面可以更加方便的查找设计中 的错误。在将VHDL 设
计编译完成以后,点击菜单Tools>RTL Viewer ,即可看 到所对应的原理图,本次设计的
RTL 电路图如图7所示
汕卜
E53
£11
卜公
rta 就
?1旺nt
SlOii :
图7 RLT电路图
上图中,可以看到16个一位全加器级联,最后组成16为全加器,这个结
果跟我们设计要求相符合。用RLD还可以看到底层模块的电路逻辑图,以下为
通过RLT viewer全加器,半加器,和或门看到的各级模块的逻辑电路图。
图8一位全加器电路图
一位全加器有两个半加器和一个或门组成。以下为上图中h_adder和or2a 的详细电路框图。
w
图9半加器h adder 图10或门or2a
2.4通过powerplay 功率分析仪分析功耗
Quartus II Powerplay 功耗分析工具提供的界面使用者能够在设计过程中,
估计静态和动态功耗。Powerplay Power An alyzer 进行适配后功率分析,产生高 亮的功耗报告,显示模块类型和实体,以及消耗的功率
本次设计的电路通过Powerplay 分析后的功耗报告如图11所示
图11功耗分析结果
图中显示了总热功耗为203.54mW 核心动态热功耗为23.27mW,核心统计
热功耗为39.61mW, I/O 热功耗为140.65mW 这个对电路在硬件实现之前的预 功率分析,有助于设计员根据结果调整设计方案,以此实现电路在功耗方面达 到全面优化。
bwerFIsy Fewer faalyzer Status Mtns II Versim Uisiin he
"op*k/el fctity he laniily levice
伽 er Idsh
?otd Ihermd Po^r Dissipation Core Dynsinic Th 苗al Dissipation Core Static Ttend fner Dissifatian I/O 血msl Power Di 曲皿灿
伽 er Sstindion Canfidence
Successful - Tne lor 3616:27:32 2013 9.1 hid 222 10/a/am SJFull tai on needier 16 Mf.湎 16
UXH
EFMF256C3
Final
203.51 1! 230 ml 39. Bl ml 140.65 N
High : user profiled sufficient to 诫e nte
2.5总结
通过此次设计对全加器器的设计和实现,确实积累和总结了不少的经验,锻炼了我的独立工作和实际动手能力,加深了对计算机中的全加器工作原理的认识,提高了对复杂的综合性实践环节具有分析问题、解决问题、概括总结的实际工作能力,对涉及全加器项目的开发、设计过程有初步认识。
经过调试和综合,用门电路设计的16位全加器基本设计完毕。其功能基本符合项目需求,能够完成16位进位加法的运算。但是由于本人在数字电路设计和VHDL语言方面的知识不够深,还有许多不尽如人意的地方,其中最大的缺憾就是没有建立16位全加器的真值表,由于工作量太过庞大,无法完成,所以还有待于进一步完善其功能。但我从中学到了不少的道理,真正的理解到,理论与实践之间还是有很大的距离,这必将有利于我们以后的学习。使我明白,在以后的学习中,要不断的完善自己的知识体系结构,注意理论与实践的结合,学知识关键是要学活,而不能死记死搬书本上的知识,关键是要会灵活应用,这样所学到的东西才真正的学以致用,才达到了学习的真正目的!
在本次课题程序设计中,我们学到了很多东西,通过本次课题程序设计,无论在理论上还是在实践中,我们的计算机应用水平得到了很大的提升,这对于今后的工作和学习都是一种巨大的财富。也使我们明白,在以后的学习中,要不断的完善自己的知识体系结构,注意理论与实践的结合,学知识关键是要学活,而不能死记死搬书本上的知识,关键是要会灵活应用,这样所学到的东西才真正的学以致用,才达到了学习的真正目的。