bigdecimal-math_r 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (309) hide show
  1. checksums.yaml +7 -0
  2. data/.ruby-version +1 -0
  3. data/CODE_OF_CONDUCT.md +132 -0
  4. data/LICENSE +21 -0
  5. data/LICENSE.txt +21 -0
  6. data/README.md +41 -0
  7. data/Rakefile +13 -0
  8. data/changelog.md +24 -0
  9. data/ext/bigdecimal/math_r/algofunc.h +203 -0
  10. data/ext/bigdecimal/math_r/api/bigdecimal/check_precise.h +12 -0
  11. data/ext/bigdecimal/math_r/api/bigdecimal/infinity.h +6 -0
  12. data/ext/bigdecimal/math_r/api/bigdecimal/minus_infinity.h +5 -0
  13. data/ext/bigdecimal/math_r/api/bigdecimal/minus_one.h +6 -0
  14. data/ext/bigdecimal/math_r/api/bigdecimal/minus_zero.h +6 -0
  15. data/ext/bigdecimal/math_r/api/bigdecimal/nan.h +6 -0
  16. data/ext/bigdecimal/math_r/api/bigdecimal/one.h +6 -0
  17. data/ext/bigdecimal/math_r/api/bigdecimal/sign.h +10 -0
  18. data/ext/bigdecimal/math_r/api/bigdecimal/zero.h +6 -0
  19. data/ext/bigdecimal/math_r/api/bigmath/api_call1.h +5 -0
  20. data/ext/bigdecimal/math_r/api/bigmath/api_call2.h +6 -0
  21. data/ext/bigdecimal/math_r/api/bigmath/atan.h +7 -0
  22. data/ext/bigdecimal/math_r/api/bigmath/atan_adopt.h +42 -0
  23. data/ext/bigdecimal/math_r/api/bigmath/cabs.h +5 -0
  24. data/ext/bigdecimal/math_r/api/bigmath/carg.h +5 -0
  25. data/ext/bigdecimal/math_r/api/bigmath/cexp.h +5 -0
  26. data/ext/bigdecimal/math_r/api/bigmath/clog.h +5 -0
  27. data/ext/bigdecimal/math_r/api/bigmath/const.h +39 -0
  28. data/ext/bigdecimal/math_r/api/bigmath/const_e.h +5 -0
  29. data/ext/bigdecimal/math_r/api/bigmath/const_log10.h +5 -0
  30. data/ext/bigdecimal/math_r/api/bigmath/const_log2.h +5 -0
  31. data/ext/bigdecimal/math_r/api/bigmath/const_log_pi.h +5 -0
  32. data/ext/bigdecimal/math_r/api/bigmath/const_pi.h +5 -0
  33. data/ext/bigdecimal/math_r/api/bigmath/const_sqrt2.h +5 -0
  34. data/ext/bigdecimal/math_r/api/bigmath/const_sqrt3.h +5 -0
  35. data/ext/bigdecimal/math_r/api/bigmath/cpow.h +5 -0
  36. data/ext/bigdecimal/math_r/api/bigmath/csqrt.h +5 -0
  37. data/ext/bigdecimal/math_r/api/bigmath/degree_sparg.h +199 -0
  38. data/ext/bigdecimal/math_r/api/bigmath/escalb.h +5 -0
  39. data/ext/bigdecimal/math_r/api/bigmath/exp.h +5 -0
  40. data/ext/bigdecimal/math_r/api/bigmath/expxt.h +18 -0
  41. data/ext/bigdecimal/math_r/api/bigmath/hypot.h +10 -0
  42. data/ext/bigdecimal/math_r/api/bigmath/ipow.h +14 -0
  43. data/ext/bigdecimal/math_r/api/bigmath/l2norm.h +5 -0
  44. data/ext/bigdecimal/math_r/api/bigmath/log.h +7 -0
  45. data/ext/bigdecimal/math_r/api/bigmath/pow.h +5 -0
  46. data/ext/bigdecimal/math_r/api/bigmath/quadrant.h +5 -0
  47. data/ext/bigdecimal/math_r/api/bigmath/sincos.h +5 -0
  48. data/ext/bigdecimal/math_r/api/bigmath/sqrt.h +5 -0
  49. data/ext/bigdecimal/math_r/api/bigmath/to_rad.h +41 -0
  50. data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal.h +6 -0
  51. data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal1.h +6 -0
  52. data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal_flo.h +9 -0
  53. data/ext/bigdecimal/math_r/api/kernel/rb_ImaginaryZ.h +8 -0
  54. data/ext/bigdecimal/math_r/api/numanalysis/condition_p.h +26 -0
  55. data/ext/bigdecimal/math_r/api/numanalysis/make_n.h +9 -0
  56. data/ext/bigdecimal/math_r/api/numeric/abs.h +7 -0
  57. data/ext/bigdecimal/math_r/api/numeric/canonicalize.h +140 -0
  58. data/ext/bigdecimal/math_r/api/numeric/cmpeql.h +6 -0
  59. data/ext/bigdecimal/math_r/api/numeric/equal_p.h +6 -0
  60. data/ext/bigdecimal/math_r/api/numeric/finite_p.h +6 -0
  61. data/ext/bigdecimal/math_r/api/numeric/imag.h +6 -0
  62. data/ext/bigdecimal/math_r/api/numeric/infinite_p.h +7 -0
  63. data/ext/bigdecimal/math_r/api/numeric/nan_p.h +5 -0
  64. data/ext/bigdecimal/math_r/api/numeric/negative_p.h +6 -0
  65. data/ext/bigdecimal/math_r/api/numeric/nonzero_p.h +6 -0
  66. data/ext/bigdecimal/math_r/api/numeric/notequal_p.h +6 -0
  67. data/ext/bigdecimal/math_r/api/numeric/numeric_p.h +5 -0
  68. data/ext/bigdecimal/math_r/api/numeric/positive_p.h +6 -0
  69. data/ext/bigdecimal/math_r/api/numeric/real.h +6 -0
  70. data/ext/bigdecimal/math_r/api/numeric/real_p.h +6 -0
  71. data/ext/bigdecimal/math_r/api/numeric/round.h +56 -0
  72. data/ext/bigdecimal/math_r/api/numeric/uminus.h +6 -0
  73. data/ext/bigdecimal/math_r/api/numeric/zero_p.h +6 -0
  74. data/ext/bigdecimal/math_r/api.c +13 -0
  75. data/ext/bigdecimal/math_r/api.h +69 -0
  76. data/ext/bigdecimal/math_r/const.c +186 -0
  77. data/ext/bigdecimal/math_r/decl.h +203 -0
  78. data/ext/bigdecimal/math_r/edf.c +180 -0
  79. data/ext/bigdecimal/math_r/erf.c +80 -0
  80. data/ext/bigdecimal/math_r/euler_f.c +572 -0
  81. data/ext/bigdecimal/math_r/exp.c +72 -0
  82. data/ext/bigdecimal/math_r/extconf.rb +185 -0
  83. data/ext/bigdecimal/math_r/gamma_r.c +251 -0
  84. data/ext/bigdecimal/math_r/hyperb.c +172 -0
  85. data/ext/bigdecimal/math_r/internal/algo/bigmath/E/ser.h +22 -0
  86. data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG10/ser.h +16 -0
  87. data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG2/BBP2002.h +36 -0
  88. data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG_PI/builtin.h +7 -0
  89. data/ext/bigdecimal/math_r/internal/algo/bigmath/PI/machin.h +48 -0
  90. data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT2/builtin.h +5 -0
  91. data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT3/builtin.h +5 -0
  92. data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/branch.h +25 -0
  93. data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/edom.h +15 -0
  94. data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/logrep.h +19 -0
  95. data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/ser.h +34 -0
  96. data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/branch.h +19 -0
  97. data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/edom.h +17 -0
  98. data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/logrep.h +14 -0
  99. data/ext/bigdecimal/math_r/internal/algo/bigmath/acot/branch.h +16 -0
  100. data/ext/bigdecimal/math_r/internal/algo/bigmath/acot/logrep.h +13 -0
  101. data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/branch.h +20 -0
  102. data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/edom.h +18 -0
  103. data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/logrep.h +33 -0
  104. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/branch.h +21 -0
  105. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/edom.h +20 -0
  106. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/logrep.h +16 -0
  107. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/branch.h +25 -0
  108. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/logrep.h +25 -0
  109. data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/branch.h +22 -0
  110. data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/edom.h +16 -0
  111. data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/logrep.h +21 -0
  112. data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/branch.h +18 -0
  113. data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/edom.h +19 -0
  114. data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/logrep.h +16 -0
  115. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/branch.h +22 -0
  116. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/edom.h +20 -0
  117. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/logrep.h +15 -0
  118. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/ser.h +32 -0
  119. data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/branch.h +26 -0
  120. data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/logrep.h +24 -0
  121. data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/ser.h +48 -0
  122. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/branch.h +16 -0
  123. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/logrep.h +14 -0
  124. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_euler.h +84 -0
  125. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_usual.h +41 -0
  126. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/branch.h +24 -0
  127. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/edom.h +16 -0
  128. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/logrep.h +16 -0
  129. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/ser.h +33 -0
  130. data/ext/bigdecimal/math_r/internal/algo/bigmath/cabs/formula.h +8 -0
  131. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacos/branch.h +38 -0
  132. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacos/logrep.h +16 -0
  133. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacosh/branch.h +34 -0
  134. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacosh/logrep.h +17 -0
  135. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacot/branch.h +39 -0
  136. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacot/logrep.h +17 -0
  137. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacoth/branch.h +29 -0
  138. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacoth/logrep.h +11 -0
  139. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsc/branch.h +28 -0
  140. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsc/logrep.h +19 -0
  141. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsch/branch.h +18 -0
  142. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsch/logrep.h +11 -0
  143. data/ext/bigdecimal/math_r/internal/algo/bigmath/carg/formula.h +8 -0
  144. data/ext/bigdecimal/math_r/internal/algo/bigmath/casec/branch.h +29 -0
  145. data/ext/bigdecimal/math_r/internal/algo/bigmath/casec/logrep.h +18 -0
  146. data/ext/bigdecimal/math_r/internal/algo/bigmath/casech/branch.h +38 -0
  147. data/ext/bigdecimal/math_r/internal/algo/bigmath/casech/logrep.h +9 -0
  148. data/ext/bigdecimal/math_r/internal/algo/bigmath/casin/branch.h +35 -0
  149. data/ext/bigdecimal/math_r/internal/algo/bigmath/casin/logrep.h +14 -0
  150. data/ext/bigdecimal/math_r/internal/algo/bigmath/casinh/branch.h +59 -0
  151. data/ext/bigdecimal/math_r/internal/algo/bigmath/casinh/logrep.h +13 -0
  152. data/ext/bigdecimal/math_r/internal/algo/bigmath/catan/branch.h +46 -0
  153. data/ext/bigdecimal/math_r/internal/algo/bigmath/catan/logrep.h +17 -0
  154. data/ext/bigdecimal/math_r/internal/algo/bigmath/catanh/branch.h +26 -0
  155. data/ext/bigdecimal/math_r/internal/algo/bigmath/catanh/logrep.h +10 -0
  156. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccbrt/formula.h +11 -0
  157. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccos/branch.h +41 -0
  158. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccos/eulerf.h +11 -0
  159. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccosh/branch.h +37 -0
  160. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccosh/eulerf.h +11 -0
  161. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccot/branch.h +46 -0
  162. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccot/eulerf.h +11 -0
  163. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccoth/branch.h +43 -0
  164. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccoth/eulerf.h +11 -0
  165. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsc/branch.h +42 -0
  166. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsc/eulerf.h +11 -0
  167. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsch/branch.h +38 -0
  168. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsch/eulerf.h +11 -0
  169. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp/branch.h +42 -0
  170. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp/eulerf.h +21 -0
  171. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp2/branch.h +42 -0
  172. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp2/eulerf.h +12 -0
  173. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog/branch.h +54 -0
  174. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog/formula.h +13 -0
  175. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog10/formula.h +12 -0
  176. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog1p/branch.h +34 -0
  177. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog2/formula.h +12 -0
  178. data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/branch.h +21 -0
  179. data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/eulerf.h +11 -0
  180. data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/ser.h +12 -0
  181. data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/branch.h +22 -0
  182. data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/eulerf.h +11 -0
  183. data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/formula.h +30 -0
  184. data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/ser.h +11 -0
  185. data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/branch.h +28 -0
  186. data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/eulerf.h +11 -0
  187. data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/ser.h +12 -0
  188. data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/branch.h +23 -0
  189. data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/eulerf.h +11 -0
  190. data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/formula.h +30 -0
  191. data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/ser.h +13 -0
  192. data/ext/bigdecimal/math_r/internal/algo/bigmath/cpow/formula.h +20 -0
  193. data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/branch.h +28 -0
  194. data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/eulerf.h +11 -0
  195. data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/ser.h +11 -0
  196. data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/branch.h +23 -0
  197. data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/eulerf.h +11 -0
  198. data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/formula.h +31 -0
  199. data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/ser.h +11 -0
  200. data/ext/bigdecimal/math_r/internal/algo/bigmath/csec/branch.h +42 -0
  201. data/ext/bigdecimal/math_r/internal/algo/bigmath/csec/eulerf.h +11 -0
  202. data/ext/bigdecimal/math_r/internal/algo/bigmath/csech/branch.h +38 -0
  203. data/ext/bigdecimal/math_r/internal/algo/bigmath/csech/eulerf.h +11 -0
  204. data/ext/bigdecimal/math_r/internal/algo/bigmath/csin/branch.h +44 -0
  205. data/ext/bigdecimal/math_r/internal/algo/bigmath/csin/eulerf.h +11 -0
  206. data/ext/bigdecimal/math_r/internal/algo/bigmath/csinh/branch.h +41 -0
  207. data/ext/bigdecimal/math_r/internal/algo/bigmath/csinh/eulerf.h +11 -0
  208. data/ext/bigdecimal/math_r/internal/algo/bigmath/csqrt/formula.h +66 -0
  209. data/ext/bigdecimal/math_r/internal/algo/bigmath/ctan/branch.h +46 -0
  210. data/ext/bigdecimal/math_r/internal/algo/bigmath/ctan/eulerf.h +11 -0
  211. data/ext/bigdecimal/math_r/internal/algo/bigmath/ctanh/branch.h +43 -0
  212. data/ext/bigdecimal/math_r/internal/algo/bigmath/ctanh/eulerf.h +11 -0
  213. data/ext/bigdecimal/math_r/internal/algo/bigmath/cuberoot/newton.h +42 -0
  214. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/algo911.h +41 -0
  215. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/branch.h +18 -0
  216. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/cf.h +51 -0
  217. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_inf.h +53 -0
  218. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_zero.h +45 -0
  219. data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/algo911.h +27 -0
  220. data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/branch.h +18 -0
  221. data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/cf.h +49 -0
  222. data/ext/bigdecimal/math_r/internal/algo/bigmath/escalb/edf.h +87 -0
  223. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/branch.h +29 -0
  224. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/builtin.h +6 -0
  225. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/edf.h +23 -0
  226. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp2/branch.h +29 -0
  227. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp2/edf.h +19 -0
  228. data/ext/bigdecimal/math_r/internal/algo/bigmath/expxt/edf.h +31 -0
  229. data/ext/bigdecimal/math_r/internal/algo/bigmath/f_euler/formula.h +11 -0
  230. data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/branch.h +25 -0
  231. data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/l2norm.h +11 -0
  232. data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/mmm.h +38 -0
  233. data/ext/bigdecimal/math_r/internal/algo/bigmath/ipow/edf.h +33 -0
  234. data/ext/bigdecimal/math_r/internal/algo/bigmath/l2norm/formula.h +48 -0
  235. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/branch.h +40 -0
  236. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/builtin.h +12 -0
  237. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edf.h +10 -0
  238. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edom.h +10 -0
  239. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/mercator.h +34 -0
  240. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/ser_okumura.h +57 -0
  241. data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/branch.h +40 -0
  242. data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/edf.h +11 -0
  243. data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/mercator.h +35 -0
  244. data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/branch.h +34 -0
  245. data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/p_adic.h +37 -0
  246. data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/ser_mercator.h +35 -0
  247. data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/branch.h +40 -0
  248. data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/edf.h +11 -0
  249. data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/mercator.h +35 -0
  250. data/ext/bigdecimal/math_r/internal/algo/bigmath/logxt/edf.h +33 -0
  251. data/ext/bigdecimal/math_r/internal/algo/bigmath/pow/formula.h +30 -0
  252. data/ext/bigdecimal/math_r/internal/algo/bigmath/quadrant/formula.h +352 -0
  253. data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm10/edf.h +34 -0
  254. data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm2/edf.h +34 -0
  255. data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/branch.h +27 -0
  256. data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/eulerf.h +11 -0
  257. data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/ser.h +11 -0
  258. data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/branch.h +21 -0
  259. data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/eulerf.h +11 -0
  260. data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/formula.h +25 -0
  261. data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/ser.h +11 -0
  262. data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/branch.h +23 -0
  263. data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/eulerf.h +11 -0
  264. data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/ser.h +13 -0
  265. data/ext/bigdecimal/math_r/internal/algo/bigmath/sincos/ser.h +50 -0
  266. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/branch.h +23 -0
  267. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/eulerf.h +11 -0
  268. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/formula.h +26 -0
  269. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/ser.h +11 -0
  270. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinhcosh/ser.h +70 -0
  271. data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/branch.h +16 -0
  272. data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/builtin.h +12 -0
  273. data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/edom.h +9 -0
  274. data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/newton.h +36 -0
  275. data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/branch.h +26 -0
  276. data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/eulerf.h +11 -0
  277. data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/ser.h +18 -0
  278. data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/branch.h +23 -0
  279. data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/eulerf.h +11 -0
  280. data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/formula.h +27 -0
  281. data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/ser.h +14 -0
  282. data/ext/bigdecimal/math_r/internal/algo/bigmath/trig/f_euler.h +290 -0
  283. data/ext/bigdecimal/math_r/log.c +256 -0
  284. data/ext/bigdecimal/math_r/logrep.c +537 -0
  285. data/ext/bigdecimal/math_r/math_r/bigdecimal.h +30 -0
  286. data/ext/bigdecimal/math_r/math_r/bigmath.h +61 -0
  287. data/ext/bigdecimal/math_r/math_r/bigmath_r.h +9 -0
  288. data/ext/bigdecimal/math_r/math_r/ext_extern.h +18 -0
  289. data/ext/bigdecimal/math_r/math_r/globals.h +71 -0
  290. data/ext/bigdecimal/math_r/math_r/numdiff.h +18 -0
  291. data/ext/bigdecimal/math_r/math_r/numeric.h +63 -0
  292. data/ext/bigdecimal/math_r/math_r.c +130 -0
  293. data/ext/bigdecimal/math_r/nucomp.c +158 -0
  294. data/ext/bigdecimal/math_r/overrides.c +91 -0
  295. data/ext/bigdecimal/math_r/power.c +207 -0
  296. data/ext/bigdecimal/math_r/solver.c +1516 -0
  297. data/ext/bigdecimal/math_r/trig.c +205 -0
  298. data/lib/bigdecimal/math_r/const/EulerGamma_engel.rb +46 -0
  299. data/lib/bigdecimal/math_r/const/LOG2_bbp2007.rb +39 -0
  300. data/lib/bigdecimal/math_r/const/PI_chudnovsky.rb +59 -0
  301. data/lib/bigdecimal/math_r/const/PI_euler.rb +40 -0
  302. data/lib/bigdecimal/math_r/const/PI_ramanujan1.rb +45 -0
  303. data/lib/bigdecimal/math_r/const/PI_ramanujan2.rb +46 -0
  304. data/lib/bigdecimal/math_r/const/b053977/b053977.txt +306 -0
  305. data/lib/bigdecimal/math_r/version.rb +7 -0
  306. data/lib/bigdecimal/math_r.rb +12 -0
  307. data/lib/bigdecimal/math_r.so +0 -0
  308. data/sig/bigdecimal/math_r.rbs +6 -0
  309. metadata +393 -0
