收藏 分享(赏)

数字逻辑电路课程设计_4bit模9加法器_VHDL实现(含完整.docx

上传人:拉拉链 文档编号:13522661 上传时间:2022-09-06 格式:DOCX 页数:43 大小:1.04MB
下载 相关 举报
数字逻辑电路课程设计_4bit模9加法器_VHDL实现(含完整.docx_第1页
第1页 / 共43页
数字逻辑电路课程设计_4bit模9加法器_VHDL实现(含完整.docx_第2页
第2页 / 共43页
数字逻辑电路课程设计_4bit模9加法器_VHDL实现(含完整.docx_第3页
第3页 / 共43页
亲,该文档总共43页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

1、电 子 科 技 大 学UNIVERSITY OF ELECTRONIC SCIENCE AND TECHNOLOGY OF CHINA数字逻辑设计实验报告 实验题目: 4bit模9加法器 学生姓名: 指导老师: 一、实验内容设计一个4bit模9加法器。输入为两个4bit的二进制数,输出为两数相加后模9的结果。其数学表达式为:y=(x1+x2)mod 9。二、实验要求1、功能性要求: 能够实现4bit无符号数的模9加法运算,即输入两个4比特数据时能够正确输出其相加并模9运算结果。2、算法要求: 模加法器有多种算法,可采用任意算法进行设计。3、设计性要求:采用全加器、半加器和基本门结构化描述。能够

2、编写Test Bench文件,并利用Modelsim进行仿真。在Modelsim仿真正确的基础上,能够生成bit文件并上板验证其正确性。4、基本上板要求:在上板实验时,输入的两个4bit数采用拨码开关输入,输出采用LED灯进行显示。三、设计思路1、整体思路:为了实现4bit无符号数的模9加法运算,可以先将两个4bit的加数a和b先分别模9,相加之后再模9得到最终结果。2、模9器:先找出读入的5bit数与模9后的4bit数之间的关系,画出卡诺图,再根据卡诺图得出其相应的逻辑表达式即可。设读入的5bit数为carry、a、b、c、d,模9后得到的4bit数为w、x、y、z。则化简后得到的逻辑表达式

3、分别为:w = carryabcd,x= carrybc + carryab + carrybd + carryabcd,y = carryac + carrycd + carryabcd + carryabcd,z= carryad + carryacd + carryabd + carry abcd。3、全加器:全加器可以实现两个1bit数a、b和进位输入cin的相加,其真值表如下所示: 这里全加器由半加器和或门构成,其原理图如下:4、 半加器: 半加器是全加器的基本组成单元,可以实现两个1bit数a和b的相加,并将进位输出,其真值表如下:半加器由一个异或门和一个与门构成,其原理图如下所示

4、:5、数码管显示:单个数码管一共有7个端(不含小数点),用来表示组成一个数字的7个部分,故只要找到这7个段和模9后的4bit数间的对应关系,将其画出卡诺图并化简成逻辑表达式即可。设得到的4bit数为a、b、c、d,则得到的7段disadisg的表达式为:disa=b + d + ca + ac;disb=c +d + b a + ab;disc=a + b + c + d;disd=ba + ca+ cb + cba;dise=d + ba + c a;disf=d + ba + ca + cb;disg=d + ba+ cb+ ca + cb;四、程序设计1、顶层:entity main i

5、s Port ( a1 : in STD_LOGIC; a2 : in STD_LOGIC; a3 : in STD_LOGIC; a4 : in STD_LOGIC; b1 : in STD_LOGIC; b2 : in STD_LOGIC; b3 : in STD_LOGIC; b4 : in STD_LOGIC; ans1 : out STD_LOGIC; ans2 : out STD_LOGIC; ans3 : out STD_LOGIC; ans4 : out STD_LOGIC; disA : out STD_LOGIC; disB : out STD_LOGIC; disC :

6、out STD_LOGIC; disD : out STD_LOGIC; disE : out STD_LOGIC; disF : out STD_LOGIC; disG : out STD_LOGIC );end main; architecture Behavioral of main isCOMPONENT fulladderPORT(a : IN std_logic;b : IN std_logic;ci : IN std_logic; s : OUT std_logic;co : OUT std_logic);END COMPONENT;COMPONENT mod9PORT(carr

7、y : IN std_logic;a : IN std_logic;b : IN std_logic;c : IN std_logic;d : IN std_logic; w : OUT std_logic;x : OUT std_logic;y : OUT std_logic;z : OUT std_logic);END COMPONENT;COMPONENT disPORT(a : IN std_logic;b : IN std_logic;c : IN std_logic;d : IN std_logic; disa : OUT std_logic;disb : OUT std_logi

8、c;disc : OUT std_logic;disd : OUT std_logic;dise : OUT std_logic;disf : OUT std_logic;disg : OUT std_logic);END COMPONENT;signal c1,c2,c3,c4,s1,s2,s3,s4,ans11,ans22,ans33,ans44,a11,a22,a33,a44,b11,b22,b33,b44,temp :std_logic;begin-mod9_a-temp temp, -carry是最高位a = a4,b = a3,c = a2,d = a1, -d是最低位w = a4

9、4, -w是最高位x = a33,y = a22,z = a11 -z是最低位);-mod9_b-Inst_mod9_b: mod9 PORT MAP(carry = temp, -carry是最高位a = b4,b = b3,c = b2,d = b1, -d是最低位w = b44, -w是最高位x = b33,y = b22,z = b11 -z是最低位);-add-Inst_fulladder_add1: fulladder PORT MAP(a = a11,b = b11,ci = temp,s = s1,co = c1);Inst_fulladder_add2: fulladder

10、PORT MAP(a = a22,b = b22,ci = c1,s = s2,co = c2);Inst_fulladder_add3: fulladder PORT MAP(a = a33,b = b33,ci = c2,s = s3,co = c3);Inst_fulladder_add4: fulladder PORT MAP(a = a44,b = b44,ci = c3,s = s4,co = c4);-mod9_ans-Inst_mod9_ans: mod9 PORT MAP(carry = c4, -carry是最高位,对应最后一个进位c4a = s4,b = s3,c = s

11、2,d = s1, -d是最低位,对应s1w = ans44, -w是最高位,对应ans4x = ans33,y = ans22,z = ans11 -z是最低位,对应ans1);-not- ans1=not ans11;ans2=not ans22;ans3=not ans33;ans4 ans11, -最低位(读入取反之前的ans)b = ans22,c = ans33,d = ans44, -最高位disa = disA,disb = disB,disc = disC,disd = disD,dise = disE,disf = disF,disg = disG);end Behavio

12、ral;2、模9器:entity mod9 is Port ( carry : in STD_LOGIC; a : in STD_LOGIC; b : in STD_LOGIC; c : in STD_LOGIC; d : in STD_LOGIC; w : out STD_LOGIC; x : out STD_LOGIC; y : out STD_LOGIC; z : out STD_LOGIC);end mod9;architecture Behavioral of mod9 issignal nota,notb,notc,notd,notcarry : std_logic;Begin-n

13、ot-nota= not a;notb= not b;notc= not c;notd= not d;notcarry=not carry;-mod9-w=a and notb and notc and notd and notcarry;x=(b and c) or (b and nota) or (b and d);y=(nota and c) or (c and d) or (a and b and notc and notd);z a,b = b,s = s1,c = c1);Inst_halfadder_sum2: halfadder PORT MAP(a = ci,b = s1,s

14、 = s,c = c2);Inst_or2i_co: or2i PORT MAP(i1 = c1,i2 = c2,o = co);end Behavioral;4、半加器:entity halfadder is Port ( a : in STD_LOGIC; b : in STD_LOGIC; s : out STD_LOGIC; c : out STD_LOGIC);end halfadder;architecture Behavioral of halfadder isCOMPONENT notiPORT(i : IN std_logic; o : OUT std_logic);END

15、COMPONENT;COMPONENT and2iPORT(i1 : IN std_logic;i2 : IN std_logic; o : OUT std_logic);END COMPONENT;COMPONENT or2iPORT(i1 : IN std_logic;i2 : IN std_logic; o : OUT std_logic);END COMPONENT;signal nota,notb,s1,s2 : std_logic;begin-not-Inst_noti_nota: noti PORT MAP(i = a,o = nota);Inst_noti_notb: noti

16、 PORT MAP(i = b,o = notb);-s-Inst_and2i_s1: and2i PORT MAP(i1 = nota,i2 = b,o = s1);Inst_and2i_s2: and2i PORT MAP(i1 = a,i2 = notb,o = s2);Inst_or2i_s: or2i PORT MAP(i1 = s1,i2 = s2,o = s);-c-Inst_and2i_c: and2i PORT MAP(i1 = a,i2 = b,o = c);end Behavioral;5、 数码管显示:entity dis is Port ( a : in STD_LO

17、GIC; b : in STD_LOGIC; c : in STD_LOGIC; d : in STD_LOGIC; disa : out STD_LOGIC; disb : out STD_LOGIC; disc : out STD_LOGIC; disd : out STD_LOGIC; dise : out STD_LOGIC; disf : out STD_LOGIC; disg : out STD_LOGIC);end dis;architecture Behavioral of dis issignal nota,notb,notc,notd,disaa,disbb,discc,d

18、isdd,disee,disff,disgg: std_logic;begin-not-nota=not a;notb=not b;notc=not c;notd=not d;-dis-disaa=b or d or (notc and nota) or (c and a);disbb=notc or d or (notb and nota) or (b and a);discc=a or notb or c or d;disdd=(b and nota) or (notc and nota) or (notc and b) or (c and notb and a);disee=d or (

19、b and nota) or (notc and nota);disff=d or (notb and nota) or (c and nota) or (c and notb);disgg=d or(b and nota)or (notc and b)or (c and nota) or (c and notb);-not-disa=not disaa;disb=not disbb;disc=not discc;disd=not disdd;dise=not disee;disf=not disff;disg=not disgg;end Behavioral;5、 仿真与硬件调试1、仿真:(

20、1)顶层仿真1.仿真文件:LIBRARY ieee;USE ieee.std_logic_1164.ALL; ENTITY test2 ISEND test2; ARCHITECTURE behavior OF test2 IS - Component Declaration for the Unit Under Test (UUT) COMPONENT main PORT( a1 : IN std_logic; a2 : IN std_logic; a3 : IN std_logic; a4 : IN std_logic; b1 : IN std_logic; b2 : IN std_log

21、ic; b3 : IN std_logic; b4 : IN std_logic; ans1 : OUT std_logic; ans2 : OUT std_logic; ans3 : OUT std_logic; ans4 : OUT std_logic; disA : OUT std_logic; disB : OUT std_logic; disC : OUT std_logic; disD : OUT std_logic; disE : OUT std_logic; disF : OUT std_logic; disG : OUT std_logic ); END COMPONENT;

22、 -Inputs signal a1 : std_logic := 0; signal a2 : std_logic := 0; signal a3 : std_logic := 0; signal a4 : std_logic := 0; signal b1 : std_logic := 0; signal b2 : std_logic := 0; signal b3 : std_logic := 0; signal b4 : std_logic := 0; -Outputs signal ans1 : std_logic; signal ans2 : std_logic; signal a

23、ns3 : std_logic; signal ans4 : std_logic; signal disA : std_logic; signal disB : std_logic; signal disC : std_logic; signal disD : std_logic; signal disE : std_logic; signal disF : std_logic; signal disG : std_logic; - No clocks detected in port list. Replace below with - appropriate port name BEGIN

24、 - Instantiate the Unit Under Test (UUT) uut: main PORT MAP ( a1 = a1, a2 = a2, a3 = a3, a4 = a4, b1 = b1, b2 = b2, b3 = b3, b4 = b4, ans1 = ans1, ans2 = ans2, ans3 = ans3, ans4 = ans4, disA = disA, disB = disB, disC = disC, disD = disD, disE = disE, disF = disF, disG = disG ); - Stimulus process st

25、im_proc: process begina4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 0; b3 = 0; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 0; b3 = 0; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 0; b3 = 0; b2 = 1; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 0; b3 =

26、0; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 0; b3 = 1; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 0; b3 = 1; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 0; b3 = 1; b2 = 1; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b

27、4 = 0; b3 = 1; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 1; b3 = 0; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 1; b3 = 0; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 1; b3 = 0; b2 = 1; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 =

28、 0; a1 = 0;b4 = 1; b3 = 0; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 1; b3 = 1; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 1; b3 = 1; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 0;b4 = 1; b3 = 1; b2 = 1; b1 = 0;wait for 100 ns;a4 = 0;

29、a3 = 0; a2 = 0; a1 = 0;b4 = 1; b3 = 1; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 0; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 0; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 0; b2 = 1; b1 = 0;wait for 100

30、 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 0; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 1; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 1; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 1; b2 = 1; b1 = 0;

31、wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 0; b3 = 1; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1; b3 = 0; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1; b3 = 0; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1; b3 = 0; b2

32、= 1; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1; b3 = 0; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1; b3 = 1; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1; b3 = 1; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1;

33、 b3 = 1; b2 = 1; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 0; a1 = 1;b4 = 1; b3 = 1; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 0; b3 = 0; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 0; b3 = 0; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1

34、 = 0;b4 = 0; b3 = 0; b2 = 1; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 0; b3 = 0; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 0; b3 = 1; b2 = 0; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 0; b3 = 1; b2 = 0; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 0; b3 = 1; b2 = 1; b1 = 0;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 0; b3 = 1; b2 = 1; b1 = 1;wait for 100 ns;a4 = 0; a3 = 0; a2 = 1; a1 = 0;b4 = 1; b3 = 0;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 企业信息化

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报