基于Libero的数字逻辑设计仿真及验证实验分析报告_第1页
基于Libero的数字逻辑设计仿真及验证实验分析报告_第2页
基于Libero的数字逻辑设计仿真及验证实验分析报告_第3页
基于Libero的数字逻辑设计仿真及验证实验分析报告_第4页
基于Libero的数字逻辑设计仿真及验证实验分析报告_第5页
已阅读5页,还剩54页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、基于Libero的数字逻辑设计仿真及验证实验报告作者: 日期:计算机 学院计算机科学与技术 专业班、学号姓名协作者教师评定实验题目基于Libero的数字逻辑设计仿真及验证实验=1、熟悉EDA工具的使用;仿真基本门电路。2、仿真组合逻辑电路。3、仿真时序逻辑电路。4、基本门电路、组合电路和时序电路的程序烧录及验证。5、数字逻辑综合设计仿真及验证。实验报告51、基本门电路、实验目的1、了解基于Verilog的基本门电路的设计及其验证。2、熟悉利用EDA工具进行设计及仿真的流程。3、学习针对实际门电路芯片 74HC00、74HC02、74HC04、74HC08、74HC32、74HC86 进行Ver

2、ilogHDL设计的方法。二、实验环境Libero仿真软件。三、实验内容1、掌握Libero软件的使用方法。2、进行针对74系列基本门电路的设计,并完成相应的仿真实验。3、 参考教材中相应章节的设计代码、测试平台代码(可自行编程),完成74HC00、 74HC02、74HC04、74HC08、74HC32、74HC86 相应的设计、综合及仿真。4、提交针对 74HC00、74HC02、74HC04、74HC08、74HC32、74HC86 (任选一个)的综合结果,以及相应的仿真结果。 四、实验结果和数据处理1、所有模块及测试平台代码清单/74HC00代码-与非/ 74HC00.V3:0 A,

3、B; 3:0 Y;Y = (A&B);module HC00(A, B, Y);inp utout put assig nen dmodule/74HC00测试平台代码/ test 00.V'timescale 1n s/1 nsmodule test_00; reg 3:0 a,b; wire 3:0 y; HC00 u(a, b, y); in itial begina = 4'b0000;b = 4'b0001;#10 b = b<<1;/0010#10 b = b<<1;/0100#10 b = b<<1;/1000a

4、 = 4'b1111;b = 4'b0001;#10 b = b<<1;#10 b = b<<1;#10 b = b<<1; enden dmodule/74HC02代码-或非/ 74HC02.Vinp ut out put assign en dmodulemodule HC02(A, B, Y);3:0 A, B;3:0Y;Y =(A|B);/74HC02测试平台代码/ test 02.V'timescale 1n s/1 nsmodule test_02;reg 3:0 a,b,c; wire 3:0 y;HC02 u(a, b

5、, y);in itialbegina = 4'b1111;c = 4'b0001;b = c;c = c<<1;#10 b = c;c = c<<1;#10 b = c;c = c<<1;#10 b = c;a = 4'b0000;c = 4'b0001;b =c;c = c<<1; #10 b = c;c = c<<1;#10 b = c;c = c<<1;#10 b = c;enden dmodule/74HC04代码-非/ 74HC04.Vinp ut out put assig n

6、 en dmodulemodule HC04(A, Y);3:0 A;3:0Y; Y = A;/74HC04测试平台代码/ test 04.V'timescale 1n s/1 nsmodule test_04; reg 3:0 a; wire 3:0 y;HC04 u (a, y);in itial begina = 4'b0001;#10 a = a<<1;#10 a = a<<1;#10 a = a<<1;enden dmodule/74HC08代码-与/ 74HC08.Vmodule HC08(A, B, Y);input 3:0 A

7、, B;out put3:0Y;assig nY = A&B;en dmodule/74HC08测试平台代码/ test 08.V'timescale 1n s/1 ns module test_08;reg 3:0 a,b; wire 3:0 y;HC00 u(a, b, y);in itial begina = 4'b0000;b = 4'b0001;#10 b = b<<1;#10 b = b<<1;#10 b = b<<1;a = 4'b1111;b = 4'b0001;#10 b = b<<

