NAG C Library Chapter Introduction S - Approximations of Special Functions

Download as pdf or txt
Download as pdf or txt
You are on page 1of 9

s Approximations of Special Functions

Introduction s

NAG C Library Chapter Introduction


s Approximations of Special Functions

Contents
1

Scope of the Chapter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

Background to the Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

2.1
2.2
2.3

Functions of a Single Real Argument . . . . . . . . . . . . . . . . . . . . . . . . . . . .


Approximations to Elliptic Integrals . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Bessel and Airy Functions of a Complex Argument . . . . . . . . . . . . . . . . . .

Recommendations on Choice and Use of Available Functions . . . . . . . .

3.1
3.2

Elliptic Integrals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Bessel and Airy Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

Functions Withdrawn or Scheduled for Withdrawal . . . . . . . . . . . . . . .

References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

[NP3645/7]

s.1

NAG C Library Manual

Introduction s

Scope of the Chapter

This chapter is concerned with the provision of some commonly occurring physical and mathematical
functions.

Background to the Problems

The majority of the functions in this chapter approximate real-valued functions of a single real argument,
and the techniques involved are described in Section 2.1. In addition the chapter contains functions for
elliptic integrals (see Section 2.2), Bessel and Airy functions of a complex argument (see Section 2.3),
exponential of a complex argument, and complementary error function of a complex argument.

2.1

Functions of a Single Real Argument

Most of the functions for functions of a single real argument have been based on truncated Chebyshev
expansions. This method of approximation was adopted as a compromise between the conflicting
requirements of efficiency and ease of implementation on many different machine ranges. For details of
the reasons behind this choice and the production and testing procedures followed in constructing this
chapter see Schonfelder (1976).
Basically, if the function to be approximated is fx, then for x 2 a; b an approximation of the form
X0
fx gx
C r T r t
r0

P0

is used (
denotes, according to the usual convention, a summation in which the first term is halved),
where gx is some suitable auxiliary function which extracts any singularities, asymptotes and, if possible,
zeros of the function in the range in question and t tx is a mapping of the general range a; b to the
specific range [1; 1] required by the Chebyshev polynomials, T r t. For a detailed description of the
properties of the Chebyshev polynomials see Clenshaw (1962) and Fox and Parker (1968).
The essential property of these polynomials for the purposes of function approximation is that T n t
oscillates between 1 and it takes its extreme values n 1 times in the interval [1; 1]. Therefore,
provided the coefficients C r decrease in magnitude sufficiently rapidly the error made by truncating the
Chebyshev expansion after n terms is approximately given by
Et C n T n t:
That is, the error oscillates between C n and takes its extreme value n 1 times in the interval in
question. Now this is just the condition that the approximation be a mini-max representation, one which
minimizes the maximum error. By suitable choice of the interval, [a; b], the auxiliary function, gx, and
the mapping of the independent variable, tx, it is almost always possible to obtain a Chebyshev
expansion with rapid convergence and hence truncations that provide near mini-max polynomial
approximations to the required function. The difference between the true mini-max polynomial and the
truncated Chebyshev expansion is seldom sufficiently great enough to be of significance.
The evaluation of the Chebyshev expansions follows one of two methods. The first and most efficient, and
hence the most commonly used, works with the equivalent simple polynomial. The second method, which
is used on the few occasions when the first method proves to be unstable, is based directly on the truncated
Chebyshev series, and uses backward recursion to evaluate the sum. For the first method, a suitably
truncated Chebyshev expansion (truncation is chosen so that the error is less than the machine precision)
is converted to the equivalent simple polynomial. That is, we evaluate the set of coefficients br such that
yt

n1
X
r0

br tr

n1
X
0

C r T r t:

r0

The polynomial can then be evaluated by the efficient Horners method of nested multiplications,
yt b0 tb1 tb2 . . . tbn2 tbn1 . . .:
This method of evaluation results in efficient functions but for some expansions there is considerable loss
of accuracy due to cancellation effects. In these cases the second method is used. It is well known that if

s.2

[NP3645/7]

s Approximations of Special Functions

Introduction s

bn1 C n1
bn2 2tbn1 C n2
bj 2tbj1  bj2 C j ;

j n  3; n  4; . . . ; 0

