VerilogHDL语言实现组合逻辑电路

本文介绍如何使用VerilogHDL语言实现组合逻辑电路,包括使用assign语句和always语句实现简单加法器、数据选择器等,并提供8选1数据选择器的具体实现示例。

VerilogHDL语言实现组合逻辑电路

组合逻辑电路:输出之与当前输入有关,与当前所处状态无关。

常用的组合电路有多路器、数据通路开关、加法器、乘法器等。

1.     assign语句实现组合逻辑

例1:assign语句实现加法器

wire a, b, c ;

assign c = a + b;        //加法器

实例实现的是一个简单的加法器,assign语句也可以实现较复杂的组合逻辑电路,例如2:assign实现选择器

wire a, b, c ;

wire ena ;

assign c = ena ? a : b;          //数据选择器

例3:assign实现8选1选择器

wire a0, a1, a2, a3, a4, a5, a6,a7,b ;

wire [2:0] addr ;

assign b =                //81数据选择器

              (addr== 3'd0) ? a0 : (addr == 3'd1) ? a1 :

              (addr== 3'd2) ? a2 : (addr == 3'd3) ? a3 :

              (addr== 3'd4) ? a4 : (addr == 3'd5) ? a5 :

              (addr== 3'd6) ? a6 : a7

              ;

使用assign语句描述组合逻辑电路时,格式为:

       assign 输出变量 =输入变量之间的运算结果;

 

2.     always 语句实现组合逻辑

例4:always实现加法器

wirea, b, c ;

always@ (a or b)                 //ab有变化时,触发加法器操作

       c = a + b ;

实例实现了一个加法器,如果需要实现一个数据选择器,如

例5:always实现选择器

wirea, b, c ;

wireena ;

always@ (a or b or ena)       //a b ena有变化时,进行下面操作

       if(ena == 1'b0)

              c = a ;

       else

              c = b ;

例6:always实现8选1选择器

moduleselect8_1_always(

    input [7:0] sw,

    input [2:0] addr,

    output reg led

    );

       always @ (sw or addr)

              begin

                     case(addr)        //使用case语句实现81数据选择器

                            3'd0 : led = sw[0] ;

                            3'd1 : led = sw[1] ;

                            3'd2 : led = sw[2] ;

                            3'd3 : led = sw[3] ;

                            3'd4 : led = sw[4] ;

                            3'd5 : led = sw[5] ;

                            3'd6 : led = sw[6] ;

                            default : led =sw[7] ;

                     endcase

              end

endmodule

由于在always块中可以使用ifcase等语句,所以对于复杂的组合逻辑,使用always语句进行描述显得层次更加清楚,可读性更强。使用格式如下:

always @ (敏感变量1 or敏感变量2…… or敏感变量N)

begin

      各种语句的组合;

end

 

其中的敏感变量包括所有的会引起输出变化的输入变量及相应的控制变量。另外,使用always语句描述组合逻辑电路时,应该使用堵塞式赋值,即“=”,而不是“<=”。


Verilog HDL语言实现组合逻辑电路可按以下方式进行: ### 设计分析 根据给定逻辑电路图,从电路的输入端开始逐级分析,写出输出端的逻辑函数表达式,对写出的输出逻辑函数进行化简,列出真值表,分析真值表以确定电路的逻辑功能。例如在分析一个具体的组合逻辑电路时,要明确输入输出端口,从输入开始逐步推导输出的逻辑关系,然后简化逻辑表达式,再根据表达式列出真值表来清晰呈现输入输出的对应关系,从而确定电路功能,如判断是表决电路、加法器等具体类型 [^1]。 ### 代码实现 #### 基本逻辑电路 - **三人表决电路**: ```verilog module JG3(ABC,X,Y); input [2:0] ABC; output X, Y; reg X, Y; always@(ABC) case(ABC) 3'b000:{X,Y} = 2'b01; 3'b001:{X,Y} = 2'b00; 3'b010:{X,Y} = 2'b00; 3'b011:{X,Y} = 2'b00; 3'b100:{X,Y} = 2'b00; 3'b101:{X,Y} = 2'b10; 3'b110:{X,Y} = 2'b10; 3'b111:{X,Y} = 2'b10; endcase endmodule ``` 此电路通过`case`语句根据输入`ABC`的不同取值组合,为输出`X`和`Y`赋予相应的值,实现三人表决的逻辑功能 [^2]。 - **多路择器**: ```verilog module mux21(a,b,s,y); input a,b,s; output y; reg y; always @(a,b,s) begin if(s == 1'b0) y = a; if(s == 1'b1) y = b; end endmodule ``` 该电路使用`if`语句,根据择信号`s`的值决定输出`y`是输入`a`还是`b`,实现了简单的二一多路择功能 [^2]。 #### 进阶逻辑电路 - **半加器**: ```verilog module hadder_test(a,b,cout,sum); input a,b; output cout,sum; assign {cout,sum} = a+b; endmodule ``` 半加器通过`assign`语句将输入`a`和`b`相加,结果的进和本分别赋给`cout`和`sum`,实现半加的功能 [^3]。 - **全加器**: ```verilog module fadder_test(a,b,ci,s,co); input a,b,ci; output s,co; assign {co,s} = a+b+ci; endmodule ``` 全加器同样使用`assign`语句,考虑了进输入`ci`,将`a`、`b`和`ci`相加,结果的进和本分别赋给`co`和`s`,实现全加的功能 [^3]。 - **显示译码器**: ```verilog module decl7s_test(a,led7s); input [3:0] a; output [6:0] led7s; reg [6:0] led7s; always @(a) case(a) 4'b0000:led7s = 7'b0111111; 4'b0001:led7s = 7'b0000110; 4'b0010:led7s = 7'b1011011; 4'b0011:led7s = 7'b1001111; 4'b0100:led7s = 7'b1100110; 4'b0101:led7s = 7'b1101101; 4'b0110:led7s = 7'b1111101; 4'b0111:led7s = 7'b0000111; 4'b1000:led7s = 7'b1111111; 4'b1001:led7s = 7'b1101111; 4'b1010:led7s = 7'b1110111; 4'b1011:led7s = 7'b1111100; 4'b1100:led7s = 7'b0111001; 4'b1101:led7s = 7'b1011110; 4'b1110:led7s = 7'b1111001; 4'b1111:led7s = 7'b1110001; endcase endmodule ``` 显示译码器利用`case`语句根据输入`a`的不同四二进制值,为输出`led7s`赋予不同的七二进制值,实现7段数码显示译码的功能 [^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值