Latest Post

Ads

Verilog: 1 to 8 DEMUX Behavioral Modelling using Case Statement with Testbench Code

Verilog Code for 1 to 8 DEMUX Behavioral Modelling using Case Statement with Testbench Code

module 1_8_DEMUX(
    input i,
    input s2, s1, s0,
    output [7:0]out 
    );
reg [7:0]out;
always @ (i or s0 or s1 or s2)
case ({s2,s1,s0})
    0: out0 = i;
    1: out1 = i;
    2: out2 = i;
    3: out3 = i;
    4: out4 = i;
    5: out5 = i;
    6: out6 = i;
    7: out7 = i;
    default: out = 8'bxxxxxxx;
endcase
endmodule

//Testbench code for 1 to 8 DEMUX (DeMultiplexer) Behavioral Modelling using Case Statement

initial begin
// Initialize Inputs 
i = 1;s2 = 0;s1 = 0;s0 = 0;
// Wait 100 ns for global reset to finish
#100;
// Add stimulus here
#100; s2=0; s1=0; s0=1;
#100; s2=0; s1=1; s0=0;
#100; s2=0; s1=1; s0=1;
#100; s2=1; s1=0; s0=0; 
#100; s2=1; s1=0; s0=1; 
#100; s2=1; s1=1; s0=0; 
#100; s2=1; s1=1; s0=1;  
end
initial begin 
#100;
$monitor(“I=%b, s2=%b, s1=%b, s0=%b, out=%b”, I, s2, s1, s0, out);
end
endmodule 

Output:

1 to 8 Demultiplexer Behavioral Modelling
1 to 8 DEMUX Response

Comments

Ads

Popular posts from this blog

1 to 4 DEMUX (Demultiplexer) Verilog CodeStructural/Gate Level Modelling with Testbench

VLSI: 2 Bit Magnitude Comparator Dataflow Modelling

VLSI: 1-4 DEMUX (Demultiplexer) Dataflow Modelling with Testbench

VLSI: BCD to Excess 3 and Excess 3 to BCD Dataflow Modelling

VLSI: Half Subtractor and Full Subtractor Gate Level Modelling