OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4227|回复: 2

short Get_Temprate(void)得到的温度值为什么要先扩大100倍,然后再缩小100倍?

[复制链接]

1

主题

6

帖子

0

精华

新手上路

积分
26
金钱
26
注册时间
2019-10-19
在线时间
10 小时
发表于 2022-5-24 21:27:13 | 显示全部楼层 |阅读模式
1金钱
short Get_Temprate(void)        //获取内部温度传感器温度值
{
        u32 adcx;
        short result;
        double temperate;
        adcx=T_Get_Adc_Average(ADC_Channel_16,20);        //读取通道16,20次取平均
        temperate=(float)adcx*(3.3/4096);                //电压值  2^12=4096  ADC采集的是到一个值,换算成电压就是ADC/4096*3.3
        temperate=(1.43-temperate)/0.0043+25;        //转换为温度值         //在25度时的电压典型值为1.43V;
                                              
        result=temperate*=100;        //扩大100倍.
        //result=temperate;
        return result;
}
result=temperate*=100;        //扩大100倍.  
这里为什么要先扩大100倍,不是直接就计算出了温度吗?看不懂为什么要这样处理,然后在主函数中将其再除以100,为什么要这样操作?

最佳答案

查看完整内容[请看2#楼]

浮点数处理太慢,一般都是把小数相应放大到整数处理,对应的显示或做其他处理时,缩小
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

805

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3832
金钱
3832
注册时间
2017-3-7
在线时间
1671 小时
发表于 2022-5-24 21:27:14 | 显示全部楼层
浮点数处理太慢,一般都是把小数相应放大到整数处理,对应的显示或做其他处理时,缩小
回复

使用道具 举报

2

主题

592

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1458
金钱
1458
注册时间
2019-7-28
在线时间
137 小时
发表于 2022-5-25 16:03:33 | 显示全部楼层
同楼上的解释   
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-27 02:59

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表