8、;1;#10 b = b<<1;#10 b = b<<1;enden dmoduleinp ut out put assign en dmodule/74HC32代码-或 /74HC32.V module HC32(A, B, Y);3:0 A, B; 3:0Y;Y = A|B;/74HC32测试平台代码/ test 32.v'timescale 1n s/1 nsmodule test_32;reg 3:0 a,b,c; wire 3:0 y;HC02 u(a, b, y);in itialbegina = 4'b1111;c = 4'b000

9、1;b =c;c = c<<1; #10 b = c;c = c<<1;#10 b = c;c = c<<1;#10 b = c;a = 4'b0000;c = 4'b0001; b = c;c = c<<1;#10 b = c;c = c<<1;#10 b = c;c = c<<1;#10 b = c;enden dmodule/74HC86代码-异或 module HC86(A, B, Y);input 3:0 A, B; out put3:0Y;assig nY = AB;en dmodule/74H

10、C86测试平台代码/ test 86.v'timescale 1n s/1 nsmodule test_86; reg 3:0 a, b; wire 3:0 y;HC86 u (a, b, y); in itialbegina = 4'b0000;b = 4'b0001;#10 b = b<<1;#10 b = b<<1;#10 b = b<<1;#10 a = 4'b1111;b = 4'b0001;#10 b = b<<1;#10 b = b<<1;#10 b = b<<1;en

11、den dmodule2、第一次仿真结果(任选一个门,请注明,插入截图,下同)。(将波形窗口背景设为白色,调整窗口至合适大小,使波形能完整显示,对窗口 截图。后面实验中的仿真 使用相同方法处理)B 丿tE£tba"idVa丿:-丿旧丿-L* aD-*fcftberi±/b*r-1* rjl*r-1* R1S- *t£stbaidiA_j r-q_J r-rc:*1C0D0000:1150刃15tl5tlboOQ1:1L1(0001&0口CduwOCOLDOOICJ100lOflO11piLlILIO1101011DLl bill lllllll

12、llllll1 I 11 11 llllll I 1 Illi120ri53、综合结果(截图)。(将相关窗口调至合适大小,使 RTL图能完整显示,对窗口截图,后面实验中的综合使用相同方法处理)¥3:q4、第二次仿真结果(综合后)(截图)。回答输出信号是否有延迟,延迟时间约为多少?:*旧丿2丿-L* QD-牡 rtbbizh/b鼻 f-i# m*r-止 rmB-丿FJl R1 rnL" ruTMo/.'111L1COO00001115 口Sti5ti5tiI03GQLllLIo SOLPJOIOsdloo:OOOLtooiclOflCUii:.fil-ioI 皿011

13、 j111J1J11JI141 30 n5)nrsICOD no输出信号有延迟,延迟时间约为 0.3 ns5、第三次仿真结果(布局布线后)<ins60 rt(截图)。回答输出信号是否有延迟,延迟时间约为多少?分析是否有出现竞争冒险。jZ -一-|»ile13i> aCTEL fi-凶叶M lEdlDR凹鱼空;弹rfC/UM%Twragw固国们叭wm邑旧4 +1 ii史虫曲 C?:rnijnMi JHEjEwinTwn5ooHid:活Dj E YiT11111-1111111 11 11 111 11 111 n I I I II1111 11: I 1 I IwwfI I

14、 I H I I Illi I I I I I Illi I L I I I I I |附力:M吐irJl而fl気銅opitrtLT 両尚1屮 IP iDcbi 输出信号有延迟,延迟时间约为3ns,没有出现竞争冒险。72、组合逻辑电路、实验目的1、了解基于Verilog的组合逻辑电路的设计及其验证。2、熟悉利用EDA工具进行设计及仿真的流程。3、 学习针对实际组合逻辑电路芯片74HC148、74HC138、74HC153、74HC85、 74HC283、74HC4511 进行 VerilogHDL 设计的方法。二、实验环境Libero仿真软件。三、实验内容1掌握Libero软件的使用方法。2、

