怎么算出小数?

[复制链接]
674|13
 楼主| jlyuan 发表于 2016-5-5 21:35 | 显示全部楼层 |阅读模式
官方例程之中用ADC10对温度传感器进行采样,转化,公式如下:
/ oF = ((A10/1024)*1500mV)-923mV)*1/1.97mV = A10*761/1024 - 468
    temp = ADC10MEM;
    IntDegF = ((temp - 630) * 761) / 1024;

    // oC = ((A10/1024)*1500mV)-986mV)*1/3.55mV = A10*423/1024 - 278
    temp = ADC10MEM;
    IntDegC = ((temp - 673) * 423) / 1024;
用公式算出来的摄氏温度和华氏温度都是整数,为什么?怎么算出小数?
jiaxw 发表于 2016-5-5 21:37 | 显示全部楼层
把INDEGF扩大一百倍
 楼主| jlyuan 发表于 2016-5-5 21:45 | 显示全部楼层
怎么搞?
zhaoxqi 发表于 2016-5-5 21:48 | 显示全部楼层
IntDegF = ((temp - 630) * 76100) / 1024;
jiajs 发表于 2016-5-5 21:51 | 显示全部楼层
对,取整就会把小数部分取出来
zhenykun 发表于 2016-5-5 21:53 | 显示全部楼层
看看你定义的变量是什么类型的
yszong 发表于 2016-5-5 21:55 | 显示全部楼层
楼上上的方法的确不错,dsp作整数运算要比小数的简单。
i1mcu 发表于 2016-5-5 22:16 | 显示全部楼层
转换float吧
zhaoxqi 发表于 2016-5-5 22:18 | 显示全部楼层
恩恩,前面定义的INTDEGF TEMP 和 INTDEGC 都是LONG
jiajs 发表于 2016-5-5 22:25 | 显示全部楼层
看看类型,转换错误了吧。
zhenykun 发表于 2016-5-5 22:28 | 显示全部楼层
该方法非常好的,若是允许浮点型的数据的话就更简单了
 楼主| jlyuan 发表于 2016-5-5 22:29 | 显示全部楼层
哦,懂了,结贴啦
cemaj 发表于 2016-5-6 23:09 | 显示全部楼层
要定义好float的类型吧
cemaj 发表于 2016-5-6 23:11 | 显示全部楼层
双精度可以double的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

880

主题

12030

帖子

4

粉丝
快速回复 在线客服 返回列表 返回顶部