数字电路-74LS283两个BCD码的加法运算

本内容主要介绍了BCD码(Binary-Coded Decimal)的基本概念、8421 BCD码加法原理、BCD码加法电路以及相关的Verilog代码编写的前置知识。

目录:

1、什么是BCD码

2、8421 BCD码加法原理

3、BCD码加法电路

4、元件功能

5、BCD码的Verilog代码


前置知识:卡诺图与逻辑代数化简法数字电路-时序逻辑电路


1、什么是BCD码

Binary-Coded Decimal‎缩写BCD,用4位二进制数来表示1位十进制数中的0~9这10个数码,简称BCD码。日常所说的BCD码大都是指8421 BCD码形式。

0dd5d0f6a390427287a309ce6bd1ec34.png

十进制数的几种4位编码

8421 BCD码表示形式如下表所示。

100014010070111
200105010181000
300116011091001

2、8421 BCD码加法原理

BCD码中0~9可以用四位二进制数0000~1001表示,而1010~1111这6个数为无效数。两个4位二进制数相加所得的结果超过1001,则将所得数加0110,来跳过6个无效数,并产生一个进位。

3、BCD码加法电路

电路由4位二进制超前进位全加器、进位控制电路、译码器74LS47N、显示电路共4个部分组成。其部分电路如下图所示,仿真原文件下载移步:两个BCD码的加法运算

004020de2f2f4b538b44f16ba92e2980.gif

也可以使用74LS83N,如下图所示。

f5d999d9a3134d72810e90ce62095007.png

4、元件功能

a6f8414f9f5047149615c26b580c18b4.png

5、BCD码的Verilog代码

  module bcd(cout,sum,ina,inb,cin);
  
  input cin;
  input [3:0] ina,inb;
  output reg [3:0] sum; //等价于output [3:0] sum;reg [3:0] sum;
  output reg cout;
  reg [4:0] temp;
  
  always @(ina, inb, cin)
    begin
      temp<=ina+inb+cin;
      if(temp>9)
        {cout,sum}<=temp+6;
      else
        {cout,sum}<=temp;
   end
 
 endmodule

知我所能,我所能者,尽善尽美;知我所不能,我所不能者,虚怀若谷。觉得不错,动动发财的小手点个赞哦!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱上电路设计

你的鼓励是我创作最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值