JavaScript 打包整数并计算任意精度浮点数:

2023-12-07

我需要在 JavaScript 中执行以下操作,但到目前为止无法找到无缝执行此操作的解决方案:

  • 按特定顺序获取两个整数并将它们像 Python 的 struct 模块一样打包。
  • 这个打包值(支持与主机不同的字节序的好处)将被转换为 64 位浮点(双精度)。它们必须是任意的,因此我可能会得到整数的指数表示(例如,它们可能是 0xdeadbeef 和 500):

    表达式形式: 1.0883076389305e-311 1.0883076389305000 * 10 ^ - 311

  • 我需要将其转换为任意精度、非指数形式,因此:

    0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 0000000000000000000000000000000000000000000000000000000000000000000010883076389305000000000000000000000000000000000000000000 00000000000000000000000000000000000

  • 该数字转换为字符串:)

我还没有找到在 Javascript 中执行此操作的方法,并且我必须输出一些必须支持任意精度的数字,或者至少支持双精度数的 1024 指数(或者说 400)。

Thanks!!

注意:我确实需要“打包/解包”来忠实地表示转换为双精度/64 位浮点数的这两个数字。但我不关心导出到字符串或原始缓冲区。只要我获得双精度的任意精度双精度表示,这一切都很好。


1:Khronos 有一个规范正在进行中 for a DataView作为 WebGL 一部分的界面TypedArray要求,结合Int32Array and Float64Array可以让你将两个 int 写入缓冲区,然后将它们作为 double 读回。

不幸的是,浏览器对此的支持还不常见 - 测试您的浏览器访问http://html5test.com/并查看标题为“本机二进制数据”的部分。

如果没有TypedArray上面的支持我认为没有任何方法可以使用位旋转来做到这一点,因为 Javascript 的位运算符将数字视为 32 位无符号值,因此您无法访问高阶位。

2: double变量没有任何特定的形式,IEE754 只是一种内部表示。

3: that's您可以尝试显示实际精度的点。不幸的是内置方法,例如Number.toFixed(),不支持显示超过20位小数。您将需要解析指数形式并手动构造一个具有适当数量的前导零的字符串。

注意 - 双精度数的指数范围是 2^1024,而不是 10^1024,因此真正的限制实际上是 ~1.0E±308 - 您的示例数字小于该范围。

EDIT实际上,可能有一种方法,但我不能保证其精度:

  1. 取两个整数,调用它们hi and lo.
  2. 提取指数 -exp = (hi >> 20) & 0x7ff
  3. 提取符号 -sign = (hi >> 31)
  4. 提取尾数 -((hi & 0xfffff) * Math.pow(2, 32) + lo) / Math.pow(2, 52)
  5. result = (1 + m) * (Math.pow(2.0, exp - 1023))
  6. if (sign) result *= -1

EDIT 2- 有用!看http://jsfiddle.net/alnitak/assXS/

var hex2double = function(input) {

    var hi = parseInt(input.substring(0, 8), 16);
    var lo = parseInt(input.substring(8   ), 16);

    var p32 = 0x100000000;
    var p52 = 0x10000000000000;

    var exp = (hi >> 20) & 0x7ff;
    var sign = (hi >> 31);
    var m = 1 + ((hi & 0xfffff) * p32 + lo) / p52;
    m = exp ? (m + 1) : (m * 2.0);

    return (sign ? -1 : 1) * m * Math.pow(2, exp - 1023);
};

输入一个浮点数http://babbage.cs.qc.edu/IEEE-754/Decimal.html,从输出的底行获取生成的十六进制字符串,并将其传递给上面的函数。您应该看到包含原始值的警报。

EDIT 3固定代码以考虑指数位全为零时的特殊情况。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

JavaScript 打包整数并计算任意精度浮点数: 的相关文章

