IEEE754浮点数转换

IEEE754规定如下的计算方法, 
   
  计算公式:   
  V=(-1)^s*2^E*M   
  当e(各位)为全'0'时,E=1-(2^(e(位数)-1)-1),;M=m。   
  如:real*4是8位,E=1-(2^(8-1)-1)=1-127=-126   
  即,   
  在real*4时:   
  V=(-1)^s*2^(-126)*m   
  在real*8时:   
  V=(-1)^s*2^(-1022)*m   
    
  当e(各位)不为全'0'且不为全'1'时,E=e(值)-(2^(e(位数)-1)-1);M=1+m。   
  即,   
  在real*4时:   
  V=(-1)^s*2^(e(值)-127)*(1+m)   
  在real*8时:   
  V=(-1)^s*2^(e(值)-1023)*(1+m)   
    
    
  三:将浮点格式转换成十进制数   
    
  [例3.1]:   
  0x00280000(real*4)   
  转换成二进制   
  00000000001010000000000000000000   
  符号位   指数部分(8位)   尾数部分   
  0   00000000   01010000000000000000000   
  符号位=0;因指数部分=0,则:尾数部分M为m:   
  0.01010000000000000000000=0.3125   
  该浮点数的十进制为:   
  (-1)^0*2^(-126)*0.3125   
  =3.6734198463196484624023016788195e-39   
    
    
  [例3.2]:   
  0xC04E000000000000(real*8)   
  转换成二进制   
  1100000001001110000000000000000000000000000000000000000000000000   
  符号位   指数部分(11位)   尾数部分   
  1   10000000100   1110000000000000000000000000000000000000000000000000   
  符号位=1;指数=1028,因指数部分不为全'0'且不为全'1',则:尾数部分M为1+m:   
  1.1110000000000000000000000000000000000000000000000000=1.875   
  该浮点数的十进制为:   
  (-1)^1*2^(1028-1023)*1.875   
  =-60   
    
    
  四:将十进制数转换成浮点格式(real*4)   
    
  [例4.1]:   
  26.0   
  十进制26.0转换成二进制   
  11010.0   
  规格化二进制数   
  1.10100*2^4   
  计算指数   
  4+127=131   
  符号位   指数部分   尾数部分   
  0   10000011   10100000000000000000000   
  以单精度(real*4)浮点格式存储该数   
  0100   0001   1101   0000   0000   0000   0000   0000   
  0x41D0   0000   
    
  [例4.2]:   
  0.75   
  十进制0.75转换成二进制   
  0.11   
  规格化二进制数   
  1.1*2^-1   
  计算指数   
  -1+127=126   
  符号位   指数部分   尾数部分   
  0   01111110   10000000000000000000000   
  以单精度(real*4)浮点格式存储该数   
  0011   1111   0100   0000   0000   0000   0000   0000   
  0x3F40   0000   
    
  [例4.3]:   
  -2.5   
  十进制-2.5转换成二进制   
  -10.1   
  规格化二进制数   
  -1.01*2^1   
  计算指数   
  1+127=128   
  符号位   指数部分   尾数部分   
  1   10000000   01000000000000000000000   
  以单精度(real*4)浮点格式存储该数   
  1100   0000   0010   0000   0000   0000   0000   0000   
  0xC020   0000   
例5
176.0652 
转换成二进制:10110000.0001 
规格化二进制数:1.01100000001*2^7 (小数点移了7位) 
计算指数:7+127=134 (127是个标准数值) 
符号位 指数部分(在本题中由134转换成8位二进制的指数) 尾数部分 
0 10000110 01100000001 000000000000 (不足32位,后面补0,直到补足32位) 

二进制结果:0100 0011 0011 0000 0001 0000 0000 0000 
十六进制结果:0x43301000 


32位(0到31bit)分配: 
符号位在最高位,[31bit], 
指数位[30-23] 

尾数位[22-0] 


http://home.51.com/tom361/diary/item/10016262.html

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答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这两个函数,可以轻松地完成浮点数转换,而通过更复杂的函数,还可以进行精度更高的运算。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值