发布于 2013-07-02 19:14:55
2楼
1.按照1L的方法用实数求解。如果显示需要用整数,可以给实数结果*10,然后再转换成整数,这样温度就有了1位小数了。同理,如果*100,那么整数结果就是2位小数。
2.全部用整数进行求解。此方法稍显复杂,但大部分情况下效率要比实数高。
比如这个公式,我会精简为:(13*AIW-57600)/2560
其中13*AIW用MUL指令,直接扩展为双整数。然后减法。
最后的除以2560,我希望整数结果精确到1位小数,所以只需除以256,这个除法用移位的方法即可(负数移位需要符号扩充,慎用)。
由于最后结果不会大于1438(满输入32767),因此最后结果可以变为16位。
两个方法运算精度差不多,但方法2也许要比方法1节省一半的运算量。