当前位置:首页 > 单片机 > 单片机
[导读]提出的快速算法思路是,首先求出整数中包含的1000的个数,方法是采用二进制整数的高6位作为其预估,再通过2次校正得到准确值。

摘要 旨在提高89C51系列单片机鳊程中经常用到的整数二十进制转换的代码执行效率。提出的快速算法思路是,首先求出整数中包含的1000的个数,方法是采用二进制整数的高6位作为其预估,再通过2次校正得到准确值。算法的关键是充分利用89C51单片机的两条特殊指令——单字节乘和单字节除。其耗费时间不及使用sprintf()函数的1/10。
关键词 89C5l 单片机二一十进制转换快速算法


    89C5l系列单片机历经20多年的发展,仍然长盛不衰,在工业控制及仪器仪表中得到广泛应用;用于89C5l单片机软件开发的Keil C51编译系统也日臻成熟,成为89C5l系列单片机软件开发的优先选择。在单片机系统开发中,经常遇到整数二十进制转换的问题,一般可以采用C语言中的标准函数sprintf()来实现;但由于该函数是通用格式输出函数,代码量大(超过l KB),用于整数二一十进制转换的运算时间过妊(在12 MHz晶振频率下超过l ms),这在计算密集(computation intensive)的应用中是一个影响系统性能的重要因素。在低功耗系统设计中,也必须考虑因为运算时间长而增加系统耗电量的问题。经常有网发询问如何高效地实现这种转换。笔者通过对二进制整数的深入分析,巧妙运用89C5l单片机的特殊单字节乘除指令,成功地实现了整数二一十进制转换的快速算法。本文将详细介绍快速算法,给出颇具实用性的优化代码,并与使用sprintf()函数的实现及传统的汇编代码实现进行性能比较。


1 传统的汇编代码实现
   
要实现快速运算,很自然地想到教科书中提到的双字节二进制整数转换成3字节BCD码整数的子程序。其采用的算法是,依次将整数的每位左移至CY位,再把CY位左移至一个3字节队列中,并进行十进制调整。通过16次移位完成运算,结果为压缩格式的3字节BCD编码。
汇编子程序如下:
   

    该算法代码简洁明了,只使用51条指令代码,但执行这段程序却要耗费312个指令周期。如果要符合C51调用规则,则要多出25个指令代码空间和21个指令周期,显然效率不高。


2 快速算法
   
快速算法从千位入手,首先求取整数中包含l 000的个数(以下称为“千数”)。求取了千数,其他问题就迎刃而解了。
    设二进制整数以b=[b15…b0]表示,取值范围为O~65535。其高6位[b15…b10]取值范围为0~63,在整数中代表的数值为(0~63)*1024;后10位[b9…b0]代表的数值范围为O~l 023。可以写出如下算式:

   
    可以用[b15…b10]作为整数中千数的预估。
    余数的最大值为63×24+1 023=2535。这表明余数中最多还有2个l000,也就是说千数的预估误差最多为2,因此最多通过2次校正,就可求得千数的准确值。2次校正方法:
    ①如果余数高位字节≥4(即余数≥1024,这样用只是为了简化代码;也可以用余数≥1000的判定条件),则千数+l,余数~1000;
    ②如果余数≥l000,则千数+1,余数~l000。
    至此就求出了千数。千数用10整除所得商和模余作为万位数和千位数。
    从余数中求取百、十,个位数也很简单:
    余数用100整除得到百位数。实际是先把余数右移2位,此时已成单字节数,再用单字节除指令进行除以25的操作,即得到百位数;而除去百位后的余数已是单字节数,可轻易取得十位数与个位数。
    用C语言编写的函数如下:

   

   
    在Keil C51集成环境中,为该函数生成汇编程序源码,再对源码进行优化,最后得到满足C51调用规则的、效率极高的汇编语言源代码。(源代码见本刊网站www.mesnct.com.cn——编者注。)
    这个汇编语言源代码可以直接作为项目文件使用,也可以用来生成函数库。

3 性能比较
(1)与传统汇编语言的性能比较
   
符合C5l调用规则的传统汇编语言子程序占用76字节的代码空间,耗用333个指令周期;快速算法最多耗用107个指令周期,耗时只有传统算法的32%。
(2)与使用sprintf()函数相比较
    使用如下的程序来比较二者的性能:
       

    sprintf()函数占用1064字节的代码空间,耗用1151个指令周期;快速算法占用97字节的代码空间,最多耗用107个指令周期,只占使用sprintf()函数耗时的9.3%。

结论
   
无论是与传统汇编语言子程序,还是与使用sprintf()函数的程序相比,快速算法都有很大的速度优势;是一种针对8位机的创新算法,具有很强的工程实用性,值得推广应用。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

程序存储器(又称数据Flash),顾名思义,是用来存储用户的程序,使单片机能够按照编写的代码顺序执行,完成指定的任务。所以程序存储器是只读存储器(只读存储器),我们已经听过很多次了。代码存储在里面,一般有常数、表格、pi...

关键字: 51单片机 存储器

单片机是计算机技术发展史上重要里程碑,标志着计算机正式形成了通用计算机系统和嵌入式计算机系统两大分支。单片机处于测控系统的核心地位并嵌入其中,所以国际上通常把单片机称为嵌入式控制器(EMCU,Embedded Micro...

关键字: 51单片机 单片机

为增进大家对单片机的认识,本文将对单片机的工作条件以及51单片机和52单片机的区别予以介绍。

关键字: 单片机 指数 51单片机

摘要:GSM模块是指具有短信发送、语音通话以及数据传输等基本通信功能的功能模块,目前广泛应用于电力、建筑、水务等领域。现设计了一款基于51单片机和GSM模块的防火防盗报警装置,该装置主要由51单片机、人体检测模块、烟雾检...

关键字: GSM模块 51单片机 蜂鸣器

在进行项目开发过程中,我们经常会遇到需要单片机选型,所以我们常常会根据项目功能需求来选择合适的单片机品牌和型号。

关键字: 选型 参数 51单片机

通过本文,你将对51单片机、51单片机通信协议有所了解。

关键字: 51单片机 单片机 指数

为增进大家对单片机的认识,本文将对51单片机予以介绍,主要内容在于介绍个人学习51单片机的步骤,或者说学习51单片机的经验。

关键字: 单片机 指数 51单片机

在这篇文章中,小编将介绍为何51单片机是学习首选,并讨论学习51单片机的步骤。

关键字: 51单片机 单片机 指数

毕设课设基于51单片机的声光控智能灯设计

关键字: 光控开关 51单片机

关注、星标公众号,直达精彩内容来源:技术让梦想更伟大作者:李肖遥嵌入式开发入门之路我相信很多朋友第一次接触的单片机应该就是51单片机,8位的mcu,丰富的教程,可以做很多小玩意,让初学者基本掌握单片机编程技术,在实际操作...

关键字: 51单片机 嵌入式开发

单片机

21600 篇文章

关注

发布文章

编辑精选

技术子站

关闭