科隆电磁流量计IFC300的累计流量,是双精度浮点型.在厂方的手册里,可以按如下方法转换成单精度浮点型.
可是在计算尾数ma时,又用到了超过32位的整型数值 2 ^ 36,2 ^ 44,2 ^ 52.自己在PLC上做实验,发现幂运算超过32位都会让PLC报错停机.
该如何计算才能得出正确结果?
8个字节计数器1的算法:(浮点数转十进制数)
例如:40/B0/0B/02/33/8B/26/96 ,如果要转换成十进制数,可按下列算法:(注:此处c(X)代表40H,此处c(X+1)代表B0H,依次类推)
符号位: si = ((c(X) And 128) / 128)
阶 码: extt = (c(X + 1) And &HF0) / 2 ^ 4 + (c(X) And &HF) * 2 ^ 4 + (c(X) And &H70) * 2 ^ 4 - 1023
尾 数: ma = (c(X + 1) And &HF) / 2 ^ 4 + c(X + 2) / 2 ^ 12 + c(X + 3) / 2 ^ 20 + c(X + 4) / 2 ^ 28 + c(X + 5) / 2 ^ 36 + c(X + 6) / 2 ^ 44 + c(X+7) / 2 ^ 52 + 1
所以所需求的量 vo = (-1) ^ si * 2 ^ (ex-127) * ma = 4107.36
则浮点数40/B0/0B/02/33/8B/26/96 代表的值为4107.36。