转换方法首先,先了解二进制与BCD码的位数对应关系,比如一个8位二进制码,可以表示的最大十进制数为255,转换成BCD码为0010_0101_0101,共需12位,其中每4位组成一个BCD单元,有三个BCD单元,分别表示百位(hundreds)、十位(tens)和个位(units)。n位二进制码转换成D位BCD码的n~D对应关系表见表1。
表1 n与D对应关系
以8位二进制转换为3位BCD码为例,转换步骤是:将待转换的二进制码从最高位开始左移BCD的寄存器(从高位到低位排列),每移一次,检查每一位BCD码是否大于4,是则加上3,否则不变。左移8次后,即完成了转换。需要注意的是第八次移位后不需要检查是否大于5。
注意:为什么检查每一个BCD码是否大于4,因为如果大于 4(比如 5、6),下一步左移就要溢出了,所以加 3,等于左移后的加 6,起到十进制调节的作用。
它的操作可以归纳如下:
1. 对于BCD移位寄存器中的每4位的BCD数字,检测这个数是否大于4。如果是,就在这个数字上加上一个3。
2. 将整个BCD寄存器向左移动一位,将输入二进制序列的最高有效位(MSB)移入到BCD寄存器的最低位(LSB)。
3. 重复步骤1和步骤2,直到所有的输入位都被使用了。
一个8位二进制输入“11101011”的转换过程如下表所示
表2 B/BCD时序
13位的转换电路代码如下:使用简单的FSMD控制整个操作。当start信号置为1时,二进制输入就存放到寄存器p2s中。然后FSM循环访问这13位二进制数的每一位,类似于前面例子描述的过程。需要四个调整电路来调整这四个BCD数字。为了清楚,将调整电路与次态逻辑分开,使用单独的代码进行描述。