课程表

CoffeeScript 语法

CoffeeScript 类和对象

CoffeeScript 字符串

CoffeeScript 数组

CoffeeScript 日期和时间

CoffeeScript 数学

CoffeeScript 方法

CoffeeScript 元编程

CoffeeScript jQuery

CoffeeScript 正则表达式

CoffeeScript 网络

CoffeeScript 设计模式

CoffeeScript 数据库

CoffeeScript 测试

工具箱
速查手册

平方根倒数快速算法

当前位置:免费教程 » JS/JS库/框架 » CoffeeScript

问题

你想快速计算某数的平方根倒数。

解决方案

在 Quake Ⅲ Arena 的源代码中,这个奇怪的算法对一个幻数进行整数运算,来计算平方根倒数的浮点近似值。

在 CoffeeScript 中,他使用经典原始的变量,以及由 Chris Lomont 发现的新的最优 32 位幻数。除此之外,还使用 64 位大小的幻数。

另一特征是可以通过控制牛顿迭代法的迭代次数来改变其精确度。

相比于传统的,该算法在性能上更胜一筹,这归功于使用的机器及其精确度。

运行的时候使用 coffee -c script.coffee 来编译 script:

然后复制粘贴编译的 JS 代码到浏览器的 JavaScript 控制台。

注意:你需要一个支持类型数组的浏览器

参考:

  1. ftp://ftp.idsoftware.com/idstuff/source/quake3-1.32b-source.zip
  2. http://www.lomont.org/Math/Papers/2003/InvSqrt.pdf
  3. http://en.wikipedia.org/wiki/Newton%27s_method
  4. https://developer.mozilla.org/en/JavaScripttypedarrays
  5. http://en.wikipedia.org/wiki/Fastinversesquare_root

以下的代码来源于:https://gist.github.com/1036533

  1. ###
  2. Author: Jason Giedymin <jasong _a_t_ apache -dot- org>
  3. http://www.jasongiedymin.com
  4. https://github.com/JasonGiedymin
  5. Quake Arena 的源代码 [1](ftp://ftp.idsoftware.com/idstuff/source/quake3-1.32b-source.zip) 中,这个奇怪的算法对一个幻数进行整数运算,来计算平方根倒数的浮点近似值 [5](http://en.wikipedia.org/wiki/Fast_inverse_square_root)。
  6. CoffeeScript 中,我使用经典原始的变量,以及由 Chris Lomont [2](http://www.lomont.org/Math/Papers/2003/InvSqrt.pdf) 发现的新的最优 32 位幻数。除此之外,还使用 64 位大小的幻数。
  7. 另一特征是可以通过控制牛顿迭代法 [3](http://en.wikipedia.org/wiki/Newton%27s_method) 的迭代次数来改变其精确度。
  8. 相比于传统的,该算法在性能上更胜一筹,归功于使用的机器及其精确度。
  9. 运行的时候使用 coffee -c script.coffee 来编译 script
  10. 然后复制粘贴编译的 JS 代码到浏览器的 JavaScript 控制台。
  11. 注意:你需要一个支持类型数组 [4](https://developer.mozilla.org/en/JavaScript_typed_arrays) 的浏览器
  12. ###
  13. approx_const_quake_32 = 0x5f3759df # See [1]
  14. approx_const_32 = 0x5f375a86 # See [2]
  15. approx_const_64 = 0x5fe6eb50c7aa19f9 # See [2]
  16. fastInvSqrt_typed = (n, precision=1) ->
  17. # 使用类型数组。现在只能在浏览器中操作。
  18. # Node.JS 的版本即将推出。
  19. y = new Float32Array(1)
  20. i = new Int32Array(y.buffer)
  21. y[0] = n
  22. i[0] = 0x5f375a86 - (i[0] >> 1)
  23. for iter in [1...precision]
  24. y[0] = y[0] * (1.5 - ((n * 0.5) * y[0] * y[0]))
  25. return y[0]
  26. ### 单次运行示例
  27. testSingle = () ->
  28. example_n = 10
  29. console.log("Fast InvSqrt of 10, precision 1: #{fastInvSqrt_typed(example_n)}")
  30. console.log("Fast InvSqrt of 10, precision 5: #{fastInvSqrt_typed(example_n, 5)}")
  31. console.log("Fast InvSqrt of 10, precision 10: #{fastInvSqrt_typed(example_n, 10)}")
  32. console.log("Fast InvSqrt of 10, precision 20: #{fastInvSqrt_typed(example_n, 20)}")
  33. console.log("Classic of 10: #{1.0 / Math.sqrt(example_n)}")
  34. testSingle()
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号