数字逻辑与部件设计基础实验——3-8译码器

通过这次实验,使用Verilog在Vivado环境中设计并实现了3-8译码器,理解了74138器件的功能,并在NEXYS4 DDR开发板上进行验证。实验过程包括根据功能表编写代码,分析Design和Constraints源文件,以及在硬件上观察输出。在实验中,通过与非门和非门实现了使能信号,并探讨了case语句与if-else语句在代码中的替代可能性。
摘要由CSDN通过智能技术生成

实验目的

用连续值 或者always语句实现3-8译码器74138

了解3-8译码器的功能,锻炼根据功能表实现硬件功能的能力

熟悉上板操作的步骤和流程
74138的器件手册中的Function Tables:

74138的器件手册中的Function Tables:

实验内容

(一)实验流程:

用verilog语言在vivado环境下编写源文件,实现3-8译码器。经综合、实现、生成bitstream文件后,将bit文件下载到NEXYS4 DDR开发板上测试功能(三个指定的拨动开关代表输入,上拨值为1,下拨值为0; 八个指定的led灯代表输出,灯亮代表H高电平1,不亮代表L低电平0。)

(二)verilog代码分析:

1.Design source(.v文件):

module ThrEightymq(

    input G1,

    input G2A,

    input G2B,   //Enable

    input [2:0]S, //input

    output reg [7:0]Y  //output

    );

    wire G2;

    assign G2=G2A|G2B;

    always@(*)

    begin

    case({G1,G2})

      2'b10:

         begin

           case(S)

           3'b000 : Y = 8'b11111110;

           3'b001 : Y = 8'b11111101;

           3'b010 : Y = 8'b11111011;

           3'b011 : Y = 8'b11110111;

           3'b100 : Y = 8'b11101111;

           3'b101 : Y = 8'b11011111;

           3'b110 : Y = 8'b10111111;

           3'b111 : Y = 8'b01111111;

           default:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

adriaW

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值