long-decimal 0.01.02 → 0.01.03

Sign up to get free protection for your applications and to get access to all the features.
Files changed (262) hide show
  1. data/README +58 -33
  2. data/Rakefile +1 -1
  3. data/VERSION +1 -1
  4. data/lib/long-decimal-extra.rb +378 -0
  5. data/lib/long-decimal.rb +277 -342
  6. data/test/testlongdecimal-extra.rb +645 -0
  7. data/test/testlongdecimal.rb +4 -605
  8. data/test/testlongdeclib.rb +4 -4
  9. data/test/testrandlib.rb +1 -1
  10. data/test/testrandom-extra.rb +76 -0
  11. data/test/testrandom.rb +4 -7
  12. data/test/testrandpower.rb +7 -4
  13. data/version.rb +1 -1
  14. metadata +5 -268
  15. data/doc/classes/Integer.html +0 -239
  16. data/doc/classes/Integer.src/M000036.html +0 -18
  17. data/doc/classes/Integer.src/M000039.html +0 -145
  18. data/doc/classes/LongDecimal.html +0 -1602
  19. data/doc/classes/LongDecimal.src/M000034.html +0 -18
  20. data/doc/classes/LongDecimal.src/M000035.html +0 -18
  21. data/doc/classes/LongDecimal.src/M000036.html +0 -18
  22. data/doc/classes/LongDecimal.src/M000037.html +0 -18
  23. data/doc/classes/LongDecimal.src/M000038.html +0 -18
  24. data/doc/classes/LongDecimal.src/M000039.html +0 -18
  25. data/doc/classes/LongDecimal.src/M000040.html +0 -18
  26. data/doc/classes/LongDecimal.src/M000041.html +0 -18
  27. data/doc/classes/LongDecimal.src/M000042.html +0 -18
  28. data/doc/classes/LongDecimal.src/M000043.html +0 -18
  29. data/doc/classes/LongDecimal.src/M000044.html +0 -18
  30. data/doc/classes/LongDecimal.src/M000045.html +0 -18
  31. data/doc/classes/LongDecimal.src/M000046.html +0 -20
  32. data/doc/classes/LongDecimal.src/M000047.html +0 -120
  33. data/doc/classes/LongDecimal.src/M000048.html +0 -35
  34. data/doc/classes/LongDecimal.src/M000049.html +0 -25
  35. data/doc/classes/LongDecimal.src/M000050.html +0 -41
  36. data/doc/classes/LongDecimal.src/M000051.html +0 -48
  37. data/doc/classes/LongDecimal.src/M000052.html +0 -33
  38. data/doc/classes/LongDecimal.src/M000053.html +0 -18
  39. data/doc/classes/LongDecimal.src/M000054.html +0 -29
  40. data/doc/classes/LongDecimal.src/M000055.html +0 -61
  41. data/doc/classes/LongDecimal.src/M000056.html +0 -18
  42. data/doc/classes/LongDecimal.src/M000057.html +0 -22
  43. data/doc/classes/LongDecimal.src/M000058.html +0 -20
  44. data/doc/classes/LongDecimal.src/M000059.html +0 -18
  45. data/doc/classes/LongDecimal.src/M000060.html +0 -29
  46. data/doc/classes/LongDecimal.src/M000061.html +0 -21
  47. data/doc/classes/LongDecimal.src/M000062.html +0 -18
  48. data/doc/classes/LongDecimal.src/M000063.html +0 -29
  49. data/doc/classes/LongDecimal.src/M000064.html +0 -27
  50. data/doc/classes/LongDecimal.src/M000065.html +0 -18
  51. data/doc/classes/LongDecimal.src/M000066.html +0 -18
  52. data/doc/classes/LongDecimal.src/M000067.html +0 -18
  53. data/doc/classes/LongDecimal.src/M000068.html +0 -19
  54. data/doc/classes/LongDecimal.src/M000069.html +0 -19
  55. data/doc/classes/LongDecimal.src/M000070.html +0 -18
  56. data/doc/classes/LongDecimal.src/M000071.html +0 -18
  57. data/doc/classes/LongDecimal.src/M000072.html +0 -22
  58. data/doc/classes/LongDecimal.src/M000073.html +0 -23
  59. data/doc/classes/LongDecimal.src/M000074.html +0 -23
  60. data/doc/classes/LongDecimal.src/M000075.html +0 -23
  61. data/doc/classes/LongDecimal.src/M000076.html +0 -18
  62. data/doc/classes/LongDecimal.src/M000077.html +0 -33
  63. data/doc/classes/LongDecimal.src/M000078.html +0 -23
  64. data/doc/classes/LongDecimal.src/M000079.html +0 -23
  65. data/doc/classes/LongDecimal.src/M000080.html +0 -35
  66. data/doc/classes/LongDecimal.src/M000081.html +0 -22
  67. data/doc/classes/LongDecimal.src/M000082.html +0 -19
  68. data/doc/classes/LongDecimal.src/M000083.html +0 -23
  69. data/doc/classes/LongDecimal.src/M000084.html +0 -23
  70. data/doc/classes/LongDecimal.src/M000085.html +0 -23
  71. data/doc/classes/LongDecimal.src/M000086.html +0 -18
  72. data/doc/classes/LongDecimal.src/M000087.html +0 -21
  73. data/doc/classes/LongDecimal.src/M000088.html +0 -21
  74. data/doc/classes/LongDecimal.src/M000089.html +0 -18
  75. data/doc/classes/LongDecimal.src/M000090.html +0 -18
  76. data/doc/classes/LongDecimal.src/M000091.html +0 -23
  77. data/doc/classes/LongDecimal.src/M000092.html +0 -23
  78. data/doc/classes/LongDecimal.src/M000093.html +0 -19
  79. data/doc/classes/LongDecimal.src/M000094.html +0 -23
  80. data/doc/classes/LongDecimal.src/M000095.html +0 -18
  81. data/doc/classes/LongDecimal.src/M000096.html +0 -18
  82. data/doc/classes/LongDecimal.src/M000097.html +0 -18
  83. data/doc/classes/LongDecimal.src/M000098.html +0 -18
  84. data/doc/classes/LongDecimal.src/M000099.html +0 -73
  85. data/doc/classes/LongDecimal.src/M000100.html +0 -18
  86. data/doc/classes/LongDecimal.src/M000101.html +0 -18
  87. data/doc/classes/LongDecimal.src/M000102.html +0 -18
  88. data/doc/classes/LongDecimal.src/M000103.html +0 -18
  89. data/doc/classes/LongDecimal.src/M000104.html +0 -19
  90. data/doc/classes/LongDecimal.src/M000105.html +0 -19
  91. data/doc/classes/LongDecimal.src/M000106.html +0 -18
  92. data/doc/classes/LongDecimal.src/M000107.html +0 -18
  93. data/doc/classes/LongDecimal.src/M000108.html +0 -18
  94. data/doc/classes/LongDecimal.src/M000109.html +0 -18
  95. data/doc/classes/LongDecimalBase.html +0 -359
  96. data/doc/classes/LongDecimalBase.src/M000101.html +0 -18
  97. data/doc/classes/LongDecimalBase.src/M000102.html +0 -18
  98. data/doc/classes/LongDecimalBase.src/M000103.html +0 -18
  99. data/doc/classes/LongDecimalBase.src/M000104.html +0 -18
  100. data/doc/classes/LongDecimalBase.src/M000105.html +0 -18
  101. data/doc/classes/LongDecimalBase.src/M000106.html +0 -18
  102. data/doc/classes/LongDecimalBase.src/M000107.html +0 -18
  103. data/doc/classes/LongDecimalBase.src/M000108.html +0 -18
  104. data/doc/classes/LongDecimalBase.src/M000109.html +0 -18
  105. data/doc/classes/LongDecimalBase.src/M000110.html +0 -18
  106. data/doc/classes/LongDecimalBase.src/M000111.html +0 -18
  107. data/doc/classes/LongDecimalBase.src/M000112.html +0 -18
  108. data/doc/classes/LongDecimalBase.src/M000113.html +0 -18
  109. data/doc/classes/LongDecimalBase.src/M000114.html +0 -18
  110. data/doc/classes/LongDecimalBase.src/M000115.html +0 -18
  111. data/doc/classes/LongDecimalBase.src/M000116.html +0 -18
  112. data/doc/classes/LongDecimalBase.src/M000117.html +0 -18
  113. data/doc/classes/LongDecimalBase.src/M000118.html +0 -23
  114. data/doc/classes/LongDecimalBase.src/M000121.html +0 -23
  115. data/doc/classes/LongDecimalBase.src/M000122.html +0 -19
  116. data/doc/classes/LongDecimalBase.src/M000123.html +0 -18
  117. data/doc/classes/LongDecimalQuot.html +0 -836
  118. data/doc/classes/LongDecimalQuot.src/M000003.html +0 -18
  119. data/doc/classes/LongDecimalQuot.src/M000004.html +0 -46
  120. data/doc/classes/LongDecimalQuot.src/M000005.html +0 -18
  121. data/doc/classes/LongDecimalQuot.src/M000006.html +0 -18
  122. data/doc/classes/LongDecimalQuot.src/M000007.html +0 -20
  123. data/doc/classes/LongDecimalQuot.src/M000008.html +0 -19
  124. data/doc/classes/LongDecimalQuot.src/M000009.html +0 -18
  125. data/doc/classes/LongDecimalQuot.src/M000010.html +0 -18
  126. data/doc/classes/LongDecimalQuot.src/M000011.html +0 -18
  127. data/doc/classes/LongDecimalQuot.src/M000012.html +0 -18
  128. data/doc/classes/LongDecimalQuot.src/M000013.html +0 -32
  129. data/doc/classes/LongDecimalQuot.src/M000014.html +0 -19
  130. data/doc/classes/LongDecimalQuot.src/M000015.html +0 -19
  131. data/doc/classes/LongDecimalQuot.src/M000016.html +0 -22
  132. data/doc/classes/LongDecimalQuot.src/M000017.html +0 -23
  133. data/doc/classes/LongDecimalQuot.src/M000018.html +0 -23
  134. data/doc/classes/LongDecimalQuot.src/M000019.html +0 -23
  135. data/doc/classes/LongDecimalQuot.src/M000020.html +0 -23
  136. data/doc/classes/LongDecimalQuot.src/M000021.html +0 -35
  137. data/doc/classes/LongDecimalQuot.src/M000022.html +0 -22
  138. data/doc/classes/LongDecimalQuot.src/M000023.html +0 -19
  139. data/doc/classes/LongDecimalQuot.src/M000024.html +0 -18
  140. data/doc/classes/LongDecimalQuot.src/M000025.html +0 -127
  141. data/doc/classes/LongDecimalQuot.src/M000026.html +0 -52
  142. data/doc/classes/LongDecimalQuot.src/M000027.html +0 -18
  143. data/doc/classes/LongDecimalQuot.src/M000028.html +0 -18
  144. data/doc/classes/LongDecimalQuot.src/M000029.html +0 -18
  145. data/doc/classes/LongDecimalQuot.src/M000030.html +0 -18
  146. data/doc/classes/LongDecimalQuot.src/M000031.html +0 -18
  147. data/doc/classes/LongDecimalQuot.src/M000032.html +0 -18
  148. data/doc/classes/LongDecimalQuot.src/M000033.html +0 -18
  149. data/doc/classes/LongDecimalQuot.src/M000034.html +0 -18
  150. data/doc/classes/LongDecimalQuot.src/M000035.html +0 -18
  151. data/doc/classes/LongDecimalRoundingMode.html +0 -242
  152. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.html +0 -214
  153. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000135.html +0 -22
  154. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000137.html +0 -22
  155. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000138.html +0 -22
  156. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000141.html +0 -22
  157. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000142.html +0 -18
  158. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000146.html +0 -22
  159. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000147.html +0 -18
  160. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000148.html +0 -22
  161. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000149.html +0 -18
  162. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000150.html +0 -22
  163. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000151.html +0 -18
  164. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000152.html +0 -18
  165. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000156.html +0 -22
  166. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000157.html +0 -18
  167. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000158.html +0 -18
  168. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000159.html +0 -18
  169. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000161.html +0 -25
  170. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000162.html +0 -18
  171. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000163.html +0 -18
  172. data/doc/classes/LongDecimalRoundingMode/RoundingModeClass.src/M000164.html +0 -18
  173. data/doc/classes/LongDecimalRoundingMode/ZeroRoundingModeClass.html +0 -178
  174. data/doc/classes/LongDecimalRoundingMode/ZeroRoundingModeClass.src/M000165.html +0 -25
  175. data/doc/classes/LongDecimalRoundingMode/ZeroRoundingModeClass.src/M000166.html +0 -18
  176. data/doc/classes/LongMath.html +0 -911
  177. data/doc/classes/LongMath.src/M000112.html +0 -19
  178. data/doc/classes/LongMath.src/M000113.html +0 -19
  179. data/doc/classes/LongMath.src/M000114.html +0 -18
  180. data/doc/classes/LongMath.src/M000115.html +0 -19
  181. data/doc/classes/LongMath.src/M000116.html +0 -19
  182. data/doc/classes/LongMath.src/M000117.html +0 -18
  183. data/doc/classes/LongMath.src/M000118.html +0 -19
  184. data/doc/classes/LongMath.src/M000119.html +0 -19
  185. data/doc/classes/LongMath.src/M000120.html +0 -18
  186. data/doc/classes/LongMath.src/M000121.html +0 -18
  187. data/doc/classes/LongMath.src/M000122.html +0 -19
  188. data/doc/classes/LongMath.src/M000123.html +0 -18
  189. data/doc/classes/LongMath.src/M000124.html +0 -19
  190. data/doc/classes/LongMath.src/M000125.html +0 -18
  191. data/doc/classes/LongMath.src/M000126.html +0 -18
  192. data/doc/classes/LongMath.src/M000127.html +0 -19
  193. data/doc/classes/LongMath.src/M000128.html +0 -18
  194. data/doc/classes/LongMath.src/M000129.html +0 -32
  195. data/doc/classes/LongMath.src/M000130.html +0 -32
  196. data/doc/classes/LongMath.src/M000131.html +0 -19
  197. data/doc/classes/LongMath.src/M000132.html +0 -43
  198. data/doc/classes/LongMath.src/M000133.html +0 -19
  199. data/doc/classes/LongMath.src/M000134.html +0 -71
  200. data/doc/classes/LongMath.src/M000135.html +0 -35
  201. data/doc/classes/LongMath.src/M000136.html +0 -50
  202. data/doc/classes/LongMath.src/M000137.html +0 -20
  203. data/doc/classes/LongMath.src/M000138.html +0 -47
  204. data/doc/classes/LongMath.src/M000139.html +0 -65
  205. data/doc/classes/LongMath.src/M000140.html +0 -21
  206. data/doc/classes/LongMath.src/M000141.html +0 -18
  207. data/doc/classes/LongMath.src/M000142.html +0 -18
  208. data/doc/classes/LongMath.src/M000143.html +0 -87
  209. data/doc/classes/LongMath.src/M000144.html +0 -58
  210. data/doc/classes/LongMath.src/M000145.html +0 -18
  211. data/doc/classes/LongMath.src/M000146.html +0 -18
  212. data/doc/classes/LongMath.src/M000147.html +0 -20
  213. data/doc/classes/LongMath.src/M000148.html +0 -34
  214. data/doc/classes/LongMath.src/M000149.html +0 -33
  215. data/doc/classes/LongMath.src/M000150.html +0 -58
  216. data/doc/classes/LongMath.src/M000151.html +0 -406
  217. data/doc/classes/LongMath.src/M000152.html +0 -63
  218. data/doc/classes/LongMath.src/M000153.html +0 -117
  219. data/doc/classes/LongMath.src/M000154.html +0 -150
  220. data/doc/classes/LongMath.src/M000155.html +0 -63
  221. data/doc/classes/LongMath.src/M000156.html +0 -18
  222. data/doc/classes/LongMath.src/M000157.html +0 -19
  223. data/doc/classes/LongMath.src/M000158.html +0 -18
  224. data/doc/classes/LongMath.src/M000159.html +0 -19
  225. data/doc/classes/LongMath/CacheKey.html +0 -164
  226. data/doc/classes/LongMath/CacheKey.src/M000140.html +0 -36
  227. data/doc/classes/LongMath/CacheKey.src/M000145.html +0 -36
  228. data/doc/classes/LongMath/CacheKey.src/M000147.html +0 -36
  229. data/doc/classes/LongMath/CacheKey.src/M000149.html +0 -36
  230. data/doc/classes/LongMath/CacheKey.src/M000155.html +0 -36
  231. data/doc/classes/LongMath/CacheKey.src/M000160.html +0 -36
  232. data/doc/classes/Numeric.html +0 -177
  233. data/doc/classes/Numeric.src/M000100.html +0 -23
  234. data/doc/classes/Numeric.src/M000102.html +0 -23
  235. data/doc/classes/Numeric.src/M000103.html +0 -18
  236. data/doc/classes/Numeric.src/M000104.html +0 -23
  237. data/doc/classes/Numeric.src/M000105.html +0 -23
  238. data/doc/classes/Numeric.src/M000106.html +0 -18
  239. data/doc/classes/Numeric.src/M000110.html +0 -23
  240. data/doc/classes/Numeric.src/M000111.html +0 -18
  241. data/doc/classes/Rational.html +0 -161
  242. data/doc/classes/Rational.src/M000101.html +0 -23
  243. data/doc/classes/Rational.src/M000103.html +0 -23
  244. data/doc/classes/Rational.src/M000104.html +0 -23
  245. data/doc/classes/Rational.src/M000106.html +0 -23
  246. data/doc/classes/Rational.src/M000107.html +0 -23
  247. data/doc/classes/Rational.src/M000112.html +0 -23
  248. data/doc/created.rid +0 -1
  249. data/doc/dot/f_0.dot +0 -166
  250. data/doc/dot/f_0.png +0 -0
  251. data/doc/dot/m_0_0.dot +0 -59
  252. data/doc/dot/m_0_0.png +0 -0
  253. data/doc/dot/m_0_1.dot +0 -62
  254. data/doc/dot/m_0_1.png +0 -0
  255. data/doc/files/lib/long-decimal_rb.html +0 -191
  256. data/doc/files/lib/long-decimal_rb.src/M000001.html +0 -22
  257. data/doc/files/lib/long-decimal_rb.src/M000002.html +0 -18
  258. data/doc/fr_class_index.html +0 -37
  259. data/doc/fr_file_index.html +0 -27
  260. data/doc/fr_method_index.html +0 -192
  261. data/doc/index.html +0 -24
  262. data/doc/rdoc-style.css +0 -208
