k0.c 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. /* k0.c
  2. *
  3. * Modified Bessel function, third kind, order zero
  4. *
  5. *
  6. *
  7. * SYNOPSIS:
  8. *
  9. * double x, y, k0();
  10. *
  11. * y = k0( x );
  12. *
  13. *
  14. *
  15. * DESCRIPTION:
  16. *
  17. * Returns modified Bessel function of the third kind
  18. * of order zero of the argument.
  19. *
  20. * The range is partitioned into the two intervals [0,8] and
  21. * (8, infinity). Chebyshev polynomial expansions are employed
  22. * in each interval.
  23. *
  24. *
  25. *
  26. * ACCURACY:
  27. *
  28. * Tested at 2000 random points between 0 and 8. Peak absolute
  29. * error (relative when K0 > 1) was 1.46e-14; rms, 4.26e-15.
  30. * Relative error:
  31. * arithmetic domain # trials peak rms
  32. * DEC 0, 30 3100 1.3e-16 2.1e-17
  33. * IEEE 0, 30 30000 1.2e-15 1.6e-16
  34. *
  35. * ERROR MESSAGES:
  36. *
  37. * message condition value returned
  38. * K0 domain x <= 0 MAXNUM
  39. *
  40. */
  41. /* k0e()
  42. *
  43. * Modified Bessel function, third kind, order zero,
  44. * exponentially scaled
  45. *
  46. *
  47. *
  48. * SYNOPSIS:
  49. *
  50. * double x, y, k0e();
  51. *
  52. * y = k0e( x );
  53. *
  54. *
  55. *
  56. * DESCRIPTION:
  57. *
  58. * Returns exponentially scaled modified Bessel function
  59. * of the third kind of order zero of the argument.
  60. *
  61. *
  62. *
  63. * ACCURACY:
  64. *
  65. * Relative error:
  66. * arithmetic domain # trials peak rms
  67. * IEEE 0, 30 30000 1.4e-15 1.4e-16
  68. * See k0().
  69. *
  70. */
  71. /*
  72. Cephes Math Library Release 2.8: June, 2000
  73. Copyright 1984, 1987, 2000 by Stephen L. Moshier
  74. */
  75. #include "mconf.h"
  76. /* Chebyshev coefficients for K0(x) + log(x/2) I0(x)
  77. * in the interval [0,2]. The odd order coefficients are all
  78. * zero; only the even order coefficients are listed.
  79. *
  80. * lim(x->0){ K0(x) + log(x/2) I0(x) } = -EUL.
  81. */
  82. #ifdef UNK
  83. static double A[] = {1.37446543561352307156E-16, 4.25981614279661018399E-14,
  84. 1.03496952576338420167E-11, 1.90451637722020886025E-9,
  85. 2.53479107902614945675E-7, 2.28621210311945178607E-5,
  86. 1.26461541144692592338E-3, 3.59799365153615016266E-2,
  87. 3.44289899924628486886E-1, -5.35327393233902768720E-1};
  88. #endif
  89. #ifdef DEC
  90. static unsigned short A[] = {
  91. 0023036, 0073417, 0032477, 0165673, 0025077, 0154126, 0016046, 0012517,
  92. 0027066, 0011342, 0035211, 0005041, 0031002, 0160233, 0037454, 0050224,
  93. 0032610, 0012747, 0037712, 0173741, 0034277, 0144007, 0172147, 0162375,
  94. 0035645, 0140563, 0125431, 0165626, 0037023, 0057662, 0125124, 0102051,
  95. 0037660, 0043304, 0004411, 0166707, 0140011, 0005467, 0047227, 0130370};
  96. #endif
  97. #ifdef IBMPC
  98. static unsigned short A[] = {
  99. 0xfd77, 0xe6a7, 0xcee1, 0x3ca3, 0xc2aa, 0xc384, 0xfb0a, 0x3d27,
  100. 0x2144, 0x4751, 0xc25c, 0x3da6, 0x8a13, 0x67e5, 0x5c13, 0x3e20,
  101. 0x5efc, 0xe7f9, 0x02bc, 0x3e91, 0xfca0, 0xfe8c, 0xf900, 0x3ef7,
  102. 0x3d73, 0x7563, 0xb82e, 0x3f54, 0x9085, 0x554a, 0x6bf6, 0x3fa2,
  103. 0x3db9, 0x8121, 0x08d8, 0x3fd6, 0xf61f, 0xe9d2, 0x2166, 0xbfe1};
  104. #endif
  105. #ifdef MIEEE
  106. static unsigned short A[] = {
  107. 0x3ca3, 0xcee1, 0xe6a7, 0xfd77, 0x3d27, 0xfb0a, 0xc384, 0xc2aa,
  108. 0x3da6, 0xc25c, 0x4751, 0x2144, 0x3e20, 0x5c13, 0x67e5, 0x8a13,
  109. 0x3e91, 0x02bc, 0xe7f9, 0x5efc, 0x3ef7, 0xf900, 0xfe8c, 0xfca0,
  110. 0x3f54, 0xb82e, 0x7563, 0x3d73, 0x3fa2, 0x6bf6, 0x554a, 0x9085,
  111. 0x3fd6, 0x08d8, 0x8121, 0x3db9, 0xbfe1, 0x2166, 0xe9d2, 0xf61f};
  112. #endif
  113. /* Chebyshev coefficients for exp(x) sqrt(x) K0(x)
  114. * in the inverted interval [2,infinity].
  115. *
  116. * lim(x->inf){ exp(x) sqrt(x) K0(x) } = sqrt(pi/2).
  117. */
  118. #ifdef UNK
  119. static double B[] = {5.30043377268626276149E-18, -1.64758043015242134646E-17,
  120. 5.21039150503902756861E-17, -1.67823109680541210385E-16,
  121. 5.51205597852431940784E-16, -1.84859337734377901440E-15,
  122. 6.34007647740507060557E-15, -2.22751332699166985548E-14,
  123. 8.03289077536357521100E-14, -2.98009692317273043925E-13,
  124. 1.14034058820847496303E-12, -4.51459788337394416547E-12,
  125. 1.85594911495471785253E-11, -7.95748924447710747776E-11,
  126. 3.57739728140030116597E-10, -1.69753450938905987466E-9,
  127. 8.57403401741422608519E-9, -4.66048989768794782956E-8,
  128. 2.76681363944501510342E-7, -1.83175552271911948767E-6,
  129. 1.39498137188764993662E-5, -1.28495495816278026384E-4,
  130. 1.56988388573005337491E-3, -3.14481013119645005427E-2,
  131. 2.44030308206595545468E0};
  132. #endif
  133. #ifdef DEC
  134. static unsigned short B[] = {
  135. 0021703, 0106456, 0076144, 0173406, 0122227, 0173144, 0116011, 0030033,
  136. 0022560, 0044562, 0006506, 0067642, 0123101, 0076243, 0123273, 0131013,
  137. 0023436, 0157713, 0056243, 0141331, 0124005, 0032207, 0063726, 0164664,
  138. 0024344, 0066342, 0051756, 0162300, 0124710, 0121365, 0154053, 0077022,
  139. 0025264, 0161166, 0066246, 0077420, 0125647, 0141671, 0006443, 0103212,
  140. 0026240, 0076431, 0077147, 0160445, 0126636, 0153741, 0174002, 0105031,
  141. 0027243, 0040102, 0035375, 0163073, 0127656, 0176256, 0113476, 0044653,
  142. 0030304, 0125544, 0006377, 0130104, 0130751, 0047257, 0110537, 0127324,
  143. 0031423, 0046400, 0014772, 0012164, 0132110, 0025240, 0155247, 0112570,
  144. 0032624, 0105314, 0007437, 0021574, 0133365, 0155243, 0174306, 0116506,
  145. 0034152, 0004776, 0061643, 0102504, 0135006, 0136277, 0036104, 0175023,
  146. 0035715, 0142217, 0162474, 0115022, 0137000, 0147671, 0065177, 0134356,
  147. 0040434, 0026754, 0175163, 0044070};
  148. #endif
  149. #ifdef IBMPC
  150. static unsigned short B[] = {
  151. 0x9ee1, 0xcf8c, 0x71a5, 0x3c58, 0x2603, 0x9381, 0xfecc, 0xbc72, 0xcdf4,
  152. 0x41a8, 0x092e, 0x3c8e, 0x7641, 0x74d7, 0x2f94, 0xbca8, 0x785b, 0x6b94,
  153. 0xdbf9, 0x3cc3, 0xdd36, 0xecfa, 0xa690, 0xbce0, 0xdc98, 0x4a7d, 0x8d9c,
  154. 0x3cfc, 0x6fc2, 0xbb05, 0x145e, 0xbd19, 0xcfe2, 0xcd94, 0x9c4e, 0x3d36,
  155. 0x70d1, 0x21a4, 0xf877, 0xbd54, 0xfc25, 0x2fcc, 0x0fa3, 0x3d74, 0x5143,
  156. 0x3f00, 0xdafc, 0xbd93, 0xbcc7, 0x475f, 0x6808, 0x3db4, 0xc935, 0xd2e7,
  157. 0xdf95, 0xbdd5, 0xf608, 0x819f, 0x956c, 0x3df8, 0xf5db, 0xf22b, 0x29d5,
  158. 0xbe1d, 0x428e, 0x033f, 0x69a0, 0x3e42, 0xf2af, 0x1b54, 0x0554, 0xbe69,
  159. 0xe46f, 0x81e3, 0x9159, 0x3e92, 0xd3a9, 0x7f18, 0xbb54, 0xbebe, 0x70a9,
  160. 0xcc74, 0x413f, 0x3eed, 0x9f42, 0xe788, 0xd797, 0xbf20, 0x9342, 0xfca7,
  161. 0xb891, 0x3f59, 0xf71e, 0x2d4f, 0x19f7, 0xbfa0, 0x6907, 0x9f4e, 0x85bd,
  162. 0x4003};
  163. #endif
  164. #ifdef MIEEE
  165. static unsigned short B[] = {
  166. 0x3c58, 0x71a5, 0xcf8c, 0x9ee1, 0xbc72, 0xfecc, 0x9381, 0x2603, 0x3c8e,
  167. 0x092e, 0x41a8, 0xcdf4, 0xbca8, 0x2f94, 0x74d7, 0x7641, 0x3cc3, 0xdbf9,
  168. 0x6b94, 0x785b, 0xbce0, 0xa690, 0xecfa, 0xdd36, 0x3cfc, 0x8d9c, 0x4a7d,
  169. 0xdc98, 0xbd19, 0x145e, 0xbb05, 0x6fc2, 0x3d36, 0x9c4e, 0xcd94, 0xcfe2,
  170. 0xbd54, 0xf877, 0x21a4, 0x70d1, 0x3d74, 0x0fa3, 0x2fcc, 0xfc25, 0xbd93,
  171. 0xdafc, 0x3f00, 0x5143, 0x3db4, 0x6808, 0x475f, 0xbcc7, 0xbdd5, 0xdf95,
  172. 0xd2e7, 0xc935, 0x3df8, 0x956c, 0x819f, 0xf608, 0xbe1d, 0x29d5, 0xf22b,
  173. 0xf5db, 0x3e42, 0x69a0, 0x033f, 0x428e, 0xbe69, 0x0554, 0x1b54, 0xf2af,
  174. 0x3e92, 0x9159, 0x81e3, 0xe46f, 0xbebe, 0xbb54, 0x7f18, 0xd3a9, 0x3eed,
  175. 0x413f, 0xcc74, 0x70a9, 0xbf20, 0xd797, 0xe788, 0x9f42, 0x3f59, 0xb891,
  176. 0xfca7, 0x9342, 0xbfa0, 0x19f7, 0x2d4f, 0xf71e, 0x4003, 0x85bd, 0x9f4e,
  177. 0x6907};
  178. #endif
  179. /* k0.c */
  180. #ifdef ANSIPROT
  181. extern double chbevl(double, void *, int);
  182. extern double exp(double);
  183. extern double i0(double);
  184. extern double log(double);
  185. extern double sqrt(double);
  186. #else
  187. double chbevl(), exp(), i0(), log(), sqrt();
  188. #endif
  189. extern double PI;
  190. extern double MAXNUM;
  191. double k0(x) double x;
  192. {
  193. double y, z;
  194. if (x <= 0.0) {
  195. mtherr("k0", DOMAIN);
  196. return (MAXNUM);
  197. }
  198. if (x <= 2.0) {
  199. y = x * x - 2.0;
  200. y = chbevl(y, A, 10) - log(0.5 * x) * i0(x);
  201. return (y);
  202. }
  203. z = 8.0 / x - 2.0;
  204. y = exp(-x) * chbevl(z, B, 25) / sqrt(x);
  205. return (y);
  206. }
  207. double k0e(x) double x;
  208. {
  209. double y;
  210. if (x <= 0.0) {
  211. mtherr("k0e", DOMAIN);
  212. return (MAXNUM);
  213. }
  214. if (x <= 2.0) {
  215. y = x * x - 2.0;
  216. y = chbevl(y, A, 10) - log(0.5 * x) * i0(x);
  217. return (y * exp(x));
  218. }
  219. y = chbevl(8.0 / x - 2.0, B, 25) / sqrt(x);
  220. return (y);
  221. }