如何把双精度浮点数转换成单精度浮点数?

已锁定

Ozone

  • 帖子

    5
  • 精华

    0
  • 被关注

    0

论坛等级:新手

注册时间:2008-01-21

普通 普通 如何晋级?

如何把双精度浮点数转换成单精度浮点数?

1772

1

2008-08-29 08:27:42

科隆电磁流量计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。
如何把双精度浮点数转换成单精度浮点数? 已锁定
编辑推荐: 关闭

请填写推广理由:

本版热门话题

SIMATIC S7-300/400

共有54663条技术帖

相关推荐

热门标签

相关帖子推荐

guzhang

恭喜,你发布的帖子

评为精华帖!

快扫描右侧二维码晒一晒吧!

再发帖或跟帖交流2条,就能晋升VIP啦!开启更多专属权限!

  • 分享

  • 只看
    楼主

top
X 图片
您收到0封站内信:
×
×
信息提示
很抱歉!您所访问的页面不存在,或网址发生了变化,请稍后再试。