then
X0

C r T r t 12b0  b2

r0

and this is always stable. This method is most efficiently implemented by using three variables cyclically
and explicitly constructing the recursion.
That is,






..
.

say 

yt

C n1
2t C n2
2t   C n3
2t   C n4
2t   C n5
2t   C 2
2t   C 1
t   12C 0

The auxiliary functions used are normally functions compounded of simple polynomial (usually linear)
factors extracting zeros, and the primary compiler-provided functions, sin, cos, ln, exp, sqrt, which extract
singularities and/or asymptotes or in some cases basic oscillatory behaviour, leaving a smooth wellbehaved function to be approximated by the Chebyshev expansion which can therefore be rapidly
convergent.
The mappings of [a; b] to [1; 1] used range from simple linear mappings to the case when b is infinite,
and considerable improvement in convergence can be obtained by use of a bilinear form of mapping.
Another common form of mapping is used when the function is even; that is, it involves only even powers
in its expansion. In this case an approximation over the whole interval [a; a] can be provided using a
mapping t 2x=a2 1. This embodies the evenness property but the expansion in t involves all powers
and hence removes the necessity of working with an expansion with half its coefficients zero.
For many of the functions an analysis of the error in principle is given, namely, if E and r are the
absolute errors in function and argument and  and  are the corresponding relative errors, then
E

jf 0 xjr

jxf 0 xj
 0 
xf x
:

fx 

If we ignore errors that arise in the argument of the function by propagation of data errors, etc., and
consider only those errors that result from the fact that a real number is being represented in the computer
in floating-point form with finite precision, then  is bounded and this bound is independent of the
magnitude of x. For example, on an 11-digit machine
jj  1011 :
(This of course implies that the absolute error r x is also bounded but the bound is now dependent on
x.) However, because of this the last two relations above are probably of more interest. If possible the
relative error propagation is discussed; that is, the behaviour of the error amplification factor jxf 0 x=fxj
is described, but in some cases, such as near zeros of the function which cannot be extracted explicitly,
absolute error in the result is the quantity of significance and here the factor jxf 0 xj is described. In
general, testing of the functions has shown that their error behaviour follows fairly well these theoretical
error behaviours. In regions where the error amplification factors are less than or of the order of one, the

[NP3645/7]

s.3

NAG C Library Manual

Introduction s

errors are slightly larger than the above predictions. The errors are here limited largely by the finite
precision of arithmetic in the machine, but  is normally no more than a few times greater than the bound
on . In regions where the amplification factors are large, of order ten or greater, the theoretical analysis
gives a good measure of the accuracy obtainable.
It should be noted that the definitions and notations used for the functions in this chapter are all taken from
Abramowitz and Stegun (1972). Users are strongly recommended to consult this book for details before
using the functions in this chapter.

2.2

Approximations to Elliptic Integrals

Four functions provided here are symmetrised variants of the classic elliptic integrals. These alternative
definitions have been suggested by Carlson (1965), Carlson (1977a) and Carlson (1977b) and he also
developed the basic algorithms used in this chapter.
The standard integral of the first kind is represented by
Z
1 1
dt
p ;
RF x; y; z
2 0
t xt yt z
where x; y; z  0 and at most one may be equal to zero.
The normalisation factor, 12, is chosen so as to make

p
RF x; x; x 1= x:

If any two of the variables are equal, RF degenerates into the second function
Z
1 1
dt
p
RC x; y RF x; y; y
;
2 0
t xt y
where the argument restrictions are now x  0 and y 6 0.
This function is related to the logarithm or inverse hyperbolic functions if 0 < y < x, and to the inverse
circular functions if 0  x  y.
The integrals of the second kind are defined by
Z
3 1
dt
q
RD x; y; z
2 0
t xt yt z3
with z > 0, x  0 and y  0, but only one of x or y may be zero.
The function is a degenerate special case of the integral of the third kind
Z
3 1
dt
p
RJ x; y; z; 
2 0
t xt yt zt 
with  6 0 and x; y; z  0 with at most one equality holding. Thus RD x; y; z RJ x; y; z; z. The
normalisation of both these functions is chosen so that
p
RD x; x; x RJ x; x; x; x 1=x x:
The algorithms used for all these functions are based on duplication theorems. These allow a recursion
system to be established which constructs a new set of arguments from the old using a combination of
arithmetic and geometric means. The value of the function at the original arguments can then be simply
related to the value at the new arguments. These recursive reductions are used until the arguments differ
from the mean by an amount small enough for a Taylor series about the mean to give sufficient accuracy
when retaining terms of order less than six. Each step of the recurrences reduces the difference from the
mean by a factor of four, and as the truncation error is of order six, the truncation error goes like 4096n ,
where n is the number of iterations.
The above forms can be related to the more traditional canonical forms (see Section 17.2 in Abramowitz
and Stegun (1972)).
If we write q cos2 ; r 1  m: sin2 ; s 1 n: sin2 , where 0 <   12, we have

