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

4bit超前进位加法器电路

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

先看1bit,1bit搞定了,nbit就串行(省面积)或者并行(省性能)

sum:

若进位为0--> 若AB相同 sum为0;若AB相异,sum为1--> S = C'(A^B)

若进位为1--> 若AB相同 sum为1;若AB相异,sum为0--> S = C (A^B)'

==》 S = C'(A^B) + C (A^B)' = C^(A^B)

CO:

若进位为0--> A,B同时为1才进位 --> CO = C'AB

若进位为1--> A,B只要有1就进位 --> CO = C(A+B)

==》CO = C'AB + C(A+B) = C'AB+CA+CB = C'AB + CAB+CAB'+CAB+CA'B = AB+C(A^B) +CAB = AB + C(A^B)

以下写法为串行;若写作并行,则将C0,C1,C2的表达式直接带入到下一级的运算中。

`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;
	wire [3:0] p;
	wire C0,C1,C2;

	assign g = A_in & B_in;
	assign p = A_in ^ B_in;
	assign S[0] = C_1 ^ p[0];  //get s0
	assign C0 = g[0] | (p[0] & C_1);  //get C_1 for S1
	
	assign S[1] = C0 ^ p[1];  //get s1
	assign C1 = g[1] | (p[1] & C0);  //get C1 for S2

	assign S[2] = C1 ^ p[2];  //get s2
	assign C2 = g[2] | (p[2] & C1);  //get C2 for S3

	assign S[3] = C2 ^ p[3];  //get s3
	assign CO = g[3] | (p[3] & C2);  //get CO 


endmodule

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-02 17:28
25届每天都在焦虑找工作的事情0offer情绪一直很低落硬撑着面了一个岗位岗位有应酬的成分面试的时候hr给我出各种场景题问的问题比较犀利 有点压力面的感觉感觉有点回答不上来本来就压抑的情绪瞬间爆发了呢一瞬间特别想哭觉得自己特别没用没绷住掉眼泪了事后想想觉得自己挺有病的 真的破大防了
喜欢唱跳rap小刺猬...:我觉得没关系吧,之前有一次面试leader给我压力面,我顶住了压力,结果入职的时候发现组里氛围很差,果断跑路。其实从面试就能大概看出组的情况,面试体验好的组倒是不一定好,但是面试体验不好的组。。。就很难说
点赞 评论 收藏
分享
星辰再现:裁员给校招生腾地方
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务