将带符号的IEEE 754浮点数转换为十六进制表示形式

用户名

我正在使用Lua的前端,不幸的是它已经过时了,所以我在这里停留在5.1版,这意味着该bit32遥不可及(我可能可以用来转换它)。

因此,我想知道是否有人知道我可以实现将浮点数转换为二进制(数字)功能,或者更好地将浮点数转换为十六进制的方法。到目前为止,我能提出的最好的办法是将十进制转换为二进制/十六进制函数...

用户名

以下函数使用FrançoisPerrad的一些代码lua-MessagePack非常感谢您。

function float2hex (n)
    if n == 0.0 then return 0.0 end

    local sign = 0
    if n < 0.0 then
        sign = 0x80
        n = -n
    end

    local mant, expo = math.frexp(n)
    local hext = {}

    if mant ~= mant then
        hext[#hext+1] = string.char(0xFF, 0x88, 0x00, 0x00)

    elseif mant == math.huge or expo > 0x80 then
        if sign == 0 then
            hext[#hext+1] = string.char(0x7F, 0x80, 0x00, 0x00)
        else
            hext[#hext+1] = string.char(0xFF, 0x80, 0x00, 0x00)
        end

    elseif (mant == 0.0 and expo == 0) or expo < -0x7E then
        hext[#hext+1] = string.char(sign, 0x00, 0x00, 0x00)

    else
        expo = expo + 0x7E
        mant = (mant * 2.0 - 1.0) * math.ldexp(0.5, 24)
        hext[#hext+1] = string.char(sign + math.floor(expo / 0x2),
                                    (expo % 0x2) * 0x80 + math.floor(mant / 0x10000),
                                    math.floor(mant / 0x100) % 0x100,
                                    mant % 0x100)
    end

    return tonumber(string.gsub(table.concat(hext),"(.)",
                                function (c) return string.format("%02X%s",string.byte(c),"") end), 16)
end


function hex2float (c)
    if c == 0 then return 0.0 end
    local c = string.gsub(string.format("%X", c),"(..)",function (x) return string.char(tonumber(x, 16)) end)
    local b1,b2,b3,b4 = string.byte(c, 1, 4)
    local sign = b1 > 0x7F
    local expo = (b1 % 0x80) * 0x2 + math.floor(b2 / 0x80)
    local mant = ((b2 % 0x80) * 0x100 + b3) * 0x100 + b4

    if sign then
        sign = -1
    else
        sign = 1
    end

    local n

    if mant == 0 and expo == 0 then
        n = sign * 0.0
    elseif expo == 0xFF then
        if mant == 0 then
            n = sign * math.huge
        else
            n = 0.0/0.0
        end
    else
        n = sign * math.ldexp(1.0 + mant / 0x800000, expo - 0x7F)
    end

    return n
end

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

Powershell-符合IEEE754单精度浮点数的十六进制

来自分类Dev

将带符号的Int转换为带空格的十六进制字符串

来自分类Dev

Java:将带符号的Int_32(十六进制)转换为Int

来自分类Dev

Python-将带符号的浮点数转换为无符号的长整数(Win32为DWORD)

来自分类Dev

如何将带符号的十进制转换为十六进制的24位二进制补码带符号数

来自分类Dev

将带符号的货币转换为十进制

来自分类Dev

将带符号的货币转换为十进制

来自分类Dev

Python程序以单精度将十六进制转换为IEEE-754浮点

来自分类Dev

将 HEX 转换为 IEEE 754 浮点数

来自分类Dev

将带符号的整数转换为带符号的无壳脚本

来自分类Dev

将带符号的char转换为C中的unsigned int

来自分类Dev

将带符号的char转换为C中的unsigned int

来自分类Dev

将十六进制转换为IEEE-754单精度浮点二进制科学计数法

来自分类Dev

将十六进制转换为带符号的Dec

来自分类Dev

将十六进制数字转换为带符号的short

来自分类Dev

将十六进制数字转换为带符号的short

来自分类Dev

java相当于php“fnum”解包函数在java中将十六进制转换为浮点IEEE 754

来自分类Dev

在 .net 中将二进制 32 位 IEEE-754 浮点数转换为 Double

来自分类Dev

将带符号的10位二进制数字转换为十进制?

来自分类Dev

为什么将带符号的负数转换为无符号的数?

来自分类Dev

十六进制浮点 IEEE 754 双精度 C++

来自分类Dev

将带符号的单精度浮点数舍入到最接近的整数的有效方法是什么?

来自分类Dev

比较带符号的十六进制数字

来自分类Dev

如何在C中将浮点数转换为16位带符号整数部分?

来自分类Dev

将数字从Excel单元格转换为IEEE 754十六进制格式

来自分类Dev

为什么这里没有将带符号的char转换为unsigned int?

来自分类Dev

将浮点数转换为十六进制格式

来自分类Dev

在C ++中将带符号的整数值转换为可排序的,无符号的标准兼容方法是什么?

来自分类Dev

如果可以用IEEE 754中的二进制格式表示的硬代码浮点数是否精确?

Related 相关文章

  1. 1

    Powershell-符合IEEE754单精度浮点数的十六进制

  2. 2

    将带符号的Int转换为带空格的十六进制字符串

  3. 3

    Java:将带符号的Int_32(十六进制)转换为Int

  4. 4

    Python-将带符号的浮点数转换为无符号的长整数(Win32为DWORD)

  5. 5

    如何将带符号的十进制转换为十六进制的24位二进制补码带符号数

  6. 6

    将带符号的货币转换为十进制

  7. 7

    将带符号的货币转换为十进制

  8. 8

    Python程序以单精度将十六进制转换为IEEE-754浮点

  9. 9

    将 HEX 转换为 IEEE 754 浮点数

  10. 10

    将带符号的整数转换为带符号的无壳脚本

  11. 11

    将带符号的char转换为C中的unsigned int

  12. 12

    将带符号的char转换为C中的unsigned int

  13. 13

    将十六进制转换为IEEE-754单精度浮点二进制科学计数法

  14. 14

    将十六进制转换为带符号的Dec

  15. 15

    将十六进制数字转换为带符号的short

  16. 16

    将十六进制数字转换为带符号的short

  17. 17

    java相当于php“fnum”解包函数在java中将十六进制转换为浮点IEEE 754

  18. 18

    在 .net 中将二进制 32 位 IEEE-754 浮点数转换为 Double

  19. 19

    将带符号的10位二进制数字转换为十进制?

  20. 20

    为什么将带符号的负数转换为无符号的数?

  21. 21

    十六进制浮点 IEEE 754 双精度 C++

  22. 22

    将带符号的单精度浮点数舍入到最接近的整数的有效方法是什么?

  23. 23

    比较带符号的十六进制数字

  24. 24

    如何在C中将浮点数转换为16位带符号整数部分?

  25. 25

    将数字从Excel单元格转换为IEEE 754十六进制格式

  26. 26

    为什么这里没有将带符号的char转换为unsigned int?

  27. 27

    将浮点数转换为十六进制格式

  28. 28

    在C ++中将带符号的整数值转换为可排序的,无符号的标准兼容方法是什么?

  29. 29

    如果可以用IEEE 754中的二进制格式表示的硬代码浮点数是否精确?

热门标签

归档