题解 | #用3-8译码器实现全减器#(需要真值表思维)

用3-8译码器实现全减器

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

`timescale 1ns/1ns

module decoder_38(
   input             E      ,
   input             A0     ,
   input             A1     ,
   input             A2     ,
   
   output reg       Y0n    ,  
   output reg       Y1n    , 
   output reg       Y2n    , 
   output reg       Y3n    , 
   output reg       Y4n    , 
   output reg       Y5n    , 
   output reg       Y6n    , 
   output reg       Y7n    
);

always @(*)begin
   if(!E)begin
      Y0n = 1'b1;
      Y1n = 1'b1;
      Y2n = 1'b1;
      Y3n = 1'b1;
      Y4n = 1'b1;
      Y5n = 1'b1;
      Y6n = 1'b1;
      Y7n = 1'b1;
   end  
   else begin
      case({A2,A1,A0})
         3'b000 : begin
                     Y0n = 1'b0; Y1n = 1'b1; Y2n = 1'b1; Y3n = 1'b1; 
                     Y4n = 1'b1; Y5n = 1'b1; Y6n = 1'b1; Y7n = 1'b1;
                  end 
         3'b001 : begin
                     Y0n = 1'b1; Y1n = 1'b0; Y2n = 1'b1; Y3n = 1'b1; 
                     Y4n = 1'b1; Y5n = 1'b1; Y6n = 1'b1; Y7n = 1'b1;
                  end 
         3'b010 : begin
                     Y0n = 1'b1; Y1n = 1'b1; Y2n = 1'b0; Y3n = 1'b1; 
                     Y4n = 1'b1; Y5n = 1'b1; Y6n = 1'b1; Y7n = 1'b1;
                  end 
         3'b011 : begin
                     Y0n = 1'b1; Y1n = 1'b1; Y2n = 1'b1; Y3n = 1'b0; 
                     Y4n = 1'b1; Y5n = 1'b1; Y6n = 1'b1; Y7n = 1'b1;
                  end 
         3'b100 : begin
                     Y0n = 1'b1; Y1n = 1'b1; Y2n = 1'b1; Y3n = 1'b1; 
                     Y4n = 1'b0; Y5n = 1'b1; Y6n = 1'b1; Y7n = 1'b1;
                  end 
         3'b101 : begin
                     Y0n = 1'b1; Y1n = 1'b1; Y2n = 1'b1; Y3n = 1'b1; 
                     Y4n = 1'b1; Y5n = 1'b0; Y6n = 1'b1; Y7n = 1'b1;
                  end 
         3'b110 : begin
                     Y0n = 1'b1; Y1n = 1'b1; Y2n = 1'b1; Y3n = 1'b1; 
                     Y4n = 1'b1; Y5n = 1'b1; Y6n = 1'b0; Y7n = 1'b1;
                  end 
         3'b111 : begin
                     Y0n = 1'b1; Y1n = 1'b1; Y2n = 1'b1; Y3n = 1'b1; 
                     Y4n = 1'b1; Y5n = 1'b1; Y6n = 1'b1; Y7n = 1'b0;
                  end 
         default: begin
                     Y0n = 1'b1; Y1n = 1'b1; Y2n = 1'b1; Y3n = 1'b1; 
                     Y4n = 1'b1; Y5n = 1'b1; Y6n = 1'b1; Y7n = 1'b1;
                  end
      endcase  
   end 
end    
     
endmodule

module decoder1(
   input             A     ,
   input             B     ,
   input             Ci    ,
   
   output wire       D     ,
   output wire       Co         
);

wire Y0n,Y1n,Y2n,Y3n,Y4n,Y5n,Y6n,Y7n;

assign D  = ~Y1n | ~Y2n | ~Y4n | ~Y7n;
assign Co = ~Y1n | ~Y4n | ~Y5n | ~Y7n;
decoder_38 decoder_38(
   .E (1'b1)  ,
   .A0(B)  ,
   .A1(A)  ,
   .A2(Ci)  ,
   
   .Y0n(Y0n)  ,  
   .Y1n(Y1n)  , 
   .Y2n(Y2n)  , 
   .Y3n(Y3n)  , 
   .Y4n(Y4n)  , 
   .Y5n(Y5n)  , 
   .Y6n(Y6n)  , 
   .Y7n(Y7n)  
);
endmodule

首先需要知道全减器的原理

真值表如下图。输入值是 低位向本位的借位borrow_in(简称in),被减数a,减数b

输出值为差值diffrent(简称d)和本位向高位的借位borrow_out(简称out)(只有被减数才需要借位,所以in,out都是相对于a来说的)输入值in,a,b的状态组合有八种。

详细分析如下:

in=0,b=0,a=0时,d=a-b=0,此时a的值足够减b,因此不需要向高位借位,所以out=0.

in=0,b=0,a=1时,d=a-b=1,同样的a的值足够减b,因此不向高位借位,所以out=0.

in=0,b=1,a=0时,此时a<b,a的值不足以减b,因此a必须向高位借位,所以out=1,二进制的借位规则是借1当2(就像十进制运算中向上一位是借1当10运算),借完之后a=2,则d=a-b=1.

in=0,b=1,a=1时,d=a-b=0,同样的a的值足够减b,因此a不向高位借位,所以out=0.

in=1,b=0,a=0时,原本a是够减b的,但是这里in=1,表示a的低位向a借位了,可是a=0没有办法借给它,因此a需要向自己的高位借位,所以out=1,a向高位借位之后为2,借给a的低位要减1,所以a=1,d=a-b=1.

in=1,b=0,a=1时,in=1表示a的低位向a借位了,a被借走1,a=0,足够减b,不需要向高位借位,所以out=0,d=a-b=0.

in=1,b=1,a=0时,in=1表示a的低位向a借位了,a=0没有办法借给它,因此a需要向自己的高位借位,所以out=1,a向高位借位之后为2,再借给a的低位要减1,所以a=1,d=a-b=0.

in=1,b=1,a=1时,in=1表示a的低位向a借位了,a=1可以借给低位,借完之后a=0,不足以减b,a要向自己的高位借位out=1,借完之后a=2,d=a-b=1.

原文链接:https://blog.csdn.net/weixin_43400722/article/details/100714046

然后需要知道译码器真值表

然后根据全减器真值表可以得到表达式:

全部评论

相关推荐

LZHR:老哥你从投递简历测评完到一面中间隔了多久呀,我这边已经过了五天了仍显示简历筛选中是不是就是挂了
腾讯求职进展汇总
点赞 评论 收藏
分享
27届学院本誓死冲击...:自我评价和校园经历全删了,荣誉经历只留奖学金,项目也全得换都不如外卖
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
2950次浏览 42人参与
# HR最不可信的一句话是__ #
985次浏览 32人参与
# MiniMax求职进展汇总 #
24824次浏览 321人参与
# 春招至今,你的战绩如何? #
14348次浏览 133人参与
# AI面会问哪些问题? #
874次浏览 21人参与
# 你的实习产出是真实的还是包装的? #
2588次浏览 52人参与
# 米连集团26产品管培生项目 #
7002次浏览 224人参与
# 沪漂/北漂你觉得哪个更苦? #
1076次浏览 29人参与
# 你做过最难的笔试是哪家公司 #
1084次浏览 20人参与
# AI时代,哪个岗位还有“活路” #
2630次浏览 49人参与
# XX请雇我工作 #
51141次浏览 171人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7950次浏览 43人参与
# 简历第一个项目做什么 #
32035次浏览 357人参与
# 简历中的项目经历要怎么写? #
310850次浏览 4257人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152795次浏览 888人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187527次浏览 1123人参与
# AI时代,哪些岗位最容易被淘汰 #
64474次浏览 860人参与
# 如果重来一次你还会读研吗 #
229960次浏览 2011人参与
# 投格力的你,拿到offer了吗? #
178175次浏览 889人参与
# 你怎么看待AI面试 #
180611次浏览 1291人参与
# 正在春招的你,也参与了去年秋招吗? #
364105次浏览 2640人参与
# 腾讯音乐求职进展汇总 #
160808次浏览 1114人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务