随机推荐

  • raw vs. html_safe vs. h 来取消转义 html

    假设我有以下字符串 x a href Turn me into a link a 在我看来 我希望显示一个链接 也就是说 我不希望 x 中的所有内容都未转义并显示为字符串 使用有什么区别 考虑 Rails 3 html safe实际上 将字
  • 如何在 Perl 中处理具有依赖关系的调度线程?

    我有以下场景 sub 1 can run immediately sub 2 can run immediately sub 3 can run only after sub 1 finishes sub 4 can run only af
  • JSONStore searchFields 中“数字”和“整数”之间的差异

    我有关于 JSONStore searchFields 的问题 如果我使用number作为 searchFields 键并尝试通过以下方式查找数据WL JSONStore find方法与0作为查询 它将命中所有数据 未过滤 随着intege
  • GPU 上的 Tensorflow matmul 计算比 CPU 上慢

    我是第一次尝试 GPU 计算 当然希望能有很大的加速 然而 对于张量流中的基本示例 情况实际上更糟 在 cpu 0 上 十次运行中的每一次平均需要 2 秒 gpu 0 需要 2 7 秒 gpu 1 比 cpu 0 差 50 需要 3 秒 这
  • 缺少 mbstring 扩展名。请检查您的 PHP 配置

    phpMyAdmin 错误 缺少 mbstring 扩展名 请检查您的 PHP 配置 我已经尝试过所有解决方案 但没有一个对我有用 我不知道还能做什么 我见过这个问题 当我从 15 10 升级到 16 04 或安装 16 04 时 会出现此
  • Safari 5 扩展:如何检测窗口的当前选项卡何时发生更改?

    我有一个包含工具栏的 Safari 5 扩展 每当当前选项卡发生更改时 该工具栏都应该更新 我想从我的酒吧脚本中做这样的事情 safari self browserWindow addEventListener activeTab tabC
  • x86 NASM 程序集 - 输入问题

    我正在努力从用户那里获取两次输入 并比较输入 如果它们相同 则程序退出 如果没有 它会重新打印第一次输入的内容 并等待用户输入内容 如果相同 则发生与之前相同的情况 如果没有 就会发生与之前相同的情况 输入和循环不是问题 主要问题是我从程序
  • R 中的大幂

    我正在尝试计算 2 1000 并对数字的值求和 出于所有意图和目的 它seems就像我有正确的方法但错误的答案 我不确定是否有特殊的方法来进行求和 或者我的选择可能是混乱的 无论如何 R 中的 2 1000 给出 1 072e 301 我用
  • 如何在matlab中创建留一交叉验证? [复制]

    这个问题在这里已经有答案了 我仍然对我的代码感到困惑 我尝试在 matlab 中实现留一交叉验证进行分类 所以在这里 我从训练中取出一个数据作为测试数据 我已经在matlab中编写了代码 但我不确定它是否正确 因为结果是错误的 有人可以帮我
  • 无论如何,是否可以在数据流管道中共享状态变量?

    我正在用 python 制作数据流管道 我想跨管道转换和跨工作节点共享全局变量 例如全局变量 跨多个工作人员 有什么办法可以支持这个吗 提前感谢 有状态处理可用于在特定节点的工作人员之间共享状态 但无法在转换之间共享 https beam
  • Azure 角色本地存储是否保证下一个使用同一主机的应用程序无法访问?

    假设我的 Azure 角色将文件存储到角色本地文件系统并忘记删除它们 将来使用该主机的另一个应用程序是否可以访问这些文件 我读了白皮书它充满了营销风格的陈述 但我找不到关于在新角色开始之前主机 清理 得有多彻底的明确陈述 我能否完全确定另一
  • 在 Swift 3 Playground 中读取 plist

    我在这里关注了很多问题 但似乎没有任何效果 我在用Swift3 in a Playground 在 El Capitan 和 Xcode 8 1 上运行 我有一个plist以根作为Dictionary包含一个 Int 值和两个 2D Int
  • wxPython 网格中的自动换行和换行符

    我想用具有以下行为的单元格实现一个网格 如果单元格文本不适合单元格 则应将其换行 单元格文本中的换行符 n 也应该被处理 即 当您为单元格启用 换行 选项时 与 MS Excel OO Calc 等表格编辑器中的行为相同 我尝试按如下方式执
  • 如何修剪传递 select 查询的 in 子句的值

    下面是使用 in 条件选择记录的简单 SQL 查询 like this I have 6000 usernames select from tblUsers where Username in abc xyz pqr mnop 我知道有LT
  • 膨胀类 android.support.design.widget.TabLayout 时出错

    我正在尝试使用 Eclipse 创建一个基于 Google 的 材料设计 的菜单选项卡 但出现错误 01 07 01 02 10 238 E tag 6696 contact on create called 01 07 01 02 10
  • Microsoft Solver Foundation 对一个简单的 ILP 给出了错误的答案

    我想使用 Microsoft Solver Foundation 解决 C 中的二元线性问题 我不知道为什么我得到了错误的答案 目标值应该是 41 1 但我得到 213 5 个变量的值应该是 1 其他变量应该是 0 但是我得到了很多错误值的
  • 在 symfony 中获取服务内的路由名称

    伙计们 我有一个服务 其中有一个接受路由器服务的构造函数 我的问题是如何知道当前的路线名称 这是我的服务 class Navigation protected modules protected router public function
  • 为长度为 1 的位域赋值

    假设我有 struct A signed char a 1 unsigned char b 1 如果我有 A two three two a 2 two b 2 three a 3 three b 3 two将包含0s 在它的领域 而thr
  • 如何使用@PathVariable配置spring-data-rest搜索方法路径

    我想通过将参数作为路径变量传递来自定义 spring data rest 搜索方法路径 如下所示 http localhost 8080 orders search customers customerId findByCustomer P
  • JavaScript 打包整数并计算任意精度浮点数:

    我需要在 JavaScript 中执行以下操作 但到目前为止无法找到无缝执行此操作的解决方案 按特定顺序获取两个整数并将它们像 Python 的 struct 模块一样打包 这个打包值 支持与主机不同的字节序的好处 将被转换为 64 位浮点