s.4

[NP3645/7]

s Approximations of Special Functions

Introduction s

the elliptic integral of the first kind:


Z sin 
F jm
1  t2 1=2 1  mt2 1=2 dt sin :RF q; r; 1;
0

the elliptic integral of the second kind:


Z
Ejm

sin 

1  t2 1=2 1  mt2 1=2 dt

sin :RF q; r; 1  13m: sin3 :RD q; r; 1


the elliptic integral of the third kind:
n; jm

sin 

1  t2 1=2 1  mt2 1=2 1 nt2 1 dt

sin :RF q; r; 1  13n: sin3 :RJ q; r; 1; s:


Also the complete elliptic integral of the first kind:
Z =2
1  m: sin2 1=2 d RF 0; 1  m; 1;
Km
0

the complete elliptic integral of the second kind:


Z =2
1  m: sin2 1=2 d RF 0; 1  m; 1  13m:RD 0; 1  m; 1:
Em
0

2.3

Bessel and Airy Functions of a Complex Argument

The functions for Bessel and Airy functions of a real argument are based on Chebyshev expansions, as
described in Section 2.1. The functions for functions of a complex argument, however, use different
methods. These functions relate all functions to the modified Bessel functions I
z and K
z computed
in the right-half complex plane, including their analytic continuations. I
and K
are computed by
different methods according to the values of z and
. The methods include power series, asymptotic
expansions and Wronskian evaluations. The relations between functions are based on well known
formulae (see Abramowitz and Stegun (1972)).

Recommendations on Choice and Use of Available Functions

3.1

Elliptic Integrals

IMPORTANT ADVICE: users who encounter elliptic integrals in the course of their work are strongly
recommended to look at transforming their analysis directly to one of the Carlson forms, rather than to the
traditional canonical Legendre forms. In general, the extra symmetry of the Carlson forms is likely to
simplify the analysis, and these symmetric forms are much more stable to calculate.
The function nag_elliptic_integral_rc (s21bac) for RC is largely included as an auxiliary to the other
functions for elliptic integrals. This integral essentially calculates elementary functions, e.g.,
  
2
ln x
x  1:RC 1x
; x ; x > 0;
2
arcsin x

x:RC 1  x2 ; 1; jxj  1;

arcsinh x x:RC 1 x2 ; 1; etc:


In general this method of calculating these elementary functions is not recommended as there are usually
much more efficient specific functions available in the Library. However, nag_elliptic_integral_rc (s21bac)
may be used, for example, to compute ln x=x  1 when x is close to 1, without the loss of significant
figures that occurs when ln x and x  1 are computed separately.

[NP3645/7]

s.5

Introduction s

3.2

NAG C Library Manual

Bessel and Airy Functions

For computing the Bessel functions J


x, Y
x, I
x and K
x where x is real and
0 or 1,
special functions are provided, which are much faster than the more general functions that allow a complex
argument and arbitrary real
 0. Similarly, special functions are provided for computing the Airy
functions and their derivatives Aix, Bix, Ai0 x, Bi0 x for a real argument which are much faster than
the functions for complex arguments.

Index

