目前的51单片机在进行带小数点结果的除法一般可以采用浮点数计算的方式,但是浮点数计算有一个缺点就是非常耗时,在对时间要求严格的工况就不太适用。
笔者的工作室长期承接单片机、电路、机电液、工控、自动化、计算机软件等项目,最近做了个单片机计算器的设计,在设计除法时利用长整形除法和取余运算,可以得到若干小数位的精度运算,与大家共享。
设计思路如下:
假设长整形除数a, 长整形被数b,步骤如下:
<1>得到除法的整数部分,c=a/b;
<2>设d为a%b,e=10*d,
得到除法的第一位小数,f=e/b;
(要点:将a余b的余数乘以10倍,再和被除数b相除,就得到小数点后一位小数)
<3>设g为e%b,h=10*g,
得到除法的第二位小数,i=h/b;
以此类推,可以得到除法的任意小数……
unsigned long result, result_p;//表示除法结果的整数和小数部分
// result_p是小数部分,例如result_p=12345678,表示0.12345678
Voidchufa(unsigned long chushu, unsigned long beichushu, unsigned char wei)
// wei表示精确到小数点后多少位
{ unsigned char i;
unsigned long tmp;
result=result_p=0;
if (beichushu!=0)//被除数必须不为0
{
if (wei==0)
{result=chushu/beichushu;//计算整数部分
result_p=0;
}
else
{result=chushu/beichushu;//计算整数部分
tmp=chushu%beichushu;
for (i=1;i<=wei;i++)//计算小数部分
{tmp=tmp*10;
result_p=result_p*10+tmp/beichushu;
tmp=tmp%beichushu;
}}} }