1500中在进行取小数的时候发现命令的数据类型需要用LREAl

在使用数学函数命令FRAC的时候。取88.9的小数位时用的FRAC的数据类型是REAL,MD52上的数据不是0.9而是0.8999    如果变成了图片中的把FEAC的数据类型LREAL就成了0.9   这是为什么 ?实数不是32位的吗   我这个MD52不是正好是REAL吗为什么要用成LREAL?

图片说明:

1500中在进行取小数的时候发现命令的数据类型需要用LREAl   

最佳答案

这个的原因的根本原因是浮点数不能在计算机中精确存储。
可以看一下REAL的格式,如截图。
数字 = 1.m × 2 的(e – 偏差)次方
此处:
e:1 <=e <= 254
偏差:偏差 = 127。这意味着不需为指数附加符号。
S:对于正数,S = 0;对于讯数,S = 1。
实际上这种表示方法只能近似等于该浮点数,并不能精确等于。
我做了个实验看截图。比较发现MD33的后几位都是0。
我的猜想,由于REAL运算时精度的问题,有些位被省去了。
实际上MD40也不能真正的0.9,只是比MD30更接近罢了。
一般那情况下,两者都可以使用,精度要求较高的情况下,建议使用LREAL类型数据。

图片说明:

1500中在进行取小数的时候发现命令的数据类型需要用LREAl  1500中在进行取小数的时候发现命令的数据类型需要用LREAl  

提问者对于答案的评价:

原创文章,作者:more0621,如若转载,请注明出处:https://www.zhaoplc.com/plc145409.html

(1)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2017年6月3日 上午12:30
下一篇 2017年6月3日 上午12:30

相关推荐