@@ -0,0 +1,38 @@
1
+ VALUE
2
+ casech_branch(VALUE z, VALUE prec, bigmath_func1 casech_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+ int z_re_inf = rb_num_infinite_p(rb_num_real(z));
6
+ int z_im_inf = rb_num_infinite_p(rb_num_imag(z));
7
+
8
+ if (rb_num_nan_p(z))
9
+ w = rb_Complex(BIG_NAN, BIG_NAN);
10
+ else if (z_re_inf || z_im_inf)
11
+ {
12
+ const ID div = rb_intern("div");
13
+ if (z_re_inf != 0 && z_im_inf == 0)
14
+ {
15
+ VALUE imag = rb_funcall(rb_bigmath_const_pi(prec), div,
16
+ 2, INT2FIX(2), prec);
17
+ w = rb_Complex(BIG_ZERO, imag);
18
+ }
19
+ else if (z_re_inf == 0 && z_im_inf != 0)
20
+ {
21
+ VALUE imag = rb_funcall(rb_bigmath_const_pi(prec), div,
22
+ 2, INT2FIX(-2 * z_im_inf), prec);
23
+ w = rb_Complex(BIG_ZERO, imag);
24
+ }
25
+ else if (z_re_inf == -1 && z_im_inf == 1)
26
+ w = rb_Complex(BIG_NAN, BIG_NAN);
27
+ else
28
+ w = rb_Complex(BIG_ZERO, BIG_ZERO);
29
+ }
30
+ else
31
+ {
32
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
33
+ w = casech_cb(z, prec);
34
+ }
35
+
36
+ return w;
37
+ }
38
+
@@ -0,0 +1,9 @@
1
+ VALUE
2
+ casech_logrep(VALUE z, VALUE prec)
3
+ {
4
+ rb_check_precise(prec);
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RECIPROCAL);
7
+
8
+ return cacosh_logrep(z, prec);
9
+ }
@@ -0,0 +1,35 @@
1
+ VALUE
2
+ casin_branch(VALUE z, VALUE prec, bigmath_func1 casin_cb)
3
+ {
4
+ int z_re_inf = rb_num_infinite_p(rb_num_real(z));
5
+ int z_im_inf = rb_num_infinite_p(rb_num_imag(z));
6
+
7
+ if (rb_num_nan_p(z))
8
+ return rb_Complex(BIG_NAN, BIG_NAN);
9
+ else if (z_re_inf || z_im_inf)
10
+ {
11
+ const ID div = rb_intern("div");
12
+ if (z_re_inf != 0 && z_im_inf == 0)
13
+ {
14
+ VALUE real = rb_num_zero_p(rb_num_imag(z)) ?
15
+ rb_funcall(rb_bigmath_const_pi(prec), div, 2,
16
+ INT2FIX(z_re_inf * 2), prec) :
17
+ BIG_ZERO;
18
+ VALUE imag = z_re_inf == 1 ? BIG_MINUS_INF : BIG_INF;
19
+ return rb_Complex(real, imag);
20
+ }
21
+ else if (z_re_inf == 0 && z_im_inf != 0)
22
+ {
23
+ return rb_Complex(BIG_ZERO, rb_num_imag(z));
24
+ }
25
+ else if (z_re_inf == -1 && z_im_inf == 1)
26
+ return rb_Complex(BIG_NAN, BIG_NAN);
27
+ else
28
+ return rb_Complex(BIG_ZERO, BIG_ZERO);
29
+ }
30
+ else
31
+ {
32
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
33
+ return casin_cb(z, prec);
34
+ }
35
+ }
@@ -0,0 +1,14 @@
1
+ VALUE
2
+ casin_logrep(VALUE z, VALUE prec)
3
+ {
4
+ VALUE c1, c2, c3;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ c1 = rb_ImaginaryZ(z, SIGN_PLUS);
9
+ c2 = rb_bigmath_csqrt(
10
+ rb_funcall1(BIG_ONE, '-', rb_funcall1(z, '*', z)), prec);
11
+ c3 = rb_bigmath_clog(rb_funcall1(c1, '+', c2), prec);
12
+
13
+ return rb_ImaginaryZ(c3, SIGN_MINUS);
14
+ }
@@ -0,0 +1,59 @@
1
+ VALUE
2
+ casinh_branch(VALUE z, VALUE prec, bigmath_func1 casinh_cb)
3
+ {
4
+ VALUE y = Qundef;
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
7
+
8
+ if (!rb_num_finite_p(z))
9
+ {
10
+ if (rb_num_infinite_p(rb_num_imag(z)) == 0)
11
+ {
12
+ switch (rb_num_infinite_p(rb_num_real(z))) {
13
+ case 1:
14
+ y = rb_Complex(BIG_INF, BIG_ZERO);
15
+ break;
16
+ case -1:
17
+ y = rb_Complex(BIG_MINUS_INF, BIG_ZERO);
18
+ break;
19
+ }
20
+ }
21
+ else if (rb_num_infinite_p(rb_num_real(z)) == 0)
22
+ {
23
+ if (rb_num_zero_p(rb_num_real(z)))
24
+ {
25
+ switch (rb_num_infinite_p(rb_num_imag(z))) {
26
+ case 1:
27
+ y = rb_Complex(BIG_INF, rb_bigmath_const_pi(prec));
28
+ break;
29
+ case -1:
30
+ y = rb_Complex(BIG_ZERO, BIG_ZERO);
31
+ break;
32
+ }
33
+ }
34
+ else
35
+ {
36
+ const ID div = rb_intern("div");
37
+ VALUE pi_2 = rb_funcall(rb_bigmath_const_pi(prec), div, 2, INT2FIX(2), prec);
38
+ switch (rb_num_infinite_p(rb_num_imag(z))) {
39
+ case 1:
40
+ y = rb_Complex(BIG_INF, pi_2);
41
+ break;
42
+ case -1:
43
+ pi_2 = rb_num_uminus(pi_2);
44
+ y = rb_Complex(BIG_ZERO, pi_2);
45
+ break;
46
+ }
47
+ }
48
+ }
49
+ else
50
+ {
51
+ y = rb_Complex(BIG_NAN, BIG_NAN);
52
+ }
53
+ }
54
+ if (y == Qundef)
55
+ {
56
+ y = casinh_cb(z, prec);
57
+ }
58
+ return y;
59
+ }
@@ -0,0 +1,13 @@
1
+ VALUE
2
+ casinh_logrep(VALUE z, VALUE prec)
3
+ {
4
+ VALUE n, t, y;
5
+
6
+ n = rb_numdiff_make_n(prec);
7
+
8
+ t = rb_funcall1(rb_funcall1(z, '*', z), '+', BIG_ONE);
9
+ t = rb_bigmath_csqrt(t, n);
10
+ y = rb_bigmath_clog(rb_funcall1(z, '+', t), n);
11
+
12
+ return rb_num_round(y, prec);
13
+ }
@@ -0,0 +1,46 @@
1
+ VALUE
2
+ catan_branch(VALUE z, VALUE prec, bigmath_func1 catan_cb)
3
+ {
4
+ #define rb_Complex_I rb_Complex(INT2FIX(0), INT2FIX(1))
5
+ #define rb_Complex_mI rb_Complex(INT2FIX(0), INT2FIX(-1))
6
+ int z_re_inf = rb_num_infinite_p(rb_num_real(z));
7
+ int z_im_inf = rb_num_infinite_p(rb_num_imag(z));
8
+
9
+ if (rb_num_nan_p(z))
10
+ return rb_Complex(BIG_NAN, BIG_NAN);
11
+ else if (z_re_inf || z_im_inf)
12
+ {
13
+ const ID div = rb_intern("div");
14
+ if (z_re_inf != 0 && z_im_inf == 0)
15
+ {
16
+ VALUE real =
17
+ rb_funcall(rb_bigmath_const_pi(prec), div, 2,
18
+ INT2FIX(z_re_inf * 2), prec);
19
+ VALUE imag = BIG_ZERO;
20
+ return rb_Complex(real, imag);
21
+ }
22
+ else if (z_re_inf == 0 && z_im_inf != 0)
23
+ {
24
+ VALUE real =
25
+ rb_funcall(rb_bigmath_const_pi(prec), div, 2,
26
+ INT2FIX(z_im_inf * 2), prec);
27
+ VALUE imag = BIG_ZERO;
28
+ return rb_Complex(real, imag);
29
+ }
30
+ else if (z_re_inf == -1 && z_im_inf == 1)
31
+ return rb_Complex(BIG_NAN, BIG_NAN);
32
+ else
33
+ return rb_Complex(BIG_ZERO, BIG_ZERO);
34
+ }
35
+ else if (rb_num_equal_p(z, rb_Complex_I))
36
+ return rb_Complex(BIG_ZERO, BIG_INF);
37
+ else if (rb_num_equal_p(z, rb_Complex_mI))
38
+ return rb_Complex(BIG_ZERO, BIG_MINUS_INF);
39
+ else
40
+ {
41
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
42
+ return catan_cb(z, prec);
43
+ }
44
+ #undef rb_Complex_I
45
+ #undef rb_Complex_mI
46
+ }
@@ -0,0 +1,17 @@
1
+ VALUE
2
+ catan_logrep(VALUE z, VALUE prec)
3
+ {
4
+ VALUE c1, c2, c3;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ c1 = rb_ImaginaryZ(z, SIGN_PLUS);
9
+ c2 = rb_funcall1(rb_Complex(BIG_ONE, rb_num_uminus(z)), '/',
10
+ rb_Complex(BIG_ONE, z));
11
+ c3 = rb_bigmath_clog(c2, prec);
12
+
13
+ c1 = rb_Complex(INT2FIX(0), rb_Rational(INT2FIX(1), INT2FIX(2)));
14
+ c2 = rb_funcall1(c1, '*', c3);
15
+
16
+ return rb_num_round(c2, prec);
17
+ }
@@ -0,0 +1,26 @@
1
+ VALUE
2
+ catanh_branch(VALUE z, VALUE prec, bigmath_func1 catanh_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
7
+
8
+ if (rb_num_nan_p(z))
9
+ w = rb_Complex(BIG_NAN, BIG_NAN);
10
+ else if (rb_num_infinite_p(z) != 0)
11
+ {
12
+ const ID div = rb_intern("div");
13
+ VALUE pi_2 = rb_funcall(
14
+ rb_bigmath_const_pi(prec), div, 2, INT2FIX(2), prec);
15
+ if (rb_num_negative_p(rb_num_imag(z)))
16
+ pi_2 = rb_num_uminus(pi_2);
17
+ w = rb_Complex(BIG_ZERO, pi_2);
18
+ }
19
+ else
20
+ {
21
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
22
+ w = catanh_cb(z, prec);
23
+ }
24
+
25
+ return w;
26
+ }
@@ -0,0 +1,10 @@
1
+ VALUE
2
+ catanh_logrep(VALUE z, VALUE prec)
3
+ {
4
+ rb_check_precise(prec);
5
+
6
+ z = rb_ImaginaryZ(z, SIGN_PLUS);
7
+ z = catan_logrep(z, prec);
8
+
9
+ return rb_ImaginaryZ(z, SIGN_MINUS);
10
+ }
@@ -0,0 +1,11 @@
1
+ VALUE
2
+ ccbrt_formula(VALUE z, VALUE prec)
3
+ {
4
+ VALUE one_third;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ one_third = rb_Rational(INT2FIX(1), INT2FIX(3));
9
+
10
+ return rb_bigmath_cpow(z, one_third, prec);
11
+ }
@@ -0,0 +1,41 @@
1
+ VALUE
2
+ ccos_branch(VALUE z, VALUE prec, bigmath_func1 ccos_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
7
+
8
+ if (!rb_num_finite_p(z))
9
+ {
10
+ if (rb_num_nan_p(z) || rb_num_finite_p(rb_num_imag(z)))
11
+ {
12
+ if (rb_num_zero_p(rb_num_imag(z)))
13
+ w = rb_Complex(BIG_NAN, BIG_ZERO);
14
+ else
15
+ w = rb_Complex(BIG_NAN, BIG_NAN);
16
+ }
17
+ else if (rb_num_finite_p(rb_num_real(z)))
18
+ {
19
+ w = rb_Complex(BIG_INF, BIG_ZERO);
20
+ }
21
+ else
22
+ w = rb_Complex(BIG_NAN, BIG_NAN);
23
+ }
24
+ if (w == Qundef)
25
+ {
26
+ VALUE real = rb_num_real(z), imag = rb_num_imag(z);
27
+ VALUE t = Qundef;
28
+ VALUE v_cos = Qundef;
29
+ real = rb_bigmath_to_rad(real, prec, &t);
30
+ if (-1 != rb_bigmath_degree_sparg(t, prec, NULL, &v_cos) &&
31
+ rb_num_zero_p(imag))
32
+ {
33
+ w = rb_Complex(v_cos, BIG_ZERO);
34
+ }
35
+ else
36
+ {
37
+ w = ccos_cb(rb_Complex(real, imag), prec);
38
+ }
39
+ }
40
+ return w;
41
+ }
@@ -0,0 +1,11 @@
1
+ VALUE
2
+ ccos_eulerf(VALUE z, VALUE prec)
3
+ {
4
+ VALUE w;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ w = trig_f_euler(mf_cos, rb_ImaginaryZ(z, SIGN_PLUS), prec);
9
+
10
+ return w;
11
+ }
@@ -0,0 +1,37 @@
1
+ VALUE
2
+ ccosh_branch(VALUE z, VALUE prec, bigmath_func1 ccosh_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+ if (!rb_num_finite_p(z))
6
+ {
7
+ if (rb_num_infinite_p(z) != 0 && rb_num_zero_p(rb_num_imag(z)))
8
+ {
9
+ w = rb_Complex(BIG_INF, BIG_ZERO);
10
+ }
11
+ else
12
+ {
13
+ w = BIG_NAN;
14
+ if (rb_num_nan_p(rb_num_real(w)) && rb_num_zero_p(rb_num_imag(z)))
15
+ w = rb_Complex(w, BIG_ZERO);
16
+ else
17
+ w = rb_Complex(w, BIG_NAN);
18
+ }
19
+ }
20
+ if (w == Qundef)
21
+ {
22
+ VALUE real = rb_num_real(z), imag = rb_num_imag(z);
23
+ VALUE t = Qundef;
24
+ VALUE v_cos = Qundef;
25
+ imag = rb_bigmath_to_rad(imag, prec, &t);
26
+ if (-1 != rb_bigmath_degree_sparg(t, prec, NULL, &v_cos) &&
27
+ rb_num_zero_p(real))
28
+ {
29
+ w = rb_Complex(BIG_ZERO, v_cos);
30
+ }
31
+ else
32
+ {
33
+ w = ccosh_cb(rb_Complex(real, imag), prec);
34
+ }
35
+ }
36
+ return w;
37
+ }
@@ -0,0 +1,11 @@
1
+ VALUE
2
+ ccosh_eulerf(VALUE z, VALUE prec)
3
+ {
4
+ VALUE w;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ w = trig_f_euler(mf_cos, z, prec);
9
+
10
+ return w;
11
+ }
@@ -0,0 +1,46 @@
1
+ VALUE
2
+ ccot_branch(VALUE z, VALUE prec, bigmath_func1 ccot_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
7
+
8
+ if (!rb_num_finite_p(z))
9
+ {
10
+ if (rb_num_nan_p(z) || rb_num_finite_p(rb_num_imag(z)))
11
+ {
12
+ if (rb_num_zero_p(rb_num_imag(z)))
13
+ w = rb_Complex(BIG_NAN, BIG_ZERO);
14
+ else
15
+ w = rb_Complex(BIG_NAN, BIG_NAN);
16
+ }
17
+ else if (rb_num_finite_p(rb_num_real(z)))
18
+ {
19
+ if (rb_num_negative_p(rb_num_imag(z)))
20
+ w = rb_Complex(BIG_ZERO, BIG_ONE);
21
+ else
22
+ w = rb_Complex(BIG_ZERO, BIG_MINUS_ONE);
23
+ }
24
+ else
25
+ w = rb_Complex(BIG_NAN, BIG_NAN);
26
+ }
27
+ if (w == Qundef)
28
+ {
29
+ VALUE real = rb_num_real(z), imag = rb_num_imag(z);
30
+ VALUE t = Qundef;
31
+ VALUE v_sin = Qundef, v_cos = Qundef;
32
+ real = rb_bigmath_to_rad(real, prec, &t);
33
+ if (-1 != rb_bigmath_degree_sparg(t, prec, &v_sin, &v_cos) &&
34
+ rb_num_zero_p(imag))
35
+ {
36
+ const ID div = rb_intern("div");
37
+ w = rb_funcall(v_cos, div, 2, v_sin, prec);
38
+ w = rb_Complex(w, BIG_ZERO);
39
+ }
40
+ else
41
+ {
42
+ w = ccot_cb(rb_Complex(real, imag), prec);
43
+ }
44
+ }
45
+ return w;
46
+ }
@@ -0,0 +1,11 @@
1
+ VALUE
2
+ ccot_eulerf(VALUE z, VALUE prec)
3
+ {
4
+ VALUE w;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ w = trig_f_euler(mf_tan, rb_ImaginaryZ(z, SIGN_PLUS), prec);
9
+
10
+ return rb_num_canonicalize(w, prec, ARG_COMPLEX, ARG_RECIPROCAL);
11
+ }
@@ -0,0 +1,43 @@
1
+ VALUE
2
+ ccoth_branch(VALUE z, VALUE prec, bigmath_func1 ccoth_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
7
+
8
+ if (!rb_num_finite_p(z))
9
+ {
10
+ if (rb_num_infinite_p(z) != 0 && rb_num_zero_p(rb_num_imag(z)))
11
+ {
12
+ w = rb_num_negative_p(rb_num_real(z)) ? BIG_MINUS_ONE : BIG_ONE;
13
+ w = rb_Complex(w, BIG_ZERO);
14
+ }
15
+ else
16
+ {
17
+ w = BIG_NAN;
18
+ if (rb_num_nan_p(rb_num_real(w)) && rb_num_zero_p(rb_num_imag(z)))
19
+ w = rb_Complex(w, BIG_ZERO);
20
+ else
21
+ w = rb_Complex(w, BIG_NAN);
22
+ }
23
+ }
24
+ if (w == Qundef)
25
+ {
26
+ VALUE real = rb_num_real(z), imag = rb_num_imag(z);
27
+ VALUE t = Qundef;
28
+ VALUE v_sin = Qundef, v_cos = Qundef;
29
+ imag = rb_bigmath_to_rad(imag, prec, &t);
30
+ if (-1 != rb_bigmath_degree_sparg(t, prec, &v_sin, &v_cos) &&
31
+ rb_num_zero_p(real))
32
+ {
33
+ const ID div = rb_intern("div");
34
+ w = rb_funcall(v_cos, div, 2, v_sin, prec);
35
+ w = rb_Complex(BIG_ZERO, w);
36
+ }
37
+ else
38
+ {
39
+ w = ccoth_cb(rb_Complex(real, imag), prec);
40
+ }
41
+ }
42
+ return w;
43
+ }
@@ -0,0 +1,11 @@
1
+ VALUE
2
+ ccoth_eulerf(VALUE z, VALUE prec)
3
+ {
4
+ VALUE w;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ w = rb_ImaginaryZ(trig_f_euler(mf_tan, z, prec), SIGN_PLUS);
9
+
10
+ return rb_num_canonicalize(w, prec, ARG_COMPLEX, ARG_RECIPROCAL);
11
+ }
@@ -0,0 +1,42 @@
1
+ VALUE
2
+ ccsc_branch(VALUE z, VALUE prec, bigmath_func1 ccsc_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
7
+
8
+ if (!rb_num_finite_p(z))
9
+ {
10
+ if (rb_num_nan_p(z) || rb_num_finite_p(rb_num_imag(z)))
11
+ {
12
+ if (rb_num_zero_p(rb_num_imag(z)))
13
+ w = rb_Complex(BIG_NAN, BIG_ZERO);
14
+ else
15
+ w = rb_Complex(BIG_NAN, BIG_NAN);
16
+ }
17
+ else if (rb_num_finite_p(rb_num_real(z)))
18
+ {
19
+ w = rb_Complex(BIG_ZERO, BIG_ZERO);
20
+ }
21
+ else
22
+ w = rb_Complex(BIG_NAN, BIG_NAN);
23
+ }
24
+ if (w == Qundef)
25
+ {
26
+ VALUE real = rb_num_real(z), imag = rb_num_imag(z);
27
+ VALUE t = Qundef;
28
+ VALUE v_sin = Qundef;
29
+ real = rb_bigmath_to_rad(real, prec, &t);
30
+ if (-1 != rb_bigmath_degree_sparg(t, prec, &v_sin, NULL) &&
31
+ rb_num_zero_p(imag))
32
+ {
33
+ v_sin = rb_num_canonicalize(v_sin, prec, ARG_REAL, ARG_RECIPROCAL);
34
+ w = rb_Complex(v_sin, BIG_ZERO);
35
+ }
36
+ else
37
+ {
38
+ w = ccsc_cb(rb_Complex(real, imag), prec);
39
+ }
40
+ }
41
+ return w;
42
+ }
@@ -0,0 +1,11 @@
1
+ VALUE
2
+ ccsc_eulerf(VALUE z, VALUE prec)
3
+ {
4
+ VALUE w;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ w = trig_f_euler(mf_sin, rb_ImaginaryZ(z, SIGN_PLUS), prec);
9
+
10
+ return rb_num_canonicalize(w, prec, ARG_COMPLEX, ARG_RECIPROCAL);
11
+ }
@@ -0,0 +1,38 @@
1
+ VALUE
2
+ ccsch_branch(VALUE z, VALUE prec, bigmath_func1 ccsch_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+ if (!rb_num_finite_p(z))
6
+ {
7
+ if (rb_num_infinite_p(z) != 0 && rb_num_zero_p(rb_num_imag(z)))
8
+ {
9
+ w = rb_Complex(BIG_ZERO, BIG_ZERO);
10
+ }
11
+ else
12
+ {
13
+ w = BIG_NAN;
14
+ if (rb_num_nan_p(rb_num_real(w)) && rb_num_zero_p(rb_num_imag(z)))
15
+ w = rb_Complex(w, BIG_ZERO);
16
+ else
17
+ w = rb_Complex(w, BIG_NAN);
18
+ }
19
+ }
20
+ if (w == Qundef)
21
+ {
22
+ VALUE real = rb_num_real(z), imag = rb_num_imag(z);
23
+ VALUE t = Qundef;
24
+ VALUE v_sin = Qundef;
25
+ imag = rb_bigmath_to_rad(imag, prec, &t);
26
+ if (-1 != rb_bigmath_degree_sparg(t, prec, &v_sin, NULL) &&
27
+ rb_num_zero_p(real))
28
+ {
29
+ v_sin = rb_num_canonicalize(v_sin, prec, ARG_REAL, ARG_RECIPROCAL);
30
+ w = rb_Complex(BIG_ZERO, v_sin);
31
+ }
32
+ else
33
+ {
34
+ w = ccsch_cb(rb_Complex(real, imag), prec);
35
+ }
36
+ }
37
+ return w;
38
+ }
@@ -0,0 +1,11 @@
1
+ VALUE
2
+ ccsch_eulerf(VALUE z, VALUE prec)
3
+ {
4
+ VALUE w;
5
+
6
+ rb_check_precise(prec);
7
+
8
+ w = rb_ImaginaryZ(trig_f_euler(mf_sin, z, prec), SIGN_PLUS);
9
+
10
+ return rb_num_canonicalize(w, prec, ARG_COMPLEX, ARG_RECIPROCAL);
11
+ }
@@ -0,0 +1,42 @@
1
+ VALUE
2
+ cexp_branch(VALUE z, VALUE prec, bigmath_func1 cexp_cb)
3
+ {
4
+ VALUE w = Qundef;
5
+
6
+ z = rb_num_canonicalize(z, prec, ARG_COMPLEX, ARG_RAWVALUE);
7
+
8
+ if (!rb_num_finite_p(z))
9
+ {
10
+ int real_sign;
11
+ if (rb_num_nan_p(z))
12
+ {
13
+ if (rb_num_zero_p(rb_num_imag(z)))
14
+ w = rb_Complex(BIG_NAN, BIG_ZERO);
15
+ else
16
+ w = rb_Complex(BIG_NAN, BIG_NAN);
17
+ }
18
+ else if ((real_sign = rb_num_infinite_p(rb_num_real(z))) != 0 &&
19
+ rb_num_finite_p(rb_num_imag(z)))
20
+ {
21
+ switch (real_sign) {
22
+ case -1:
23
+ w = rb_Complex(BIG_ZERO, BIG_ZERO);
24
+ break;
25
+ case 1:
26
+ w = rb_Complex(BIG_INF, BIG_ZERO);
27
+ break;
28
+ }
29
+ }
30
+ else
31
+ {
32
+ w = rb_Complex(BIG_NAN, BIG_NAN);
33
+ }
34
+ }
35
+ if (w == Qundef)
36
+ {
37
+ VALUE real = rb_num_real(z), imag = rb_num_imag(z);
38
+ imag = rb_bigmath_to_rad(imag, prec, NULL);
39
+ w = cexp_cb(rb_Complex(real, imag), prec);
40
+ }
41
+ return w;
42
+ }
@@ -0,0 +1,21 @@
1
+ VALUE
2
+ cexp_eulerf(VALUE z, VALUE prec)
3
+ {
4
+ const ID mult = rb_intern("mult");
5
+ VALUE theta, r;
6
+
7
+ rb_check_precise(prec);
8
+
9
+ if (!rb_num_finite_p(rb_num_imag(z)))
10
+ return rb_Complex(BIG_NAN, BIG_NAN);
11
+ r = rb_num_canonicalize(rb_num_real(z), prec, ARG_REAL, ARG_RAWVALUE);
12
+ r = rb_bigmath_exp(r, prec);
13
+ if (rb_num_notequal_p(r, r))
14
+ return rb_Complex(BIG_NAN, BIG_NAN);
15
+ theta = f_euler_formula(rb_num_imag(z), prec);
16
+
17
+ return rb_Complex(
18
+ rb_funcall(rb_BigDecimal1(r), mult, 2, rb_num_real(theta), prec),
19
+ rb_funcall(rb_BigDecimal1(r), mult, 2, rb_num_imag(theta), prec)
20
+ );
21
+ }