15、进行针对74系列基本组合逻辑电路的设计,并完成相应的仿真实验。3、参考教材中相应章节的设计代码、 测试平台代码(可自行编程),完成74HC148、 74HC138、74HC153、74HC85、74HC283、74HC4511 相应的设计、综合及仿真。4、74HC85测试平台的测试数据要求:进行比较的 A、B两数,分别为本人学号的 末两位,如“ 89”,则A数为“ 1000”,B数为“ 1001”。若两数相等,需考虑级联输入(级联输入的各种取值情况均需包括);若两数不等,则需增加一对取值情况,验证 A、 B相等时的比较结果。5、74HC4511设计成扩展型的,即能显示数字 09、字母af。6、

16、提交针对 74HC148、74HC138、74HC153、74HC85、74HC283、74HC4511 (任 选一个)的综合结果,以及相应的仿真结果。四、实验结果和数据处理1所有模块及测试平台代码清单/74HC148 代码/ 74HC148.VEI; 7:01 n; 2:0Out; EO, GS;module HC148(EI, I n. Out, EO, GS); input input outp ut out put reg 2:0Out; reg EO, GS; in terger I;17always (EI or In) if(EI)beginOut = 3'b111;en

17、delseEO = 1;GS = 1;if( In = 8'b11111111 ) beginOut = 3'b111;endelseEO = 0;GS = 1;beginfor(l = 0;I < 8; I = I + 1) beginif( l n I)beginOut = l;endendenden dmoduleEO = 1;GS = 0;/74HC148测试平台代码/ test 148.V'timescale 1n s/1 nsmodule test_148;reg ei;reg 7:0turn; wire 7:0in = turn;wire 2:0ou

18、t;wire eo,gs;HC148 u(ei, i n, out, eo, gs); in itialbegi nei = 1;turn = 8'b1;rep eat(8)#10 turn = turn<<1;ei = 0;turn = 8'b1;rep eat(8)#10 turn = turn<<1;enden dmodule/74HC138 代码/ 74HC138.Vmodule decoder3_8_1(Data ln,En able,Eq); inp ut 2:0 Data In;input En able;out put 7:0 Eq;re

19、g 7:0 Eq;wire2:0 Data In;in teger I;always (Data In or En able) beginif(En able)Eq=0;elsefor(l=0;l<=7;l=l+1) if(DataI n=l) Eql=1;elseEql=0;enden dmodule/74HC138测试平台代码/ test 138.V'timescale 1n s/1 nsmodule test_138; wire 2:0 out;reg 7:0 in;reg 2:0 ei;HC138 u(out, i n, ei);task circle; beginin

20、= 0;rep eat(8)#10 in = in + 1;end en dtaskin itialbeginei = 1;circle();ei = 0;circle();ei = 2;rep eat(6) begincircleO;#10 ei = ei + 1;endenden dmodule代码/ 74HC153.Vmodule HC153(DateOut, DateI n, Sel, En able); input input input out put reg/74HC1533:0Date In; 1:0Sel; En able;DateOut;always (E nable or

21、 Sel or Date In) if(En able) elseDateOut = 0;DateOut = DateI nSel;en dmodule/74HC153测试平台代码/ test 153.V 'timescale 1n s/1 ns module test_153(); wire out;reg 3:0i n;reg 1:0sel;reg ei;HC153 u(out, i n, sel, ei);in itial beginei = 0; sel = 0; in = 4'b1010; rep eat(4)#10 sel = sel +1;ei = 1; sel

