将带符号的IEEE 754浮点数转换为十六进制表示。
2013-9-21 14:2:54
收藏:0
阅读:148
评论:3
我正在使用一个过时的Lua前端,因此我在这里被困在5.1版本上,这意味着bit32库无法使用(我可能本可以使用它来进行转换)。
因此,我想知道是否有人知道我可以实现浮点数转二进制(数字)函数或更好的浮点数转十六进制的方法。到目前为止,我能想到的最好方法是一个十进制转二进制/十六进制函数...
点赞
用户8150685
在上面的示例中,float2hex返回一个整数。话虽如此,如果有人需要,这里有一个intToHex转换函数,可以在lua档案中找到(http://lua-users.org/lists/lua-l/2004-09/msg00054.html)。我使用了上面的float2hex函数的返回值,并将其输入到此函数中。intToHex的输出是一个字符串(例如:0xA4CD)。
function intToHex(IN)
local B,K,OUT,I,D=16,"0123456789ABCDEF","",0
while IN>0 do
I=I+1
IN,D=math.floor(IN/B),math.mod(IN,B)+1
OUT=string.sub(K,D,D)..OUT
end
OUT = "0x" .. OUT
return OUT
end
2017-06-16 14:08:16
用户7370623
我面临的问题是试图将十六进制转换为浮点数;你可以使用tonumber(x, 16)与"Error - Syntactical Remorse"的回应相结合进行转换。string.sub只存在是因为我的Modbus驱动程序不会交换字节 :)
function convertFloatSwapWord(number) -- number是格式为0x########的字符串
local x = 0
x = float2hex(number)
x = intToHex(x)
x = string.sub(x,5,6) .. string.sub(x,3,4) .. string.sub(x,9,10) .. string.sub(x,7,8)
x = hex2float(tonumber(x, 16))
return x
end
2018-03-12 19:26:39
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
下面的函数使用了一些来自François Perrad的
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