题解 | #4bit超前进位加法器电路#

4bit超前进位加法器电路

https://www.nowcoder.com/practice/4d5b6dc4bb2848039da2ee40f9738363

`timescale 1ns/1ns

module lca_4(
    input        [3:0]       A_in  ,
    input        [3:0]        B_in  ,
    input                   C_1   ,
 
     output     wire            CO    ,
    output   wire [3:0]        S
);
    wire [3:0] G,P,C;
    genvar i;
    generate
        for(i=0;i<4;i=i+1) begin:initi_proc
            assign G[i] = A_in[i] & B_in[i];
            assign P[i] = A_in[i] ^ B_in[i];
            assign S[i] = P[i] ^ ((i==0)?C_1:C[i-1]);
        end
    endgenerate
    
    assign C[0] = G[0] | (P[0] & C_1);
    assign C[1] = G[1] | (P[1] & G[0]) | (P[1] & P[0] & C_1);
    assign C[2] = G[2] | (P[2] & G[1]) | (P[2] & P[1] & G[0]) | (P[2] & P[1] & P[0] & C_1);
    assign C[3] = G[3] | (P[3] & G[2]) | (P[3] & P[2] & G[1]) | (P[3] & P[2] & P[1] & G[0]) | (P[3] & P[2] & P[1] & P[0] & C_1);
    
    assign CO = C[3];
endmodule
全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务