16位二进制数转换成BCD码的的快速算法-51单片机
来源:互联网 发布:淘宝店新手如何推广 编辑:程序博客网 时间:2024/05/21 19:07
在做而论道上篇博文中,回答了一个16位二进制数转换成BCD码的问题,给出了一个网上广泛流传的经典转换程序。
程序可见:http://hi.baidu.com/%D7%F6%B6%F8%C2%DB%B5%C0/blog/item/6154551f93ba561440341732.html中的HEX2BCD子程序。
.
说它经典,不仅是因为它已经流传已久,重要的是它的编程思路十分清晰,十分易于延伸推广。做而论道曾经利用它的思路,很容易的编写出了48位二进制数变换成16位BCD码的程序。
但是这个程序有个明显的缺点,就是执行时间太长,转换16位二进制数,就必须循环16遍,转换48位二进制数,就必须循环48遍。
上述的HEX2BCD子程序,虽然长度仅仅为26字节,执行时间却要用331个机器周期。
.
单片机系统多半是用于各种类型的控制场合,很多时候都是需要“争分夺秒”的,在低功耗系统设计中,也必须考虑因为运算时间长而增加系统耗电量的问题。
为了提高整机运行的速度,在多年前,做而论道就另外编写了一个转换程序,程序的长度为81字节,执行时间是81个机器周期,(这两个数字怎么这么巧!) 执行时间仅仅是经典程序的1/4!
.
近来,在网上发现了一个链接:http://www.mcu123.com/news/Article/uc/uc8051/200803/4751.html,也对这个经典转换程序进行了改进,话是说了不少,只是没有实质性的东西。这篇文章提到的程序,一直也没有找到,也难辩真假。
这篇文章好像是选自某个著名杂志,但是在术语的使用上,有着明显的漏洞,不像是专业人员的手笔。比如说文中提到的:“使用51条指令代码,但执行这段程序却要耗费312个指令周期”,就是败笔。51条指令代码,真不知道说的是什么,指令周期是因各种机型和指令而异的,也不能表示确切的时间。
.
下面说说做而论道的编程思路。
;-----------------------------------------------------------------------
;已知16位二进制整数n以b15~b0表示,取值范围为0~65535。
;那么可以写成:
; n = [b15 ~ b0]
;把16位数分解成高8位、低8位来写,也是常见的形式:
; n = [b15~b8] * 256 + [b7~b0]
;那么,写成下列形式,也就可以理解了:
; n = [b15~b12] * 4096 + [b11~b0]
;式中高4位[b15~b12]取值范围为0~15,代表了4096的个数;
;上式可以变形为:
; n = [b15~b12] * 4000 + {[b15~b12] * (100 - 4) + [b11~b0]}
;用x代表[b15~b12],有:
; n = x * 4000 + {x * (100 - 4) + [b11~b0]}
;即:
; n = 4*x (千位) + x (百位) + [b11~b0] - 4*x
;写到这里,就可以看出一点BCD码变换的意思来了。
;
;上式中后面的位:[b11~b0] - 4*x,如果小于256,那就太简单了,马上就可以去按照常规转换BCD了。
;如果数值较大,就要把[b11~b7]看成128的个数y;在百位中加上y、在十位加上3*y、并在[b6~b0]中减去2*y。
;那么就有:
; n = 4*x (千位) + x (百位) + [b11~b0] - 4*x
; n = 4*x (千位) + (x + y) (百位) + 3*y (十位) + [b6~b0] - 2*y
;由此,就可以明确由高9位[b15~b7]变换出来十进制的各个位的数值,可能大于9,到最后整理一下即可。
;剩下的低7位[b6~b0],已经是单字节数据,变换成BCD码那就十分简单了。
;-----------------------------------------------------------------------
从最后的表达式中可以看出,高9位变换的计算方法极为简单,只是使用左移、加减等指令即可,基本上不涉及多字节的运算。
编程的时候,要充分利用单字节、单周期的指令,使程序的长度和执行时间尽量缩短。
做而论道的编程思路已经给出,程序代码还是过一段时间再公布,给大家留下一个发挥的时间。
感兴趣的网友可以留言,写出自己编写的程序。
- 16位二进制数转换成BCD码的的快速算法-51单片机
- R0中的8位二进制数转换成3位BCD码 -单片机编程
- 16位二进制数转成BCD码--51单片机
- 将A中的二进制数转换为3位的BCD码,其中百位数存放......
- 16个拼装4位二进制数0~F转换成ASCII码 -单片机编程
- 什么是BCD码?BCD码的用处。怎么把BCD码转换成二进制值?
- 32位二进制数转BCD码
- Verilog - 二进制数转换成BCD编码
- 二进制数转化为8421BCD码的C++程序
- 把数转换成length位的二进制字符串
- 返回十进制转换成二进制数的第i位
- 51单片机汇编编程:BCD 码与 BIN 数据的转换程序
- C# BCD码与十进制数的转换
- ASCII 码和十六进制数的转换 -51单片机
- 二进制与BCD码转换
- PIC单片机的BCD码处理程序
- 51单片机对两位 BCD拨盘 的读出程序
- 二进制数的转换
- 在20H后放入10个字节,用51汇编,找出重复出现频率最高的字节
- 由DLL (sqlite3.dll)直接转为 LIB 库
- Keil 与Proteus的联合仿真调试
- spring4 学习4 spring MVC+mybatis+Mysql
- 51单片机把4位16进制数转成10进制数的方法
- 16位二进制数转换成BCD码的的快速算法-51单片机
- 两个BCD码的数字相减,用汇编怎么写?
- Color lighter osmanthus
- 计算机中二进制减法的问题
- 几道单片机编程题
- select
- MCS-51系列单片机指令如何判断字节数
- 两道单片机编程题--求最大值和数据传送
- 一个串口通信发送的程序,51汇编的