我使用的单片机AD采集的数据储存到寄存器中的是u16(无符号16位),但是在运算中是float,怎么解决类型转换

我使用的单片机AD采集的数据储存到寄存器中的是u16(无符号16位),但是在运算中是float的怎么解决类型转换以及存储问题

“单片机AD采集的数据储存到寄存器中的是u16(无符号16位)”
这个是指采样得到的数字量读数,要换算后才能得到实际的模拟值。例如16位ADC的采样范围是0~3.3V,那么每个bit对应于50μV。当读数为0x0123、即十进制的291时,代表此时采样电压为14.55mV左右。
“在运算中是float的”

这要看你运算中取用数据的要求。假如你运算时直接要以mV或μV为单位进行运算,例如上面的例子,你就需要将采集的u16值0x0123转换为float型代表的14.55。这个转换过程就需要你编写函数进行转换,而不是直接强转的。
温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2018-03-10
直接存u16型原始数据即可,显示时再换算
如AD是16位,基准电压是2.5伏,所测数字量是val,则计算结果是:
V=2.5*val/65536
无需类型转换,直接将V定义成float型即可
当然你可以将val强制转换成float型
V=2.5*(float)val/65536本回答被网友采纳
第2个回答  2018-03-07
如果运算对象有float类型,U16会自动转换的,不用处理追答

这是C语言的运算规则,你回头看看教材就会想起来的

第3个回答  2018-03-07
直接定义一个float的变量赋值就行了
第4个回答  2018-03-10
使用强制类型转化,如:
int a = 3490593;
float b = (float)a;