「HDLBits题解」Multiplexers

本文档提供了多个Verilog模块实例,包括Mux2to1、Mux2to1v、Mux9to1v、Mux256to1和Mux256to1v,展示了如何使用HDLBits进行多路复用器的设计与仿真,适合Verilog学习者参考。
摘要由CSDN通过智能技术生成

本专栏的目的是分享可以通过HDLBits仿真的Verilog代码 以提供参考 各位可同时参考我的代码和官方题解代码 或许会有所收益

题目链接:Mux2to1 - HDLBits

module top_module( 
    input a, b, sel,
    output out ); 
    assign out = sel ? b : a ; 
endmodule

题目链接:Mux2to1v - HDLBits

module top_module( 
    input [99:0] a, b,
    input sel,
    output [99:0] out );
    assign out = sel ? b : a ; 
endmodule

题目链接:Mux9to1v - HDLBits

module top_module( 
    input [15:0] a, b, c, d, e, f, g, h, i,
    input [3:0] sel,
    output reg [15:0] out );

    always @(*) begin
        case (sel)
            0 : out = a ; 
            1 : out = b ; 
            2 : out = c ; 
            3 : out = d ; 
            4 : out = e ; 
            5 : out = f ; 
            6 : out = g ; 
            7 : out = h ; 
            8 : out = i ; 
            default : out = '1 ; // Set all bits to 1
        endcase
    end

endmodule

题目链接:Mux256to1 - HDLBits

module top_module( 
    input [255:0] in,
    input [7:0] sel,
    output out );
    assign out = in[sel] ;
endmodule

题目链接:Mux256to1v - HDLBits

module top_module( 
    input [1023:0] in,
    input [7:0] sel,
    output reg [3:0] out );

    always @(*) begin
        integer i ; 
        for (i = 0 ; i <= 3 ; i = i + 1)
            out[i] = in[sel * 4 + i] ;
    end

endmodule
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

UCSD.KS

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

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

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

打赏作者

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

抵扣说明:

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

余额充值