22、= 0; in = 4'b1010; rep eat(4)enden dmodule#10 sei = sei +1;/74HC85 代码/ 74HC85.Vmodule HC85(DateA, DateB, Cas, Q); input3:0 DateA, DateB;input2:0Cas;out put reg 2:0Q;in terger l;always (DateA or DateB or Cas) beginif(DateA=DateB) beginif(Cas1)else if(Cas=3'b000)else if(Cas=3'b101)elseendQ

23、 = 3'b010;Q = 3'b101;Q = 3'bOOO;Q = Cas;elsebeginfor(l=0;l<4;l=l+1) if(DateAl>DateBl) else if(DateAl<DateBl) endQ = 3'b100;Q = 3'b001;enden dmodule/74HC85测试平台代码/ test_85.v'timescale 1n s/1 nsmodule test_85;reg 3:0 a,b;reg 2:0 cas;wire 2:0 res;HC85 u(a, b, cas, res);t

24、ask cascade_ input; begin#0 cas = 0;#10 cas = 1;#10 cas = 3'b100; #10 cas = 3'b101;#10 cas = 3'b010; end#10 cas = 3'b011; #10 cas = 3'b110; #10 cas = 3'b111; #10;en dtaskin itialbegina = 4'd9; b = a;b = 4'd7;endcascadenpu t();cascadenpu t();en dmodule/74HC283 代码/ 74HC

25、283.Vmodule HC283(DateA, DateB, Cin, Sum, Cout); input input out put out putreg3:0 DateA, DateB;Cin;3:0 Sum;Cout;4:0Buf;assig n Cout,Sum = Buf;always (DateA or DateB or Cin) Buf = DateA + DateB + Cin + 5'd0; en dmodule/74HC283测试平台代码/ test 283.V'timescale 1n s/1 nsmodule test_283;reg 3:0 a, b

26、;reg in;wire 3:0sum;wire out;in terger I;HC283 u(a, b, i n, sum, out);task accumulate;begina = 4'b0100;for(l=0;l<16;l=l+1)beginb = I; #10;end en dtask in itial begi nin = 0; accumulate。;in = 1;accumulate。;end en dmodule/74HC4511 代码/ 74HC4511.V7:0DateOut; 3:0Date In; LE, BL_N, LT_N; 7:0Buf;reg

27、module HC4511(DateOut, Date In, LE, BL_N, LT_N); outp ut input inputassignDateOut = Buf;Buf = 8'b11111111;Buf = 8'bOOOOOOO;Buf = Buf;always (Dateln or LE or BL_N or LT_N) begin if(!LT_N) else if(!BL_N) else if(LE) elsecase(Date In)4'dO:Buf = 8'b00111111;4'd1:Buf = 8'b00000110

28、;4'd2:Buf = 8'b01011011;4'd3:Buf = 8'b01001111;4'd4:Buf = 8'b01100110;4'd5:Buf = 8'b01101101;4'd6:Buf = 8'b01111101;4'd7:Buf = 8'b00000111;4'd8:Buf = 8'b01111111;4'd9:Buf = 8'b01101111;4'ha:Buf = 8'b01110111;4'hb:Buf = 8'

29、;b01111100;4'hc:Buf = 8'b00111001;4'hd:Buf = 8'b01011110;4'he:Buf = 8'b01111001;4'hf:Buf = 8'b01110001; default:;endcase end2、第一次仿真结果(任选一个模块,请注明)74HC1481 1B-J1L111111 :1L . Ill- . Ifll . 11.-11.13., DO L,.11-.:,:L . IlL-, :., lil. 1【垃”B:, 1r - - . 1 -址11'111 *酝址11

30、11 1 * LH111 11-#诜m 111 1一 V% 1 I1 1図鮎1' 11 f1.,f丸1'1 111一*附出11 113W111*8戌=1«冋比!11B-丿羽伽:L1I: Si 3101 IiiJiJDlO 1曲1 nxi iLii一“由-;1一宝一1r-* 01址11_111 I .15015D n.S IPfflO r'S3、综合结果K1I_PrL -丄,E_ 34”严 f -4、第二次仿真结果(综合后)Ac5L_Hifl/oCAaL.l-rt'in11L11111“【习Pl.【门介1*网S'lS'l【勺乞1Pl(Si

31、l-口S:ly河济辟恋加Sn111-国沁-卩】STL-ICJStL *ri(jY-IWD时 L ,T。回答输出信号是否有延迟,延迟时间约为多少?II(llJ. 1111. 11 r ii. i【1= ifl. JIf., ibu.1 IL . Il IL .:1 L . I'Ll. IL - 1 JfilC 111111I1111111J1f1If1J111111- 11J111J111(31;11:;】1g101 ilOD J&ll 0DO; 90GC111J11iI,1J1IL1 1 1.1 . .III1 1 1 1 1.1III1;11III111 P50 r.:001

32、50in3输出信号有延迟,延迟时间约为 0.5 ns5、第三次仿真结果(布局布线后)。回答输出信号是否有延迟,延迟时间约为多少? 分析是否有出现竞争冒险。U LlLil. IlLli.»LLU;Hnr1|汕 JtlLnI却已1|越*11JlKL.-7eaT_li:Cfl7L;J 3 iii-i CJ | TO-",IE_ 細 IMH. 】L1:.;1:IHD;山1 . LP亡1:41,tJ PJ 加TJ即" 如:羽把iH-j:书坷十胡hltJi二»I >1 1 Ull l>li| Pill iJhmIIi 4|l I P4 |I M >

33、dF-4l|i 4 h I4 I'M li'lll > Ml I« g I E : H 却E&J-!舄埠W: nj输出信号有延迟,延迟时间约为5.2 ns,出现了竞争冒险。III M>l M1>- |> 1« M IIM >|lp liDn?3、时序逻辑电路、实验目的1、了解基于Verilog的时序逻辑电路的设计及其验证。2、熟悉利用EDA工具进行设计及仿真的流程。3、学习针对实际时序逻辑电路芯片 74HC74、74HC112、74HC194、 VerilogHDL设计的方法。74HC161 进行二、实验环境Libero

34、仿真软件。三、实验内容1、熟练掌握Libero软件的使用方法。2、进行针对74系列时序逻辑电路的设计,并完成相应的仿真实验。3、 参考教材中相应章节的设计代码、测试平台代码(可自行编程), 74HC112、74HC161、74HC194相应的设计、综合及仿真。4、提交针对 74HC74、74HC112、74HC161、74HC194 (任选一个) 以及相应的仿真结果。完成 74HC74、的综合结果,四、实验结果和数据处理1、所有模块及测试平台代码清单/74HC74 代码/ 74HC74.Vmodule HC74(Set_ N, Rst_N, Clk, D, Q, Qn); input outp

35、 ut regSet_N, Rst_N, Clk, D;Q, Qn;1:0 Buf;assignQ, Qn = Buf;25always (n egedge Set_N or n egedge Rst_N or po sedge Clk) case(Rst_N,Set_N)0: Buf <= 2'b11;1: Buf <= 2'b10;2: Buf <= 2'b01;default:Buf <= D,D;endcaseen dmodule/74HC74测试平台代码/ test 74.v'timescale 1n s/1 nsmodule

36、test_74;reg s, r, clk, d;wire q, qn;HC74 u(s, r, clk, d, q, qn);task clock;rep eat(10)begind = 0;#3; d = 1;#3;enden dtaskalwaysbeginclk = 0;#2; clk = 1;#2;endin itialbegins = 0;r = 1;clock;#5#5#5s = 1;r = 0;clock;s = 0;r = 0;clock;s = 1;r = 1;clock;end en dmodule/74HC112 代码/ 74HC112.VSet_N, Rst_N, C

37、lk_N, J, K;Q, Qn;Q;regmodule HC112(Set_N, Rst_N, Clk_N, J, K, Q, Qn); input outp ut assig n Qn = Q;always (n egedge Set_N or n egedge Rst_N or n egedge Clk_N) case(Set_N,Rst_N)0: Q <= 1;1: Q <= 1;2: Q <= 0;case(J,K)0default:Q <= Q;Q <= 0;Q <= 1;default: Q <= Q;endcase endcase en

38、 dmodule /74HC112测试平台代码 / test 112.V 'timescale 1n s/1 ns module test_112;reg set, res, clk, j, k;wire q, qn;HC112 u(set, res, clk, j, k, q, qn);always#5 clk = clk;task clock;rep eat(3)beginj = 0;k = 1;#20; j = 1;k = 0;#20;j = 0;k = 0;#20; j = 1;k = 1;#20;end en dtask in itial beginclk = 0;set =

39、 0;res = 0;clock; set = 0;res = 1;clock; set = 1;res = 0;clock;set = 1;res = 1;clock;end en dmodule/74HC161 代码/ 74HC161.Vmodule HC161(C P,CE P,CET,MRN, PEN,D n,Qn ,TC);input CP;input CEP, CET;out put 3:0Q n;input MRN ,P EN;inp ut 3:0D n;out put TC;reg 3:0qaux;always( posedge CP, negedge MRN) beginif

40、(!MRN) qaux<=4'b0000;else if(!P EN) qaux<=D n;else if(CE P & CET)qaux<=qaux+1;elseqaux<=qaux; endassign TC=(&qaux )&CET;assig n Qn=qaux;en dmodule /74HC161测试平台代码/ 161testbe nch.v 'timescale 1n s/1 ns module fre_testbe nch;reg CP ,CE P,CET,MRN; reg LT_N,BI_N,LE;reg 3:0

41、D n;wire TC;wire 3:0Q n;wire 7:0Seg;in itialbeginCP=0;CEP=1; CET=1; MRN=0;LT_N=1; BI_N=1; LE=0;#10 MRN<=1; endp arameter clock_ penod=20; always #(clock_period/2) CP=CP;in itialbeginDn=4'b0010;(p osedge TC)D n=4'b0100;(p osedge TC)D n=4'b1000;(p osedge TC)D n=4'b1010;(p osedge TC)

42、D n=4'b1110; endfreque ncy fre_test(C P,CE P,CET,MRN,D n,Seg,LT_N,BI_N,LE,Q n,TC); en dmodule/74HC194 代码/ 74HC194.V3:0 DataOut;3:0 ParIn;1:0 Seri n, Sel;Clk, MR_N;module HC194(DataOut, ParIn, Serin, Sel, Clk, MR_N); out put reg input inputinput always (n egedge MR_N or posedge Clk) if(MR_N) Data

43、Out <= 0;elsecase(Sel)DataOut <= 1'b1,DataOut3:1;DataOut <= DataOut>>1;DataOut <= DataOut2:0,1'b1;DataOut <= DataOut<<1;2'b00: DataOut <= DataOut; 2'b01:if(Seri n1)else2'b10:if(Seri n0)elsedefault: DataOut <= Pari n;endcaseen dmodule /74HC194测试平台代

44、码/ test 194.V'timescale 1ns/1nsmodule test_194;wireregreg3:0 out; 3:0 p ,t0:3;1:0 s, sel; mr,clk;regHC194 u(out, p, s, sel, clk, mr);always #2 clk = clk;task s_clock;begins = 0;rep eat(4)#10 s = s+1;enden dtasktask clock; beginsel = 2'b11;sel = 2'b00;sel = 2'b01;s_clock;s_clock;s_clo

45、ck;sel = 2'b10;s_clock;enden dtaskin itialbeginclk = 1; p = 4'b0110; clock;endin itialbeginmr = 1;#5 mr = 0;#10 mr = 1;enden dmodule2、第一次仿真结果(任选一个模块,请注明)74HC74imumWrawiniuuMuwwjwowumifinnoMcasogcs |0Uh Zt2t_71/31©.乍屯科11Sil杰 /ti(t_74/qrSlOho J;1SWX |;,nsnnrjiniuuirmiLnnunRWLJiRnnuuwLJUin

46、niunniirL!萨USOrsma fig3、综合结果4、第次仿真结果(综合后)/4.dOTfumuMinflfywwoInfumnnmnwMumiuuumnfuinratimM钊-GLOO p ill!1史PLnrumjumnr iLTLTLrurL J LrLTLTLri *1如浑iw2WrE5、第三次仿真结果(布局布线后)4、基本门电路、组合电路和时序电路的程序烧录及验证、实验目的1、熟悉利用EDA工具进行设计及仿真的流程。2、熟悉实验箱的使用和程序下载(烧录)及测试的方法。二、实验环境及仪器1、Libero仿真软件。2、DIGILOGIC-2011数字逻辑及系统实验箱。3、Actel Proasic3 A3P030 FPGA核心

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论