Airy function,
Ai or Ai0,
complex argument,
optionally scaled .................................................................... nag_complex_airy_ai
0
Ai ,
real argument ................................................................................... nag_airy_ai_deriv
Ai,
real argument ................................................................................................ nag_airy_ai
Bi or Bi0,
complex argument,
optionally scaled .................................................................... nag_complex_airy_bi
Bi0 ,
real argument ................................................................................... nag_airy_bi_deriv
Bi,
real argument ................................................................................................ nag_airy_bi
Arccosh,
inverse hyperbolic cosine ................................................................................. nag_arccosh
Arcsinh,
inverse hyperbolic sine ..................................................................................... nag_arcsinh
Arctanh,
inverse hyperbolic tangent ................................................................................ nag_arctanh
Bessel function,
J 0,
real argument ............................................................................................ nag_bessel_j0
J 1,
real argument ............................................................................................ nag_bessel_j1
Jn z,
real argument ..................................................................... nag_complex_bessel_j_seq
J
,
complex argument,
optionally scaled .................................................................. nag_complex_bessel_j
Y 0,
real argument ............................................................................................ nag_bessel_y0
Y 1,
real argument ............................................................................................ nag_bessel_y1
Y
,
complex argument,
optionally scaled .................................................................. nag_complex_bessel_y
Complement of the Cumulative Normal distribution ................ nag_cumul_normal_complem
Complement of the Error function,
real argument ........................................................................................................... nag_erfc
scaled,
complex argument ............................................................................. nag_complex_erfc
Cosine Integral ............................................................................................. nag_cos_integral
Cosine,
hyperbolic ................................................................................................................ nag_cosh
Cumulative Normal distribution function ................................................... nag_cumul_normal
Dawsons Integral ..................................................................................................... nag_dawson

s.6

(s17dgc)
(s17ajc)
(s17agc)

(s17dhc)
(s17akc)
(s17ahc)
(s11acc)
(s11abc)
(s11aac)

(s17aec)
(s17afc)
(s18gkc)

(s17dec)
(s17acc)
(s17adc)

(s17dcc)
(s15acc)
(s15adc)
(s15ddc)
(s13acc)
(s10acc)
(s15abc)
(s15afc)

[NP3645/7]

s Approximations of Special Functions

Introduction s

Digamma function,
scaled ................................................................................................. nag_polygamma_deriv
Elliptic functions,
Jacobian, sn, cn, dn ........................................................... nag_real_jacobian_elliptic
Elliptic integral,
general,
of 2nd kind,
F z; k0 ; a; b ................................................................... nag_elliptic_integral_f
symmetrised,
degenerate of 1st kind,
RC ................................................................................ nag_elliptic_integral_rc
of 1st kind,
RF ................................................................................ nag_elliptic_integral_rf
of 2nd kind,
RD ............................................................................... nag_elliptic_integral_rd
of 3rd kind,
RJ ................................................................................ nag_elliptic_integral_rj
Erf,
real argument .............................................................................................................. nag_erf
Erfc,
real argument ........................................................................................................... nag_erfc
scaled,
complex argument ............................................................................. nag_complex_erfc
Error function,
real argument .............................................................................................................. nag_erf
Exponential Integral ..................................................................................... nag_exp_integral
Fresnel Integral,
C .................................................................................................................... nag_fresnel_c
S .................................................................................................................... nag_fresnel_s
Gamma function .......................................................................................................... nag_gamma
Gamma function,
incomplete ...................................................................................... nag_incomplete_gamma
Generalized Factorial function ................................................................................... nag_gamma
2
Hankel function H 1

or H
,
complex argument,
optionally scaled ........................................................................... nag_complex_hankel
Incomplete Gamma function ............................................................... nag_incomplete_gamma
Jacobian elliptic functions, sn, cn, dn,
complex argument ........................................................................ nag_jacobian_elliptic
real argument ...................................................................... nag_real_jacobian_elliptic
Jacobian theta functions k x; q,
real argument ....................................................................................... nag_jacobian_theta
Kelvin function,
bei x ............................................................................................................. nag_kelvin_bei
ber x ............................................................................................................. nag_kelvin_ber
kei x ............................................................................................................. nag_kelvin_kei
ker x ............................................................................................................. nag_kelvin_ker
Legendre functions of 1st kind P m
n x,
Pm
x
..........................................................................................................
nag_legendre_p
n
Logarithm of 1 x ........................................................................................ nag_shifted_log
Logarithm of Gamma function
complex ........................................................................................ nag_complex_log_gamma
real ................................................................................................................. nag_log_gamma
Modified Bessel function(s),
I 0,
real argument ............................................................................................ nag_bessel_i0
I 1,
real argument ............................................................................................ nag_bessel_i1

