[MCU] 怎么算出小数?

[复制链接]
1154|33
 楼主| jlyuan 发表于 2020-9-2 20:26 | 显示全部楼层 |阅读模式
官方例程之中用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 发表于 2020-9-2 20:29 | 显示全部楼层
把INDEGF扩大一百倍
 楼主| jlyuan 发表于 2020-9-2 20:32 | 显示全部楼层
怎么搞?
zhaoxqi 发表于 2020-9-2 20:35 | 显示全部楼层
IntDegF = ((temp - 630) * 76100) / 1024;
jiajs 发表于 2020-9-2 20:40 | 显示全部楼层
对,取整就会把小数部分取出来
zhenykun 发表于 2020-9-2 20:44 | 显示全部楼层
看看你定义的变量是什么类型的
yszong 发表于 2020-9-2 20:47 | 显示全部楼层
楼上上的方法的确不错,dsp作整数运算要比小数的简单。
liliang9554 发表于 2020-9-2 20:57 | 显示全部楼层
转换float吧
zhaoxqi 发表于 2020-9-2 21:01 | 显示全部楼层
恩恩,前面定义的INTDEGF TEMP 和 INTDEGC 都是LONG
jiajs 发表于 2020-9-2 21:06 | 显示全部楼层
看看类型,转换错误了吧。
zhenykun 发表于 2020-9-2 21:13 | 显示全部楼层
该方法非常好的,若是允许浮点型的数据的话就更简单了
huangchui 发表于 2020-9-2 21:18 | 显示全部楼层
要定义好float的类型吧
zhanghqi 发表于 2020-9-2 21:21 | 显示全部楼层
双精度可以double的
chenho 发表于 2020-9-2 21:25 | 显示全部楼层
转换为float
stly 发表于 2020-9-2 21:29 | 显示全部楼层
类型吗?
supernan 发表于 2020-9-2 21:35 | 显示全部楼层
跟数据类型有关系的
pangb 发表于 2020-9-2 21:38 | 显示全部楼层
把定义的变量粘贴出来
xxmmi 发表于 2020-9-2 21:41 | 显示全部楼层
可以放大再缩小处理。
langgq 发表于 2020-9-2 21:44 | 显示全部楼层
结果跟输出有干系的。
zhuhuis 发表于 2020-9-2 21:47 | 显示全部楼层
这个计算是不是很大呢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

880

主题

12030

帖子

4

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