@@ -1,58 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>exp_raw (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 2799</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">exp_raw</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">j</span>, <span class="ruby-identifier">k</span>, <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
15
- <span class="ruby-comment cmt"># dprec = [ (iprec*0.9).round , (prec + 1) &lt;&lt; 1 ].min</span>
16
- <span class="ruby-identifier">dprec</span> = [ (<span class="ruby-identifier">iprec</span><span class="ruby-operator">*</span><span class="ruby-value">0</span><span class="ruby-value">.9</span>).<span class="ruby-identifier">round</span>, <span class="ruby-identifier">prec</span> ].<span class="ruby-identifier">max</span>
17
- <span class="ruby-comment cmt"># puts(&quot;prec=#{prec} dprec=#{dprec} iprec=#{iprec}&quot;)</span>
18
-
19
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>)
20
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
21
- <span class="ruby-keyword kw">end</span>
22
-
23
- <span class="ruby-identifier">x_k</span> = (<span class="ruby-identifier">x</span> <span class="ruby-operator">/</span> (<span class="ruby-value">1</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">k</span>)).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
24
- <span class="ruby-identifier">x_j</span> = (<span class="ruby-identifier">x_k</span> <span class="ruby-operator">**</span> <span class="ruby-identifier">j</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
25
- <span class="ruby-identifier">s</span> = [ <span class="ruby-constant">LongDecimal</span>(<span class="ruby-value">0</span>) ] <span class="ruby-operator">*</span> <span class="ruby-identifier">j</span>
26
- <span class="ruby-identifier">t</span> = <span class="ruby-constant">LongDecimal</span>(<span class="ruby-value">1</span>)
27
- <span class="ruby-identifier">last_t</span> = <span class="ruby-value">1</span>
28
- <span class="ruby-identifier">f</span> = <span class="ruby-value">0</span>
29
- <span class="ruby-identifier">loop</span> <span class="ruby-keyword kw">do</span>
30
- <span class="ruby-identifier">j</span>.<span class="ruby-identifier">times</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">i</span><span class="ruby-operator">|</span>
31
- <span class="ruby-identifier">s</span>[<span class="ruby-identifier">i</span>] <span class="ruby-operator">+=</span> <span class="ruby-identifier">t</span>
32
- <span class="ruby-identifier">f</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span>
33
- <span class="ruby-identifier">t</span> = (<span class="ruby-identifier">t</span> <span class="ruby-operator">/</span> <span class="ruby-identifier">f</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
34
- <span class="ruby-keyword kw">end</span>
35
- <span class="ruby-identifier">t</span> = (<span class="ruby-identifier">t</span> <span class="ruby-operator">*</span> <span class="ruby-identifier">x_j</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
36
- <span class="ruby-keyword kw">break</span> <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">t</span>.<span class="ruby-identifier">zero?</span>)
37
- <span class="ruby-identifier">tr</span> = <span class="ruby-identifier">t</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">dprec</span>, <span class="ruby-constant">LongDecimal</span><span class="ruby-operator">::</span><span class="ruby-constant">ROUND_DOWN</span>).<span class="ruby-identifier">abs</span>
38
- <span class="ruby-keyword kw">break</span> <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">t</span>.<span class="ruby-identifier">zero?</span>)
39
- <span class="ruby-identifier">tu</span> = <span class="ruby-identifier">t</span>.<span class="ruby-identifier">unit</span>
40
- <span class="ruby-keyword kw">break</span> <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">tr</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-identifier">tu</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">last_t</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-identifier">tu</span>)
41
- <span class="ruby-identifier">last_t</span> = <span class="ruby-identifier">tr</span>
42
- <span class="ruby-keyword kw">end</span>
43
- <span class="ruby-identifier">x_i</span> = <span class="ruby-value">1</span>
44
- <span class="ruby-identifier">y_k</span> = <span class="ruby-constant">LongDecimal</span>(<span class="ruby-value">0</span>)
45
- <span class="ruby-identifier">j</span>.<span class="ruby-identifier">times</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">i</span><span class="ruby-operator">|</span>
46
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">i</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>) <span class="ruby-keyword kw">then</span>
47
- <span class="ruby-identifier">x_i</span> = (<span class="ruby-identifier">x_i</span> <span class="ruby-operator">*</span> <span class="ruby-identifier">x_k</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
48
- <span class="ruby-keyword kw">end</span>
49
- <span class="ruby-identifier">y_k</span> <span class="ruby-operator">+=</span> (<span class="ruby-identifier">s</span>[<span class="ruby-identifier">i</span>] <span class="ruby-operator">*</span> <span class="ruby-identifier">x_i</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
50
- <span class="ruby-keyword kw">end</span>
51
- <span class="ruby-identifier">k</span>.<span class="ruby-identifier">times</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">i</span><span class="ruby-operator">|</span>
52
- <span class="ruby-identifier">y_k</span> = <span class="ruby-identifier">y_k</span>.<span class="ruby-identifier">square</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
53
- <span class="ruby-keyword kw">end</span>
54
-
55
- <span class="ruby-identifier">y_k</span>
56
- <span class="ruby-keyword kw">end</span></pre>
57
- </body>
58
- </html>
@@ -1,18 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>sqrt (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 2846</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">sqrt</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>) <span class="ruby-comment cmt"># down</span>
15
- <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">sqrt_internal</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>, <span class="ruby-keyword kw">false</span>)
16
- <span class="ruby-keyword kw">end</span></pre>
17
- </body>
18
- </html>
@@ -1,18 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>sqrt_with_remainder (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 2853</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">sqrt_with_remainder</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>)
15
- <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">sqrt_internal</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-constant">ROUND_DOWN</span>, <span class="ruby-keyword kw">true</span>)
16
- <span class="ruby-keyword kw">end</span></pre>
17
- </body>
18
- </html>
@@ -1,20 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>log (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 2914</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">log</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>) <span class="ruby-comment cmt"># down?</span>
15
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-value str">&quot;prec&quot;</span>)
16
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">mode</span>, <span class="ruby-value str">&quot;mode&quot;</span>)
17
- <span class="ruby-identifier">log_internal</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
18
- <span class="ruby-keyword kw">end</span></pre>
19
- </body>
20
- </html>
@@ -1,34 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>log10 (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 2924</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">log10</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>) <span class="ruby-comment cmt"># down?</span>
15
-
16
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-value str">&quot;prec&quot;</span>)
17
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">mode</span>, <span class="ruby-value str">&quot;mode&quot;</span>)
18
- <span class="ruby-identifier">iprec</span> = <span class="ruby-identifier">prec</span> <span class="ruby-operator">+</span> <span class="ruby-value">6</span>
19
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>)
20
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
21
- <span class="ruby-keyword kw">end</span>
22
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">one?</span>) <span class="ruby-keyword kw">then</span>
23
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">zero!</span>(<span class="ruby-identifier">prec</span>)
24
- <span class="ruby-keyword kw">end</span>
25
-
26
- <span class="ruby-identifier">id</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">int_digits10</span>
27
- <span class="ruby-identifier">xx</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">move_point_left</span>(<span class="ruby-identifier">id</span>)
28
- <span class="ruby-identifier">lnxx</span> = <span class="ruby-identifier">log_internal</span>(<span class="ruby-identifier">xx</span>, <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
29
- <span class="ruby-identifier">ln10</span> = <span class="ruby-identifier">log_internal</span>(<span class="ruby-value">10</span>, <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
30
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">id</span> <span class="ruby-operator">+</span> (<span class="ruby-identifier">lnxx</span> <span class="ruby-operator">/</span> <span class="ruby-identifier">ln10</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
31
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">y</span>
32
- <span class="ruby-keyword kw">end</span></pre>
33
- </body>
34
- </html>
@@ -1,33 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>log2 (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 2948</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">log2</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>)
15
-
16
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-value str">&quot;prec&quot;</span>)
17
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">mode</span>, <span class="ruby-value str">&quot;mode&quot;</span>)
18
- <span class="ruby-identifier">iprec</span> = <span class="ruby-identifier">prec</span> <span class="ruby-operator">+</span> <span class="ruby-value">6</span>
19
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>)
20
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
21
- <span class="ruby-keyword kw">end</span>
22
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">one?</span>) <span class="ruby-keyword kw">then</span>
23
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">zero!</span>(<span class="ruby-identifier">prec</span>)
24
- <span class="ruby-keyword kw">end</span>
25
- <span class="ruby-identifier">id</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">int_digits2</span>
26
- <span class="ruby-identifier">xx</span> = (<span class="ruby-identifier">x</span> <span class="ruby-operator">/</span> (<span class="ruby-value">1</span> <span class="ruby-operator">&lt;&lt;</span> <span class="ruby-identifier">id</span>)).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">x</span>.<span class="ruby-identifier">scale</span><span class="ruby-operator">+</span><span class="ruby-identifier">id</span>)
27
- <span class="ruby-identifier">lnxx</span> = <span class="ruby-identifier">log_internal</span>(<span class="ruby-identifier">xx</span>, <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
28
- <span class="ruby-identifier">ln2</span> = <span class="ruby-identifier">log_internal</span>(<span class="ruby-value">2</span>.<span class="ruby-identifier">to_ld</span>, <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
29
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">id</span> <span class="ruby-operator">+</span> (<span class="ruby-identifier">lnxx</span> <span class="ruby-operator">/</span> <span class="ruby-identifier">ln2</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
30
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">y</span>
31
- <span class="ruby-keyword kw">end</span></pre>
32
- </body>
33
- </html>
@@ -1,58 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>log_internal (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 2974</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">log_internal</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">final_mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>, <span class="ruby-identifier">iprec</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_imode</span>, <span class="ruby-identifier">cache_result</span> = <span class="ruby-keyword kw">true</span>)
15
-
16
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;x=#{x.inspect} must not be positive&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">x</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>
17
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">prec</span>.<span class="ruby-identifier">nil?</span>) <span class="ruby-keyword kw">then</span>
18
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>)
19
- <span class="ruby-identifier">prec</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">scale</span>
20
- <span class="ruby-keyword kw">else</span>
21
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">ArgumentError</span>, <span class="ruby-node">&quot;precision must be supplied either as precision of x=#{x} or explicitely&quot;</span>
22
- <span class="ruby-keyword kw">end</span>
23
- <span class="ruby-keyword kw">end</span>
24
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-value str">&quot;prec&quot;</span>)
25
-
26
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">final_mode</span>.<span class="ruby-identifier">nil?</span>)
27
- <span class="ruby-identifier">final_mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>
28
- <span class="ruby-keyword kw">end</span>
29
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">final_mode</span>, <span class="ruby-value str">&quot;final_mode&quot;</span>)
30
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">mode</span>, <span class="ruby-value str">&quot;mode&quot;</span>)
31
-
32
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">iprec</span>.<span class="ruby-identifier">nil?</span>) <span class="ruby-keyword kw">then</span>
33
- <span class="ruby-comment cmt"># iprec = ((prec+10)*1.20).round</span>
34
- <span class="ruby-identifier">iprec</span> = ((<span class="ruby-identifier">prec</span><span class="ruby-operator">+</span><span class="ruby-value">12</span>)<span class="ruby-operator">*</span><span class="ruby-value">1.20</span>).<span class="ruby-identifier">round</span>
35
- <span class="ruby-keyword kw">end</span>
36
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">iprec</span> <span class="ruby-operator">&lt;</span> <span class="ruby-identifier">prec</span>) <span class="ruby-keyword kw">then</span>
37
- <span class="ruby-identifier">iprec</span> = <span class="ruby-identifier">prec</span>
38
- <span class="ruby-keyword kw">end</span>
39
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-value str">&quot;iprec&quot;</span>)
40
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>)
41
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
42
- <span class="ruby-keyword kw">end</span>
43
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">one?</span>) <span class="ruby-keyword kw">then</span>
44
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">zero!</span>(<span class="ruby-identifier">prec</span>)
45
- <span class="ruby-keyword kw">end</span>
46
-
47
- <span class="ruby-identifier">cache_key</span> = <span class="ruby-identifier">get_cache_key</span>(<span class="ruby-value str">&quot;log&quot;</span>, <span class="ruby-identifier">x</span>, <span class="ruby-identifier">mode</span>, [<span class="ruby-value">2</span>, <span class="ruby-value">3</span>, <span class="ruby-value">5</span>, <span class="ruby-value">10</span>])
48
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">get_cached</span>(<span class="ruby-identifier">cache_key</span>, <span class="ruby-identifier">x</span>, <span class="ruby-identifier">iprec</span>)
49
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">nil?</span>)
50
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">log_raw</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
51
- <span class="ruby-identifier">set_cached</span>(<span class="ruby-identifier">cache_key</span>, <span class="ruby-identifier">y</span>) <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">cache_result</span>
52
- <span class="ruby-keyword kw">end</span>
53
-
54
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">final_mode</span>)
55
-
56
- <span class="ruby-keyword kw">end</span></pre>
57
- </body>
58
- </html>
@@ -1,406 +0,0 @@
1
- <?xml version="1.0" encoding="iso-8859-1"?>
2
- <!DOCTYPE html
3
- PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
4
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5
-
6
- <html>
7
- <head>
8
- <title>log_raw (LongMath)</title>
9
- <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
10
- <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
11
- </head>
12
- <body class="standalone-code">
13
- <pre><span class="ruby-comment cmt"># File lib/long-decimal.rb, line 3023</span>
14
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">log_raw</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
15
-
16
- <span class="ruby-comment cmt"># puts(&quot;log_raw start x=#{x}&quot;)</span>
17
-
18
- <span class="ruby-comment cmt"># we have to rely on iprec being at least 10</span>
19
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;iprec=#{iprec} out of range&quot;</span> <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">iprec</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Fixnum</span>) <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">iprec</span> <span class="ruby-operator">&gt;=</span> <span class="ruby-value">10</span>
20
-
21
- <span class="ruby-comment cmt"># dprec = [ iprec - 1, (prec + 1) &lt;&lt; 1 ].min</span>
22
- <span class="ruby-comment cmt"># dprec &gt;= 9</span>
23
- <span class="ruby-identifier">dprec</span> = <span class="ruby-identifier">iprec</span> <span class="ruby-operator">-</span> <span class="ruby-value">1</span>
24
-
25
- <span class="ruby-comment cmt"># result is stored in y</span>
26
- <span class="ruby-identifier">y</span> = <span class="ruby-value">0</span>
27
- <span class="ruby-comment cmt"># sign of result</span>
28
- <span class="ruby-identifier">s</span> = <span class="ruby-value">1</span>
29
- <span class="ruby-comment cmt"># make sure x is &gt;= 1</span>
30
- <span class="ruby-identifier">mode1</span> = <span class="ruby-identifier">mode</span>
31
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">1</span>) <span class="ruby-keyword kw">then</span>
32
- <span class="ruby-identifier">mode1</span> = <span class="ruby-identifier">mode1</span>.<span class="ruby-identifier">minverse</span>
33
- <span class="ruby-identifier">x</span> = (<span class="ruby-value">1</span> <span class="ruby-operator">/</span> <span class="ruby-identifier">x</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode1</span>)
34
- <span class="ruby-identifier">s</span> = <span class="ruby-value">-1</span>
35
- <span class="ruby-keyword kw">end</span>
36
- <span class="ruby-comment cmt"># puts(&quot;log_raw prepared t=#{Time.new-t0} x=#{x} s=#{s} mode=#{mode} mode1=#{mode1}&quot;)</span>
37
-
38
- <span class="ruby-comment cmt"># number that are beyond the usual range of Float need to be</span>
39
- <span class="ruby-comment cmt"># handled specially to reduce to something expressable as Float</span>
40
- <span class="ruby-identifier">exp_keys</span> = [ <span class="ruby-constant">MAX_EXP_ABLE</span>.<span class="ruby-identifier">to_i</span>, <span class="ruby-value">100</span>, <span class="ruby-value">10</span>, <span class="ruby-value">1</span> ]
41
- <span class="ruby-identifier">exp_keys</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">exp_key</span><span class="ruby-operator">|</span>
42
- <span class="ruby-identifier">exp_val</span> = <span class="ruby-identifier">exp</span>(<span class="ruby-identifier">exp_key</span>, <span class="ruby-identifier">iprec</span>)
43
- <span class="ruby-keyword kw">while</span> (<span class="ruby-identifier">x</span> <span class="ruby-operator">&gt;</span> <span class="ruby-identifier">exp_val</span>) <span class="ruby-keyword kw">do</span>
44
- <span class="ruby-identifier">x</span> = (<span class="ruby-identifier">x</span> <span class="ruby-operator">/</span> <span class="ruby-identifier">exp_val</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode1</span>)
45
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">s</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">0</span>) <span class="ruby-keyword kw">then</span>
46
- <span class="ruby-identifier">y</span> <span class="ruby-operator">-=</span> <span class="ruby-identifier">exp_key</span>
47
- <span class="ruby-keyword kw">else</span>
48
- <span class="ruby-identifier">y</span> <span class="ruby-operator">+=</span> <span class="ruby-identifier">exp_key</span>
49
- <span class="ruby-keyword kw">end</span>
50
- <span class="ruby-keyword kw">end</span>
51
- <span class="ruby-keyword kw">end</span>
52
- <span class="ruby-comment cmt"># puts(&quot;log_raw divided t=#{Time.new-t0} x=#{x} y=#{y} s=#{s}&quot;)</span>
53
-
54
- <span class="ruby-identifier">factor</span> = <span class="ruby-value">1</span>
55
- <span class="ruby-identifier">sprec</span> = (<span class="ruby-identifier">iprec</span> <span class="ruby-operator">*</span> <span class="ruby-value">1.5</span>).<span class="ruby-identifier">round</span>
56
- <span class="ruby-comment cmt"># delta = LongDecimal(1, (iprec.to_f**(1/3)).round)</span>
57
- <span class="ruby-comment cmt"># delta = LongDecimal(1, (iprec.to_f**0.3).round)</span>
58
- <span class="ruby-identifier">delta</span> = <span class="ruby-constant">LongDecimal</span>(<span class="ruby-value">1</span>, (<span class="ruby-identifier">iprec</span>.<span class="ruby-identifier">to_f</span><span class="ruby-operator">**</span><span class="ruby-value">0</span><span class="ruby-value">.45</span>).<span class="ruby-identifier">round</span>)
59
- <span class="ruby-comment cmt"># delta = LongDecimal(1, LongMath.sqrtw(iprec))</span>
60
- <span class="ruby-comment cmt"># delta = LongDecimal(1, LongMath.sqrtw(LongMath.sqrtw(iprec+1)+1))</span>
61
- <span class="ruby-keyword kw">while</span> (<span class="ruby-identifier">x</span> <span class="ruby-operator">-</span> <span class="ruby-value">1</span>).<span class="ruby-identifier">abs</span> <span class="ruby-operator">&gt;</span> <span class="ruby-identifier">delta</span> <span class="ruby-keyword kw">do</span>
62
- <span class="ruby-identifier">x</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">sqrt</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">sprec</span>, <span class="ruby-identifier">mode1</span>)
63
- <span class="ruby-identifier">factor</span> <span class="ruby-operator">*=</span> <span class="ruby-value">2</span>
64
- <span class="ruby-keyword kw">end</span>
65
- <span class="ruby-comment cmt"># puts(&quot;log_raw rooted t=#{Time.new-t0} x=#{x} y=#{y} s=#{s} f=#{factor}&quot;)</span>
66
-
67
- <span class="ruby-identifier">ss</span> = <span class="ruby-value">1</span>
68
- <span class="ruby-identifier">mode2</span> = <span class="ruby-identifier">mode1</span>.<span class="ruby-identifier">ainverse</span>
69
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">1</span>)
70
- <span class="ruby-identifier">puts</span>(<span class="ruby-value str">&quot;x&lt;1 inverting&quot;</span>)
71
- <span class="ruby-identifier">mode2</span> = <span class="ruby-identifier">mode2</span>.<span class="ruby-identifier">ainverse</span>
72
- <span class="ruby-identifier">x</span> = (<span class="ruby-value">1</span> <span class="ruby-operator">/</span> <span class="ruby-identifier">x</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode2</span>)
73
- <span class="ruby-identifier">ss</span> = <span class="ruby-value">-1</span>
74
- <span class="ruby-keyword kw">end</span>
75
- <span class="ruby-comment cmt"># puts(&quot;log_raw 2nd prep t=#{Time.new-t0} x=#{x} y=#{y} s=#{s} ss=#{ss} f=#{factor}&quot;)</span>
76
-
77
- <span class="ruby-identifier">sum</span> = <span class="ruby-value">0</span>
78
- <span class="ruby-identifier">z</span> = <span class="ruby-value">1</span> <span class="ruby-operator">-</span> <span class="ruby-identifier">x</span>
79
- <span class="ruby-identifier">i</span> = <span class="ruby-value">1</span>
80
- <span class="ruby-identifier">p</span> = <span class="ruby-value">1</span>.<span class="ruby-identifier">to_ld</span>
81
- <span class="ruby-identifier">d</span> = <span class="ruby-value">1</span>.<span class="ruby-identifier">to_ld</span>
82
- <span class="ruby-keyword kw">until</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">abs</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">dprec</span>, <span class="ruby-constant">LongDecimal</span><span class="ruby-operator">::</span><span class="ruby-constant">ROUND_DOWN</span>).<span class="ruby-identifier">zero?</span> <span class="ruby-keyword kw">do</span>
83
- <span class="ruby-identifier">p</span> = (<span class="ruby-identifier">p</span> <span class="ruby-operator">*</span> <span class="ruby-identifier">z</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode2</span>)
84
- <span class="ruby-identifier">d</span> = (<span class="ruby-identifier">p</span> <span class="ruby-operator">/</span> <span class="ruby-identifier">i</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode2</span>)
85
- <span class="ruby-identifier">i</span> <span class="ruby-operator">+=</span> <span class="ruby-value">1</span>
86
- <span class="ruby-identifier">sum</span> <span class="ruby-operator">+=</span> <span class="ruby-identifier">d</span>
87
-
88
- <span class="ruby-keyword kw">end</span>
89
- <span class="ruby-identifier">sum</span> <span class="ruby-operator">*=</span> <span class="ruby-identifier">ss</span>
90
- <span class="ruby-comment cmt"># puts(&quot;log_raw added t=#{Time.new-t0} x=#{x} y=#{y} sum=#{sum} s=#{s} ss=#{ss} f=#{factor}&quot;)</span>
91
-
92
- <span class="ruby-identifier">y</span> <span class="ruby-operator">-=</span> ((<span class="ruby-identifier">s</span> <span class="ruby-operator">*</span> <span class="ruby-identifier">factor</span>) <span class="ruby-operator">*</span> <span class="ruby-identifier">sum</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>.<span class="ruby-identifier">ainverse</span>)
93
- <span class="ruby-comment cmt"># puts(&quot;log_raw done t=#{Time.new-t0} x=#{x} y=#{y} sum=#{sum} s=#{s} ss=#{ss} f=#{factor}&quot;)</span>
94
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">y</span>
95
- <span class="ruby-keyword kw">end</span>
96
-
97
- <span class="ruby-identifier">private</span>
98
-
99
- <span class="ruby-comment cmt">#</span>
100
- <span class="ruby-comment cmt"># internal helper method for calculating the internal precision for power</span>
101
- <span class="ruby-comment cmt">#</span>
102
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">calc_iprec_for_power</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span>)
103
-
104
- <span class="ruby-identifier">logx_f</span> = <span class="ruby-keyword kw">nil</span>
105
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-constant">LongMath</span><span class="ruby-operator">::</span><span class="ruby-constant">MAX_FLOATABLE</span>)
106
- <span class="ruby-identifier">x_f</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_f</span>
107
- <span class="ruby-identifier">logx_f</span> = <span class="ruby-constant">Math</span>.<span class="ruby-identifier">log</span>(<span class="ruby-identifier">x_f</span>.<span class="ruby-identifier">abs</span>)
108
- <span class="ruby-keyword kw">else</span>
109
- <span class="ruby-identifier">logx_f</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">log</span>(<span class="ruby-identifier">x</span>, <span class="ruby-value">15</span>, <span class="ruby-constant">LongMath</span><span class="ruby-operator">::</span><span class="ruby-constant">ROUND_UP</span>)
110
- <span class="ruby-keyword kw">end</span>
111
-
112
- <span class="ruby-identifier">y_f</span> = <span class="ruby-keyword kw">nil</span>
113
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-constant">LongMath</span><span class="ruby-operator">::</span><span class="ruby-constant">MAX_FLOATABLE</span>) <span class="ruby-keyword kw">then</span>
114
- <span class="ruby-identifier">y_f</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">to_f</span>
115
- <span class="ruby-keyword kw">else</span>
116
- <span class="ruby-identifier">y_f</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-value">15</span>, <span class="ruby-constant">LongMath</span><span class="ruby-operator">::</span><span class="ruby-constant">ROUND_UP</span>)
117
- <span class="ruby-keyword kw">end</span>
118
-
119
- <span class="ruby-identifier">logx_y_f</span> = <span class="ruby-identifier">logx_f</span> <span class="ruby-operator">*</span> <span class="ruby-identifier">y_f</span>
120
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">logx_y_f</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&gt;</span> <span class="ruby-constant">LongMath</span><span class="ruby-operator">::</span><span class="ruby-constant">MAX_FLOATABLE</span>) <span class="ruby-keyword kw">then</span>
121
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">ArgumentError</span>, <span class="ruby-node">&quot;power would be way too big: y*log(x)=#{logx_y_f}&quot;</span>;
122
- <span class="ruby-keyword kw">end</span>
123
- <span class="ruby-identifier">logx_y_f</span> = <span class="ruby-identifier">logx_y_f</span>.<span class="ruby-identifier">to_f</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">logx_y_f</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Float</span>
124
-
125
- <span class="ruby-identifier">iprec_x</span> = <span class="ruby-identifier">calc_iprec_for_exp</span>(<span class="ruby-identifier">logx_y_f</span>.<span class="ruby-identifier">abs</span>.<span class="ruby-identifier">ceil</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">logx_y_f</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">0</span>)
126
- <span class="ruby-identifier">iprec_y</span> = <span class="ruby-identifier">iprec_x</span>
127
- <span class="ruby-identifier">iprec</span> = <span class="ruby-identifier">iprec_x</span> <span class="ruby-operator">+</span> <span class="ruby-value">2</span>
128
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">logx_f</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">0</span>)
129
- <span class="ruby-identifier">iprec_x</span> <span class="ruby-operator">-=</span> (<span class="ruby-identifier">logx_f</span><span class="ruby-operator">/</span><span class="ruby-constant">LOG10</span>).<span class="ruby-identifier">round</span>
130
- <span class="ruby-keyword kw">end</span>
131
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y_f</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">1</span>)
132
- <span class="ruby-identifier">logy_f</span> = <span class="ruby-keyword kw">nil</span>
133
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y_f</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Float</span>) <span class="ruby-keyword kw">then</span>
134
- <span class="ruby-identifier">logy_f</span> = <span class="ruby-constant">Math</span>.<span class="ruby-identifier">log</span>(<span class="ruby-identifier">y_f</span>.<span class="ruby-identifier">abs</span>)
135
- <span class="ruby-keyword kw">else</span>
136
- <span class="ruby-identifier">logy_f</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">log</span>(<span class="ruby-identifier">y_f</span>.<span class="ruby-identifier">abs</span>, <span class="ruby-value">15</span>, <span class="ruby-constant">LongMath</span><span class="ruby-operator">::</span><span class="ruby-constant">ROUND_UP</span>)
137
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">logy_f</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&gt;</span> <span class="ruby-constant">LongMath</span><span class="ruby-operator">::</span><span class="ruby-constant">MAX_FLOATABLE</span>) <span class="ruby-keyword kw">then</span>
138
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">ArgumentError</span>, <span class="ruby-node">&quot;exponent would be way too big: y=#{y} logy_f=#{logy_f}&quot;</span>;
139
- <span class="ruby-keyword kw">end</span>
140
- <span class="ruby-identifier">logy_f</span> = <span class="ruby-identifier">logy_f</span>.<span class="ruby-identifier">to_f</span>
141
- <span class="ruby-keyword kw">end</span>
142
- <span class="ruby-comment cmt"># puts(&quot;x=#{x} y=#{y} x_f=#{x_f} y_f=#{y_f} logx_f=#{logx_f} logy_f=#{logy_f} logx_y_f=#{logx_y_f}\n&quot;)</span>
143
- <span class="ruby-identifier">iprec_y</span> <span class="ruby-operator">-=</span> (<span class="ruby-identifier">logy_f</span><span class="ruby-operator">/</span><span class="ruby-constant">LOG10</span>).<span class="ruby-identifier">round</span>
144
- <span class="ruby-keyword kw">end</span>
145
- <span class="ruby-comment cmt"># puts(&quot;x=#{x} y=#{y} x_f=#{x_f} y_f=#{y_f} logx_f=#{logx_f} logy_f=#{logy_f} logx_y_f=#{logx_y_f}\n&quot;)</span>
146
- <span class="ruby-comment cmt"># puts(&quot;\niprec: x=#{x} y=#{y} iprec=#{iprec} iprec_x=#{iprec_x} iprec_y=#{iprec_y}\n&quot;)</span>
147
- [ <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">iprec_x</span>, <span class="ruby-identifier">iprec_y</span>, <span class="ruby-identifier">logx_y_f</span> ]
148
-
149
- <span class="ruby-keyword kw">end</span>
150
-
151
- <span class="ruby-identifier">public</span>
152
-
153
- <span class="ruby-comment cmt">#</span>
154
- <span class="ruby-comment cmt"># calc the power of x with exponent y to the given precision as</span>
155
- <span class="ruby-comment cmt"># LongDecimal. Only supports values of y such that exp(y) still</span>
156
- <span class="ruby-comment cmt"># fits into a float (y &lt;= 709)</span>
157
- <span class="ruby-comment cmt">#</span>
158
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">power</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>)
159
-
160
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;x=#{x} must be numeric&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Numeric</span>
161
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;y=#{y} must be numeric&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Numeric</span>
162
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;x=#{x.inspect} must not be greater #{MAX_FLOATABLE}&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-constant">MAX_FLOATABLE</span>
163
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;y=#{y.inspect} must not be greater #{MAX_FLOATABLE}&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-constant">MAX_FLOATABLE</span>
164
- <span class="ruby-comment cmt"># raise TypeError, &quot;y=#{y.inspect} must not be greater #{MAX_EXP_ABLE}&quot; unless y &lt;= MAX_EXP_ABLE</span>
165
- <span class="ruby-comment cmt"># raise TypeError, &quot;x=#{x.inspect} must not negative&quot; unless x &gt;= 0 || (y.kind_of? Integer) || (y.kind_of? LongDecimalBase) &amp;&amp; y.is_int?</span>
166
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;x=#{x.inspect} must not negative&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">x</span> <span class="ruby-operator">&gt;=</span> <span class="ruby-value">0</span>
167
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-value str">&quot;prec&quot;</span>)
168
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">mode</span>, <span class="ruby-value str">&quot;mode&quot;</span>)
169
-
170
- <span class="ruby-comment cmt"># handle the special cases where base or exponent are 0 or 1 explicitely</span>
171
- <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">zero?</span> <span class="ruby-keyword kw">then</span>
172
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">one!</span>(<span class="ruby-identifier">prec</span>)
173
- <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">zero?</span> <span class="ruby-keyword kw">then</span>
174
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">zero!</span>(<span class="ruby-identifier">prec</span>)
175
- <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">one?</span> <span class="ruby-keyword kw">then</span>
176
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
177
- <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">one?</span> <span class="ruby-keyword kw">then</span>
178
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">one!</span>(<span class="ruby-identifier">prec</span>)
179
- <span class="ruby-keyword kw">end</span>
180
-
181
- <span class="ruby-comment cmt"># els</span>
182
- <span class="ruby-comment cmt"># could be result with our precision</span>
183
- <span class="ruby-comment cmt"># x ** y &lt;= 10**-s/2 &lt;=&gt; y * log(x) &lt;= -s log(10) - log(2)</span>
184
-
185
- <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">iprec_x</span>, <span class="ruby-identifier">iprec_y</span>, <span class="ruby-identifier">logx_y_f</span> = <span class="ruby-identifier">calc_iprec_for_power</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span>)
186
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">1</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">y</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span> <span class="ruby-operator">||</span> <span class="ruby-identifier">x</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">1</span> <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">y</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">0</span>) <span class="ruby-keyword kw">then</span>
187
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">logx_y_f</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-operator">-</span> <span class="ruby-identifier">prec</span> <span class="ruby-operator">*</span> <span class="ruby-constant">LOG10</span> <span class="ruby-operator">-</span> <span class="ruby-constant">LOG2</span>) <span class="ruby-keyword kw">then</span>
188
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">zero!</span>(<span class="ruby-identifier">prec</span>)
189
- <span class="ruby-keyword kw">end</span>
190
- <span class="ruby-keyword kw">end</span>
191
- <span class="ruby-comment cmt"># puts(&quot;x=#{x} y=#{y} iprec=#{iprec} iprec_x=#{iprec_x} iprec_y=#{iprec_y} prec=#{prec}&quot;)</span>
192
-
193
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>) <span class="ruby-operator">||</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Integer</span>)
194
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec_x</span>, <span class="ruby-identifier">mode</span>)
195
- <span class="ruby-keyword kw">end</span>
196
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>) <span class="ruby-operator">||</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Integer</span>)
197
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec_y</span>, <span class="ruby-identifier">mode</span>)
198
- <span class="ruby-keyword kw">end</span>
199
-
200
- <span class="ruby-comment cmt"># try shortcut if exponent is an integer</span>
201
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>) <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">is_int?</span> <span class="ruby-keyword kw">then</span>
202
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">to_i</span>
203
- <span class="ruby-keyword kw">end</span>
204
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Integer</span>)
205
- <span class="ruby-identifier">y2</span> = <span class="ruby-identifier">y</span><span class="ruby-operator">*</span><span class="ruby-value">2</span>
206
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y2</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>) <span class="ruby-operator">&amp;&amp;</span> <span class="ruby-identifier">y2</span>.<span class="ruby-identifier">is_int?</span> <span class="ruby-keyword kw">then</span>
207
- <span class="ruby-identifier">y2</span> = <span class="ruby-identifier">y2</span>.<span class="ruby-identifier">to_i</span>
208
- <span class="ruby-identifier">puts</span>(<span class="ruby-node">&quot;y2=#{y2}&quot;</span>)
209
- <span class="ruby-keyword kw">end</span>
210
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y2</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Integer</span>)
211
- <span class="ruby-identifier">x</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">sqrt</span>(<span class="ruby-identifier">x</span>, <span class="ruby-value">2</span><span class="ruby-operator">*</span><span class="ruby-identifier">iprec_x</span>, <span class="ruby-identifier">mode</span>)
212
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">y2</span>
213
- <span class="ruby-keyword kw">end</span>
214
- <span class="ruby-keyword kw">end</span>
215
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Integer</span>)
216
- <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>
217
- <span class="ruby-comment cmt"># x = x.to_ld(prec)</span>
218
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec_x</span>)
219
- <span class="ruby-keyword kw">end</span>
220
- <span class="ruby-comment cmt"># z = x ** y</span>
221
- <span class="ruby-identifier">z</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">ipower</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-value">2</span><span class="ruby-operator">*</span><span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
222
- <span class="ruby-comment cmt"># puts(&quot;x=#{x} y=#{y} z=#{z} y int&quot;)</span>
223
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">z</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
224
- <span class="ruby-keyword kw">end</span>
225
-
226
- <span class="ruby-comment cmt"># it can be assumed that the exponent is not an integer, so it should</span>
227
- <span class="ruby-comment cmt"># be converted into LongDecimal</span>
228
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>)
229
- <span class="ruby-comment cmt"># y = y.to_ld(prec, mode)</span>
230
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec_y</span>, <span class="ruby-identifier">mode</span>)
231
- <span class="ruby-keyword kw">end</span>
232
-
233
- <span class="ruby-comment cmt"># if x &lt; 1 &amp;&amp; y &lt; 0 then</span>
234
- <span class="ruby-comment cmt"># working with x &lt; 1 should be improved, less precision needed</span>
235
- <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">x</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">1</span> <span class="ruby-keyword kw">then</span>
236
- <span class="ruby-comment cmt"># since we do not allow x &lt; 0 and we have handled x = 0 already,</span>
237
- <span class="ruby-comment cmt"># we can be sure that x is no integer, so it has been converted</span>
238
- <span class="ruby-comment cmt"># if necessary to LongDecimalBase</span>
239
- <span class="ruby-identifier">y</span> = <span class="ruby-operator">-</span><span class="ruby-identifier">y</span>
240
- <span class="ruby-identifier">x</span> = (<span class="ruby-value">1</span><span class="ruby-operator">/</span><span class="ruby-identifier">x</span>).<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">iprec_x</span><span class="ruby-operator">*</span><span class="ruby-value">2</span>, <span class="ruby-identifier">mode</span>)
241
- <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">iprec_x</span>, <span class="ruby-identifier">iprec_y</span> = <span class="ruby-identifier">calc_iprec_for_power</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span>)
242
- <span class="ruby-keyword kw">end</span>
243
-
244
- <span class="ruby-comment cmt"># exponent is split in two parts, an integer part and a</span>
245
- <span class="ruby-comment cmt"># LongDecimal with absolute value &lt;= 0.5</span>
246
- <span class="ruby-identifier">y0</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-value">0</span>, <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_imode</span>).<span class="ruby-identifier">to_i</span>
247
- <span class="ruby-comment cmt"># z0 = x**y0</span>
248
- <span class="ruby-identifier">z0</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">ipower</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y0</span>, <span class="ruby-value">2</span><span class="ruby-operator">*</span><span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">mode</span>)
249
- <span class="ruby-identifier">y1</span> = <span class="ruby-identifier">y</span> <span class="ruby-operator">-</span> <span class="ruby-identifier">y0</span>
250
- <span class="ruby-identifier">prec_extra</span> = <span class="ruby-value">0</span>
251
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y0</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>)
252
- <span class="ruby-identifier">prec_extra</span> = (<span class="ruby-identifier">y0</span><span class="ruby-operator">*</span><span class="ruby-constant">Math</span>.<span class="ruby-identifier">log10</span>(<span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_f</span>).<span class="ruby-identifier">abs</span>).<span class="ruby-identifier">ceil</span>
253
- <span class="ruby-keyword kw">end</span>
254
- <span class="ruby-comment cmt"># z1 = LongMath.power_internal(x, y1, prec+prec_extra , mode)</span>
255
- <span class="ruby-identifier">z1</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">power_internal</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y1</span>, <span class="ruby-identifier">prec</span><span class="ruby-operator">+</span><span class="ruby-identifier">prec_extra</span> <span class="ruby-operator">+</span> <span class="ruby-value">4</span>, <span class="ruby-identifier">mode</span>)
256
- <span class="ruby-identifier">z</span> = <span class="ruby-identifier">z0</span> <span class="ruby-operator">*</span> <span class="ruby-identifier">z1</span>
257
- <span class="ruby-comment cmt"># puts(&quot;x=#{x} y=#{y} z=#{z} y not int&quot;)</span>
258
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">z</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
259
- <span class="ruby-keyword kw">end</span>
260
-
261
- <span class="ruby-comment cmt">#</span>
262
- <span class="ruby-comment cmt"># internal functionality to calculate the y-th power of x assuming</span>
263
- <span class="ruby-comment cmt"># that y is an integer</span>
264
- <span class="ruby-comment cmt"># prec is a hint on how much internal precision is needed at most</span>
265
- <span class="ruby-comment cmt"># final rounding is left to the caller</span>
266
- <span class="ruby-comment cmt">#</span>
267
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">ipower</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
268
-
269
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;x=#{x} must be numeric&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Numeric</span>
270
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;y=#{y} must be integer&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Integer</span>
271
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;x=#{x.inspect} must not be greater #{MAX_FLOATABLE}&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-constant">MAX_FLOATABLE</span>
272
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">TypeError</span>, <span class="ruby-node">&quot;y=#{y.inspect} must not be greater #{MAX_FLOATABLE}&quot;</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-constant">MAX_FLOATABLE</span>
273
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-value str">&quot;prec&quot;</span>)
274
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">mode</span>, <span class="ruby-value str">&quot;mode&quot;</span>)
275
-
276
- <span class="ruby-identifier">cnt</span> = <span class="ruby-value">0</span>
277
-
278
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">zero?</span>)
279
- <span class="ruby-keyword kw">return</span> <span class="ruby-value">1</span>
280
- <span class="ruby-keyword kw">elsif</span> <span class="ruby-operator">!</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>) <span class="ruby-operator">||</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">scale</span> <span class="ruby-operator">*</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">abs</span> <span class="ruby-operator">&lt;=</span> <span class="ruby-identifier">prec</span>
281
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">x</span> <span class="ruby-operator">**</span> <span class="ruby-identifier">y</span>
282
- <span class="ruby-keyword kw">elsif</span> (<span class="ruby-identifier">y</span> <span class="ruby-operator">&lt;</span> <span class="ruby-value">0</span>)
283
- <span class="ruby-identifier">l</span> = <span class="ruby-constant">Math</span>.<span class="ruby-identifier">log10</span>(<span class="ruby-identifier">x</span>.<span class="ruby-identifier">abs</span>.<span class="ruby-identifier">to_f</span>)
284
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">l</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">0</span>)
285
- <span class="ruby-identifier">prec</span> <span class="ruby-operator">+=</span> (<span class="ruby-value">2</span><span class="ruby-operator">*</span><span class="ruby-identifier">l</span>).<span class="ruby-identifier">ceil</span>
286
- <span class="ruby-keyword kw">end</span>
287
- <span class="ruby-keyword kw">return</span> <span class="ruby-value">1</span><span class="ruby-operator">/</span><span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">ipower</span>(<span class="ruby-identifier">x</span>, <span class="ruby-operator">-</span><span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
288
- <span class="ruby-keyword kw">else</span>
289
- <span class="ruby-comment cmt"># y &gt; 0</span>
290
- <span class="ruby-comment cmt"># puts(&quot;ipower y&gt;0 x=#{x} y=#{y} prec=#{prec}&quot;)</span>
291
- <span class="ruby-identifier">z</span> = <span class="ruby-identifier">x</span>
292
- <span class="ruby-keyword kw">while</span> <span class="ruby-keyword kw">true</span> <span class="ruby-keyword kw">do</span>
293
-
294
- <span class="ruby-identifier">cnt</span><span class="ruby-operator">+</span><span class="ruby-operator">+</span>
295
- <span class="ruby-identifier">y</span> <span class="ruby-operator">-=</span> <span class="ruby-value">1</span>
296
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">zero?</span>)
297
- <span class="ruby-keyword kw">break</span>
298
- <span class="ruby-keyword kw">end</span>
299
- <span class="ruby-keyword kw">while</span> (<span class="ruby-identifier">y</span> <span class="ruby-operator">&amp;</span> <span class="ruby-value">0x01</span>) <span class="ruby-operator">==</span> <span class="ruby-value">0</span> <span class="ruby-keyword kw">do</span>
300
-
301
- <span class="ruby-identifier">cnt</span><span class="ruby-operator">+</span><span class="ruby-operator">+</span>
302
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">y</span> <span class="ruby-operator">&gt;&gt;</span> <span class="ruby-value">1</span>
303
- <span class="ruby-identifier">x</span> = (<span class="ruby-identifier">x</span><span class="ruby-operator">*</span><span class="ruby-identifier">x</span>)
304
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>)
305
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
306
- <span class="ruby-keyword kw">end</span>
307
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">cnt</span> <span class="ruby-operator">&gt;</span> <span class="ruby-value">1000</span>)
308
- <span class="ruby-identifier">puts</span>(<span class="ruby-node">&quot;ipower x=#{x} y=#{y} cnt=#{cnt} z=#{z}&quot;</span>)
309
- <span class="ruby-identifier">cnt</span> = <span class="ruby-value">0</span>
310
- <span class="ruby-keyword kw">end</span>
311
-
312
- <span class="ruby-keyword kw">end</span>
313
- <span class="ruby-identifier">z</span> = (<span class="ruby-identifier">z</span><span class="ruby-operator">*</span><span class="ruby-identifier">x</span>)
314
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">z</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>)
315
- <span class="ruby-identifier">z</span> = <span class="ruby-identifier">z</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">mode</span>)
316
- <span class="ruby-keyword kw">end</span>
317
-
318
- <span class="ruby-keyword kw">end</span>
319
- <span class="ruby-keyword kw">end</span>
320
- <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">z</span>
321
- <span class="ruby-keyword kw">end</span>
322
-
323
- <span class="ruby-comment cmt">#</span>
324
- <span class="ruby-comment cmt"># internal functionality of exp. exposes some more parameters, that</span>
325
- <span class="ruby-comment cmt"># should usually be set to defaut values, in order to allow better testing.</span>
326
- <span class="ruby-comment cmt"># do not actually call this method unless you are testing exp.</span>
327
- <span class="ruby-comment cmt"># create a bug report, if the default settings for the parameters do</span>
328
- <span class="ruby-comment cmt"># not work correctly</span>
329
- <span class="ruby-comment cmt">#</span>
330
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">power_internal</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">final_mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>, <span class="ruby-identifier">iprec</span> = <span class="ruby-keyword kw">nil</span>, <span class="ruby-identifier">mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_imode</span>)
331
-
332
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">prec</span>.<span class="ruby-identifier">nil?</span>) <span class="ruby-keyword kw">then</span>
333
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>) <span class="ruby-operator">&amp;&amp;</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>)
334
- <span class="ruby-identifier">prec</span> = [<span class="ruby-identifier">x</span>.<span class="ruby-identifier">scale</span>, <span class="ruby-identifier">y</span>.<span class="ruby-identifier">scale</span>].<span class="ruby-identifier">max</span>
335
- <span class="ruby-keyword kw">elsif</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>)
336
- <span class="ruby-identifier">prec</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">scale</span>
337
- <span class="ruby-keyword kw">elsif</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimalBase</span>)
338
- <span class="ruby-identifier">prec</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">scale</span>
339
- <span class="ruby-keyword kw">else</span>
340
- <span class="ruby-identifier">raise</span> <span class="ruby-constant">ArgumentError</span>, <span class="ruby-node">&quot;precision must be supplied either as precision of x=#{x} or explicitely&quot;</span>
341
- <span class="ruby-keyword kw">end</span>
342
- <span class="ruby-keyword kw">end</span>
343
- <span class="ruby-identifier">check_is_prec</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-value str">&quot;prec&quot;</span>)
344
-
345
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">final_mode</span>.<span class="ruby-identifier">nil?</span>)
346
- <span class="ruby-identifier">final_mode</span> = <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>
347
- <span class="ruby-keyword kw">end</span>
348
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">final_mode</span>, <span class="ruby-value str">&quot;final_mode&quot;</span>)
349
- <span class="ruby-identifier">check_is_mode</span>(<span class="ruby-identifier">mode</span>, <span class="ruby-value str">&quot;mode&quot;</span>)
350
-
351
- <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">y</span>.<span class="ruby-identifier">zero?</span> <span class="ruby-keyword kw">then</span>
352
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">one!</span>(<span class="ruby-identifier">prec</span>)
353
- <span class="ruby-keyword kw">elsif</span> <span class="ruby-identifier">x</span>.<span class="ruby-identifier">zero?</span> <span class="ruby-keyword kw">then</span>
354
- <span class="ruby-keyword kw">return</span> <span class="ruby-constant">LongDecimal</span>.<span class="ruby-identifier">zero!</span>(<span class="ruby-identifier">prec</span>)
355
- <span class="ruby-keyword kw">end</span>
356
-
357
- <span class="ruby-keyword kw">if</span> (<span class="ruby-identifier">iprec</span>.<span class="ruby-identifier">nil?</span>) <span class="ruby-keyword kw">then</span>
358
- <span class="ruby-identifier">iprec</span>, <span class="ruby-identifier">iprec_x</span>, <span class="ruby-identifier">iprec_y</span> = <span class="ruby-identifier">calc_iprec_for_power</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">y</span>, <span class="ruby-identifier">prec</span>)
359
- <span class="ruby-keyword kw">end</span>
360
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">x</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>)
361
- <span class="ruby-comment cmt"># x = x.to_ld(iprec, mode)</span>
362
- <span class="ruby-identifier">x</span> = <span class="ruby-identifier">x</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec_x</span>, <span class="ruby-identifier">mode</span>)
363
- <span class="ruby-keyword kw">end</span>
364
- <span class="ruby-keyword kw">unless</span> (<span class="ruby-identifier">y</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">LongDecimal</span>)
365
- <span class="ruby-comment cmt"># y = y.to_ld(iprec, mode)</span>
366
- <span class="ruby-identifier">y</span> = <span class="ruby-identifier">y</span>.<span class="ruby-identifier">to_ld</span>(<span class="ruby-identifier">iprec_y</span>, <span class="ruby-identifier">mode</span>)
367
- <span class="ruby-keyword kw">end</span>
368
-
369
- <span class="ruby-comment cmt"># logx = log(x, iprec, mode)</span>
370
- <span class="ruby-identifier">logx</span> = <span class="ruby-identifier">log</span>(<span class="ruby-identifier">x</span>, <span class="ruby-identifier">iprec</span> <span class="ruby-operator">+</span> <span class="ruby-value">20</span>, <span class="ruby-identifier">mode</span>)
371
- <span class="ruby-identifier">logx_y</span> = <span class="ruby-identifier">logx</span><span class="ruby-operator">*</span><span class="ruby-identifier">y</span>
372
- <span class="ruby-comment cmt"># xy = exp_internal(logx_y, prec + 1, mode)</span>
373
- <span class="ruby-comment cmt"># xy = exp_internal(logx_y, prec + 4, mode)</span>
374
- <span class="ruby-identifier">xy</span> = <span class="ruby-identifier">exp_internal</span>(<span class="ruby-identifier">logx_y</span>, <span class="ruby-identifier">prec</span> <span class="ruby-operator">+</span> <span class="ruby-value">3</span>, <span class="ruby-identifier">mode</span>)
375
- <span class="ruby-identifier">xy</span>.<span class="ruby-identifier">round_to_scale</span>(<span class="ruby-identifier">prec</span>, <span class="ruby-identifier">final_mode</span>)
376
-
377
- <span class="ruby-keyword kw">end</span> <span class="ruby-comment cmt"># power_internal</span>
378
-
379
- <span class="ruby-ivar">@@standard_mode</span> = <span class="ruby-constant">ROUND_HALF_UP</span>
380
-
381
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode</span>
382
- <span class="ruby-ivar">@@standard_mode</span>
383
- <span class="ruby-keyword kw">end</span>
384
-
385
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_mode=</span>(<span class="ruby-identifier">x</span>)
386
- <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">check_is_mode</span>
387
- <span class="ruby-ivar">@@standard_mode</span> = <span class="ruby-identifier">x</span>
388
- <span class="ruby-keyword kw">end</span>
389
-
390
- <span class="ruby-ivar">@@standard_imode</span> = <span class="ruby-constant">ROUND_HALF_EVEN</span>
391
-
392
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_imode</span>
393
- <span class="ruby-ivar">@@standard_imode</span>
394
- <span class="ruby-keyword kw">end</span>
395
-
396
- <span class="ruby-keyword kw">def</span> <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">standard_imode=</span>(<span class="ruby-identifier">x</span>)
397
- <span class="ruby-constant">LongMath</span>.<span class="ruby-identifier">check_is_mode</span>
398
- <span class="ruby-ivar">@@standard_imode</span> = <span class="ruby-identifier">x</span>
399
- <span class="ruby-keyword kw">end</span>
400
-
401
- <span class="ruby-keyword kw">end</span> <span class="ruby-comment cmt"># LongMath</span>
402
-
403
- <span class="ruby-comment cmt"># end of file long-decimal.rb</span>
404
- </pre>
405
- </body>
406
- </html>