[NP3645/7]

(s14adc)
(s21cac)

(s21dac)

(s21bac)
(s21bbc)
(s21bcc)
(s21bdc)
(s15aec)
(s15adc)
(s15ddc)
(s15aec)
(s13aac)
(s20adc)
(s20acc)
(s14aac)
(s14bac)
(s14aac)

(s17dlc)
(s14bac)
(s21cbc)
(s21cac)
(s21ccc)
(s19abc)
(s19aac)
(s19adc)
(s19acc)
(s22aac)
(s01bac)
(s14agc)
(s14abc)

(s18aec)
(s18afc)

s.7

Introduction s

NAG C Library Manual

In1 x or In1 x,
real argument ................................................................................. nag_bessel_i_alpha
I
=4 x,
real argument ....................................................................................... nag_bessel_i_nu
I
,
complex argument,
optionally scaled .................................................................. nag_complex_bessel_i
Jn1 x or Jn1 x,
real argument ................................................................................. nag_bessel_j_alpha
K0,
real argument ............................................................................................ nag_bessel_k0
K1,
real argument ............................................................................................ nag_bessel_k1
Kn x,
real argument ................................................................................. nag_bessel_k_alpha
K
=4 x,
real argument ....................................................................................... nag_bessel_k_nu
K
,
complex argument,
optionally scaled .................................................................. nag_complex_bessel_k
Polygamma function n x,
real x ................................................................................................... nag_real_polygamma
Polygamma function n z,
complex z ..................................................................................... nag_complex_polygamma
Psi function ................................................................................................ nag_polygamma_fun
Psi function and derivatives,
scaled ................................................................................................. nag_polygamma_deriv
Scaled modified Bessel function(s),
ex K 0 x,
real argument ............................................................................. nag_bessel_k0_scaled
ex K 1 x,
real argument ............................................................................. nag_bessel_k1_scaled
ex K
=4 x,
real argument ......................................................................... nag_bessel_k_nu_scaled
ex I
=4 x,
real argument ......................................................................... nag_bessel_i_nu_scaled
ejxj I 0 x,
real argument ............................................................................. nag_bessel_i0_scaled
jxj
e I 1 x,
real argument ............................................................................. nag_bessel_i1_scaled
Kn x,
real argument ................................................................... nag_bessel_k_alpha_scaled
Sine integral ................................................................................................. nag_sin_integral
Sine,
hyperbolic ................................................................................................................ nag_sinh
Tangent,
hyperbolic ................................................................................................................ nag_tanh
Trigamma function,
scaled ................................................................................................. nag_polygamma_deriv
Zeros of Bessel functions J  x, J 0 x, Y  x, Y 0 x .......................... nag_bessel_zeros

(s18ejc)
(s18eec)

(s18dec)
(s18ekc)
(s18acc)
(s18adc)
(s18egc)
(s18efc)

(s18dcc)
(s14aec)
(s14afc)
(s14acc)
(s14adc)

(s18ccc)
(s18cdc)
(s18edc)
(s18ecc)
(s18cec)
(s18cfc)
(s18ehc)
(s13adc)
(s10abc)
(s10aac)
(s14adc)
(s17alc)

Functions Withdrawn or Scheduled for Withdrawal

None.

s.8

[NP3645/7]

s Approximations of Special Functions

Introduction s

References

Abramowitz M and Stegun I A (1972) Handbook of Mathematical Functions (3rd Edition) Dover
Publications
Carlson B C (1965) On computing elliptic integrals and functions J. Math. Phys. 44 3651
Carlson B C (1977a) Elliptic integrals of the first kind SIAM J. Math. Anal. 8 231242
Carlson B C (1977b) Special Functions of Applied Mathematics Academic Press
Clenshaw C W (1962) Mathematical tables Chebyshev Series for Mathematical Functions HMSO
Fox L and Parker I B (1968) Chebyshev Polynomials in Numerical Analysis Oxford University Press
Schonfelder J L (1976) The production of special function routines for a multi-machine library Softw.
Pract. Exper. 6 (1)

[NP3645/7]

s.9 (last)

You might also like