当前位置:首页 > 单片机 > 单片机
[导读]0 引言 实时控制系统程序设计中,常涉及到小数运算问题.计算机系统中用二进制表示小数的方法有定点数表示法和浮点数表示法.采用浮点数表示法表示的小数范围大、精度高,但程序代码长,运算速度慢.定点数表示的小数

0 引言
实时控制系统程序设计中,常涉及到小数运算问题.计算机系统中用二进制表示小数的方法有定点数表示法和浮点数表示法.采用浮点数表示法表示的小数范围大、精度高,但程序代码长,运算速度慢.定点数表示的小数范围小、精度低,但程序代码短,运算速度快.
使用C语言设计程序具有程序可读性强,编程方便等优点,但按常规方法设计程序时,实时性不如采用汇编语言设计的程序,这在涉及到小数运算时表现更为突出.这样就限制了C语言的应用.如果采用合适的计算方法,使用C语言编程可以获得与汇编语言编程同样的实时性.
实时控制系统中的前向通道采集的原始数据大多是定点整数,例如前向模拟通道的A/D转换器的转换结果,定时/计数器的计数结果等,都是定点整数.而系统的后向通道能接受的输入量也都为整数,即由量化产生的有限字长误差不可避免,精确到小数位的控制量因执行机构无法接受而不得不舍去.因而,虽然采用定点数表示小数的方法精度低,但在大多数情况下,仍能满足实时控制系统的控制精度要求.
MCS-51单片机的内部程序存储器仅有4K,运算速度较慢.对于实时性、代码长度限制要求较高的控制系统,采用MCS-51单片机控制时,不宜大量采用浮点运算.本文介绍Keil C51下的16位定点小数的乘法程序.

1 定点小数运算算法
1.1 控制算法的特点.
计算机实时控制系统中,控制算法通常可用下面的差分方程表示.


式中y[n]为第n个采样周期的输出,通常为二进制整数;x [n]为第n个采样周期的输入,通常也为二进制整数;ai、bi为实系数.在保证计算精度的条件下,计算上述差分方程时,将系数ai、bi转换成整数或定点小数,会大幅度提高运算速度和大幅度减少代码长度.这对于在程序存储器容量或运算速度有限的嵌入式控制器中实现快速控制算法计算有重要意义.

1.2 定点小数
小数可分为整数部分为0的纯小数和带整数的小数.纯小数可直接用定点小数表示,当使用16位定点小数时,分辩率可达2-16,可以获的足够的运算精度.

1.3 定点算法
设x为十进制纯小数,M为16位二进制整数.若程序需计算y=(x·M)取整,则可先将x转换成16位二进制定点小数.
X =(x·65536)取整(2)
由于X的小数点在X的最高位前,2个16位二进制数相乘结果为32位二进制数,小数点在高16位和低16位间,乘法运算后的高16位为计算结果的整数部分,低16位为计算结果的小数部分.即
(x·M)取整=(X·M)取高16位 (3)
这样处理后可以大幅度提高运算速度,且大幅度减少代码长度.
汇编语言程序设计中的取整操作容易实现,在C语言中实现取整操作可以使用联合体,方法如下.
先定义2个联合体.
union{
unsigned char a_byte[4];
long a_long;
}r;
union{
unigned char b_byte[2];
int b_int;
}p;
第一个是长整数变量与4字节变量的联合体,长整型变量用于保存计算结果,第二个是整型变量与2个字节型变量的联合体,用于取整运算.在Keil C51中,长整数占4个字节,在RAM中按从高到低的顺序存放,r.a_byte[0]、r.a_byte[1]存放计算结果的整数部分,r.a_byte[2]、r.a_byte[3]存放计算结果的小数部分.
通过下列程序,实现取整运算.
p.b_byte[0]=r.a_byte[0];
p.b_byte[1]=r.a_byte[1];
这样p.b_int为计算结果的整数部分.以上程序在编译后仅为2条数据传送指令,需要4个机器周期的执行时间.与采用除法运算或移位运算实现取整运算相比,具有更快的执行速度.

2 程序
设程序需要计算0.12345乘16位二进制数后取整,采用浮点数时的程序如下所示.
main()
{
int b;
b=20000;
a=0.12345*b;
}
本程序的运行结果a=2527,程序编译后长度513字节,做浮点运算时需要602个机器周期.
main()
{
int a,b;
union{
char c[4];
long d;
}u1;
union{
char e[2];
int f;
}u2;
b=20000;
u1.d=(long)8090*b;
u2.e[0]=u1.c[0];
u2.e[1]=u1.c[2];
}
本程序的运行结果u2.f=2527,程序编译后长度129字节,做整数运算时仅需134个机器周期.

3 结束语
采用本文中所述方法,使用c语言设计MCS-51单片机控制算法程序,可获得与采用汇编语言设计的控制算法程序同样的效果.充分发挥了
c语言设计程序的优点,笔者在设计的某控制系统时,采用这种方法在获得了很好的效果.


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

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