串口接收到浮点数如何解析
。。
分享大家一个学习单片机与嵌入式的地方,可以关注一下微信公众号【玩转单片机与嵌入式】,每天都会分享三篇有价值的文章,通过碎片化的学习时间,提高自己的水平。
我是把他转换成文本的
那怎么校验呢,MODBUS需要进行CRC检验,需要将帧数据每次取出8位进行运算,如果不先将浮点数转换为二进制或者十六进制,那该怎么校验呢?
把地址直接赋给浮点数指针,然后在取指针指向单元的值。单片机会自动按浮点数取值
如 : float * fp; fp = (flaot *)&buf[5]; *fp;
我觉得你把浮点的四个字节,原封不动的以二进制发出去,。接收端再以uint8类型从地址tab(变量名,只是举个例子)存放,原封不动的接收。最后定义一个浮点数指针float* p = tab 。P就是那个浮点数了
那怎么校验呢,MODBUS需要进行CRC检验,需要将帧数据每次取出8位进行运算,如果不先将浮点数转换为二进制或者十六进制,那该怎么校验呢?
那怎么校验呢,MODBUS需要进行CRC检验,需要将帧数据每次取出8位进行运算,如果不先将浮点数转换为二进制或者十六进制,那该怎么校验呢?这个才是我真正的目的
不是应该先校验成功再用数据吗?接受buf[]是8位的,直接CRC校验啊。8位数据是可以和32位float相互转换的,就是通过指针。
我是用matlab做主机,发给PLC,要先生产CRC
我是用matlab做主机,发给PLC,要先生产CRC
计算机是用二进制计算的。float数据通过位操作,每次取8位,或者通过指针付给8位数组,就可以进行CRC了
ModBus 发送的时候最后两个字节是CRC校检,ModBus发送一个浮点数的时候,也是直接拆分成无符号char类型,然后根据大小端换一下顺序吧,确定好发送数据的顺序之后进行CRC校检,把校检结果放在一帧的结尾。接收到之后直接对数据进行CRC校检,然后还原浮点数。
如果你两端都进行浮点数的计算的话,会比较费资源,不确定发送端的浮点数是如何来的,如果是通过计算得来的,建议不计算直接发,然后到从机处先校验,再计算成浮点数。
