64位浮点数_IEEE754标准浮点数转换

IEEE754标准是一种浮点数表示标准,一般分为单、双精度两种,也即32位的二进制数和64位的二进制数。根据国际标准IEEE754,任意一个二进制浮点数V可以表示为下面形式:

V = (-1)^s *(1+M)* 2^(E-127)(单精度)

V = (-1)^s *(1+M)* 2^(E-1023)(双精度)

一个浮点数的组成分为三个部分(以单精度为例):最高位是符号位s(0正,1负),2-9位为阶码位E(双精度为2-12位),剩下的为有效数字M。

其中1<= M <2 ,即M写成1.xxxxx形式。IEEE 754规定,计算机内部保存M它的第一位总是1,因此可以只保存后面的xxxxxx部分。如1.001时,尾数001,需要读取时,再把第一位的1加上去。这样做可以节省1位有效数字。以32位浮点数为例,留给M只有23位,将第一位的1舍去以后,等于可以保存24位有效数字。

E为一个无符号整数(unsigned int),如果E为8位,其取值范围为0~255;若E为11位,取值范围为0~2047。而科学计数法中的E是可以出现负数的,所以IEEE 754规定,E的真实值必须再减去一个中间数,对于8位的E,这个中间数是127;对于11位的E,这个中间数是1023。比如,2^10的E是10,所以保存成32位浮点数时,必须保存成10+127=137,即10001001。

其中E还分三种情况:

1)E不全为0或1时,浮点数就采用上面的规则表示,即指数E的计算值减去127(或1023),得到真实值,再将有效数字M前加上第一位的1。

2)E全为0时,浮点数的指数E等于1-127(或者1-1023),有效数字M不再加上第一位的1,而是还原为0.xxxxxx的小数。这样做是为了表示±0,以及接近于0的很小的数字。

3)E全为1时,如果有效数字M全为0,表示±无穷大(正负取决于符号位s);如果有效数字M不全为0,表示这个数不是一个数(NaN)。

v2-13cb45d9d0f4b03feb36831f6a72fc8d_b.jpg

下面我们以上图的十进制0.15625转换为浮点数二进制表示为例子展开说明:

第一步,十进制换算为二进制有:DEC 0.15625 = BIN 0.00101 ,换算步骤如下:

0.15625x2=0.3125 取整0 0.31250x2=0.6250 取整0

0.62500x2=1.2500 取整1, 0.25000x2=0.5000 取整0

0.50000x2=1.0000 取整1,结束,依次把得到的组合在小数点后得到:0.00101

(验证:0*2-1 + 0*2-2 + 1*2-3 + 0*2-4 + 1*2-5 = 0.15625 ,换算正确)

第二步,用国际标准IEEE754表示换算好的二进制数:

0.00101表示为:1.01 * 2 -3 由公式:V= (-1)^s *(1+M)* 2^(E-127)(单精度)可得出:

S = 0 ,M = 1.01 -1 = 0.01 ,E = 127 -3 = EDC 124 = BIN 0111 1100

第三步,列出浮点数二进制表示式:

则有:0011 1110 0010 0000 0000 0000 0000 0000 ,和上图的表示一致,结果正确。

附上两个小例子:

例1:

BIN 1101101.1,写成以上形式有:1.1011011*2^6,对应上式得出:S = 0,M = 0.1011011,

E =DEC (127 + 6 )= DEC 133 = BIN 1000 0101,DEC表示十进制,BIN表示二进制

则单精度浮点数表示为:0100 0010 1101 1011 0000 0000 0000 0000

例2:

DEC -0.0625 = BIN -0.0001 = -1.0*2-4 s=1,M=1-1=0,E=-4 +127=123=0111 1011

单精度:1011 1101 1000 0000 0000 0000 0000 0000 (S E M顺序)

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: IEEE 754点数是一种可表示实数的标准格式,在计算机科学中被广泛使用。LabVIEW作为一种高级程序设计语言,也支持IEEE 754点数转换。 在LabVIEW中,将点数转换为IEEE 754格式可以通过使用“Type Cast”或“Flatten to String”函数来实现。Type Cast函数可以将任何数据类型转换为另一个数据类型,而Flatten to String函数则将任何数据类型转换为字符串格式。 另外,在LabVIEW中还可以使用“IEEE Floating Point”面板对象来表示IEEE 754点数。这个对象有多种不同的显示格式,可以根据实际需要选择。 同时,也可以使用“Unflatten from String”函数将字符串格式的IEEE 754点数转换为实数。这个函数与“Flatten to String”函数相对应,可以将任何字符串转换为指定数据类型的数据。 总之,通过上述方法,在LabVIEW中可以方便地进行IEEE 754点数转换和表示,方便实现各种复杂的计算任务。 ### 回答2: IEEE754点数是现代计算机系统中广泛使用的一种二进制数表示方法,用于表示实数。在LabVIEW中,通过使用数字数据类型的标签来指定点数据是单精度点数还是双精度点数。 为将点数转换为IEEE754点数,需要将点数的符号、阶码和尾数转换成对应的二进制格式。在单精度点数中,符号位占1位,阶码占8位,尾数占23位,而在双精度点数中,符号位占1位,阶码占11位,尾数占52位。在进行点数转换时,需要注意计算机中点数的字节序,以正确存储转换后的IEEE754点数。 为了在LabVIEW中完成点数转换,可以使用“单精度点数转换”或“双精度点数转换”函数。这些函数可以将点数转换为IEEE754点数,并将结果存储在指定的输出变量中。此外,在LabVIEW中也可以使用“数字到字符串”函数,将点数转换为字符串格式,方便输出或显示。 需要注意的是,由于点数的精度限制,在进行点数计算时可能会出现舍入误差,这些误差可能会影响计算结果的精度和准确性。因此,在LabVIEW中进行点数计算时,需要注意点精度问题,并尽可能采用正确的计算方法来避免误差积累的影响。 ### 回答3: IEEE 754点数是一种二进制数的表示方式,用于表示实数。这种表示方式包括三个部分:符号位、指数位和尾数位。 在LabVIEW中,可以使用Float to Hex和Hex to Float这两个函数进行IEEE 754点数转换。Float to Hex函数将一个点数转换成其对应的16进制数,而Hex to Float函数将16进制数转换成对应的点数。 在进行转换时,需要注意保留位数的问题。IEEE 754点数中有单精度点数和双精度点数,其精度分别为32位(4字节)和64位(8字节)。在LabVIEW中,Float to Hex函数默认输出8位16进制数,而Hex to Float函数默认输入8位16进制数。如果需要更多的位数精度,可以在函数的属性中进行相应的设置。 除了转换函数外,LabVIEW中还提供了计算IEEE 754点数的函数,如Get Single Precision Float Info和Get Double Precision Float Info。这些函数可以获取点数的符号位、指数位和尾数位等信息,方便进行更复杂的运算。 总之,IEEE 754点数转换在LabVIEW中非常方便快捷。使用Float to Hex和Hex to Float这两个函数,可以轻松地完成点数转换,而通过更复杂的函数,还可以进行精度更高的运算。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值