Line data Source code
1 : /*************************************************************************
2 : ALGLIB 3.17.0 (source code generated 2020-12-27)
3 : Copyright (c) Sergey Bochkanov (ALGLIB project).
4 :
5 : >>> SOURCE LICENSE >>>
6 : This program is free software; you can redistribute it and/or modify
7 : it under the terms of the GNU General Public License as published by
8 : the Free Software Foundation (www.fsf.org); either version 2 of the
9 : License, or (at your option) any later version.
10 :
11 : This program is distributed in the hope that it will be useful,
12 : but WITHOUT ANY WARRANTY; without even the implied warranty of
13 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 : GNU General Public License for more details.
15 :
16 : A copy of the GNU General Public License is available at
17 : http://www.fsf.org/licensing/licenses
18 : >>> END OF LICENSE >>>
19 : *************************************************************************/
20 : #ifdef _MSC_VER
21 : #define _CRT_SECURE_NO_WARNINGS
22 : #endif
23 : #include "stdafx.h"
24 : #include "specialfunctions.h"
25 :
26 : // disable some irrelevant warnings
27 : #if (AE_COMPILER==AE_MSVC) && !defined(AE_ALL_WARNINGS)
28 : #pragma warning(disable:4100)
29 : #pragma warning(disable:4127)
30 : #pragma warning(disable:4611)
31 : #pragma warning(disable:4702)
32 : #pragma warning(disable:4996)
33 : #endif
34 :
35 : /////////////////////////////////////////////////////////////////////////
36 : //
37 : // THIS SECTION CONTAINS IMPLEMENTATION OF C++ INTERFACE
38 : //
39 : /////////////////////////////////////////////////////////////////////////
40 : namespace alglib
41 : {
42 :
43 : #if defined(AE_COMPILE_GAMMAFUNC) || !defined(AE_PARTIAL_BUILD)
44 :
45 : #endif
46 :
47 : #if defined(AE_COMPILE_NORMALDISTR) || !defined(AE_PARTIAL_BUILD)
48 :
49 : #endif
50 :
51 : #if defined(AE_COMPILE_IGAMMAF) || !defined(AE_PARTIAL_BUILD)
52 :
53 : #endif
54 :
55 : #if defined(AE_COMPILE_ELLIPTIC) || !defined(AE_PARTIAL_BUILD)
56 :
57 : #endif
58 :
59 : #if defined(AE_COMPILE_HERMITE) || !defined(AE_PARTIAL_BUILD)
60 :
61 : #endif
62 :
63 : #if defined(AE_COMPILE_DAWSON) || !defined(AE_PARTIAL_BUILD)
64 :
65 : #endif
66 :
67 : #if defined(AE_COMPILE_TRIGINTEGRALS) || !defined(AE_PARTIAL_BUILD)
68 :
69 : #endif
70 :
71 : #if defined(AE_COMPILE_POISSONDISTR) || !defined(AE_PARTIAL_BUILD)
72 :
73 : #endif
74 :
75 : #if defined(AE_COMPILE_BESSEL) || !defined(AE_PARTIAL_BUILD)
76 :
77 : #endif
78 :
79 : #if defined(AE_COMPILE_IBETAF) || !defined(AE_PARTIAL_BUILD)
80 :
81 : #endif
82 :
83 : #if defined(AE_COMPILE_FDISTR) || !defined(AE_PARTIAL_BUILD)
84 :
85 : #endif
86 :
87 : #if defined(AE_COMPILE_FRESNEL) || !defined(AE_PARTIAL_BUILD)
88 :
89 : #endif
90 :
91 : #if defined(AE_COMPILE_JACOBIANELLIPTIC) || !defined(AE_PARTIAL_BUILD)
92 :
93 : #endif
94 :
95 : #if defined(AE_COMPILE_PSIF) || !defined(AE_PARTIAL_BUILD)
96 :
97 : #endif
98 :
99 : #if defined(AE_COMPILE_EXPINTEGRALS) || !defined(AE_PARTIAL_BUILD)
100 :
101 : #endif
102 :
103 : #if defined(AE_COMPILE_LAGUERRE) || !defined(AE_PARTIAL_BUILD)
104 :
105 : #endif
106 :
107 : #if defined(AE_COMPILE_CHISQUAREDISTR) || !defined(AE_PARTIAL_BUILD)
108 :
109 : #endif
110 :
111 : #if defined(AE_COMPILE_LEGENDRE) || !defined(AE_PARTIAL_BUILD)
112 :
113 : #endif
114 :
115 : #if defined(AE_COMPILE_BETAF) || !defined(AE_PARTIAL_BUILD)
116 :
117 : #endif
118 :
119 : #if defined(AE_COMPILE_CHEBYSHEV) || !defined(AE_PARTIAL_BUILD)
120 :
121 : #endif
122 :
123 : #if defined(AE_COMPILE_STUDENTTDISTR) || !defined(AE_PARTIAL_BUILD)
124 :
125 : #endif
126 :
127 : #if defined(AE_COMPILE_BINOMIALDISTR) || !defined(AE_PARTIAL_BUILD)
128 :
129 : #endif
130 :
131 : #if defined(AE_COMPILE_AIRYF) || !defined(AE_PARTIAL_BUILD)
132 :
133 : #endif
134 :
135 : #if defined(AE_COMPILE_GAMMAFUNC) || !defined(AE_PARTIAL_BUILD)
136 : /*************************************************************************
137 : Gamma function
138 :
139 : Input parameters:
140 : X - argument
141 :
142 : Domain:
143 : 0 < X < 171.6
144 : -170 < X < 0, X is not an integer.
145 :
146 : Relative error:
147 : arithmetic domain # trials peak rms
148 : IEEE -170,-33 20000 2.3e-15 3.3e-16
149 : IEEE -33, 33 20000 9.4e-16 2.2e-16
150 : IEEE 33, 171.6 20000 2.3e-15 3.2e-16
151 :
152 : Cephes Math Library Release 2.8: June, 2000
153 : Original copyright 1984, 1987, 1989, 1992, 2000 by Stephen L. Moshier
154 : Translated to AlgoPascal by Bochkanov Sergey (2005, 2006, 2007).
155 : *************************************************************************/
156 0 : double gammafunction(const double x, const xparams _xparams)
157 : {
158 : jmp_buf _break_jump;
159 : alglib_impl::ae_state _alglib_env_state;
160 0 : alglib_impl::ae_state_init(&_alglib_env_state);
161 0 : if( setjmp(_break_jump) )
162 : {
163 : #if !defined(AE_NO_EXCEPTIONS)
164 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
165 : #else
166 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
167 : return 0;
168 : #endif
169 : }
170 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
171 0 : if( _xparams.flags!=0x0 )
172 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
173 0 : double result = alglib_impl::gammafunction(x, &_alglib_env_state);
174 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
175 0 : return *(reinterpret_cast<double*>(&result));
176 : }
177 :
178 : /*************************************************************************
179 : Natural logarithm of gamma function
180 :
181 : Input parameters:
182 : X - argument
183 :
184 : Result:
185 : logarithm of the absolute value of the Gamma(X).
186 :
187 : Output parameters:
188 : SgnGam - sign(Gamma(X))
189 :
190 : Domain:
191 : 0 < X < 2.55e305
192 : -2.55e305 < X < 0, X is not an integer.
193 :
194 : ACCURACY:
195 : arithmetic domain # trials peak rms
196 : IEEE 0, 3 28000 5.4e-16 1.1e-16
197 : IEEE 2.718, 2.556e305 40000 3.5e-16 8.3e-17
198 : The error criterion was relative when the function magnitude
199 : was greater than one but absolute when it was less than one.
200 :
201 : The following test used the relative error criterion, though
202 : at certain points the relative error could be much higher than
203 : indicated.
204 : IEEE -200, -4 10000 4.8e-16 1.3e-16
205 :
206 : Cephes Math Library Release 2.8: June, 2000
207 : Copyright 1984, 1987, 1989, 1992, 2000 by Stephen L. Moshier
208 : Translated to AlgoPascal by Bochkanov Sergey (2005, 2006, 2007).
209 : *************************************************************************/
210 0 : double lngamma(const double x, double &sgngam, const xparams _xparams)
211 : {
212 : jmp_buf _break_jump;
213 : alglib_impl::ae_state _alglib_env_state;
214 0 : alglib_impl::ae_state_init(&_alglib_env_state);
215 0 : if( setjmp(_break_jump) )
216 : {
217 : #if !defined(AE_NO_EXCEPTIONS)
218 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
219 : #else
220 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
221 : return 0;
222 : #endif
223 : }
224 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
225 0 : if( _xparams.flags!=0x0 )
226 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
227 0 : double result = alglib_impl::lngamma(x, &sgngam, &_alglib_env_state);
228 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
229 0 : return *(reinterpret_cast<double*>(&result));
230 : }
231 : #endif
232 :
233 : #if defined(AE_COMPILE_NORMALDISTR) || !defined(AE_PARTIAL_BUILD)
234 : /*************************************************************************
235 : Error function
236 :
237 : The integral is
238 :
239 : x
240 : -
241 : 2 | | 2
242 : erf(x) = -------- | exp( - t ) dt.
243 : sqrt(pi) | |
244 : -
245 : 0
246 :
247 : For 0 <= |x| < 1, erf(x) = x * P4(x**2)/Q5(x**2); otherwise
248 : erf(x) = 1 - erfc(x).
249 :
250 :
251 : ACCURACY:
252 :
253 : Relative error:
254 : arithmetic domain # trials peak rms
255 : IEEE 0,1 30000 3.7e-16 1.0e-16
256 :
257 : Cephes Math Library Release 2.8: June, 2000
258 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
259 : *************************************************************************/
260 0 : double errorfunction(const double x, const xparams _xparams)
261 : {
262 : jmp_buf _break_jump;
263 : alglib_impl::ae_state _alglib_env_state;
264 0 : alglib_impl::ae_state_init(&_alglib_env_state);
265 0 : if( setjmp(_break_jump) )
266 : {
267 : #if !defined(AE_NO_EXCEPTIONS)
268 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
269 : #else
270 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
271 : return 0;
272 : #endif
273 : }
274 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
275 0 : if( _xparams.flags!=0x0 )
276 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
277 0 : double result = alglib_impl::errorfunction(x, &_alglib_env_state);
278 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
279 0 : return *(reinterpret_cast<double*>(&result));
280 : }
281 :
282 : /*************************************************************************
283 : Complementary error function
284 :
285 : 1 - erf(x) =
286 :
287 : inf.
288 : -
289 : 2 | | 2
290 : erfc(x) = -------- | exp( - t ) dt
291 : sqrt(pi) | |
292 : -
293 : x
294 :
295 :
296 : For small x, erfc(x) = 1 - erf(x); otherwise rational
297 : approximations are computed.
298 :
299 :
300 : ACCURACY:
301 :
302 : Relative error:
303 : arithmetic domain # trials peak rms
304 : IEEE 0,26.6417 30000 5.7e-14 1.5e-14
305 :
306 : Cephes Math Library Release 2.8: June, 2000
307 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
308 : *************************************************************************/
309 0 : double errorfunctionc(const double x, const xparams _xparams)
310 : {
311 : jmp_buf _break_jump;
312 : alglib_impl::ae_state _alglib_env_state;
313 0 : alglib_impl::ae_state_init(&_alglib_env_state);
314 0 : if( setjmp(_break_jump) )
315 : {
316 : #if !defined(AE_NO_EXCEPTIONS)
317 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
318 : #else
319 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
320 : return 0;
321 : #endif
322 : }
323 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
324 0 : if( _xparams.flags!=0x0 )
325 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
326 0 : double result = alglib_impl::errorfunctionc(x, &_alglib_env_state);
327 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
328 0 : return *(reinterpret_cast<double*>(&result));
329 : }
330 :
331 : /*************************************************************************
332 : Same as normalcdf(), obsolete name.
333 : *************************************************************************/
334 0 : double normaldistribution(const double x, const xparams _xparams)
335 : {
336 : jmp_buf _break_jump;
337 : alglib_impl::ae_state _alglib_env_state;
338 0 : alglib_impl::ae_state_init(&_alglib_env_state);
339 0 : if( setjmp(_break_jump) )
340 : {
341 : #if !defined(AE_NO_EXCEPTIONS)
342 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
343 : #else
344 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
345 : return 0;
346 : #endif
347 : }
348 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
349 0 : if( _xparams.flags!=0x0 )
350 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
351 0 : double result = alglib_impl::normaldistribution(x, &_alglib_env_state);
352 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
353 0 : return *(reinterpret_cast<double*>(&result));
354 : }
355 :
356 : /*************************************************************************
357 : Normal distribution PDF
358 :
359 : Returns Gaussian probability density function:
360 :
361 : 1
362 : f(x) = --------- * exp(-x^2/2)
363 : sqrt(2pi)
364 :
365 : Cephes Math Library Release 2.8: June, 2000
366 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
367 : *************************************************************************/
368 0 : double normalpdf(const double x, const xparams _xparams)
369 : {
370 : jmp_buf _break_jump;
371 : alglib_impl::ae_state _alglib_env_state;
372 0 : alglib_impl::ae_state_init(&_alglib_env_state);
373 0 : if( setjmp(_break_jump) )
374 : {
375 : #if !defined(AE_NO_EXCEPTIONS)
376 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
377 : #else
378 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
379 : return 0;
380 : #endif
381 : }
382 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
383 0 : if( _xparams.flags!=0x0 )
384 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
385 0 : double result = alglib_impl::normalpdf(x, &_alglib_env_state);
386 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
387 0 : return *(reinterpret_cast<double*>(&result));
388 : }
389 :
390 : /*************************************************************************
391 : Normal distribution CDF
392 :
393 : Returns the area under the Gaussian probability density
394 : function, integrated from minus infinity to x:
395 :
396 : x
397 : -
398 : 1 | | 2
399 : ndtr(x) = --------- | exp( - t /2 ) dt
400 : sqrt(2pi) | |
401 : -
402 : -inf.
403 :
404 : = ( 1 + erf(z) ) / 2
405 : = erfc(z) / 2
406 :
407 : where z = x/sqrt(2). Computation is via the functions
408 : erf and erfc.
409 :
410 :
411 : ACCURACY:
412 :
413 : Relative error:
414 : arithmetic domain # trials peak rms
415 : IEEE -13,0 30000 3.4e-14 6.7e-15
416 :
417 : Cephes Math Library Release 2.8: June, 2000
418 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
419 : *************************************************************************/
420 0 : double normalcdf(const double x, const xparams _xparams)
421 : {
422 : jmp_buf _break_jump;
423 : alglib_impl::ae_state _alglib_env_state;
424 0 : alglib_impl::ae_state_init(&_alglib_env_state);
425 0 : if( setjmp(_break_jump) )
426 : {
427 : #if !defined(AE_NO_EXCEPTIONS)
428 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
429 : #else
430 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
431 : return 0;
432 : #endif
433 : }
434 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
435 0 : if( _xparams.flags!=0x0 )
436 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
437 0 : double result = alglib_impl::normalcdf(x, &_alglib_env_state);
438 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
439 0 : return *(reinterpret_cast<double*>(&result));
440 : }
441 :
442 : /*************************************************************************
443 : Inverse of the error function
444 :
445 : Cephes Math Library Release 2.8: June, 2000
446 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
447 : *************************************************************************/
448 0 : double inverf(const double e, const xparams _xparams)
449 : {
450 : jmp_buf _break_jump;
451 : alglib_impl::ae_state _alglib_env_state;
452 0 : alglib_impl::ae_state_init(&_alglib_env_state);
453 0 : if( setjmp(_break_jump) )
454 : {
455 : #if !defined(AE_NO_EXCEPTIONS)
456 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
457 : #else
458 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
459 : return 0;
460 : #endif
461 : }
462 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
463 0 : if( _xparams.flags!=0x0 )
464 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
465 0 : double result = alglib_impl::inverf(e, &_alglib_env_state);
466 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
467 0 : return *(reinterpret_cast<double*>(&result));
468 : }
469 :
470 : /*************************************************************************
471 : Same as invnormalcdf(), deprecated name
472 : *************************************************************************/
473 0 : double invnormaldistribution(const double y0, const xparams _xparams)
474 : {
475 : jmp_buf _break_jump;
476 : alglib_impl::ae_state _alglib_env_state;
477 0 : alglib_impl::ae_state_init(&_alglib_env_state);
478 0 : if( setjmp(_break_jump) )
479 : {
480 : #if !defined(AE_NO_EXCEPTIONS)
481 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
482 : #else
483 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
484 : return 0;
485 : #endif
486 : }
487 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
488 0 : if( _xparams.flags!=0x0 )
489 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
490 0 : double result = alglib_impl::invnormaldistribution(y0, &_alglib_env_state);
491 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
492 0 : return *(reinterpret_cast<double*>(&result));
493 : }
494 :
495 : /*************************************************************************
496 : Inverse of Normal CDF
497 :
498 : Returns the argument, x, for which the area under the
499 : Gaussian probability density function (integrated from
500 : minus infinity to x) is equal to y.
501 :
502 :
503 : For small arguments 0 < y < exp(-2), the program computes
504 : z = sqrt( -2.0 * log(y) ); then the approximation is
505 : x = z - log(z)/z - (1/z) P(1/z) / Q(1/z).
506 : There are two rational functions P/Q, one for 0 < y < exp(-32)
507 : and the other for y up to exp(-2). For larger arguments,
508 : w = y - 0.5, and x/sqrt(2pi) = w + w**3 R(w**2)/S(w**2)).
509 :
510 : ACCURACY:
511 :
512 : Relative error:
513 : arithmetic domain # trials peak rms
514 : IEEE 0.125, 1 20000 7.2e-16 1.3e-16
515 : IEEE 3e-308, 0.135 50000 4.6e-16 9.8e-17
516 :
517 : Cephes Math Library Release 2.8: June, 2000
518 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
519 : *************************************************************************/
520 0 : double invnormalcdf(const double y0, const xparams _xparams)
521 : {
522 : jmp_buf _break_jump;
523 : alglib_impl::ae_state _alglib_env_state;
524 0 : alglib_impl::ae_state_init(&_alglib_env_state);
525 0 : if( setjmp(_break_jump) )
526 : {
527 : #if !defined(AE_NO_EXCEPTIONS)
528 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
529 : #else
530 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
531 : return 0;
532 : #endif
533 : }
534 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
535 0 : if( _xparams.flags!=0x0 )
536 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
537 0 : double result = alglib_impl::invnormalcdf(y0, &_alglib_env_state);
538 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
539 0 : return *(reinterpret_cast<double*>(&result));
540 : }
541 :
542 : /*************************************************************************
543 : Bivariate normal PDF
544 :
545 : Returns probability density function of the bivariate Gaussian with
546 : correlation parameter equal to Rho:
547 :
548 : 1 ( x^2 - 2*rho*x*y + y^2 )
549 : f(x,y,rho) = ----------------- * exp( - ----------------------- )
550 : 2pi*sqrt(1-rho^2) ( 2*(1-rho^2) )
551 :
552 :
553 : with -1<rho<+1 and arbitrary x, y.
554 :
555 : This function won't fail as long as Rho is in (-1,+1) range.
556 :
557 : -- ALGLIB --
558 : Copyright 15.11.2019 by Bochkanov Sergey
559 : *************************************************************************/
560 0 : double bivariatenormalpdf(const double x, const double y, const double rho, const xparams _xparams)
561 : {
562 : jmp_buf _break_jump;
563 : alglib_impl::ae_state _alglib_env_state;
564 0 : alglib_impl::ae_state_init(&_alglib_env_state);
565 0 : if( setjmp(_break_jump) )
566 : {
567 : #if !defined(AE_NO_EXCEPTIONS)
568 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
569 : #else
570 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
571 : return 0;
572 : #endif
573 : }
574 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
575 0 : if( _xparams.flags!=0x0 )
576 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
577 0 : double result = alglib_impl::bivariatenormalpdf(x, y, rho, &_alglib_env_state);
578 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
579 0 : return *(reinterpret_cast<double*>(&result));
580 : }
581 :
582 : /*************************************************************************
583 : Bivariate normal CDF
584 :
585 : Returns the area under the bivariate Gaussian PDF with correlation
586 : parameter equal to Rho, integrated from minus infinity to (x,y):
587 :
588 :
589 : x y
590 : - -
591 : 1 | | | |
592 : bvn(x,y,rho) = ------------------- | | f(u,v,rho)*du*dv
593 : 2pi*sqrt(1-rho^2) | | | |
594 : - -
595 : -INF -INF
596 :
597 :
598 : where
599 :
600 : ( u^2 - 2*rho*u*v + v^2 )
601 : f(u,v,rho) = exp( - ----------------------- )
602 : ( 2*(1-rho^2) )
603 :
604 :
605 : with -1<rho<+1 and arbitrary x, y.
606 :
607 : This subroutine uses high-precision approximation scheme proposed by
608 : Alan Genz in "Numerical Computation of Rectangular Bivariate and
609 : Trivariate Normal and t probabilities", which computes CDF with
610 : absolute error roughly equal to 1e-14.
611 :
612 : This function won't fail as long as Rho is in (-1,+1) range.
613 :
614 : -- ALGLIB --
615 : Copyright 15.11.2019 by Bochkanov Sergey
616 : *************************************************************************/
617 0 : double bivariatenormalcdf(const double x, const double y, const double rho, const xparams _xparams)
618 : {
619 : jmp_buf _break_jump;
620 : alglib_impl::ae_state _alglib_env_state;
621 0 : alglib_impl::ae_state_init(&_alglib_env_state);
622 0 : if( setjmp(_break_jump) )
623 : {
624 : #if !defined(AE_NO_EXCEPTIONS)
625 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
626 : #else
627 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
628 : return 0;
629 : #endif
630 : }
631 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
632 0 : if( _xparams.flags!=0x0 )
633 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
634 0 : double result = alglib_impl::bivariatenormalcdf(x, y, rho, &_alglib_env_state);
635 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
636 0 : return *(reinterpret_cast<double*>(&result));
637 : }
638 : #endif
639 :
640 : #if defined(AE_COMPILE_IGAMMAF) || !defined(AE_PARTIAL_BUILD)
641 : /*************************************************************************
642 : Incomplete gamma integral
643 :
644 : The function is defined by
645 :
646 : x
647 : -
648 : 1 | | -t a-1
649 : igam(a,x) = ----- | e t dt.
650 : - | |
651 : | (a) -
652 : 0
653 :
654 :
655 : In this implementation both arguments must be positive.
656 : The integral is evaluated by either a power series or
657 : continued fraction expansion, depending on the relative
658 : values of a and x.
659 :
660 : ACCURACY:
661 :
662 : Relative error:
663 : arithmetic domain # trials peak rms
664 : IEEE 0,30 200000 3.6e-14 2.9e-15
665 : IEEE 0,100 300000 9.9e-14 1.5e-14
666 :
667 : Cephes Math Library Release 2.8: June, 2000
668 : Copyright 1985, 1987, 2000 by Stephen L. Moshier
669 : *************************************************************************/
670 0 : double incompletegamma(const double a, const double x, const xparams _xparams)
671 : {
672 : jmp_buf _break_jump;
673 : alglib_impl::ae_state _alglib_env_state;
674 0 : alglib_impl::ae_state_init(&_alglib_env_state);
675 0 : if( setjmp(_break_jump) )
676 : {
677 : #if !defined(AE_NO_EXCEPTIONS)
678 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
679 : #else
680 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
681 : return 0;
682 : #endif
683 : }
684 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
685 0 : if( _xparams.flags!=0x0 )
686 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
687 0 : double result = alglib_impl::incompletegamma(a, x, &_alglib_env_state);
688 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
689 0 : return *(reinterpret_cast<double*>(&result));
690 : }
691 :
692 : /*************************************************************************
693 : Complemented incomplete gamma integral
694 :
695 : The function is defined by
696 :
697 :
698 : igamc(a,x) = 1 - igam(a,x)
699 :
700 : inf.
701 : -
702 : 1 | | -t a-1
703 : = ----- | e t dt.
704 : - | |
705 : | (a) -
706 : x
707 :
708 :
709 : In this implementation both arguments must be positive.
710 : The integral is evaluated by either a power series or
711 : continued fraction expansion, depending on the relative
712 : values of a and x.
713 :
714 : ACCURACY:
715 :
716 : Tested at random a, x.
717 : a x Relative error:
718 : arithmetic domain domain # trials peak rms
719 : IEEE 0.5,100 0,100 200000 1.9e-14 1.7e-15
720 : IEEE 0.01,0.5 0,100 200000 1.4e-13 1.6e-15
721 :
722 : Cephes Math Library Release 2.8: June, 2000
723 : Copyright 1985, 1987, 2000 by Stephen L. Moshier
724 : *************************************************************************/
725 0 : double incompletegammac(const double a, const double x, const xparams _xparams)
726 : {
727 : jmp_buf _break_jump;
728 : alglib_impl::ae_state _alglib_env_state;
729 0 : alglib_impl::ae_state_init(&_alglib_env_state);
730 0 : if( setjmp(_break_jump) )
731 : {
732 : #if !defined(AE_NO_EXCEPTIONS)
733 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
734 : #else
735 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
736 : return 0;
737 : #endif
738 : }
739 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
740 0 : if( _xparams.flags!=0x0 )
741 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
742 0 : double result = alglib_impl::incompletegammac(a, x, &_alglib_env_state);
743 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
744 0 : return *(reinterpret_cast<double*>(&result));
745 : }
746 :
747 : /*************************************************************************
748 : Inverse of complemented imcomplete gamma integral
749 :
750 : Given p, the function finds x such that
751 :
752 : igamc( a, x ) = p.
753 :
754 : Starting with the approximate value
755 :
756 : 3
757 : x = a t
758 :
759 : where
760 :
761 : t = 1 - d - ndtri(p) sqrt(d)
762 :
763 : and
764 :
765 : d = 1/9a,
766 :
767 : the routine performs up to 10 Newton iterations to find the
768 : root of igamc(a,x) - p = 0.
769 :
770 : ACCURACY:
771 :
772 : Tested at random a, p in the intervals indicated.
773 :
774 : a p Relative error:
775 : arithmetic domain domain # trials peak rms
776 : IEEE 0.5,100 0,0.5 100000 1.0e-14 1.7e-15
777 : IEEE 0.01,0.5 0,0.5 100000 9.0e-14 3.4e-15
778 : IEEE 0.5,10000 0,0.5 20000 2.3e-13 3.8e-14
779 :
780 : Cephes Math Library Release 2.8: June, 2000
781 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
782 : *************************************************************************/
783 0 : double invincompletegammac(const double a, const double y0, const xparams _xparams)
784 : {
785 : jmp_buf _break_jump;
786 : alglib_impl::ae_state _alglib_env_state;
787 0 : alglib_impl::ae_state_init(&_alglib_env_state);
788 0 : if( setjmp(_break_jump) )
789 : {
790 : #if !defined(AE_NO_EXCEPTIONS)
791 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
792 : #else
793 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
794 : return 0;
795 : #endif
796 : }
797 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
798 0 : if( _xparams.flags!=0x0 )
799 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
800 0 : double result = alglib_impl::invincompletegammac(a, y0, &_alglib_env_state);
801 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
802 0 : return *(reinterpret_cast<double*>(&result));
803 : }
804 : #endif
805 :
806 : #if defined(AE_COMPILE_ELLIPTIC) || !defined(AE_PARTIAL_BUILD)
807 : /*************************************************************************
808 : Complete elliptic integral of the first kind
809 :
810 : Approximates the integral
811 :
812 :
813 :
814 : pi/2
815 : -
816 : | |
817 : | dt
818 : K(m) = | ------------------
819 : | 2
820 : | | sqrt( 1 - m sin t )
821 : -
822 : 0
823 :
824 : using the approximation
825 :
826 : P(x) - log x Q(x).
827 :
828 : ACCURACY:
829 :
830 : Relative error:
831 : arithmetic domain # trials peak rms
832 : IEEE 0,1 30000 2.5e-16 6.8e-17
833 :
834 : Cephes Math Library, Release 2.8: June, 2000
835 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
836 : *************************************************************************/
837 0 : double ellipticintegralk(const double m, const xparams _xparams)
838 : {
839 : jmp_buf _break_jump;
840 : alglib_impl::ae_state _alglib_env_state;
841 0 : alglib_impl::ae_state_init(&_alglib_env_state);
842 0 : if( setjmp(_break_jump) )
843 : {
844 : #if !defined(AE_NO_EXCEPTIONS)
845 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
846 : #else
847 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
848 : return 0;
849 : #endif
850 : }
851 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
852 0 : if( _xparams.flags!=0x0 )
853 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
854 0 : double result = alglib_impl::ellipticintegralk(m, &_alglib_env_state);
855 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
856 0 : return *(reinterpret_cast<double*>(&result));
857 : }
858 :
859 : /*************************************************************************
860 : Complete elliptic integral of the first kind
861 :
862 : Approximates the integral
863 :
864 :
865 :
866 : pi/2
867 : -
868 : | |
869 : | dt
870 : K(m) = | ------------------
871 : | 2
872 : | | sqrt( 1 - m sin t )
873 : -
874 : 0
875 :
876 : where m = 1 - m1, using the approximation
877 :
878 : P(x) - log x Q(x).
879 :
880 : The argument m1 is used rather than m so that the logarithmic
881 : singularity at m = 1 will be shifted to the origin; this
882 : preserves maximum accuracy.
883 :
884 : K(0) = pi/2.
885 :
886 : ACCURACY:
887 :
888 : Relative error:
889 : arithmetic domain # trials peak rms
890 : IEEE 0,1 30000 2.5e-16 6.8e-17
891 :
892 : Cephes Math Library, Release 2.8: June, 2000
893 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
894 : *************************************************************************/
895 0 : double ellipticintegralkhighprecision(const double m1, const xparams _xparams)
896 : {
897 : jmp_buf _break_jump;
898 : alglib_impl::ae_state _alglib_env_state;
899 0 : alglib_impl::ae_state_init(&_alglib_env_state);
900 0 : if( setjmp(_break_jump) )
901 : {
902 : #if !defined(AE_NO_EXCEPTIONS)
903 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
904 : #else
905 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
906 : return 0;
907 : #endif
908 : }
909 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
910 0 : if( _xparams.flags!=0x0 )
911 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
912 0 : double result = alglib_impl::ellipticintegralkhighprecision(m1, &_alglib_env_state);
913 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
914 0 : return *(reinterpret_cast<double*>(&result));
915 : }
916 :
917 : /*************************************************************************
918 : Incomplete elliptic integral of the first kind F(phi|m)
919 :
920 : Approximates the integral
921 :
922 :
923 :
924 : phi
925 : -
926 : | |
927 : | dt
928 : F(phi_\m) = | ------------------
929 : | 2
930 : | | sqrt( 1 - m sin t )
931 : -
932 : 0
933 :
934 : of amplitude phi and modulus m, using the arithmetic -
935 : geometric mean algorithm.
936 :
937 :
938 :
939 :
940 : ACCURACY:
941 :
942 : Tested at random points with m in [0, 1] and phi as indicated.
943 :
944 : Relative error:
945 : arithmetic domain # trials peak rms
946 : IEEE -10,10 200000 7.4e-16 1.0e-16
947 :
948 : Cephes Math Library Release 2.8: June, 2000
949 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
950 : *************************************************************************/
951 0 : double incompleteellipticintegralk(const double phi, const double m, const xparams _xparams)
952 : {
953 : jmp_buf _break_jump;
954 : alglib_impl::ae_state _alglib_env_state;
955 0 : alglib_impl::ae_state_init(&_alglib_env_state);
956 0 : if( setjmp(_break_jump) )
957 : {
958 : #if !defined(AE_NO_EXCEPTIONS)
959 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
960 : #else
961 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
962 : return 0;
963 : #endif
964 : }
965 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
966 0 : if( _xparams.flags!=0x0 )
967 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
968 0 : double result = alglib_impl::incompleteellipticintegralk(phi, m, &_alglib_env_state);
969 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
970 0 : return *(reinterpret_cast<double*>(&result));
971 : }
972 :
973 : /*************************************************************************
974 : Complete elliptic integral of the second kind
975 :
976 : Approximates the integral
977 :
978 :
979 : pi/2
980 : -
981 : | | 2
982 : E(m) = | sqrt( 1 - m sin t ) dt
983 : | |
984 : -
985 : 0
986 :
987 : using the approximation
988 :
989 : P(x) - x log x Q(x).
990 :
991 : ACCURACY:
992 :
993 : Relative error:
994 : arithmetic domain # trials peak rms
995 : IEEE 0, 1 10000 2.1e-16 7.3e-17
996 :
997 : Cephes Math Library, Release 2.8: June, 2000
998 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
999 : *************************************************************************/
1000 0 : double ellipticintegrale(const double m, const xparams _xparams)
1001 : {
1002 : jmp_buf _break_jump;
1003 : alglib_impl::ae_state _alglib_env_state;
1004 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1005 0 : if( setjmp(_break_jump) )
1006 : {
1007 : #if !defined(AE_NO_EXCEPTIONS)
1008 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1009 : #else
1010 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1011 : return 0;
1012 : #endif
1013 : }
1014 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1015 0 : if( _xparams.flags!=0x0 )
1016 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1017 0 : double result = alglib_impl::ellipticintegrale(m, &_alglib_env_state);
1018 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1019 0 : return *(reinterpret_cast<double*>(&result));
1020 : }
1021 :
1022 : /*************************************************************************
1023 : Incomplete elliptic integral of the second kind
1024 :
1025 : Approximates the integral
1026 :
1027 :
1028 : phi
1029 : -
1030 : | |
1031 : | 2
1032 : E(phi_\m) = | sqrt( 1 - m sin t ) dt
1033 : |
1034 : | |
1035 : -
1036 : 0
1037 :
1038 : of amplitude phi and modulus m, using the arithmetic -
1039 : geometric mean algorithm.
1040 :
1041 : ACCURACY:
1042 :
1043 : Tested at random arguments with phi in [-10, 10] and m in
1044 : [0, 1].
1045 : Relative error:
1046 : arithmetic domain # trials peak rms
1047 : IEEE -10,10 150000 3.3e-15 1.4e-16
1048 :
1049 : Cephes Math Library Release 2.8: June, 2000
1050 : Copyright 1984, 1987, 1993, 2000 by Stephen L. Moshier
1051 : *************************************************************************/
1052 0 : double incompleteellipticintegrale(const double phi, const double m, const xparams _xparams)
1053 : {
1054 : jmp_buf _break_jump;
1055 : alglib_impl::ae_state _alglib_env_state;
1056 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1057 0 : if( setjmp(_break_jump) )
1058 : {
1059 : #if !defined(AE_NO_EXCEPTIONS)
1060 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1061 : #else
1062 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1063 : return 0;
1064 : #endif
1065 : }
1066 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1067 0 : if( _xparams.flags!=0x0 )
1068 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1069 0 : double result = alglib_impl::incompleteellipticintegrale(phi, m, &_alglib_env_state);
1070 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1071 0 : return *(reinterpret_cast<double*>(&result));
1072 : }
1073 : #endif
1074 :
1075 : #if defined(AE_COMPILE_HERMITE) || !defined(AE_PARTIAL_BUILD)
1076 : /*************************************************************************
1077 : Calculation of the value of the Hermite polynomial.
1078 :
1079 : Parameters:
1080 : n - degree, n>=0
1081 : x - argument
1082 :
1083 : Result:
1084 : the value of the Hermite polynomial Hn at x
1085 : *************************************************************************/
1086 0 : double hermitecalculate(const ae_int_t n, const double x, const xparams _xparams)
1087 : {
1088 : jmp_buf _break_jump;
1089 : alglib_impl::ae_state _alglib_env_state;
1090 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1091 0 : if( setjmp(_break_jump) )
1092 : {
1093 : #if !defined(AE_NO_EXCEPTIONS)
1094 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1095 : #else
1096 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1097 : return 0;
1098 : #endif
1099 : }
1100 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1101 0 : if( _xparams.flags!=0x0 )
1102 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1103 0 : double result = alglib_impl::hermitecalculate(n, x, &_alglib_env_state);
1104 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1105 0 : return *(reinterpret_cast<double*>(&result));
1106 : }
1107 :
1108 : /*************************************************************************
1109 : Summation of Hermite polynomials using Clenshaw's recurrence formula.
1110 :
1111 : This routine calculates
1112 : c[0]*H0(x) + c[1]*H1(x) + ... + c[N]*HN(x)
1113 :
1114 : Parameters:
1115 : n - degree, n>=0
1116 : x - argument
1117 :
1118 : Result:
1119 : the value of the Hermite polynomial at x
1120 : *************************************************************************/
1121 0 : double hermitesum(const real_1d_array &c, const ae_int_t n, const double x, const xparams _xparams)
1122 : {
1123 : jmp_buf _break_jump;
1124 : alglib_impl::ae_state _alglib_env_state;
1125 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1126 0 : if( setjmp(_break_jump) )
1127 : {
1128 : #if !defined(AE_NO_EXCEPTIONS)
1129 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1130 : #else
1131 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1132 : return 0;
1133 : #endif
1134 : }
1135 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1136 0 : if( _xparams.flags!=0x0 )
1137 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1138 0 : double result = alglib_impl::hermitesum(const_cast<alglib_impl::ae_vector*>(c.c_ptr()), n, x, &_alglib_env_state);
1139 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1140 0 : return *(reinterpret_cast<double*>(&result));
1141 : }
1142 :
1143 : /*************************************************************************
1144 : Representation of Hn as C[0] + C[1]*X + ... + C[N]*X^N
1145 :
1146 : Input parameters:
1147 : N - polynomial degree, n>=0
1148 :
1149 : Output parameters:
1150 : C - coefficients
1151 : *************************************************************************/
1152 0 : void hermitecoefficients(const ae_int_t n, real_1d_array &c, const xparams _xparams)
1153 : {
1154 : jmp_buf _break_jump;
1155 : alglib_impl::ae_state _alglib_env_state;
1156 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1157 0 : if( setjmp(_break_jump) )
1158 : {
1159 : #if !defined(AE_NO_EXCEPTIONS)
1160 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1161 : #else
1162 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1163 : return;
1164 : #endif
1165 : }
1166 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1167 0 : if( _xparams.flags!=0x0 )
1168 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1169 0 : alglib_impl::hermitecoefficients(n, const_cast<alglib_impl::ae_vector*>(c.c_ptr()), &_alglib_env_state);
1170 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1171 0 : return;
1172 : }
1173 : #endif
1174 :
1175 : #if defined(AE_COMPILE_DAWSON) || !defined(AE_PARTIAL_BUILD)
1176 : /*************************************************************************
1177 : Dawson's Integral
1178 :
1179 : Approximates the integral
1180 :
1181 : x
1182 : -
1183 : 2 | | 2
1184 : dawsn(x) = exp( -x ) | exp( t ) dt
1185 : | |
1186 : -
1187 : 0
1188 :
1189 : Three different rational approximations are employed, for
1190 : the intervals 0 to 3.25; 3.25 to 6.25; and 6.25 up.
1191 :
1192 : ACCURACY:
1193 :
1194 : Relative error:
1195 : arithmetic domain # trials peak rms
1196 : IEEE 0,10 10000 6.9e-16 1.0e-16
1197 :
1198 : Cephes Math Library Release 2.8: June, 2000
1199 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
1200 : *************************************************************************/
1201 0 : double dawsonintegral(const double x, const xparams _xparams)
1202 : {
1203 : jmp_buf _break_jump;
1204 : alglib_impl::ae_state _alglib_env_state;
1205 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1206 0 : if( setjmp(_break_jump) )
1207 : {
1208 : #if !defined(AE_NO_EXCEPTIONS)
1209 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1210 : #else
1211 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1212 : return 0;
1213 : #endif
1214 : }
1215 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1216 0 : if( _xparams.flags!=0x0 )
1217 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1218 0 : double result = alglib_impl::dawsonintegral(x, &_alglib_env_state);
1219 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1220 0 : return *(reinterpret_cast<double*>(&result));
1221 : }
1222 : #endif
1223 :
1224 : #if defined(AE_COMPILE_TRIGINTEGRALS) || !defined(AE_PARTIAL_BUILD)
1225 : /*************************************************************************
1226 : Sine and cosine integrals
1227 :
1228 : Evaluates the integrals
1229 :
1230 : x
1231 : -
1232 : | cos t - 1
1233 : Ci(x) = eul + ln x + | --------- dt,
1234 : | t
1235 : -
1236 : 0
1237 : x
1238 : -
1239 : | sin t
1240 : Si(x) = | ----- dt
1241 : | t
1242 : -
1243 : 0
1244 :
1245 : where eul = 0.57721566490153286061 is Euler's constant.
1246 : The integrals are approximated by rational functions.
1247 : For x > 8 auxiliary functions f(x) and g(x) are employed
1248 : such that
1249 :
1250 : Ci(x) = f(x) sin(x) - g(x) cos(x)
1251 : Si(x) = pi/2 - f(x) cos(x) - g(x) sin(x)
1252 :
1253 :
1254 : ACCURACY:
1255 : Test interval = [0,50].
1256 : Absolute error, except relative when > 1:
1257 : arithmetic function # trials peak rms
1258 : IEEE Si 30000 4.4e-16 7.3e-17
1259 : IEEE Ci 30000 6.9e-16 5.1e-17
1260 :
1261 : Cephes Math Library Release 2.1: January, 1989
1262 : Copyright 1984, 1987, 1989 by Stephen L. Moshier
1263 : *************************************************************************/
1264 0 : void sinecosineintegrals(const double x, double &si, double &ci, const xparams _xparams)
1265 : {
1266 : jmp_buf _break_jump;
1267 : alglib_impl::ae_state _alglib_env_state;
1268 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1269 0 : if( setjmp(_break_jump) )
1270 : {
1271 : #if !defined(AE_NO_EXCEPTIONS)
1272 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1273 : #else
1274 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1275 : return;
1276 : #endif
1277 : }
1278 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1279 0 : if( _xparams.flags!=0x0 )
1280 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1281 0 : alglib_impl::sinecosineintegrals(x, &si, &ci, &_alglib_env_state);
1282 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1283 0 : return;
1284 : }
1285 :
1286 : /*************************************************************************
1287 : Hyperbolic sine and cosine integrals
1288 :
1289 : Approximates the integrals
1290 :
1291 : x
1292 : -
1293 : | | cosh t - 1
1294 : Chi(x) = eul + ln x + | ----------- dt,
1295 : | | t
1296 : -
1297 : 0
1298 :
1299 : x
1300 : -
1301 : | | sinh t
1302 : Shi(x) = | ------ dt
1303 : | | t
1304 : -
1305 : 0
1306 :
1307 : where eul = 0.57721566490153286061 is Euler's constant.
1308 : The integrals are evaluated by power series for x < 8
1309 : and by Chebyshev expansions for x between 8 and 88.
1310 : For large x, both functions approach exp(x)/2x.
1311 : Arguments greater than 88 in magnitude return MAXNUM.
1312 :
1313 :
1314 : ACCURACY:
1315 :
1316 : Test interval 0 to 88.
1317 : Relative error:
1318 : arithmetic function # trials peak rms
1319 : IEEE Shi 30000 6.9e-16 1.6e-16
1320 : Absolute error, except relative when |Chi| > 1:
1321 : IEEE Chi 30000 8.4e-16 1.4e-16
1322 :
1323 : Cephes Math Library Release 2.8: June, 2000
1324 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
1325 : *************************************************************************/
1326 0 : void hyperbolicsinecosineintegrals(const double x, double &shi, double &chi, const xparams _xparams)
1327 : {
1328 : jmp_buf _break_jump;
1329 : alglib_impl::ae_state _alglib_env_state;
1330 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1331 0 : if( setjmp(_break_jump) )
1332 : {
1333 : #if !defined(AE_NO_EXCEPTIONS)
1334 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1335 : #else
1336 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1337 : return;
1338 : #endif
1339 : }
1340 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1341 0 : if( _xparams.flags!=0x0 )
1342 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1343 0 : alglib_impl::hyperbolicsinecosineintegrals(x, &shi, &chi, &_alglib_env_state);
1344 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1345 0 : return;
1346 : }
1347 : #endif
1348 :
1349 : #if defined(AE_COMPILE_POISSONDISTR) || !defined(AE_PARTIAL_BUILD)
1350 : /*************************************************************************
1351 : Poisson distribution
1352 :
1353 : Returns the sum of the first k+1 terms of the Poisson
1354 : distribution:
1355 :
1356 : k j
1357 : -- -m m
1358 : > e --
1359 : -- j!
1360 : j=0
1361 :
1362 : The terms are not summed directly; instead the incomplete
1363 : gamma integral is employed, according to the relation
1364 :
1365 : y = pdtr( k, m ) = igamc( k+1, m ).
1366 :
1367 : The arguments must both be positive.
1368 : ACCURACY:
1369 :
1370 : See incomplete gamma function
1371 :
1372 : Cephes Math Library Release 2.8: June, 2000
1373 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
1374 : *************************************************************************/
1375 0 : double poissondistribution(const ae_int_t k, const double m, const xparams _xparams)
1376 : {
1377 : jmp_buf _break_jump;
1378 : alglib_impl::ae_state _alglib_env_state;
1379 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1380 0 : if( setjmp(_break_jump) )
1381 : {
1382 : #if !defined(AE_NO_EXCEPTIONS)
1383 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1384 : #else
1385 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1386 : return 0;
1387 : #endif
1388 : }
1389 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1390 0 : if( _xparams.flags!=0x0 )
1391 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1392 0 : double result = alglib_impl::poissondistribution(k, m, &_alglib_env_state);
1393 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1394 0 : return *(reinterpret_cast<double*>(&result));
1395 : }
1396 :
1397 : /*************************************************************************
1398 : Complemented Poisson distribution
1399 :
1400 : Returns the sum of the terms k+1 to infinity of the Poisson
1401 : distribution:
1402 :
1403 : inf. j
1404 : -- -m m
1405 : > e --
1406 : -- j!
1407 : j=k+1
1408 :
1409 : The terms are not summed directly; instead the incomplete
1410 : gamma integral is employed, according to the formula
1411 :
1412 : y = pdtrc( k, m ) = igam( k+1, m ).
1413 :
1414 : The arguments must both be positive.
1415 :
1416 : ACCURACY:
1417 :
1418 : See incomplete gamma function
1419 :
1420 : Cephes Math Library Release 2.8: June, 2000
1421 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
1422 : *************************************************************************/
1423 0 : double poissoncdistribution(const ae_int_t k, const double m, const xparams _xparams)
1424 : {
1425 : jmp_buf _break_jump;
1426 : alglib_impl::ae_state _alglib_env_state;
1427 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1428 0 : if( setjmp(_break_jump) )
1429 : {
1430 : #if !defined(AE_NO_EXCEPTIONS)
1431 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1432 : #else
1433 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1434 : return 0;
1435 : #endif
1436 : }
1437 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1438 0 : if( _xparams.flags!=0x0 )
1439 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1440 0 : double result = alglib_impl::poissoncdistribution(k, m, &_alglib_env_state);
1441 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1442 0 : return *(reinterpret_cast<double*>(&result));
1443 : }
1444 :
1445 : /*************************************************************************
1446 : Inverse Poisson distribution
1447 :
1448 : Finds the Poisson variable x such that the integral
1449 : from 0 to x of the Poisson density is equal to the
1450 : given probability y.
1451 :
1452 : This is accomplished using the inverse gamma integral
1453 : function and the relation
1454 :
1455 : m = igami( k+1, y ).
1456 :
1457 : ACCURACY:
1458 :
1459 : See inverse incomplete gamma function
1460 :
1461 : Cephes Math Library Release 2.8: June, 2000
1462 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
1463 : *************************************************************************/
1464 0 : double invpoissondistribution(const ae_int_t k, const double y, const xparams _xparams)
1465 : {
1466 : jmp_buf _break_jump;
1467 : alglib_impl::ae_state _alglib_env_state;
1468 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1469 0 : if( setjmp(_break_jump) )
1470 : {
1471 : #if !defined(AE_NO_EXCEPTIONS)
1472 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1473 : #else
1474 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1475 : return 0;
1476 : #endif
1477 : }
1478 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1479 0 : if( _xparams.flags!=0x0 )
1480 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1481 0 : double result = alglib_impl::invpoissondistribution(k, y, &_alglib_env_state);
1482 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1483 0 : return *(reinterpret_cast<double*>(&result));
1484 : }
1485 : #endif
1486 :
1487 : #if defined(AE_COMPILE_BESSEL) || !defined(AE_PARTIAL_BUILD)
1488 : /*************************************************************************
1489 : Bessel function of order zero
1490 :
1491 : Returns Bessel function of order zero of the argument.
1492 :
1493 : The domain is divided into the intervals [0, 5] and
1494 : (5, infinity). In the first interval the following rational
1495 : approximation is used:
1496 :
1497 :
1498 : 2 2
1499 : (w - r ) (w - r ) P (w) / Q (w)
1500 : 1 2 3 8
1501 :
1502 : 2
1503 : where w = x and the two r's are zeros of the function.
1504 :
1505 : In the second interval, the Hankel asymptotic expansion
1506 : is employed with two rational functions of degree 6/6
1507 : and 7/7.
1508 :
1509 : ACCURACY:
1510 :
1511 : Absolute error:
1512 : arithmetic domain # trials peak rms
1513 : IEEE 0, 30 60000 4.2e-16 1.1e-16
1514 :
1515 : Cephes Math Library Release 2.8: June, 2000
1516 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
1517 : *************************************************************************/
1518 0 : double besselj0(const double x, const xparams _xparams)
1519 : {
1520 : jmp_buf _break_jump;
1521 : alglib_impl::ae_state _alglib_env_state;
1522 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1523 0 : if( setjmp(_break_jump) )
1524 : {
1525 : #if !defined(AE_NO_EXCEPTIONS)
1526 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1527 : #else
1528 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1529 : return 0;
1530 : #endif
1531 : }
1532 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1533 0 : if( _xparams.flags!=0x0 )
1534 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1535 0 : double result = alglib_impl::besselj0(x, &_alglib_env_state);
1536 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1537 0 : return *(reinterpret_cast<double*>(&result));
1538 : }
1539 :
1540 : /*************************************************************************
1541 : Bessel function of order one
1542 :
1543 : Returns Bessel function of order one of the argument.
1544 :
1545 : The domain is divided into the intervals [0, 8] and
1546 : (8, infinity). In the first interval a 24 term Chebyshev
1547 : expansion is used. In the second, the asymptotic
1548 : trigonometric representation is employed using two
1549 : rational functions of degree 5/5.
1550 :
1551 : ACCURACY:
1552 :
1553 : Absolute error:
1554 : arithmetic domain # trials peak rms
1555 : IEEE 0, 30 30000 2.6e-16 1.1e-16
1556 :
1557 : Cephes Math Library Release 2.8: June, 2000
1558 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
1559 : *************************************************************************/
1560 0 : double besselj1(const double x, const xparams _xparams)
1561 : {
1562 : jmp_buf _break_jump;
1563 : alglib_impl::ae_state _alglib_env_state;
1564 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1565 0 : if( setjmp(_break_jump) )
1566 : {
1567 : #if !defined(AE_NO_EXCEPTIONS)
1568 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1569 : #else
1570 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1571 : return 0;
1572 : #endif
1573 : }
1574 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1575 0 : if( _xparams.flags!=0x0 )
1576 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1577 0 : double result = alglib_impl::besselj1(x, &_alglib_env_state);
1578 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1579 0 : return *(reinterpret_cast<double*>(&result));
1580 : }
1581 :
1582 : /*************************************************************************
1583 : Bessel function of integer order
1584 :
1585 : Returns Bessel function of order n, where n is a
1586 : (possibly negative) integer.
1587 :
1588 : The ratio of jn(x) to j0(x) is computed by backward
1589 : recurrence. First the ratio jn/jn-1 is found by a
1590 : continued fraction expansion. Then the recurrence
1591 : relating successive orders is applied until j0 or j1 is
1592 : reached.
1593 :
1594 : If n = 0 or 1 the routine for j0 or j1 is called
1595 : directly.
1596 :
1597 : ACCURACY:
1598 :
1599 : Absolute error:
1600 : arithmetic range # trials peak rms
1601 : IEEE 0, 30 5000 4.4e-16 7.9e-17
1602 :
1603 :
1604 : Not suitable for large n or x. Use jv() (fractional order) instead.
1605 :
1606 : Cephes Math Library Release 2.8: June, 2000
1607 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
1608 : *************************************************************************/
1609 0 : double besseljn(const ae_int_t n, const double x, const xparams _xparams)
1610 : {
1611 : jmp_buf _break_jump;
1612 : alglib_impl::ae_state _alglib_env_state;
1613 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1614 0 : if( setjmp(_break_jump) )
1615 : {
1616 : #if !defined(AE_NO_EXCEPTIONS)
1617 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1618 : #else
1619 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1620 : return 0;
1621 : #endif
1622 : }
1623 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1624 0 : if( _xparams.flags!=0x0 )
1625 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1626 0 : double result = alglib_impl::besseljn(n, x, &_alglib_env_state);
1627 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1628 0 : return *(reinterpret_cast<double*>(&result));
1629 : }
1630 :
1631 : /*************************************************************************
1632 : Bessel function of the second kind, order zero
1633 :
1634 : Returns Bessel function of the second kind, of order
1635 : zero, of the argument.
1636 :
1637 : The domain is divided into the intervals [0, 5] and
1638 : (5, infinity). In the first interval a rational approximation
1639 : R(x) is employed to compute
1640 : y0(x) = R(x) + 2 * log(x) * j0(x) / PI.
1641 : Thus a call to j0() is required.
1642 :
1643 : In the second interval, the Hankel asymptotic expansion
1644 : is employed with two rational functions of degree 6/6
1645 : and 7/7.
1646 :
1647 :
1648 :
1649 : ACCURACY:
1650 :
1651 : Absolute error, when y0(x) < 1; else relative error:
1652 :
1653 : arithmetic domain # trials peak rms
1654 : IEEE 0, 30 30000 1.3e-15 1.6e-16
1655 :
1656 : Cephes Math Library Release 2.8: June, 2000
1657 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
1658 : *************************************************************************/
1659 0 : double bessely0(const double x, const xparams _xparams)
1660 : {
1661 : jmp_buf _break_jump;
1662 : alglib_impl::ae_state _alglib_env_state;
1663 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1664 0 : if( setjmp(_break_jump) )
1665 : {
1666 : #if !defined(AE_NO_EXCEPTIONS)
1667 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1668 : #else
1669 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1670 : return 0;
1671 : #endif
1672 : }
1673 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1674 0 : if( _xparams.flags!=0x0 )
1675 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1676 0 : double result = alglib_impl::bessely0(x, &_alglib_env_state);
1677 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1678 0 : return *(reinterpret_cast<double*>(&result));
1679 : }
1680 :
1681 : /*************************************************************************
1682 : Bessel function of second kind of order one
1683 :
1684 : Returns Bessel function of the second kind of order one
1685 : of the argument.
1686 :
1687 : The domain is divided into the intervals [0, 8] and
1688 : (8, infinity). In the first interval a 25 term Chebyshev
1689 : expansion is used, and a call to j1() is required.
1690 : In the second, the asymptotic trigonometric representation
1691 : is employed using two rational functions of degree 5/5.
1692 :
1693 : ACCURACY:
1694 :
1695 : Absolute error:
1696 : arithmetic domain # trials peak rms
1697 : IEEE 0, 30 30000 1.0e-15 1.3e-16
1698 :
1699 : Cephes Math Library Release 2.8: June, 2000
1700 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
1701 : *************************************************************************/
1702 0 : double bessely1(const double x, const xparams _xparams)
1703 : {
1704 : jmp_buf _break_jump;
1705 : alglib_impl::ae_state _alglib_env_state;
1706 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1707 0 : if( setjmp(_break_jump) )
1708 : {
1709 : #if !defined(AE_NO_EXCEPTIONS)
1710 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1711 : #else
1712 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1713 : return 0;
1714 : #endif
1715 : }
1716 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1717 0 : if( _xparams.flags!=0x0 )
1718 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1719 0 : double result = alglib_impl::bessely1(x, &_alglib_env_state);
1720 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1721 0 : return *(reinterpret_cast<double*>(&result));
1722 : }
1723 :
1724 : /*************************************************************************
1725 : Bessel function of second kind of integer order
1726 :
1727 : Returns Bessel function of order n, where n is a
1728 : (possibly negative) integer.
1729 :
1730 : The function is evaluated by forward recurrence on
1731 : n, starting with values computed by the routines
1732 : y0() and y1().
1733 :
1734 : If n = 0 or 1 the routine for y0 or y1 is called
1735 : directly.
1736 :
1737 : ACCURACY:
1738 : Absolute error, except relative
1739 : when y > 1:
1740 : arithmetic domain # trials peak rms
1741 : IEEE 0, 30 30000 3.4e-15 4.3e-16
1742 :
1743 : Cephes Math Library Release 2.8: June, 2000
1744 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
1745 : *************************************************************************/
1746 0 : double besselyn(const ae_int_t n, const double x, const xparams _xparams)
1747 : {
1748 : jmp_buf _break_jump;
1749 : alglib_impl::ae_state _alglib_env_state;
1750 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1751 0 : if( setjmp(_break_jump) )
1752 : {
1753 : #if !defined(AE_NO_EXCEPTIONS)
1754 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1755 : #else
1756 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1757 : return 0;
1758 : #endif
1759 : }
1760 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1761 0 : if( _xparams.flags!=0x0 )
1762 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1763 0 : double result = alglib_impl::besselyn(n, x, &_alglib_env_state);
1764 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1765 0 : return *(reinterpret_cast<double*>(&result));
1766 : }
1767 :
1768 : /*************************************************************************
1769 : Modified Bessel function of order zero
1770 :
1771 : Returns modified Bessel function of order zero of the
1772 : argument.
1773 :
1774 : The function is defined as i0(x) = j0( ix ).
1775 :
1776 : The range is partitioned into the two intervals [0,8] and
1777 : (8, infinity). Chebyshev polynomial expansions are employed
1778 : in each interval.
1779 :
1780 : ACCURACY:
1781 :
1782 : Relative error:
1783 : arithmetic domain # trials peak rms
1784 : IEEE 0,30 30000 5.8e-16 1.4e-16
1785 :
1786 : Cephes Math Library Release 2.8: June, 2000
1787 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
1788 : *************************************************************************/
1789 0 : double besseli0(const double x, const xparams _xparams)
1790 : {
1791 : jmp_buf _break_jump;
1792 : alglib_impl::ae_state _alglib_env_state;
1793 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1794 0 : if( setjmp(_break_jump) )
1795 : {
1796 : #if !defined(AE_NO_EXCEPTIONS)
1797 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1798 : #else
1799 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1800 : return 0;
1801 : #endif
1802 : }
1803 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1804 0 : if( _xparams.flags!=0x0 )
1805 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1806 0 : double result = alglib_impl::besseli0(x, &_alglib_env_state);
1807 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1808 0 : return *(reinterpret_cast<double*>(&result));
1809 : }
1810 :
1811 : /*************************************************************************
1812 : Modified Bessel function of order one
1813 :
1814 : Returns modified Bessel function of order one of the
1815 : argument.
1816 :
1817 : The function is defined as i1(x) = -i j1( ix ).
1818 :
1819 : The range is partitioned into the two intervals [0,8] and
1820 : (8, infinity). Chebyshev polynomial expansions are employed
1821 : in each interval.
1822 :
1823 : ACCURACY:
1824 :
1825 : Relative error:
1826 : arithmetic domain # trials peak rms
1827 : IEEE 0, 30 30000 1.9e-15 2.1e-16
1828 :
1829 : Cephes Math Library Release 2.8: June, 2000
1830 : Copyright 1985, 1987, 2000 by Stephen L. Moshier
1831 : *************************************************************************/
1832 0 : double besseli1(const double x, const xparams _xparams)
1833 : {
1834 : jmp_buf _break_jump;
1835 : alglib_impl::ae_state _alglib_env_state;
1836 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1837 0 : if( setjmp(_break_jump) )
1838 : {
1839 : #if !defined(AE_NO_EXCEPTIONS)
1840 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1841 : #else
1842 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1843 : return 0;
1844 : #endif
1845 : }
1846 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1847 0 : if( _xparams.flags!=0x0 )
1848 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1849 0 : double result = alglib_impl::besseli1(x, &_alglib_env_state);
1850 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1851 0 : return *(reinterpret_cast<double*>(&result));
1852 : }
1853 :
1854 : /*************************************************************************
1855 : Modified Bessel function, second kind, order zero
1856 :
1857 : Returns modified Bessel function of the second kind
1858 : of order zero of the argument.
1859 :
1860 : The range is partitioned into the two intervals [0,8] and
1861 : (8, infinity). Chebyshev polynomial expansions are employed
1862 : in each interval.
1863 :
1864 : ACCURACY:
1865 :
1866 : Tested at 2000 random points between 0 and 8. Peak absolute
1867 : error (relative when K0 > 1) was 1.46e-14; rms, 4.26e-15.
1868 : Relative error:
1869 : arithmetic domain # trials peak rms
1870 : IEEE 0, 30 30000 1.2e-15 1.6e-16
1871 :
1872 : Cephes Math Library Release 2.8: June, 2000
1873 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
1874 : *************************************************************************/
1875 0 : double besselk0(const double x, const xparams _xparams)
1876 : {
1877 : jmp_buf _break_jump;
1878 : alglib_impl::ae_state _alglib_env_state;
1879 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1880 0 : if( setjmp(_break_jump) )
1881 : {
1882 : #if !defined(AE_NO_EXCEPTIONS)
1883 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1884 : #else
1885 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1886 : return 0;
1887 : #endif
1888 : }
1889 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1890 0 : if( _xparams.flags!=0x0 )
1891 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1892 0 : double result = alglib_impl::besselk0(x, &_alglib_env_state);
1893 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1894 0 : return *(reinterpret_cast<double*>(&result));
1895 : }
1896 :
1897 : /*************************************************************************
1898 : Modified Bessel function, second kind, order one
1899 :
1900 : Computes the modified Bessel function of the second kind
1901 : of order one of the argument.
1902 :
1903 : The range is partitioned into the two intervals [0,2] and
1904 : (2, infinity). Chebyshev polynomial expansions are employed
1905 : in each interval.
1906 :
1907 : ACCURACY:
1908 :
1909 : Relative error:
1910 : arithmetic domain # trials peak rms
1911 : IEEE 0, 30 30000 1.2e-15 1.6e-16
1912 :
1913 : Cephes Math Library Release 2.8: June, 2000
1914 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
1915 : *************************************************************************/
1916 0 : double besselk1(const double x, const xparams _xparams)
1917 : {
1918 : jmp_buf _break_jump;
1919 : alglib_impl::ae_state _alglib_env_state;
1920 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1921 0 : if( setjmp(_break_jump) )
1922 : {
1923 : #if !defined(AE_NO_EXCEPTIONS)
1924 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1925 : #else
1926 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1927 : return 0;
1928 : #endif
1929 : }
1930 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1931 0 : if( _xparams.flags!=0x0 )
1932 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1933 0 : double result = alglib_impl::besselk1(x, &_alglib_env_state);
1934 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1935 0 : return *(reinterpret_cast<double*>(&result));
1936 : }
1937 :
1938 : /*************************************************************************
1939 : Modified Bessel function, second kind, integer order
1940 :
1941 : Returns modified Bessel function of the second kind
1942 : of order n of the argument.
1943 :
1944 : The range is partitioned into the two intervals [0,9.55] and
1945 : (9.55, infinity). An ascending power series is used in the
1946 : low range, and an asymptotic expansion in the high range.
1947 :
1948 : ACCURACY:
1949 :
1950 : Relative error:
1951 : arithmetic domain # trials peak rms
1952 : IEEE 0,30 90000 1.8e-8 3.0e-10
1953 :
1954 : Error is high only near the crossover point x = 9.55
1955 : between the two expansions used.
1956 :
1957 : Cephes Math Library Release 2.8: June, 2000
1958 : Copyright 1984, 1987, 1988, 2000 by Stephen L. Moshier
1959 : *************************************************************************/
1960 0 : double besselkn(const ae_int_t nn, const double x, const xparams _xparams)
1961 : {
1962 : jmp_buf _break_jump;
1963 : alglib_impl::ae_state _alglib_env_state;
1964 0 : alglib_impl::ae_state_init(&_alglib_env_state);
1965 0 : if( setjmp(_break_jump) )
1966 : {
1967 : #if !defined(AE_NO_EXCEPTIONS)
1968 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
1969 : #else
1970 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
1971 : return 0;
1972 : #endif
1973 : }
1974 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
1975 0 : if( _xparams.flags!=0x0 )
1976 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
1977 0 : double result = alglib_impl::besselkn(nn, x, &_alglib_env_state);
1978 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
1979 0 : return *(reinterpret_cast<double*>(&result));
1980 : }
1981 : #endif
1982 :
1983 : #if defined(AE_COMPILE_IBETAF) || !defined(AE_PARTIAL_BUILD)
1984 : /*************************************************************************
1985 : Incomplete beta integral
1986 :
1987 : Returns incomplete beta integral of the arguments, evaluated
1988 : from zero to x. The function is defined as
1989 :
1990 : x
1991 : - -
1992 : | (a+b) | | a-1 b-1
1993 : ----------- | t (1-t) dt.
1994 : - - | |
1995 : | (a) | (b) -
1996 : 0
1997 :
1998 : The domain of definition is 0 <= x <= 1. In this
1999 : implementation a and b are restricted to positive values.
2000 : The integral from x to 1 may be obtained by the symmetry
2001 : relation
2002 :
2003 : 1 - incbet( a, b, x ) = incbet( b, a, 1-x ).
2004 :
2005 : The integral is evaluated by a continued fraction expansion
2006 : or, when b*x is small, by a power series.
2007 :
2008 : ACCURACY:
2009 :
2010 : Tested at uniformly distributed random points (a,b,x) with a and b
2011 : in "domain" and x between 0 and 1.
2012 : Relative error
2013 : arithmetic domain # trials peak rms
2014 : IEEE 0,5 10000 6.9e-15 4.5e-16
2015 : IEEE 0,85 250000 2.2e-13 1.7e-14
2016 : IEEE 0,1000 30000 5.3e-12 6.3e-13
2017 : IEEE 0,10000 250000 9.3e-11 7.1e-12
2018 : IEEE 0,100000 10000 8.7e-10 4.8e-11
2019 : Outputs smaller than the IEEE gradual underflow threshold
2020 : were excluded from these statistics.
2021 :
2022 : Cephes Math Library, Release 2.8: June, 2000
2023 : Copyright 1984, 1995, 2000 by Stephen L. Moshier
2024 : *************************************************************************/
2025 0 : double incompletebeta(const double a, const double b, const double x, const xparams _xparams)
2026 : {
2027 : jmp_buf _break_jump;
2028 : alglib_impl::ae_state _alglib_env_state;
2029 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2030 0 : if( setjmp(_break_jump) )
2031 : {
2032 : #if !defined(AE_NO_EXCEPTIONS)
2033 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2034 : #else
2035 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2036 : return 0;
2037 : #endif
2038 : }
2039 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2040 0 : if( _xparams.flags!=0x0 )
2041 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2042 0 : double result = alglib_impl::incompletebeta(a, b, x, &_alglib_env_state);
2043 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2044 0 : return *(reinterpret_cast<double*>(&result));
2045 : }
2046 :
2047 : /*************************************************************************
2048 : Inverse of imcomplete beta integral
2049 :
2050 : Given y, the function finds x such that
2051 :
2052 : incbet( a, b, x ) = y .
2053 :
2054 : The routine performs interval halving or Newton iterations to find the
2055 : root of incbet(a,b,x) - y = 0.
2056 :
2057 :
2058 : ACCURACY:
2059 :
2060 : Relative error:
2061 : x a,b
2062 : arithmetic domain domain # trials peak rms
2063 : IEEE 0,1 .5,10000 50000 5.8e-12 1.3e-13
2064 : IEEE 0,1 .25,100 100000 1.8e-13 3.9e-15
2065 : IEEE 0,1 0,5 50000 1.1e-12 5.5e-15
2066 : With a and b constrained to half-integer or integer values:
2067 : IEEE 0,1 .5,10000 50000 5.8e-12 1.1e-13
2068 : IEEE 0,1 .5,100 100000 1.7e-14 7.9e-16
2069 : With a = .5, b constrained to half-integer or integer values:
2070 : IEEE 0,1 .5,10000 10000 8.3e-11 1.0e-11
2071 :
2072 : Cephes Math Library Release 2.8: June, 2000
2073 : Copyright 1984, 1996, 2000 by Stephen L. Moshier
2074 : *************************************************************************/
2075 0 : double invincompletebeta(const double a, const double b, const double y, const xparams _xparams)
2076 : {
2077 : jmp_buf _break_jump;
2078 : alglib_impl::ae_state _alglib_env_state;
2079 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2080 0 : if( setjmp(_break_jump) )
2081 : {
2082 : #if !defined(AE_NO_EXCEPTIONS)
2083 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2084 : #else
2085 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2086 : return 0;
2087 : #endif
2088 : }
2089 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2090 0 : if( _xparams.flags!=0x0 )
2091 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2092 0 : double result = alglib_impl::invincompletebeta(a, b, y, &_alglib_env_state);
2093 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2094 0 : return *(reinterpret_cast<double*>(&result));
2095 : }
2096 : #endif
2097 :
2098 : #if defined(AE_COMPILE_FDISTR) || !defined(AE_PARTIAL_BUILD)
2099 : /*************************************************************************
2100 : F distribution
2101 :
2102 : Returns the area from zero to x under the F density
2103 : function (also known as Snedcor's density or the
2104 : variance ratio density). This is the density
2105 : of x = (u1/df1)/(u2/df2), where u1 and u2 are random
2106 : variables having Chi square distributions with df1
2107 : and df2 degrees of freedom, respectively.
2108 : The incomplete beta integral is used, according to the
2109 : formula
2110 :
2111 : P(x) = incbet( df1/2, df2/2, (df1*x/(df2 + df1*x) ).
2112 :
2113 :
2114 : The arguments a and b are greater than zero, and x is
2115 : nonnegative.
2116 :
2117 : ACCURACY:
2118 :
2119 : Tested at random points (a,b,x).
2120 :
2121 : x a,b Relative error:
2122 : arithmetic domain domain # trials peak rms
2123 : IEEE 0,1 0,100 100000 9.8e-15 1.7e-15
2124 : IEEE 1,5 0,100 100000 6.5e-15 3.5e-16
2125 : IEEE 0,1 1,10000 100000 2.2e-11 3.3e-12
2126 : IEEE 1,5 1,10000 100000 1.1e-11 1.7e-13
2127 :
2128 : Cephes Math Library Release 2.8: June, 2000
2129 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
2130 : *************************************************************************/
2131 0 : double fdistribution(const ae_int_t a, const ae_int_t b, const double x, const xparams _xparams)
2132 : {
2133 : jmp_buf _break_jump;
2134 : alglib_impl::ae_state _alglib_env_state;
2135 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2136 0 : if( setjmp(_break_jump) )
2137 : {
2138 : #if !defined(AE_NO_EXCEPTIONS)
2139 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2140 : #else
2141 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2142 : return 0;
2143 : #endif
2144 : }
2145 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2146 0 : if( _xparams.flags!=0x0 )
2147 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2148 0 : double result = alglib_impl::fdistribution(a, b, x, &_alglib_env_state);
2149 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2150 0 : return *(reinterpret_cast<double*>(&result));
2151 : }
2152 :
2153 : /*************************************************************************
2154 : Complemented F distribution
2155 :
2156 : Returns the area from x to infinity under the F density
2157 : function (also known as Snedcor's density or the
2158 : variance ratio density).
2159 :
2160 :
2161 : inf.
2162 : -
2163 : 1 | | a-1 b-1
2164 : 1-P(x) = ------ | t (1-t) dt
2165 : B(a,b) | |
2166 : -
2167 : x
2168 :
2169 :
2170 : The incomplete beta integral is used, according to the
2171 : formula
2172 :
2173 : P(x) = incbet( df2/2, df1/2, (df2/(df2 + df1*x) ).
2174 :
2175 :
2176 : ACCURACY:
2177 :
2178 : Tested at random points (a,b,x) in the indicated intervals.
2179 : x a,b Relative error:
2180 : arithmetic domain domain # trials peak rms
2181 : IEEE 0,1 1,100 100000 3.7e-14 5.9e-16
2182 : IEEE 1,5 1,100 100000 8.0e-15 1.6e-15
2183 : IEEE 0,1 1,10000 100000 1.8e-11 3.5e-13
2184 : IEEE 1,5 1,10000 100000 2.0e-11 3.0e-12
2185 :
2186 : Cephes Math Library Release 2.8: June, 2000
2187 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
2188 : *************************************************************************/
2189 0 : double fcdistribution(const ae_int_t a, const ae_int_t b, const double x, const xparams _xparams)
2190 : {
2191 : jmp_buf _break_jump;
2192 : alglib_impl::ae_state _alglib_env_state;
2193 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2194 0 : if( setjmp(_break_jump) )
2195 : {
2196 : #if !defined(AE_NO_EXCEPTIONS)
2197 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2198 : #else
2199 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2200 : return 0;
2201 : #endif
2202 : }
2203 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2204 0 : if( _xparams.flags!=0x0 )
2205 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2206 0 : double result = alglib_impl::fcdistribution(a, b, x, &_alglib_env_state);
2207 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2208 0 : return *(reinterpret_cast<double*>(&result));
2209 : }
2210 :
2211 : /*************************************************************************
2212 : Inverse of complemented F distribution
2213 :
2214 : Finds the F density argument x such that the integral
2215 : from x to infinity of the F density is equal to the
2216 : given probability p.
2217 :
2218 : This is accomplished using the inverse beta integral
2219 : function and the relations
2220 :
2221 : z = incbi( df2/2, df1/2, p )
2222 : x = df2 (1-z) / (df1 z).
2223 :
2224 : Note: the following relations hold for the inverse of
2225 : the uncomplemented F distribution:
2226 :
2227 : z = incbi( df1/2, df2/2, p )
2228 : x = df2 z / (df1 (1-z)).
2229 :
2230 : ACCURACY:
2231 :
2232 : Tested at random points (a,b,p).
2233 :
2234 : a,b Relative error:
2235 : arithmetic domain # trials peak rms
2236 : For p between .001 and 1:
2237 : IEEE 1,100 100000 8.3e-15 4.7e-16
2238 : IEEE 1,10000 100000 2.1e-11 1.4e-13
2239 : For p between 10^-6 and 10^-3:
2240 : IEEE 1,100 50000 1.3e-12 8.4e-15
2241 : IEEE 1,10000 50000 3.0e-12 4.8e-14
2242 :
2243 : Cephes Math Library Release 2.8: June, 2000
2244 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
2245 : *************************************************************************/
2246 0 : double invfdistribution(const ae_int_t a, const ae_int_t b, const double y, const xparams _xparams)
2247 : {
2248 : jmp_buf _break_jump;
2249 : alglib_impl::ae_state _alglib_env_state;
2250 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2251 0 : if( setjmp(_break_jump) )
2252 : {
2253 : #if !defined(AE_NO_EXCEPTIONS)
2254 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2255 : #else
2256 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2257 : return 0;
2258 : #endif
2259 : }
2260 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2261 0 : if( _xparams.flags!=0x0 )
2262 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2263 0 : double result = alglib_impl::invfdistribution(a, b, y, &_alglib_env_state);
2264 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2265 0 : return *(reinterpret_cast<double*>(&result));
2266 : }
2267 : #endif
2268 :
2269 : #if defined(AE_COMPILE_FRESNEL) || !defined(AE_PARTIAL_BUILD)
2270 : /*************************************************************************
2271 : Fresnel integral
2272 :
2273 : Evaluates the Fresnel integrals
2274 :
2275 : x
2276 : -
2277 : | |
2278 : C(x) = | cos(pi/2 t**2) dt,
2279 : | |
2280 : -
2281 : 0
2282 :
2283 : x
2284 : -
2285 : | |
2286 : S(x) = | sin(pi/2 t**2) dt.
2287 : | |
2288 : -
2289 : 0
2290 :
2291 :
2292 : The integrals are evaluated by a power series for x < 1.
2293 : For x >= 1 auxiliary functions f(x) and g(x) are employed
2294 : such that
2295 :
2296 : C(x) = 0.5 + f(x) sin( pi/2 x**2 ) - g(x) cos( pi/2 x**2 )
2297 : S(x) = 0.5 - f(x) cos( pi/2 x**2 ) - g(x) sin( pi/2 x**2 )
2298 :
2299 :
2300 :
2301 : ACCURACY:
2302 :
2303 : Relative error.
2304 :
2305 : Arithmetic function domain # trials peak rms
2306 : IEEE S(x) 0, 10 10000 2.0e-15 3.2e-16
2307 : IEEE C(x) 0, 10 10000 1.8e-15 3.3e-16
2308 :
2309 : Cephes Math Library Release 2.8: June, 2000
2310 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
2311 : *************************************************************************/
2312 0 : void fresnelintegral(const double x, double &c, double &s, const xparams _xparams)
2313 : {
2314 : jmp_buf _break_jump;
2315 : alglib_impl::ae_state _alglib_env_state;
2316 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2317 0 : if( setjmp(_break_jump) )
2318 : {
2319 : #if !defined(AE_NO_EXCEPTIONS)
2320 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2321 : #else
2322 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2323 : return;
2324 : #endif
2325 : }
2326 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2327 0 : if( _xparams.flags!=0x0 )
2328 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2329 0 : alglib_impl::fresnelintegral(x, &c, &s, &_alglib_env_state);
2330 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2331 0 : return;
2332 : }
2333 : #endif
2334 :
2335 : #if defined(AE_COMPILE_JACOBIANELLIPTIC) || !defined(AE_PARTIAL_BUILD)
2336 : /*************************************************************************
2337 : Jacobian Elliptic Functions
2338 :
2339 : Evaluates the Jacobian elliptic functions sn(u|m), cn(u|m),
2340 : and dn(u|m) of parameter m between 0 and 1, and real
2341 : argument u.
2342 :
2343 : These functions are periodic, with quarter-period on the
2344 : real axis equal to the complete elliptic integral
2345 : ellpk(1.0-m).
2346 :
2347 : Relation to incomplete elliptic integral:
2348 : If u = ellik(phi,m), then sn(u|m) = sin(phi),
2349 : and cn(u|m) = cos(phi). Phi is called the amplitude of u.
2350 :
2351 : Computation is by means of the arithmetic-geometric mean
2352 : algorithm, except when m is within 1e-9 of 0 or 1. In the
2353 : latter case with m close to 1, the approximation applies
2354 : only for phi < pi/2.
2355 :
2356 : ACCURACY:
2357 :
2358 : Tested at random points with u between 0 and 10, m between
2359 : 0 and 1.
2360 :
2361 : Absolute error (* = relative error):
2362 : arithmetic function # trials peak rms
2363 : IEEE phi 10000 9.2e-16* 1.4e-16*
2364 : IEEE sn 50000 4.1e-15 4.6e-16
2365 : IEEE cn 40000 3.6e-15 4.4e-16
2366 : IEEE dn 10000 1.3e-12 1.8e-14
2367 :
2368 : Peak error observed in consistency check using addition
2369 : theorem for sn(u+v) was 4e-16 (absolute). Also tested by
2370 : the above relation to the incomplete elliptic integral.
2371 : Accuracy deteriorates when u is large.
2372 :
2373 : Cephes Math Library Release 2.8: June, 2000
2374 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
2375 : *************************************************************************/
2376 0 : void jacobianellipticfunctions(const double u, const double m, double &sn, double &cn, double &dn, double &ph, const xparams _xparams)
2377 : {
2378 : jmp_buf _break_jump;
2379 : alglib_impl::ae_state _alglib_env_state;
2380 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2381 0 : if( setjmp(_break_jump) )
2382 : {
2383 : #if !defined(AE_NO_EXCEPTIONS)
2384 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2385 : #else
2386 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2387 : return;
2388 : #endif
2389 : }
2390 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2391 0 : if( _xparams.flags!=0x0 )
2392 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2393 0 : alglib_impl::jacobianellipticfunctions(u, m, &sn, &cn, &dn, &ph, &_alglib_env_state);
2394 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2395 0 : return;
2396 : }
2397 : #endif
2398 :
2399 : #if defined(AE_COMPILE_PSIF) || !defined(AE_PARTIAL_BUILD)
2400 : /*************************************************************************
2401 : Psi (digamma) function
2402 :
2403 : d -
2404 : psi(x) = -- ln | (x)
2405 : dx
2406 :
2407 : is the logarithmic derivative of the gamma function.
2408 : For integer x,
2409 : n-1
2410 : -
2411 : psi(n) = -EUL + > 1/k.
2412 : -
2413 : k=1
2414 :
2415 : This formula is used for 0 < n <= 10. If x is negative, it
2416 : is transformed to a positive argument by the reflection
2417 : formula psi(1-x) = psi(x) + pi cot(pi x).
2418 : For general positive x, the argument is made greater than 10
2419 : using the recurrence psi(x+1) = psi(x) + 1/x.
2420 : Then the following asymptotic expansion is applied:
2421 :
2422 : inf. B
2423 : - 2k
2424 : psi(x) = log(x) - 1/2x - > -------
2425 : - 2k
2426 : k=1 2k x
2427 :
2428 : where the B2k are Bernoulli numbers.
2429 :
2430 : ACCURACY:
2431 : Relative error (except absolute when |psi| < 1):
2432 : arithmetic domain # trials peak rms
2433 : IEEE 0,30 30000 1.3e-15 1.4e-16
2434 : IEEE -30,0 40000 1.5e-15 2.2e-16
2435 :
2436 : Cephes Math Library Release 2.8: June, 2000
2437 : Copyright 1984, 1987, 1992, 2000 by Stephen L. Moshier
2438 : *************************************************************************/
2439 0 : double psi(const double x, const xparams _xparams)
2440 : {
2441 : jmp_buf _break_jump;
2442 : alglib_impl::ae_state _alglib_env_state;
2443 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2444 0 : if( setjmp(_break_jump) )
2445 : {
2446 : #if !defined(AE_NO_EXCEPTIONS)
2447 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2448 : #else
2449 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2450 : return 0;
2451 : #endif
2452 : }
2453 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2454 0 : if( _xparams.flags!=0x0 )
2455 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2456 0 : double result = alglib_impl::psi(x, &_alglib_env_state);
2457 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2458 0 : return *(reinterpret_cast<double*>(&result));
2459 : }
2460 : #endif
2461 :
2462 : #if defined(AE_COMPILE_EXPINTEGRALS) || !defined(AE_PARTIAL_BUILD)
2463 : /*************************************************************************
2464 : Exponential integral Ei(x)
2465 :
2466 : x
2467 : - t
2468 : | | e
2469 : Ei(x) = -|- --- dt .
2470 : | | t
2471 : -
2472 : -inf
2473 :
2474 : Not defined for x <= 0.
2475 : See also expn.c.
2476 :
2477 :
2478 :
2479 : ACCURACY:
2480 :
2481 : Relative error:
2482 : arithmetic domain # trials peak rms
2483 : IEEE 0,100 50000 8.6e-16 1.3e-16
2484 :
2485 : Cephes Math Library Release 2.8: May, 1999
2486 : Copyright 1999 by Stephen L. Moshier
2487 : *************************************************************************/
2488 0 : double exponentialintegralei(const double x, const xparams _xparams)
2489 : {
2490 : jmp_buf _break_jump;
2491 : alglib_impl::ae_state _alglib_env_state;
2492 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2493 0 : if( setjmp(_break_jump) )
2494 : {
2495 : #if !defined(AE_NO_EXCEPTIONS)
2496 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2497 : #else
2498 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2499 : return 0;
2500 : #endif
2501 : }
2502 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2503 0 : if( _xparams.flags!=0x0 )
2504 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2505 0 : double result = alglib_impl::exponentialintegralei(x, &_alglib_env_state);
2506 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2507 0 : return *(reinterpret_cast<double*>(&result));
2508 : }
2509 :
2510 : /*************************************************************************
2511 : Exponential integral En(x)
2512 :
2513 : Evaluates the exponential integral
2514 :
2515 : inf.
2516 : -
2517 : | | -xt
2518 : | e
2519 : E (x) = | ---- dt.
2520 : n | n
2521 : | | t
2522 : -
2523 : 1
2524 :
2525 :
2526 : Both n and x must be nonnegative.
2527 :
2528 : The routine employs either a power series, a continued
2529 : fraction, or an asymptotic formula depending on the
2530 : relative values of n and x.
2531 :
2532 : ACCURACY:
2533 :
2534 : Relative error:
2535 : arithmetic domain # trials peak rms
2536 : IEEE 0, 30 10000 1.7e-15 3.6e-16
2537 :
2538 : Cephes Math Library Release 2.8: June, 2000
2539 : Copyright 1985, 2000 by Stephen L. Moshier
2540 : *************************************************************************/
2541 0 : double exponentialintegralen(const double x, const ae_int_t n, const xparams _xparams)
2542 : {
2543 : jmp_buf _break_jump;
2544 : alglib_impl::ae_state _alglib_env_state;
2545 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2546 0 : if( setjmp(_break_jump) )
2547 : {
2548 : #if !defined(AE_NO_EXCEPTIONS)
2549 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2550 : #else
2551 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2552 : return 0;
2553 : #endif
2554 : }
2555 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2556 0 : if( _xparams.flags!=0x0 )
2557 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2558 0 : double result = alglib_impl::exponentialintegralen(x, n, &_alglib_env_state);
2559 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2560 0 : return *(reinterpret_cast<double*>(&result));
2561 : }
2562 : #endif
2563 :
2564 : #if defined(AE_COMPILE_LAGUERRE) || !defined(AE_PARTIAL_BUILD)
2565 : /*************************************************************************
2566 : Calculation of the value of the Laguerre polynomial.
2567 :
2568 : Parameters:
2569 : n - degree, n>=0
2570 : x - argument
2571 :
2572 : Result:
2573 : the value of the Laguerre polynomial Ln at x
2574 : *************************************************************************/
2575 0 : double laguerrecalculate(const ae_int_t n, const double x, const xparams _xparams)
2576 : {
2577 : jmp_buf _break_jump;
2578 : alglib_impl::ae_state _alglib_env_state;
2579 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2580 0 : if( setjmp(_break_jump) )
2581 : {
2582 : #if !defined(AE_NO_EXCEPTIONS)
2583 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2584 : #else
2585 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2586 : return 0;
2587 : #endif
2588 : }
2589 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2590 0 : if( _xparams.flags!=0x0 )
2591 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2592 0 : double result = alglib_impl::laguerrecalculate(n, x, &_alglib_env_state);
2593 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2594 0 : return *(reinterpret_cast<double*>(&result));
2595 : }
2596 :
2597 : /*************************************************************************
2598 : Summation of Laguerre polynomials using Clenshaw's recurrence formula.
2599 :
2600 : This routine calculates c[0]*L0(x) + c[1]*L1(x) + ... + c[N]*LN(x)
2601 :
2602 : Parameters:
2603 : n - degree, n>=0
2604 : x - argument
2605 :
2606 : Result:
2607 : the value of the Laguerre polynomial at x
2608 : *************************************************************************/
2609 0 : double laguerresum(const real_1d_array &c, const ae_int_t n, const double x, const xparams _xparams)
2610 : {
2611 : jmp_buf _break_jump;
2612 : alglib_impl::ae_state _alglib_env_state;
2613 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2614 0 : if( setjmp(_break_jump) )
2615 : {
2616 : #if !defined(AE_NO_EXCEPTIONS)
2617 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2618 : #else
2619 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2620 : return 0;
2621 : #endif
2622 : }
2623 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2624 0 : if( _xparams.flags!=0x0 )
2625 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2626 0 : double result = alglib_impl::laguerresum(const_cast<alglib_impl::ae_vector*>(c.c_ptr()), n, x, &_alglib_env_state);
2627 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2628 0 : return *(reinterpret_cast<double*>(&result));
2629 : }
2630 :
2631 : /*************************************************************************
2632 : Representation of Ln as C[0] + C[1]*X + ... + C[N]*X^N
2633 :
2634 : Input parameters:
2635 : N - polynomial degree, n>=0
2636 :
2637 : Output parameters:
2638 : C - coefficients
2639 : *************************************************************************/
2640 0 : void laguerrecoefficients(const ae_int_t n, real_1d_array &c, const xparams _xparams)
2641 : {
2642 : jmp_buf _break_jump;
2643 : alglib_impl::ae_state _alglib_env_state;
2644 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2645 0 : if( setjmp(_break_jump) )
2646 : {
2647 : #if !defined(AE_NO_EXCEPTIONS)
2648 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2649 : #else
2650 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2651 : return;
2652 : #endif
2653 : }
2654 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2655 0 : if( _xparams.flags!=0x0 )
2656 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2657 0 : alglib_impl::laguerrecoefficients(n, const_cast<alglib_impl::ae_vector*>(c.c_ptr()), &_alglib_env_state);
2658 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2659 0 : return;
2660 : }
2661 : #endif
2662 :
2663 : #if defined(AE_COMPILE_CHISQUAREDISTR) || !defined(AE_PARTIAL_BUILD)
2664 : /*************************************************************************
2665 : Chi-square distribution
2666 :
2667 : Returns the area under the left hand tail (from 0 to x)
2668 : of the Chi square probability density function with
2669 : v degrees of freedom.
2670 :
2671 :
2672 : x
2673 : -
2674 : 1 | | v/2-1 -t/2
2675 : P( x | v ) = ----------- | t e dt
2676 : v/2 - | |
2677 : 2 | (v/2) -
2678 : 0
2679 :
2680 : where x is the Chi-square variable.
2681 :
2682 : The incomplete gamma integral is used, according to the
2683 : formula
2684 :
2685 : y = chdtr( v, x ) = igam( v/2.0, x/2.0 ).
2686 :
2687 : The arguments must both be positive.
2688 :
2689 : ACCURACY:
2690 :
2691 : See incomplete gamma function
2692 :
2693 :
2694 : Cephes Math Library Release 2.8: June, 2000
2695 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
2696 : *************************************************************************/
2697 0 : double chisquaredistribution(const double v, const double x, const xparams _xparams)
2698 : {
2699 : jmp_buf _break_jump;
2700 : alglib_impl::ae_state _alglib_env_state;
2701 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2702 0 : if( setjmp(_break_jump) )
2703 : {
2704 : #if !defined(AE_NO_EXCEPTIONS)
2705 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2706 : #else
2707 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2708 : return 0;
2709 : #endif
2710 : }
2711 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2712 0 : if( _xparams.flags!=0x0 )
2713 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2714 0 : double result = alglib_impl::chisquaredistribution(v, x, &_alglib_env_state);
2715 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2716 0 : return *(reinterpret_cast<double*>(&result));
2717 : }
2718 :
2719 : /*************************************************************************
2720 : Complemented Chi-square distribution
2721 :
2722 : Returns the area under the right hand tail (from x to
2723 : infinity) of the Chi square probability density function
2724 : with v degrees of freedom:
2725 :
2726 : inf.
2727 : -
2728 : 1 | | v/2-1 -t/2
2729 : P( x | v ) = ----------- | t e dt
2730 : v/2 - | |
2731 : 2 | (v/2) -
2732 : x
2733 :
2734 : where x is the Chi-square variable.
2735 :
2736 : The incomplete gamma integral is used, according to the
2737 : formula
2738 :
2739 : y = chdtr( v, x ) = igamc( v/2.0, x/2.0 ).
2740 :
2741 : The arguments must both be positive.
2742 :
2743 : ACCURACY:
2744 :
2745 : See incomplete gamma function
2746 :
2747 : Cephes Math Library Release 2.8: June, 2000
2748 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
2749 : *************************************************************************/
2750 0 : double chisquarecdistribution(const double v, const double x, const xparams _xparams)
2751 : {
2752 : jmp_buf _break_jump;
2753 : alglib_impl::ae_state _alglib_env_state;
2754 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2755 0 : if( setjmp(_break_jump) )
2756 : {
2757 : #if !defined(AE_NO_EXCEPTIONS)
2758 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2759 : #else
2760 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2761 : return 0;
2762 : #endif
2763 : }
2764 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2765 0 : if( _xparams.flags!=0x0 )
2766 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2767 0 : double result = alglib_impl::chisquarecdistribution(v, x, &_alglib_env_state);
2768 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2769 0 : return *(reinterpret_cast<double*>(&result));
2770 : }
2771 :
2772 : /*************************************************************************
2773 : Inverse of complemented Chi-square distribution
2774 :
2775 : Finds the Chi-square argument x such that the integral
2776 : from x to infinity of the Chi-square density is equal
2777 : to the given cumulative probability y.
2778 :
2779 : This is accomplished using the inverse gamma integral
2780 : function and the relation
2781 :
2782 : x/2 = igami( df/2, y );
2783 :
2784 : ACCURACY:
2785 :
2786 : See inverse incomplete gamma function
2787 :
2788 :
2789 : Cephes Math Library Release 2.8: June, 2000
2790 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
2791 : *************************************************************************/
2792 0 : double invchisquaredistribution(const double v, const double y, const xparams _xparams)
2793 : {
2794 : jmp_buf _break_jump;
2795 : alglib_impl::ae_state _alglib_env_state;
2796 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2797 0 : if( setjmp(_break_jump) )
2798 : {
2799 : #if !defined(AE_NO_EXCEPTIONS)
2800 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2801 : #else
2802 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2803 : return 0;
2804 : #endif
2805 : }
2806 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2807 0 : if( _xparams.flags!=0x0 )
2808 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2809 0 : double result = alglib_impl::invchisquaredistribution(v, y, &_alglib_env_state);
2810 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2811 0 : return *(reinterpret_cast<double*>(&result));
2812 : }
2813 : #endif
2814 :
2815 : #if defined(AE_COMPILE_LEGENDRE) || !defined(AE_PARTIAL_BUILD)
2816 : /*************************************************************************
2817 : Calculation of the value of the Legendre polynomial Pn.
2818 :
2819 : Parameters:
2820 : n - degree, n>=0
2821 : x - argument
2822 :
2823 : Result:
2824 : the value of the Legendre polynomial Pn at x
2825 : *************************************************************************/
2826 0 : double legendrecalculate(const ae_int_t n, const double x, const xparams _xparams)
2827 : {
2828 : jmp_buf _break_jump;
2829 : alglib_impl::ae_state _alglib_env_state;
2830 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2831 0 : if( setjmp(_break_jump) )
2832 : {
2833 : #if !defined(AE_NO_EXCEPTIONS)
2834 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2835 : #else
2836 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2837 : return 0;
2838 : #endif
2839 : }
2840 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2841 0 : if( _xparams.flags!=0x0 )
2842 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2843 0 : double result = alglib_impl::legendrecalculate(n, x, &_alglib_env_state);
2844 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2845 0 : return *(reinterpret_cast<double*>(&result));
2846 : }
2847 :
2848 : /*************************************************************************
2849 : Summation of Legendre polynomials using Clenshaw's recurrence formula.
2850 :
2851 : This routine calculates
2852 : c[0]*P0(x) + c[1]*P1(x) + ... + c[N]*PN(x)
2853 :
2854 : Parameters:
2855 : n - degree, n>=0
2856 : x - argument
2857 :
2858 : Result:
2859 : the value of the Legendre polynomial at x
2860 : *************************************************************************/
2861 0 : double legendresum(const real_1d_array &c, const ae_int_t n, const double x, const xparams _xparams)
2862 : {
2863 : jmp_buf _break_jump;
2864 : alglib_impl::ae_state _alglib_env_state;
2865 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2866 0 : if( setjmp(_break_jump) )
2867 : {
2868 : #if !defined(AE_NO_EXCEPTIONS)
2869 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2870 : #else
2871 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2872 : return 0;
2873 : #endif
2874 : }
2875 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2876 0 : if( _xparams.flags!=0x0 )
2877 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2878 0 : double result = alglib_impl::legendresum(const_cast<alglib_impl::ae_vector*>(c.c_ptr()), n, x, &_alglib_env_state);
2879 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2880 0 : return *(reinterpret_cast<double*>(&result));
2881 : }
2882 :
2883 : /*************************************************************************
2884 : Representation of Pn as C[0] + C[1]*X + ... + C[N]*X^N
2885 :
2886 : Input parameters:
2887 : N - polynomial degree, n>=0
2888 :
2889 : Output parameters:
2890 : C - coefficients
2891 : *************************************************************************/
2892 0 : void legendrecoefficients(const ae_int_t n, real_1d_array &c, const xparams _xparams)
2893 : {
2894 : jmp_buf _break_jump;
2895 : alglib_impl::ae_state _alglib_env_state;
2896 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2897 0 : if( setjmp(_break_jump) )
2898 : {
2899 : #if !defined(AE_NO_EXCEPTIONS)
2900 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2901 : #else
2902 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2903 : return;
2904 : #endif
2905 : }
2906 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2907 0 : if( _xparams.flags!=0x0 )
2908 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2909 0 : alglib_impl::legendrecoefficients(n, const_cast<alglib_impl::ae_vector*>(c.c_ptr()), &_alglib_env_state);
2910 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2911 0 : return;
2912 : }
2913 : #endif
2914 :
2915 : #if defined(AE_COMPILE_BETAF) || !defined(AE_PARTIAL_BUILD)
2916 : /*************************************************************************
2917 : Beta function
2918 :
2919 :
2920 : - -
2921 : | (a) | (b)
2922 : beta( a, b ) = -----------.
2923 : -
2924 : | (a+b)
2925 :
2926 : For large arguments the logarithm of the function is
2927 : evaluated using lgam(), then exponentiated.
2928 :
2929 : ACCURACY:
2930 :
2931 : Relative error:
2932 : arithmetic domain # trials peak rms
2933 : IEEE 0,30 30000 8.1e-14 1.1e-14
2934 :
2935 : Cephes Math Library Release 2.0: April, 1987
2936 : Copyright 1984, 1987 by Stephen L. Moshier
2937 : *************************************************************************/
2938 0 : double beta(const double a, const double b, const xparams _xparams)
2939 : {
2940 : jmp_buf _break_jump;
2941 : alglib_impl::ae_state _alglib_env_state;
2942 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2943 0 : if( setjmp(_break_jump) )
2944 : {
2945 : #if !defined(AE_NO_EXCEPTIONS)
2946 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2947 : #else
2948 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2949 : return 0;
2950 : #endif
2951 : }
2952 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2953 0 : if( _xparams.flags!=0x0 )
2954 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2955 0 : double result = alglib_impl::beta(a, b, &_alglib_env_state);
2956 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2957 0 : return *(reinterpret_cast<double*>(&result));
2958 : }
2959 : #endif
2960 :
2961 : #if defined(AE_COMPILE_CHEBYSHEV) || !defined(AE_PARTIAL_BUILD)
2962 : /*************************************************************************
2963 : Calculation of the value of the Chebyshev polynomials of the
2964 : first and second kinds.
2965 :
2966 : Parameters:
2967 : r - polynomial kind, either 1 or 2.
2968 : n - degree, n>=0
2969 : x - argument, -1 <= x <= 1
2970 :
2971 : Result:
2972 : the value of the Chebyshev polynomial at x
2973 : *************************************************************************/
2974 0 : double chebyshevcalculate(const ae_int_t r, const ae_int_t n, const double x, const xparams _xparams)
2975 : {
2976 : jmp_buf _break_jump;
2977 : alglib_impl::ae_state _alglib_env_state;
2978 0 : alglib_impl::ae_state_init(&_alglib_env_state);
2979 0 : if( setjmp(_break_jump) )
2980 : {
2981 : #if !defined(AE_NO_EXCEPTIONS)
2982 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
2983 : #else
2984 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
2985 : return 0;
2986 : #endif
2987 : }
2988 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
2989 0 : if( _xparams.flags!=0x0 )
2990 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
2991 0 : double result = alglib_impl::chebyshevcalculate(r, n, x, &_alglib_env_state);
2992 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
2993 0 : return *(reinterpret_cast<double*>(&result));
2994 : }
2995 :
2996 : /*************************************************************************
2997 : Summation of Chebyshev polynomials using Clenshaw's recurrence formula.
2998 :
2999 : This routine calculates
3000 : c[0]*T0(x) + c[1]*T1(x) + ... + c[N]*TN(x)
3001 : or
3002 : c[0]*U0(x) + c[1]*U1(x) + ... + c[N]*UN(x)
3003 : depending on the R.
3004 :
3005 : Parameters:
3006 : r - polynomial kind, either 1 or 2.
3007 : n - degree, n>=0
3008 : x - argument
3009 :
3010 : Result:
3011 : the value of the Chebyshev polynomial at x
3012 : *************************************************************************/
3013 0 : double chebyshevsum(const real_1d_array &c, const ae_int_t r, const ae_int_t n, const double x, const xparams _xparams)
3014 : {
3015 : jmp_buf _break_jump;
3016 : alglib_impl::ae_state _alglib_env_state;
3017 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3018 0 : if( setjmp(_break_jump) )
3019 : {
3020 : #if !defined(AE_NO_EXCEPTIONS)
3021 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3022 : #else
3023 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3024 : return 0;
3025 : #endif
3026 : }
3027 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3028 0 : if( _xparams.flags!=0x0 )
3029 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3030 0 : double result = alglib_impl::chebyshevsum(const_cast<alglib_impl::ae_vector*>(c.c_ptr()), r, n, x, &_alglib_env_state);
3031 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3032 0 : return *(reinterpret_cast<double*>(&result));
3033 : }
3034 :
3035 : /*************************************************************************
3036 : Representation of Tn as C[0] + C[1]*X + ... + C[N]*X^N
3037 :
3038 : Input parameters:
3039 : N - polynomial degree, n>=0
3040 :
3041 : Output parameters:
3042 : C - coefficients
3043 : *************************************************************************/
3044 0 : void chebyshevcoefficients(const ae_int_t n, real_1d_array &c, const xparams _xparams)
3045 : {
3046 : jmp_buf _break_jump;
3047 : alglib_impl::ae_state _alglib_env_state;
3048 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3049 0 : if( setjmp(_break_jump) )
3050 : {
3051 : #if !defined(AE_NO_EXCEPTIONS)
3052 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3053 : #else
3054 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3055 : return;
3056 : #endif
3057 : }
3058 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3059 0 : if( _xparams.flags!=0x0 )
3060 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3061 0 : alglib_impl::chebyshevcoefficients(n, const_cast<alglib_impl::ae_vector*>(c.c_ptr()), &_alglib_env_state);
3062 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3063 0 : return;
3064 : }
3065 :
3066 : /*************************************************************************
3067 : Conversion of a series of Chebyshev polynomials to a power series.
3068 :
3069 : Represents A[0]*T0(x) + A[1]*T1(x) + ... + A[N]*Tn(x) as
3070 : B[0] + B[1]*X + ... + B[N]*X^N.
3071 :
3072 : Input parameters:
3073 : A - Chebyshev series coefficients
3074 : N - degree, N>=0
3075 :
3076 : Output parameters
3077 : B - power series coefficients
3078 : *************************************************************************/
3079 0 : void fromchebyshev(const real_1d_array &a, const ae_int_t n, real_1d_array &b, const xparams _xparams)
3080 : {
3081 : jmp_buf _break_jump;
3082 : alglib_impl::ae_state _alglib_env_state;
3083 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3084 0 : if( setjmp(_break_jump) )
3085 : {
3086 : #if !defined(AE_NO_EXCEPTIONS)
3087 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3088 : #else
3089 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3090 : return;
3091 : #endif
3092 : }
3093 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3094 0 : if( _xparams.flags!=0x0 )
3095 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3096 0 : alglib_impl::fromchebyshev(const_cast<alglib_impl::ae_vector*>(a.c_ptr()), n, const_cast<alglib_impl::ae_vector*>(b.c_ptr()), &_alglib_env_state);
3097 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3098 0 : return;
3099 : }
3100 : #endif
3101 :
3102 : #if defined(AE_COMPILE_STUDENTTDISTR) || !defined(AE_PARTIAL_BUILD)
3103 : /*************************************************************************
3104 : Student's t distribution
3105 :
3106 : Computes the integral from minus infinity to t of the Student
3107 : t distribution with integer k > 0 degrees of freedom:
3108 :
3109 : t
3110 : -
3111 : | |
3112 : - | 2 -(k+1)/2
3113 : | ( (k+1)/2 ) | ( x )
3114 : ---------------------- | ( 1 + --- ) dx
3115 : - | ( k )
3116 : sqrt( k pi ) | ( k/2 ) |
3117 : | |
3118 : -
3119 : -inf.
3120 :
3121 : Relation to incomplete beta integral:
3122 :
3123 : 1 - stdtr(k,t) = 0.5 * incbet( k/2, 1/2, z )
3124 : where
3125 : z = k/(k + t**2).
3126 :
3127 : For t < -2, this is the method of computation. For higher t,
3128 : a direct method is derived from integration by parts.
3129 : Since the function is symmetric about t=0, the area under the
3130 : right tail of the density is found by calling the function
3131 : with -t instead of t.
3132 :
3133 : ACCURACY:
3134 :
3135 : Tested at random 1 <= k <= 25. The "domain" refers to t.
3136 : Relative error:
3137 : arithmetic domain # trials peak rms
3138 : IEEE -100,-2 50000 5.9e-15 1.4e-15
3139 : IEEE -2,100 500000 2.7e-15 4.9e-17
3140 :
3141 : Cephes Math Library Release 2.8: June, 2000
3142 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
3143 : *************************************************************************/
3144 0 : double studenttdistribution(const ae_int_t k, const double t, const xparams _xparams)
3145 : {
3146 : jmp_buf _break_jump;
3147 : alglib_impl::ae_state _alglib_env_state;
3148 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3149 0 : if( setjmp(_break_jump) )
3150 : {
3151 : #if !defined(AE_NO_EXCEPTIONS)
3152 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3153 : #else
3154 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3155 : return 0;
3156 : #endif
3157 : }
3158 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3159 0 : if( _xparams.flags!=0x0 )
3160 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3161 0 : double result = alglib_impl::studenttdistribution(k, t, &_alglib_env_state);
3162 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3163 0 : return *(reinterpret_cast<double*>(&result));
3164 : }
3165 :
3166 : /*************************************************************************
3167 : Functional inverse of Student's t distribution
3168 :
3169 : Given probability p, finds the argument t such that stdtr(k,t)
3170 : is equal to p.
3171 :
3172 : ACCURACY:
3173 :
3174 : Tested at random 1 <= k <= 100. The "domain" refers to p:
3175 : Relative error:
3176 : arithmetic domain # trials peak rms
3177 : IEEE .001,.999 25000 5.7e-15 8.0e-16
3178 : IEEE 10^-6,.001 25000 2.0e-12 2.9e-14
3179 :
3180 : Cephes Math Library Release 2.8: June, 2000
3181 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
3182 : *************************************************************************/
3183 0 : double invstudenttdistribution(const ae_int_t k, const double p, const xparams _xparams)
3184 : {
3185 : jmp_buf _break_jump;
3186 : alglib_impl::ae_state _alglib_env_state;
3187 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3188 0 : if( setjmp(_break_jump) )
3189 : {
3190 : #if !defined(AE_NO_EXCEPTIONS)
3191 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3192 : #else
3193 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3194 : return 0;
3195 : #endif
3196 : }
3197 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3198 0 : if( _xparams.flags!=0x0 )
3199 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3200 0 : double result = alglib_impl::invstudenttdistribution(k, p, &_alglib_env_state);
3201 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3202 0 : return *(reinterpret_cast<double*>(&result));
3203 : }
3204 : #endif
3205 :
3206 : #if defined(AE_COMPILE_BINOMIALDISTR) || !defined(AE_PARTIAL_BUILD)
3207 : /*************************************************************************
3208 : Binomial distribution
3209 :
3210 : Returns the sum of the terms 0 through k of the Binomial
3211 : probability density:
3212 :
3213 : k
3214 : -- ( n ) j n-j
3215 : > ( ) p (1-p)
3216 : -- ( j )
3217 : j=0
3218 :
3219 : The terms are not summed directly; instead the incomplete
3220 : beta integral is employed, according to the formula
3221 :
3222 : y = bdtr( k, n, p ) = incbet( n-k, k+1, 1-p ).
3223 :
3224 : The arguments must be positive, with p ranging from 0 to 1.
3225 :
3226 : ACCURACY:
3227 :
3228 : Tested at random points (a,b,p), with p between 0 and 1.
3229 :
3230 : a,b Relative error:
3231 : arithmetic domain # trials peak rms
3232 : For p between 0.001 and 1:
3233 : IEEE 0,100 100000 4.3e-15 2.6e-16
3234 :
3235 : Cephes Math Library Release 2.8: June, 2000
3236 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
3237 : *************************************************************************/
3238 0 : double binomialdistribution(const ae_int_t k, const ae_int_t n, const double p, const xparams _xparams)
3239 : {
3240 : jmp_buf _break_jump;
3241 : alglib_impl::ae_state _alglib_env_state;
3242 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3243 0 : if( setjmp(_break_jump) )
3244 : {
3245 : #if !defined(AE_NO_EXCEPTIONS)
3246 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3247 : #else
3248 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3249 : return 0;
3250 : #endif
3251 : }
3252 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3253 0 : if( _xparams.flags!=0x0 )
3254 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3255 0 : double result = alglib_impl::binomialdistribution(k, n, p, &_alglib_env_state);
3256 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3257 0 : return *(reinterpret_cast<double*>(&result));
3258 : }
3259 :
3260 : /*************************************************************************
3261 : Complemented binomial distribution
3262 :
3263 : Returns the sum of the terms k+1 through n of the Binomial
3264 : probability density:
3265 :
3266 : n
3267 : -- ( n ) j n-j
3268 : > ( ) p (1-p)
3269 : -- ( j )
3270 : j=k+1
3271 :
3272 : The terms are not summed directly; instead the incomplete
3273 : beta integral is employed, according to the formula
3274 :
3275 : y = bdtrc( k, n, p ) = incbet( k+1, n-k, p ).
3276 :
3277 : The arguments must be positive, with p ranging from 0 to 1.
3278 :
3279 : ACCURACY:
3280 :
3281 : Tested at random points (a,b,p).
3282 :
3283 : a,b Relative error:
3284 : arithmetic domain # trials peak rms
3285 : For p between 0.001 and 1:
3286 : IEEE 0,100 100000 6.7e-15 8.2e-16
3287 : For p between 0 and .001:
3288 : IEEE 0,100 100000 1.5e-13 2.7e-15
3289 :
3290 : Cephes Math Library Release 2.8: June, 2000
3291 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
3292 : *************************************************************************/
3293 0 : double binomialcdistribution(const ae_int_t k, const ae_int_t n, const double p, const xparams _xparams)
3294 : {
3295 : jmp_buf _break_jump;
3296 : alglib_impl::ae_state _alglib_env_state;
3297 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3298 0 : if( setjmp(_break_jump) )
3299 : {
3300 : #if !defined(AE_NO_EXCEPTIONS)
3301 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3302 : #else
3303 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3304 : return 0;
3305 : #endif
3306 : }
3307 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3308 0 : if( _xparams.flags!=0x0 )
3309 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3310 0 : double result = alglib_impl::binomialcdistribution(k, n, p, &_alglib_env_state);
3311 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3312 0 : return *(reinterpret_cast<double*>(&result));
3313 : }
3314 :
3315 : /*************************************************************************
3316 : Inverse binomial distribution
3317 :
3318 : Finds the event probability p such that the sum of the
3319 : terms 0 through k of the Binomial probability density
3320 : is equal to the given cumulative probability y.
3321 :
3322 : This is accomplished using the inverse beta integral
3323 : function and the relation
3324 :
3325 : 1 - p = incbi( n-k, k+1, y ).
3326 :
3327 : ACCURACY:
3328 :
3329 : Tested at random points (a,b,p).
3330 :
3331 : a,b Relative error:
3332 : arithmetic domain # trials peak rms
3333 : For p between 0.001 and 1:
3334 : IEEE 0,100 100000 2.3e-14 6.4e-16
3335 : IEEE 0,10000 100000 6.6e-12 1.2e-13
3336 : For p between 10^-6 and 0.001:
3337 : IEEE 0,100 100000 2.0e-12 1.3e-14
3338 : IEEE 0,10000 100000 1.5e-12 3.2e-14
3339 :
3340 : Cephes Math Library Release 2.8: June, 2000
3341 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
3342 : *************************************************************************/
3343 0 : double invbinomialdistribution(const ae_int_t k, const ae_int_t n, const double y, const xparams _xparams)
3344 : {
3345 : jmp_buf _break_jump;
3346 : alglib_impl::ae_state _alglib_env_state;
3347 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3348 0 : if( setjmp(_break_jump) )
3349 : {
3350 : #if !defined(AE_NO_EXCEPTIONS)
3351 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3352 : #else
3353 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3354 : return 0;
3355 : #endif
3356 : }
3357 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3358 0 : if( _xparams.flags!=0x0 )
3359 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3360 0 : double result = alglib_impl::invbinomialdistribution(k, n, y, &_alglib_env_state);
3361 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3362 0 : return *(reinterpret_cast<double*>(&result));
3363 : }
3364 : #endif
3365 :
3366 : #if defined(AE_COMPILE_AIRYF) || !defined(AE_PARTIAL_BUILD)
3367 : /*************************************************************************
3368 : Airy function
3369 :
3370 : Solution of the differential equation
3371 :
3372 : y"(x) = xy.
3373 :
3374 : The function returns the two independent solutions Ai, Bi
3375 : and their first derivatives Ai'(x), Bi'(x).
3376 :
3377 : Evaluation is by power series summation for small x,
3378 : by rational minimax approximations for large x.
3379 :
3380 :
3381 :
3382 : ACCURACY:
3383 : Error criterion is absolute when function <= 1, relative
3384 : when function > 1, except * denotes relative error criterion.
3385 : For large negative x, the absolute error increases as x^1.5.
3386 : For large positive x, the relative error increases as x^1.5.
3387 :
3388 : Arithmetic domain function # trials peak rms
3389 : IEEE -10, 0 Ai 10000 1.6e-15 2.7e-16
3390 : IEEE 0, 10 Ai 10000 2.3e-14* 1.8e-15*
3391 : IEEE -10, 0 Ai' 10000 4.6e-15 7.6e-16
3392 : IEEE 0, 10 Ai' 10000 1.8e-14* 1.5e-15*
3393 : IEEE -10, 10 Bi 30000 4.2e-15 5.3e-16
3394 : IEEE -10, 10 Bi' 30000 4.9e-15 7.3e-16
3395 :
3396 : Cephes Math Library Release 2.8: June, 2000
3397 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
3398 : *************************************************************************/
3399 0 : void airy(const double x, double &ai, double &aip, double &bi, double &bip, const xparams _xparams)
3400 : {
3401 : jmp_buf _break_jump;
3402 : alglib_impl::ae_state _alglib_env_state;
3403 0 : alglib_impl::ae_state_init(&_alglib_env_state);
3404 0 : if( setjmp(_break_jump) )
3405 : {
3406 : #if !defined(AE_NO_EXCEPTIONS)
3407 0 : _ALGLIB_CPP_EXCEPTION(_alglib_env_state.error_msg);
3408 : #else
3409 : _ALGLIB_SET_ERROR_FLAG(_alglib_env_state.error_msg);
3410 : return;
3411 : #endif
3412 : }
3413 0 : ae_state_set_break_jump(&_alglib_env_state, &_break_jump);
3414 0 : if( _xparams.flags!=0x0 )
3415 0 : ae_state_set_flags(&_alglib_env_state, _xparams.flags);
3416 0 : alglib_impl::airy(x, &ai, &aip, &bi, &bip, &_alglib_env_state);
3417 0 : alglib_impl::ae_state_clear(&_alglib_env_state);
3418 0 : return;
3419 : }
3420 : #endif
3421 : }
3422 :
3423 : /////////////////////////////////////////////////////////////////////////
3424 : //
3425 : // THIS SECTION CONTAINS IMPLEMENTATION OF COMPUTATIONAL CORE
3426 : //
3427 : /////////////////////////////////////////////////////////////////////////
3428 : namespace alglib_impl
3429 : {
3430 : #if defined(AE_COMPILE_GAMMAFUNC) || !defined(AE_PARTIAL_BUILD)
3431 : static double gammafunc_gammastirf(double x, ae_state *_state);
3432 :
3433 :
3434 : #endif
3435 : #if defined(AE_COMPILE_NORMALDISTR) || !defined(AE_PARTIAL_BUILD)
3436 : static double normaldistr_bvnintegrate3(double rangea,
3437 : double rangeb,
3438 : double x,
3439 : double y,
3440 : double gw,
3441 : double gx,
3442 : ae_state *_state);
3443 : static double normaldistr_bvnintegrate6(double rangea,
3444 : double rangeb,
3445 : double x,
3446 : double y,
3447 : double s,
3448 : double gw,
3449 : double gx,
3450 : ae_state *_state);
3451 :
3452 :
3453 : #endif
3454 : #if defined(AE_COMPILE_IGAMMAF) || !defined(AE_PARTIAL_BUILD)
3455 :
3456 :
3457 : #endif
3458 : #if defined(AE_COMPILE_ELLIPTIC) || !defined(AE_PARTIAL_BUILD)
3459 :
3460 :
3461 : #endif
3462 : #if defined(AE_COMPILE_HERMITE) || !defined(AE_PARTIAL_BUILD)
3463 :
3464 :
3465 : #endif
3466 : #if defined(AE_COMPILE_DAWSON) || !defined(AE_PARTIAL_BUILD)
3467 :
3468 :
3469 : #endif
3470 : #if defined(AE_COMPILE_TRIGINTEGRALS) || !defined(AE_PARTIAL_BUILD)
3471 : static void trigintegrals_chebiterationshichi(double x,
3472 : double c,
3473 : double* b0,
3474 : double* b1,
3475 : double* b2,
3476 : ae_state *_state);
3477 :
3478 :
3479 : #endif
3480 : #if defined(AE_COMPILE_POISSONDISTR) || !defined(AE_PARTIAL_BUILD)
3481 :
3482 :
3483 : #endif
3484 : #if defined(AE_COMPILE_BESSEL) || !defined(AE_PARTIAL_BUILD)
3485 : static void bessel_besselmfirstcheb(double c,
3486 : double* b0,
3487 : double* b1,
3488 : double* b2,
3489 : ae_state *_state);
3490 : static void bessel_besselmnextcheb(double x,
3491 : double c,
3492 : double* b0,
3493 : double* b1,
3494 : double* b2,
3495 : ae_state *_state);
3496 : static void bessel_besselm1firstcheb(double c,
3497 : double* b0,
3498 : double* b1,
3499 : double* b2,
3500 : ae_state *_state);
3501 : static void bessel_besselm1nextcheb(double x,
3502 : double c,
3503 : double* b0,
3504 : double* b1,
3505 : double* b2,
3506 : ae_state *_state);
3507 : static void bessel_besselasympt0(double x,
3508 : double* pzero,
3509 : double* qzero,
3510 : ae_state *_state);
3511 : static void bessel_besselasympt1(double x,
3512 : double* pzero,
3513 : double* qzero,
3514 : ae_state *_state);
3515 :
3516 :
3517 : #endif
3518 : #if defined(AE_COMPILE_IBETAF) || !defined(AE_PARTIAL_BUILD)
3519 : static double ibetaf_incompletebetafe(double a,
3520 : double b,
3521 : double x,
3522 : double big,
3523 : double biginv,
3524 : ae_state *_state);
3525 : static double ibetaf_incompletebetafe2(double a,
3526 : double b,
3527 : double x,
3528 : double big,
3529 : double biginv,
3530 : ae_state *_state);
3531 : static double ibetaf_incompletebetaps(double a,
3532 : double b,
3533 : double x,
3534 : double maxgam,
3535 : ae_state *_state);
3536 :
3537 :
3538 : #endif
3539 : #if defined(AE_COMPILE_FDISTR) || !defined(AE_PARTIAL_BUILD)
3540 :
3541 :
3542 : #endif
3543 : #if defined(AE_COMPILE_FRESNEL) || !defined(AE_PARTIAL_BUILD)
3544 :
3545 :
3546 : #endif
3547 : #if defined(AE_COMPILE_JACOBIANELLIPTIC) || !defined(AE_PARTIAL_BUILD)
3548 :
3549 :
3550 : #endif
3551 : #if defined(AE_COMPILE_PSIF) || !defined(AE_PARTIAL_BUILD)
3552 :
3553 :
3554 : #endif
3555 : #if defined(AE_COMPILE_EXPINTEGRALS) || !defined(AE_PARTIAL_BUILD)
3556 :
3557 :
3558 : #endif
3559 : #if defined(AE_COMPILE_LAGUERRE) || !defined(AE_PARTIAL_BUILD)
3560 :
3561 :
3562 : #endif
3563 : #if defined(AE_COMPILE_CHISQUAREDISTR) || !defined(AE_PARTIAL_BUILD)
3564 :
3565 :
3566 : #endif
3567 : #if defined(AE_COMPILE_LEGENDRE) || !defined(AE_PARTIAL_BUILD)
3568 :
3569 :
3570 : #endif
3571 : #if defined(AE_COMPILE_BETAF) || !defined(AE_PARTIAL_BUILD)
3572 :
3573 :
3574 : #endif
3575 : #if defined(AE_COMPILE_CHEBYSHEV) || !defined(AE_PARTIAL_BUILD)
3576 :
3577 :
3578 : #endif
3579 : #if defined(AE_COMPILE_STUDENTTDISTR) || !defined(AE_PARTIAL_BUILD)
3580 :
3581 :
3582 : #endif
3583 : #if defined(AE_COMPILE_BINOMIALDISTR) || !defined(AE_PARTIAL_BUILD)
3584 :
3585 :
3586 : #endif
3587 : #if defined(AE_COMPILE_AIRYF) || !defined(AE_PARTIAL_BUILD)
3588 :
3589 :
3590 : #endif
3591 :
3592 : #if defined(AE_COMPILE_GAMMAFUNC) || !defined(AE_PARTIAL_BUILD)
3593 :
3594 :
3595 : /*************************************************************************
3596 : Gamma function
3597 :
3598 : Input parameters:
3599 : X - argument
3600 :
3601 : Domain:
3602 : 0 < X < 171.6
3603 : -170 < X < 0, X is not an integer.
3604 :
3605 : Relative error:
3606 : arithmetic domain # trials peak rms
3607 : IEEE -170,-33 20000 2.3e-15 3.3e-16
3608 : IEEE -33, 33 20000 9.4e-16 2.2e-16
3609 : IEEE 33, 171.6 20000 2.3e-15 3.2e-16
3610 :
3611 : Cephes Math Library Release 2.8: June, 2000
3612 : Original copyright 1984, 1987, 1989, 1992, 2000 by Stephen L. Moshier
3613 : Translated to AlgoPascal by Bochkanov Sergey (2005, 2006, 2007).
3614 : *************************************************************************/
3615 0 : double gammafunction(double x, ae_state *_state)
3616 : {
3617 : #ifndef ALGLIB_INTERCEPTS_SPECFUNCS
3618 : double p;
3619 : double pp;
3620 : double q;
3621 : double qq;
3622 : double z;
3623 : ae_int_t i;
3624 : double sgngam;
3625 : double result;
3626 :
3627 :
3628 0 : sgngam = (double)(1);
3629 0 : q = ae_fabs(x, _state);
3630 0 : if( ae_fp_greater(q,33.0) )
3631 : {
3632 0 : if( ae_fp_less(x,0.0) )
3633 : {
3634 0 : p = (double)(ae_ifloor(q, _state));
3635 0 : i = ae_round(p, _state);
3636 0 : if( i%2==0 )
3637 : {
3638 0 : sgngam = (double)(-1);
3639 : }
3640 0 : z = q-p;
3641 0 : if( ae_fp_greater(z,0.5) )
3642 : {
3643 0 : p = p+1;
3644 0 : z = q-p;
3645 : }
3646 0 : z = q*ae_sin(ae_pi*z, _state);
3647 0 : z = ae_fabs(z, _state);
3648 0 : z = ae_pi/(z*gammafunc_gammastirf(q, _state));
3649 : }
3650 : else
3651 : {
3652 0 : z = gammafunc_gammastirf(x, _state);
3653 : }
3654 0 : result = sgngam*z;
3655 0 : return result;
3656 : }
3657 0 : z = (double)(1);
3658 0 : while(ae_fp_greater_eq(x,(double)(3)))
3659 : {
3660 0 : x = x-1;
3661 0 : z = z*x;
3662 : }
3663 0 : while(ae_fp_less(x,(double)(0)))
3664 : {
3665 0 : if( ae_fp_greater(x,-0.000000001) )
3666 : {
3667 0 : result = z/((1+0.5772156649015329*x)*x);
3668 0 : return result;
3669 : }
3670 0 : z = z/x;
3671 0 : x = x+1;
3672 : }
3673 0 : while(ae_fp_less(x,(double)(2)))
3674 : {
3675 0 : if( ae_fp_less(x,0.000000001) )
3676 : {
3677 0 : result = z/((1+0.5772156649015329*x)*x);
3678 0 : return result;
3679 : }
3680 0 : z = z/x;
3681 0 : x = x+1.0;
3682 : }
3683 0 : if( ae_fp_eq(x,(double)(2)) )
3684 : {
3685 0 : result = z;
3686 0 : return result;
3687 : }
3688 0 : x = x-2.0;
3689 0 : pp = 1.60119522476751861407E-4;
3690 0 : pp = 1.19135147006586384913E-3+x*pp;
3691 0 : pp = 1.04213797561761569935E-2+x*pp;
3692 0 : pp = 4.76367800457137231464E-2+x*pp;
3693 0 : pp = 2.07448227648435975150E-1+x*pp;
3694 0 : pp = 4.94214826801497100753E-1+x*pp;
3695 0 : pp = 9.99999999999999996796E-1+x*pp;
3696 0 : qq = -2.31581873324120129819E-5;
3697 0 : qq = 5.39605580493303397842E-4+x*qq;
3698 0 : qq = -4.45641913851797240494E-3+x*qq;
3699 0 : qq = 1.18139785222060435552E-2+x*qq;
3700 0 : qq = 3.58236398605498653373E-2+x*qq;
3701 0 : qq = -2.34591795718243348568E-1+x*qq;
3702 0 : qq = 7.14304917030273074085E-2+x*qq;
3703 0 : qq = 1.00000000000000000320+x*qq;
3704 0 : result = z*pp/qq;
3705 0 : return result;
3706 : #else
3707 : return _ialglib_i_gammafunction(x);
3708 : #endif
3709 : }
3710 :
3711 :
3712 : /*************************************************************************
3713 : Natural logarithm of gamma function
3714 :
3715 : Input parameters:
3716 : X - argument
3717 :
3718 : Result:
3719 : logarithm of the absolute value of the Gamma(X).
3720 :
3721 : Output parameters:
3722 : SgnGam - sign(Gamma(X))
3723 :
3724 : Domain:
3725 : 0 < X < 2.55e305
3726 : -2.55e305 < X < 0, X is not an integer.
3727 :
3728 : ACCURACY:
3729 : arithmetic domain # trials peak rms
3730 : IEEE 0, 3 28000 5.4e-16 1.1e-16
3731 : IEEE 2.718, 2.556e305 40000 3.5e-16 8.3e-17
3732 : The error criterion was relative when the function magnitude
3733 : was greater than one but absolute when it was less than one.
3734 :
3735 : The following test used the relative error criterion, though
3736 : at certain points the relative error could be much higher than
3737 : indicated.
3738 : IEEE -200, -4 10000 4.8e-16 1.3e-16
3739 :
3740 : Cephes Math Library Release 2.8: June, 2000
3741 : Copyright 1984, 1987, 1989, 1992, 2000 by Stephen L. Moshier
3742 : Translated to AlgoPascal by Bochkanov Sergey (2005, 2006, 2007).
3743 : *************************************************************************/
3744 0 : double lngamma(double x, double* sgngam, ae_state *_state)
3745 : {
3746 : #ifndef ALGLIB_INTERCEPTS_SPECFUNCS
3747 : double a;
3748 : double b;
3749 : double c;
3750 : double p;
3751 : double q;
3752 : double u;
3753 : double w;
3754 : double z;
3755 : ae_int_t i;
3756 : double logpi;
3757 : double ls2pi;
3758 : double tmp;
3759 : double result;
3760 :
3761 0 : *sgngam = 0;
3762 :
3763 0 : *sgngam = (double)(1);
3764 0 : logpi = 1.14472988584940017414;
3765 0 : ls2pi = 0.91893853320467274178;
3766 0 : if( ae_fp_less(x,-34.0) )
3767 : {
3768 0 : q = -x;
3769 0 : w = lngamma(q, &tmp, _state);
3770 0 : p = (double)(ae_ifloor(q, _state));
3771 0 : i = ae_round(p, _state);
3772 0 : if( i%2==0 )
3773 : {
3774 0 : *sgngam = (double)(-1);
3775 : }
3776 : else
3777 : {
3778 0 : *sgngam = (double)(1);
3779 : }
3780 0 : z = q-p;
3781 0 : if( ae_fp_greater(z,0.5) )
3782 : {
3783 0 : p = p+1;
3784 0 : z = p-q;
3785 : }
3786 0 : z = q*ae_sin(ae_pi*z, _state);
3787 0 : result = logpi-ae_log(z, _state)-w;
3788 0 : return result;
3789 : }
3790 0 : if( ae_fp_less(x,(double)(13)) )
3791 : {
3792 0 : z = (double)(1);
3793 0 : p = (double)(0);
3794 0 : u = x;
3795 0 : while(ae_fp_greater_eq(u,(double)(3)))
3796 : {
3797 0 : p = p-1;
3798 0 : u = x+p;
3799 0 : z = z*u;
3800 : }
3801 0 : while(ae_fp_less(u,(double)(2)))
3802 : {
3803 0 : z = z/u;
3804 0 : p = p+1;
3805 0 : u = x+p;
3806 : }
3807 0 : if( ae_fp_less(z,(double)(0)) )
3808 : {
3809 0 : *sgngam = (double)(-1);
3810 0 : z = -z;
3811 : }
3812 : else
3813 : {
3814 0 : *sgngam = (double)(1);
3815 : }
3816 0 : if( ae_fp_eq(u,(double)(2)) )
3817 : {
3818 0 : result = ae_log(z, _state);
3819 0 : return result;
3820 : }
3821 0 : p = p-2;
3822 0 : x = x+p;
3823 0 : b = -1378.25152569120859100;
3824 0 : b = -38801.6315134637840924+x*b;
3825 0 : b = -331612.992738871184744+x*b;
3826 0 : b = -1162370.97492762307383+x*b;
3827 0 : b = -1721737.00820839662146+x*b;
3828 0 : b = -853555.664245765465627+x*b;
3829 0 : c = (double)(1);
3830 0 : c = -351.815701436523470549+x*c;
3831 0 : c = -17064.2106651881159223+x*c;
3832 0 : c = -220528.590553854454839+x*c;
3833 0 : c = -1139334.44367982507207+x*c;
3834 0 : c = -2532523.07177582951285+x*c;
3835 0 : c = -2018891.41433532773231+x*c;
3836 0 : p = x*b/c;
3837 0 : result = ae_log(z, _state)+p;
3838 0 : return result;
3839 : }
3840 0 : q = (x-0.5)*ae_log(x, _state)-x+ls2pi;
3841 0 : if( ae_fp_greater(x,(double)(100000000)) )
3842 : {
3843 0 : result = q;
3844 0 : return result;
3845 : }
3846 0 : p = 1/(x*x);
3847 0 : if( ae_fp_greater_eq(x,1000.0) )
3848 : {
3849 0 : q = q+((7.9365079365079365079365*0.0001*p-2.7777777777777777777778*0.001)*p+0.0833333333333333333333)/x;
3850 : }
3851 : else
3852 : {
3853 0 : a = 8.11614167470508450300*0.0001;
3854 0 : a = -5.95061904284301438324*0.0001+p*a;
3855 0 : a = 7.93650340457716943945*0.0001+p*a;
3856 0 : a = -2.77777777730099687205*0.001+p*a;
3857 0 : a = 8.33333333333331927722*0.01+p*a;
3858 0 : q = q+a/x;
3859 : }
3860 0 : result = q;
3861 0 : return result;
3862 : #else
3863 : return _ialglib_i_lngamma(x, sgngam);
3864 : #endif
3865 : }
3866 :
3867 :
3868 0 : static double gammafunc_gammastirf(double x, ae_state *_state)
3869 : {
3870 : double y;
3871 : double w;
3872 : double v;
3873 : double stir;
3874 : double result;
3875 :
3876 :
3877 0 : w = 1/x;
3878 0 : stir = 7.87311395793093628397E-4;
3879 0 : stir = -2.29549961613378126380E-4+w*stir;
3880 0 : stir = -2.68132617805781232825E-3+w*stir;
3881 0 : stir = 3.47222221605458667310E-3+w*stir;
3882 0 : stir = 8.33333333333482257126E-2+w*stir;
3883 0 : w = 1+w*stir;
3884 0 : y = ae_exp(x, _state);
3885 0 : if( ae_fp_greater(x,143.01608) )
3886 : {
3887 0 : v = ae_pow(x, 0.5*x-0.25, _state);
3888 0 : y = v*(v/y);
3889 : }
3890 : else
3891 : {
3892 0 : y = ae_pow(x, x-0.5, _state)/y;
3893 : }
3894 0 : result = 2.50662827463100050242*y*w;
3895 0 : return result;
3896 : }
3897 :
3898 :
3899 : #endif
3900 : #if defined(AE_COMPILE_NORMALDISTR) || !defined(AE_PARTIAL_BUILD)
3901 :
3902 :
3903 : /*************************************************************************
3904 : Error function
3905 :
3906 : The integral is
3907 :
3908 : x
3909 : -
3910 : 2 | | 2
3911 : erf(x) = -------- | exp( - t ) dt.
3912 : sqrt(pi) | |
3913 : -
3914 : 0
3915 :
3916 : For 0 <= |x| < 1, erf(x) = x * P4(x**2)/Q5(x**2); otherwise
3917 : erf(x) = 1 - erfc(x).
3918 :
3919 :
3920 : ACCURACY:
3921 :
3922 : Relative error:
3923 : arithmetic domain # trials peak rms
3924 : IEEE 0,1 30000 3.7e-16 1.0e-16
3925 :
3926 : Cephes Math Library Release 2.8: June, 2000
3927 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
3928 : *************************************************************************/
3929 0 : double errorfunction(double x, ae_state *_state)
3930 : {
3931 : double xsq;
3932 : double s;
3933 : double p;
3934 : double q;
3935 : double result;
3936 :
3937 :
3938 0 : s = (double)(ae_sign(x, _state));
3939 0 : x = ae_fabs(x, _state);
3940 0 : if( ae_fp_less(x,0.5) )
3941 : {
3942 0 : xsq = x*x;
3943 0 : p = 0.007547728033418631287834;
3944 0 : p = -0.288805137207594084924010+xsq*p;
3945 0 : p = 14.3383842191748205576712+xsq*p;
3946 0 : p = 38.0140318123903008244444+xsq*p;
3947 0 : p = 3017.82788536507577809226+xsq*p;
3948 0 : p = 7404.07142710151470082064+xsq*p;
3949 0 : p = 80437.3630960840172832162+xsq*p;
3950 0 : q = 0.0;
3951 0 : q = 1.00000000000000000000000+xsq*q;
3952 0 : q = 38.0190713951939403753468+xsq*q;
3953 0 : q = 658.070155459240506326937+xsq*q;
3954 0 : q = 6379.60017324428279487120+xsq*q;
3955 0 : q = 34216.5257924628539769006+xsq*q;
3956 0 : q = 80437.3630960840172826266+xsq*q;
3957 0 : result = s*1.1283791670955125738961589031*x*p/q;
3958 0 : return result;
3959 : }
3960 0 : if( ae_fp_greater_eq(x,(double)(10)) )
3961 : {
3962 0 : result = s;
3963 0 : return result;
3964 : }
3965 0 : result = s*(1-errorfunctionc(x, _state));
3966 0 : return result;
3967 : }
3968 :
3969 :
3970 : /*************************************************************************
3971 : Complementary error function
3972 :
3973 : 1 - erf(x) =
3974 :
3975 : inf.
3976 : -
3977 : 2 | | 2
3978 : erfc(x) = -------- | exp( - t ) dt
3979 : sqrt(pi) | |
3980 : -
3981 : x
3982 :
3983 :
3984 : For small x, erfc(x) = 1 - erf(x); otherwise rational
3985 : approximations are computed.
3986 :
3987 :
3988 : ACCURACY:
3989 :
3990 : Relative error:
3991 : arithmetic domain # trials peak rms
3992 : IEEE 0,26.6417 30000 5.7e-14 1.5e-14
3993 :
3994 : Cephes Math Library Release 2.8: June, 2000
3995 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
3996 : *************************************************************************/
3997 0 : double errorfunctionc(double x, ae_state *_state)
3998 : {
3999 : double p;
4000 : double q;
4001 : double result;
4002 :
4003 :
4004 0 : if( ae_fp_less(x,(double)(0)) )
4005 : {
4006 0 : result = 2-errorfunctionc(-x, _state);
4007 0 : return result;
4008 : }
4009 0 : if( ae_fp_less(x,0.5) )
4010 : {
4011 0 : result = 1.0-errorfunction(x, _state);
4012 0 : return result;
4013 : }
4014 0 : if( ae_fp_greater_eq(x,(double)(10)) )
4015 : {
4016 0 : result = (double)(0);
4017 0 : return result;
4018 : }
4019 0 : p = 0.0;
4020 0 : p = 0.5641877825507397413087057563+x*p;
4021 0 : p = 9.675807882987265400604202961+x*p;
4022 0 : p = 77.08161730368428609781633646+x*p;
4023 0 : p = 368.5196154710010637133875746+x*p;
4024 0 : p = 1143.262070703886173606073338+x*p;
4025 0 : p = 2320.439590251635247384768711+x*p;
4026 0 : p = 2898.0293292167655611275846+x*p;
4027 0 : p = 1826.3348842295112592168999+x*p;
4028 0 : q = 1.0;
4029 0 : q = 17.14980943627607849376131193+x*q;
4030 0 : q = 137.1255960500622202878443578+x*q;
4031 0 : q = 661.7361207107653469211984771+x*q;
4032 0 : q = 2094.384367789539593790281779+x*q;
4033 0 : q = 4429.612803883682726711528526+x*q;
4034 0 : q = 6089.5424232724435504633068+x*q;
4035 0 : q = 4958.82756472114071495438422+x*q;
4036 0 : q = 1826.3348842295112595576438+x*q;
4037 0 : result = ae_exp(-ae_sqr(x, _state), _state)*p/q;
4038 0 : return result;
4039 : }
4040 :
4041 :
4042 : /*************************************************************************
4043 : Same as normalcdf(), obsolete name.
4044 : *************************************************************************/
4045 0 : double normaldistribution(double x, ae_state *_state)
4046 : {
4047 : double result;
4048 :
4049 :
4050 0 : result = 0.5*(errorfunction(x/1.41421356237309504880, _state)+1);
4051 0 : return result;
4052 : }
4053 :
4054 :
4055 : /*************************************************************************
4056 : Normal distribution PDF
4057 :
4058 : Returns Gaussian probability density function:
4059 :
4060 : 1
4061 : f(x) = --------- * exp(-x^2/2)
4062 : sqrt(2pi)
4063 :
4064 : Cephes Math Library Release 2.8: June, 2000
4065 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
4066 : *************************************************************************/
4067 0 : double normalpdf(double x, ae_state *_state)
4068 : {
4069 : double result;
4070 :
4071 :
4072 0 : ae_assert(ae_isfinite(x, _state), "NormalPDF: X is infinite", _state);
4073 0 : result = ae_exp(-x*x/2, _state)/ae_sqrt(2*ae_pi, _state);
4074 0 : return result;
4075 : }
4076 :
4077 :
4078 : /*************************************************************************
4079 : Normal distribution CDF
4080 :
4081 : Returns the area under the Gaussian probability density
4082 : function, integrated from minus infinity to x:
4083 :
4084 : x
4085 : -
4086 : 1 | | 2
4087 : ndtr(x) = --------- | exp( - t /2 ) dt
4088 : sqrt(2pi) | |
4089 : -
4090 : -inf.
4091 :
4092 : = ( 1 + erf(z) ) / 2
4093 : = erfc(z) / 2
4094 :
4095 : where z = x/sqrt(2). Computation is via the functions
4096 : erf and erfc.
4097 :
4098 :
4099 : ACCURACY:
4100 :
4101 : Relative error:
4102 : arithmetic domain # trials peak rms
4103 : IEEE -13,0 30000 3.4e-14 6.7e-15
4104 :
4105 : Cephes Math Library Release 2.8: June, 2000
4106 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
4107 : *************************************************************************/
4108 0 : double normalcdf(double x, ae_state *_state)
4109 : {
4110 : double result;
4111 :
4112 :
4113 0 : result = 0.5*(errorfunction(x/1.41421356237309504880, _state)+1);
4114 0 : return result;
4115 : }
4116 :
4117 :
4118 : /*************************************************************************
4119 : Inverse of the error function
4120 :
4121 : Cephes Math Library Release 2.8: June, 2000
4122 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
4123 : *************************************************************************/
4124 0 : double inverf(double e, ae_state *_state)
4125 : {
4126 : double result;
4127 :
4128 :
4129 0 : result = invnormaldistribution(0.5*(e+1), _state)/ae_sqrt((double)(2), _state);
4130 0 : return result;
4131 : }
4132 :
4133 :
4134 : /*************************************************************************
4135 : Same as invnormalcdf(), deprecated name
4136 : *************************************************************************/
4137 0 : double invnormaldistribution(double y0, ae_state *_state)
4138 : {
4139 : double result;
4140 :
4141 :
4142 0 : result = invnormalcdf(y0, _state);
4143 0 : return result;
4144 : }
4145 :
4146 :
4147 : /*************************************************************************
4148 : Inverse of Normal CDF
4149 :
4150 : Returns the argument, x, for which the area under the
4151 : Gaussian probability density function (integrated from
4152 : minus infinity to x) is equal to y.
4153 :
4154 :
4155 : For small arguments 0 < y < exp(-2), the program computes
4156 : z = sqrt( -2.0 * log(y) ); then the approximation is
4157 : x = z - log(z)/z - (1/z) P(1/z) / Q(1/z).
4158 : There are two rational functions P/Q, one for 0 < y < exp(-32)
4159 : and the other for y up to exp(-2). For larger arguments,
4160 : w = y - 0.5, and x/sqrt(2pi) = w + w**3 R(w**2)/S(w**2)).
4161 :
4162 : ACCURACY:
4163 :
4164 : Relative error:
4165 : arithmetic domain # trials peak rms
4166 : IEEE 0.125, 1 20000 7.2e-16 1.3e-16
4167 : IEEE 3e-308, 0.135 50000 4.6e-16 9.8e-17
4168 :
4169 : Cephes Math Library Release 2.8: June, 2000
4170 : Copyright 1984, 1987, 1988, 1992, 2000 by Stephen L. Moshier
4171 : *************************************************************************/
4172 0 : double invnormalcdf(double y0, ae_state *_state)
4173 : {
4174 : double expm2;
4175 : double s2pi;
4176 : double x;
4177 : double y;
4178 : double z;
4179 : double y2;
4180 : double x0;
4181 : double x1;
4182 : ae_int_t code;
4183 : double p0;
4184 : double q0;
4185 : double p1;
4186 : double q1;
4187 : double p2;
4188 : double q2;
4189 : double result;
4190 :
4191 :
4192 0 : expm2 = 0.13533528323661269189;
4193 0 : s2pi = 2.50662827463100050242;
4194 0 : if( ae_fp_less_eq(y0,(double)(0)) )
4195 : {
4196 0 : result = -ae_maxrealnumber;
4197 0 : return result;
4198 : }
4199 0 : if( ae_fp_greater_eq(y0,(double)(1)) )
4200 : {
4201 0 : result = ae_maxrealnumber;
4202 0 : return result;
4203 : }
4204 0 : code = 1;
4205 0 : y = y0;
4206 0 : if( ae_fp_greater(y,1.0-expm2) )
4207 : {
4208 0 : y = 1.0-y;
4209 0 : code = 0;
4210 : }
4211 0 : if( ae_fp_greater(y,expm2) )
4212 : {
4213 0 : y = y-0.5;
4214 0 : y2 = y*y;
4215 0 : p0 = -59.9633501014107895267;
4216 0 : p0 = 98.0010754185999661536+y2*p0;
4217 0 : p0 = -56.6762857469070293439+y2*p0;
4218 0 : p0 = 13.9312609387279679503+y2*p0;
4219 0 : p0 = -1.23916583867381258016+y2*p0;
4220 0 : q0 = (double)(1);
4221 0 : q0 = 1.95448858338141759834+y2*q0;
4222 0 : q0 = 4.67627912898881538453+y2*q0;
4223 0 : q0 = 86.3602421390890590575+y2*q0;
4224 0 : q0 = -225.462687854119370527+y2*q0;
4225 0 : q0 = 200.260212380060660359+y2*q0;
4226 0 : q0 = -82.0372256168333339912+y2*q0;
4227 0 : q0 = 15.9056225126211695515+y2*q0;
4228 0 : q0 = -1.18331621121330003142+y2*q0;
4229 0 : x = y+y*y2*p0/q0;
4230 0 : x = x*s2pi;
4231 0 : result = x;
4232 0 : return result;
4233 : }
4234 0 : x = ae_sqrt(-2.0*ae_log(y, _state), _state);
4235 0 : x0 = x-ae_log(x, _state)/x;
4236 0 : z = 1.0/x;
4237 0 : if( ae_fp_less(x,8.0) )
4238 : {
4239 0 : p1 = 4.05544892305962419923;
4240 0 : p1 = 31.5251094599893866154+z*p1;
4241 0 : p1 = 57.1628192246421288162+z*p1;
4242 0 : p1 = 44.0805073893200834700+z*p1;
4243 0 : p1 = 14.6849561928858024014+z*p1;
4244 0 : p1 = 2.18663306850790267539+z*p1;
4245 0 : p1 = -1.40256079171354495875*0.1+z*p1;
4246 0 : p1 = -3.50424626827848203418*0.01+z*p1;
4247 0 : p1 = -8.57456785154685413611*0.0001+z*p1;
4248 0 : q1 = (double)(1);
4249 0 : q1 = 15.7799883256466749731+z*q1;
4250 0 : q1 = 45.3907635128879210584+z*q1;
4251 0 : q1 = 41.3172038254672030440+z*q1;
4252 0 : q1 = 15.0425385692907503408+z*q1;
4253 0 : q1 = 2.50464946208309415979+z*q1;
4254 0 : q1 = -1.42182922854787788574*0.1+z*q1;
4255 0 : q1 = -3.80806407691578277194*0.01+z*q1;
4256 0 : q1 = -9.33259480895457427372*0.0001+z*q1;
4257 0 : x1 = z*p1/q1;
4258 : }
4259 : else
4260 : {
4261 0 : p2 = 3.23774891776946035970;
4262 0 : p2 = 6.91522889068984211695+z*p2;
4263 0 : p2 = 3.93881025292474443415+z*p2;
4264 0 : p2 = 1.33303460815807542389+z*p2;
4265 0 : p2 = 2.01485389549179081538*0.1+z*p2;
4266 0 : p2 = 1.23716634817820021358*0.01+z*p2;
4267 0 : p2 = 3.01581553508235416007*0.0001+z*p2;
4268 0 : p2 = 2.65806974686737550832*0.000001+z*p2;
4269 0 : p2 = 6.23974539184983293730*0.000000001+z*p2;
4270 0 : q2 = (double)(1);
4271 0 : q2 = 6.02427039364742014255+z*q2;
4272 0 : q2 = 3.67983563856160859403+z*q2;
4273 0 : q2 = 1.37702099489081330271+z*q2;
4274 0 : q2 = 2.16236993594496635890*0.1+z*q2;
4275 0 : q2 = 1.34204006088543189037*0.01+z*q2;
4276 0 : q2 = 3.28014464682127739104*0.0001+z*q2;
4277 0 : q2 = 2.89247864745380683936*0.000001+z*q2;
4278 0 : q2 = 6.79019408009981274425*0.000000001+z*q2;
4279 0 : x1 = z*p2/q2;
4280 : }
4281 0 : x = x0-x1;
4282 0 : if( code!=0 )
4283 : {
4284 0 : x = -x;
4285 : }
4286 0 : result = x;
4287 0 : return result;
4288 : }
4289 :
4290 :
4291 : /*************************************************************************
4292 : Bivariate normal PDF
4293 :
4294 : Returns probability density function of the bivariate Gaussian with
4295 : correlation parameter equal to Rho:
4296 :
4297 : 1 ( x^2 - 2*rho*x*y + y^2 )
4298 : f(x,y,rho) = ----------------- * exp( - ----------------------- )
4299 : 2pi*sqrt(1-rho^2) ( 2*(1-rho^2) )
4300 :
4301 :
4302 : with -1<rho<+1 and arbitrary x, y.
4303 :
4304 : This function won't fail as long as Rho is in (-1,+1) range.
4305 :
4306 : -- ALGLIB --
4307 : Copyright 15.11.2019 by Bochkanov Sergey
4308 : *************************************************************************/
4309 0 : double bivariatenormalpdf(double x,
4310 : double y,
4311 : double rho,
4312 : ae_state *_state)
4313 : {
4314 : double onerho2;
4315 : double result;
4316 :
4317 :
4318 0 : ae_assert(ae_isfinite(x, _state), "BivariateNormalCDF: X is infinite", _state);
4319 0 : ae_assert(ae_isfinite(y, _state), "BivariateNormalCDF: Y is infinite", _state);
4320 0 : ae_assert(ae_isfinite(rho, _state), "BivariateNormalCDF: Rho is infinite", _state);
4321 0 : ae_assert(ae_fp_less((double)(-1),rho)&&ae_fp_less(rho,(double)(1)), "BivariateNormalCDF: Rho is not in (-1,+1) range", _state);
4322 0 : onerho2 = (1-rho)*(1+rho);
4323 0 : result = ae_exp(-(x*x+y*y-2*rho*x*y)/(2*onerho2), _state)/(2*ae_pi*ae_sqrt(onerho2, _state));
4324 0 : return result;
4325 : }
4326 :
4327 :
4328 : /*************************************************************************
4329 : Bivariate normal CDF
4330 :
4331 : Returns the area under the bivariate Gaussian PDF with correlation
4332 : parameter equal to Rho, integrated from minus infinity to (x,y):
4333 :
4334 :
4335 : x y
4336 : - -
4337 : 1 | | | |
4338 : bvn(x,y,rho) = ------------------- | | f(u,v,rho)*du*dv
4339 : 2pi*sqrt(1-rho^2) | | | |
4340 : - -
4341 : -INF -INF
4342 :
4343 :
4344 : where
4345 :
4346 : ( u^2 - 2*rho*u*v + v^2 )
4347 : f(u,v,rho) = exp( - ----------------------- )
4348 : ( 2*(1-rho^2) )
4349 :
4350 :
4351 : with -1<rho<+1 and arbitrary x, y.
4352 :
4353 : This subroutine uses high-precision approximation scheme proposed by
4354 : Alan Genz in "Numerical Computation of Rectangular Bivariate and
4355 : Trivariate Normal and t probabilities", which computes CDF with
4356 : absolute error roughly equal to 1e-14.
4357 :
4358 : This function won't fail as long as Rho is in (-1,+1) range.
4359 :
4360 : -- ALGLIB --
4361 : Copyright 15.11.2019 by Bochkanov Sergey
4362 : *************************************************************************/
4363 0 : double bivariatenormalcdf(double x,
4364 : double y,
4365 : double rho,
4366 : ae_state *_state)
4367 : {
4368 : double rangea;
4369 : double rangeb;
4370 : double s;
4371 : double v;
4372 : double v0;
4373 : double v1;
4374 : double fxys;
4375 : double ta;
4376 : double tb;
4377 : double tc;
4378 : double result;
4379 :
4380 :
4381 0 : ae_assert(ae_isfinite(x, _state), "BivariateNormalCDF: X is infinite", _state);
4382 0 : ae_assert(ae_isfinite(y, _state), "BivariateNormalCDF: Y is infinite", _state);
4383 0 : ae_assert(ae_isfinite(rho, _state), "BivariateNormalCDF: Rho is infinite", _state);
4384 0 : ae_assert(ae_fp_less((double)(-1),rho)&&ae_fp_less(rho,(double)(1)), "BivariateNormalCDF: Rho is not in (-1,+1) range", _state);
4385 0 : if( ae_fp_eq(rho,(double)(0)) )
4386 : {
4387 0 : result = normalcdf(x, _state)*normalcdf(y, _state);
4388 0 : return result;
4389 : }
4390 0 : if( ae_fp_less_eq(ae_fabs(rho, _state),0.8) )
4391 : {
4392 :
4393 : /*
4394 : * Rho is small, compute integral using using formula (3) by Alan Genz, integrated
4395 : * by means of 10-point Gauss-Legendre quadrature
4396 : */
4397 0 : rangea = (double)(0);
4398 0 : rangeb = ae_asin(rho, _state);
4399 0 : v = (double)(0);
4400 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.2491470458134028, -0.1252334085114689, _state);
4401 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.2491470458134028, 0.1252334085114689, _state);
4402 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.2334925365383548, -0.3678314989981802, _state);
4403 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.2334925365383548, 0.3678314989981802, _state);
4404 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.2031674267230659, -0.5873179542866175, _state);
4405 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.2031674267230659, 0.5873179542866175, _state);
4406 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.1600783285433462, -0.7699026741943047, _state);
4407 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.1600783285433462, 0.7699026741943047, _state);
4408 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.1069393259953184, -0.9041172563704749, _state);
4409 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.1069393259953184, 0.9041172563704749, _state);
4410 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.0471753363865118, -0.9815606342467192, _state);
4411 0 : v = v+normaldistr_bvnintegrate3(rangea, rangeb, x, y, 0.0471753363865118, 0.9815606342467192, _state);
4412 0 : v = v*0.5*(rangeb-rangea)/(2*ae_pi);
4413 0 : result = normalcdf(x, _state)*normalcdf(y, _state)+v;
4414 : }
4415 : else
4416 : {
4417 :
4418 : /*
4419 : * Rho is large, compute integral using using formula (6) by Alan Genz, integrated
4420 : * by means of 20-point Gauss-Legendre quadrature.
4421 : */
4422 0 : x = -x;
4423 0 : y = -y;
4424 0 : s = (double)(ae_sign(rho, _state));
4425 0 : if( ae_fp_greater(s,(double)(0)) )
4426 : {
4427 0 : fxys = normalcdf(-ae_maxreal(x, y, _state), _state);
4428 : }
4429 : else
4430 : {
4431 0 : fxys = ae_maxreal(0.0, normalcdf(-x, _state)-normalcdf(y, _state), _state);
4432 : }
4433 0 : rangea = (double)(0);
4434 0 : rangeb = ae_sqrt((1-rho)*(1+rho), _state);
4435 :
4436 : /*
4437 : * Compute first term (analytic integral) from formula (6)
4438 : */
4439 0 : ta = rangeb;
4440 0 : tb = ae_fabs(x-s*y, _state);
4441 0 : tc = (4-s*x*y)/8;
4442 0 : v0 = ta*(1-tc*(tb*tb-ta*ta)/3)*ae_exp(-tb*tb/(2*ta*ta), _state)-tb*(1-tc*tb*tb/3)*ae_sqrt(2*ae_pi, _state)*normalcdf(-tb/ta, _state);
4443 0 : v0 = v0*ae_exp(-s*x*y/2, _state)/(2*ae_pi);
4444 :
4445 : /*
4446 : * Compute second term (numerical integral, 20-point Gauss-Legendre rule) from formula (6)
4447 : */
4448 0 : v1 = (double)(0);
4449 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1527533871307258, -0.0765265211334973, _state);
4450 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1527533871307258, 0.0765265211334973, _state);
4451 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1491729864726037, -0.2277858511416451, _state);
4452 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1491729864726037, 0.2277858511416451, _state);
4453 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1420961093183820, -0.3737060887154195, _state);
4454 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1420961093183820, 0.3737060887154195, _state);
4455 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1316886384491766, -0.5108670019508271, _state);
4456 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1316886384491766, 0.5108670019508271, _state);
4457 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1181945319615184, -0.6360536807265150, _state);
4458 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1181945319615184, 0.6360536807265150, _state);
4459 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1019301198172404, -0.7463319064601508, _state);
4460 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.1019301198172404, 0.7463319064601508, _state);
4461 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0832767415767048, -0.8391169718222188, _state);
4462 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0832767415767048, 0.8391169718222188, _state);
4463 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0626720483341091, -0.9122344282513259, _state);
4464 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0626720483341091, 0.9122344282513259, _state);
4465 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0406014298003869, -0.9639719272779138, _state);
4466 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0406014298003869, 0.9639719272779138, _state);
4467 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0176140071391521, -0.9931285991850949, _state);
4468 0 : v1 = v1+normaldistr_bvnintegrate6(rangea, rangeb, x, y, s, 0.0176140071391521, 0.9931285991850949, _state);
4469 0 : v1 = v1*0.5*(rangeb-rangea)/(2*ae_pi);
4470 0 : result = fxys-s*(v0+v1);
4471 : }
4472 0 : result = ae_maxreal(result, (double)(0), _state);
4473 0 : result = ae_minreal(result, (double)(1), _state);
4474 0 : return result;
4475 : }
4476 :
4477 :
4478 : /*************************************************************************
4479 : Internal function which computes integrand of formula (3) by Alan
4480 : Genz times Gaussian weights (passed by user).
4481 :
4482 : -- ALGLIB --
4483 : Copyright 15.11.2019 by Bochkanov Sergey
4484 : *************************************************************************/
4485 0 : static double normaldistr_bvnintegrate3(double rangea,
4486 : double rangeb,
4487 : double x,
4488 : double y,
4489 : double gw,
4490 : double gx,
4491 : ae_state *_state)
4492 : {
4493 : double r;
4494 : double t2;
4495 : double dd;
4496 : double sinr;
4497 : double cosr;
4498 : double result;
4499 :
4500 :
4501 0 : r = (rangeb-rangea)*0.5*gx+(rangeb+rangea)*0.5;
4502 0 : t2 = ae_tan(0.5*r, _state);
4503 0 : dd = 1/(1+t2*t2);
4504 0 : sinr = 2*t2*dd;
4505 0 : cosr = (1-t2*t2)*dd;
4506 0 : result = gw*ae_exp(-(x*x+y*y-2*x*y*sinr)/(2*cosr*cosr), _state);
4507 0 : return result;
4508 : }
4509 :
4510 :
4511 : /*************************************************************************
4512 : Internal function which computes integrand of formula (6) by Alan
4513 : Genz times Gaussian weights (passed by user).
4514 :
4515 : -- ALGLIB --
4516 : Copyright 15.11.2019 by Bochkanov Sergey
4517 : *************************************************************************/
4518 0 : static double normaldistr_bvnintegrate6(double rangea,
4519 : double rangeb,
4520 : double x,
4521 : double y,
4522 : double s,
4523 : double gw,
4524 : double gx,
4525 : ae_state *_state)
4526 : {
4527 : double r;
4528 : double exphsk22x2;
4529 : double exphsk2;
4530 : double sqrt1x2;
4531 : double exphsk1sqrt1x2;
4532 : double result;
4533 :
4534 :
4535 0 : r = (rangeb-rangea)*0.5*gx+(rangeb+rangea)*0.5;
4536 0 : exphsk22x2 = ae_exp(-(x-s*y)*(x-s*y)/(2*r*r), _state);
4537 0 : exphsk2 = ae_exp(-x*s*y/2, _state);
4538 0 : sqrt1x2 = ae_sqrt((1-r)*(1+r), _state);
4539 0 : exphsk1sqrt1x2 = ae_exp(-x*s*y/(1+sqrt1x2), _state);
4540 0 : result = gw*exphsk22x2*(exphsk1sqrt1x2/sqrt1x2-exphsk2*(1+(4-x*y*s)*r*r/8));
4541 0 : return result;
4542 : }
4543 :
4544 :
4545 : #endif
4546 : #if defined(AE_COMPILE_IGAMMAF) || !defined(AE_PARTIAL_BUILD)
4547 :
4548 :
4549 : /*************************************************************************
4550 : Incomplete gamma integral
4551 :
4552 : The function is defined by
4553 :
4554 : x
4555 : -
4556 : 1 | | -t a-1
4557 : igam(a,x) = ----- | e t dt.
4558 : - | |
4559 : | (a) -
4560 : 0
4561 :
4562 :
4563 : In this implementation both arguments must be positive.
4564 : The integral is evaluated by either a power series or
4565 : continued fraction expansion, depending on the relative
4566 : values of a and x.
4567 :
4568 : ACCURACY:
4569 :
4570 : Relative error:
4571 : arithmetic domain # trials peak rms
4572 : IEEE 0,30 200000 3.6e-14 2.9e-15
4573 : IEEE 0,100 300000 9.9e-14 1.5e-14
4574 :
4575 : Cephes Math Library Release 2.8: June, 2000
4576 : Copyright 1985, 1987, 2000 by Stephen L. Moshier
4577 : *************************************************************************/
4578 0 : double incompletegamma(double a, double x, ae_state *_state)
4579 : {
4580 : double igammaepsilon;
4581 : double ans;
4582 : double ax;
4583 : double c;
4584 : double r;
4585 : double tmp;
4586 : double result;
4587 :
4588 :
4589 0 : igammaepsilon = 0.000000000000001;
4590 0 : if( ae_fp_less_eq(x,(double)(0))||ae_fp_less_eq(a,(double)(0)) )
4591 : {
4592 0 : result = (double)(0);
4593 0 : return result;
4594 : }
4595 0 : if( ae_fp_greater(x,(double)(1))&&ae_fp_greater(x,a) )
4596 : {
4597 0 : result = 1-incompletegammac(a, x, _state);
4598 0 : return result;
4599 : }
4600 0 : ax = a*ae_log(x, _state)-x-lngamma(a, &tmp, _state);
4601 0 : if( ae_fp_less(ax,-709.78271289338399) )
4602 : {
4603 0 : result = (double)(0);
4604 0 : return result;
4605 : }
4606 0 : ax = ae_exp(ax, _state);
4607 0 : r = a;
4608 0 : c = (double)(1);
4609 0 : ans = (double)(1);
4610 0 : do
4611 : {
4612 0 : r = r+1;
4613 0 : c = c*x/r;
4614 0 : ans = ans+c;
4615 : }
4616 0 : while(ae_fp_greater(c/ans,igammaepsilon));
4617 0 : result = ans*ax/a;
4618 0 : return result;
4619 : }
4620 :
4621 :
4622 : /*************************************************************************
4623 : Complemented incomplete gamma integral
4624 :
4625 : The function is defined by
4626 :
4627 :
4628 : igamc(a,x) = 1 - igam(a,x)
4629 :
4630 : inf.
4631 : -
4632 : 1 | | -t a-1
4633 : = ----- | e t dt.
4634 : - | |
4635 : | (a) -
4636 : x
4637 :
4638 :
4639 : In this implementation both arguments must be positive.
4640 : The integral is evaluated by either a power series or
4641 : continued fraction expansion, depending on the relative
4642 : values of a and x.
4643 :
4644 : ACCURACY:
4645 :
4646 : Tested at random a, x.
4647 : a x Relative error:
4648 : arithmetic domain domain # trials peak rms
4649 : IEEE 0.5,100 0,100 200000 1.9e-14 1.7e-15
4650 : IEEE 0.01,0.5 0,100 200000 1.4e-13 1.6e-15
4651 :
4652 : Cephes Math Library Release 2.8: June, 2000
4653 : Copyright 1985, 1987, 2000 by Stephen L. Moshier
4654 : *************************************************************************/
4655 0 : double incompletegammac(double a, double x, ae_state *_state)
4656 : {
4657 : double igammaepsilon;
4658 : double igammabignumber;
4659 : double igammabignumberinv;
4660 : double ans;
4661 : double ax;
4662 : double c;
4663 : double yc;
4664 : double r;
4665 : double t;
4666 : double y;
4667 : double z;
4668 : double pk;
4669 : double pkm1;
4670 : double pkm2;
4671 : double qk;
4672 : double qkm1;
4673 : double qkm2;
4674 : double tmp;
4675 : double result;
4676 :
4677 :
4678 0 : igammaepsilon = 0.000000000000001;
4679 0 : igammabignumber = 4503599627370496.0;
4680 0 : igammabignumberinv = 2.22044604925031308085*0.0000000000000001;
4681 0 : if( ae_fp_less_eq(x,(double)(0))||ae_fp_less_eq(a,(double)(0)) )
4682 : {
4683 0 : result = (double)(1);
4684 0 : return result;
4685 : }
4686 0 : if( ae_fp_less(x,(double)(1))||ae_fp_less(x,a) )
4687 : {
4688 0 : result = 1-incompletegamma(a, x, _state);
4689 0 : return result;
4690 : }
4691 0 : ax = a*ae_log(x, _state)-x-lngamma(a, &tmp, _state);
4692 0 : if( ae_fp_less(ax,-709.78271289338399) )
4693 : {
4694 0 : result = (double)(0);
4695 0 : return result;
4696 : }
4697 0 : ax = ae_exp(ax, _state);
4698 0 : y = 1-a;
4699 0 : z = x+y+1;
4700 0 : c = (double)(0);
4701 0 : pkm2 = (double)(1);
4702 0 : qkm2 = x;
4703 0 : pkm1 = x+1;
4704 0 : qkm1 = z*x;
4705 0 : ans = pkm1/qkm1;
4706 0 : do
4707 : {
4708 0 : c = c+1;
4709 0 : y = y+1;
4710 0 : z = z+2;
4711 0 : yc = y*c;
4712 0 : pk = pkm1*z-pkm2*yc;
4713 0 : qk = qkm1*z-qkm2*yc;
4714 0 : if( ae_fp_neq(qk,(double)(0)) )
4715 : {
4716 0 : r = pk/qk;
4717 0 : t = ae_fabs((ans-r)/r, _state);
4718 0 : ans = r;
4719 : }
4720 : else
4721 : {
4722 0 : t = (double)(1);
4723 : }
4724 0 : pkm2 = pkm1;
4725 0 : pkm1 = pk;
4726 0 : qkm2 = qkm1;
4727 0 : qkm1 = qk;
4728 0 : if( ae_fp_greater(ae_fabs(pk, _state),igammabignumber) )
4729 : {
4730 0 : pkm2 = pkm2*igammabignumberinv;
4731 0 : pkm1 = pkm1*igammabignumberinv;
4732 0 : qkm2 = qkm2*igammabignumberinv;
4733 0 : qkm1 = qkm1*igammabignumberinv;
4734 : }
4735 : }
4736 0 : while(ae_fp_greater(t,igammaepsilon));
4737 0 : result = ans*ax;
4738 0 : return result;
4739 : }
4740 :
4741 :
4742 : /*************************************************************************
4743 : Inverse of complemented imcomplete gamma integral
4744 :
4745 : Given p, the function finds x such that
4746 :
4747 : igamc( a, x ) = p.
4748 :
4749 : Starting with the approximate value
4750 :
4751 : 3
4752 : x = a t
4753 :
4754 : where
4755 :
4756 : t = 1 - d - ndtri(p) sqrt(d)
4757 :
4758 : and
4759 :
4760 : d = 1/9a,
4761 :
4762 : the routine performs up to 10 Newton iterations to find the
4763 : root of igamc(a,x) - p = 0.
4764 :
4765 : ACCURACY:
4766 :
4767 : Tested at random a, p in the intervals indicated.
4768 :
4769 : a p Relative error:
4770 : arithmetic domain domain # trials peak rms
4771 : IEEE 0.5,100 0,0.5 100000 1.0e-14 1.7e-15
4772 : IEEE 0.01,0.5 0,0.5 100000 9.0e-14 3.4e-15
4773 : IEEE 0.5,10000 0,0.5 20000 2.3e-13 3.8e-14
4774 :
4775 : Cephes Math Library Release 2.8: June, 2000
4776 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
4777 : *************************************************************************/
4778 0 : double invincompletegammac(double a, double y0, ae_state *_state)
4779 : {
4780 : double igammaepsilon;
4781 : double iinvgammabignumber;
4782 : double x0;
4783 : double x1;
4784 : double x;
4785 : double yl;
4786 : double yh;
4787 : double y;
4788 : double d;
4789 : double lgm;
4790 : double dithresh;
4791 : ae_int_t i;
4792 : ae_int_t dir;
4793 : double tmp;
4794 : double result;
4795 :
4796 :
4797 0 : igammaepsilon = 0.000000000000001;
4798 0 : iinvgammabignumber = 4503599627370496.0;
4799 0 : x0 = iinvgammabignumber;
4800 0 : yl = (double)(0);
4801 0 : x1 = (double)(0);
4802 0 : yh = (double)(1);
4803 0 : dithresh = 5*igammaepsilon;
4804 0 : d = 1/(9*a);
4805 0 : y = 1-d-invnormaldistribution(y0, _state)*ae_sqrt(d, _state);
4806 0 : x = a*y*y*y;
4807 0 : lgm = lngamma(a, &tmp, _state);
4808 0 : i = 0;
4809 0 : while(i<10)
4810 : {
4811 0 : if( ae_fp_greater(x,x0)||ae_fp_less(x,x1) )
4812 : {
4813 0 : d = 0.0625;
4814 0 : break;
4815 : }
4816 0 : y = incompletegammac(a, x, _state);
4817 0 : if( ae_fp_less(y,yl)||ae_fp_greater(y,yh) )
4818 : {
4819 0 : d = 0.0625;
4820 0 : break;
4821 : }
4822 0 : if( ae_fp_less(y,y0) )
4823 : {
4824 0 : x0 = x;
4825 0 : yl = y;
4826 : }
4827 : else
4828 : {
4829 0 : x1 = x;
4830 0 : yh = y;
4831 : }
4832 0 : d = (a-1)*ae_log(x, _state)-x-lgm;
4833 0 : if( ae_fp_less(d,-709.78271289338399) )
4834 : {
4835 0 : d = 0.0625;
4836 0 : break;
4837 : }
4838 0 : d = -ae_exp(d, _state);
4839 0 : d = (y-y0)/d;
4840 0 : if( ae_fp_less(ae_fabs(d/x, _state),igammaepsilon) )
4841 : {
4842 0 : result = x;
4843 0 : return result;
4844 : }
4845 0 : x = x-d;
4846 0 : i = i+1;
4847 : }
4848 0 : if( ae_fp_eq(x0,iinvgammabignumber) )
4849 : {
4850 0 : if( ae_fp_less_eq(x,(double)(0)) )
4851 : {
4852 0 : x = (double)(1);
4853 : }
4854 0 : while(ae_fp_eq(x0,iinvgammabignumber))
4855 : {
4856 0 : x = (1+d)*x;
4857 0 : y = incompletegammac(a, x, _state);
4858 0 : if( ae_fp_less(y,y0) )
4859 : {
4860 0 : x0 = x;
4861 0 : yl = y;
4862 0 : break;
4863 : }
4864 0 : d = d+d;
4865 : }
4866 : }
4867 0 : d = 0.5;
4868 0 : dir = 0;
4869 0 : i = 0;
4870 0 : while(i<400)
4871 : {
4872 0 : x = x1+d*(x0-x1);
4873 0 : y = incompletegammac(a, x, _state);
4874 0 : lgm = (x0-x1)/(x1+x0);
4875 0 : if( ae_fp_less(ae_fabs(lgm, _state),dithresh) )
4876 : {
4877 0 : break;
4878 : }
4879 0 : lgm = (y-y0)/y0;
4880 0 : if( ae_fp_less(ae_fabs(lgm, _state),dithresh) )
4881 : {
4882 0 : break;
4883 : }
4884 0 : if( ae_fp_less_eq(x,0.0) )
4885 : {
4886 0 : break;
4887 : }
4888 0 : if( ae_fp_greater_eq(y,y0) )
4889 : {
4890 0 : x1 = x;
4891 0 : yh = y;
4892 0 : if( dir<0 )
4893 : {
4894 0 : dir = 0;
4895 0 : d = 0.5;
4896 : }
4897 : else
4898 : {
4899 0 : if( dir>1 )
4900 : {
4901 0 : d = 0.5*d+0.5;
4902 : }
4903 : else
4904 : {
4905 0 : d = (y0-yl)/(yh-yl);
4906 : }
4907 : }
4908 0 : dir = dir+1;
4909 : }
4910 : else
4911 : {
4912 0 : x0 = x;
4913 0 : yl = y;
4914 0 : if( dir>0 )
4915 : {
4916 0 : dir = 0;
4917 0 : d = 0.5;
4918 : }
4919 : else
4920 : {
4921 0 : if( dir<-1 )
4922 : {
4923 0 : d = 0.5*d;
4924 : }
4925 : else
4926 : {
4927 0 : d = (y0-yl)/(yh-yl);
4928 : }
4929 : }
4930 0 : dir = dir-1;
4931 : }
4932 0 : i = i+1;
4933 : }
4934 0 : result = x;
4935 0 : return result;
4936 : }
4937 :
4938 :
4939 : #endif
4940 : #if defined(AE_COMPILE_ELLIPTIC) || !defined(AE_PARTIAL_BUILD)
4941 :
4942 :
4943 : /*************************************************************************
4944 : Complete elliptic integral of the first kind
4945 :
4946 : Approximates the integral
4947 :
4948 :
4949 :
4950 : pi/2
4951 : -
4952 : | |
4953 : | dt
4954 : K(m) = | ------------------
4955 : | 2
4956 : | | sqrt( 1 - m sin t )
4957 : -
4958 : 0
4959 :
4960 : using the approximation
4961 :
4962 : P(x) - log x Q(x).
4963 :
4964 : ACCURACY:
4965 :
4966 : Relative error:
4967 : arithmetic domain # trials peak rms
4968 : IEEE 0,1 30000 2.5e-16 6.8e-17
4969 :
4970 : Cephes Math Library, Release 2.8: June, 2000
4971 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
4972 : *************************************************************************/
4973 0 : double ellipticintegralk(double m, ae_state *_state)
4974 : {
4975 : double result;
4976 :
4977 :
4978 0 : result = ellipticintegralkhighprecision(1.0-m, _state);
4979 0 : return result;
4980 : }
4981 :
4982 :
4983 : /*************************************************************************
4984 : Complete elliptic integral of the first kind
4985 :
4986 : Approximates the integral
4987 :
4988 :
4989 :
4990 : pi/2
4991 : -
4992 : | |
4993 : | dt
4994 : K(m) = | ------------------
4995 : | 2
4996 : | | sqrt( 1 - m sin t )
4997 : -
4998 : 0
4999 :
5000 : where m = 1 - m1, using the approximation
5001 :
5002 : P(x) - log x Q(x).
5003 :
5004 : The argument m1 is used rather than m so that the logarithmic
5005 : singularity at m = 1 will be shifted to the origin; this
5006 : preserves maximum accuracy.
5007 :
5008 : K(0) = pi/2.
5009 :
5010 : ACCURACY:
5011 :
5012 : Relative error:
5013 : arithmetic domain # trials peak rms
5014 : IEEE 0,1 30000 2.5e-16 6.8e-17
5015 :
5016 : Cephes Math Library, Release 2.8: June, 2000
5017 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
5018 : *************************************************************************/
5019 0 : double ellipticintegralkhighprecision(double m1, ae_state *_state)
5020 : {
5021 : double p;
5022 : double q;
5023 : double result;
5024 :
5025 :
5026 0 : if( ae_fp_less_eq(m1,ae_machineepsilon) )
5027 : {
5028 0 : result = 1.3862943611198906188E0-0.5*ae_log(m1, _state);
5029 : }
5030 : else
5031 : {
5032 0 : p = 1.37982864606273237150E-4;
5033 0 : p = p*m1+2.28025724005875567385E-3;
5034 0 : p = p*m1+7.97404013220415179367E-3;
5035 0 : p = p*m1+9.85821379021226008714E-3;
5036 0 : p = p*m1+6.87489687449949877925E-3;
5037 0 : p = p*m1+6.18901033637687613229E-3;
5038 0 : p = p*m1+8.79078273952743772254E-3;
5039 0 : p = p*m1+1.49380448916805252718E-2;
5040 0 : p = p*m1+3.08851465246711995998E-2;
5041 0 : p = p*m1+9.65735902811690126535E-2;
5042 0 : p = p*m1+1.38629436111989062502E0;
5043 0 : q = 2.94078955048598507511E-5;
5044 0 : q = q*m1+9.14184723865917226571E-4;
5045 0 : q = q*m1+5.94058303753167793257E-3;
5046 0 : q = q*m1+1.54850516649762399335E-2;
5047 0 : q = q*m1+2.39089602715924892727E-2;
5048 0 : q = q*m1+3.01204715227604046988E-2;
5049 0 : q = q*m1+3.73774314173823228969E-2;
5050 0 : q = q*m1+4.88280347570998239232E-2;
5051 0 : q = q*m1+7.03124996963957469739E-2;
5052 0 : q = q*m1+1.24999999999870820058E-1;
5053 0 : q = q*m1+4.99999999999999999821E-1;
5054 0 : result = p-q*ae_log(m1, _state);
5055 : }
5056 0 : return result;
5057 : }
5058 :
5059 :
5060 : /*************************************************************************
5061 : Incomplete elliptic integral of the first kind F(phi|m)
5062 :
5063 : Approximates the integral
5064 :
5065 :
5066 :
5067 : phi
5068 : -
5069 : | |
5070 : | dt
5071 : F(phi_\m) = | ------------------
5072 : | 2
5073 : | | sqrt( 1 - m sin t )
5074 : -
5075 : 0
5076 :
5077 : of amplitude phi and modulus m, using the arithmetic -
5078 : geometric mean algorithm.
5079 :
5080 :
5081 :
5082 :
5083 : ACCURACY:
5084 :
5085 : Tested at random points with m in [0, 1] and phi as indicated.
5086 :
5087 : Relative error:
5088 : arithmetic domain # trials peak rms
5089 : IEEE -10,10 200000 7.4e-16 1.0e-16
5090 :
5091 : Cephes Math Library Release 2.8: June, 2000
5092 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
5093 : *************************************************************************/
5094 0 : double incompleteellipticintegralk(double phi, double m, ae_state *_state)
5095 : {
5096 : double a;
5097 : double b;
5098 : double c;
5099 : double e;
5100 : double temp;
5101 : double pio2;
5102 : double t;
5103 : double k;
5104 : ae_int_t d;
5105 : ae_int_t md;
5106 : ae_int_t s;
5107 : ae_int_t npio2;
5108 : double result;
5109 :
5110 :
5111 0 : pio2 = 1.57079632679489661923;
5112 0 : if( ae_fp_eq(m,(double)(0)) )
5113 : {
5114 0 : result = phi;
5115 0 : return result;
5116 : }
5117 0 : a = 1-m;
5118 0 : if( ae_fp_eq(a,(double)(0)) )
5119 : {
5120 0 : result = ae_log(ae_tan(0.5*(pio2+phi), _state), _state);
5121 0 : return result;
5122 : }
5123 0 : npio2 = ae_ifloor(phi/pio2, _state);
5124 0 : if( npio2%2!=0 )
5125 : {
5126 0 : npio2 = npio2+1;
5127 : }
5128 0 : if( npio2!=0 )
5129 : {
5130 0 : k = ellipticintegralk(1-a, _state);
5131 0 : phi = phi-npio2*pio2;
5132 : }
5133 : else
5134 : {
5135 0 : k = (double)(0);
5136 : }
5137 0 : if( ae_fp_less(phi,(double)(0)) )
5138 : {
5139 0 : phi = -phi;
5140 0 : s = -1;
5141 : }
5142 : else
5143 : {
5144 0 : s = 0;
5145 : }
5146 0 : b = ae_sqrt(a, _state);
5147 0 : t = ae_tan(phi, _state);
5148 0 : if( ae_fp_greater(ae_fabs(t, _state),(double)(10)) )
5149 : {
5150 0 : e = 1.0/(b*t);
5151 0 : if( ae_fp_less(ae_fabs(e, _state),(double)(10)) )
5152 : {
5153 0 : e = ae_atan(e, _state);
5154 0 : if( npio2==0 )
5155 : {
5156 0 : k = ellipticintegralk(1-a, _state);
5157 : }
5158 0 : temp = k-incompleteellipticintegralk(e, m, _state);
5159 0 : if( s<0 )
5160 : {
5161 0 : temp = -temp;
5162 : }
5163 0 : result = temp+npio2*k;
5164 0 : return result;
5165 : }
5166 : }
5167 0 : a = 1.0;
5168 0 : c = ae_sqrt(m, _state);
5169 0 : d = 1;
5170 0 : md = 0;
5171 0 : while(ae_fp_greater(ae_fabs(c/a, _state),ae_machineepsilon))
5172 : {
5173 0 : temp = b/a;
5174 0 : phi = phi+ae_atan(t*temp, _state)+md*ae_pi;
5175 0 : md = ae_trunc((phi+pio2)/ae_pi, _state);
5176 0 : t = t*(1.0+temp)/(1.0-temp*t*t);
5177 0 : c = 0.5*(a-b);
5178 0 : temp = ae_sqrt(a*b, _state);
5179 0 : a = 0.5*(a+b);
5180 0 : b = temp;
5181 0 : d = d+d;
5182 : }
5183 0 : temp = (ae_atan(t, _state)+md*ae_pi)/(d*a);
5184 0 : if( s<0 )
5185 : {
5186 0 : temp = -temp;
5187 : }
5188 0 : result = temp+npio2*k;
5189 0 : return result;
5190 : }
5191 :
5192 :
5193 : /*************************************************************************
5194 : Complete elliptic integral of the second kind
5195 :
5196 : Approximates the integral
5197 :
5198 :
5199 : pi/2
5200 : -
5201 : | | 2
5202 : E(m) = | sqrt( 1 - m sin t ) dt
5203 : | |
5204 : -
5205 : 0
5206 :
5207 : using the approximation
5208 :
5209 : P(x) - x log x Q(x).
5210 :
5211 : ACCURACY:
5212 :
5213 : Relative error:
5214 : arithmetic domain # trials peak rms
5215 : IEEE 0, 1 10000 2.1e-16 7.3e-17
5216 :
5217 : Cephes Math Library, Release 2.8: June, 2000
5218 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
5219 : *************************************************************************/
5220 0 : double ellipticintegrale(double m, ae_state *_state)
5221 : {
5222 : double p;
5223 : double q;
5224 : double result;
5225 :
5226 :
5227 0 : ae_assert(ae_fp_greater_eq(m,(double)(0))&&ae_fp_less_eq(m,(double)(1)), "Domain error in EllipticIntegralE: m<0 or m>1", _state);
5228 0 : m = 1-m;
5229 0 : if( ae_fp_eq(m,(double)(0)) )
5230 : {
5231 0 : result = (double)(1);
5232 0 : return result;
5233 : }
5234 0 : p = 1.53552577301013293365E-4;
5235 0 : p = p*m+2.50888492163602060990E-3;
5236 0 : p = p*m+8.68786816565889628429E-3;
5237 0 : p = p*m+1.07350949056076193403E-2;
5238 0 : p = p*m+7.77395492516787092951E-3;
5239 0 : p = p*m+7.58395289413514708519E-3;
5240 0 : p = p*m+1.15688436810574127319E-2;
5241 0 : p = p*m+2.18317996015557253103E-2;
5242 0 : p = p*m+5.68051945617860553470E-2;
5243 0 : p = p*m+4.43147180560990850618E-1;
5244 0 : p = p*m+1.00000000000000000299E0;
5245 0 : q = 3.27954898576485872656E-5;
5246 0 : q = q*m+1.00962792679356715133E-3;
5247 0 : q = q*m+6.50609489976927491433E-3;
5248 0 : q = q*m+1.68862163993311317300E-2;
5249 0 : q = q*m+2.61769742454493659583E-2;
5250 0 : q = q*m+3.34833904888224918614E-2;
5251 0 : q = q*m+4.27180926518931511717E-2;
5252 0 : q = q*m+5.85936634471101055642E-2;
5253 0 : q = q*m+9.37499997197644278445E-2;
5254 0 : q = q*m+2.49999999999888314361E-1;
5255 0 : result = p-q*m*ae_log(m, _state);
5256 0 : return result;
5257 : }
5258 :
5259 :
5260 : /*************************************************************************
5261 : Incomplete elliptic integral of the second kind
5262 :
5263 : Approximates the integral
5264 :
5265 :
5266 : phi
5267 : -
5268 : | |
5269 : | 2
5270 : E(phi_\m) = | sqrt( 1 - m sin t ) dt
5271 : |
5272 : | |
5273 : -
5274 : 0
5275 :
5276 : of amplitude phi and modulus m, using the arithmetic -
5277 : geometric mean algorithm.
5278 :
5279 : ACCURACY:
5280 :
5281 : Tested at random arguments with phi in [-10, 10] and m in
5282 : [0, 1].
5283 : Relative error:
5284 : arithmetic domain # trials peak rms
5285 : IEEE -10,10 150000 3.3e-15 1.4e-16
5286 :
5287 : Cephes Math Library Release 2.8: June, 2000
5288 : Copyright 1984, 1987, 1993, 2000 by Stephen L. Moshier
5289 : *************************************************************************/
5290 0 : double incompleteellipticintegrale(double phi, double m, ae_state *_state)
5291 : {
5292 : double pio2;
5293 : double a;
5294 : double b;
5295 : double c;
5296 : double e;
5297 : double temp;
5298 : double lphi;
5299 : double t;
5300 : double ebig;
5301 : ae_int_t d;
5302 : ae_int_t md;
5303 : ae_int_t npio2;
5304 : ae_int_t s;
5305 : double result;
5306 :
5307 :
5308 0 : pio2 = 1.57079632679489661923;
5309 0 : if( ae_fp_eq(m,(double)(0)) )
5310 : {
5311 0 : result = phi;
5312 0 : return result;
5313 : }
5314 0 : lphi = phi;
5315 0 : npio2 = ae_ifloor(lphi/pio2, _state);
5316 0 : if( npio2%2!=0 )
5317 : {
5318 0 : npio2 = npio2+1;
5319 : }
5320 0 : lphi = lphi-npio2*pio2;
5321 0 : if( ae_fp_less(lphi,(double)(0)) )
5322 : {
5323 0 : lphi = -lphi;
5324 0 : s = -1;
5325 : }
5326 : else
5327 : {
5328 0 : s = 1;
5329 : }
5330 0 : a = 1.0-m;
5331 0 : ebig = ellipticintegrale(m, _state);
5332 0 : if( ae_fp_eq(a,(double)(0)) )
5333 : {
5334 0 : temp = ae_sin(lphi, _state);
5335 0 : if( s<0 )
5336 : {
5337 0 : temp = -temp;
5338 : }
5339 0 : result = temp+npio2*ebig;
5340 0 : return result;
5341 : }
5342 0 : t = ae_tan(lphi, _state);
5343 0 : b = ae_sqrt(a, _state);
5344 :
5345 : /*
5346 : * Thanks to Brian Fitzgerald <fitzgb@mml0.meche.rpi.edu>
5347 : * for pointing out an instability near odd multiples of pi/2
5348 : */
5349 0 : if( ae_fp_greater(ae_fabs(t, _state),(double)(10)) )
5350 : {
5351 :
5352 : /*
5353 : * Transform the amplitude
5354 : */
5355 0 : e = 1.0/(b*t);
5356 :
5357 : /*
5358 : * ... but avoid multiple recursions.
5359 : */
5360 0 : if( ae_fp_less(ae_fabs(e, _state),(double)(10)) )
5361 : {
5362 0 : e = ae_atan(e, _state);
5363 0 : temp = ebig+m*ae_sin(lphi, _state)*ae_sin(e, _state)-incompleteellipticintegrale(e, m, _state);
5364 0 : if( s<0 )
5365 : {
5366 0 : temp = -temp;
5367 : }
5368 0 : result = temp+npio2*ebig;
5369 0 : return result;
5370 : }
5371 : }
5372 0 : c = ae_sqrt(m, _state);
5373 0 : a = 1.0;
5374 0 : d = 1;
5375 0 : e = 0.0;
5376 0 : md = 0;
5377 0 : while(ae_fp_greater(ae_fabs(c/a, _state),ae_machineepsilon))
5378 : {
5379 0 : temp = b/a;
5380 0 : lphi = lphi+ae_atan(t*temp, _state)+md*ae_pi;
5381 0 : md = ae_trunc((lphi+pio2)/ae_pi, _state);
5382 0 : t = t*(1.0+temp)/(1.0-temp*t*t);
5383 0 : c = 0.5*(a-b);
5384 0 : temp = ae_sqrt(a*b, _state);
5385 0 : a = 0.5*(a+b);
5386 0 : b = temp;
5387 0 : d = d+d;
5388 0 : e = e+c*ae_sin(lphi, _state);
5389 : }
5390 0 : temp = ebig/ellipticintegralk(m, _state);
5391 0 : temp = temp*((ae_atan(t, _state)+md*ae_pi)/(d*a));
5392 0 : temp = temp+e;
5393 0 : if( s<0 )
5394 : {
5395 0 : temp = -temp;
5396 : }
5397 0 : result = temp+npio2*ebig;
5398 0 : return result;
5399 : }
5400 :
5401 :
5402 : #endif
5403 : #if defined(AE_COMPILE_HERMITE) || !defined(AE_PARTIAL_BUILD)
5404 :
5405 :
5406 : /*************************************************************************
5407 : Calculation of the value of the Hermite polynomial.
5408 :
5409 : Parameters:
5410 : n - degree, n>=0
5411 : x - argument
5412 :
5413 : Result:
5414 : the value of the Hermite polynomial Hn at x
5415 : *************************************************************************/
5416 0 : double hermitecalculate(ae_int_t n, double x, ae_state *_state)
5417 : {
5418 : ae_int_t i;
5419 : double a;
5420 : double b;
5421 : double result;
5422 :
5423 :
5424 0 : result = (double)(0);
5425 :
5426 : /*
5427 : * Prepare A and B
5428 : */
5429 0 : a = (double)(1);
5430 0 : b = 2*x;
5431 :
5432 : /*
5433 : * Special cases: N=0 or N=1
5434 : */
5435 0 : if( n==0 )
5436 : {
5437 0 : result = a;
5438 0 : return result;
5439 : }
5440 0 : if( n==1 )
5441 : {
5442 0 : result = b;
5443 0 : return result;
5444 : }
5445 :
5446 : /*
5447 : * General case: N>=2
5448 : */
5449 0 : for(i=2; i<=n; i++)
5450 : {
5451 0 : result = 2*x*b-2*(i-1)*a;
5452 0 : a = b;
5453 0 : b = result;
5454 : }
5455 0 : return result;
5456 : }
5457 :
5458 :
5459 : /*************************************************************************
5460 : Summation of Hermite polynomials using Clenshaw's recurrence formula.
5461 :
5462 : This routine calculates
5463 : c[0]*H0(x) + c[1]*H1(x) + ... + c[N]*HN(x)
5464 :
5465 : Parameters:
5466 : n - degree, n>=0
5467 : x - argument
5468 :
5469 : Result:
5470 : the value of the Hermite polynomial at x
5471 : *************************************************************************/
5472 0 : double hermitesum(/* Real */ ae_vector* c,
5473 : ae_int_t n,
5474 : double x,
5475 : ae_state *_state)
5476 : {
5477 : double b1;
5478 : double b2;
5479 : ae_int_t i;
5480 : double result;
5481 :
5482 :
5483 0 : b1 = (double)(0);
5484 0 : b2 = (double)(0);
5485 0 : result = (double)(0);
5486 0 : for(i=n; i>=0; i--)
5487 : {
5488 0 : result = 2*(x*b1-(i+1)*b2)+c->ptr.p_double[i];
5489 0 : b2 = b1;
5490 0 : b1 = result;
5491 : }
5492 0 : return result;
5493 : }
5494 :
5495 :
5496 : /*************************************************************************
5497 : Representation of Hn as C[0] + C[1]*X + ... + C[N]*X^N
5498 :
5499 : Input parameters:
5500 : N - polynomial degree, n>=0
5501 :
5502 : Output parameters:
5503 : C - coefficients
5504 : *************************************************************************/
5505 0 : void hermitecoefficients(ae_int_t n,
5506 : /* Real */ ae_vector* c,
5507 : ae_state *_state)
5508 : {
5509 : ae_int_t i;
5510 :
5511 0 : ae_vector_clear(c);
5512 :
5513 0 : ae_vector_set_length(c, n+1, _state);
5514 0 : for(i=0; i<=n; i++)
5515 : {
5516 0 : c->ptr.p_double[i] = (double)(0);
5517 : }
5518 0 : c->ptr.p_double[n] = ae_exp(n*ae_log((double)(2), _state), _state);
5519 0 : for(i=0; i<=n/2-1; i++)
5520 : {
5521 0 : c->ptr.p_double[n-2*(i+1)] = -c->ptr.p_double[n-2*i]*(n-2*i)*(n-2*i-1)/4/(i+1);
5522 : }
5523 0 : }
5524 :
5525 :
5526 : #endif
5527 : #if defined(AE_COMPILE_DAWSON) || !defined(AE_PARTIAL_BUILD)
5528 :
5529 :
5530 : /*************************************************************************
5531 : Dawson's Integral
5532 :
5533 : Approximates the integral
5534 :
5535 : x
5536 : -
5537 : 2 | | 2
5538 : dawsn(x) = exp( -x ) | exp( t ) dt
5539 : | |
5540 : -
5541 : 0
5542 :
5543 : Three different rational approximations are employed, for
5544 : the intervals 0 to 3.25; 3.25 to 6.25; and 6.25 up.
5545 :
5546 : ACCURACY:
5547 :
5548 : Relative error:
5549 : arithmetic domain # trials peak rms
5550 : IEEE 0,10 10000 6.9e-16 1.0e-16
5551 :
5552 : Cephes Math Library Release 2.8: June, 2000
5553 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
5554 : *************************************************************************/
5555 0 : double dawsonintegral(double x, ae_state *_state)
5556 : {
5557 : double x2;
5558 : double y;
5559 : ae_int_t sg;
5560 : double an;
5561 : double ad;
5562 : double bn;
5563 : double bd;
5564 : double cn;
5565 : double cd;
5566 : double result;
5567 :
5568 :
5569 0 : sg = 1;
5570 0 : if( ae_fp_less(x,(double)(0)) )
5571 : {
5572 0 : sg = -1;
5573 0 : x = -x;
5574 : }
5575 0 : if( ae_fp_less(x,3.25) )
5576 : {
5577 0 : x2 = x*x;
5578 0 : an = 1.13681498971755972054E-11;
5579 0 : an = an*x2+8.49262267667473811108E-10;
5580 0 : an = an*x2+1.94434204175553054283E-8;
5581 0 : an = an*x2+9.53151741254484363489E-7;
5582 0 : an = an*x2+3.07828309874913200438E-6;
5583 0 : an = an*x2+3.52513368520288738649E-4;
5584 0 : an = an*x2+(-8.50149846724410912031E-4);
5585 0 : an = an*x2+4.22618223005546594270E-2;
5586 0 : an = an*x2+(-9.17480371773452345351E-2);
5587 0 : an = an*x2+9.99999999999999994612E-1;
5588 0 : ad = 2.40372073066762605484E-11;
5589 0 : ad = ad*x2+1.48864681368493396752E-9;
5590 0 : ad = ad*x2+5.21265281010541664570E-8;
5591 0 : ad = ad*x2+1.27258478273186970203E-6;
5592 0 : ad = ad*x2+2.32490249820789513991E-5;
5593 0 : ad = ad*x2+3.25524741826057911661E-4;
5594 0 : ad = ad*x2+3.48805814657162590916E-3;
5595 0 : ad = ad*x2+2.79448531198828973716E-2;
5596 0 : ad = ad*x2+1.58874241960120565368E-1;
5597 0 : ad = ad*x2+5.74918629489320327824E-1;
5598 0 : ad = ad*x2+1.00000000000000000539E0;
5599 0 : y = x*an/ad;
5600 0 : result = sg*y;
5601 0 : return result;
5602 : }
5603 0 : x2 = 1.0/(x*x);
5604 0 : if( ae_fp_less(x,6.25) )
5605 : {
5606 0 : bn = 5.08955156417900903354E-1;
5607 0 : bn = bn*x2-2.44754418142697847934E-1;
5608 0 : bn = bn*x2+9.41512335303534411857E-2;
5609 0 : bn = bn*x2-2.18711255142039025206E-2;
5610 0 : bn = bn*x2+3.66207612329569181322E-3;
5611 0 : bn = bn*x2-4.23209114460388756528E-4;
5612 0 : bn = bn*x2+3.59641304793896631888E-5;
5613 0 : bn = bn*x2-2.14640351719968974225E-6;
5614 0 : bn = bn*x2+9.10010780076391431042E-8;
5615 0 : bn = bn*x2-2.40274520828250956942E-9;
5616 0 : bn = bn*x2+3.59233385440928410398E-11;
5617 0 : bd = 1.00000000000000000000E0;
5618 0 : bd = bd*x2-6.31839869873368190192E-1;
5619 0 : bd = bd*x2+2.36706788228248691528E-1;
5620 0 : bd = bd*x2-5.31806367003223277662E-2;
5621 0 : bd = bd*x2+8.48041718586295374409E-3;
5622 0 : bd = bd*x2-9.47996768486665330168E-4;
5623 0 : bd = bd*x2+7.81025592944552338085E-5;
5624 0 : bd = bd*x2-4.55875153252442634831E-6;
5625 0 : bd = bd*x2+1.89100358111421846170E-7;
5626 0 : bd = bd*x2-4.91324691331920606875E-9;
5627 0 : bd = bd*x2+7.18466403235734541950E-11;
5628 0 : y = 1.0/x+x2*bn/(bd*x);
5629 0 : result = sg*0.5*y;
5630 0 : return result;
5631 : }
5632 0 : if( ae_fp_greater(x,1.0E9) )
5633 : {
5634 0 : result = sg*0.5/x;
5635 0 : return result;
5636 : }
5637 0 : cn = -5.90592860534773254987E-1;
5638 0 : cn = cn*x2+6.29235242724368800674E-1;
5639 0 : cn = cn*x2-1.72858975380388136411E-1;
5640 0 : cn = cn*x2+1.64837047825189632310E-2;
5641 0 : cn = cn*x2-4.86827613020462700845E-4;
5642 0 : cd = 1.00000000000000000000E0;
5643 0 : cd = cd*x2-2.69820057197544900361E0;
5644 0 : cd = cd*x2+1.73270799045947845857E0;
5645 0 : cd = cd*x2-3.93708582281939493482E-1;
5646 0 : cd = cd*x2+3.44278924041233391079E-2;
5647 0 : cd = cd*x2-9.73655226040941223894E-4;
5648 0 : y = 1.0/x+x2*cn/(cd*x);
5649 0 : result = sg*0.5*y;
5650 0 : return result;
5651 : }
5652 :
5653 :
5654 : #endif
5655 : #if defined(AE_COMPILE_TRIGINTEGRALS) || !defined(AE_PARTIAL_BUILD)
5656 :
5657 :
5658 : /*************************************************************************
5659 : Sine and cosine integrals
5660 :
5661 : Evaluates the integrals
5662 :
5663 : x
5664 : -
5665 : | cos t - 1
5666 : Ci(x) = eul + ln x + | --------- dt,
5667 : | t
5668 : -
5669 : 0
5670 : x
5671 : -
5672 : | sin t
5673 : Si(x) = | ----- dt
5674 : | t
5675 : -
5676 : 0
5677 :
5678 : where eul = 0.57721566490153286061 is Euler's constant.
5679 : The integrals are approximated by rational functions.
5680 : For x > 8 auxiliary functions f(x) and g(x) are employed
5681 : such that
5682 :
5683 : Ci(x) = f(x) sin(x) - g(x) cos(x)
5684 : Si(x) = pi/2 - f(x) cos(x) - g(x) sin(x)
5685 :
5686 :
5687 : ACCURACY:
5688 : Test interval = [0,50].
5689 : Absolute error, except relative when > 1:
5690 : arithmetic function # trials peak rms
5691 : IEEE Si 30000 4.4e-16 7.3e-17
5692 : IEEE Ci 30000 6.9e-16 5.1e-17
5693 :
5694 : Cephes Math Library Release 2.1: January, 1989
5695 : Copyright 1984, 1987, 1989 by Stephen L. Moshier
5696 : *************************************************************************/
5697 0 : void sinecosineintegrals(double x,
5698 : double* si,
5699 : double* ci,
5700 : ae_state *_state)
5701 : {
5702 : double z;
5703 : double c;
5704 : double s;
5705 : double f;
5706 : double g;
5707 : ae_int_t sg;
5708 : double sn;
5709 : double sd;
5710 : double cn;
5711 : double cd;
5712 : double fn;
5713 : double fd;
5714 : double gn;
5715 : double gd;
5716 :
5717 0 : *si = 0;
5718 0 : *ci = 0;
5719 :
5720 0 : if( ae_fp_less(x,(double)(0)) )
5721 : {
5722 0 : sg = -1;
5723 0 : x = -x;
5724 : }
5725 : else
5726 : {
5727 0 : sg = 0;
5728 : }
5729 0 : if( ae_fp_eq(x,(double)(0)) )
5730 : {
5731 0 : *si = (double)(0);
5732 0 : *ci = -ae_maxrealnumber;
5733 0 : return;
5734 : }
5735 0 : if( ae_fp_greater(x,1.0E9) )
5736 : {
5737 0 : *si = 1.570796326794896619-ae_cos(x, _state)/x;
5738 0 : *ci = ae_sin(x, _state)/x;
5739 0 : return;
5740 : }
5741 0 : if( ae_fp_less_eq(x,(double)(4)) )
5742 : {
5743 0 : z = x*x;
5744 0 : sn = -8.39167827910303881427E-11;
5745 0 : sn = sn*z+4.62591714427012837309E-8;
5746 0 : sn = sn*z-9.75759303843632795789E-6;
5747 0 : sn = sn*z+9.76945438170435310816E-4;
5748 0 : sn = sn*z-4.13470316229406538752E-2;
5749 0 : sn = sn*z+1.00000000000000000302E0;
5750 0 : sd = 2.03269266195951942049E-12;
5751 0 : sd = sd*z+1.27997891179943299903E-9;
5752 0 : sd = sd*z+4.41827842801218905784E-7;
5753 0 : sd = sd*z+9.96412122043875552487E-5;
5754 0 : sd = sd*z+1.42085239326149893930E-2;
5755 0 : sd = sd*z+9.99999999999999996984E-1;
5756 0 : s = x*sn/sd;
5757 0 : cn = 2.02524002389102268789E-11;
5758 0 : cn = cn*z-1.35249504915790756375E-8;
5759 0 : cn = cn*z+3.59325051419993077021E-6;
5760 0 : cn = cn*z-4.74007206873407909465E-4;
5761 0 : cn = cn*z+2.89159652607555242092E-2;
5762 0 : cn = cn*z-1.00000000000000000080E0;
5763 0 : cd = 4.07746040061880559506E-12;
5764 0 : cd = cd*z+3.06780997581887812692E-9;
5765 0 : cd = cd*z+1.23210355685883423679E-6;
5766 0 : cd = cd*z+3.17442024775032769882E-4;
5767 0 : cd = cd*z+5.10028056236446052392E-2;
5768 0 : cd = cd*z+4.00000000000000000080E0;
5769 0 : c = z*cn/cd;
5770 0 : if( sg!=0 )
5771 : {
5772 0 : s = -s;
5773 : }
5774 0 : *si = s;
5775 0 : *ci = 0.57721566490153286061+ae_log(x, _state)+c;
5776 0 : return;
5777 : }
5778 0 : s = ae_sin(x, _state);
5779 0 : c = ae_cos(x, _state);
5780 0 : z = 1.0/(x*x);
5781 0 : if( ae_fp_less(x,(double)(8)) )
5782 : {
5783 0 : fn = 4.23612862892216586994E0;
5784 0 : fn = fn*z+5.45937717161812843388E0;
5785 0 : fn = fn*z+1.62083287701538329132E0;
5786 0 : fn = fn*z+1.67006611831323023771E-1;
5787 0 : fn = fn*z+6.81020132472518137426E-3;
5788 0 : fn = fn*z+1.08936580650328664411E-4;
5789 0 : fn = fn*z+5.48900223421373614008E-7;
5790 0 : fd = 1.00000000000000000000E0;
5791 0 : fd = fd*z+8.16496634205391016773E0;
5792 0 : fd = fd*z+7.30828822505564552187E0;
5793 0 : fd = fd*z+1.86792257950184183883E0;
5794 0 : fd = fd*z+1.78792052963149907262E-1;
5795 0 : fd = fd*z+7.01710668322789753610E-3;
5796 0 : fd = fd*z+1.10034357153915731354E-4;
5797 0 : fd = fd*z+5.48900252756255700982E-7;
5798 0 : f = fn/(x*fd);
5799 0 : gn = 8.71001698973114191777E-2;
5800 0 : gn = gn*z+6.11379109952219284151E-1;
5801 0 : gn = gn*z+3.97180296392337498885E-1;
5802 0 : gn = gn*z+7.48527737628469092119E-2;
5803 0 : gn = gn*z+5.38868681462177273157E-3;
5804 0 : gn = gn*z+1.61999794598934024525E-4;
5805 0 : gn = gn*z+1.97963874140963632189E-6;
5806 0 : gn = gn*z+7.82579040744090311069E-9;
5807 0 : gd = 1.00000000000000000000E0;
5808 0 : gd = gd*z+1.64402202413355338886E0;
5809 0 : gd = gd*z+6.66296701268987968381E-1;
5810 0 : gd = gd*z+9.88771761277688796203E-2;
5811 0 : gd = gd*z+6.22396345441768420760E-3;
5812 0 : gd = gd*z+1.73221081474177119497E-4;
5813 0 : gd = gd*z+2.02659182086343991969E-6;
5814 0 : gd = gd*z+7.82579218933534490868E-9;
5815 0 : g = z*gn/gd;
5816 : }
5817 : else
5818 : {
5819 0 : fn = 4.55880873470465315206E-1;
5820 0 : fn = fn*z+7.13715274100146711374E-1;
5821 0 : fn = fn*z+1.60300158222319456320E-1;
5822 0 : fn = fn*z+1.16064229408124407915E-2;
5823 0 : fn = fn*z+3.49556442447859055605E-4;
5824 0 : fn = fn*z+4.86215430826454749482E-6;
5825 0 : fn = fn*z+3.20092790091004902806E-8;
5826 0 : fn = fn*z+9.41779576128512936592E-11;
5827 0 : fn = fn*z+9.70507110881952024631E-14;
5828 0 : fd = 1.00000000000000000000E0;
5829 0 : fd = fd*z+9.17463611873684053703E-1;
5830 0 : fd = fd*z+1.78685545332074536321E-1;
5831 0 : fd = fd*z+1.22253594771971293032E-2;
5832 0 : fd = fd*z+3.58696481881851580297E-4;
5833 0 : fd = fd*z+4.92435064317881464393E-6;
5834 0 : fd = fd*z+3.21956939101046018377E-8;
5835 0 : fd = fd*z+9.43720590350276732376E-11;
5836 0 : fd = fd*z+9.70507110881952025725E-14;
5837 0 : f = fn/(x*fd);
5838 0 : gn = 6.97359953443276214934E-1;
5839 0 : gn = gn*z+3.30410979305632063225E-1;
5840 0 : gn = gn*z+3.84878767649974295920E-2;
5841 0 : gn = gn*z+1.71718239052347903558E-3;
5842 0 : gn = gn*z+3.48941165502279436777E-5;
5843 0 : gn = gn*z+3.47131167084116673800E-7;
5844 0 : gn = gn*z+1.70404452782044526189E-9;
5845 0 : gn = gn*z+3.85945925430276600453E-12;
5846 0 : gn = gn*z+3.14040098946363334640E-15;
5847 0 : gd = 1.00000000000000000000E0;
5848 0 : gd = gd*z+1.68548898811011640017E0;
5849 0 : gd = gd*z+4.87852258695304967486E-1;
5850 0 : gd = gd*z+4.67913194259625806320E-2;
5851 0 : gd = gd*z+1.90284426674399523638E-3;
5852 0 : gd = gd*z+3.68475504442561108162E-5;
5853 0 : gd = gd*z+3.57043223443740838771E-7;
5854 0 : gd = gd*z+1.72693748966316146736E-9;
5855 0 : gd = gd*z+3.87830166023954706752E-12;
5856 0 : gd = gd*z+3.14040098946363335242E-15;
5857 0 : g = z*gn/gd;
5858 : }
5859 0 : *si = 1.570796326794896619-f*c-g*s;
5860 0 : if( sg!=0 )
5861 : {
5862 0 : *si = -*si;
5863 : }
5864 0 : *ci = f*s-g*c;
5865 : }
5866 :
5867 :
5868 : /*************************************************************************
5869 : Hyperbolic sine and cosine integrals
5870 :
5871 : Approximates the integrals
5872 :
5873 : x
5874 : -
5875 : | | cosh t - 1
5876 : Chi(x) = eul + ln x + | ----------- dt,
5877 : | | t
5878 : -
5879 : 0
5880 :
5881 : x
5882 : -
5883 : | | sinh t
5884 : Shi(x) = | ------ dt
5885 : | | t
5886 : -
5887 : 0
5888 :
5889 : where eul = 0.57721566490153286061 is Euler's constant.
5890 : The integrals are evaluated by power series for x < 8
5891 : and by Chebyshev expansions for x between 8 and 88.
5892 : For large x, both functions approach exp(x)/2x.
5893 : Arguments greater than 88 in magnitude return MAXNUM.
5894 :
5895 :
5896 : ACCURACY:
5897 :
5898 : Test interval 0 to 88.
5899 : Relative error:
5900 : arithmetic function # trials peak rms
5901 : IEEE Shi 30000 6.9e-16 1.6e-16
5902 : Absolute error, except relative when |Chi| > 1:
5903 : IEEE Chi 30000 8.4e-16 1.4e-16
5904 :
5905 : Cephes Math Library Release 2.8: June, 2000
5906 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
5907 : *************************************************************************/
5908 0 : void hyperbolicsinecosineintegrals(double x,
5909 : double* shi,
5910 : double* chi,
5911 : ae_state *_state)
5912 : {
5913 : double k;
5914 : double z;
5915 : double c;
5916 : double s;
5917 : double a;
5918 : ae_int_t sg;
5919 : double b0;
5920 : double b1;
5921 : double b2;
5922 :
5923 0 : *shi = 0;
5924 0 : *chi = 0;
5925 :
5926 0 : if( ae_fp_less(x,(double)(0)) )
5927 : {
5928 0 : sg = -1;
5929 0 : x = -x;
5930 : }
5931 : else
5932 : {
5933 0 : sg = 0;
5934 : }
5935 0 : if( ae_fp_eq(x,(double)(0)) )
5936 : {
5937 0 : *shi = (double)(0);
5938 0 : *chi = -ae_maxrealnumber;
5939 0 : return;
5940 : }
5941 0 : if( ae_fp_less(x,8.0) )
5942 : {
5943 0 : z = x*x;
5944 0 : a = 1.0;
5945 0 : s = 1.0;
5946 0 : c = 0.0;
5947 0 : k = 2.0;
5948 0 : do
5949 : {
5950 0 : a = a*z/k;
5951 0 : c = c+a/k;
5952 0 : k = k+1.0;
5953 0 : a = a/k;
5954 0 : s = s+a/k;
5955 0 : k = k+1.0;
5956 : }
5957 0 : while(ae_fp_greater_eq(ae_fabs(a/s, _state),ae_machineepsilon));
5958 0 : s = s*x;
5959 : }
5960 : else
5961 : {
5962 0 : if( ae_fp_less(x,18.0) )
5963 : {
5964 0 : a = (576.0/x-52.0)/10.0;
5965 0 : k = ae_exp(x, _state)/x;
5966 0 : b0 = 1.83889230173399459482E-17;
5967 0 : b1 = 0.0;
5968 0 : trigintegrals_chebiterationshichi(a, -9.55485532279655569575E-17, &b0, &b1, &b2, _state);
5969 0 : trigintegrals_chebiterationshichi(a, 2.04326105980879882648E-16, &b0, &b1, &b2, _state);
5970 0 : trigintegrals_chebiterationshichi(a, 1.09896949074905343022E-15, &b0, &b1, &b2, _state);
5971 0 : trigintegrals_chebiterationshichi(a, -1.31313534344092599234E-14, &b0, &b1, &b2, _state);
5972 0 : trigintegrals_chebiterationshichi(a, 5.93976226264314278932E-14, &b0, &b1, &b2, _state);
5973 0 : trigintegrals_chebiterationshichi(a, -3.47197010497749154755E-14, &b0, &b1, &b2, _state);
5974 0 : trigintegrals_chebiterationshichi(a, -1.40059764613117131000E-12, &b0, &b1, &b2, _state);
5975 0 : trigintegrals_chebiterationshichi(a, 9.49044626224223543299E-12, &b0, &b1, &b2, _state);
5976 0 : trigintegrals_chebiterationshichi(a, -1.61596181145435454033E-11, &b0, &b1, &b2, _state);
5977 0 : trigintegrals_chebiterationshichi(a, -1.77899784436430310321E-10, &b0, &b1, &b2, _state);
5978 0 : trigintegrals_chebiterationshichi(a, 1.35455469767246947469E-9, &b0, &b1, &b2, _state);
5979 0 : trigintegrals_chebiterationshichi(a, -1.03257121792819495123E-9, &b0, &b1, &b2, _state);
5980 0 : trigintegrals_chebiterationshichi(a, -3.56699611114982536845E-8, &b0, &b1, &b2, _state);
5981 0 : trigintegrals_chebiterationshichi(a, 1.44818877384267342057E-7, &b0, &b1, &b2, _state);
5982 0 : trigintegrals_chebiterationshichi(a, 7.82018215184051295296E-7, &b0, &b1, &b2, _state);
5983 0 : trigintegrals_chebiterationshichi(a, -5.39919118403805073710E-6, &b0, &b1, &b2, _state);
5984 0 : trigintegrals_chebiterationshichi(a, -3.12458202168959833422E-5, &b0, &b1, &b2, _state);
5985 0 : trigintegrals_chebiterationshichi(a, 8.90136741950727517826E-5, &b0, &b1, &b2, _state);
5986 0 : trigintegrals_chebiterationshichi(a, 2.02558474743846862168E-3, &b0, &b1, &b2, _state);
5987 0 : trigintegrals_chebiterationshichi(a, 2.96064440855633256972E-2, &b0, &b1, &b2, _state);
5988 0 : trigintegrals_chebiterationshichi(a, 1.11847751047257036625E0, &b0, &b1, &b2, _state);
5989 0 : s = k*0.5*(b0-b2);
5990 0 : b0 = -8.12435385225864036372E-18;
5991 0 : b1 = 0.0;
5992 0 : trigintegrals_chebiterationshichi(a, 2.17586413290339214377E-17, &b0, &b1, &b2, _state);
5993 0 : trigintegrals_chebiterationshichi(a, 5.22624394924072204667E-17, &b0, &b1, &b2, _state);
5994 0 : trigintegrals_chebiterationshichi(a, -9.48812110591690559363E-16, &b0, &b1, &b2, _state);
5995 0 : trigintegrals_chebiterationshichi(a, 5.35546311647465209166E-15, &b0, &b1, &b2, _state);
5996 0 : trigintegrals_chebiterationshichi(a, -1.21009970113732918701E-14, &b0, &b1, &b2, _state);
5997 0 : trigintegrals_chebiterationshichi(a, -6.00865178553447437951E-14, &b0, &b1, &b2, _state);
5998 0 : trigintegrals_chebiterationshichi(a, 7.16339649156028587775E-13, &b0, &b1, &b2, _state);
5999 0 : trigintegrals_chebiterationshichi(a, -2.93496072607599856104E-12, &b0, &b1, &b2, _state);
6000 0 : trigintegrals_chebiterationshichi(a, -1.40359438136491256904E-12, &b0, &b1, &b2, _state);
6001 0 : trigintegrals_chebiterationshichi(a, 8.76302288609054966081E-11, &b0, &b1, &b2, _state);
6002 0 : trigintegrals_chebiterationshichi(a, -4.40092476213282340617E-10, &b0, &b1, &b2, _state);
6003 0 : trigintegrals_chebiterationshichi(a, -1.87992075640569295479E-10, &b0, &b1, &b2, _state);
6004 0 : trigintegrals_chebiterationshichi(a, 1.31458150989474594064E-8, &b0, &b1, &b2, _state);
6005 0 : trigintegrals_chebiterationshichi(a, -4.75513930924765465590E-8, &b0, &b1, &b2, _state);
6006 0 : trigintegrals_chebiterationshichi(a, -2.21775018801848880741E-7, &b0, &b1, &b2, _state);
6007 0 : trigintegrals_chebiterationshichi(a, 1.94635531373272490962E-6, &b0, &b1, &b2, _state);
6008 0 : trigintegrals_chebiterationshichi(a, 4.33505889257316408893E-6, &b0, &b1, &b2, _state);
6009 0 : trigintegrals_chebiterationshichi(a, -6.13387001076494349496E-5, &b0, &b1, &b2, _state);
6010 0 : trigintegrals_chebiterationshichi(a, -3.13085477492997465138E-4, &b0, &b1, &b2, _state);
6011 0 : trigintegrals_chebiterationshichi(a, 4.97164789823116062801E-4, &b0, &b1, &b2, _state);
6012 0 : trigintegrals_chebiterationshichi(a, 2.64347496031374526641E-2, &b0, &b1, &b2, _state);
6013 0 : trigintegrals_chebiterationshichi(a, 1.11446150876699213025E0, &b0, &b1, &b2, _state);
6014 0 : c = k*0.5*(b0-b2);
6015 : }
6016 : else
6017 : {
6018 0 : if( ae_fp_less_eq(x,88.0) )
6019 : {
6020 0 : a = (6336.0/x-212.0)/70.0;
6021 0 : k = ae_exp(x, _state)/x;
6022 0 : b0 = -1.05311574154850938805E-17;
6023 0 : b1 = 0.0;
6024 0 : trigintegrals_chebiterationshichi(a, 2.62446095596355225821E-17, &b0, &b1, &b2, _state);
6025 0 : trigintegrals_chebiterationshichi(a, 8.82090135625368160657E-17, &b0, &b1, &b2, _state);
6026 0 : trigintegrals_chebiterationshichi(a, -3.38459811878103047136E-16, &b0, &b1, &b2, _state);
6027 0 : trigintegrals_chebiterationshichi(a, -8.30608026366935789136E-16, &b0, &b1, &b2, _state);
6028 0 : trigintegrals_chebiterationshichi(a, 3.93397875437050071776E-15, &b0, &b1, &b2, _state);
6029 0 : trigintegrals_chebiterationshichi(a, 1.01765565969729044505E-14, &b0, &b1, &b2, _state);
6030 0 : trigintegrals_chebiterationshichi(a, -4.21128170307640802703E-14, &b0, &b1, &b2, _state);
6031 0 : trigintegrals_chebiterationshichi(a, -1.60818204519802480035E-13, &b0, &b1, &b2, _state);
6032 0 : trigintegrals_chebiterationshichi(a, 3.34714954175994481761E-13, &b0, &b1, &b2, _state);
6033 0 : trigintegrals_chebiterationshichi(a, 2.72600352129153073807E-12, &b0, &b1, &b2, _state);
6034 0 : trigintegrals_chebiterationshichi(a, 1.66894954752839083608E-12, &b0, &b1, &b2, _state);
6035 0 : trigintegrals_chebiterationshichi(a, -3.49278141024730899554E-11, &b0, &b1, &b2, _state);
6036 0 : trigintegrals_chebiterationshichi(a, -1.58580661666482709598E-10, &b0, &b1, &b2, _state);
6037 0 : trigintegrals_chebiterationshichi(a, -1.79289437183355633342E-10, &b0, &b1, &b2, _state);
6038 0 : trigintegrals_chebiterationshichi(a, 1.76281629144264523277E-9, &b0, &b1, &b2, _state);
6039 0 : trigintegrals_chebiterationshichi(a, 1.69050228879421288846E-8, &b0, &b1, &b2, _state);
6040 0 : trigintegrals_chebiterationshichi(a, 1.25391771228487041649E-7, &b0, &b1, &b2, _state);
6041 0 : trigintegrals_chebiterationshichi(a, 1.16229947068677338732E-6, &b0, &b1, &b2, _state);
6042 0 : trigintegrals_chebiterationshichi(a, 1.61038260117376323993E-5, &b0, &b1, &b2, _state);
6043 0 : trigintegrals_chebiterationshichi(a, 3.49810375601053973070E-4, &b0, &b1, &b2, _state);
6044 0 : trigintegrals_chebiterationshichi(a, 1.28478065259647610779E-2, &b0, &b1, &b2, _state);
6045 0 : trigintegrals_chebiterationshichi(a, 1.03665722588798326712E0, &b0, &b1, &b2, _state);
6046 0 : s = k*0.5*(b0-b2);
6047 0 : b0 = 8.06913408255155572081E-18;
6048 0 : b1 = 0.0;
6049 0 : trigintegrals_chebiterationshichi(a, -2.08074168180148170312E-17, &b0, &b1, &b2, _state);
6050 0 : trigintegrals_chebiterationshichi(a, -5.98111329658272336816E-17, &b0, &b1, &b2, _state);
6051 0 : trigintegrals_chebiterationshichi(a, 2.68533951085945765591E-16, &b0, &b1, &b2, _state);
6052 0 : trigintegrals_chebiterationshichi(a, 4.52313941698904694774E-16, &b0, &b1, &b2, _state);
6053 0 : trigintegrals_chebiterationshichi(a, -3.10734917335299464535E-15, &b0, &b1, &b2, _state);
6054 0 : trigintegrals_chebiterationshichi(a, -4.42823207332531972288E-15, &b0, &b1, &b2, _state);
6055 0 : trigintegrals_chebiterationshichi(a, 3.49639695410806959872E-14, &b0, &b1, &b2, _state);
6056 0 : trigintegrals_chebiterationshichi(a, 6.63406731718911586609E-14, &b0, &b1, &b2, _state);
6057 0 : trigintegrals_chebiterationshichi(a, -3.71902448093119218395E-13, &b0, &b1, &b2, _state);
6058 0 : trigintegrals_chebiterationshichi(a, -1.27135418132338309016E-12, &b0, &b1, &b2, _state);
6059 0 : trigintegrals_chebiterationshichi(a, 2.74851141935315395333E-12, &b0, &b1, &b2, _state);
6060 0 : trigintegrals_chebiterationshichi(a, 2.33781843985453438400E-11, &b0, &b1, &b2, _state);
6061 0 : trigintegrals_chebiterationshichi(a, 2.71436006377612442764E-11, &b0, &b1, &b2, _state);
6062 0 : trigintegrals_chebiterationshichi(a, -2.56600180000355990529E-10, &b0, &b1, &b2, _state);
6063 0 : trigintegrals_chebiterationshichi(a, -1.61021375163803438552E-9, &b0, &b1, &b2, _state);
6064 0 : trigintegrals_chebiterationshichi(a, -4.72543064876271773512E-9, &b0, &b1, &b2, _state);
6065 0 : trigintegrals_chebiterationshichi(a, -3.00095178028681682282E-9, &b0, &b1, &b2, _state);
6066 0 : trigintegrals_chebiterationshichi(a, 7.79387474390914922337E-8, &b0, &b1, &b2, _state);
6067 0 : trigintegrals_chebiterationshichi(a, 1.06942765566401507066E-6, &b0, &b1, &b2, _state);
6068 0 : trigintegrals_chebiterationshichi(a, 1.59503164802313196374E-5, &b0, &b1, &b2, _state);
6069 0 : trigintegrals_chebiterationshichi(a, 3.49592575153777996871E-4, &b0, &b1, &b2, _state);
6070 0 : trigintegrals_chebiterationshichi(a, 1.28475387530065247392E-2, &b0, &b1, &b2, _state);
6071 0 : trigintegrals_chebiterationshichi(a, 1.03665693917934275131E0, &b0, &b1, &b2, _state);
6072 0 : c = k*0.5*(b0-b2);
6073 : }
6074 : else
6075 : {
6076 0 : if( sg!=0 )
6077 : {
6078 0 : *shi = -ae_maxrealnumber;
6079 : }
6080 : else
6081 : {
6082 0 : *shi = ae_maxrealnumber;
6083 : }
6084 0 : *chi = ae_maxrealnumber;
6085 0 : return;
6086 : }
6087 : }
6088 : }
6089 0 : if( sg!=0 )
6090 : {
6091 0 : s = -s;
6092 : }
6093 0 : *shi = s;
6094 0 : *chi = 0.57721566490153286061+ae_log(x, _state)+c;
6095 : }
6096 :
6097 :
6098 0 : static void trigintegrals_chebiterationshichi(double x,
6099 : double c,
6100 : double* b0,
6101 : double* b1,
6102 : double* b2,
6103 : ae_state *_state)
6104 : {
6105 :
6106 :
6107 0 : *b2 = *b1;
6108 0 : *b1 = *b0;
6109 0 : *b0 = x*(*b1)-(*b2)+c;
6110 0 : }
6111 :
6112 :
6113 : #endif
6114 : #if defined(AE_COMPILE_POISSONDISTR) || !defined(AE_PARTIAL_BUILD)
6115 :
6116 :
6117 : /*************************************************************************
6118 : Poisson distribution
6119 :
6120 : Returns the sum of the first k+1 terms of the Poisson
6121 : distribution:
6122 :
6123 : k j
6124 : -- -m m
6125 : > e --
6126 : -- j!
6127 : j=0
6128 :
6129 : The terms are not summed directly; instead the incomplete
6130 : gamma integral is employed, according to the relation
6131 :
6132 : y = pdtr( k, m ) = igamc( k+1, m ).
6133 :
6134 : The arguments must both be positive.
6135 : ACCURACY:
6136 :
6137 : See incomplete gamma function
6138 :
6139 : Cephes Math Library Release 2.8: June, 2000
6140 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
6141 : *************************************************************************/
6142 0 : double poissondistribution(ae_int_t k, double m, ae_state *_state)
6143 : {
6144 : double result;
6145 :
6146 :
6147 0 : ae_assert(k>=0&&ae_fp_greater(m,(double)(0)), "Domain error in PoissonDistribution", _state);
6148 0 : result = incompletegammac((double)(k+1), m, _state);
6149 0 : return result;
6150 : }
6151 :
6152 :
6153 : /*************************************************************************
6154 : Complemented Poisson distribution
6155 :
6156 : Returns the sum of the terms k+1 to infinity of the Poisson
6157 : distribution:
6158 :
6159 : inf. j
6160 : -- -m m
6161 : > e --
6162 : -- j!
6163 : j=k+1
6164 :
6165 : The terms are not summed directly; instead the incomplete
6166 : gamma integral is employed, according to the formula
6167 :
6168 : y = pdtrc( k, m ) = igam( k+1, m ).
6169 :
6170 : The arguments must both be positive.
6171 :
6172 : ACCURACY:
6173 :
6174 : See incomplete gamma function
6175 :
6176 : Cephes Math Library Release 2.8: June, 2000
6177 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
6178 : *************************************************************************/
6179 0 : double poissoncdistribution(ae_int_t k, double m, ae_state *_state)
6180 : {
6181 : double result;
6182 :
6183 :
6184 0 : ae_assert(k>=0&&ae_fp_greater(m,(double)(0)), "Domain error in PoissonDistributionC", _state);
6185 0 : result = incompletegamma((double)(k+1), m, _state);
6186 0 : return result;
6187 : }
6188 :
6189 :
6190 : /*************************************************************************
6191 : Inverse Poisson distribution
6192 :
6193 : Finds the Poisson variable x such that the integral
6194 : from 0 to x of the Poisson density is equal to the
6195 : given probability y.
6196 :
6197 : This is accomplished using the inverse gamma integral
6198 : function and the relation
6199 :
6200 : m = igami( k+1, y ).
6201 :
6202 : ACCURACY:
6203 :
6204 : See inverse incomplete gamma function
6205 :
6206 : Cephes Math Library Release 2.8: June, 2000
6207 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
6208 : *************************************************************************/
6209 0 : double invpoissondistribution(ae_int_t k, double y, ae_state *_state)
6210 : {
6211 : double result;
6212 :
6213 :
6214 0 : ae_assert((k>=0&&ae_fp_greater_eq(y,(double)(0)))&&ae_fp_less(y,(double)(1)), "Domain error in InvPoissonDistribution", _state);
6215 0 : result = invincompletegammac((double)(k+1), y, _state);
6216 0 : return result;
6217 : }
6218 :
6219 :
6220 : #endif
6221 : #if defined(AE_COMPILE_BESSEL) || !defined(AE_PARTIAL_BUILD)
6222 :
6223 :
6224 : /*************************************************************************
6225 : Bessel function of order zero
6226 :
6227 : Returns Bessel function of order zero of the argument.
6228 :
6229 : The domain is divided into the intervals [0, 5] and
6230 : (5, infinity). In the first interval the following rational
6231 : approximation is used:
6232 :
6233 :
6234 : 2 2
6235 : (w - r ) (w - r ) P (w) / Q (w)
6236 : 1 2 3 8
6237 :
6238 : 2
6239 : where w = x and the two r's are zeros of the function.
6240 :
6241 : In the second interval, the Hankel asymptotic expansion
6242 : is employed with two rational functions of degree 6/6
6243 : and 7/7.
6244 :
6245 : ACCURACY:
6246 :
6247 : Absolute error:
6248 : arithmetic domain # trials peak rms
6249 : IEEE 0, 30 60000 4.2e-16 1.1e-16
6250 :
6251 : Cephes Math Library Release 2.8: June, 2000
6252 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
6253 : *************************************************************************/
6254 0 : double besselj0(double x, ae_state *_state)
6255 : {
6256 : double xsq;
6257 : double nn;
6258 : double pzero;
6259 : double qzero;
6260 : double p1;
6261 : double q1;
6262 : double result;
6263 :
6264 :
6265 0 : if( ae_fp_less(x,(double)(0)) )
6266 : {
6267 0 : x = -x;
6268 : }
6269 0 : if( ae_fp_greater(x,8.0) )
6270 : {
6271 0 : bessel_besselasympt0(x, &pzero, &qzero, _state);
6272 0 : nn = x-ae_pi/4;
6273 0 : result = ae_sqrt(2/ae_pi/x, _state)*(pzero*ae_cos(nn, _state)-qzero*ae_sin(nn, _state));
6274 0 : return result;
6275 : }
6276 0 : xsq = ae_sqr(x, _state);
6277 0 : p1 = 26857.86856980014981415848441;
6278 0 : p1 = -40504123.71833132706360663322+xsq*p1;
6279 0 : p1 = 25071582855.36881945555156435+xsq*p1;
6280 0 : p1 = -8085222034853.793871199468171+xsq*p1;
6281 0 : p1 = 1434354939140344.111664316553+xsq*p1;
6282 0 : p1 = -136762035308817138.6865416609+xsq*p1;
6283 0 : p1 = 6382059341072356562.289432465+xsq*p1;
6284 0 : p1 = -117915762910761053603.8440800+xsq*p1;
6285 0 : p1 = 493378725179413356181.6813446+xsq*p1;
6286 0 : q1 = 1.0;
6287 0 : q1 = 1363.063652328970604442810507+xsq*q1;
6288 0 : q1 = 1114636.098462985378182402543+xsq*q1;
6289 0 : q1 = 669998767.2982239671814028660+xsq*q1;
6290 0 : q1 = 312304311494.1213172572469442+xsq*q1;
6291 0 : q1 = 112775673967979.8507056031594+xsq*q1;
6292 0 : q1 = 30246356167094626.98627330784+xsq*q1;
6293 0 : q1 = 5428918384092285160.200195092+xsq*q1;
6294 0 : q1 = 493378725179413356211.3278438+xsq*q1;
6295 0 : result = p1/q1;
6296 0 : return result;
6297 : }
6298 :
6299 :
6300 : /*************************************************************************
6301 : Bessel function of order one
6302 :
6303 : Returns Bessel function of order one of the argument.
6304 :
6305 : The domain is divided into the intervals [0, 8] and
6306 : (8, infinity). In the first interval a 24 term Chebyshev
6307 : expansion is used. In the second, the asymptotic
6308 : trigonometric representation is employed using two
6309 : rational functions of degree 5/5.
6310 :
6311 : ACCURACY:
6312 :
6313 : Absolute error:
6314 : arithmetic domain # trials peak rms
6315 : IEEE 0, 30 30000 2.6e-16 1.1e-16
6316 :
6317 : Cephes Math Library Release 2.8: June, 2000
6318 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
6319 : *************************************************************************/
6320 0 : double besselj1(double x, ae_state *_state)
6321 : {
6322 : double s;
6323 : double xsq;
6324 : double nn;
6325 : double pzero;
6326 : double qzero;
6327 : double p1;
6328 : double q1;
6329 : double result;
6330 :
6331 :
6332 0 : s = (double)(ae_sign(x, _state));
6333 0 : if( ae_fp_less(x,(double)(0)) )
6334 : {
6335 0 : x = -x;
6336 : }
6337 0 : if( ae_fp_greater(x,8.0) )
6338 : {
6339 0 : bessel_besselasympt1(x, &pzero, &qzero, _state);
6340 0 : nn = x-3*ae_pi/4;
6341 0 : result = ae_sqrt(2/ae_pi/x, _state)*(pzero*ae_cos(nn, _state)-qzero*ae_sin(nn, _state));
6342 0 : if( ae_fp_less(s,(double)(0)) )
6343 : {
6344 0 : result = -result;
6345 : }
6346 0 : return result;
6347 : }
6348 0 : xsq = ae_sqr(x, _state);
6349 0 : p1 = 2701.122710892323414856790990;
6350 0 : p1 = -4695753.530642995859767162166+xsq*p1;
6351 0 : p1 = 3413234182.301700539091292655+xsq*p1;
6352 0 : p1 = -1322983480332.126453125473247+xsq*p1;
6353 0 : p1 = 290879526383477.5409737601689+xsq*p1;
6354 0 : p1 = -35888175699101060.50743641413+xsq*p1;
6355 0 : p1 = 2316433580634002297.931815435+xsq*p1;
6356 0 : p1 = -66721065689249162980.20941484+xsq*p1;
6357 0 : p1 = 581199354001606143928.050809+xsq*p1;
6358 0 : q1 = 1.0;
6359 0 : q1 = 1606.931573481487801970916749+xsq*q1;
6360 0 : q1 = 1501793.594998585505921097578+xsq*q1;
6361 0 : q1 = 1013863514.358673989967045588+xsq*q1;
6362 0 : q1 = 524371026216.7649715406728642+xsq*q1;
6363 0 : q1 = 208166122130760.7351240184229+xsq*q1;
6364 0 : q1 = 60920613989175217.46105196863+xsq*q1;
6365 0 : q1 = 11857707121903209998.37113348+xsq*q1;
6366 0 : q1 = 1162398708003212287858.529400+xsq*q1;
6367 0 : result = s*x*p1/q1;
6368 0 : return result;
6369 : }
6370 :
6371 :
6372 : /*************************************************************************
6373 : Bessel function of integer order
6374 :
6375 : Returns Bessel function of order n, where n is a
6376 : (possibly negative) integer.
6377 :
6378 : The ratio of jn(x) to j0(x) is computed by backward
6379 : recurrence. First the ratio jn/jn-1 is found by a
6380 : continued fraction expansion. Then the recurrence
6381 : relating successive orders is applied until j0 or j1 is
6382 : reached.
6383 :
6384 : If n = 0 or 1 the routine for j0 or j1 is called
6385 : directly.
6386 :
6387 : ACCURACY:
6388 :
6389 : Absolute error:
6390 : arithmetic range # trials peak rms
6391 : IEEE 0, 30 5000 4.4e-16 7.9e-17
6392 :
6393 :
6394 : Not suitable for large n or x. Use jv() (fractional order) instead.
6395 :
6396 : Cephes Math Library Release 2.8: June, 2000
6397 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
6398 : *************************************************************************/
6399 0 : double besseljn(ae_int_t n, double x, ae_state *_state)
6400 : {
6401 : double pkm2;
6402 : double pkm1;
6403 : double pk;
6404 : double xk;
6405 : double r;
6406 : double ans;
6407 : ae_int_t k;
6408 : ae_int_t sg;
6409 : double result;
6410 :
6411 :
6412 0 : if( n<0 )
6413 : {
6414 0 : n = -n;
6415 0 : if( n%2==0 )
6416 : {
6417 0 : sg = 1;
6418 : }
6419 : else
6420 : {
6421 0 : sg = -1;
6422 : }
6423 : }
6424 : else
6425 : {
6426 0 : sg = 1;
6427 : }
6428 0 : if( ae_fp_less(x,(double)(0)) )
6429 : {
6430 0 : if( n%2!=0 )
6431 : {
6432 0 : sg = -sg;
6433 : }
6434 0 : x = -x;
6435 : }
6436 0 : if( n==0 )
6437 : {
6438 0 : result = sg*besselj0(x, _state);
6439 0 : return result;
6440 : }
6441 0 : if( n==1 )
6442 : {
6443 0 : result = sg*besselj1(x, _state);
6444 0 : return result;
6445 : }
6446 0 : if( n==2 )
6447 : {
6448 0 : if( ae_fp_eq(x,(double)(0)) )
6449 : {
6450 0 : result = (double)(0);
6451 : }
6452 : else
6453 : {
6454 0 : result = sg*(2.0*besselj1(x, _state)/x-besselj0(x, _state));
6455 : }
6456 0 : return result;
6457 : }
6458 0 : if( ae_fp_less(x,ae_machineepsilon) )
6459 : {
6460 0 : result = (double)(0);
6461 0 : return result;
6462 : }
6463 0 : k = 53;
6464 0 : pk = (double)(2*(n+k));
6465 0 : ans = pk;
6466 0 : xk = x*x;
6467 0 : do
6468 : {
6469 0 : pk = pk-2.0;
6470 0 : ans = pk-xk/ans;
6471 0 : k = k-1;
6472 : }
6473 0 : while(k!=0);
6474 0 : ans = x/ans;
6475 0 : pk = 1.0;
6476 0 : pkm1 = 1.0/ans;
6477 0 : k = n-1;
6478 0 : r = (double)(2*k);
6479 0 : do
6480 : {
6481 0 : pkm2 = (pkm1*r-pk*x)/x;
6482 0 : pk = pkm1;
6483 0 : pkm1 = pkm2;
6484 0 : r = r-2.0;
6485 0 : k = k-1;
6486 : }
6487 0 : while(k!=0);
6488 0 : if( ae_fp_greater(ae_fabs(pk, _state),ae_fabs(pkm1, _state)) )
6489 : {
6490 0 : ans = besselj1(x, _state)/pk;
6491 : }
6492 : else
6493 : {
6494 0 : ans = besselj0(x, _state)/pkm1;
6495 : }
6496 0 : result = sg*ans;
6497 0 : return result;
6498 : }
6499 :
6500 :
6501 : /*************************************************************************
6502 : Bessel function of the second kind, order zero
6503 :
6504 : Returns Bessel function of the second kind, of order
6505 : zero, of the argument.
6506 :
6507 : The domain is divided into the intervals [0, 5] and
6508 : (5, infinity). In the first interval a rational approximation
6509 : R(x) is employed to compute
6510 : y0(x) = R(x) + 2 * log(x) * j0(x) / PI.
6511 : Thus a call to j0() is required.
6512 :
6513 : In the second interval, the Hankel asymptotic expansion
6514 : is employed with two rational functions of degree 6/6
6515 : and 7/7.
6516 :
6517 :
6518 :
6519 : ACCURACY:
6520 :
6521 : Absolute error, when y0(x) < 1; else relative error:
6522 :
6523 : arithmetic domain # trials peak rms
6524 : IEEE 0, 30 30000 1.3e-15 1.6e-16
6525 :
6526 : Cephes Math Library Release 2.8: June, 2000
6527 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
6528 : *************************************************************************/
6529 0 : double bessely0(double x, ae_state *_state)
6530 : {
6531 : double nn;
6532 : double xsq;
6533 : double pzero;
6534 : double qzero;
6535 : double p4;
6536 : double q4;
6537 : double result;
6538 :
6539 :
6540 0 : if( ae_fp_greater(x,8.0) )
6541 : {
6542 0 : bessel_besselasympt0(x, &pzero, &qzero, _state);
6543 0 : nn = x-ae_pi/4;
6544 0 : result = ae_sqrt(2/ae_pi/x, _state)*(pzero*ae_sin(nn, _state)+qzero*ae_cos(nn, _state));
6545 0 : return result;
6546 : }
6547 0 : xsq = ae_sqr(x, _state);
6548 0 : p4 = -41370.35497933148554125235152;
6549 0 : p4 = 59152134.65686889654273830069+xsq*p4;
6550 0 : p4 = -34363712229.79040378171030138+xsq*p4;
6551 0 : p4 = 10255208596863.94284509167421+xsq*p4;
6552 0 : p4 = -1648605817185729.473122082537+xsq*p4;
6553 0 : p4 = 137562431639934407.8571335453+xsq*p4;
6554 0 : p4 = -5247065581112764941.297350814+xsq*p4;
6555 0 : p4 = 65874732757195549259.99402049+xsq*p4;
6556 0 : p4 = -27502866786291095837.01933175+xsq*p4;
6557 0 : q4 = 1.0;
6558 0 : q4 = 1282.452772478993804176329391+xsq*q4;
6559 0 : q4 = 1001702.641288906265666651753+xsq*q4;
6560 0 : q4 = 579512264.0700729537480087915+xsq*q4;
6561 0 : q4 = 261306575504.1081249568482092+xsq*q4;
6562 0 : q4 = 91620380340751.85262489147968+xsq*q4;
6563 0 : q4 = 23928830434997818.57439356652+xsq*q4;
6564 0 : q4 = 4192417043410839973.904769661+xsq*q4;
6565 0 : q4 = 372645883898616588198.9980+xsq*q4;
6566 0 : result = p4/q4+2/ae_pi*besselj0(x, _state)*ae_log(x, _state);
6567 0 : return result;
6568 : }
6569 :
6570 :
6571 : /*************************************************************************
6572 : Bessel function of second kind of order one
6573 :
6574 : Returns Bessel function of the second kind of order one
6575 : of the argument.
6576 :
6577 : The domain is divided into the intervals [0, 8] and
6578 : (8, infinity). In the first interval a 25 term Chebyshev
6579 : expansion is used, and a call to j1() is required.
6580 : In the second, the asymptotic trigonometric representation
6581 : is employed using two rational functions of degree 5/5.
6582 :
6583 : ACCURACY:
6584 :
6585 : Absolute error:
6586 : arithmetic domain # trials peak rms
6587 : IEEE 0, 30 30000 1.0e-15 1.3e-16
6588 :
6589 : Cephes Math Library Release 2.8: June, 2000
6590 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
6591 : *************************************************************************/
6592 0 : double bessely1(double x, ae_state *_state)
6593 : {
6594 : double nn;
6595 : double xsq;
6596 : double pzero;
6597 : double qzero;
6598 : double p4;
6599 : double q4;
6600 : double result;
6601 :
6602 :
6603 0 : if( ae_fp_greater(x,8.0) )
6604 : {
6605 0 : bessel_besselasympt1(x, &pzero, &qzero, _state);
6606 0 : nn = x-3*ae_pi/4;
6607 0 : result = ae_sqrt(2/ae_pi/x, _state)*(pzero*ae_sin(nn, _state)+qzero*ae_cos(nn, _state));
6608 0 : return result;
6609 : }
6610 0 : xsq = ae_sqr(x, _state);
6611 0 : p4 = -2108847.540133123652824139923;
6612 0 : p4 = 3639488548.124002058278999428+xsq*p4;
6613 0 : p4 = -2580681702194.450950541426399+xsq*p4;
6614 0 : p4 = 956993023992168.3481121552788+xsq*p4;
6615 0 : p4 = -196588746272214065.8820322248+xsq*p4;
6616 0 : p4 = 21931073399177975921.11427556+xsq*p4;
6617 0 : p4 = -1212297555414509577913.561535+xsq*p4;
6618 0 : p4 = 26554738314348543268942.48968+xsq*p4;
6619 0 : p4 = -99637534243069222259967.44354+xsq*p4;
6620 0 : q4 = 1.0;
6621 0 : q4 = 1612.361029677000859332072312+xsq*q4;
6622 0 : q4 = 1563282.754899580604737366452+xsq*q4;
6623 0 : q4 = 1128686837.169442121732366891+xsq*q4;
6624 0 : q4 = 646534088126.5275571961681500+xsq*q4;
6625 0 : q4 = 297663212564727.6729292742282+xsq*q4;
6626 0 : q4 = 108225825940881955.2553850180+xsq*q4;
6627 0 : q4 = 29549879358971486742.90758119+xsq*q4;
6628 0 : q4 = 5435310377188854170800.653097+xsq*q4;
6629 0 : q4 = 508206736694124324531442.4152+xsq*q4;
6630 0 : result = x*p4/q4+2/ae_pi*(besselj1(x, _state)*ae_log(x, _state)-1/x);
6631 0 : return result;
6632 : }
6633 :
6634 :
6635 : /*************************************************************************
6636 : Bessel function of second kind of integer order
6637 :
6638 : Returns Bessel function of order n, where n is a
6639 : (possibly negative) integer.
6640 :
6641 : The function is evaluated by forward recurrence on
6642 : n, starting with values computed by the routines
6643 : y0() and y1().
6644 :
6645 : If n = 0 or 1 the routine for y0 or y1 is called
6646 : directly.
6647 :
6648 : ACCURACY:
6649 : Absolute error, except relative
6650 : when y > 1:
6651 : arithmetic domain # trials peak rms
6652 : IEEE 0, 30 30000 3.4e-15 4.3e-16
6653 :
6654 : Cephes Math Library Release 2.8: June, 2000
6655 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
6656 : *************************************************************************/
6657 0 : double besselyn(ae_int_t n, double x, ae_state *_state)
6658 : {
6659 : ae_int_t i;
6660 : double a;
6661 : double b;
6662 : double tmp;
6663 : double s;
6664 : double result;
6665 :
6666 :
6667 0 : s = (double)(1);
6668 0 : if( n<0 )
6669 : {
6670 0 : n = -n;
6671 0 : if( n%2!=0 )
6672 : {
6673 0 : s = (double)(-1);
6674 : }
6675 : }
6676 0 : if( n==0 )
6677 : {
6678 0 : result = bessely0(x, _state);
6679 0 : return result;
6680 : }
6681 0 : if( n==1 )
6682 : {
6683 0 : result = s*bessely1(x, _state);
6684 0 : return result;
6685 : }
6686 0 : a = bessely0(x, _state);
6687 0 : b = bessely1(x, _state);
6688 0 : for(i=1; i<=n-1; i++)
6689 : {
6690 0 : tmp = b;
6691 0 : b = 2*i/x*b-a;
6692 0 : a = tmp;
6693 : }
6694 0 : result = s*b;
6695 0 : return result;
6696 : }
6697 :
6698 :
6699 : /*************************************************************************
6700 : Modified Bessel function of order zero
6701 :
6702 : Returns modified Bessel function of order zero of the
6703 : argument.
6704 :
6705 : The function is defined as i0(x) = j0( ix ).
6706 :
6707 : The range is partitioned into the two intervals [0,8] and
6708 : (8, infinity). Chebyshev polynomial expansions are employed
6709 : in each interval.
6710 :
6711 : ACCURACY:
6712 :
6713 : Relative error:
6714 : arithmetic domain # trials peak rms
6715 : IEEE 0,30 30000 5.8e-16 1.4e-16
6716 :
6717 : Cephes Math Library Release 2.8: June, 2000
6718 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
6719 : *************************************************************************/
6720 0 : double besseli0(double x, ae_state *_state)
6721 : {
6722 : double y;
6723 : double v;
6724 : double z;
6725 : double b0;
6726 : double b1;
6727 : double b2;
6728 : double result;
6729 :
6730 :
6731 0 : if( ae_fp_less(x,(double)(0)) )
6732 : {
6733 0 : x = -x;
6734 : }
6735 0 : if( ae_fp_less_eq(x,8.0) )
6736 : {
6737 0 : y = x/2.0-2.0;
6738 0 : bessel_besselmfirstcheb(-4.41534164647933937950E-18, &b0, &b1, &b2, _state);
6739 0 : bessel_besselmnextcheb(y, 3.33079451882223809783E-17, &b0, &b1, &b2, _state);
6740 0 : bessel_besselmnextcheb(y, -2.43127984654795469359E-16, &b0, &b1, &b2, _state);
6741 0 : bessel_besselmnextcheb(y, 1.71539128555513303061E-15, &b0, &b1, &b2, _state);
6742 0 : bessel_besselmnextcheb(y, -1.16853328779934516808E-14, &b0, &b1, &b2, _state);
6743 0 : bessel_besselmnextcheb(y, 7.67618549860493561688E-14, &b0, &b1, &b2, _state);
6744 0 : bessel_besselmnextcheb(y, -4.85644678311192946090E-13, &b0, &b1, &b2, _state);
6745 0 : bessel_besselmnextcheb(y, 2.95505266312963983461E-12, &b0, &b1, &b2, _state);
6746 0 : bessel_besselmnextcheb(y, -1.72682629144155570723E-11, &b0, &b1, &b2, _state);
6747 0 : bessel_besselmnextcheb(y, 9.67580903537323691224E-11, &b0, &b1, &b2, _state);
6748 0 : bessel_besselmnextcheb(y, -5.18979560163526290666E-10, &b0, &b1, &b2, _state);
6749 0 : bessel_besselmnextcheb(y, 2.65982372468238665035E-9, &b0, &b1, &b2, _state);
6750 0 : bessel_besselmnextcheb(y, -1.30002500998624804212E-8, &b0, &b1, &b2, _state);
6751 0 : bessel_besselmnextcheb(y, 6.04699502254191894932E-8, &b0, &b1, &b2, _state);
6752 0 : bessel_besselmnextcheb(y, -2.67079385394061173391E-7, &b0, &b1, &b2, _state);
6753 0 : bessel_besselmnextcheb(y, 1.11738753912010371815E-6, &b0, &b1, &b2, _state);
6754 0 : bessel_besselmnextcheb(y, -4.41673835845875056359E-6, &b0, &b1, &b2, _state);
6755 0 : bessel_besselmnextcheb(y, 1.64484480707288970893E-5, &b0, &b1, &b2, _state);
6756 0 : bessel_besselmnextcheb(y, -5.75419501008210370398E-5, &b0, &b1, &b2, _state);
6757 0 : bessel_besselmnextcheb(y, 1.88502885095841655729E-4, &b0, &b1, &b2, _state);
6758 0 : bessel_besselmnextcheb(y, -5.76375574538582365885E-4, &b0, &b1, &b2, _state);
6759 0 : bessel_besselmnextcheb(y, 1.63947561694133579842E-3, &b0, &b1, &b2, _state);
6760 0 : bessel_besselmnextcheb(y, -4.32430999505057594430E-3, &b0, &b1, &b2, _state);
6761 0 : bessel_besselmnextcheb(y, 1.05464603945949983183E-2, &b0, &b1, &b2, _state);
6762 0 : bessel_besselmnextcheb(y, -2.37374148058994688156E-2, &b0, &b1, &b2, _state);
6763 0 : bessel_besselmnextcheb(y, 4.93052842396707084878E-2, &b0, &b1, &b2, _state);
6764 0 : bessel_besselmnextcheb(y, -9.49010970480476444210E-2, &b0, &b1, &b2, _state);
6765 0 : bessel_besselmnextcheb(y, 1.71620901522208775349E-1, &b0, &b1, &b2, _state);
6766 0 : bessel_besselmnextcheb(y, -3.04682672343198398683E-1, &b0, &b1, &b2, _state);
6767 0 : bessel_besselmnextcheb(y, 6.76795274409476084995E-1, &b0, &b1, &b2, _state);
6768 0 : v = 0.5*(b0-b2);
6769 0 : result = ae_exp(x, _state)*v;
6770 0 : return result;
6771 : }
6772 0 : z = 32.0/x-2.0;
6773 0 : bessel_besselmfirstcheb(-7.23318048787475395456E-18, &b0, &b1, &b2, _state);
6774 0 : bessel_besselmnextcheb(z, -4.83050448594418207126E-18, &b0, &b1, &b2, _state);
6775 0 : bessel_besselmnextcheb(z, 4.46562142029675999901E-17, &b0, &b1, &b2, _state);
6776 0 : bessel_besselmnextcheb(z, 3.46122286769746109310E-17, &b0, &b1, &b2, _state);
6777 0 : bessel_besselmnextcheb(z, -2.82762398051658348494E-16, &b0, &b1, &b2, _state);
6778 0 : bessel_besselmnextcheb(z, -3.42548561967721913462E-16, &b0, &b1, &b2, _state);
6779 0 : bessel_besselmnextcheb(z, 1.77256013305652638360E-15, &b0, &b1, &b2, _state);
6780 0 : bessel_besselmnextcheb(z, 3.81168066935262242075E-15, &b0, &b1, &b2, _state);
6781 0 : bessel_besselmnextcheb(z, -9.55484669882830764870E-15, &b0, &b1, &b2, _state);
6782 0 : bessel_besselmnextcheb(z, -4.15056934728722208663E-14, &b0, &b1, &b2, _state);
6783 0 : bessel_besselmnextcheb(z, 1.54008621752140982691E-14, &b0, &b1, &b2, _state);
6784 0 : bessel_besselmnextcheb(z, 3.85277838274214270114E-13, &b0, &b1, &b2, _state);
6785 0 : bessel_besselmnextcheb(z, 7.18012445138366623367E-13, &b0, &b1, &b2, _state);
6786 0 : bessel_besselmnextcheb(z, -1.79417853150680611778E-12, &b0, &b1, &b2, _state);
6787 0 : bessel_besselmnextcheb(z, -1.32158118404477131188E-11, &b0, &b1, &b2, _state);
6788 0 : bessel_besselmnextcheb(z, -3.14991652796324136454E-11, &b0, &b1, &b2, _state);
6789 0 : bessel_besselmnextcheb(z, 1.18891471078464383424E-11, &b0, &b1, &b2, _state);
6790 0 : bessel_besselmnextcheb(z, 4.94060238822496958910E-10, &b0, &b1, &b2, _state);
6791 0 : bessel_besselmnextcheb(z, 3.39623202570838634515E-9, &b0, &b1, &b2, _state);
6792 0 : bessel_besselmnextcheb(z, 2.26666899049817806459E-8, &b0, &b1, &b2, _state);
6793 0 : bessel_besselmnextcheb(z, 2.04891858946906374183E-7, &b0, &b1, &b2, _state);
6794 0 : bessel_besselmnextcheb(z, 2.89137052083475648297E-6, &b0, &b1, &b2, _state);
6795 0 : bessel_besselmnextcheb(z, 6.88975834691682398426E-5, &b0, &b1, &b2, _state);
6796 0 : bessel_besselmnextcheb(z, 3.36911647825569408990E-3, &b0, &b1, &b2, _state);
6797 0 : bessel_besselmnextcheb(z, 8.04490411014108831608E-1, &b0, &b1, &b2, _state);
6798 0 : v = 0.5*(b0-b2);
6799 0 : result = ae_exp(x, _state)*v/ae_sqrt(x, _state);
6800 0 : return result;
6801 : }
6802 :
6803 :
6804 : /*************************************************************************
6805 : Modified Bessel function of order one
6806 :
6807 : Returns modified Bessel function of order one of the
6808 : argument.
6809 :
6810 : The function is defined as i1(x) = -i j1( ix ).
6811 :
6812 : The range is partitioned into the two intervals [0,8] and
6813 : (8, infinity). Chebyshev polynomial expansions are employed
6814 : in each interval.
6815 :
6816 : ACCURACY:
6817 :
6818 : Relative error:
6819 : arithmetic domain # trials peak rms
6820 : IEEE 0, 30 30000 1.9e-15 2.1e-16
6821 :
6822 : Cephes Math Library Release 2.8: June, 2000
6823 : Copyright 1985, 1987, 2000 by Stephen L. Moshier
6824 : *************************************************************************/
6825 0 : double besseli1(double x, ae_state *_state)
6826 : {
6827 : double y;
6828 : double z;
6829 : double v;
6830 : double b0;
6831 : double b1;
6832 : double b2;
6833 : double result;
6834 :
6835 :
6836 0 : z = ae_fabs(x, _state);
6837 0 : if( ae_fp_less_eq(z,8.0) )
6838 : {
6839 0 : y = z/2.0-2.0;
6840 0 : bessel_besselm1firstcheb(2.77791411276104639959E-18, &b0, &b1, &b2, _state);
6841 0 : bessel_besselm1nextcheb(y, -2.11142121435816608115E-17, &b0, &b1, &b2, _state);
6842 0 : bessel_besselm1nextcheb(y, 1.55363195773620046921E-16, &b0, &b1, &b2, _state);
6843 0 : bessel_besselm1nextcheb(y, -1.10559694773538630805E-15, &b0, &b1, &b2, _state);
6844 0 : bessel_besselm1nextcheb(y, 7.60068429473540693410E-15, &b0, &b1, &b2, _state);
6845 0 : bessel_besselm1nextcheb(y, -5.04218550472791168711E-14, &b0, &b1, &b2, _state);
6846 0 : bessel_besselm1nextcheb(y, 3.22379336594557470981E-13, &b0, &b1, &b2, _state);
6847 0 : bessel_besselm1nextcheb(y, -1.98397439776494371520E-12, &b0, &b1, &b2, _state);
6848 0 : bessel_besselm1nextcheb(y, 1.17361862988909016308E-11, &b0, &b1, &b2, _state);
6849 0 : bessel_besselm1nextcheb(y, -6.66348972350202774223E-11, &b0, &b1, &b2, _state);
6850 0 : bessel_besselm1nextcheb(y, 3.62559028155211703701E-10, &b0, &b1, &b2, _state);
6851 0 : bessel_besselm1nextcheb(y, -1.88724975172282928790E-9, &b0, &b1, &b2, _state);
6852 0 : bessel_besselm1nextcheb(y, 9.38153738649577178388E-9, &b0, &b1, &b2, _state);
6853 0 : bessel_besselm1nextcheb(y, -4.44505912879632808065E-8, &b0, &b1, &b2, _state);
6854 0 : bessel_besselm1nextcheb(y, 2.00329475355213526229E-7, &b0, &b1, &b2, _state);
6855 0 : bessel_besselm1nextcheb(y, -8.56872026469545474066E-7, &b0, &b1, &b2, _state);
6856 0 : bessel_besselm1nextcheb(y, 3.47025130813767847674E-6, &b0, &b1, &b2, _state);
6857 0 : bessel_besselm1nextcheb(y, -1.32731636560394358279E-5, &b0, &b1, &b2, _state);
6858 0 : bessel_besselm1nextcheb(y, 4.78156510755005422638E-5, &b0, &b1, &b2, _state);
6859 0 : bessel_besselm1nextcheb(y, -1.61760815825896745588E-4, &b0, &b1, &b2, _state);
6860 0 : bessel_besselm1nextcheb(y, 5.12285956168575772895E-4, &b0, &b1, &b2, _state);
6861 0 : bessel_besselm1nextcheb(y, -1.51357245063125314899E-3, &b0, &b1, &b2, _state);
6862 0 : bessel_besselm1nextcheb(y, 4.15642294431288815669E-3, &b0, &b1, &b2, _state);
6863 0 : bessel_besselm1nextcheb(y, -1.05640848946261981558E-2, &b0, &b1, &b2, _state);
6864 0 : bessel_besselm1nextcheb(y, 2.47264490306265168283E-2, &b0, &b1, &b2, _state);
6865 0 : bessel_besselm1nextcheb(y, -5.29459812080949914269E-2, &b0, &b1, &b2, _state);
6866 0 : bessel_besselm1nextcheb(y, 1.02643658689847095384E-1, &b0, &b1, &b2, _state);
6867 0 : bessel_besselm1nextcheb(y, -1.76416518357834055153E-1, &b0, &b1, &b2, _state);
6868 0 : bessel_besselm1nextcheb(y, 2.52587186443633654823E-1, &b0, &b1, &b2, _state);
6869 0 : v = 0.5*(b0-b2);
6870 0 : z = v*z*ae_exp(z, _state);
6871 : }
6872 : else
6873 : {
6874 0 : y = 32.0/z-2.0;
6875 0 : bessel_besselm1firstcheb(7.51729631084210481353E-18, &b0, &b1, &b2, _state);
6876 0 : bessel_besselm1nextcheb(y, 4.41434832307170791151E-18, &b0, &b1, &b2, _state);
6877 0 : bessel_besselm1nextcheb(y, -4.65030536848935832153E-17, &b0, &b1, &b2, _state);
6878 0 : bessel_besselm1nextcheb(y, -3.20952592199342395980E-17, &b0, &b1, &b2, _state);
6879 0 : bessel_besselm1nextcheb(y, 2.96262899764595013876E-16, &b0, &b1, &b2, _state);
6880 0 : bessel_besselm1nextcheb(y, 3.30820231092092828324E-16, &b0, &b1, &b2, _state);
6881 0 : bessel_besselm1nextcheb(y, -1.88035477551078244854E-15, &b0, &b1, &b2, _state);
6882 0 : bessel_besselm1nextcheb(y, -3.81440307243700780478E-15, &b0, &b1, &b2, _state);
6883 0 : bessel_besselm1nextcheb(y, 1.04202769841288027642E-14, &b0, &b1, &b2, _state);
6884 0 : bessel_besselm1nextcheb(y, 4.27244001671195135429E-14, &b0, &b1, &b2, _state);
6885 0 : bessel_besselm1nextcheb(y, -2.10154184277266431302E-14, &b0, &b1, &b2, _state);
6886 0 : bessel_besselm1nextcheb(y, -4.08355111109219731823E-13, &b0, &b1, &b2, _state);
6887 0 : bessel_besselm1nextcheb(y, -7.19855177624590851209E-13, &b0, &b1, &b2, _state);
6888 0 : bessel_besselm1nextcheb(y, 2.03562854414708950722E-12, &b0, &b1, &b2, _state);
6889 0 : bessel_besselm1nextcheb(y, 1.41258074366137813316E-11, &b0, &b1, &b2, _state);
6890 0 : bessel_besselm1nextcheb(y, 3.25260358301548823856E-11, &b0, &b1, &b2, _state);
6891 0 : bessel_besselm1nextcheb(y, -1.89749581235054123450E-11, &b0, &b1, &b2, _state);
6892 0 : bessel_besselm1nextcheb(y, -5.58974346219658380687E-10, &b0, &b1, &b2, _state);
6893 0 : bessel_besselm1nextcheb(y, -3.83538038596423702205E-9, &b0, &b1, &b2, _state);
6894 0 : bessel_besselm1nextcheb(y, -2.63146884688951950684E-8, &b0, &b1, &b2, _state);
6895 0 : bessel_besselm1nextcheb(y, -2.51223623787020892529E-7, &b0, &b1, &b2, _state);
6896 0 : bessel_besselm1nextcheb(y, -3.88256480887769039346E-6, &b0, &b1, &b2, _state);
6897 0 : bessel_besselm1nextcheb(y, -1.10588938762623716291E-4, &b0, &b1, &b2, _state);
6898 0 : bessel_besselm1nextcheb(y, -9.76109749136146840777E-3, &b0, &b1, &b2, _state);
6899 0 : bessel_besselm1nextcheb(y, 7.78576235018280120474E-1, &b0, &b1, &b2, _state);
6900 0 : v = 0.5*(b0-b2);
6901 0 : z = v*ae_exp(z, _state)/ae_sqrt(z, _state);
6902 : }
6903 0 : if( ae_fp_less(x,(double)(0)) )
6904 : {
6905 0 : z = -z;
6906 : }
6907 0 : result = z;
6908 0 : return result;
6909 : }
6910 :
6911 :
6912 : /*************************************************************************
6913 : Modified Bessel function, second kind, order zero
6914 :
6915 : Returns modified Bessel function of the second kind
6916 : of order zero of the argument.
6917 :
6918 : The range is partitioned into the two intervals [0,8] and
6919 : (8, infinity). Chebyshev polynomial expansions are employed
6920 : in each interval.
6921 :
6922 : ACCURACY:
6923 :
6924 : Tested at 2000 random points between 0 and 8. Peak absolute
6925 : error (relative when K0 > 1) was 1.46e-14; rms, 4.26e-15.
6926 : Relative error:
6927 : arithmetic domain # trials peak rms
6928 : IEEE 0, 30 30000 1.2e-15 1.6e-16
6929 :
6930 : Cephes Math Library Release 2.8: June, 2000
6931 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
6932 : *************************************************************************/
6933 0 : double besselk0(double x, ae_state *_state)
6934 : {
6935 : double y;
6936 : double z;
6937 : double v;
6938 : double b0;
6939 : double b1;
6940 : double b2;
6941 : double result;
6942 :
6943 :
6944 0 : ae_assert(ae_fp_greater(x,(double)(0)), "Domain error in BesselK0: x<=0", _state);
6945 0 : if( ae_fp_less_eq(x,(double)(2)) )
6946 : {
6947 0 : y = x*x-2.0;
6948 0 : bessel_besselmfirstcheb(1.37446543561352307156E-16, &b0, &b1, &b2, _state);
6949 0 : bessel_besselmnextcheb(y, 4.25981614279661018399E-14, &b0, &b1, &b2, _state);
6950 0 : bessel_besselmnextcheb(y, 1.03496952576338420167E-11, &b0, &b1, &b2, _state);
6951 0 : bessel_besselmnextcheb(y, 1.90451637722020886025E-9, &b0, &b1, &b2, _state);
6952 0 : bessel_besselmnextcheb(y, 2.53479107902614945675E-7, &b0, &b1, &b2, _state);
6953 0 : bessel_besselmnextcheb(y, 2.28621210311945178607E-5, &b0, &b1, &b2, _state);
6954 0 : bessel_besselmnextcheb(y, 1.26461541144692592338E-3, &b0, &b1, &b2, _state);
6955 0 : bessel_besselmnextcheb(y, 3.59799365153615016266E-2, &b0, &b1, &b2, _state);
6956 0 : bessel_besselmnextcheb(y, 3.44289899924628486886E-1, &b0, &b1, &b2, _state);
6957 0 : bessel_besselmnextcheb(y, -5.35327393233902768720E-1, &b0, &b1, &b2, _state);
6958 0 : v = 0.5*(b0-b2);
6959 0 : v = v-ae_log(0.5*x, _state)*besseli0(x, _state);
6960 : }
6961 : else
6962 : {
6963 0 : z = 8.0/x-2.0;
6964 0 : bessel_besselmfirstcheb(5.30043377268626276149E-18, &b0, &b1, &b2, _state);
6965 0 : bessel_besselmnextcheb(z, -1.64758043015242134646E-17, &b0, &b1, &b2, _state);
6966 0 : bessel_besselmnextcheb(z, 5.21039150503902756861E-17, &b0, &b1, &b2, _state);
6967 0 : bessel_besselmnextcheb(z, -1.67823109680541210385E-16, &b0, &b1, &b2, _state);
6968 0 : bessel_besselmnextcheb(z, 5.51205597852431940784E-16, &b0, &b1, &b2, _state);
6969 0 : bessel_besselmnextcheb(z, -1.84859337734377901440E-15, &b0, &b1, &b2, _state);
6970 0 : bessel_besselmnextcheb(z, 6.34007647740507060557E-15, &b0, &b1, &b2, _state);
6971 0 : bessel_besselmnextcheb(z, -2.22751332699166985548E-14, &b0, &b1, &b2, _state);
6972 0 : bessel_besselmnextcheb(z, 8.03289077536357521100E-14, &b0, &b1, &b2, _state);
6973 0 : bessel_besselmnextcheb(z, -2.98009692317273043925E-13, &b0, &b1, &b2, _state);
6974 0 : bessel_besselmnextcheb(z, 1.14034058820847496303E-12, &b0, &b1, &b2, _state);
6975 0 : bessel_besselmnextcheb(z, -4.51459788337394416547E-12, &b0, &b1, &b2, _state);
6976 0 : bessel_besselmnextcheb(z, 1.85594911495471785253E-11, &b0, &b1, &b2, _state);
6977 0 : bessel_besselmnextcheb(z, -7.95748924447710747776E-11, &b0, &b1, &b2, _state);
6978 0 : bessel_besselmnextcheb(z, 3.57739728140030116597E-10, &b0, &b1, &b2, _state);
6979 0 : bessel_besselmnextcheb(z, -1.69753450938905987466E-9, &b0, &b1, &b2, _state);
6980 0 : bessel_besselmnextcheb(z, 8.57403401741422608519E-9, &b0, &b1, &b2, _state);
6981 0 : bessel_besselmnextcheb(z, -4.66048989768794782956E-8, &b0, &b1, &b2, _state);
6982 0 : bessel_besselmnextcheb(z, 2.76681363944501510342E-7, &b0, &b1, &b2, _state);
6983 0 : bessel_besselmnextcheb(z, -1.83175552271911948767E-6, &b0, &b1, &b2, _state);
6984 0 : bessel_besselmnextcheb(z, 1.39498137188764993662E-5, &b0, &b1, &b2, _state);
6985 0 : bessel_besselmnextcheb(z, -1.28495495816278026384E-4, &b0, &b1, &b2, _state);
6986 0 : bessel_besselmnextcheb(z, 1.56988388573005337491E-3, &b0, &b1, &b2, _state);
6987 0 : bessel_besselmnextcheb(z, -3.14481013119645005427E-2, &b0, &b1, &b2, _state);
6988 0 : bessel_besselmnextcheb(z, 2.44030308206595545468E0, &b0, &b1, &b2, _state);
6989 0 : v = 0.5*(b0-b2);
6990 0 : v = v*ae_exp(-x, _state)/ae_sqrt(x, _state);
6991 : }
6992 0 : result = v;
6993 0 : return result;
6994 : }
6995 :
6996 :
6997 : /*************************************************************************
6998 : Modified Bessel function, second kind, order one
6999 :
7000 : Computes the modified Bessel function of the second kind
7001 : of order one of the argument.
7002 :
7003 : The range is partitioned into the two intervals [0,2] and
7004 : (2, infinity). Chebyshev polynomial expansions are employed
7005 : in each interval.
7006 :
7007 : ACCURACY:
7008 :
7009 : Relative error:
7010 : arithmetic domain # trials peak rms
7011 : IEEE 0, 30 30000 1.2e-15 1.6e-16
7012 :
7013 : Cephes Math Library Release 2.8: June, 2000
7014 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
7015 : *************************************************************************/
7016 0 : double besselk1(double x, ae_state *_state)
7017 : {
7018 : double y;
7019 : double z;
7020 : double v;
7021 : double b0;
7022 : double b1;
7023 : double b2;
7024 : double result;
7025 :
7026 :
7027 0 : z = 0.5*x;
7028 0 : ae_assert(ae_fp_greater(z,(double)(0)), "Domain error in K1", _state);
7029 0 : if( ae_fp_less_eq(x,(double)(2)) )
7030 : {
7031 0 : y = x*x-2.0;
7032 0 : bessel_besselm1firstcheb(-7.02386347938628759343E-18, &b0, &b1, &b2, _state);
7033 0 : bessel_besselm1nextcheb(y, -2.42744985051936593393E-15, &b0, &b1, &b2, _state);
7034 0 : bessel_besselm1nextcheb(y, -6.66690169419932900609E-13, &b0, &b1, &b2, _state);
7035 0 : bessel_besselm1nextcheb(y, -1.41148839263352776110E-10, &b0, &b1, &b2, _state);
7036 0 : bessel_besselm1nextcheb(y, -2.21338763073472585583E-8, &b0, &b1, &b2, _state);
7037 0 : bessel_besselm1nextcheb(y, -2.43340614156596823496E-6, &b0, &b1, &b2, _state);
7038 0 : bessel_besselm1nextcheb(y, -1.73028895751305206302E-4, &b0, &b1, &b2, _state);
7039 0 : bessel_besselm1nextcheb(y, -6.97572385963986435018E-3, &b0, &b1, &b2, _state);
7040 0 : bessel_besselm1nextcheb(y, -1.22611180822657148235E-1, &b0, &b1, &b2, _state);
7041 0 : bessel_besselm1nextcheb(y, -3.53155960776544875667E-1, &b0, &b1, &b2, _state);
7042 0 : bessel_besselm1nextcheb(y, 1.52530022733894777053E0, &b0, &b1, &b2, _state);
7043 0 : v = 0.5*(b0-b2);
7044 0 : result = ae_log(z, _state)*besseli1(x, _state)+v/x;
7045 : }
7046 : else
7047 : {
7048 0 : y = 8.0/x-2.0;
7049 0 : bessel_besselm1firstcheb(-5.75674448366501715755E-18, &b0, &b1, &b2, _state);
7050 0 : bessel_besselm1nextcheb(y, 1.79405087314755922667E-17, &b0, &b1, &b2, _state);
7051 0 : bessel_besselm1nextcheb(y, -5.68946255844285935196E-17, &b0, &b1, &b2, _state);
7052 0 : bessel_besselm1nextcheb(y, 1.83809354436663880070E-16, &b0, &b1, &b2, _state);
7053 0 : bessel_besselm1nextcheb(y, -6.05704724837331885336E-16, &b0, &b1, &b2, _state);
7054 0 : bessel_besselm1nextcheb(y, 2.03870316562433424052E-15, &b0, &b1, &b2, _state);
7055 0 : bessel_besselm1nextcheb(y, -7.01983709041831346144E-15, &b0, &b1, &b2, _state);
7056 0 : bessel_besselm1nextcheb(y, 2.47715442448130437068E-14, &b0, &b1, &b2, _state);
7057 0 : bessel_besselm1nextcheb(y, -8.97670518232499435011E-14, &b0, &b1, &b2, _state);
7058 0 : bessel_besselm1nextcheb(y, 3.34841966607842919884E-13, &b0, &b1, &b2, _state);
7059 0 : bessel_besselm1nextcheb(y, -1.28917396095102890680E-12, &b0, &b1, &b2, _state);
7060 0 : bessel_besselm1nextcheb(y, 5.13963967348173025100E-12, &b0, &b1, &b2, _state);
7061 0 : bessel_besselm1nextcheb(y, -2.12996783842756842877E-11, &b0, &b1, &b2, _state);
7062 0 : bessel_besselm1nextcheb(y, 9.21831518760500529508E-11, &b0, &b1, &b2, _state);
7063 0 : bessel_besselm1nextcheb(y, -4.19035475934189648750E-10, &b0, &b1, &b2, _state);
7064 0 : bessel_besselm1nextcheb(y, 2.01504975519703286596E-9, &b0, &b1, &b2, _state);
7065 0 : bessel_besselm1nextcheb(y, -1.03457624656780970260E-8, &b0, &b1, &b2, _state);
7066 0 : bessel_besselm1nextcheb(y, 5.74108412545004946722E-8, &b0, &b1, &b2, _state);
7067 0 : bessel_besselm1nextcheb(y, -3.50196060308781257119E-7, &b0, &b1, &b2, _state);
7068 0 : bessel_besselm1nextcheb(y, 2.40648494783721712015E-6, &b0, &b1, &b2, _state);
7069 0 : bessel_besselm1nextcheb(y, -1.93619797416608296024E-5, &b0, &b1, &b2, _state);
7070 0 : bessel_besselm1nextcheb(y, 1.95215518471351631108E-4, &b0, &b1, &b2, _state);
7071 0 : bessel_besselm1nextcheb(y, -2.85781685962277938680E-3, &b0, &b1, &b2, _state);
7072 0 : bessel_besselm1nextcheb(y, 1.03923736576817238437E-1, &b0, &b1, &b2, _state);
7073 0 : bessel_besselm1nextcheb(y, 2.72062619048444266945E0, &b0, &b1, &b2, _state);
7074 0 : v = 0.5*(b0-b2);
7075 0 : result = ae_exp(-x, _state)*v/ae_sqrt(x, _state);
7076 : }
7077 0 : return result;
7078 : }
7079 :
7080 :
7081 : /*************************************************************************
7082 : Modified Bessel function, second kind, integer order
7083 :
7084 : Returns modified Bessel function of the second kind
7085 : of order n of the argument.
7086 :
7087 : The range is partitioned into the two intervals [0,9.55] and
7088 : (9.55, infinity). An ascending power series is used in the
7089 : low range, and an asymptotic expansion in the high range.
7090 :
7091 : ACCURACY:
7092 :
7093 : Relative error:
7094 : arithmetic domain # trials peak rms
7095 : IEEE 0,30 90000 1.8e-8 3.0e-10
7096 :
7097 : Error is high only near the crossover point x = 9.55
7098 : between the two expansions used.
7099 :
7100 : Cephes Math Library Release 2.8: June, 2000
7101 : Copyright 1984, 1987, 1988, 2000 by Stephen L. Moshier
7102 : *************************************************************************/
7103 0 : double besselkn(ae_int_t nn, double x, ae_state *_state)
7104 : {
7105 : double k;
7106 : double kf;
7107 : double nk1f;
7108 : double nkf;
7109 : double zn;
7110 : double t;
7111 : double s;
7112 : double z0;
7113 : double z;
7114 : double ans;
7115 : double fn;
7116 : double pn;
7117 : double pk;
7118 : double zmn;
7119 : double tlg;
7120 : double tox;
7121 : ae_int_t i;
7122 : ae_int_t n;
7123 : double eul;
7124 : double result;
7125 :
7126 :
7127 0 : eul = 5.772156649015328606065e-1;
7128 0 : if( nn<0 )
7129 : {
7130 0 : n = -nn;
7131 : }
7132 : else
7133 : {
7134 0 : n = nn;
7135 : }
7136 0 : ae_assert(n<=31, "Overflow in BesselKN", _state);
7137 0 : ae_assert(ae_fp_greater(x,(double)(0)), "Domain error in BesselKN", _state);
7138 0 : if( ae_fp_less_eq(x,9.55) )
7139 : {
7140 0 : ans = 0.0;
7141 0 : z0 = 0.25*x*x;
7142 0 : fn = 1.0;
7143 0 : pn = 0.0;
7144 0 : zmn = 1.0;
7145 0 : tox = 2.0/x;
7146 0 : if( n>0 )
7147 : {
7148 0 : pn = -eul;
7149 0 : k = 1.0;
7150 0 : for(i=1; i<=n-1; i++)
7151 : {
7152 0 : pn = pn+1.0/k;
7153 0 : k = k+1.0;
7154 0 : fn = fn*k;
7155 : }
7156 0 : zmn = tox;
7157 0 : if( n==1 )
7158 : {
7159 0 : ans = 1.0/x;
7160 : }
7161 : else
7162 : {
7163 0 : nk1f = fn/n;
7164 0 : kf = 1.0;
7165 0 : s = nk1f;
7166 0 : z = -z0;
7167 0 : zn = 1.0;
7168 0 : for(i=1; i<=n-1; i++)
7169 : {
7170 0 : nk1f = nk1f/(n-i);
7171 0 : kf = kf*i;
7172 0 : zn = zn*z;
7173 0 : t = nk1f*zn/kf;
7174 0 : s = s+t;
7175 0 : ae_assert(ae_fp_greater(ae_maxrealnumber-ae_fabs(t, _state),ae_fabs(s, _state)), "Overflow in BesselKN", _state);
7176 0 : ae_assert(!(ae_fp_greater(tox,1.0)&&ae_fp_less(ae_maxrealnumber/tox,zmn)), "Overflow in BesselKN", _state);
7177 0 : zmn = zmn*tox;
7178 : }
7179 0 : s = s*0.5;
7180 0 : t = ae_fabs(s, _state);
7181 0 : ae_assert(!(ae_fp_greater(zmn,1.0)&&ae_fp_less(ae_maxrealnumber/zmn,t)), "Overflow in BesselKN", _state);
7182 0 : ae_assert(!(ae_fp_greater(t,1.0)&&ae_fp_less(ae_maxrealnumber/t,zmn)), "Overflow in BesselKN", _state);
7183 0 : ans = s*zmn;
7184 : }
7185 : }
7186 0 : tlg = 2.0*ae_log(0.5*x, _state);
7187 0 : pk = -eul;
7188 0 : if( n==0 )
7189 : {
7190 0 : pn = pk;
7191 0 : t = 1.0;
7192 : }
7193 : else
7194 : {
7195 0 : pn = pn+1.0/n;
7196 0 : t = 1.0/fn;
7197 : }
7198 0 : s = (pk+pn-tlg)*t;
7199 0 : k = 1.0;
7200 0 : do
7201 : {
7202 0 : t = t*(z0/(k*(k+n)));
7203 0 : pk = pk+1.0/k;
7204 0 : pn = pn+1.0/(k+n);
7205 0 : s = s+(pk+pn-tlg)*t;
7206 0 : k = k+1.0;
7207 : }
7208 0 : while(ae_fp_greater(ae_fabs(t/s, _state),ae_machineepsilon));
7209 0 : s = 0.5*s/zmn;
7210 0 : if( n%2!=0 )
7211 : {
7212 0 : s = -s;
7213 : }
7214 0 : ans = ans+s;
7215 0 : result = ans;
7216 0 : return result;
7217 : }
7218 0 : if( ae_fp_greater(x,ae_log(ae_maxrealnumber, _state)) )
7219 : {
7220 0 : result = (double)(0);
7221 0 : return result;
7222 : }
7223 0 : k = (double)(n);
7224 0 : pn = 4.0*k*k;
7225 0 : pk = 1.0;
7226 0 : z0 = 8.0*x;
7227 0 : fn = 1.0;
7228 0 : t = 1.0;
7229 0 : s = t;
7230 0 : nkf = ae_maxrealnumber;
7231 0 : i = 0;
7232 0 : do
7233 : {
7234 0 : z = pn-pk*pk;
7235 0 : t = t*z/(fn*z0);
7236 0 : nk1f = ae_fabs(t, _state);
7237 0 : if( i>=n&&ae_fp_greater(nk1f,nkf) )
7238 : {
7239 0 : break;
7240 : }
7241 0 : nkf = nk1f;
7242 0 : s = s+t;
7243 0 : fn = fn+1.0;
7244 0 : pk = pk+2.0;
7245 0 : i = i+1;
7246 : }
7247 0 : while(ae_fp_greater(ae_fabs(t/s, _state),ae_machineepsilon));
7248 0 : result = ae_exp(-x, _state)*ae_sqrt(ae_pi/(2.0*x), _state)*s;
7249 0 : return result;
7250 : }
7251 :
7252 :
7253 : /*************************************************************************
7254 : Internal subroutine
7255 :
7256 : Cephes Math Library Release 2.8: June, 2000
7257 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
7258 : *************************************************************************/
7259 0 : static void bessel_besselmfirstcheb(double c,
7260 : double* b0,
7261 : double* b1,
7262 : double* b2,
7263 : ae_state *_state)
7264 : {
7265 :
7266 :
7267 0 : *b0 = c;
7268 0 : *b1 = 0.0;
7269 0 : *b2 = 0.0;
7270 0 : }
7271 :
7272 :
7273 : /*************************************************************************
7274 : Internal subroutine
7275 :
7276 : Cephes Math Library Release 2.8: June, 2000
7277 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
7278 : *************************************************************************/
7279 0 : static void bessel_besselmnextcheb(double x,
7280 : double c,
7281 : double* b0,
7282 : double* b1,
7283 : double* b2,
7284 : ae_state *_state)
7285 : {
7286 :
7287 :
7288 0 : *b2 = *b1;
7289 0 : *b1 = *b0;
7290 0 : *b0 = x*(*b1)-(*b2)+c;
7291 0 : }
7292 :
7293 :
7294 : /*************************************************************************
7295 : Internal subroutine
7296 :
7297 : Cephes Math Library Release 2.8: June, 2000
7298 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
7299 : *************************************************************************/
7300 0 : static void bessel_besselm1firstcheb(double c,
7301 : double* b0,
7302 : double* b1,
7303 : double* b2,
7304 : ae_state *_state)
7305 : {
7306 :
7307 :
7308 0 : *b0 = c;
7309 0 : *b1 = 0.0;
7310 0 : *b2 = 0.0;
7311 0 : }
7312 :
7313 :
7314 : /*************************************************************************
7315 : Internal subroutine
7316 :
7317 : Cephes Math Library Release 2.8: June, 2000
7318 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
7319 : *************************************************************************/
7320 0 : static void bessel_besselm1nextcheb(double x,
7321 : double c,
7322 : double* b0,
7323 : double* b1,
7324 : double* b2,
7325 : ae_state *_state)
7326 : {
7327 :
7328 :
7329 0 : *b2 = *b1;
7330 0 : *b1 = *b0;
7331 0 : *b0 = x*(*b1)-(*b2)+c;
7332 0 : }
7333 :
7334 :
7335 0 : static void bessel_besselasympt0(double x,
7336 : double* pzero,
7337 : double* qzero,
7338 : ae_state *_state)
7339 : {
7340 : double xsq;
7341 : double p2;
7342 : double q2;
7343 : double p3;
7344 : double q3;
7345 :
7346 0 : *pzero = 0;
7347 0 : *qzero = 0;
7348 :
7349 0 : xsq = 64.0/(x*x);
7350 0 : p2 = 0.0;
7351 0 : p2 = 2485.271928957404011288128951+xsq*p2;
7352 0 : p2 = 153982.6532623911470917825993+xsq*p2;
7353 0 : p2 = 2016135.283049983642487182349+xsq*p2;
7354 0 : p2 = 8413041.456550439208464315611+xsq*p2;
7355 0 : p2 = 12332384.76817638145232406055+xsq*p2;
7356 0 : p2 = 5393485.083869438325262122897+xsq*p2;
7357 0 : q2 = 1.0;
7358 0 : q2 = 2615.700736920839685159081813+xsq*q2;
7359 0 : q2 = 156001.7276940030940592769933+xsq*q2;
7360 0 : q2 = 2025066.801570134013891035236+xsq*q2;
7361 0 : q2 = 8426449.050629797331554404810+xsq*q2;
7362 0 : q2 = 12338310.22786324960844856182+xsq*q2;
7363 0 : q2 = 5393485.083869438325560444960+xsq*q2;
7364 0 : p3 = -0.0;
7365 0 : p3 = -4.887199395841261531199129300+xsq*p3;
7366 0 : p3 = -226.2630641933704113967255053+xsq*p3;
7367 0 : p3 = -2365.956170779108192723612816+xsq*p3;
7368 0 : p3 = -8239.066313485606568803548860+xsq*p3;
7369 0 : p3 = -10381.41698748464093880530341+xsq*p3;
7370 0 : p3 = -3984.617357595222463506790588+xsq*p3;
7371 0 : q3 = 1.0;
7372 0 : q3 = 408.7714673983499223402830260+xsq*q3;
7373 0 : q3 = 15704.89191515395519392882766+xsq*q3;
7374 0 : q3 = 156021.3206679291652539287109+xsq*q3;
7375 0 : q3 = 533291.3634216897168722255057+xsq*q3;
7376 0 : q3 = 666745.4239319826986004038103+xsq*q3;
7377 0 : q3 = 255015.5108860942382983170882+xsq*q3;
7378 0 : *pzero = p2/q2;
7379 0 : *qzero = 8*p3/q3/x;
7380 0 : }
7381 :
7382 :
7383 0 : static void bessel_besselasympt1(double x,
7384 : double* pzero,
7385 : double* qzero,
7386 : ae_state *_state)
7387 : {
7388 : double xsq;
7389 : double p2;
7390 : double q2;
7391 : double p3;
7392 : double q3;
7393 :
7394 0 : *pzero = 0;
7395 0 : *qzero = 0;
7396 :
7397 0 : xsq = 64.0/(x*x);
7398 0 : p2 = -1611.616644324610116477412898;
7399 0 : p2 = -109824.0554345934672737413139+xsq*p2;
7400 0 : p2 = -1523529.351181137383255105722+xsq*p2;
7401 0 : p2 = -6603373.248364939109255245434+xsq*p2;
7402 0 : p2 = -9942246.505077641195658377899+xsq*p2;
7403 0 : p2 = -4435757.816794127857114720794+xsq*p2;
7404 0 : q2 = 1.0;
7405 0 : q2 = -1455.009440190496182453565068+xsq*q2;
7406 0 : q2 = -107263.8599110382011903063867+xsq*q2;
7407 0 : q2 = -1511809.506634160881644546358+xsq*q2;
7408 0 : q2 = -6585339.479723087072826915069+xsq*q2;
7409 0 : q2 = -9934124.389934585658967556309+xsq*q2;
7410 0 : q2 = -4435757.816794127856828016962+xsq*q2;
7411 0 : p3 = 35.26513384663603218592175580;
7412 0 : p3 = 1706.375429020768002061283546+xsq*p3;
7413 0 : p3 = 18494.26287322386679652009819+xsq*p3;
7414 0 : p3 = 66178.83658127083517939992166+xsq*p3;
7415 0 : p3 = 85145.16067533570196555001171+xsq*p3;
7416 0 : p3 = 33220.91340985722351859704442+xsq*p3;
7417 0 : q3 = 1.0;
7418 0 : q3 = 863.8367769604990967475517183+xsq*q3;
7419 0 : q3 = 37890.22974577220264142952256+xsq*q3;
7420 0 : q3 = 400294.4358226697511708610813+xsq*q3;
7421 0 : q3 = 1419460.669603720892855755253+xsq*q3;
7422 0 : q3 = 1819458.042243997298924553839+xsq*q3;
7423 0 : q3 = 708712.8194102874357377502472+xsq*q3;
7424 0 : *pzero = p2/q2;
7425 0 : *qzero = 8*p3/q3/x;
7426 0 : }
7427 :
7428 :
7429 : #endif
7430 : #if defined(AE_COMPILE_IBETAF) || !defined(AE_PARTIAL_BUILD)
7431 :
7432 :
7433 : /*************************************************************************
7434 : Incomplete beta integral
7435 :
7436 : Returns incomplete beta integral of the arguments, evaluated
7437 : from zero to x. The function is defined as
7438 :
7439 : x
7440 : - -
7441 : | (a+b) | | a-1 b-1
7442 : ----------- | t (1-t) dt.
7443 : - - | |
7444 : | (a) | (b) -
7445 : 0
7446 :
7447 : The domain of definition is 0 <= x <= 1. In this
7448 : implementation a and b are restricted to positive values.
7449 : The integral from x to 1 may be obtained by the symmetry
7450 : relation
7451 :
7452 : 1 - incbet( a, b, x ) = incbet( b, a, 1-x ).
7453 :
7454 : The integral is evaluated by a continued fraction expansion
7455 : or, when b*x is small, by a power series.
7456 :
7457 : ACCURACY:
7458 :
7459 : Tested at uniformly distributed random points (a,b,x) with a and b
7460 : in "domain" and x between 0 and 1.
7461 : Relative error
7462 : arithmetic domain # trials peak rms
7463 : IEEE 0,5 10000 6.9e-15 4.5e-16
7464 : IEEE 0,85 250000 2.2e-13 1.7e-14
7465 : IEEE 0,1000 30000 5.3e-12 6.3e-13
7466 : IEEE 0,10000 250000 9.3e-11 7.1e-12
7467 : IEEE 0,100000 10000 8.7e-10 4.8e-11
7468 : Outputs smaller than the IEEE gradual underflow threshold
7469 : were excluded from these statistics.
7470 :
7471 : Cephes Math Library, Release 2.8: June, 2000
7472 : Copyright 1984, 1995, 2000 by Stephen L. Moshier
7473 : *************************************************************************/
7474 0 : double incompletebeta(double a, double b, double x, ae_state *_state)
7475 : {
7476 : double t;
7477 : double xc;
7478 : double w;
7479 : double y;
7480 : ae_int_t flag;
7481 : double sg;
7482 : double big;
7483 : double biginv;
7484 : double maxgam;
7485 : double minlog;
7486 : double maxlog;
7487 : double result;
7488 :
7489 :
7490 0 : big = 4.503599627370496e15;
7491 0 : biginv = 2.22044604925031308085e-16;
7492 0 : maxgam = 171.624376956302725;
7493 0 : minlog = ae_log(ae_minrealnumber, _state);
7494 0 : maxlog = ae_log(ae_maxrealnumber, _state);
7495 0 : ae_assert(ae_fp_greater(a,(double)(0))&&ae_fp_greater(b,(double)(0)), "Domain error in IncompleteBeta", _state);
7496 0 : ae_assert(ae_fp_greater_eq(x,(double)(0))&&ae_fp_less_eq(x,(double)(1)), "Domain error in IncompleteBeta", _state);
7497 0 : if( ae_fp_eq(x,(double)(0)) )
7498 : {
7499 0 : result = (double)(0);
7500 0 : return result;
7501 : }
7502 0 : if( ae_fp_eq(x,(double)(1)) )
7503 : {
7504 0 : result = (double)(1);
7505 0 : return result;
7506 : }
7507 0 : flag = 0;
7508 0 : if( ae_fp_less_eq(b*x,1.0)&&ae_fp_less_eq(x,0.95) )
7509 : {
7510 0 : result = ibetaf_incompletebetaps(a, b, x, maxgam, _state);
7511 0 : return result;
7512 : }
7513 0 : w = 1.0-x;
7514 0 : if( ae_fp_greater(x,a/(a+b)) )
7515 : {
7516 0 : flag = 1;
7517 0 : t = a;
7518 0 : a = b;
7519 0 : b = t;
7520 0 : xc = x;
7521 0 : x = w;
7522 : }
7523 : else
7524 : {
7525 0 : xc = w;
7526 : }
7527 0 : if( (flag==1&&ae_fp_less_eq(b*x,1.0))&&ae_fp_less_eq(x,0.95) )
7528 : {
7529 0 : t = ibetaf_incompletebetaps(a, b, x, maxgam, _state);
7530 0 : if( ae_fp_less_eq(t,ae_machineepsilon) )
7531 : {
7532 0 : result = 1.0-ae_machineepsilon;
7533 : }
7534 : else
7535 : {
7536 0 : result = 1.0-t;
7537 : }
7538 0 : return result;
7539 : }
7540 0 : y = x*(a+b-2.0)-(a-1.0);
7541 0 : if( ae_fp_less(y,0.0) )
7542 : {
7543 0 : w = ibetaf_incompletebetafe(a, b, x, big, biginv, _state);
7544 : }
7545 : else
7546 : {
7547 0 : w = ibetaf_incompletebetafe2(a, b, x, big, biginv, _state)/xc;
7548 : }
7549 0 : y = a*ae_log(x, _state);
7550 0 : t = b*ae_log(xc, _state);
7551 0 : if( (ae_fp_less(a+b,maxgam)&&ae_fp_less(ae_fabs(y, _state),maxlog))&&ae_fp_less(ae_fabs(t, _state),maxlog) )
7552 : {
7553 0 : t = ae_pow(xc, b, _state);
7554 0 : t = t*ae_pow(x, a, _state);
7555 0 : t = t/a;
7556 0 : t = t*w;
7557 0 : t = t*(gammafunction(a+b, _state)/(gammafunction(a, _state)*gammafunction(b, _state)));
7558 0 : if( flag==1 )
7559 : {
7560 0 : if( ae_fp_less_eq(t,ae_machineepsilon) )
7561 : {
7562 0 : result = 1.0-ae_machineepsilon;
7563 : }
7564 : else
7565 : {
7566 0 : result = 1.0-t;
7567 : }
7568 : }
7569 : else
7570 : {
7571 0 : result = t;
7572 : }
7573 0 : return result;
7574 : }
7575 0 : y = y+t+lngamma(a+b, &sg, _state)-lngamma(a, &sg, _state)-lngamma(b, &sg, _state);
7576 0 : y = y+ae_log(w/a, _state);
7577 0 : if( ae_fp_less(y,minlog) )
7578 : {
7579 0 : t = 0.0;
7580 : }
7581 : else
7582 : {
7583 0 : t = ae_exp(y, _state);
7584 : }
7585 0 : if( flag==1 )
7586 : {
7587 0 : if( ae_fp_less_eq(t,ae_machineepsilon) )
7588 : {
7589 0 : t = 1.0-ae_machineepsilon;
7590 : }
7591 : else
7592 : {
7593 0 : t = 1.0-t;
7594 : }
7595 : }
7596 0 : result = t;
7597 0 : return result;
7598 : }
7599 :
7600 :
7601 : /*************************************************************************
7602 : Inverse of imcomplete beta integral
7603 :
7604 : Given y, the function finds x such that
7605 :
7606 : incbet( a, b, x ) = y .
7607 :
7608 : The routine performs interval halving or Newton iterations to find the
7609 : root of incbet(a,b,x) - y = 0.
7610 :
7611 :
7612 : ACCURACY:
7613 :
7614 : Relative error:
7615 : x a,b
7616 : arithmetic domain domain # trials peak rms
7617 : IEEE 0,1 .5,10000 50000 5.8e-12 1.3e-13
7618 : IEEE 0,1 .25,100 100000 1.8e-13 3.9e-15
7619 : IEEE 0,1 0,5 50000 1.1e-12 5.5e-15
7620 : With a and b constrained to half-integer or integer values:
7621 : IEEE 0,1 .5,10000 50000 5.8e-12 1.1e-13
7622 : IEEE 0,1 .5,100 100000 1.7e-14 7.9e-16
7623 : With a = .5, b constrained to half-integer or integer values:
7624 : IEEE 0,1 .5,10000 10000 8.3e-11 1.0e-11
7625 :
7626 : Cephes Math Library Release 2.8: June, 2000
7627 : Copyright 1984, 1996, 2000 by Stephen L. Moshier
7628 : *************************************************************************/
7629 0 : double invincompletebeta(double a, double b, double y, ae_state *_state)
7630 : {
7631 : double aaa;
7632 : double bbb;
7633 : double y0;
7634 : double d;
7635 : double yyy;
7636 : double x;
7637 : double x0;
7638 : double x1;
7639 : double lgm;
7640 : double yp;
7641 : double di;
7642 : double dithresh;
7643 : double yl;
7644 : double yh;
7645 : double xt;
7646 : ae_int_t i;
7647 : ae_int_t rflg;
7648 : ae_int_t dir;
7649 : ae_int_t nflg;
7650 : double s;
7651 : ae_int_t mainlooppos;
7652 : ae_int_t ihalve;
7653 : ae_int_t ihalvecycle;
7654 : ae_int_t newt;
7655 : ae_int_t newtcycle;
7656 : ae_int_t breaknewtcycle;
7657 : ae_int_t breakihalvecycle;
7658 : double result;
7659 :
7660 :
7661 0 : i = 0;
7662 0 : ae_assert(ae_fp_greater_eq(y,(double)(0))&&ae_fp_less_eq(y,(double)(1)), "Domain error in InvIncompleteBeta", _state);
7663 :
7664 : /*
7665 : * special cases
7666 : */
7667 0 : if( ae_fp_eq(y,(double)(0)) )
7668 : {
7669 0 : result = (double)(0);
7670 0 : return result;
7671 : }
7672 0 : if( ae_fp_eq(y,1.0) )
7673 : {
7674 0 : result = (double)(1);
7675 0 : return result;
7676 : }
7677 :
7678 : /*
7679 : * these initializations are not really necessary,
7680 : * but without them compiler complains about 'possibly uninitialized variables'.
7681 : */
7682 0 : dithresh = (double)(0);
7683 0 : rflg = 0;
7684 0 : aaa = (double)(0);
7685 0 : bbb = (double)(0);
7686 0 : y0 = (double)(0);
7687 0 : x = (double)(0);
7688 0 : yyy = (double)(0);
7689 0 : lgm = (double)(0);
7690 0 : dir = 0;
7691 0 : di = (double)(0);
7692 :
7693 : /*
7694 : * normal initializations
7695 : */
7696 0 : x0 = 0.0;
7697 0 : yl = 0.0;
7698 0 : x1 = 1.0;
7699 0 : yh = 1.0;
7700 0 : nflg = 0;
7701 0 : mainlooppos = 0;
7702 0 : ihalve = 1;
7703 0 : ihalvecycle = 2;
7704 0 : newt = 3;
7705 0 : newtcycle = 4;
7706 0 : breaknewtcycle = 5;
7707 0 : breakihalvecycle = 6;
7708 :
7709 : /*
7710 : * main loop
7711 : */
7712 : for(;;)
7713 : {
7714 :
7715 : /*
7716 : * start
7717 : */
7718 0 : if( mainlooppos==0 )
7719 : {
7720 0 : if( ae_fp_less_eq(a,1.0)||ae_fp_less_eq(b,1.0) )
7721 : {
7722 0 : dithresh = 1.0e-6;
7723 0 : rflg = 0;
7724 0 : aaa = a;
7725 0 : bbb = b;
7726 0 : y0 = y;
7727 0 : x = aaa/(aaa+bbb);
7728 0 : yyy = incompletebeta(aaa, bbb, x, _state);
7729 0 : mainlooppos = ihalve;
7730 0 : continue;
7731 : }
7732 : else
7733 : {
7734 0 : dithresh = 1.0e-4;
7735 : }
7736 0 : yp = -invnormaldistribution(y, _state);
7737 0 : if( ae_fp_greater(y,0.5) )
7738 : {
7739 0 : rflg = 1;
7740 0 : aaa = b;
7741 0 : bbb = a;
7742 0 : y0 = 1.0-y;
7743 0 : yp = -yp;
7744 : }
7745 : else
7746 : {
7747 0 : rflg = 0;
7748 0 : aaa = a;
7749 0 : bbb = b;
7750 0 : y0 = y;
7751 : }
7752 0 : lgm = (yp*yp-3.0)/6.0;
7753 0 : x = 2.0/(1.0/(2.0*aaa-1.0)+1.0/(2.0*bbb-1.0));
7754 0 : d = yp*ae_sqrt(x+lgm, _state)/x-(1.0/(2.0*bbb-1.0)-1.0/(2.0*aaa-1.0))*(lgm+5.0/6.0-2.0/(3.0*x));
7755 0 : d = 2.0*d;
7756 0 : if( ae_fp_less(d,ae_log(ae_minrealnumber, _state)) )
7757 : {
7758 0 : x = (double)(0);
7759 0 : break;
7760 : }
7761 0 : x = aaa/(aaa+bbb*ae_exp(d, _state));
7762 0 : yyy = incompletebeta(aaa, bbb, x, _state);
7763 0 : yp = (yyy-y0)/y0;
7764 0 : if( ae_fp_less(ae_fabs(yp, _state),0.2) )
7765 : {
7766 0 : mainlooppos = newt;
7767 0 : continue;
7768 : }
7769 0 : mainlooppos = ihalve;
7770 0 : continue;
7771 : }
7772 :
7773 : /*
7774 : * ihalve
7775 : */
7776 0 : if( mainlooppos==ihalve )
7777 : {
7778 0 : dir = 0;
7779 0 : di = 0.5;
7780 0 : i = 0;
7781 0 : mainlooppos = ihalvecycle;
7782 0 : continue;
7783 : }
7784 :
7785 : /*
7786 : * ihalvecycle
7787 : */
7788 0 : if( mainlooppos==ihalvecycle )
7789 : {
7790 0 : if( i<=99 )
7791 : {
7792 0 : if( i!=0 )
7793 : {
7794 0 : x = x0+di*(x1-x0);
7795 0 : if( ae_fp_eq(x,1.0) )
7796 : {
7797 0 : x = 1.0-ae_machineepsilon;
7798 : }
7799 0 : if( ae_fp_eq(x,0.0) )
7800 : {
7801 0 : di = 0.5;
7802 0 : x = x0+di*(x1-x0);
7803 0 : if( ae_fp_eq(x,0.0) )
7804 : {
7805 0 : break;
7806 : }
7807 : }
7808 0 : yyy = incompletebeta(aaa, bbb, x, _state);
7809 0 : yp = (x1-x0)/(x1+x0);
7810 0 : if( ae_fp_less(ae_fabs(yp, _state),dithresh) )
7811 : {
7812 0 : mainlooppos = newt;
7813 0 : continue;
7814 : }
7815 0 : yp = (yyy-y0)/y0;
7816 0 : if( ae_fp_less(ae_fabs(yp, _state),dithresh) )
7817 : {
7818 0 : mainlooppos = newt;
7819 0 : continue;
7820 : }
7821 : }
7822 0 : if( ae_fp_less(yyy,y0) )
7823 : {
7824 0 : x0 = x;
7825 0 : yl = yyy;
7826 0 : if( dir<0 )
7827 : {
7828 0 : dir = 0;
7829 0 : di = 0.5;
7830 : }
7831 : else
7832 : {
7833 0 : if( dir>3 )
7834 : {
7835 0 : di = 1.0-(1.0-di)*(1.0-di);
7836 : }
7837 : else
7838 : {
7839 0 : if( dir>1 )
7840 : {
7841 0 : di = 0.5*di+0.5;
7842 : }
7843 : else
7844 : {
7845 0 : di = (y0-yyy)/(yh-yl);
7846 : }
7847 : }
7848 : }
7849 0 : dir = dir+1;
7850 0 : if( ae_fp_greater(x0,0.75) )
7851 : {
7852 0 : if( rflg==1 )
7853 : {
7854 0 : rflg = 0;
7855 0 : aaa = a;
7856 0 : bbb = b;
7857 0 : y0 = y;
7858 : }
7859 : else
7860 : {
7861 0 : rflg = 1;
7862 0 : aaa = b;
7863 0 : bbb = a;
7864 0 : y0 = 1.0-y;
7865 : }
7866 0 : x = 1.0-x;
7867 0 : yyy = incompletebeta(aaa, bbb, x, _state);
7868 0 : x0 = 0.0;
7869 0 : yl = 0.0;
7870 0 : x1 = 1.0;
7871 0 : yh = 1.0;
7872 0 : mainlooppos = ihalve;
7873 0 : continue;
7874 : }
7875 : }
7876 : else
7877 : {
7878 0 : x1 = x;
7879 0 : if( rflg==1&&ae_fp_less(x1,ae_machineepsilon) )
7880 : {
7881 0 : x = 0.0;
7882 0 : break;
7883 : }
7884 0 : yh = yyy;
7885 0 : if( dir>0 )
7886 : {
7887 0 : dir = 0;
7888 0 : di = 0.5;
7889 : }
7890 : else
7891 : {
7892 0 : if( dir<-3 )
7893 : {
7894 0 : di = di*di;
7895 : }
7896 : else
7897 : {
7898 0 : if( dir<-1 )
7899 : {
7900 0 : di = 0.5*di;
7901 : }
7902 : else
7903 : {
7904 0 : di = (yyy-y0)/(yh-yl);
7905 : }
7906 : }
7907 : }
7908 0 : dir = dir-1;
7909 : }
7910 0 : i = i+1;
7911 0 : mainlooppos = ihalvecycle;
7912 0 : continue;
7913 : }
7914 : else
7915 : {
7916 0 : mainlooppos = breakihalvecycle;
7917 0 : continue;
7918 : }
7919 : }
7920 :
7921 : /*
7922 : * breakihalvecycle
7923 : */
7924 0 : if( mainlooppos==breakihalvecycle )
7925 : {
7926 0 : if( ae_fp_greater_eq(x0,1.0) )
7927 : {
7928 0 : x = 1.0-ae_machineepsilon;
7929 0 : break;
7930 : }
7931 0 : if( ae_fp_less_eq(x,0.0) )
7932 : {
7933 0 : x = 0.0;
7934 0 : break;
7935 : }
7936 0 : mainlooppos = newt;
7937 0 : continue;
7938 : }
7939 :
7940 : /*
7941 : * newt
7942 : */
7943 0 : if( mainlooppos==newt )
7944 : {
7945 0 : if( nflg!=0 )
7946 : {
7947 0 : break;
7948 : }
7949 0 : nflg = 1;
7950 0 : lgm = lngamma(aaa+bbb, &s, _state)-lngamma(aaa, &s, _state)-lngamma(bbb, &s, _state);
7951 0 : i = 0;
7952 0 : mainlooppos = newtcycle;
7953 0 : continue;
7954 : }
7955 :
7956 : /*
7957 : * newtcycle
7958 : */
7959 0 : if( mainlooppos==newtcycle )
7960 : {
7961 0 : if( i<=7 )
7962 : {
7963 0 : if( i!=0 )
7964 : {
7965 0 : yyy = incompletebeta(aaa, bbb, x, _state);
7966 : }
7967 0 : if( ae_fp_less(yyy,yl) )
7968 : {
7969 0 : x = x0;
7970 0 : yyy = yl;
7971 : }
7972 : else
7973 : {
7974 0 : if( ae_fp_greater(yyy,yh) )
7975 : {
7976 0 : x = x1;
7977 0 : yyy = yh;
7978 : }
7979 : else
7980 : {
7981 0 : if( ae_fp_less(yyy,y0) )
7982 : {
7983 0 : x0 = x;
7984 0 : yl = yyy;
7985 : }
7986 : else
7987 : {
7988 0 : x1 = x;
7989 0 : yh = yyy;
7990 : }
7991 : }
7992 : }
7993 0 : if( ae_fp_eq(x,1.0)||ae_fp_eq(x,0.0) )
7994 : {
7995 0 : mainlooppos = breaknewtcycle;
7996 0 : continue;
7997 : }
7998 0 : d = (aaa-1.0)*ae_log(x, _state)+(bbb-1.0)*ae_log(1.0-x, _state)+lgm;
7999 0 : if( ae_fp_less(d,ae_log(ae_minrealnumber, _state)) )
8000 : {
8001 0 : break;
8002 : }
8003 0 : if( ae_fp_greater(d,ae_log(ae_maxrealnumber, _state)) )
8004 : {
8005 0 : mainlooppos = breaknewtcycle;
8006 0 : continue;
8007 : }
8008 0 : d = ae_exp(d, _state);
8009 0 : d = (yyy-y0)/d;
8010 0 : xt = x-d;
8011 0 : if( ae_fp_less_eq(xt,x0) )
8012 : {
8013 0 : yyy = (x-x0)/(x1-x0);
8014 0 : xt = x0+0.5*yyy*(x-x0);
8015 0 : if( ae_fp_less_eq(xt,0.0) )
8016 : {
8017 0 : mainlooppos = breaknewtcycle;
8018 0 : continue;
8019 : }
8020 : }
8021 0 : if( ae_fp_greater_eq(xt,x1) )
8022 : {
8023 0 : yyy = (x1-x)/(x1-x0);
8024 0 : xt = x1-0.5*yyy*(x1-x);
8025 0 : if( ae_fp_greater_eq(xt,1.0) )
8026 : {
8027 0 : mainlooppos = breaknewtcycle;
8028 0 : continue;
8029 : }
8030 : }
8031 0 : x = xt;
8032 0 : if( ae_fp_less(ae_fabs(d/x, _state),128.0*ae_machineepsilon) )
8033 : {
8034 0 : break;
8035 : }
8036 0 : i = i+1;
8037 0 : mainlooppos = newtcycle;
8038 0 : continue;
8039 : }
8040 : else
8041 : {
8042 0 : mainlooppos = breaknewtcycle;
8043 0 : continue;
8044 : }
8045 : }
8046 :
8047 : /*
8048 : * breaknewtcycle
8049 : */
8050 0 : if( mainlooppos==breaknewtcycle )
8051 : {
8052 0 : dithresh = 256.0*ae_machineepsilon;
8053 0 : mainlooppos = ihalve;
8054 0 : continue;
8055 : }
8056 : }
8057 :
8058 : /*
8059 : * done
8060 : */
8061 0 : if( rflg!=0 )
8062 : {
8063 0 : if( ae_fp_less_eq(x,ae_machineepsilon) )
8064 : {
8065 0 : x = 1.0-ae_machineepsilon;
8066 : }
8067 : else
8068 : {
8069 0 : x = 1.0-x;
8070 : }
8071 : }
8072 0 : result = x;
8073 0 : return result;
8074 : }
8075 :
8076 :
8077 : /*************************************************************************
8078 : Continued fraction expansion #1 for incomplete beta integral
8079 :
8080 : Cephes Math Library, Release 2.8: June, 2000
8081 : Copyright 1984, 1995, 2000 by Stephen L. Moshier
8082 : *************************************************************************/
8083 0 : static double ibetaf_incompletebetafe(double a,
8084 : double b,
8085 : double x,
8086 : double big,
8087 : double biginv,
8088 : ae_state *_state)
8089 : {
8090 : double xk;
8091 : double pk;
8092 : double pkm1;
8093 : double pkm2;
8094 : double qk;
8095 : double qkm1;
8096 : double qkm2;
8097 : double k1;
8098 : double k2;
8099 : double k3;
8100 : double k4;
8101 : double k5;
8102 : double k6;
8103 : double k7;
8104 : double k8;
8105 : double r;
8106 : double t;
8107 : double ans;
8108 : double thresh;
8109 : ae_int_t n;
8110 : double result;
8111 :
8112 :
8113 0 : k1 = a;
8114 0 : k2 = a+b;
8115 0 : k3 = a;
8116 0 : k4 = a+1.0;
8117 0 : k5 = 1.0;
8118 0 : k6 = b-1.0;
8119 0 : k7 = k4;
8120 0 : k8 = a+2.0;
8121 0 : pkm2 = 0.0;
8122 0 : qkm2 = 1.0;
8123 0 : pkm1 = 1.0;
8124 0 : qkm1 = 1.0;
8125 0 : ans = 1.0;
8126 0 : r = 1.0;
8127 0 : n = 0;
8128 0 : thresh = 3.0*ae_machineepsilon;
8129 0 : do
8130 : {
8131 0 : xk = -x*k1*k2/(k3*k4);
8132 0 : pk = pkm1+pkm2*xk;
8133 0 : qk = qkm1+qkm2*xk;
8134 0 : pkm2 = pkm1;
8135 0 : pkm1 = pk;
8136 0 : qkm2 = qkm1;
8137 0 : qkm1 = qk;
8138 0 : xk = x*k5*k6/(k7*k8);
8139 0 : pk = pkm1+pkm2*xk;
8140 0 : qk = qkm1+qkm2*xk;
8141 0 : pkm2 = pkm1;
8142 0 : pkm1 = pk;
8143 0 : qkm2 = qkm1;
8144 0 : qkm1 = qk;
8145 0 : if( ae_fp_neq(qk,(double)(0)) )
8146 : {
8147 0 : r = pk/qk;
8148 : }
8149 0 : if( ae_fp_neq(r,(double)(0)) )
8150 : {
8151 0 : t = ae_fabs((ans-r)/r, _state);
8152 0 : ans = r;
8153 : }
8154 : else
8155 : {
8156 0 : t = 1.0;
8157 : }
8158 0 : if( ae_fp_less(t,thresh) )
8159 : {
8160 0 : break;
8161 : }
8162 0 : k1 = k1+1.0;
8163 0 : k2 = k2+1.0;
8164 0 : k3 = k3+2.0;
8165 0 : k4 = k4+2.0;
8166 0 : k5 = k5+1.0;
8167 0 : k6 = k6-1.0;
8168 0 : k7 = k7+2.0;
8169 0 : k8 = k8+2.0;
8170 0 : if( ae_fp_greater(ae_fabs(qk, _state)+ae_fabs(pk, _state),big) )
8171 : {
8172 0 : pkm2 = pkm2*biginv;
8173 0 : pkm1 = pkm1*biginv;
8174 0 : qkm2 = qkm2*biginv;
8175 0 : qkm1 = qkm1*biginv;
8176 : }
8177 0 : if( ae_fp_less(ae_fabs(qk, _state),biginv)||ae_fp_less(ae_fabs(pk, _state),biginv) )
8178 : {
8179 0 : pkm2 = pkm2*big;
8180 0 : pkm1 = pkm1*big;
8181 0 : qkm2 = qkm2*big;
8182 0 : qkm1 = qkm1*big;
8183 : }
8184 0 : n = n+1;
8185 : }
8186 0 : while(n!=300);
8187 0 : result = ans;
8188 0 : return result;
8189 : }
8190 :
8191 :
8192 : /*************************************************************************
8193 : Continued fraction expansion #2
8194 : for incomplete beta integral
8195 :
8196 : Cephes Math Library, Release 2.8: June, 2000
8197 : Copyright 1984, 1995, 2000 by Stephen L. Moshier
8198 : *************************************************************************/
8199 0 : static double ibetaf_incompletebetafe2(double a,
8200 : double b,
8201 : double x,
8202 : double big,
8203 : double biginv,
8204 : ae_state *_state)
8205 : {
8206 : double xk;
8207 : double pk;
8208 : double pkm1;
8209 : double pkm2;
8210 : double qk;
8211 : double qkm1;
8212 : double qkm2;
8213 : double k1;
8214 : double k2;
8215 : double k3;
8216 : double k4;
8217 : double k5;
8218 : double k6;
8219 : double k7;
8220 : double k8;
8221 : double r;
8222 : double t;
8223 : double ans;
8224 : double z;
8225 : double thresh;
8226 : ae_int_t n;
8227 : double result;
8228 :
8229 :
8230 0 : k1 = a;
8231 0 : k2 = b-1.0;
8232 0 : k3 = a;
8233 0 : k4 = a+1.0;
8234 0 : k5 = 1.0;
8235 0 : k6 = a+b;
8236 0 : k7 = a+1.0;
8237 0 : k8 = a+2.0;
8238 0 : pkm2 = 0.0;
8239 0 : qkm2 = 1.0;
8240 0 : pkm1 = 1.0;
8241 0 : qkm1 = 1.0;
8242 0 : z = x/(1.0-x);
8243 0 : ans = 1.0;
8244 0 : r = 1.0;
8245 0 : n = 0;
8246 0 : thresh = 3.0*ae_machineepsilon;
8247 0 : do
8248 : {
8249 0 : xk = -z*k1*k2/(k3*k4);
8250 0 : pk = pkm1+pkm2*xk;
8251 0 : qk = qkm1+qkm2*xk;
8252 0 : pkm2 = pkm1;
8253 0 : pkm1 = pk;
8254 0 : qkm2 = qkm1;
8255 0 : qkm1 = qk;
8256 0 : xk = z*k5*k6/(k7*k8);
8257 0 : pk = pkm1+pkm2*xk;
8258 0 : qk = qkm1+qkm2*xk;
8259 0 : pkm2 = pkm1;
8260 0 : pkm1 = pk;
8261 0 : qkm2 = qkm1;
8262 0 : qkm1 = qk;
8263 0 : if( ae_fp_neq(qk,(double)(0)) )
8264 : {
8265 0 : r = pk/qk;
8266 : }
8267 0 : if( ae_fp_neq(r,(double)(0)) )
8268 : {
8269 0 : t = ae_fabs((ans-r)/r, _state);
8270 0 : ans = r;
8271 : }
8272 : else
8273 : {
8274 0 : t = 1.0;
8275 : }
8276 0 : if( ae_fp_less(t,thresh) )
8277 : {
8278 0 : break;
8279 : }
8280 0 : k1 = k1+1.0;
8281 0 : k2 = k2-1.0;
8282 0 : k3 = k3+2.0;
8283 0 : k4 = k4+2.0;
8284 0 : k5 = k5+1.0;
8285 0 : k6 = k6+1.0;
8286 0 : k7 = k7+2.0;
8287 0 : k8 = k8+2.0;
8288 0 : if( ae_fp_greater(ae_fabs(qk, _state)+ae_fabs(pk, _state),big) )
8289 : {
8290 0 : pkm2 = pkm2*biginv;
8291 0 : pkm1 = pkm1*biginv;
8292 0 : qkm2 = qkm2*biginv;
8293 0 : qkm1 = qkm1*biginv;
8294 : }
8295 0 : if( ae_fp_less(ae_fabs(qk, _state),biginv)||ae_fp_less(ae_fabs(pk, _state),biginv) )
8296 : {
8297 0 : pkm2 = pkm2*big;
8298 0 : pkm1 = pkm1*big;
8299 0 : qkm2 = qkm2*big;
8300 0 : qkm1 = qkm1*big;
8301 : }
8302 0 : n = n+1;
8303 : }
8304 0 : while(n!=300);
8305 0 : result = ans;
8306 0 : return result;
8307 : }
8308 :
8309 :
8310 : /*************************************************************************
8311 : Power series for incomplete beta integral.
8312 : Use when b*x is small and x not too close to 1.
8313 :
8314 : Cephes Math Library, Release 2.8: June, 2000
8315 : Copyright 1984, 1995, 2000 by Stephen L. Moshier
8316 : *************************************************************************/
8317 0 : static double ibetaf_incompletebetaps(double a,
8318 : double b,
8319 : double x,
8320 : double maxgam,
8321 : ae_state *_state)
8322 : {
8323 : double s;
8324 : double t;
8325 : double u;
8326 : double v;
8327 : double n;
8328 : double t1;
8329 : double z;
8330 : double ai;
8331 : double sg;
8332 : double result;
8333 :
8334 :
8335 0 : ai = 1.0/a;
8336 0 : u = (1.0-b)*x;
8337 0 : v = u/(a+1.0);
8338 0 : t1 = v;
8339 0 : t = u;
8340 0 : n = 2.0;
8341 0 : s = 0.0;
8342 0 : z = ae_machineepsilon*ai;
8343 0 : while(ae_fp_greater(ae_fabs(v, _state),z))
8344 : {
8345 0 : u = (n-b)*x/n;
8346 0 : t = t*u;
8347 0 : v = t/(a+n);
8348 0 : s = s+v;
8349 0 : n = n+1.0;
8350 : }
8351 0 : s = s+t1;
8352 0 : s = s+ai;
8353 0 : u = a*ae_log(x, _state);
8354 0 : if( ae_fp_less(a+b,maxgam)&&ae_fp_less(ae_fabs(u, _state),ae_log(ae_maxrealnumber, _state)) )
8355 : {
8356 0 : t = gammafunction(a+b, _state)/(gammafunction(a, _state)*gammafunction(b, _state));
8357 0 : s = s*t*ae_pow(x, a, _state);
8358 : }
8359 : else
8360 : {
8361 0 : t = lngamma(a+b, &sg, _state)-lngamma(a, &sg, _state)-lngamma(b, &sg, _state)+u+ae_log(s, _state);
8362 0 : if( ae_fp_less(t,ae_log(ae_minrealnumber, _state)) )
8363 : {
8364 0 : s = 0.0;
8365 : }
8366 : else
8367 : {
8368 0 : s = ae_exp(t, _state);
8369 : }
8370 : }
8371 0 : result = s;
8372 0 : return result;
8373 : }
8374 :
8375 :
8376 : #endif
8377 : #if defined(AE_COMPILE_FDISTR) || !defined(AE_PARTIAL_BUILD)
8378 :
8379 :
8380 : /*************************************************************************
8381 : F distribution
8382 :
8383 : Returns the area from zero to x under the F density
8384 : function (also known as Snedcor's density or the
8385 : variance ratio density). This is the density
8386 : of x = (u1/df1)/(u2/df2), where u1 and u2 are random
8387 : variables having Chi square distributions with df1
8388 : and df2 degrees of freedom, respectively.
8389 : The incomplete beta integral is used, according to the
8390 : formula
8391 :
8392 : P(x) = incbet( df1/2, df2/2, (df1*x/(df2 + df1*x) ).
8393 :
8394 :
8395 : The arguments a and b are greater than zero, and x is
8396 : nonnegative.
8397 :
8398 : ACCURACY:
8399 :
8400 : Tested at random points (a,b,x).
8401 :
8402 : x a,b Relative error:
8403 : arithmetic domain domain # trials peak rms
8404 : IEEE 0,1 0,100 100000 9.8e-15 1.7e-15
8405 : IEEE 1,5 0,100 100000 6.5e-15 3.5e-16
8406 : IEEE 0,1 1,10000 100000 2.2e-11 3.3e-12
8407 : IEEE 1,5 1,10000 100000 1.1e-11 1.7e-13
8408 :
8409 : Cephes Math Library Release 2.8: June, 2000
8410 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
8411 : *************************************************************************/
8412 0 : double fdistribution(ae_int_t a, ae_int_t b, double x, ae_state *_state)
8413 : {
8414 : double w;
8415 : double result;
8416 :
8417 :
8418 0 : ae_assert((a>=1&&b>=1)&&ae_fp_greater_eq(x,(double)(0)), "Domain error in FDistribution", _state);
8419 0 : w = a*x;
8420 0 : w = w/(b+w);
8421 0 : result = incompletebeta(0.5*a, 0.5*b, w, _state);
8422 0 : return result;
8423 : }
8424 :
8425 :
8426 : /*************************************************************************
8427 : Complemented F distribution
8428 :
8429 : Returns the area from x to infinity under the F density
8430 : function (also known as Snedcor's density or the
8431 : variance ratio density).
8432 :
8433 :
8434 : inf.
8435 : -
8436 : 1 | | a-1 b-1
8437 : 1-P(x) = ------ | t (1-t) dt
8438 : B(a,b) | |
8439 : -
8440 : x
8441 :
8442 :
8443 : The incomplete beta integral is used, according to the
8444 : formula
8445 :
8446 : P(x) = incbet( df2/2, df1/2, (df2/(df2 + df1*x) ).
8447 :
8448 :
8449 : ACCURACY:
8450 :
8451 : Tested at random points (a,b,x) in the indicated intervals.
8452 : x a,b Relative error:
8453 : arithmetic domain domain # trials peak rms
8454 : IEEE 0,1 1,100 100000 3.7e-14 5.9e-16
8455 : IEEE 1,5 1,100 100000 8.0e-15 1.6e-15
8456 : IEEE 0,1 1,10000 100000 1.8e-11 3.5e-13
8457 : IEEE 1,5 1,10000 100000 2.0e-11 3.0e-12
8458 :
8459 : Cephes Math Library Release 2.8: June, 2000
8460 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
8461 : *************************************************************************/
8462 0 : double fcdistribution(ae_int_t a, ae_int_t b, double x, ae_state *_state)
8463 : {
8464 : double w;
8465 : double result;
8466 :
8467 :
8468 0 : ae_assert((a>=1&&b>=1)&&ae_fp_greater_eq(x,(double)(0)), "Domain error in FCDistribution", _state);
8469 0 : w = b/(b+a*x);
8470 0 : result = incompletebeta(0.5*b, 0.5*a, w, _state);
8471 0 : return result;
8472 : }
8473 :
8474 :
8475 : /*************************************************************************
8476 : Inverse of complemented F distribution
8477 :
8478 : Finds the F density argument x such that the integral
8479 : from x to infinity of the F density is equal to the
8480 : given probability p.
8481 :
8482 : This is accomplished using the inverse beta integral
8483 : function and the relations
8484 :
8485 : z = incbi( df2/2, df1/2, p )
8486 : x = df2 (1-z) / (df1 z).
8487 :
8488 : Note: the following relations hold for the inverse of
8489 : the uncomplemented F distribution:
8490 :
8491 : z = incbi( df1/2, df2/2, p )
8492 : x = df2 z / (df1 (1-z)).
8493 :
8494 : ACCURACY:
8495 :
8496 : Tested at random points (a,b,p).
8497 :
8498 : a,b Relative error:
8499 : arithmetic domain # trials peak rms
8500 : For p between .001 and 1:
8501 : IEEE 1,100 100000 8.3e-15 4.7e-16
8502 : IEEE 1,10000 100000 2.1e-11 1.4e-13
8503 : For p between 10^-6 and 10^-3:
8504 : IEEE 1,100 50000 1.3e-12 8.4e-15
8505 : IEEE 1,10000 50000 3.0e-12 4.8e-14
8506 :
8507 : Cephes Math Library Release 2.8: June, 2000
8508 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
8509 : *************************************************************************/
8510 0 : double invfdistribution(ae_int_t a,
8511 : ae_int_t b,
8512 : double y,
8513 : ae_state *_state)
8514 : {
8515 : double w;
8516 : double result;
8517 :
8518 :
8519 0 : ae_assert(((a>=1&&b>=1)&&ae_fp_greater(y,(double)(0)))&&ae_fp_less_eq(y,(double)(1)), "Domain error in InvFDistribution", _state);
8520 :
8521 : /*
8522 : * Compute probability for x = 0.5
8523 : */
8524 0 : w = incompletebeta(0.5*b, 0.5*a, 0.5, _state);
8525 :
8526 : /*
8527 : * If that is greater than y, then the solution w < .5
8528 : * Otherwise, solve at 1-y to remove cancellation in (b - b*w)
8529 : */
8530 0 : if( ae_fp_greater(w,y)||ae_fp_less(y,0.001) )
8531 : {
8532 0 : w = invincompletebeta(0.5*b, 0.5*a, y, _state);
8533 0 : result = (b-b*w)/(a*w);
8534 : }
8535 : else
8536 : {
8537 0 : w = invincompletebeta(0.5*a, 0.5*b, 1.0-y, _state);
8538 0 : result = b*w/(a*(1.0-w));
8539 : }
8540 0 : return result;
8541 : }
8542 :
8543 :
8544 : #endif
8545 : #if defined(AE_COMPILE_FRESNEL) || !defined(AE_PARTIAL_BUILD)
8546 :
8547 :
8548 : /*************************************************************************
8549 : Fresnel integral
8550 :
8551 : Evaluates the Fresnel integrals
8552 :
8553 : x
8554 : -
8555 : | |
8556 : C(x) = | cos(pi/2 t**2) dt,
8557 : | |
8558 : -
8559 : 0
8560 :
8561 : x
8562 : -
8563 : | |
8564 : S(x) = | sin(pi/2 t**2) dt.
8565 : | |
8566 : -
8567 : 0
8568 :
8569 :
8570 : The integrals are evaluated by a power series for x < 1.
8571 : For x >= 1 auxiliary functions f(x) and g(x) are employed
8572 : such that
8573 :
8574 : C(x) = 0.5 + f(x) sin( pi/2 x**2 ) - g(x) cos( pi/2 x**2 )
8575 : S(x) = 0.5 - f(x) cos( pi/2 x**2 ) - g(x) sin( pi/2 x**2 )
8576 :
8577 :
8578 :
8579 : ACCURACY:
8580 :
8581 : Relative error.
8582 :
8583 : Arithmetic function domain # trials peak rms
8584 : IEEE S(x) 0, 10 10000 2.0e-15 3.2e-16
8585 : IEEE C(x) 0, 10 10000 1.8e-15 3.3e-16
8586 :
8587 : Cephes Math Library Release 2.8: June, 2000
8588 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
8589 : *************************************************************************/
8590 0 : void fresnelintegral(double x, double* c, double* s, ae_state *_state)
8591 : {
8592 : double xxa;
8593 : double f;
8594 : double g;
8595 : double cc;
8596 : double ss;
8597 : double t;
8598 : double u;
8599 : double x2;
8600 : double sn;
8601 : double sd;
8602 : double cn;
8603 : double cd;
8604 : double fn;
8605 : double fd;
8606 : double gn;
8607 : double gd;
8608 : double mpi;
8609 : double mpio2;
8610 :
8611 :
8612 0 : mpi = 3.14159265358979323846;
8613 0 : mpio2 = 1.57079632679489661923;
8614 0 : xxa = x;
8615 0 : x = ae_fabs(xxa, _state);
8616 0 : x2 = x*x;
8617 0 : if( ae_fp_less(x2,2.5625) )
8618 : {
8619 0 : t = x2*x2;
8620 0 : sn = -2.99181919401019853726E3;
8621 0 : sn = sn*t+7.08840045257738576863E5;
8622 0 : sn = sn*t-6.29741486205862506537E7;
8623 0 : sn = sn*t+2.54890880573376359104E9;
8624 0 : sn = sn*t-4.42979518059697779103E10;
8625 0 : sn = sn*t+3.18016297876567817986E11;
8626 0 : sd = 1.00000000000000000000E0;
8627 0 : sd = sd*t+2.81376268889994315696E2;
8628 0 : sd = sd*t+4.55847810806532581675E4;
8629 0 : sd = sd*t+5.17343888770096400730E6;
8630 0 : sd = sd*t+4.19320245898111231129E8;
8631 0 : sd = sd*t+2.24411795645340920940E10;
8632 0 : sd = sd*t+6.07366389490084639049E11;
8633 0 : cn = -4.98843114573573548651E-8;
8634 0 : cn = cn*t+9.50428062829859605134E-6;
8635 0 : cn = cn*t-6.45191435683965050962E-4;
8636 0 : cn = cn*t+1.88843319396703850064E-2;
8637 0 : cn = cn*t-2.05525900955013891793E-1;
8638 0 : cn = cn*t+9.99999999999999998822E-1;
8639 0 : cd = 3.99982968972495980367E-12;
8640 0 : cd = cd*t+9.15439215774657478799E-10;
8641 0 : cd = cd*t+1.25001862479598821474E-7;
8642 0 : cd = cd*t+1.22262789024179030997E-5;
8643 0 : cd = cd*t+8.68029542941784300606E-4;
8644 0 : cd = cd*t+4.12142090722199792936E-2;
8645 0 : cd = cd*t+1.00000000000000000118E0;
8646 0 : *s = ae_sign(xxa, _state)*x*x2*sn/sd;
8647 0 : *c = ae_sign(xxa, _state)*x*cn/cd;
8648 0 : return;
8649 : }
8650 0 : if( ae_fp_greater(x,36974.0) )
8651 : {
8652 0 : *c = ae_sign(xxa, _state)*0.5;
8653 0 : *s = ae_sign(xxa, _state)*0.5;
8654 0 : return;
8655 : }
8656 0 : x2 = x*x;
8657 0 : t = mpi*x2;
8658 0 : u = 1/(t*t);
8659 0 : t = 1/t;
8660 0 : fn = 4.21543555043677546506E-1;
8661 0 : fn = fn*u+1.43407919780758885261E-1;
8662 0 : fn = fn*u+1.15220955073585758835E-2;
8663 0 : fn = fn*u+3.45017939782574027900E-4;
8664 0 : fn = fn*u+4.63613749287867322088E-6;
8665 0 : fn = fn*u+3.05568983790257605827E-8;
8666 0 : fn = fn*u+1.02304514164907233465E-10;
8667 0 : fn = fn*u+1.72010743268161828879E-13;
8668 0 : fn = fn*u+1.34283276233062758925E-16;
8669 0 : fn = fn*u+3.76329711269987889006E-20;
8670 0 : fd = 1.00000000000000000000E0;
8671 0 : fd = fd*u+7.51586398353378947175E-1;
8672 0 : fd = fd*u+1.16888925859191382142E-1;
8673 0 : fd = fd*u+6.44051526508858611005E-3;
8674 0 : fd = fd*u+1.55934409164153020873E-4;
8675 0 : fd = fd*u+1.84627567348930545870E-6;
8676 0 : fd = fd*u+1.12699224763999035261E-8;
8677 0 : fd = fd*u+3.60140029589371370404E-11;
8678 0 : fd = fd*u+5.88754533621578410010E-14;
8679 0 : fd = fd*u+4.52001434074129701496E-17;
8680 0 : fd = fd*u+1.25443237090011264384E-20;
8681 0 : gn = 5.04442073643383265887E-1;
8682 0 : gn = gn*u+1.97102833525523411709E-1;
8683 0 : gn = gn*u+1.87648584092575249293E-2;
8684 0 : gn = gn*u+6.84079380915393090172E-4;
8685 0 : gn = gn*u+1.15138826111884280931E-5;
8686 0 : gn = gn*u+9.82852443688422223854E-8;
8687 0 : gn = gn*u+4.45344415861750144738E-10;
8688 0 : gn = gn*u+1.08268041139020870318E-12;
8689 0 : gn = gn*u+1.37555460633261799868E-15;
8690 0 : gn = gn*u+8.36354435630677421531E-19;
8691 0 : gn = gn*u+1.86958710162783235106E-22;
8692 0 : gd = 1.00000000000000000000E0;
8693 0 : gd = gd*u+1.47495759925128324529E0;
8694 0 : gd = gd*u+3.37748989120019970451E-1;
8695 0 : gd = gd*u+2.53603741420338795122E-2;
8696 0 : gd = gd*u+8.14679107184306179049E-4;
8697 0 : gd = gd*u+1.27545075667729118702E-5;
8698 0 : gd = gd*u+1.04314589657571990585E-7;
8699 0 : gd = gd*u+4.60680728146520428211E-10;
8700 0 : gd = gd*u+1.10273215066240270757E-12;
8701 0 : gd = gd*u+1.38796531259578871258E-15;
8702 0 : gd = gd*u+8.39158816283118707363E-19;
8703 0 : gd = gd*u+1.86958710162783236342E-22;
8704 0 : f = 1-u*fn/fd;
8705 0 : g = t*gn/gd;
8706 0 : t = mpio2*x2;
8707 0 : cc = ae_cos(t, _state);
8708 0 : ss = ae_sin(t, _state);
8709 0 : t = mpi*x;
8710 0 : *c = 0.5+(f*ss-g*cc)/t;
8711 0 : *s = 0.5-(f*cc+g*ss)/t;
8712 0 : *c = *c*ae_sign(xxa, _state);
8713 0 : *s = *s*ae_sign(xxa, _state);
8714 : }
8715 :
8716 :
8717 : #endif
8718 : #if defined(AE_COMPILE_JACOBIANELLIPTIC) || !defined(AE_PARTIAL_BUILD)
8719 :
8720 :
8721 : /*************************************************************************
8722 : Jacobian Elliptic Functions
8723 :
8724 : Evaluates the Jacobian elliptic functions sn(u|m), cn(u|m),
8725 : and dn(u|m) of parameter m between 0 and 1, and real
8726 : argument u.
8727 :
8728 : These functions are periodic, with quarter-period on the
8729 : real axis equal to the complete elliptic integral
8730 : ellpk(1.0-m).
8731 :
8732 : Relation to incomplete elliptic integral:
8733 : If u = ellik(phi,m), then sn(u|m) = sin(phi),
8734 : and cn(u|m) = cos(phi). Phi is called the amplitude of u.
8735 :
8736 : Computation is by means of the arithmetic-geometric mean
8737 : algorithm, except when m is within 1e-9 of 0 or 1. In the
8738 : latter case with m close to 1, the approximation applies
8739 : only for phi < pi/2.
8740 :
8741 : ACCURACY:
8742 :
8743 : Tested at random points with u between 0 and 10, m between
8744 : 0 and 1.
8745 :
8746 : Absolute error (* = relative error):
8747 : arithmetic function # trials peak rms
8748 : IEEE phi 10000 9.2e-16* 1.4e-16*
8749 : IEEE sn 50000 4.1e-15 4.6e-16
8750 : IEEE cn 40000 3.6e-15 4.4e-16
8751 : IEEE dn 10000 1.3e-12 1.8e-14
8752 :
8753 : Peak error observed in consistency check using addition
8754 : theorem for sn(u+v) was 4e-16 (absolute). Also tested by
8755 : the above relation to the incomplete elliptic integral.
8756 : Accuracy deteriorates when u is large.
8757 :
8758 : Cephes Math Library Release 2.8: June, 2000
8759 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
8760 : *************************************************************************/
8761 0 : void jacobianellipticfunctions(double u,
8762 : double m,
8763 : double* sn,
8764 : double* cn,
8765 : double* dn,
8766 : double* ph,
8767 : ae_state *_state)
8768 : {
8769 : ae_frame _frame_block;
8770 : double ai;
8771 : double b;
8772 : double phi;
8773 : double t;
8774 : double twon;
8775 : ae_vector a;
8776 : ae_vector c;
8777 : ae_int_t i;
8778 :
8779 0 : ae_frame_make(_state, &_frame_block);
8780 0 : memset(&a, 0, sizeof(a));
8781 0 : memset(&c, 0, sizeof(c));
8782 0 : *sn = 0;
8783 0 : *cn = 0;
8784 0 : *dn = 0;
8785 0 : *ph = 0;
8786 0 : ae_vector_init(&a, 0, DT_REAL, _state, ae_true);
8787 0 : ae_vector_init(&c, 0, DT_REAL, _state, ae_true);
8788 :
8789 0 : ae_assert(ae_fp_greater_eq(m,(double)(0))&&ae_fp_less_eq(m,(double)(1)), "Domain error in JacobianEllipticFunctions: m<0 or m>1", _state);
8790 0 : ae_vector_set_length(&a, 8+1, _state);
8791 0 : ae_vector_set_length(&c, 8+1, _state);
8792 0 : if( ae_fp_less(m,1.0e-9) )
8793 : {
8794 0 : t = ae_sin(u, _state);
8795 0 : b = ae_cos(u, _state);
8796 0 : ai = 0.25*m*(u-t*b);
8797 0 : *sn = t-ai*b;
8798 0 : *cn = b+ai*t;
8799 0 : *ph = u-ai;
8800 0 : *dn = 1.0-0.5*m*t*t;
8801 0 : ae_frame_leave(_state);
8802 0 : return;
8803 : }
8804 0 : if( ae_fp_greater_eq(m,0.9999999999) )
8805 : {
8806 0 : ai = 0.25*(1.0-m);
8807 0 : b = ae_cosh(u, _state);
8808 0 : t = ae_tanh(u, _state);
8809 0 : phi = 1.0/b;
8810 0 : twon = b*ae_sinh(u, _state);
8811 0 : *sn = t+ai*(twon-u)/(b*b);
8812 0 : *ph = 2.0*ae_atan(ae_exp(u, _state), _state)-1.57079632679489661923+ai*(twon-u)/b;
8813 0 : ai = ai*t*phi;
8814 0 : *cn = phi-ai*(twon-u);
8815 0 : *dn = phi+ai*(twon+u);
8816 0 : ae_frame_leave(_state);
8817 0 : return;
8818 : }
8819 0 : a.ptr.p_double[0] = 1.0;
8820 0 : b = ae_sqrt(1.0-m, _state);
8821 0 : c.ptr.p_double[0] = ae_sqrt(m, _state);
8822 0 : twon = 1.0;
8823 0 : i = 0;
8824 0 : while(ae_fp_greater(ae_fabs(c.ptr.p_double[i]/a.ptr.p_double[i], _state),ae_machineepsilon))
8825 : {
8826 0 : if( i>7 )
8827 : {
8828 0 : ae_assert(ae_false, "Overflow in JacobianEllipticFunctions", _state);
8829 0 : break;
8830 : }
8831 0 : ai = a.ptr.p_double[i];
8832 0 : i = i+1;
8833 0 : c.ptr.p_double[i] = 0.5*(ai-b);
8834 0 : t = ae_sqrt(ai*b, _state);
8835 0 : a.ptr.p_double[i] = 0.5*(ai+b);
8836 0 : b = t;
8837 0 : twon = twon*2.0;
8838 : }
8839 0 : phi = twon*a.ptr.p_double[i]*u;
8840 0 : do
8841 : {
8842 0 : t = c.ptr.p_double[i]*ae_sin(phi, _state)/a.ptr.p_double[i];
8843 0 : b = phi;
8844 0 : phi = (ae_asin(t, _state)+phi)/2.0;
8845 0 : i = i-1;
8846 : }
8847 0 : while(i!=0);
8848 0 : *sn = ae_sin(phi, _state);
8849 0 : t = ae_cos(phi, _state);
8850 0 : *cn = t;
8851 0 : *dn = t/ae_cos(phi-b, _state);
8852 0 : *ph = phi;
8853 0 : ae_frame_leave(_state);
8854 : }
8855 :
8856 :
8857 : #endif
8858 : #if defined(AE_COMPILE_PSIF) || !defined(AE_PARTIAL_BUILD)
8859 :
8860 :
8861 : /*************************************************************************
8862 : Psi (digamma) function
8863 :
8864 : d -
8865 : psi(x) = -- ln | (x)
8866 : dx
8867 :
8868 : is the logarithmic derivative of the gamma function.
8869 : For integer x,
8870 : n-1
8871 : -
8872 : psi(n) = -EUL + > 1/k.
8873 : -
8874 : k=1
8875 :
8876 : This formula is used for 0 < n <= 10. If x is negative, it
8877 : is transformed to a positive argument by the reflection
8878 : formula psi(1-x) = psi(x) + pi cot(pi x).
8879 : For general positive x, the argument is made greater than 10
8880 : using the recurrence psi(x+1) = psi(x) + 1/x.
8881 : Then the following asymptotic expansion is applied:
8882 :
8883 : inf. B
8884 : - 2k
8885 : psi(x) = log(x) - 1/2x - > -------
8886 : - 2k
8887 : k=1 2k x
8888 :
8889 : where the B2k are Bernoulli numbers.
8890 :
8891 : ACCURACY:
8892 : Relative error (except absolute when |psi| < 1):
8893 : arithmetic domain # trials peak rms
8894 : IEEE 0,30 30000 1.3e-15 1.4e-16
8895 : IEEE -30,0 40000 1.5e-15 2.2e-16
8896 :
8897 : Cephes Math Library Release 2.8: June, 2000
8898 : Copyright 1984, 1987, 1992, 2000 by Stephen L. Moshier
8899 : *************************************************************************/
8900 0 : double psi(double x, ae_state *_state)
8901 : {
8902 : double p;
8903 : double q;
8904 : double nz;
8905 : double s;
8906 : double w;
8907 : double y;
8908 : double z;
8909 : double polv;
8910 : ae_int_t i;
8911 : ae_int_t n;
8912 : ae_int_t negative;
8913 : double result;
8914 :
8915 :
8916 0 : negative = 0;
8917 0 : nz = 0.0;
8918 0 : if( ae_fp_less_eq(x,(double)(0)) )
8919 : {
8920 0 : negative = 1;
8921 0 : q = x;
8922 0 : p = (double)(ae_ifloor(q, _state));
8923 0 : if( ae_fp_eq(p,q) )
8924 : {
8925 0 : ae_assert(ae_false, "Singularity in Psi(x)", _state);
8926 0 : result = ae_maxrealnumber;
8927 0 : return result;
8928 : }
8929 0 : nz = q-p;
8930 0 : if( ae_fp_neq(nz,0.5) )
8931 : {
8932 0 : if( ae_fp_greater(nz,0.5) )
8933 : {
8934 0 : p = p+1.0;
8935 0 : nz = q-p;
8936 : }
8937 0 : nz = ae_pi/ae_tan(ae_pi*nz, _state);
8938 : }
8939 : else
8940 : {
8941 0 : nz = 0.0;
8942 : }
8943 0 : x = 1.0-x;
8944 : }
8945 0 : if( ae_fp_less_eq(x,10.0)&&ae_fp_eq(x,(double)(ae_ifloor(x, _state))) )
8946 : {
8947 0 : y = 0.0;
8948 0 : n = ae_ifloor(x, _state);
8949 0 : for(i=1; i<=n-1; i++)
8950 : {
8951 0 : w = (double)(i);
8952 0 : y = y+1.0/w;
8953 : }
8954 0 : y = y-0.57721566490153286061;
8955 : }
8956 : else
8957 : {
8958 0 : s = x;
8959 0 : w = 0.0;
8960 0 : while(ae_fp_less(s,10.0))
8961 : {
8962 0 : w = w+1.0/s;
8963 0 : s = s+1.0;
8964 : }
8965 0 : if( ae_fp_less(s,1.0E17) )
8966 : {
8967 0 : z = 1.0/(s*s);
8968 0 : polv = 8.33333333333333333333E-2;
8969 0 : polv = polv*z-2.10927960927960927961E-2;
8970 0 : polv = polv*z+7.57575757575757575758E-3;
8971 0 : polv = polv*z-4.16666666666666666667E-3;
8972 0 : polv = polv*z+3.96825396825396825397E-3;
8973 0 : polv = polv*z-8.33333333333333333333E-3;
8974 0 : polv = polv*z+8.33333333333333333333E-2;
8975 0 : y = z*polv;
8976 : }
8977 : else
8978 : {
8979 0 : y = 0.0;
8980 : }
8981 0 : y = ae_log(s, _state)-0.5/s-y-w;
8982 : }
8983 0 : if( negative!=0 )
8984 : {
8985 0 : y = y-nz;
8986 : }
8987 0 : result = y;
8988 0 : return result;
8989 : }
8990 :
8991 :
8992 : #endif
8993 : #if defined(AE_COMPILE_EXPINTEGRALS) || !defined(AE_PARTIAL_BUILD)
8994 :
8995 :
8996 : /*************************************************************************
8997 : Exponential integral Ei(x)
8998 :
8999 : x
9000 : - t
9001 : | | e
9002 : Ei(x) = -|- --- dt .
9003 : | | t
9004 : -
9005 : -inf
9006 :
9007 : Not defined for x <= 0.
9008 : See also expn.c.
9009 :
9010 :
9011 :
9012 : ACCURACY:
9013 :
9014 : Relative error:
9015 : arithmetic domain # trials peak rms
9016 : IEEE 0,100 50000 8.6e-16 1.3e-16
9017 :
9018 : Cephes Math Library Release 2.8: May, 1999
9019 : Copyright 1999 by Stephen L. Moshier
9020 : *************************************************************************/
9021 0 : double exponentialintegralei(double x, ae_state *_state)
9022 : {
9023 : double eul;
9024 : double f;
9025 : double f1;
9026 : double f2;
9027 : double w;
9028 : double result;
9029 :
9030 :
9031 0 : eul = 0.5772156649015328606065;
9032 0 : if( ae_fp_less_eq(x,(double)(0)) )
9033 : {
9034 0 : result = (double)(0);
9035 0 : return result;
9036 : }
9037 0 : if( ae_fp_less(x,(double)(2)) )
9038 : {
9039 0 : f1 = -5.350447357812542947283;
9040 0 : f1 = f1*x+218.5049168816613393830;
9041 0 : f1 = f1*x-4176.572384826693777058;
9042 0 : f1 = f1*x+55411.76756393557601232;
9043 0 : f1 = f1*x-331338.1331178144034309;
9044 0 : f1 = f1*x+1592627.163384945414220;
9045 0 : f2 = 1.000000000000000000000;
9046 0 : f2 = f2*x-52.50547959112862969197;
9047 0 : f2 = f2*x+1259.616186786790571525;
9048 0 : f2 = f2*x-17565.49581973534652631;
9049 0 : f2 = f2*x+149306.2117002725991967;
9050 0 : f2 = f2*x-729494.9239640527645655;
9051 0 : f2 = f2*x+1592627.163384945429726;
9052 0 : f = f1/f2;
9053 0 : result = eul+ae_log(x, _state)+x*f;
9054 0 : return result;
9055 : }
9056 0 : if( ae_fp_less(x,(double)(4)) )
9057 : {
9058 0 : w = 1/x;
9059 0 : f1 = 1.981808503259689673238E-2;
9060 0 : f1 = f1*w-1.271645625984917501326;
9061 0 : f1 = f1*w-2.088160335681228318920;
9062 0 : f1 = f1*w+2.755544509187936721172;
9063 0 : f1 = f1*w-4.409507048701600257171E-1;
9064 0 : f1 = f1*w+4.665623805935891391017E-2;
9065 0 : f1 = f1*w-1.545042679673485262580E-3;
9066 0 : f1 = f1*w+7.059980605299617478514E-5;
9067 0 : f2 = 1.000000000000000000000;
9068 0 : f2 = f2*w+1.476498670914921440652;
9069 0 : f2 = f2*w+5.629177174822436244827E-1;
9070 0 : f2 = f2*w+1.699017897879307263248E-1;
9071 0 : f2 = f2*w+2.291647179034212017463E-2;
9072 0 : f2 = f2*w+4.450150439728752875043E-3;
9073 0 : f2 = f2*w+1.727439612206521482874E-4;
9074 0 : f2 = f2*w+3.953167195549672482304E-5;
9075 0 : f = f1/f2;
9076 0 : result = ae_exp(x, _state)*w*(1+w*f);
9077 0 : return result;
9078 : }
9079 0 : if( ae_fp_less(x,(double)(8)) )
9080 : {
9081 0 : w = 1/x;
9082 0 : f1 = -1.373215375871208729803;
9083 0 : f1 = f1*w-7.084559133740838761406E-1;
9084 0 : f1 = f1*w+1.580806855547941010501;
9085 0 : f1 = f1*w-2.601500427425622944234E-1;
9086 0 : f1 = f1*w+2.994674694113713763365E-2;
9087 0 : f1 = f1*w-1.038086040188744005513E-3;
9088 0 : f1 = f1*w+4.371064420753005429514E-5;
9089 0 : f1 = f1*w+2.141783679522602903795E-6;
9090 0 : f2 = 1.000000000000000000000;
9091 0 : f2 = f2*w+8.585231423622028380768E-1;
9092 0 : f2 = f2*w+4.483285822873995129957E-1;
9093 0 : f2 = f2*w+7.687932158124475434091E-2;
9094 0 : f2 = f2*w+2.449868241021887685904E-2;
9095 0 : f2 = f2*w+8.832165941927796567926E-4;
9096 0 : f2 = f2*w+4.590952299511353531215E-4;
9097 0 : f2 = f2*w+(-4.729848351866523044863E-6);
9098 0 : f2 = f2*w+2.665195537390710170105E-6;
9099 0 : f = f1/f2;
9100 0 : result = ae_exp(x, _state)*w*(1+w*f);
9101 0 : return result;
9102 : }
9103 0 : if( ae_fp_less(x,(double)(16)) )
9104 : {
9105 0 : w = 1/x;
9106 0 : f1 = -2.106934601691916512584;
9107 0 : f1 = f1*w+1.732733869664688041885;
9108 0 : f1 = f1*w-2.423619178935841904839E-1;
9109 0 : f1 = f1*w+2.322724180937565842585E-2;
9110 0 : f1 = f1*w+2.372880440493179832059E-4;
9111 0 : f1 = f1*w-8.343219561192552752335E-5;
9112 0 : f1 = f1*w+1.363408795605250394881E-5;
9113 0 : f1 = f1*w-3.655412321999253963714E-7;
9114 0 : f1 = f1*w+1.464941733975961318456E-8;
9115 0 : f1 = f1*w+6.176407863710360207074E-10;
9116 0 : f2 = 1.000000000000000000000;
9117 0 : f2 = f2*w-2.298062239901678075778E-1;
9118 0 : f2 = f2*w+1.105077041474037862347E-1;
9119 0 : f2 = f2*w-1.566542966630792353556E-2;
9120 0 : f2 = f2*w+2.761106850817352773874E-3;
9121 0 : f2 = f2*w-2.089148012284048449115E-4;
9122 0 : f2 = f2*w+1.708528938807675304186E-5;
9123 0 : f2 = f2*w-4.459311796356686423199E-7;
9124 0 : f2 = f2*w+1.394634930353847498145E-8;
9125 0 : f2 = f2*w+6.150865933977338354138E-10;
9126 0 : f = f1/f2;
9127 0 : result = ae_exp(x, _state)*w*(1+w*f);
9128 0 : return result;
9129 : }
9130 0 : if( ae_fp_less(x,(double)(32)) )
9131 : {
9132 0 : w = 1/x;
9133 0 : f1 = -2.458119367674020323359E-1;
9134 0 : f1 = f1*w-1.483382253322077687183E-1;
9135 0 : f1 = f1*w+7.248291795735551591813E-2;
9136 0 : f1 = f1*w-1.348315687380940523823E-2;
9137 0 : f1 = f1*w+1.342775069788636972294E-3;
9138 0 : f1 = f1*w-7.942465637159712264564E-5;
9139 0 : f1 = f1*w+2.644179518984235952241E-6;
9140 0 : f1 = f1*w-4.239473659313765177195E-8;
9141 0 : f2 = 1.000000000000000000000;
9142 0 : f2 = f2*w-1.044225908443871106315E-1;
9143 0 : f2 = f2*w-2.676453128101402655055E-1;
9144 0 : f2 = f2*w+9.695000254621984627876E-2;
9145 0 : f2 = f2*w-1.601745692712991078208E-2;
9146 0 : f2 = f2*w+1.496414899205908021882E-3;
9147 0 : f2 = f2*w-8.462452563778485013756E-5;
9148 0 : f2 = f2*w+2.728938403476726394024E-6;
9149 0 : f2 = f2*w-4.239462431819542051337E-8;
9150 0 : f = f1/f2;
9151 0 : result = ae_exp(x, _state)*w*(1+w*f);
9152 0 : return result;
9153 : }
9154 0 : if( ae_fp_less(x,(double)(64)) )
9155 : {
9156 0 : w = 1/x;
9157 0 : f1 = 1.212561118105456670844E-1;
9158 0 : f1 = f1*w-5.823133179043894485122E-1;
9159 0 : f1 = f1*w+2.348887314557016779211E-1;
9160 0 : f1 = f1*w-3.040034318113248237280E-2;
9161 0 : f1 = f1*w+1.510082146865190661777E-3;
9162 0 : f1 = f1*w-2.523137095499571377122E-5;
9163 0 : f2 = 1.000000000000000000000;
9164 0 : f2 = f2*w-1.002252150365854016662;
9165 0 : f2 = f2*w+2.928709694872224144953E-1;
9166 0 : f2 = f2*w-3.337004338674007801307E-2;
9167 0 : f2 = f2*w+1.560544881127388842819E-3;
9168 0 : f2 = f2*w-2.523137093603234562648E-5;
9169 0 : f = f1/f2;
9170 0 : result = ae_exp(x, _state)*w*(1+w*f);
9171 0 : return result;
9172 : }
9173 0 : w = 1/x;
9174 0 : f1 = -7.657847078286127362028E-1;
9175 0 : f1 = f1*w+6.886192415566705051750E-1;
9176 0 : f1 = f1*w-2.132598113545206124553E-1;
9177 0 : f1 = f1*w+3.346107552384193813594E-2;
9178 0 : f1 = f1*w-3.076541477344756050249E-3;
9179 0 : f1 = f1*w+1.747119316454907477380E-4;
9180 0 : f1 = f1*w-6.103711682274170530369E-6;
9181 0 : f1 = f1*w+1.218032765428652199087E-7;
9182 0 : f1 = f1*w-1.086076102793290233007E-9;
9183 0 : f2 = 1.000000000000000000000;
9184 0 : f2 = f2*w-1.888802868662308731041;
9185 0 : f2 = f2*w+1.066691687211408896850;
9186 0 : f2 = f2*w-2.751915982306380647738E-1;
9187 0 : f2 = f2*w+3.930852688233823569726E-2;
9188 0 : f2 = f2*w-3.414684558602365085394E-3;
9189 0 : f2 = f2*w+1.866844370703555398195E-4;
9190 0 : f2 = f2*w-6.345146083130515357861E-6;
9191 0 : f2 = f2*w+1.239754287483206878024E-7;
9192 0 : f2 = f2*w-1.086076102793126632978E-9;
9193 0 : f = f1/f2;
9194 0 : result = ae_exp(x, _state)*w*(1+w*f);
9195 0 : return result;
9196 : }
9197 :
9198 :
9199 : /*************************************************************************
9200 : Exponential integral En(x)
9201 :
9202 : Evaluates the exponential integral
9203 :
9204 : inf.
9205 : -
9206 : | | -xt
9207 : | e
9208 : E (x) = | ---- dt.
9209 : n | n
9210 : | | t
9211 : -
9212 : 1
9213 :
9214 :
9215 : Both n and x must be nonnegative.
9216 :
9217 : The routine employs either a power series, a continued
9218 : fraction, or an asymptotic formula depending on the
9219 : relative values of n and x.
9220 :
9221 : ACCURACY:
9222 :
9223 : Relative error:
9224 : arithmetic domain # trials peak rms
9225 : IEEE 0, 30 10000 1.7e-15 3.6e-16
9226 :
9227 : Cephes Math Library Release 2.8: June, 2000
9228 : Copyright 1985, 2000 by Stephen L. Moshier
9229 : *************************************************************************/
9230 0 : double exponentialintegralen(double x, ae_int_t n, ae_state *_state)
9231 : {
9232 : double r;
9233 : double t;
9234 : double yk;
9235 : double xk;
9236 : double pk;
9237 : double pkm1;
9238 : double pkm2;
9239 : double qk;
9240 : double qkm1;
9241 : double qkm2;
9242 : double psi;
9243 : double z;
9244 : ae_int_t i;
9245 : ae_int_t k;
9246 : double big;
9247 : double eul;
9248 : double result;
9249 :
9250 :
9251 0 : eul = 0.57721566490153286060;
9252 0 : big = 1.44115188075855872*ae_pow((double)(10), (double)(17), _state);
9253 0 : if( ((n<0||ae_fp_less(x,(double)(0)))||ae_fp_greater(x,(double)(170)))||(ae_fp_eq(x,(double)(0))&&n<2) )
9254 : {
9255 0 : result = (double)(-1);
9256 0 : return result;
9257 : }
9258 0 : if( ae_fp_eq(x,(double)(0)) )
9259 : {
9260 0 : result = (double)1/(double)(n-1);
9261 0 : return result;
9262 : }
9263 0 : if( n==0 )
9264 : {
9265 0 : result = ae_exp(-x, _state)/x;
9266 0 : return result;
9267 : }
9268 0 : if( n>5000 )
9269 : {
9270 0 : xk = x+n;
9271 0 : yk = 1/(xk*xk);
9272 0 : t = (double)(n);
9273 0 : result = yk*t*(6*x*x-8*t*x+t*t);
9274 0 : result = yk*(result+t*(t-2.0*x));
9275 0 : result = yk*(result+t);
9276 0 : result = (result+1)*ae_exp(-x, _state)/xk;
9277 0 : return result;
9278 : }
9279 0 : if( ae_fp_less_eq(x,(double)(1)) )
9280 : {
9281 0 : psi = -eul-ae_log(x, _state);
9282 0 : for(i=1; i<=n-1; i++)
9283 : {
9284 0 : psi = psi+(double)1/(double)i;
9285 : }
9286 0 : z = -x;
9287 0 : xk = (double)(0);
9288 0 : yk = (double)(1);
9289 0 : pk = (double)(1-n);
9290 0 : if( n==1 )
9291 : {
9292 0 : result = 0.0;
9293 : }
9294 : else
9295 : {
9296 0 : result = 1.0/pk;
9297 : }
9298 0 : do
9299 : {
9300 0 : xk = xk+1;
9301 0 : yk = yk*z/xk;
9302 0 : pk = pk+1;
9303 0 : if( ae_fp_neq(pk,(double)(0)) )
9304 : {
9305 0 : result = result+yk/pk;
9306 : }
9307 0 : if( ae_fp_neq(result,(double)(0)) )
9308 : {
9309 0 : t = ae_fabs(yk/result, _state);
9310 : }
9311 : else
9312 : {
9313 0 : t = (double)(1);
9314 : }
9315 : }
9316 0 : while(ae_fp_greater_eq(t,ae_machineepsilon));
9317 0 : t = (double)(1);
9318 0 : for(i=1; i<=n-1; i++)
9319 : {
9320 0 : t = t*z/i;
9321 : }
9322 0 : result = psi*t-result;
9323 0 : return result;
9324 : }
9325 : else
9326 : {
9327 0 : k = 1;
9328 0 : pkm2 = (double)(1);
9329 0 : qkm2 = x;
9330 0 : pkm1 = 1.0;
9331 0 : qkm1 = x+n;
9332 0 : result = pkm1/qkm1;
9333 0 : do
9334 : {
9335 0 : k = k+1;
9336 0 : if( k%2==1 )
9337 : {
9338 0 : yk = (double)(1);
9339 0 : xk = n+(double)(k-1)/(double)2;
9340 : }
9341 : else
9342 : {
9343 0 : yk = x;
9344 0 : xk = (double)k/(double)2;
9345 : }
9346 0 : pk = pkm1*yk+pkm2*xk;
9347 0 : qk = qkm1*yk+qkm2*xk;
9348 0 : if( ae_fp_neq(qk,(double)(0)) )
9349 : {
9350 0 : r = pk/qk;
9351 0 : t = ae_fabs((result-r)/r, _state);
9352 0 : result = r;
9353 : }
9354 : else
9355 : {
9356 0 : t = (double)(1);
9357 : }
9358 0 : pkm2 = pkm1;
9359 0 : pkm1 = pk;
9360 0 : qkm2 = qkm1;
9361 0 : qkm1 = qk;
9362 0 : if( ae_fp_greater(ae_fabs(pk, _state),big) )
9363 : {
9364 0 : pkm2 = pkm2/big;
9365 0 : pkm1 = pkm1/big;
9366 0 : qkm2 = qkm2/big;
9367 0 : qkm1 = qkm1/big;
9368 : }
9369 : }
9370 0 : while(ae_fp_greater_eq(t,ae_machineepsilon));
9371 0 : result = result*ae_exp(-x, _state);
9372 : }
9373 0 : return result;
9374 : }
9375 :
9376 :
9377 : #endif
9378 : #if defined(AE_COMPILE_LAGUERRE) || !defined(AE_PARTIAL_BUILD)
9379 :
9380 :
9381 : /*************************************************************************
9382 : Calculation of the value of the Laguerre polynomial.
9383 :
9384 : Parameters:
9385 : n - degree, n>=0
9386 : x - argument
9387 :
9388 : Result:
9389 : the value of the Laguerre polynomial Ln at x
9390 : *************************************************************************/
9391 0 : double laguerrecalculate(ae_int_t n, double x, ae_state *_state)
9392 : {
9393 : double a;
9394 : double b;
9395 : double i;
9396 : double result;
9397 :
9398 :
9399 0 : result = (double)(1);
9400 0 : a = (double)(1);
9401 0 : b = 1-x;
9402 0 : if( n==1 )
9403 : {
9404 0 : result = b;
9405 : }
9406 0 : i = (double)(2);
9407 0 : while(ae_fp_less_eq(i,(double)(n)))
9408 : {
9409 0 : result = ((2*i-1-x)*b-(i-1)*a)/i;
9410 0 : a = b;
9411 0 : b = result;
9412 0 : i = i+1;
9413 : }
9414 0 : return result;
9415 : }
9416 :
9417 :
9418 : /*************************************************************************
9419 : Summation of Laguerre polynomials using Clenshaw's recurrence formula.
9420 :
9421 : This routine calculates c[0]*L0(x) + c[1]*L1(x) + ... + c[N]*LN(x)
9422 :
9423 : Parameters:
9424 : n - degree, n>=0
9425 : x - argument
9426 :
9427 : Result:
9428 : the value of the Laguerre polynomial at x
9429 : *************************************************************************/
9430 0 : double laguerresum(/* Real */ ae_vector* c,
9431 : ae_int_t n,
9432 : double x,
9433 : ae_state *_state)
9434 : {
9435 : double b1;
9436 : double b2;
9437 : ae_int_t i;
9438 : double result;
9439 :
9440 :
9441 0 : b1 = (double)(0);
9442 0 : b2 = (double)(0);
9443 0 : result = (double)(0);
9444 0 : for(i=n; i>=0; i--)
9445 : {
9446 0 : result = (2*i+1-x)*b1/(i+1)-(i+1)*b2/(i+2)+c->ptr.p_double[i];
9447 0 : b2 = b1;
9448 0 : b1 = result;
9449 : }
9450 0 : return result;
9451 : }
9452 :
9453 :
9454 : /*************************************************************************
9455 : Representation of Ln as C[0] + C[1]*X + ... + C[N]*X^N
9456 :
9457 : Input parameters:
9458 : N - polynomial degree, n>=0
9459 :
9460 : Output parameters:
9461 : C - coefficients
9462 : *************************************************************************/
9463 0 : void laguerrecoefficients(ae_int_t n,
9464 : /* Real */ ae_vector* c,
9465 : ae_state *_state)
9466 : {
9467 : ae_int_t i;
9468 :
9469 0 : ae_vector_clear(c);
9470 :
9471 0 : ae_vector_set_length(c, n+1, _state);
9472 0 : c->ptr.p_double[0] = (double)(1);
9473 0 : for(i=0; i<=n-1; i++)
9474 : {
9475 0 : c->ptr.p_double[i+1] = -c->ptr.p_double[i]*(n-i)/(i+1)/(i+1);
9476 : }
9477 0 : }
9478 :
9479 :
9480 : #endif
9481 : #if defined(AE_COMPILE_CHISQUAREDISTR) || !defined(AE_PARTIAL_BUILD)
9482 :
9483 :
9484 : /*************************************************************************
9485 : Chi-square distribution
9486 :
9487 : Returns the area under the left hand tail (from 0 to x)
9488 : of the Chi square probability density function with
9489 : v degrees of freedom.
9490 :
9491 :
9492 : x
9493 : -
9494 : 1 | | v/2-1 -t/2
9495 : P( x | v ) = ----------- | t e dt
9496 : v/2 - | |
9497 : 2 | (v/2) -
9498 : 0
9499 :
9500 : where x is the Chi-square variable.
9501 :
9502 : The incomplete gamma integral is used, according to the
9503 : formula
9504 :
9505 : y = chdtr( v, x ) = igam( v/2.0, x/2.0 ).
9506 :
9507 : The arguments must both be positive.
9508 :
9509 : ACCURACY:
9510 :
9511 : See incomplete gamma function
9512 :
9513 :
9514 : Cephes Math Library Release 2.8: June, 2000
9515 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
9516 : *************************************************************************/
9517 0 : double chisquaredistribution(double v, double x, ae_state *_state)
9518 : {
9519 : double result;
9520 :
9521 :
9522 0 : ae_assert(ae_fp_greater_eq(x,(double)(0))&&ae_fp_greater_eq(v,(double)(1)), "Domain error in ChiSquareDistribution", _state);
9523 0 : result = incompletegamma(v/2.0, x/2.0, _state);
9524 0 : return result;
9525 : }
9526 :
9527 :
9528 : /*************************************************************************
9529 : Complemented Chi-square distribution
9530 :
9531 : Returns the area under the right hand tail (from x to
9532 : infinity) of the Chi square probability density function
9533 : with v degrees of freedom:
9534 :
9535 : inf.
9536 : -
9537 : 1 | | v/2-1 -t/2
9538 : P( x | v ) = ----------- | t e dt
9539 : v/2 - | |
9540 : 2 | (v/2) -
9541 : x
9542 :
9543 : where x is the Chi-square variable.
9544 :
9545 : The incomplete gamma integral is used, according to the
9546 : formula
9547 :
9548 : y = chdtr( v, x ) = igamc( v/2.0, x/2.0 ).
9549 :
9550 : The arguments must both be positive.
9551 :
9552 : ACCURACY:
9553 :
9554 : See incomplete gamma function
9555 :
9556 : Cephes Math Library Release 2.8: June, 2000
9557 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
9558 : *************************************************************************/
9559 0 : double chisquarecdistribution(double v, double x, ae_state *_state)
9560 : {
9561 : double result;
9562 :
9563 :
9564 0 : ae_assert(ae_fp_greater_eq(x,(double)(0))&&ae_fp_greater_eq(v,(double)(1)), "Domain error in ChiSquareDistributionC", _state);
9565 0 : result = incompletegammac(v/2.0, x/2.0, _state);
9566 0 : return result;
9567 : }
9568 :
9569 :
9570 : /*************************************************************************
9571 : Inverse of complemented Chi-square distribution
9572 :
9573 : Finds the Chi-square argument x such that the integral
9574 : from x to infinity of the Chi-square density is equal
9575 : to the given cumulative probability y.
9576 :
9577 : This is accomplished using the inverse gamma integral
9578 : function and the relation
9579 :
9580 : x/2 = igami( df/2, y );
9581 :
9582 : ACCURACY:
9583 :
9584 : See inverse incomplete gamma function
9585 :
9586 :
9587 : Cephes Math Library Release 2.8: June, 2000
9588 : Copyright 1984, 1987, 2000 by Stephen L. Moshier
9589 : *************************************************************************/
9590 0 : double invchisquaredistribution(double v, double y, ae_state *_state)
9591 : {
9592 : double result;
9593 :
9594 :
9595 0 : ae_assert((ae_fp_greater_eq(y,(double)(0))&&ae_fp_less_eq(y,(double)(1)))&&ae_fp_greater_eq(v,(double)(1)), "Domain error in InvChiSquareDistribution", _state);
9596 0 : result = 2*invincompletegammac(0.5*v, y, _state);
9597 0 : return result;
9598 : }
9599 :
9600 :
9601 : #endif
9602 : #if defined(AE_COMPILE_LEGENDRE) || !defined(AE_PARTIAL_BUILD)
9603 :
9604 :
9605 : /*************************************************************************
9606 : Calculation of the value of the Legendre polynomial Pn.
9607 :
9608 : Parameters:
9609 : n - degree, n>=0
9610 : x - argument
9611 :
9612 : Result:
9613 : the value of the Legendre polynomial Pn at x
9614 : *************************************************************************/
9615 0 : double legendrecalculate(ae_int_t n, double x, ae_state *_state)
9616 : {
9617 : double a;
9618 : double b;
9619 : ae_int_t i;
9620 : double result;
9621 :
9622 :
9623 0 : result = (double)(1);
9624 0 : a = (double)(1);
9625 0 : b = x;
9626 0 : if( n==0 )
9627 : {
9628 0 : result = a;
9629 0 : return result;
9630 : }
9631 0 : if( n==1 )
9632 : {
9633 0 : result = b;
9634 0 : return result;
9635 : }
9636 0 : for(i=2; i<=n; i++)
9637 : {
9638 0 : result = ((2*i-1)*x*b-(i-1)*a)/i;
9639 0 : a = b;
9640 0 : b = result;
9641 : }
9642 0 : return result;
9643 : }
9644 :
9645 :
9646 : /*************************************************************************
9647 : Summation of Legendre polynomials using Clenshaw's recurrence formula.
9648 :
9649 : This routine calculates
9650 : c[0]*P0(x) + c[1]*P1(x) + ... + c[N]*PN(x)
9651 :
9652 : Parameters:
9653 : n - degree, n>=0
9654 : x - argument
9655 :
9656 : Result:
9657 : the value of the Legendre polynomial at x
9658 : *************************************************************************/
9659 0 : double legendresum(/* Real */ ae_vector* c,
9660 : ae_int_t n,
9661 : double x,
9662 : ae_state *_state)
9663 : {
9664 : double b1;
9665 : double b2;
9666 : ae_int_t i;
9667 : double result;
9668 :
9669 :
9670 0 : b1 = (double)(0);
9671 0 : b2 = (double)(0);
9672 0 : result = (double)(0);
9673 0 : for(i=n; i>=0; i--)
9674 : {
9675 0 : result = (2*i+1)*x*b1/(i+1)-(i+1)*b2/(i+2)+c->ptr.p_double[i];
9676 0 : b2 = b1;
9677 0 : b1 = result;
9678 : }
9679 0 : return result;
9680 : }
9681 :
9682 :
9683 : /*************************************************************************
9684 : Representation of Pn as C[0] + C[1]*X + ... + C[N]*X^N
9685 :
9686 : Input parameters:
9687 : N - polynomial degree, n>=0
9688 :
9689 : Output parameters:
9690 : C - coefficients
9691 : *************************************************************************/
9692 0 : void legendrecoefficients(ae_int_t n,
9693 : /* Real */ ae_vector* c,
9694 : ae_state *_state)
9695 : {
9696 : ae_int_t i;
9697 :
9698 0 : ae_vector_clear(c);
9699 :
9700 0 : ae_vector_set_length(c, n+1, _state);
9701 0 : for(i=0; i<=n; i++)
9702 : {
9703 0 : c->ptr.p_double[i] = (double)(0);
9704 : }
9705 0 : c->ptr.p_double[n] = (double)(1);
9706 0 : for(i=1; i<=n; i++)
9707 : {
9708 0 : c->ptr.p_double[n] = c->ptr.p_double[n]*(n+i)/2/i;
9709 : }
9710 0 : for(i=0; i<=n/2-1; i++)
9711 : {
9712 0 : c->ptr.p_double[n-2*(i+1)] = -c->ptr.p_double[n-2*i]*(n-2*i)*(n-2*i-1)/2/(i+1)/(2*(n-i)-1);
9713 : }
9714 0 : }
9715 :
9716 :
9717 : #endif
9718 : #if defined(AE_COMPILE_BETAF) || !defined(AE_PARTIAL_BUILD)
9719 :
9720 :
9721 : /*************************************************************************
9722 : Beta function
9723 :
9724 :
9725 : - -
9726 : | (a) | (b)
9727 : beta( a, b ) = -----------.
9728 : -
9729 : | (a+b)
9730 :
9731 : For large arguments the logarithm of the function is
9732 : evaluated using lgam(), then exponentiated.
9733 :
9734 : ACCURACY:
9735 :
9736 : Relative error:
9737 : arithmetic domain # trials peak rms
9738 : IEEE 0,30 30000 8.1e-14 1.1e-14
9739 :
9740 : Cephes Math Library Release 2.0: April, 1987
9741 : Copyright 1984, 1987 by Stephen L. Moshier
9742 : *************************************************************************/
9743 0 : double beta(double a, double b, ae_state *_state)
9744 : {
9745 : double y;
9746 : double sg;
9747 : double s;
9748 : double result;
9749 :
9750 :
9751 0 : sg = (double)(1);
9752 0 : ae_assert(ae_fp_greater(a,(double)(0))||ae_fp_neq(a,(double)(ae_ifloor(a, _state))), "Overflow in Beta", _state);
9753 0 : ae_assert(ae_fp_greater(b,(double)(0))||ae_fp_neq(b,(double)(ae_ifloor(b, _state))), "Overflow in Beta", _state);
9754 0 : y = a+b;
9755 0 : if( ae_fp_greater(ae_fabs(y, _state),171.624376956302725) )
9756 : {
9757 0 : y = lngamma(y, &s, _state);
9758 0 : sg = sg*s;
9759 0 : y = lngamma(b, &s, _state)-y;
9760 0 : sg = sg*s;
9761 0 : y = lngamma(a, &s, _state)+y;
9762 0 : sg = sg*s;
9763 0 : ae_assert(ae_fp_less_eq(y,ae_log(ae_maxrealnumber, _state)), "Overflow in Beta", _state);
9764 0 : result = sg*ae_exp(y, _state);
9765 0 : return result;
9766 : }
9767 0 : y = gammafunction(y, _state);
9768 0 : ae_assert(ae_fp_neq(y,(double)(0)), "Overflow in Beta", _state);
9769 0 : if( ae_fp_greater(a,b) )
9770 : {
9771 0 : y = gammafunction(a, _state)/y;
9772 0 : y = y*gammafunction(b, _state);
9773 : }
9774 : else
9775 : {
9776 0 : y = gammafunction(b, _state)/y;
9777 0 : y = y*gammafunction(a, _state);
9778 : }
9779 0 : result = y;
9780 0 : return result;
9781 : }
9782 :
9783 :
9784 : #endif
9785 : #if defined(AE_COMPILE_CHEBYSHEV) || !defined(AE_PARTIAL_BUILD)
9786 :
9787 :
9788 : /*************************************************************************
9789 : Calculation of the value of the Chebyshev polynomials of the
9790 : first and second kinds.
9791 :
9792 : Parameters:
9793 : r - polynomial kind, either 1 or 2.
9794 : n - degree, n>=0
9795 : x - argument, -1 <= x <= 1
9796 :
9797 : Result:
9798 : the value of the Chebyshev polynomial at x
9799 : *************************************************************************/
9800 0 : double chebyshevcalculate(ae_int_t r,
9801 : ae_int_t n,
9802 : double x,
9803 : ae_state *_state)
9804 : {
9805 : ae_int_t i;
9806 : double a;
9807 : double b;
9808 : double result;
9809 :
9810 :
9811 0 : result = (double)(0);
9812 :
9813 : /*
9814 : * Prepare A and B
9815 : */
9816 0 : if( r==1 )
9817 : {
9818 0 : a = (double)(1);
9819 0 : b = x;
9820 : }
9821 : else
9822 : {
9823 0 : a = (double)(1);
9824 0 : b = 2*x;
9825 : }
9826 :
9827 : /*
9828 : * Special cases: N=0 or N=1
9829 : */
9830 0 : if( n==0 )
9831 : {
9832 0 : result = a;
9833 0 : return result;
9834 : }
9835 0 : if( n==1 )
9836 : {
9837 0 : result = b;
9838 0 : return result;
9839 : }
9840 :
9841 : /*
9842 : * General case: N>=2
9843 : */
9844 0 : for(i=2; i<=n; i++)
9845 : {
9846 0 : result = 2*x*b-a;
9847 0 : a = b;
9848 0 : b = result;
9849 : }
9850 0 : return result;
9851 : }
9852 :
9853 :
9854 : /*************************************************************************
9855 : Summation of Chebyshev polynomials using Clenshaw's recurrence formula.
9856 :
9857 : This routine calculates
9858 : c[0]*T0(x) + c[1]*T1(x) + ... + c[N]*TN(x)
9859 : or
9860 : c[0]*U0(x) + c[1]*U1(x) + ... + c[N]*UN(x)
9861 : depending on the R.
9862 :
9863 : Parameters:
9864 : r - polynomial kind, either 1 or 2.
9865 : n - degree, n>=0
9866 : x - argument
9867 :
9868 : Result:
9869 : the value of the Chebyshev polynomial at x
9870 : *************************************************************************/
9871 0 : double chebyshevsum(/* Real */ ae_vector* c,
9872 : ae_int_t r,
9873 : ae_int_t n,
9874 : double x,
9875 : ae_state *_state)
9876 : {
9877 : double b1;
9878 : double b2;
9879 : ae_int_t i;
9880 : double result;
9881 :
9882 :
9883 0 : b1 = (double)(0);
9884 0 : b2 = (double)(0);
9885 0 : for(i=n; i>=1; i--)
9886 : {
9887 0 : result = 2*x*b1-b2+c->ptr.p_double[i];
9888 0 : b2 = b1;
9889 0 : b1 = result;
9890 : }
9891 0 : if( r==1 )
9892 : {
9893 0 : result = -b2+x*b1+c->ptr.p_double[0];
9894 : }
9895 : else
9896 : {
9897 0 : result = -b2+2*x*b1+c->ptr.p_double[0];
9898 : }
9899 0 : return result;
9900 : }
9901 :
9902 :
9903 : /*************************************************************************
9904 : Representation of Tn as C[0] + C[1]*X + ... + C[N]*X^N
9905 :
9906 : Input parameters:
9907 : N - polynomial degree, n>=0
9908 :
9909 : Output parameters:
9910 : C - coefficients
9911 : *************************************************************************/
9912 0 : void chebyshevcoefficients(ae_int_t n,
9913 : /* Real */ ae_vector* c,
9914 : ae_state *_state)
9915 : {
9916 : ae_int_t i;
9917 :
9918 0 : ae_vector_clear(c);
9919 :
9920 0 : ae_vector_set_length(c, n+1, _state);
9921 0 : for(i=0; i<=n; i++)
9922 : {
9923 0 : c->ptr.p_double[i] = (double)(0);
9924 : }
9925 0 : if( n==0||n==1 )
9926 : {
9927 0 : c->ptr.p_double[n] = (double)(1);
9928 : }
9929 : else
9930 : {
9931 0 : c->ptr.p_double[n] = ae_exp((n-1)*ae_log((double)(2), _state), _state);
9932 0 : for(i=0; i<=n/2-1; i++)
9933 : {
9934 0 : c->ptr.p_double[n-2*(i+1)] = -c->ptr.p_double[n-2*i]*(n-2*i)*(n-2*i-1)/4/(i+1)/(n-i-1);
9935 : }
9936 : }
9937 0 : }
9938 :
9939 :
9940 : /*************************************************************************
9941 : Conversion of a series of Chebyshev polynomials to a power series.
9942 :
9943 : Represents A[0]*T0(x) + A[1]*T1(x) + ... + A[N]*Tn(x) as
9944 : B[0] + B[1]*X + ... + B[N]*X^N.
9945 :
9946 : Input parameters:
9947 : A - Chebyshev series coefficients
9948 : N - degree, N>=0
9949 :
9950 : Output parameters
9951 : B - power series coefficients
9952 : *************************************************************************/
9953 0 : void fromchebyshev(/* Real */ ae_vector* a,
9954 : ae_int_t n,
9955 : /* Real */ ae_vector* b,
9956 : ae_state *_state)
9957 : {
9958 : ae_int_t i;
9959 : ae_int_t k;
9960 : double e;
9961 : double d;
9962 :
9963 0 : ae_vector_clear(b);
9964 :
9965 0 : ae_vector_set_length(b, n+1, _state);
9966 0 : for(i=0; i<=n; i++)
9967 : {
9968 0 : b->ptr.p_double[i] = (double)(0);
9969 : }
9970 0 : d = (double)(0);
9971 0 : i = 0;
9972 0 : do
9973 : {
9974 0 : k = i;
9975 0 : do
9976 : {
9977 0 : e = b->ptr.p_double[k];
9978 0 : b->ptr.p_double[k] = (double)(0);
9979 0 : if( i<=1&&k==i )
9980 : {
9981 0 : b->ptr.p_double[k] = (double)(1);
9982 : }
9983 : else
9984 : {
9985 0 : if( i!=0 )
9986 : {
9987 0 : b->ptr.p_double[k] = 2*d;
9988 : }
9989 0 : if( k>i+1 )
9990 : {
9991 0 : b->ptr.p_double[k] = b->ptr.p_double[k]-b->ptr.p_double[k-2];
9992 : }
9993 : }
9994 0 : d = e;
9995 0 : k = k+1;
9996 : }
9997 0 : while(k<=n);
9998 0 : d = b->ptr.p_double[i];
9999 0 : e = (double)(0);
10000 0 : k = i;
10001 0 : while(k<=n)
10002 : {
10003 0 : e = e+b->ptr.p_double[k]*a->ptr.p_double[k];
10004 0 : k = k+2;
10005 : }
10006 0 : b->ptr.p_double[i] = e;
10007 0 : i = i+1;
10008 : }
10009 0 : while(i<=n);
10010 0 : }
10011 :
10012 :
10013 : #endif
10014 : #if defined(AE_COMPILE_STUDENTTDISTR) || !defined(AE_PARTIAL_BUILD)
10015 :
10016 :
10017 : /*************************************************************************
10018 : Student's t distribution
10019 :
10020 : Computes the integral from minus infinity to t of the Student
10021 : t distribution with integer k > 0 degrees of freedom:
10022 :
10023 : t
10024 : -
10025 : | |
10026 : - | 2 -(k+1)/2
10027 : | ( (k+1)/2 ) | ( x )
10028 : ---------------------- | ( 1 + --- ) dx
10029 : - | ( k )
10030 : sqrt( k pi ) | ( k/2 ) |
10031 : | |
10032 : -
10033 : -inf.
10034 :
10035 : Relation to incomplete beta integral:
10036 :
10037 : 1 - stdtr(k,t) = 0.5 * incbet( k/2, 1/2, z )
10038 : where
10039 : z = k/(k + t**2).
10040 :
10041 : For t < -2, this is the method of computation. For higher t,
10042 : a direct method is derived from integration by parts.
10043 : Since the function is symmetric about t=0, the area under the
10044 : right tail of the density is found by calling the function
10045 : with -t instead of t.
10046 :
10047 : ACCURACY:
10048 :
10049 : Tested at random 1 <= k <= 25. The "domain" refers to t.
10050 : Relative error:
10051 : arithmetic domain # trials peak rms
10052 : IEEE -100,-2 50000 5.9e-15 1.4e-15
10053 : IEEE -2,100 500000 2.7e-15 4.9e-17
10054 :
10055 : Cephes Math Library Release 2.8: June, 2000
10056 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
10057 : *************************************************************************/
10058 0 : double studenttdistribution(ae_int_t k, double t, ae_state *_state)
10059 : {
10060 : double x;
10061 : double rk;
10062 : double z;
10063 : double f;
10064 : double tz;
10065 : double p;
10066 : double xsqk;
10067 : ae_int_t j;
10068 : double result;
10069 :
10070 :
10071 0 : ae_assert(k>0, "Domain error in StudentTDistribution", _state);
10072 0 : if( ae_fp_eq(t,(double)(0)) )
10073 : {
10074 0 : result = 0.5;
10075 0 : return result;
10076 : }
10077 0 : if( ae_fp_less(t,-2.0) )
10078 : {
10079 0 : rk = (double)(k);
10080 0 : z = rk/(rk+t*t);
10081 0 : result = 0.5*incompletebeta(0.5*rk, 0.5, z, _state);
10082 0 : return result;
10083 : }
10084 0 : if( ae_fp_less(t,(double)(0)) )
10085 : {
10086 0 : x = -t;
10087 : }
10088 : else
10089 : {
10090 0 : x = t;
10091 : }
10092 0 : rk = (double)(k);
10093 0 : z = 1.0+x*x/rk;
10094 0 : if( k%2!=0 )
10095 : {
10096 0 : xsqk = x/ae_sqrt(rk, _state);
10097 0 : p = ae_atan(xsqk, _state);
10098 0 : if( k>1 )
10099 : {
10100 0 : f = 1.0;
10101 0 : tz = 1.0;
10102 0 : j = 3;
10103 0 : while(j<=k-2&&ae_fp_greater(tz/f,ae_machineepsilon))
10104 : {
10105 0 : tz = tz*((j-1)/(z*j));
10106 0 : f = f+tz;
10107 0 : j = j+2;
10108 : }
10109 0 : p = p+f*xsqk/z;
10110 : }
10111 0 : p = p*2.0/ae_pi;
10112 : }
10113 : else
10114 : {
10115 0 : f = 1.0;
10116 0 : tz = 1.0;
10117 0 : j = 2;
10118 0 : while(j<=k-2&&ae_fp_greater(tz/f,ae_machineepsilon))
10119 : {
10120 0 : tz = tz*((j-1)/(z*j));
10121 0 : f = f+tz;
10122 0 : j = j+2;
10123 : }
10124 0 : p = f*x/ae_sqrt(z*rk, _state);
10125 : }
10126 0 : if( ae_fp_less(t,(double)(0)) )
10127 : {
10128 0 : p = -p;
10129 : }
10130 0 : result = 0.5+0.5*p;
10131 0 : return result;
10132 : }
10133 :
10134 :
10135 : /*************************************************************************
10136 : Functional inverse of Student's t distribution
10137 :
10138 : Given probability p, finds the argument t such that stdtr(k,t)
10139 : is equal to p.
10140 :
10141 : ACCURACY:
10142 :
10143 : Tested at random 1 <= k <= 100. The "domain" refers to p:
10144 : Relative error:
10145 : arithmetic domain # trials peak rms
10146 : IEEE .001,.999 25000 5.7e-15 8.0e-16
10147 : IEEE 10^-6,.001 25000 2.0e-12 2.9e-14
10148 :
10149 : Cephes Math Library Release 2.8: June, 2000
10150 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
10151 : *************************************************************************/
10152 0 : double invstudenttdistribution(ae_int_t k, double p, ae_state *_state)
10153 : {
10154 : double t;
10155 : double rk;
10156 : double z;
10157 : ae_int_t rflg;
10158 : double result;
10159 :
10160 :
10161 0 : ae_assert((k>0&&ae_fp_greater(p,(double)(0)))&&ae_fp_less(p,(double)(1)), "Domain error in InvStudentTDistribution", _state);
10162 0 : rk = (double)(k);
10163 0 : if( ae_fp_greater(p,0.25)&&ae_fp_less(p,0.75) )
10164 : {
10165 0 : if( ae_fp_eq(p,0.5) )
10166 : {
10167 0 : result = (double)(0);
10168 0 : return result;
10169 : }
10170 0 : z = 1.0-2.0*p;
10171 0 : z = invincompletebeta(0.5, 0.5*rk, ae_fabs(z, _state), _state);
10172 0 : t = ae_sqrt(rk*z/(1.0-z), _state);
10173 0 : if( ae_fp_less(p,0.5) )
10174 : {
10175 0 : t = -t;
10176 : }
10177 0 : result = t;
10178 0 : return result;
10179 : }
10180 0 : rflg = -1;
10181 0 : if( ae_fp_greater_eq(p,0.5) )
10182 : {
10183 0 : p = 1.0-p;
10184 0 : rflg = 1;
10185 : }
10186 0 : z = invincompletebeta(0.5*rk, 0.5, 2.0*p, _state);
10187 0 : if( ae_fp_less(ae_maxrealnumber*z,rk) )
10188 : {
10189 0 : result = rflg*ae_maxrealnumber;
10190 0 : return result;
10191 : }
10192 0 : t = ae_sqrt(rk/z-rk, _state);
10193 0 : result = rflg*t;
10194 0 : return result;
10195 : }
10196 :
10197 :
10198 : #endif
10199 : #if defined(AE_COMPILE_BINOMIALDISTR) || !defined(AE_PARTIAL_BUILD)
10200 :
10201 :
10202 : /*************************************************************************
10203 : Binomial distribution
10204 :
10205 : Returns the sum of the terms 0 through k of the Binomial
10206 : probability density:
10207 :
10208 : k
10209 : -- ( n ) j n-j
10210 : > ( ) p (1-p)
10211 : -- ( j )
10212 : j=0
10213 :
10214 : The terms are not summed directly; instead the incomplete
10215 : beta integral is employed, according to the formula
10216 :
10217 : y = bdtr( k, n, p ) = incbet( n-k, k+1, 1-p ).
10218 :
10219 : The arguments must be positive, with p ranging from 0 to 1.
10220 :
10221 : ACCURACY:
10222 :
10223 : Tested at random points (a,b,p), with p between 0 and 1.
10224 :
10225 : a,b Relative error:
10226 : arithmetic domain # trials peak rms
10227 : For p between 0.001 and 1:
10228 : IEEE 0,100 100000 4.3e-15 2.6e-16
10229 :
10230 : Cephes Math Library Release 2.8: June, 2000
10231 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
10232 : *************************************************************************/
10233 0 : double binomialdistribution(ae_int_t k,
10234 : ae_int_t n,
10235 : double p,
10236 : ae_state *_state)
10237 : {
10238 : double dk;
10239 : double dn;
10240 : double result;
10241 :
10242 :
10243 0 : ae_assert(ae_fp_greater_eq(p,(double)(0))&&ae_fp_less_eq(p,(double)(1)), "Domain error in BinomialDistribution", _state);
10244 0 : ae_assert(k>=-1&&k<=n, "Domain error in BinomialDistribution", _state);
10245 0 : if( k==-1 )
10246 : {
10247 0 : result = (double)(0);
10248 0 : return result;
10249 : }
10250 0 : if( k==n )
10251 : {
10252 0 : result = (double)(1);
10253 0 : return result;
10254 : }
10255 0 : dn = (double)(n-k);
10256 0 : if( k==0 )
10257 : {
10258 0 : dk = ae_pow(1.0-p, dn, _state);
10259 : }
10260 : else
10261 : {
10262 0 : dk = (double)(k+1);
10263 0 : dk = incompletebeta(dn, dk, 1.0-p, _state);
10264 : }
10265 0 : result = dk;
10266 0 : return result;
10267 : }
10268 :
10269 :
10270 : /*************************************************************************
10271 : Complemented binomial distribution
10272 :
10273 : Returns the sum of the terms k+1 through n of the Binomial
10274 : probability density:
10275 :
10276 : n
10277 : -- ( n ) j n-j
10278 : > ( ) p (1-p)
10279 : -- ( j )
10280 : j=k+1
10281 :
10282 : The terms are not summed directly; instead the incomplete
10283 : beta integral is employed, according to the formula
10284 :
10285 : y = bdtrc( k, n, p ) = incbet( k+1, n-k, p ).
10286 :
10287 : The arguments must be positive, with p ranging from 0 to 1.
10288 :
10289 : ACCURACY:
10290 :
10291 : Tested at random points (a,b,p).
10292 :
10293 : a,b Relative error:
10294 : arithmetic domain # trials peak rms
10295 : For p between 0.001 and 1:
10296 : IEEE 0,100 100000 6.7e-15 8.2e-16
10297 : For p between 0 and .001:
10298 : IEEE 0,100 100000 1.5e-13 2.7e-15
10299 :
10300 : Cephes Math Library Release 2.8: June, 2000
10301 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
10302 : *************************************************************************/
10303 0 : double binomialcdistribution(ae_int_t k,
10304 : ae_int_t n,
10305 : double p,
10306 : ae_state *_state)
10307 : {
10308 : double dk;
10309 : double dn;
10310 : double result;
10311 :
10312 :
10313 0 : ae_assert(ae_fp_greater_eq(p,(double)(0))&&ae_fp_less_eq(p,(double)(1)), "Domain error in BinomialDistributionC", _state);
10314 0 : ae_assert(k>=-1&&k<=n, "Domain error in BinomialDistributionC", _state);
10315 0 : if( k==-1 )
10316 : {
10317 0 : result = (double)(1);
10318 0 : return result;
10319 : }
10320 0 : if( k==n )
10321 : {
10322 0 : result = (double)(0);
10323 0 : return result;
10324 : }
10325 0 : dn = (double)(n-k);
10326 0 : if( k==0 )
10327 : {
10328 0 : if( ae_fp_less(p,0.01) )
10329 : {
10330 0 : dk = -nuexpm1(dn*nulog1p(-p, _state), _state);
10331 : }
10332 : else
10333 : {
10334 0 : dk = 1.0-ae_pow(1.0-p, dn, _state);
10335 : }
10336 : }
10337 : else
10338 : {
10339 0 : dk = (double)(k+1);
10340 0 : dk = incompletebeta(dk, dn, p, _state);
10341 : }
10342 0 : result = dk;
10343 0 : return result;
10344 : }
10345 :
10346 :
10347 : /*************************************************************************
10348 : Inverse binomial distribution
10349 :
10350 : Finds the event probability p such that the sum of the
10351 : terms 0 through k of the Binomial probability density
10352 : is equal to the given cumulative probability y.
10353 :
10354 : This is accomplished using the inverse beta integral
10355 : function and the relation
10356 :
10357 : 1 - p = incbi( n-k, k+1, y ).
10358 :
10359 : ACCURACY:
10360 :
10361 : Tested at random points (a,b,p).
10362 :
10363 : a,b Relative error:
10364 : arithmetic domain # trials peak rms
10365 : For p between 0.001 and 1:
10366 : IEEE 0,100 100000 2.3e-14 6.4e-16
10367 : IEEE 0,10000 100000 6.6e-12 1.2e-13
10368 : For p between 10^-6 and 0.001:
10369 : IEEE 0,100 100000 2.0e-12 1.3e-14
10370 : IEEE 0,10000 100000 1.5e-12 3.2e-14
10371 :
10372 : Cephes Math Library Release 2.8: June, 2000
10373 : Copyright 1984, 1987, 1995, 2000 by Stephen L. Moshier
10374 : *************************************************************************/
10375 0 : double invbinomialdistribution(ae_int_t k,
10376 : ae_int_t n,
10377 : double y,
10378 : ae_state *_state)
10379 : {
10380 : double dk;
10381 : double dn;
10382 : double p;
10383 : double result;
10384 :
10385 :
10386 0 : ae_assert(k>=0&&k<n, "Domain error in InvBinomialDistribution", _state);
10387 0 : dn = (double)(n-k);
10388 0 : if( k==0 )
10389 : {
10390 0 : if( ae_fp_greater(y,0.8) )
10391 : {
10392 0 : p = -nuexpm1(nulog1p(y-1.0, _state)/dn, _state);
10393 : }
10394 : else
10395 : {
10396 0 : p = 1.0-ae_pow(y, 1.0/dn, _state);
10397 : }
10398 : }
10399 : else
10400 : {
10401 0 : dk = (double)(k+1);
10402 0 : p = incompletebeta(dn, dk, 0.5, _state);
10403 0 : if( ae_fp_greater(p,0.5) )
10404 : {
10405 0 : p = invincompletebeta(dk, dn, 1.0-y, _state);
10406 : }
10407 : else
10408 : {
10409 0 : p = 1.0-invincompletebeta(dn, dk, y, _state);
10410 : }
10411 : }
10412 0 : result = p;
10413 0 : return result;
10414 : }
10415 :
10416 :
10417 : #endif
10418 : #if defined(AE_COMPILE_AIRYF) || !defined(AE_PARTIAL_BUILD)
10419 :
10420 :
10421 : /*************************************************************************
10422 : Airy function
10423 :
10424 : Solution of the differential equation
10425 :
10426 : y"(x) = xy.
10427 :
10428 : The function returns the two independent solutions Ai, Bi
10429 : and their first derivatives Ai'(x), Bi'(x).
10430 :
10431 : Evaluation is by power series summation for small x,
10432 : by rational minimax approximations for large x.
10433 :
10434 :
10435 :
10436 : ACCURACY:
10437 : Error criterion is absolute when function <= 1, relative
10438 : when function > 1, except * denotes relative error criterion.
10439 : For large negative x, the absolute error increases as x^1.5.
10440 : For large positive x, the relative error increases as x^1.5.
10441 :
10442 : Arithmetic domain function # trials peak rms
10443 : IEEE -10, 0 Ai 10000 1.6e-15 2.7e-16
10444 : IEEE 0, 10 Ai 10000 2.3e-14* 1.8e-15*
10445 : IEEE -10, 0 Ai' 10000 4.6e-15 7.6e-16
10446 : IEEE 0, 10 Ai' 10000 1.8e-14* 1.5e-15*
10447 : IEEE -10, 10 Bi 30000 4.2e-15 5.3e-16
10448 : IEEE -10, 10 Bi' 30000 4.9e-15 7.3e-16
10449 :
10450 : Cephes Math Library Release 2.8: June, 2000
10451 : Copyright 1984, 1987, 1989, 2000 by Stephen L. Moshier
10452 : *************************************************************************/
10453 0 : void airy(double x,
10454 : double* ai,
10455 : double* aip,
10456 : double* bi,
10457 : double* bip,
10458 : ae_state *_state)
10459 : {
10460 : double z;
10461 : double zz;
10462 : double t;
10463 : double f;
10464 : double g;
10465 : double uf;
10466 : double ug;
10467 : double k;
10468 : double zeta;
10469 : double theta;
10470 : ae_int_t domflg;
10471 : double c1;
10472 : double c2;
10473 : double sqrt3;
10474 : double sqpii;
10475 : double afn;
10476 : double afd;
10477 : double agn;
10478 : double agd;
10479 : double apfn;
10480 : double apfd;
10481 : double apgn;
10482 : double apgd;
10483 : double an;
10484 : double ad;
10485 : double apn;
10486 : double apd;
10487 : double bn16;
10488 : double bd16;
10489 : double bppn;
10490 : double bppd;
10491 :
10492 0 : *ai = 0;
10493 0 : *aip = 0;
10494 0 : *bi = 0;
10495 0 : *bip = 0;
10496 :
10497 0 : sqpii = 5.64189583547756286948E-1;
10498 0 : c1 = 0.35502805388781723926;
10499 0 : c2 = 0.258819403792806798405;
10500 0 : sqrt3 = 1.732050807568877293527;
10501 0 : domflg = 0;
10502 0 : if( ae_fp_greater(x,25.77) )
10503 : {
10504 0 : *ai = (double)(0);
10505 0 : *aip = (double)(0);
10506 0 : *bi = ae_maxrealnumber;
10507 0 : *bip = ae_maxrealnumber;
10508 0 : return;
10509 : }
10510 0 : if( ae_fp_less(x,-2.09) )
10511 : {
10512 0 : domflg = 15;
10513 0 : t = ae_sqrt(-x, _state);
10514 0 : zeta = -2.0*x*t/3.0;
10515 0 : t = ae_sqrt(t, _state);
10516 0 : k = sqpii/t;
10517 0 : z = 1.0/zeta;
10518 0 : zz = z*z;
10519 0 : afn = -1.31696323418331795333E-1;
10520 0 : afn = afn*zz-6.26456544431912369773E-1;
10521 0 : afn = afn*zz-6.93158036036933542233E-1;
10522 0 : afn = afn*zz-2.79779981545119124951E-1;
10523 0 : afn = afn*zz-4.91900132609500318020E-2;
10524 0 : afn = afn*zz-4.06265923594885404393E-3;
10525 0 : afn = afn*zz-1.59276496239262096340E-4;
10526 0 : afn = afn*zz-2.77649108155232920844E-6;
10527 0 : afn = afn*zz-1.67787698489114633780E-8;
10528 0 : afd = 1.00000000000000000000E0;
10529 0 : afd = afd*zz+1.33560420706553243746E1;
10530 0 : afd = afd*zz+3.26825032795224613948E1;
10531 0 : afd = afd*zz+2.67367040941499554804E1;
10532 0 : afd = afd*zz+9.18707402907259625840E0;
10533 0 : afd = afd*zz+1.47529146771666414581E0;
10534 0 : afd = afd*zz+1.15687173795188044134E-1;
10535 0 : afd = afd*zz+4.40291641615211203805E-3;
10536 0 : afd = afd*zz+7.54720348287414296618E-5;
10537 0 : afd = afd*zz+4.51850092970580378464E-7;
10538 0 : uf = 1.0+zz*afn/afd;
10539 0 : agn = 1.97339932091685679179E-2;
10540 0 : agn = agn*zz+3.91103029615688277255E-1;
10541 0 : agn = agn*zz+1.06579897599595591108E0;
10542 0 : agn = agn*zz+9.39169229816650230044E-1;
10543 0 : agn = agn*zz+3.51465656105547619242E-1;
10544 0 : agn = agn*zz+6.33888919628925490927E-2;
10545 0 : agn = agn*zz+5.85804113048388458567E-3;
10546 0 : agn = agn*zz+2.82851600836737019778E-4;
10547 0 : agn = agn*zz+6.98793669997260967291E-6;
10548 0 : agn = agn*zz+8.11789239554389293311E-8;
10549 0 : agn = agn*zz+3.41551784765923618484E-10;
10550 0 : agd = 1.00000000000000000000E0;
10551 0 : agd = agd*zz+9.30892908077441974853E0;
10552 0 : agd = agd*zz+1.98352928718312140417E1;
10553 0 : agd = agd*zz+1.55646628932864612953E1;
10554 0 : agd = agd*zz+5.47686069422975497931E0;
10555 0 : agd = agd*zz+9.54293611618961883998E-1;
10556 0 : agd = agd*zz+8.64580826352392193095E-2;
10557 0 : agd = agd*zz+4.12656523824222607191E-3;
10558 0 : agd = agd*zz+1.01259085116509135510E-4;
10559 0 : agd = agd*zz+1.17166733214413521882E-6;
10560 0 : agd = agd*zz+4.91834570062930015649E-9;
10561 0 : ug = z*agn/agd;
10562 0 : theta = zeta+0.25*ae_pi;
10563 0 : f = ae_sin(theta, _state);
10564 0 : g = ae_cos(theta, _state);
10565 0 : *ai = k*(f*uf-g*ug);
10566 0 : *bi = k*(g*uf+f*ug);
10567 0 : apfn = 1.85365624022535566142E-1;
10568 0 : apfn = apfn*zz+8.86712188052584095637E-1;
10569 0 : apfn = apfn*zz+9.87391981747398547272E-1;
10570 0 : apfn = apfn*zz+4.01241082318003734092E-1;
10571 0 : apfn = apfn*zz+7.10304926289631174579E-2;
10572 0 : apfn = apfn*zz+5.90618657995661810071E-3;
10573 0 : apfn = apfn*zz+2.33051409401776799569E-4;
10574 0 : apfn = apfn*zz+4.08718778289035454598E-6;
10575 0 : apfn = apfn*zz+2.48379932900442457853E-8;
10576 0 : apfd = 1.00000000000000000000E0;
10577 0 : apfd = apfd*zz+1.47345854687502542552E1;
10578 0 : apfd = apfd*zz+3.75423933435489594466E1;
10579 0 : apfd = apfd*zz+3.14657751203046424330E1;
10580 0 : apfd = apfd*zz+1.09969125207298778536E1;
10581 0 : apfd = apfd*zz+1.78885054766999417817E0;
10582 0 : apfd = apfd*zz+1.41733275753662636873E-1;
10583 0 : apfd = apfd*zz+5.44066067017226003627E-3;
10584 0 : apfd = apfd*zz+9.39421290654511171663E-5;
10585 0 : apfd = apfd*zz+5.65978713036027009243E-7;
10586 0 : uf = 1.0+zz*apfn/apfd;
10587 0 : apgn = -3.55615429033082288335E-2;
10588 0 : apgn = apgn*zz-6.37311518129435504426E-1;
10589 0 : apgn = apgn*zz-1.70856738884312371053E0;
10590 0 : apgn = apgn*zz-1.50221872117316635393E0;
10591 0 : apgn = apgn*zz-5.63606665822102676611E-1;
10592 0 : apgn = apgn*zz-1.02101031120216891789E-1;
10593 0 : apgn = apgn*zz-9.48396695961445269093E-3;
10594 0 : apgn = apgn*zz-4.60325307486780994357E-4;
10595 0 : apgn = apgn*zz-1.14300836484517375919E-5;
10596 0 : apgn = apgn*zz-1.33415518685547420648E-7;
10597 0 : apgn = apgn*zz-5.63803833958893494476E-10;
10598 0 : apgd = 1.00000000000000000000E0;
10599 0 : apgd = apgd*zz+9.85865801696130355144E0;
10600 0 : apgd = apgd*zz+2.16401867356585941885E1;
10601 0 : apgd = apgd*zz+1.73130776389749389525E1;
10602 0 : apgd = apgd*zz+6.17872175280828766327E0;
10603 0 : apgd = apgd*zz+1.08848694396321495475E0;
10604 0 : apgd = apgd*zz+9.95005543440888479402E-2;
10605 0 : apgd = apgd*zz+4.78468199683886610842E-3;
10606 0 : apgd = apgd*zz+1.18159633322838625562E-4;
10607 0 : apgd = apgd*zz+1.37480673554219441465E-6;
10608 0 : apgd = apgd*zz+5.79912514929147598821E-9;
10609 0 : ug = z*apgn/apgd;
10610 0 : k = sqpii*t;
10611 0 : *aip = -k*(g*uf+f*ug);
10612 0 : *bip = k*(f*uf-g*ug);
10613 0 : return;
10614 : }
10615 0 : if( ae_fp_greater_eq(x,2.09) )
10616 : {
10617 0 : domflg = 5;
10618 0 : t = ae_sqrt(x, _state);
10619 0 : zeta = 2.0*x*t/3.0;
10620 0 : g = ae_exp(zeta, _state);
10621 0 : t = ae_sqrt(t, _state);
10622 0 : k = 2.0*t*g;
10623 0 : z = 1.0/zeta;
10624 0 : an = 3.46538101525629032477E-1;
10625 0 : an = an*z+1.20075952739645805542E1;
10626 0 : an = an*z+7.62796053615234516538E1;
10627 0 : an = an*z+1.68089224934630576269E2;
10628 0 : an = an*z+1.59756391350164413639E2;
10629 0 : an = an*z+7.05360906840444183113E1;
10630 0 : an = an*z+1.40264691163389668864E1;
10631 0 : an = an*z+9.99999999999999995305E-1;
10632 0 : ad = 5.67594532638770212846E-1;
10633 0 : ad = ad*z+1.47562562584847203173E1;
10634 0 : ad = ad*z+8.45138970141474626562E1;
10635 0 : ad = ad*z+1.77318088145400459522E2;
10636 0 : ad = ad*z+1.64234692871529701831E2;
10637 0 : ad = ad*z+7.14778400825575695274E1;
10638 0 : ad = ad*z+1.40959135607834029598E1;
10639 0 : ad = ad*z+1.00000000000000000470E0;
10640 0 : f = an/ad;
10641 0 : *ai = sqpii*f/k;
10642 0 : k = -0.5*sqpii*t/g;
10643 0 : apn = 6.13759184814035759225E-1;
10644 0 : apn = apn*z+1.47454670787755323881E1;
10645 0 : apn = apn*z+8.20584123476060982430E1;
10646 0 : apn = apn*z+1.71184781360976385540E2;
10647 0 : apn = apn*z+1.59317847137141783523E2;
10648 0 : apn = apn*z+6.99778599330103016170E1;
10649 0 : apn = apn*z+1.39470856980481566958E1;
10650 0 : apn = apn*z+1.00000000000000000550E0;
10651 0 : apd = 3.34203677749736953049E-1;
10652 0 : apd = apd*z+1.11810297306158156705E1;
10653 0 : apd = apd*z+7.11727352147859965283E1;
10654 0 : apd = apd*z+1.58778084372838313640E2;
10655 0 : apd = apd*z+1.53206427475809220834E2;
10656 0 : apd = apd*z+6.86752304592780337944E1;
10657 0 : apd = apd*z+1.38498634758259442477E1;
10658 0 : apd = apd*z+9.99999999999999994502E-1;
10659 0 : f = apn/apd;
10660 0 : *aip = f*k;
10661 0 : if( ae_fp_greater(x,8.3203353) )
10662 : {
10663 0 : bn16 = -2.53240795869364152689E-1;
10664 0 : bn16 = bn16*z+5.75285167332467384228E-1;
10665 0 : bn16 = bn16*z-3.29907036873225371650E-1;
10666 0 : bn16 = bn16*z+6.44404068948199951727E-2;
10667 0 : bn16 = bn16*z-3.82519546641336734394E-3;
10668 0 : bd16 = 1.00000000000000000000E0;
10669 0 : bd16 = bd16*z-7.15685095054035237902E0;
10670 0 : bd16 = bd16*z+1.06039580715664694291E1;
10671 0 : bd16 = bd16*z-5.23246636471251500874E0;
10672 0 : bd16 = bd16*z+9.57395864378383833152E-1;
10673 0 : bd16 = bd16*z-5.50828147163549611107E-2;
10674 0 : f = z*bn16/bd16;
10675 0 : k = sqpii*g;
10676 0 : *bi = k*(1.0+f)/t;
10677 0 : bppn = 4.65461162774651610328E-1;
10678 0 : bppn = bppn*z-1.08992173800493920734E0;
10679 0 : bppn = bppn*z+6.38800117371827987759E-1;
10680 0 : bppn = bppn*z-1.26844349553102907034E-1;
10681 0 : bppn = bppn*z+7.62487844342109852105E-3;
10682 0 : bppd = 1.00000000000000000000E0;
10683 0 : bppd = bppd*z-8.70622787633159124240E0;
10684 0 : bppd = bppd*z+1.38993162704553213172E1;
10685 0 : bppd = bppd*z-7.14116144616431159572E0;
10686 0 : bppd = bppd*z+1.34008595960680518666E0;
10687 0 : bppd = bppd*z-7.84273211323341930448E-2;
10688 0 : f = z*bppn/bppd;
10689 0 : *bip = k*t*(1.0+f);
10690 0 : return;
10691 : }
10692 : }
10693 0 : f = 1.0;
10694 0 : g = x;
10695 0 : t = 1.0;
10696 0 : uf = 1.0;
10697 0 : ug = x;
10698 0 : k = 1.0;
10699 0 : z = x*x*x;
10700 0 : while(ae_fp_greater(t,ae_machineepsilon))
10701 : {
10702 0 : uf = uf*z;
10703 0 : k = k+1.0;
10704 0 : uf = uf/k;
10705 0 : ug = ug*z;
10706 0 : k = k+1.0;
10707 0 : ug = ug/k;
10708 0 : uf = uf/k;
10709 0 : f = f+uf;
10710 0 : k = k+1.0;
10711 0 : ug = ug/k;
10712 0 : g = g+ug;
10713 0 : t = ae_fabs(uf/f, _state);
10714 : }
10715 0 : uf = c1*f;
10716 0 : ug = c2*g;
10717 0 : if( domflg%2==0 )
10718 : {
10719 0 : *ai = uf-ug;
10720 : }
10721 0 : if( domflg/2%2==0 )
10722 : {
10723 0 : *bi = sqrt3*(uf+ug);
10724 : }
10725 0 : k = 4.0;
10726 0 : uf = x*x/2.0;
10727 0 : ug = z/3.0;
10728 0 : f = uf;
10729 0 : g = 1.0+ug;
10730 0 : uf = uf/3.0;
10731 0 : t = 1.0;
10732 0 : while(ae_fp_greater(t,ae_machineepsilon))
10733 : {
10734 0 : uf = uf*z;
10735 0 : ug = ug/k;
10736 0 : k = k+1.0;
10737 0 : ug = ug*z;
10738 0 : uf = uf/k;
10739 0 : f = f+uf;
10740 0 : k = k+1.0;
10741 0 : ug = ug/k;
10742 0 : uf = uf/k;
10743 0 : g = g+ug;
10744 0 : k = k+1.0;
10745 0 : t = ae_fabs(ug/g, _state);
10746 : }
10747 0 : uf = c1*f;
10748 0 : ug = c2*g;
10749 0 : if( domflg/4%2==0 )
10750 : {
10751 0 : *aip = uf-ug;
10752 : }
10753 0 : if( domflg/8%2==0 )
10754 : {
10755 0 : *bip = sqrt3*(uf+ug);
10756 : }
10757 : }
10758 :
10759 :
10760 : #endif
10761 :
10762 : }
10763 :
|