采用verilog语言设计38译码器(两种方法:分别用case和if语句)
时间: 2023-07-15 18:10:29 浏览: 307
用case语句设计38译码器的Verilog代码如下:
module decoder_3_8_case(
input [2:0] in,
output reg [7:0] out
);
always @*
begin
case(in)
3'b000: out = 8'b00000001;
3'b001: out = 8'b00000010;
3'b010: out = 8'b00000100;
3'b011: out = 8'b00001000;
3'b100: out = 8'b00010000;
3'b101: out = 8'b00100000;
3'b110: out = 8'b01000000;
3'b111: out = 8'b10000000;
default: out = 8'b00000000;
endcase
end
endmodule
用if语句设计38译码器的Verilog代码如下:
module decoder_3_8_if(
input [2:0] in,
output reg [7:0] out
);
always @*
begin
if(in == 3'b000) out = 8'b00000001;
else if(in == 3'b001) out = 8'b00000010;
else if(in == 3'b010) out = 8'b00000100;
else if(in == 3'b011) out = 8'b00001000;
else if(in == 3'b100) out = 8'b00010000;
else if(in == 3'b101) out = 8'b00100000;
else if(in == 3'b110) out = 8'b01000000;
else if(in == 3'b111) out = 8'b10000000;
else out = 8'b00000000;
end
endmodule