SSL2UG
SSL2UG
SSL2UG
PREFACE
This manual describes the functions and use of the Scientific Subroutine Library II (SSL II), SSL II can be used for various systems ranging from personal computers to vector computers. The interface between a user-created program and SSL II is always the same regardless of the system type. Therefore, this manual can be used for all systems that use SSL II. When using SSL II for the first time, the user should read How to Use This Manual first. The contents of SSL II or this manual may be amended to keep up with the latest state of technology, That is, if the revised or added subroutines should functionally include or surpass some of the old subroutines, those old subroutines will be deleted in a time of allowance. Note: Some of the SSL II functions may be restricted in certain systems due to hardware restrictions. These functions are in the SSL II Subroutine List in this manual.
This document contains technology relating to strategic products controlled by export control laws of the producing and/or exporting countries. This document or a portion thereof should not be exported (or reexported) without authorization from the appropriate governmental authorities in accordance with such laws. FUJITSU LIMITED
The contents of this manual may be revised without prior notice. All Rights Reserved, Copyright FUJITSU LIMITED 1989 No part of this manual may be reproduced in any from without permission
ACKNOWLEDGEMENTS
We believe that a scientific subroutine library can be one of convenient vehicles for the dissemination of the fruits of investigation made by experts concerned with numerical analysis, furthermore, through the library a user can make use of these new fruits without ever having to become familiar with the technical details. This led us to conclude that we had better request as many experts as possible to implement their new methods, and then promote distribution of them to a wide community of users. As a result of our efforts to show our idea to many experts or authorities and to discuss continuously with them, we could fortunately get a common consensus from them. We are pleased to enumerate below experts who have contributed to SSL II until now in acknowledgment of their efforts. Contributors
Name Masatsugu Tanaka Ichizo Ninomiya Tatsuo Torii Takemitsu Hawegawa Kazuo Hatano Yasuyo Hatano Toshio Yoshida Kaoru Tone Takashi Kobayashi Toshio Hosono Organization Faculty of Engineering, Yamanashi University, Japan Faculty of Management Information Chubu University, Japan Faculty of Engineering, Nagoya University, Japan Faulty of Engineering, Fukui University, Japan Faculty of Engineering, Aichi Technical University, Japan Department of Education, Chukyo University, Japan Faculty of Management Information Chubu University, Japan Graduate School for Policy Science, Saitama University, Japan Graduate School for Policy Science, Saitama University, Japan College of Science and Technology, Nihon University, Japan (Nov., 1987)
Also, our thanks are due to many universities and research institutes, especially those shown below, for helpful discussions and advises on our project, for providing information on recent algorithms, numerical comparisons, and for suggesting several important improvements in this users guide. Organizations Computation Center, Hokkaido University Computation Center, Nagoya University Computation Center, Kyoto University Computation Center, Kyusyu University Japan Atomic Energy Research Institute It would be another pleasure that users would appreciate the efforts by contributors, and on the occasions of publication of users own technical papers they would advertise on the papers as possible the fact of having used SSL II.
CONTENTS
Page SSL II SUBROUTINE LIST ..........................................................................................................................................1 HOW TO USE THIS MANUAL .................................................................................................................................. 12
PART I
Background of Development....................................................................................................................... 17 Development Objectives.............................................................................................................................. 17 Features ...................................................................................................................................................... 17 System That Can Use SSL II....................................................................................................................... 18 GENERAL RULES............................................................................................................................ 19
CHAPTER 2 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 2.10 2.11
Types of Subroutines................................................................................................................................... 19 Classification Codes.................................................................................................................................... 19 Subroutine Names....................................................................................................................................... 19 Parameters.................................................................................................................................................. 19 Definitions.................................................................................................................................................. 21 Return Conditions of Processing ................................................................................................................. 23 Array .......................................................................................................................................................... 23 Data Storage ............................................................................................................................................... 24 Unit Round Off........................................................................................................................................... 27 Accumulation of Sums................................................................................................................................ 27 Computer Constants ................................................................................................................................... 27 LINEAR ALGEBRA.......................................................................................................................... 28
Outline ....................................................................................................................................................... 28 Matrix Storage Mode Conversion ............................................................................................................... 28 Matrix Manipulation................................................................................................................................... 28 Linear Equations and Matrix Inversion (Direct Method)............................................................................. 29 Least Squares Solution................................................................................................................................ 32 EIGENVALUES AND EIGENVECTORS ......................................................................................... 35
Outline ....................................................................................................................................................... 35 Eigenvalues and Eigenvectors of a Real Matrix........................................................................................... 35 Eigenvalues and Eigenvectors of a Complex Matrix.................................................................................... 36 Eigenvalues and Eigenvectors of a Real Symmetric Matrix ......................................................................... 38 Eigenvalues and Eigenvectors of an Hermitian Matrix................................................................................ 40 Eigenvalues and Eigenvectors of a Real Symmetric Band Matrix................................................................ 41
4.7 4.8
Eigenvalues and Eigenvectors of a Real Symmetric Generalized Eigenproblem .......................................... 43 Eigenvalues and Eigenvectors of a Real Symmetric Band Generalized Eigenproblem................................. 45 NONLINEAR EQUATIONS ............................................................................................................. 46
Outline ....................................................................................................................................................... 46 Polynomial Equations................................................................................................................................. 46 Transcendental Equations........................................................................................................................... 47 Nonlinear Simultaneous Equations ............................................................................................................. 47 EXTREMA........................................................................................................................................ 49
Outline ....................................................................................................................................................... 49 Minimization of Function with a Variable .................................................................................................. 49 Unconstrained Minimization of Multivariable Function.............................................................................. 49 Unconstrained Minimization of Sum of Squares of Functions (Nonlinear Least Squares Solution) ............................................................................................................ 51 Linear Programming .................................................................................................................................. 52 Nonlinear Programming (Constrained Minimization of Multivariable Function) ........................................ 54 INTERPOLATION AND APPROXIMATION .................................................................................. 55
Outline ....................................................................................................................................................... 63 Discrete Real Fourier Transforms ............................................................................................................... 63 Discrete Cosine Transforms........................................................................................................................ 63 Discrete Sine Transforms ........................................................................................................................... 64 Discrete Complex Fourier Transforms ........................................................................................................ 64 Laplace Transform ..................................................................................................................................... 66 NUMERICAL DIFFERENTIATION AND QUADRATURE ............................................................. 70
CHAPTER 10 DIFFERENTIAL EQUATIONS......................................................................................................... 75 10.1 10.2 Outline ....................................................................................................................................................... 75 Ordinary Differential Equations.................................................................................................................. 75
CHAPTER 11 SPECIAL FUNCTIONS .................................................................................................................... 78 11.1 11.2 Outline ....................................................................................................................................................... 78 Elliptic Integrals......................................................................................................................................... 78
ii
Exponential Integral ................................................................................................................................... 79 Sine and Cosine Integrals ........................................................................................................................... 79 Fresnel Integrals ......................................................................................................................................... 79 Gamma Functions....................................................................................................................................... 79 Error Functions........................................................................................................................................... 79 Bessel Functions ......................................................................................................................................... 80 Normal Distribution Functions.................................................................................................................... 80
CHAPTER 12 PSEUDO RANDOM NUMBERS....................................................................................................... 81 12.1 12.2 12.3 Outline ....................................................................................................................................................... 81 Pseudo Random Generation ........................................................................................................................ 81 Pseudo Random Testing.............................................................................................................................. 81
PART II
APPENDICES ........................................................................................................................................................... 606 APPENDIX A AUXILIARY SUBROUTINES......................................................................................................... 607 A.1 A.2 A.3 A.4 A.5 A.6 A.7 A.8 Outline ..................................................................................................................................................... 607 AMACH, DMACH................................................................................................................................... 608 MGSSL .................................................................................................................................................... 609 MGSET .................................................................................................................................................... 610 ASUM (BSUM), DSUM (DBSUM) .......................................................................................................... 611 CSUM, DCSUM....................................................................................................................................... 612 IRADIX.................................................................................................................................................... 613 AFMAX, DFMAX, AFMIN, DFMIN ....................................................................................................... 614
APPENDIX B ALPHABETIC GUIDE FOR SUBROUTINES ................................................................................. 615 B.1 B.2 B.3 General Subroutines.................................................................................................................................. 615 Slave Subroutines ..................................................................................................................................... 618 Auxiliary Subroutines ............................................................................................................................... 619
APPENDIX C CLASSIFICATION CODES AND SUBROUTINES ........................................................................ 620 APPENDIX D REFERENCES ................................................................................................................................ 622 CONTRIBUTORS AND THEIR WORKS ................................................................................................................. 626 INDEX ...................................................................................................................................................................... 629
iii
SSL II SUBROUTINE LIST The SSL II functions are listed below. Generally, a single-precision routine and a doubleprecision routine are available for each function. The subroutine name column gives the names of routines. Double-precision routine names start with a D. If the use of a function is restricted due to hardware restrictions, it is indicated in the remarks column. The symbols that appear in the remarks column mean the following: #: Only the single-precision routine is available in all systems.
Storage mode conversion of matrices Subroutine name CGSM CSGM CGSBM CSBGM CSSBM CSBSM Item Storage mode conversion of matrices (real symmetric to real general) Storage mode conversion of matrices (real general to real symmetric) Storage mode conversion of matrices (real general to real symmetric band) Storage mode conversion of matrices (real symmetric band to real general) Storage mode conversion of matrices (real symmetric to real symmetric band) Storage mode conversion of matrices (real symmetric band to real symmetric) Page 264 290 263 287 291 289 Remarks
Matrix manipulation Subroutine name AGGM SGGM MGGM MGSM ASSM SSSM MSSM MSGM MAV MCV MSV MSBV MBV Item Addition of two matrices (real general + real general) Subtraction of two matrices (real general real general) Multiplication of two matrices (real general by real general) Multiplication of two matrices (real general by real symmetric) Addition of two matrices (real symmetric + real symmetric) Subtraction of two matrices (real symmetric real symmetric) Multiplication of two matrices (real symmetric by real symmetric) Multiplication of two matrices (real symmetric by real general) Multiplication of a real matrix by a real vector Multiplication of a complex matrix by a complex vector Multiplication of a real symmetric matrix by a real vector Multiplication of a real symmetric band matrix and a real vector Multiplication of a real band matrix and a real vector Page 85 563 454 465 131 582 477 476 456 460 478 474 458 Remarks
Linear equations Subroutine name LAX LCX LSX LSIX LSBX LSBIX LBX1 LSTX LTX LAXR LCXR LSXR LSIXR LSBXR LBX1R Item A system of linear equations with a real general matrix (Crouts method) A system of linear equations with a complex general matrix (Crouts method) A system of linear equations with a positive-definite symmetric matrix (Modified Choleskys method) A system of linear equations with a real indefinite symmetric matrix (Block diagonal pivoting method) A system of linear equations with a positive-definite symmetric band matrix (Modified Choleskys method) A system of linear equations with a real indefinite symmetric band matrix (block diagonal pivoting method) A system of linear equations with a real general band matrix (Gaussian elimination method) A system of linear equations with a positive-definite symmetric tridiagonal matrix (Modified Choleskys method) A system of linear equations with a positive-definite symmetric tridiagonal matrix (Gaussian elimination method) Iterative refinement of the solution to a system of linear equations with a real general matrix Iterative refinament of the solution to a system of linear equations with a complex general matrix Iterative refinement of the solution to a system of linear equations with a positive-definite symmetric matrix Iterative refinament of the solution to a system of linear equations with a real indefinite symmetric matrix Iterative refinament of the solution to a system of linear equations with a positive-definite symmetric band matrix Iterative refinement of the solution to a system of linear equations with a real general band matrix 404 435 440 447 409 399 449 442 402 431 433 438 Page 388 407 445 Remarks
Matrix inversion Subroutine name LUIV CLUIV LDIV Item The inverse of a real general matrix decomposed into the factors L and U The inverse of a complex general matrix decomposed into the factors L and U The inverse of a positive-definite symmetric matrix decomposed into the factors L, D and LT Page 452 279 412 Remarks
Decomposition of matrices Subroutine name ALU CLU SLDL SMDM SBDL SBMDM BLU1 Item LU-decomposition of a real general matrix (Crouts method) LU-decomposition of a complex general matrix (Crouts method) LDLT-decomposition of a positive-definite symmetric matrix (Modified Choleskys method) MDMT-decomposition of a real indefinite symmetric matrix (Block diagonal pivoting method) LDLT-decomposition of a positive-definite symmetric band matrix (Modified Cholskys method) MDMT decomposition of a real indefinite symmetric band matrix (block diagonal pivoting method) LU-decomposition of a real general band matrix (Gaussian elimination method) 189 555 553 572 Page 98 277 570 Remarks
Solution of decomposed system Subroutine name LUX CLUX LDLX MDMX BDLX BMDMX BLUX1 and U A system of linear equations with a complex general matrix decomposed into the factors L and U A system of linear equations with a positive-definite symmetric matrix decomposed into the factors L, D and LT A system of linear equations with a real indefinite symmetric matrix decomposed into the factors M, D and MT A system of linear equations with a positive-definite symmetric band matrix decomposed into the factors L, D and LT A system of linear equations with a real indefinite symmetric band matrix decomposed into factors M, D, and MT A system of linear equations with a real general band matrix decomposed into the factors L and U 186 192 136 462 414 281 Item A system of linear equations with a real general matrix decomposed into the factors L Page 454 Remarks
Least squares solution Subroutine name LAXL LAXLR LAXLM GINV ASVD1 Item Least squares solution with a real matrix (Householder transformation) Interative refinement of the least squares solution with a real matrix Least squares minimal norm solution with a real matrix (Singular value decomposition method) Generalized Inverse of a real matrix (Singular value decomposition method) Singular value decomposition of a real matrix (Householder and QR methods) 341 132 Page 390 397 393 Remarks
B.
Eigenvalues and eigenvectors Subroutine name EIG1 CEIG2 SEIG1 SEIG2 HEIG2 BSEG BSEGJ TEIG1 TEIG2 GSEG2 GBSEG Item Eigenvalues and corresponding eigenvectors of a real matrix (double QR method) Eigenvalues and corresponding eigenvectors of a complex matrix (QR method) Eigenvalues and corresponding eigenvectors of a real symmetric matrix (QL method) Selected eigenvalues and corresponding eigenvectors of a real symmetric matrix (Bisection method, inverse iteration method) Eigenvalues and corresponding eigenvectors of an Hermition matrix (Householder method, bisection method, and inverse interation method) Eigenvalues and eigenvectors of a real symmetric band matrix (Lutisheuser-Schwarz method, bisection method and inverse interation method) Eigenvalues and eigenvectors of a real symmetric band matrix (Jannings method) Eigenvalues and corresponding eigenvectors of a real symmetric tridiagonal matrix (QL method) Selected eigenvalues and corresponding eigenvectors of a real symmetric tridiagonal matrix (Bisection method, inverse iteration method) Eigenvalues and corresponding eigenvectors of a real symmetric generalized matrix system AxBx (Bisection method, inverse iteration method) Eigenvalues and corresponding eigenvectors of a real symmetric band generalized eigenproblem (Jennings method) 335 347 585 208 583 206 356 Page 298 242 558 560 Remarks
Eigenvalues Subroutine name HSQR CHSQR TRQL BSCT1 Item Eigenvalues of a real Hessenberg matrix (double QR method) Eigenvalues of a complex Hessenberg matrix (QR method) Eigenvalues of a real symmetric tridiagonal matrix (QL method) Selected eigenvalues of a real symmetric tridiagonal matrix (Bisection method) Page 361 270 598 198 Remarks
Eigenvectors Subroutine name HVEC CHVEC BSVEC Item Eigenvectors of a real Hessenberg matrix (Inverse iteration method) Eigenvectors of a complex Hessenberg matrix (Inverse iteration method) Eigenvectors of a real symmetric band matrix (Inverse iteration method) Page 363 272 218 Remarks
Others Subroutine name BLNC CBLNC HES1 CHES2 TRID1 TRIDH BTRID HBK1 CHBK2 TRBK TRBKH NRML CNRMl GSCHL GSBK Balancing of a real matrix Balancing of a complex matrix Reduction of a real matrix to a real Hessenberg matrix (Householder method) Reduction of a complex matrix to a complex Hessenberg matrix (Stabilized elementary transformation) Reduction of a real symmetric matrix to a real symmetric tridiagonal matrix (Householder method) Reduction of an Hermition matrix to a real symmetric tridiagonal matrix (Householder method and diagonal unitary transformation) Reduction of a real symmetric band matrix to a tridiagonal matrix (Lutishauser-Schwarz method) Back transformation and normalization of the eigenvectors of a real Hessenberg matrix Back transformation of the eigenvectors of a complex Hessenberg matrix to the eigenvectors of a complex matrix Back transformation of the eigenvectors of a tridiagonal matrix to the eigenvectors of a real symmetric matrix Back transformation of eigenvectors of a tridiagonal matrix to the eigenvectors of an Hermition matrix Normalization of eigenvectors Normalization of eigenvectors of a complex matrix Reduction of a real symmetric matrix system Ax = Bx to a standard form Back transformation of the eigenvectors of the standard form the eigenvectors of the real symmetric generalized matrix system 498 283 345 343 591 589 354 266 221 593 596 Item Page 184 239 358 268 Remarks
C.
Nonlinear Equations Subroutine name RQDR CQDR LOWP RJETR CJART TSD1 TSDM CTSDM NOLBR Zeros of a quadratic with real coefficients Zeros of a quadratic with complex coefficients Zeros of a low degree polynomial with real coefficients (fifth degree or lower) Zeros of a polynomial with real coefficients (Jenkins-Traub method) Zeros of a polynomial with complex coefficients (Jarrett method) Zero of a real function which changes sign in a given interval (derivative not required) Zero of a real function (Mullers method) Zero of complex function (Mullers method) Solution of a system of nonlinear equations (Brents method) Item Page 552 286 423 546 275 604 601 292 487 Remarks
D.
Extrema Subroutine name LMINF LMING MINF1 MING1 NOLF1 NOLG1 LPRS1 NLPG1 only) Minimization of function with a variable (cubic interpolation using function values and its derivatives) Minimization of function with several variables (revised quasi-Newton method, uses function values only) Minimization of a function with several variables (Quasi-Newton method, using function values and its derivatives) Minimization of the sum of squares of functions with several variable s(Revised Marquardt method, using function values only) Minimization of the sum of squares of functions (revised Marquardt method using function values and its derivatives) Solution of a linear programming problem (Revised simplex method) Nonlinear programming (powells method using function values and its derivatives) 425 482 494 490 470 466 420 Item Minimization of function with a variable (quadratic interpolation using function values Page 418 Remarks
E.
Interpolation Subroutine name AKLAG AKHER SPLV BIF1 BIF2 BIF3 BIF4 BIFD1 BIFD3 AKMID INSPL AKMIN BIC1 BIC2 BIC3 BIC4 BICD1 BICD3 Aitken-Lagrange interpolation Aitkan-Hermite interpolation Cubic spline interpolation B-spline interpolation (I) B-spline interpolation (II) B-spline interpolation (III) B-spline interpolation (IV) B-spline two-dimensional interpolation (I-I) B-spline two-dimensional interpolation (III-III) Two-dimensional quasi-Hermite Interpolation Cubic spline interpolation coefficient calculation Quasi-Hermite interpolation coefficient calculation B-spline interpolation coefficient calculation (I) B-spline interpolation coefficient calculation (II) B-spline interpolation coefficient calculation (III) B-spline interpolation coefficient calculation (IV) B-spline two-dimensional interpolation coefficient calculation (I-I) B-spline two-dimensional interpolation coefficient calculation (III-III) Item Page 89 86 579 156 158 160 162 151 154 91 377 95 143 145 147 149 138 141 Remarks
Approximation Subroutine name LESQ1 Polynomial least squares approximation Item Page 416 Remarks
Smoothing Subroutine name SMLE1 SMLE2 BSF1 BSC1 BSC2 BSFD1 BSCD2 Item Data smoothing by local least squares polynomials (equally spaced data points) Data smoothing by local least squares polynomials (unequally spaced date points) B-spline smoothing B-spline smoothing coefficient calculation B-spline smoothing coefficient calculation (variable knots) B-spline two-dimensional smoothing B-spline two-dimensional smoothing coefficient calculation (variable knots) Page 575 577 216 201 203 214 194 Remarks
Series Subroutine name FCOSF ECOSP FSINF ESINP FCHEB ECHEB GCHEB ICHEB transform) Evaluation of a cosine series Fourier sine series expansion of an odd function (Function input, fast sine transform) Evaluation of a sine series Chabyshev series expansion of a real function (Function input, fast cosine transform) Evaluation of a Chebyshev series Differentiation of a Chabyshev series Indefinite integral of a Chebyshev series 296 324 302 306 294 339 367 Item Fourier Cosine series expansion of an even function (Function input, fast cosine Page 312 Remarks
F.
Transforms Subroutine name FCOST FCOSM FSINT FSINM RFT CFTM CFT CFTN CFTR PNR LAPS1 LAPS2 LAPS3 HRWIZ Item Discrete cosine transform (Trapezoidal rule, radix 2 FFT) Discrete cosine transform (midpoint rule, radix 2 FFT) Discrete since transform (Trapezoidal rule, radix 2 FFT) Discrete sine transform (midpoint rule, radix 2 FFT) Discrete real Fourier transform Multi-variate discrete complex Fourier transform (mixed radix FFT) Multi-variate discrete complex Fourier transform (radix 8 and 2 FFT) Discrete complex Fourier transforms (radix 8 and 2 FFT, reverse binary order output) Discrete complex Fourier transforms (radix 8 and 2 FFT, reverse binary order input) Permutation of data (reverse binary transformation) Inversion of Laplace transform of a rational function (regular in the right-half plane) Inversion of Laplace transform of a general rational function Inversion of Laplace transform of a general function Judgment on Hurwiz polynomials Page 321 318 333 330 543 250 247 254 259 522 379 381 383 360 Remarks
G.
Numerical Differentiation Subroutine name SPLV BIF1 BIF2 BIF3 BIF4 BSF1 BIFD1 BIFD3 BSFD1 GCHEB Differentiation by B-spline least squares fit (Fixed knots) Two-dimensional differentiation (unequally spaced lattice points. B-spline two-dimensional interpolation) Two-dimensional differentiation by B-spline last squares fit Differentiation of a Chebyshev series Cubic spline differentiation Differentiation (Unequally spaced discrete points, B-spline Interpolation) Item Page 579 156 158 160 162 216 151 154 214 339 Remarks
Numerical Quadrature Subroutine name SIMP1 TRAP BIF1 BIF2 BIF3 BIF4 BSF1 BIFD1 BIFD3 BSFD1 SIMP2 AQN9 AQC8 AQE AQEH AQEI AQMC8 AQME Smoothing differentiation and integration of a tabulated function by B-spline least squares fit (fixed knots) Integration of a two-dimensional tabulated function (unequally spaced lattice points, Bspline two-dimensional interpolation) Two-dimensional integration of a tabulated function by B-spline interpolation Integration of a function by adaptive Simpsons rule Integration of a function by adaptive Newton-Cotes 9-point rule Integration of a function by a modified Clenshaw-Curtis rule Integration of a function by double exponential formula Integration of a function over the semi-infinite interval by double exponential formula Integration of a function over the Infinite interval by double exponential formula Multiple integration of a function by a modified Clenshaw-Curtis Integration rule Multiple integration of a function by double exponential formula 151 154 214 565 126 100 106 110 112 115 121 Intergration of a tabulated function by B-spline interpolation (unequally spaced discrete points, B-spline interpolation) Item Integration of a tabulated function by Simpsons rule (equally spaced) Integration of a tabulated function by trapezoidal rule (unequally spaced) Page 564 588 156 158 160 162 216 Remarks
H.
Differential equations Item A system of first order ordinary differential equations (Runge-Kutta method) A system of first order ordinary differential equations (Hamming method) A system of first order ordinary differential equations (Runge-Kutta-Verner method) A system of first order ordinary differential equations (Adams method) A stiff system of first order ordinary differential equations (Gears method) Page 550 350 518 500 509 Remarks
I.
Special Functions Subroutine name CELI1 CELI2 EXPI SINI COSI SFRI CFRI IGAM1 IGAM2 IERF IERFC BJ0 BJ1 BY0 BY1 BI0 BI1 BK0 BK1 BJN BYN BIN BKN CBIN CBKN CBJN CBYN BJR BYR BIR BKR CBJR NDF NDFC INDF INDFC Item Complete elliptic Integral of the first kind K (x) Complete elliptic integral of the second kind E (x) Exponential integral Ei (x), Ei (x) Sine integral Si (x) Cosine integral Ci (x) Sine Fresnel integral S (x) Cosine Fresnel integral C (x) Incomplete Gamma function of the first kind (,x) Incomplete Gamma function of the second kind (,x) Inverse error function eff-1 (x) Inverse complimented error function erfc-1 (x) Zero-order Bessel function of the first kind J0 (x) First-order Bessel function of the first kind J1 (x) Zero-order Bessel function of the second kind Y0 (x) First-order Bessel function of the second kind Y1 (x) Modified Zero-order Bessel function of the first kind l0 (x) Modified First-order Bessel function of the first kind l1 (x) Modified Zero-order Bessel function of the second kind K0 (x) Modified First-order Bessel function of the second kind K1 (x) Nth-order Bessel function of the first kind Jn (x) Nth-order Bessel function of the second kind Yn (x) Modified Nth-order Bessel function of the first kind In (x) Modified Nth-order Bessel function of the second kind Kn (x) Modified Nth-order Bessel function of the first kind In (z) with complex variable Modified Nth-order Bessel function of the second kind Kn (z) with complex variable Integer order Bessel function of the first kind with complex variable Jn (z) Integer order Bessel function of the second kind with complex variable Yn (z) Real-order Bessel function of the first kind J (x) Real-order Bessel function of the second kind Y (x) Modified real-order Bessel function of the first kind l (x) Real order modified Bessel function of the second kind K (x) Real-order Bessel function of the first kind with a complex variable J (z) Normal distribution function (x) Complementary normal distribution function (x) Inverse normal distribution function -1 (x) Inverse complementary normal distribution function -1 (x) Page 244 245 304 569 285 562 246 372 373 369 370 173 175 228 230 167 168 182 183 169 223 164 177 232 236 233 241 171 224 166 178 234 480 481 375 376 Remarks
10
J.
Pseudo Random Numbers Subroutine name RANU2 RANU3 RANN1 RANN2 RANE2 RANP2 RANB2 RATF1 RATR1 Uniform (0, 1) pseudo random numbers Shuffled uniform (0, 1) pseudo random numbers Fast normal pseudo random numbers Normal pseudo random numbers Exponential pseudo random numbers Poisson pseudo random integers Binominal pseudo random numbers Frequency test for uniform (0, 1) pseudo random numbers Run test of up-and-down for uniform (0, 1) pseudo random numbers Item Page 533 536 528 530 527 531 525 538 540 Remarks # # # # # # # # #
11
HOW TO USE THIS MANUAL This section describes the logical organization of this manual, and the way in which the user can quickly and accurately get informations necessary to him from the manual. This manual consists of two parts. Part I describes an outline of SSL II. Part II describes usage of SSL II subroutines. Part I consists of twelve chapters. Chapter 2 describes the general rules which apply to each SSL II subroutine. It is suggested that the user read this chapter first. Chapters 3 through 12 are concerned with certain fields of numerical computation, and were edited as independently as possible for easy reference. At the beginning of every chapter, the section OUTLINE is given, which describes the classification of available subroutines in the chapter, and how to select subroutines suitable for a certain purpose. The user should read the section at least once. As mentioned above, there is no confusing or difficult relation between the chapters: it is quite simple as shown in the following diagram.
Chapter 3
Function Describes explanation of the functions. Parameters Describes variables and arrays used for transmitting information into or from the subroutine. Generally, parameter names, which are commonly used in SSL II, are those habitually used so far in many libraries. Comments on use This consists of the following three parts. Subprograms used If other SSL II subroutines are used internally by the subroutine, they are listed under SSL II. Also, if FORTRAN intrinsic functions or basic external functions are used, they are listed under FOR-TRAN basic functions. Notes Discusses various considerations that the user should be aware of when using the subroutine. Example An example of the use of the subroutine is shown. For clarity and ease of understanding, any applications to a certain field of engineering or physical science have not been described. In case other subroutines must be used as well as the subroutine to obtain a mathematical solution, the example has been designed to show how other subroutines are involved. This is especially true in the chapters concerning linear equations or eigenvalues etc. Conditions assumed in an example are mentioned at the beginning of the example. Method The method used by the subroutine is outlined. Since this is a usage manual, only practical aspects of the algorithm or computational procedures are described. References on which the implementation is based and those which are important in theory, are listed in Appendix D References, so refer to them for further information or details beyond the scope of the Method section. In this manual, included are the SSL II Subroutine list and four appendices. In the SSL II Subroutine list, SSL II Subroutines are arranged in the order of fields and then in the order of their classification codes. This list can be used for quick reference of subroutines. Appendix A explains the functions of the auxiliary subroutines and Appendix B contains the three lists, which are concerned respectively with General subroutines Slave subroutines Auxiliary subroutines General subroutines is an alphabetical listing of all subroutines. In the list, if a certain entry uses other subroutines, they are shown on the right. Slave
Chapter 4
Chapter 1
Chapter 2
Chapter 5
Chapter 12
Each chapter from chapter 3 on has several sections, the first of which is the section OUTLINE that, as noted previously, introduces the following sections. As the diagram shows, if the user wants to obtain eigenvalues, for example, of a certain matrix, he should first read Chapter 2, then jump to Chapter 4, where the can select subroutines suitable for his purposes. Part II describes how to use SSL II subroutines. The subroutines are listed in alphabetical order. When describing an individual subroutine, the following contents associated with the subroutine are shown: Function Parameters Comments on use Method and what we intend to describe under each title above are as follows:
12
subroutines is an alphabetical listing of slave subroutines (as for the definition of the m, see Section 2.1), and in the list, general subroutines which use the slave subroutine are shown on the right. Auxiliary subroutines is a listing of auxiliary subroutines, and it is also alphabetical. Appendix C explains the subroutine names in order of classification code. This list can be used for quick reference of subroutines by classification
code. Appendix D lists the documents referred for SSL II development and/or logically important theory. Although no preliminary knowledge except the ability to understand FORTRAN is required to use this manual. Mathematical symbols used in this manual are listed below. We expect that the user has same interest in, or some familiarity with numerical analysis.
Mathematical symbol table Symbol T Example AT xT T x = (x1,...,xn) -1 A A* x* z* Meaning Transposed matrix of matrix A Transposed vector of column vector x Column vector Inverse of matrix A Conjugate transposed matrix of matrix A Conjugate transposed vector of column vector x Conjugate complex number of complex number z Remarks
-1 *
z = a + ib z* = a ib z = z*
11 12 22 A = 21 n1
1n nn
( )
x = (x1,..., xn)T
x is an n-dimensional column vector whose elements are xj. Elements of matrix A are defined as aij. Elements of column vector x are defined as xi. Matrix A is a diagonal matrix whose elements are aii. Unit matrix Determinant of matrix A Rank of matrix A Norm of vector x For n-dimensional vector x, x=(xj):
x 1 = xi
i=1 n
:Uniform norm
2
x 2 = xi
i=1
:Euclidean norm
:Infinity norm Refer to symbols , , max Norm of matrix A For a matrix of order in A = (aij): :Infinity norm n a A =
x = max xi
max i i =1
ij
13
Symbol (,)
Example (x, y)
Remarks When x and y are complex vectors, (x,y)=xT y Refer to symbols and T.
[,] >> { }
Open interval Closed interval a is much greater than b. a is not equal to b. f(x) is approximately equal to P(x). F(x) is defined as f(x)/f(x). Sequence of numbers Summation (xm ...., xn) Sum cannot be given if n<m if xi,
i= m i n
xi
xi + 2 j
i
Summation with respect to i dy df ( x ) , f'(x) = dx dx For n-order derivative: d n f ( x) f (n) (x)= dx n If z=a+ib z = a 2 + b2
y, f (x)
y' =
Absolute value of z
max
max(x1, ...., xn) min xi i min(x1, ...., xn) min xi i sign (x) log x Re (z) lm (z) argz
The maximum value of (x1, ....., xn) The minimum value of (x1, ....., xn) Sign of x Natural logarithm of x Real part of complex number z Imaginary part of complex number z Argument of complex number z Kroneckers delta Eulers constant Ratio of the circumference of the circle to its diameter imaginary unit Principal value of an integral Continued fraction Element x is contained set X. All elements of set x satisfy the equation. f(x) and up to k-th derivatives are continuous in the interval [a, b]. When x is positive, 1. When x is negative, -1.
min
i P.V.
z = a + ib
e P.V. t dt
x . t
i = 1
b0+ b
a1
1
a2 + b2
{}
Ck
x X
{x x = ( x )}
f ( x) c k a , b
[ ]
Note: This table defines how each symbol is used in this guide. A symbol may have a different meaning elsewhere. Commonly used symbols, such as + and , were not included in the list.
14
1.1
BACKGROUND OF DEVELOPMENT
Many years have passed since SSL (Scientific Subroutine Library) was first developed. Due to advancements in numerical calculation techniques and to increased power of computers, SSL has been updated and new functions have been added on many occasions. However, users have further requested the followings: Better balance of the functions and uses of individual subroutines That addition of new functions not adversely affect the organization of the system Better documentation of various functions and their uses SSLII was developed with these requirements in mind.
not only general purpose-oriented subroutines but also those which perform as components of the former, so that the user can use the components when he wishes to analize the sequence of the computational procedures. Performance improvement Through algorithmic and programming revisions, improvements have been made both in accuracy and speed. The algorithmic methods which are stable and precise are newly adopted. Some of the standard methods used in the past are neglected. In programming, importance is attached to reducing execution time. Thus, the subroutines, are written in FORTRAN to enjoy the optimization of the compiler. SSLII improves the locality of the virtual storage system program, but does not decrease the efficiency of a computer without virtual storage. Improvement of reliability In most cases, single and double precision routines are generated from the same source program. Maintenance of compatibility Nowadays, developed softwares are easily transferred between different type systems. The SSL II subroutines are structured to maintain compatibility. A few auxiliary subroutines which are dependent of the system are created.
1.2
DEVELOPMENT OBJECTIVES
Systematizing It is important for a library to enable the user to quickly identify subroutines which will suit his purposes. SSLII is organized with emphasis on the following points: We classify numerical computations as follows: A Linear algebra B Eigenvalues and eigenvectors C Nonlinear equations D Extrema E Interpolations and approximations F Transforms G Numerical differentiation and quadrature H Differential equations I Special functions J Pseudo random numbers These categories are further subdivided for each branch. The library is made in a hierarchy organization. The organization allows easier identifying the locations of individual subroutines. Some branches have subdivided functions. We present
1.3
FEATURES
SSL II is a collection of subroutines written in FORTRAN and desired subroutines are called in user programs using the CALL statement. All subroutines are written without input statements, user data is assumed to be in main storage. Data size is defined with subroutine parameters. No restrictions are applied to data size within subroutines. To save storage space for linear and eigenvalue17
eigenvector calculus, symmetric and band matrices are stored in a compressed mode (see Section 2.8 Data Storage Methods). All subroutines have an output parameter which indicates status after execution. A code giving the state of the processing is returned with this parameter (refer to Section 2.6 Return Conditions of Processing). Subroutines will always return control to the calling program. The user can check the contents of this parameter to determine proper processing. If specified, the condition messages are output (refer to section 2.6 return conditions of processing).
1.4
If the FORTRAN compilers can be used on the users system, SSL II can also be used regardless of the system configuration. But, the storage size depends on the number and size of SSL II subroutines, the size of the user program, and the size of the data. Although, as shown above, SSL II subroutines are usually called by FORTRAN programs, they can also be called by programs written in ALGOL, PL/1, COBOL, etc., if the system permits. When the user wishes to do that, refer to the section in FORTRAN (or another compiler) Users Guide which describes the interlanguage linkage.
18
2.1
TYPES OF SUBROUTINES
2.3
SUBROUTINE NAMES
Each of SSL II subroutines has the inherent subroutine name according to the subroutine type on following conventions. General subroutine names Names begin with S or D depending on the working precision, as shown in Fig. 2.2. Slave subroutine names For subroutine subprograms or real function subprograms Names begin with the working precision identifier which is same as in general subroutines followed by a letter U as shown in Fig. 2.3. For complex function subprograms Names begin with letter Z. The other positions are similar to those shown above. See Fig. 2.4. Auxiliary subroutines Auxiliary subroutines are appropriately named according to their functions, see Appendix A for details.
Auxiliary subroutine
The general subroutines in Table 2.1 are further divided, as shown in Table 2.2, into two levels according to the function. This division occurs when, in order to performs a particular function, a routine is internally subdivided into elementary functions.
Table 2.2 Subroutine levels Level Standard routine Component routine Function A single unified function is performed, for instance, when solving a system of linear equations. An elementary function is performed, for instance, for triangular factoring of a coefficient matrix. Several component routines are grouped to make a standard routine.
2.4
PARAMETERS
Transmission of data between SSL II subroutines and user programs is performed only through parameters. This section describes the types of SSL II parameters, their order, and precautions. Usage of parameters Input/output parameters These parameters are used for supplying values to the subroutine on input, and the resultant values are returned in the same areas on output. Input parameters These parameters are used for only supplying values to the subroutine on input. The values are unchanged on output. If values are changed by subroutine, it is described as The contents of 19
2.2
CLASSIFICATION CODES
Each of SSL II general subroutines has the eleven character classification codes according to the conventions in Fig. 2.1.
10
3 digits: Subroutine number Serial number assigned under the same classification 2 digits: Minor classification and appending classification 1 digit: Middle classification Alphabetic letter + 1 digit: Major classification
A B C D E F G H I J
Linear algebra Eigenvalues and eigenvectors Non-linear equations Extrema Interpolation and approximation Transform Nomerical differentiation and quadrature Differential equations Special function Pseudo random numbers
Output parameters The resultant values are returned on output. Work parameters These are used as work areas. In general, the contents of these parameters are meaningless on output. In addition, parameters can be also classified as follows: Main parameters These parameters contain the data which is used as the object of numerical calculations (for example, the elements of matrices). Control parameters These parameters contain data which is not used as the object of numerical calculations (for example, the order of matrices, decision values, etc.). Order of parameter Generally, parameters are ordered according to their kind as shown in Fig. 2.5.
An alphanumeric string of up to 4 characters: Corresponds to that of general subroutine. Fixed 1 alphabetic letter: Identifies the working precision. Fig. 2.3 Subroutine names of slave subroutines (1)
Fixed 1 alphabetic letter: Identifies the working precision. Fixed Fig. 2.4 Subroutine names of slave subroutines (2)
20
GENERAL RULES
, ICON)
EXTERNAL statement in the user program which calls the SSL II subroutines. Status after execution SSL II subroutines have a parameter named ICON which indicates the return conditions of processing. See Section 2.6.
Work parameters Output parameters Input parameters Input/output parameters Note: The unshaded blocks indicate main parameters: the shaded blocks indicate control parameters. The ICON parameter indicates the return conditions of processing. Fig. 2.5 Parameter ordering
2.5
DEFINITIONS
Matrix classifications Matrices handled by SSL II are classified as shown in Table 2.3.
Table 2.3 Matrix classification Factors Structure Form Type Character Classifications Dense matrix Band matrix Symmetric matrix Unsymmetric matrix Real matrix Complex matrix Positive definite Non singular Singular
Some control parameters cannot conform to Fig. 2.5 (for instance, adjustable dimension of array), therefore the explanation of each subroutine gives the actual ordering. Handling of parameters Type of parameter Type of parameter conforms to the implicit typing convention of FORTRAN except parameters that begin with the letter Z. For instance, A is a 4 byte real number (8 byte real number in double precision subroutines) and IA is a standard-byte-length integer. When complex data is handled with complex variables, Z is the first letter of the parameter. ZA is an 8-byte complex number (16-byte complex number in double precision subroutines). External procedure name When external procedure names are specified for parameters, those names must be declared with an
Portion names of matrix In SSL II, the portion names of matrix are defined as shown in Fig. 2.6. The portion names are usually used for collective reference of matrix elements. Where, the elements of the matrix are referred to as aij.
Upper triangular portion {Upper triangular elements |aij A , j i+1} Lower triangular portion {Lower triangular elements | aij A, I j+1} Second super-diagonal portion (*) {Second super-diagonal elements | aij A, j=i+2} (First) super-diagonal portion(*) {(First) super-diagonal elements | aij A, j=i+1} (Main) diagonal portion (*) {(Main) diagonal elements | aij A, i=j} (First)sub-diagonal portion {(First) sub-diagonal elements | aij A, i=j+1} Second sub-diagonal portion(*) {Second sub-diagonal elements | aij A, i=j+2} Upper band portion {Upper band elements | aij A, i+h2 j i+1} Lower band portion {Upper band elements | aij A, i+h1 j i+1} (*) Sometimes called diagonal line Upper band width h2 Lower band width h1
A=
21
Matrix definition and naming Matrices handled by SSL II have special names depending on their construction. Upper triangular matrix The upper triangular matrix is defined as aij = 0 , j < i (2.1)
Block diagonal matrix Considering an ni n j matrix Aij (i.e. a block) within an n n matrix A, where n = ni = n j , then the block diagonal matrix is defined as Aij = 0 , i j (2.7)
Namely, the elements of the lower triangular portion are zero. Unit upper triangular matrix The unit upper triangular matrix is defined as 1 , j = i aij = 0 , j < i (2.2)
In other words, all the blocks are on the diagonal line so that the block diagonal matrix is represented by a direct sum of those blocks. Hessenberg matrix The Hessenberg matrix is defined as aij = 0 , j < i 1 (2.8)
Namely, this matrix is the same as an upper triangular matrix whose diagonal elements are all 1. Lower triangular matrix The lower triangular matrix is defined as aij = 0 , j > i (2.3)
Namely, all of the elements except for ones of the upper triangular, the main-diagonal and the lower subdiagonal portions are zero. Symmetric band matrix The symmetric band matrix whose both upper and lower band widths are h is defined as 0 , i j > h aij = a ji , i j h Namely, all of the elements except for ones of the diagonal, upper and lower band portions are zero. Band matrix The band matrix whose upper band width is h1, and lower band width is h2 is defined as 0 , j > i + h2 aij = 0 , i > j + h1 (2.10)
(2.9)
Namely, the elements of the upper triangular portion are zero. Unit lower triangular matrix The unit lower triangular matrix is defined as 1 , j = i aij = 0 , j > i (2.4)
This matrix is the same as a lower triangular matrix whose diagonal elements are all 1. Diagonal matrix The diagonal matrix is defined as aij = 0 , j i (2.5)
Namely, all of the elements except for ones of the diagonal, the upper and lower band portions are zero. Upper band matrix The upper band matrix whose upper band width is h is defined as 0 , j > i + h aij = 0 , j < i (2.11)
Namely, all of the elements of the lower and the upper triangular portions are zero. Tridiagonal matrix The tridiagonal matrix is defined as 0 , j < i 1 aij = 0 , j > i + 1 Namely, all of the elements except for ones of the upper and lower sub-diagonal and main-diagonal portions are zero. (2.6)
Namely, all of the elements except for ones of the diagonal and upper band portions are zero. Unit upper band matrix The unit upper band matrix whose upper band width is h is defined as
22
GENERAL RULES
Code
Meaning Processing has ended normally. Processing has ended normally. Auxiliary information was given. Restrictions were employed during execution in order to complete the processing. Processing was aborted due to abnormal conditions which had occurred during processing. Processing was aborted due to invalid input parameters.
(2.12)
0 1~ 9999
Status Normal
This matrix is the same as an upper band matrix whose diagonal elements are all 1. Lower band matrix The lower band matrix whose lower band width is h is defined as 0, aij = 0, j <ih j >i (2.13)
10000 ~ 19999
The results are correct on the restrictions. The results are not correct.
Caution
20000 ~ 29999
Abnormal
30000
Namely, all of the elements except for ones of the diagonal and lower band portions are zero. Unit lower ban matrix The unit lower band matrix whose lower band width is h is defined as 1, j = i aij = 0, j < i h 0, j > i
(2.14)
Comments about condition codes Processing control by code testing The condition code had better be tested in the users program immediately after the statement which calls the SSL II subroutine. Then, the processing should be controlled depending on whether the results are correct or not.
Namely, this matrix is the same as a lower band matrix whose diagonal elements are all 1. Hermitian matrix The hermitian matrix is defined as a ji = a *ij (2.15)
CALL LSX (A, N, B, EPSZ, ISW, ICON) IF (ICON. GE. 20000) STOP
Output of condition messages The SSL II subroutines have a function to output condition messages. Normally, these messages are not output. When the user uses message output control routine MGSET (SSL II auxiliary subroutine) messages are automatically output.
2.7
ARRAY
SSL II uses arrays to process vectors or matrices. This section describes the arrays used as parameters and their handling. Adjustable arrays, whose sizes are declared in an array declaration in the program, are used by SSL II. The user may prepare arrays the size of which are determined corresponding to the size of the data processed in the user program. One-dimensional arrays When the user stores and n (= N) - dimensional vector b(=(b1, , bn)T) in a one-dimensional array B of size N,
23
as shown below, various ways are possible. In examples below, an attention should be paid to the parameter B used in calling the subroutine LAX, which solves systems of linear equations (n 10 is assumed). A general example The following describes the case in which a constant vector b is stored in a one-dimensional array B of size 10, as B(1) = b1, B(2) = b2, ...
DIMENSION B(10)
)
In this case, regardless of the value of N, the adjustable dimension must be defined as K = 10.
The n n coefficient matrix is stored in this region which becomes the object of the processing of the SSL II subroutine. This is declared in the user program as a two-dimensional array A (10,10).
CALL LAX (
, N, B, )
N 10 Adjustable dimension
An application example The following describes the case in which a constant vector b is stored in the I-th column of a twodimensional array C (10, 10), such that C (1, I) = b1, C (2, I) = b2, .....
DIMENSION C (10, 10)
CALL LAX (
, N, C (1, I), )
When equations of different order are to be solved, if the largest order is NMAX, then a two-dimensional array A (NMAX, NMAX) should be declared in the user program. That array can then be used to solve all of the sets of equations. In this case, the value of NMAX must always be specified as the adjustable dimension.
As shown in the above example, in parameter B, if a leading element (leading address) of one array in which the data is stored consecutively is specified it is not constrained to a one-dimensional array of size N. Therefore, if vector b is stored in I-th row of array C as C(I, I) = b1 C (I, 2) = b2... it is impossible to call as follows.
2.8
DATA STORAGE
This section describes data storage modes for matrices or vectors. Matrices The methods for storing matrices depend on structure and form of the matrices. All elements of unsymmetric dense matrices, called general matrices, are stored in two-dimensional arrays. For all other matrices, only necessary elements are stored in a one-dimensional array. The former storage method is called general mode, the latter compressed mode. Detailed definition of storage modes are as follows. General mode General mode is shown in Fig. 2.8. Compressed mode for symmetric matrix As shown in Fig. 2.9, the elements of the diagonal and the lower triangular portions of the symmetric dense matrix A are stored row by row in the one-dimensional array A. Compressed mode for hermition matrix The elements of the diagonal and the lower triangular portions of the Hermitian matrix A are stored in a twodimensional array A as shown in Fig. 2.10.
CALL LAX (
, N, C (I, 1), )
Two-dimensional arrays Consider an n n real matrix A (=(aij)) being stored in a two-dimensional array A (K, N). Note that in handling two dimensional arrays in SSL II subroutines, adjustable dimension K is required as an input parameter in addition to the array A and the number of order N. The adjustable dimension used by SSL II means the number of rows K of two-dimensional array A declared in the user program. An example using a two-dimensional array along with an adjustable dimension K is shown next. The key points of the example are parameters A and K of the subroutine LAX. (Here N < 10). The following describes the case in which coefficient matrix is stored in a two-dimensional array A (10, 10) as shown in Fig. 2.7, as A (1, 1) = a11, A (2, 1) = a21, ...., A (1, 2) = a 12 ....
24
GENERAL RULES
a11 a12 a13 a14 a15 a21 a22 a23 a24 a25 a31 a32 a33 a34 a35 a41 a42 a43 a44 a45 a51 a52 a53 a54 a55
5 K
a11 b12 b13 b14 b51 a21 a22 b23 b24 b52 a31 a32 a33 b34 b53 a41 a42 a43 a44 b54 a51 a52 a53 a54 a55
5 K
I(I 1)
NT
Note:
a54
Compressed mode for symmetric band matrix The elements of the diagonal and the lower band portions of a symmetric band matrix A are stored row by row in a one-dimensional array A as shown in Fig. 2.11. Compressed mode for band matrix The elements of the diagonal and the upper and lower band portions of an unsymmetric band matrix A are stored row by row in a one-dimensional array A as shown in Fig. 2.12.
a
ij
( ( )) (2 + J) A (hI + J h (h + 1) 2)
)
a55
) (
Fig. 2.11 Storage of symmetric band matrices Vectors Vector is stored as shown in Fig. 2.13.
25
a11 a 21 A = a31 0
0 a32 a33 a34 a42 a43 a44 a45 a53 a54 a55 a12 a22 a23
a11 a12
* *
a21 a22 a23
h
*
a31 a32 a33 a34 Note: R NT =nh h =min(h1+h2+1,n) where h2: Upper band width h1: Lower band width n : Order of metrix a42 a43 a44 a45 a53 a54 a55
h h h NT
*
Fig. 2.12 Storage of unsymmetric band matrices
x = x1 x2 x3 x n
x1 x2 x3 n
xn
a = a1 a2 a3 a n
a1 a2 a3 n+1
an
Coefficients of polynomial equations The general form of polynomial equation is shown in (2.16)
a0 + a1 xn + + an 1 x + an = 0
1
(2.16)
Regarding the coefficients as the elements of a vector, the vector is stored as shown in Fig. 2.14. Coefficients of approximating polynomials The general form of approximating polynomial is shown in (2.17).
2 n Pn( x ) = c0 + c1x + c2x + + cnx
c = c1 c2 c3 c n
c1 c2 c3 n+1
cn
(2.17)
Regarding the coefficients as the elements of a vector, the vector is stored as shown in Fig. 2.15.
26
GENERAL RULES
[2]
2.9
Wilkinson, J.H. Rounding Errors in Algebraic Process Her Britannic Majestys Stationery Office, London 1963
SSL II subroutines frequently use the unit round off. The unit round off is a basic concept in error analysis for floating point arithmetic. Definition The unit round off of floating-point arithmetic are defined as follows: u = M1-L / 2, for (correctly) rounded arithmetic u = M1-L, for chopped arithmetic In SSL II, the unit round off is used for convergence criterion or testing loss of significant figures. Error analysis for floating point arithmetic is covered in the following references: [1] Yamashita, S. On the Error Estimation in Floating-point Arithmetic Information Processing in Japan Vol. 15, PP.935939, 1974
2.10
ACCUMULATION OF SUMS
Accumulation of sums is often used in numerical calculations. For instance, it occurs in solving a system of linear equations as sum of products, and in calculations of various vector operations. On the theory of error analysis for floating point arithmetic, in order to preserve the significant figures during the operation, it is important that accumulation of sums must be given exactly. As a rule, in SSL II the higher precision accumulation is used to reduce the effect of round off errors.
2.11
Computer Constants
This manual uses symbols to express computer constants that are based on hardware restrictions. The symbols are defined as follows: flmax: Positive maximum value for the floating-point number system (See AFMAX in Appendix A.) flmin: Positive minimum value for the floating-point number system (See AFMIN in Appendix A.) tmax: Upper limit value of an argument for a trigonometric function (sin and cos)
Upper limit of argument Single 8.23 x 105 precision Double 3.53 1015 precision Application FACOM M series FACOM S series SX/G 100/200 series FM series
27
3.1
OUTLINE
Operations of linear algebra are classified as in Table 3.1 depending on the structure of the coefficient matrix and related problems.
Table 3.1 Classification of operation for linear equations Structures Problem Conversion of matrix storage mode Dense Matrix manipulation matrix Systems of linear equations Matrix inversion Least squares solution Band Matrix manipulation matrix Systems of linear Direct method equations
This classification allows selecting the most suitable solution method according to the structure and form of the band matrices when solving system of linear equations. The method of storing band matrix elements in memory is especially important. It is therefore important when performing linear equations to first determine the structure of the matrices.
The method to store the elements of a matrix depends on the structure and form of the matrix. For example, when storing the elements of a real symmetric matrix, only elements on the diagonal and upper triangle portion are stored. (See Section 2.8). Therefore, to solve systems of linear equations, SSL II provides various subroutines to handle different matrices. The mode conversion subroutines are required when the subroutine for a particular storage mode is used for other storage mode. The mode conversion subroutines shown in Table 3.2 are provided for this purposed.
General mode
CSBSM (A11-50-0201)
28
LINEAR ALGEBRA
Basic arithmetic Addition/Subtraction of two matrices Multiplication of a matrix by a vector Multiplication of two matrices AB
Vector
MGSM (A21-11-0401)
MSGM (A21-12-0401)
These subroutines are designed to multiply a matrix and a vector as well as obtain a residual vector in approximation solution of systems of linear equations. That is, they are used iteratively to refine the approximation solution or to solve a system of linear equations.
(c) Iterative refinement of the initial solution (d) Matrix inversion based on the decomposed matrix Combinations of the subroutines ensure that systems of linear equations, inverse matrices, and the determinants can be solved. Linear equations The solution of the equations can be obtained by calling the component routines consecutively as follows:
Matrix inversion The inverse can be obtained by calling the above components routines serially as follows:
29
GENERAL DESCRIPTION
The inverse of band matrices generally result in dense matrices so that to obtain such the inverse is not inefficient for operation convenience. Those component routines for the inverse are not prepared in SSL II. Determinants There is no component routine which finds the values of determinant. However, the values can be obtained from the elements decomposed by the component routine (a). Though any problem can be solved by properly combining these component routines, SSL II also has routines, called standard routines, in which component routines are grouped for standard needs, it is recommended that the user calls these standard routines. Table 3.4 lists the standard routines and component routines. Comments on uses Iterative refinement of a solution In order to refine the accuracy of solution obtained by standard routines, component routines (c) should be successively called regarding the solution as the initial approximation. In addition, the component routine (c) serves to estimate the accuracy of the initial approximation. Matrix inversion Usually, it is not advisable to invert a matrix when solving a system of linear equations. Ax = b (3.1)
Therefore, matrix inversion should only be performed when absolutely necessary. Equations with identical coefficient matrices When solving a number of systems of linear equations as in (3.5) where the coefficient matrices are the identical and the constant vectors are the different, Ax1 = b1 Ax 2 = b2 Ax m = bm
(3.5)
it isnt advisable to decompose the coefficient A for each equation. After decomposing A when solving the first equation, only the forward and backward substitution shown in (3.3) should be performed for solving the other equations. In standard routines, whether or not processing begins with the decomposing of A is determined by parameter ISW provided in the routines. Notes and internal processing When using subroutines, the following should be noted for convenience of internal processing. Crouts method, modified Choleskys method In SSL II, the Crouts method is used for decomposing a general matrix. Generally the Gaussian elimination and the Crouts method are known for decomposing (as in (3.6)) general matrices. A = LU (3.6)
That is, in solving equations (3.1), the solution should not obtained by calculating the inverse A-1 and then multiplying b by A-1 from the left side as shown in (3.2). x=A b
-1
where: L is a lower triangular matrix and U is an upper triangular matrix. The two methods require the different calculation order, that is, the former is that an intermediate value is calculated during decomposing and all elements are available only after decomposing. The latter is that each element is available during decomposing. Numerically the latter can be obtained the decomposed element by using the inner product of two vectors. So if the effect of rounding errors by inner product is designed to be minimized. Crouts method can compute the decompotion with higher accuracy than Gaussian method. Also, the data reference order in the Crouts method is more localized during the decomposition process than in the Gaussian method. Therefore, in SSL II, the Crouts method is used as possible as, and the precision of accumulation is raised to minimize the effect of rounding errors. While, the modified Cholesky method is used for positive-definite symmetric matrices, that is, the decomposition shown in (3.7) is done.
(3.2)
But, it is advisable to compute the LU-decomposition of A and then perform the operations (forward and backward substitutions) shown in (3.3). Ly = b Ux = y (3.3)
Higher operating speed and accuracy can be attained by using method (3.3). The approximate number of multiplications involved in the two methods (3.2) and (3.3) are compared in (3.4). For(3.2) n3 + n 2 For(3.3) n 3 / 3 (3.4)
30
LINEAR ALGEBRA
Table 3.4 Standard and component routines Standard routines Problem Basic functions Types of matrix Real general matrix Complex general matrix Real symmetric matrix Real positivedefinite symmetric matrix Real general band matrix Systems of linear equations LAX (A22-11-0101) LCX (A22-15-0101) LSIX (A22-21-0101) LSX (A22-51-0101) LBX1 (A52-11-0101)
LTX (A52 - 11- 0501)
Component routines (a) ALU (A22-11-0202) CLU (A22-15-0202) SMDM (A22-21-0202) SLDL (A22-51-0202) BLU1 (A52-11-0202) (b) LUX (A22-11-0302) CLUX (A22-15-0302) MDMX (A22-21-0302) LDLX (A22-51-0302) BLUX1 (A52-11-0302) (c) LAXR (A32-11-0401) LCXR (A22-15-0401) LSIXR (A22-21-0401) LSXR (A22-51-0401) LBXIR (A52-11-0401) (d) LUIV (A22-11-0602) CLUIV (A22-15-0602)
LDIV (A22-51-0702)
LSBXR (A52-31-0401)
A = LDLT where: L is a lower triangular matrix and D is a diagonal matrix. Matrices are decomposed as shown in Table 3.5.
Table 3.5 Decomposed matrices Kinds of matrices General matrices
(3.7)
Contents of decomposed matrices PA = LU L: Lower triangular matrix U: Unit upper triangular matrix P is a permutation matrix. A = LDLT L: Unit lower triangular matrix D: Diagonal matrix To minimize calculation, the diagonal matrix is given as D-1
Pivoting and scaling Consider to decompose the real general matrix (3.8) into the form shown in (3.6). . 0.0 10 A= 2.0 0.0 (3.8)
These unfavorable conditions can frequently occur when the state of a matrix is not proper. This can be avoided by pivoting, which selects the element with the maximum absolute value for the pivot. Problems can be avoided in (3.9) by exchanging each element in the first row and the second row. In order to perform pivoting, the method used to select the maximum absolute value must be unique. By multiplying all of the elements of a row by a large enough constant, any absolute value of non-zero element in the row can be made larger than those of elements in the other rows. Therefore, it is just as important to equilibrate the rows and columns as it is to validly determine a pivot element of the maximum size in pivoting. SSL II uses partial pivoting with row equilibration. The row equilibration is performed by scaling so that the maximum absolute value of each row of the matrix to be decomposed is 1. However, actually the values of the elements are not changed in scaling; the scaling factor is used when selecting the pivot. Since row exchanges are performed in pivoting, the historical data is stored as the transposition vector. The matrix decomposition which accompanies this partial pivoting can be expressed as; PA = LU (3.10)
In this state, LU decomposition is impossible. And also in the case of (3.9) . 0.0001 10 A= . 10 . 10 (3.9)
Decomposing by floating point arithmetic with the precision of three digits will cause unstable solutions. 31
GENERAL DESCRIPTION
Transposition vectors As mentioned above, row exchange with pivoting is indicated by the permutation matrix P of (3.10) in SSL II. This permutation matrix P is not stored directly, but is handled as a transposition vector. In other words, in the j th, stage (j = 1,.., n) of decomposition, if the th row (i j) is selected as the j th pivotal row, the i th row and the j th row of the matrix in the decomposition process are exchanged and the j th row element of the transposition vector is set to i. How to test the zero or relatively zero pivot In the decomposition process, if the zero or relatively zero pivot is detected, the matrix can be considered to be singular. In such a case, proceeding the calculation involved such a pivot under limited significant digits might fail to obtain the accurate result. In SSL II, parameter EPSZ is used in such a case to determine whether to continue or discontinue processing. In other words, when EPSZ is set to 10-s in calculating the pivot, if a loss of over s significant digits occurred, the pivot might be considered to be relatively zero. Iterative refinement of a solution To solve a system of linear equations numerically means to obtain only an approximate solution. Ax = b (3.11)
From Eqs. (3.12), (3.14) and (3.15), the following relationships can be obtained. x ( s 1) x = I ( A + E ) A
+ 1
r ( s 1) = I A( A + E)
+
1 s
]r
] (x
s
( 1)
(3.16) (3.17)
( 1)
As can be seen from Eqs. (3.16) and (3.17), if the following conditions are satisfied, x(s+1) and r(s+1) converge to the solutions X and 0, respectively, as s.
1 1 I ( A + E) A , I ( A + E) A < 1
In other words, if the following condition is satisfied, an refined solution can be obtained. E A 1
< 1/ 2
(3.18)
This method described above is the iterative refinement of a solution The SSL II repeats the computation until at least one binary digit of precision is obtained for each repetition. This method will not work if the matrix A conditions are not suitable. A1 may become large, so that no refined solution will be obtained. Accuracy estimation for approximate solution Suppose e(1) (= x(1) x) is an error generated when the approximate solution x(1) is computed to solve a linear equations. The relative error is represented by e (1)
SSL II provides a subroutine to refine the accuracy of the obtained approximate solution SSL II repeats the following calculations until a certain convergence criterion is satisfied.
r = b Ax Ad ( s ) = r ( s ) x ( s+1) = x ( s ) + d ( s )
( s) (s)
/ x (1) .
From the relationship between d(1) and e(1), Eq. (3.19) results from Eqs. (3.12) and (3.15), where E is the error matrix described in paragraph above. d (1) = ( A + E ) b Ax( 1 ) = ( I + A1 E ) e (1)
1 1
where s = 1, 2,..... The x(2) becomes an exact solution of Eq. (3.11) if substitutions are performed accurately as follows by using Eqs. (3.12), (3.13) and (3.14); Ax
(2 )
(3.19)
If the iterative method satisfies the condition (3.18) and converges, d (1) d (1 )
= A( x + d
(1)
(1 )
) = Ax
(1)
+r
(1)
=b
Actually, however, rounding errors will be generated in the computation of Eqs. (3.12), (3.13) and (3.14). As a result, the SSL II assumes that rounding errors occur only when the correction d(s) is computed by using Eq. (3.13), so that d(s) is assumed to be the exact solution of the following equation
/ x (1) .
3.5
( A + E )d
(s )
=r
(s )
(3.15)
Here, the following problems are handled: Least squares solution Least squares minimal norm solution Generalized inverse Singular value decomposition SSL II provides the following subroutines to perform the following functions as listed in Table 3.6.
32
LINEAR ALGEBRA
Table 3.6 Subroutines for m n matrices Kinds of matrix Function Least squares solution Interactive refinement of the least squares solution Least squares minimal norm solution Generalized inverse Singular value decomposition Real matrix LAXL (A25-11-0101) LAXLR (A25-11-0401) LAXLM (A25-21-0101) GINV (A25-31-0101) ASVD1 (A25-31-0201)
Least squares solution ~ The least squares solution obtains the solution x which minimizes Ax b 2 of the system of linear equations Ax = b, where A is an m n matrix (m n, rank (A) = n), x is an n-dimensional vector and b is an m-dimensional vector. SSL II has two subroutines which perform the following functions. Obtaining the least squares solution Iterative refinement of the least squares solution Least squares minimal norm solution The least squares minimal norm solution obtains the solution x+ which minimizes x 2 in vector x in which Ax b 2 has been minimized in the system of linear equations Ax = b. Where A is an m n matrix, x is an n-dimensional vector and b is an m-dimensional vector. Generalized inverse When n m matrix X satisfies the following equations in (3.20) for m n matrix A, this is called a MoorPenrose generalized inverse of a matrix A. AXA = A XAX = X ( AX )T = AX ( XA)T = XA
Here U0 and V are orthogonal matrices of n m and m n respectively, 0 is an m n diagonal matrix where 0=diag(i ) and i 0. The i are called singular values of a real matrix A. Suppose m n in real matrix A with matrix m n. Since 0 is an m n diagonal matrix, the first n columns of U0 are used for U0 n VT in (3.21). That is, U0 may be considered as an m n matrix. Let U be this matrix, and let be an n n matrix consisting of matrix 0 without the zero part, (mn) n, of 0. When using matrices U and , if m is far larger than n, the storage space can be reduced. So matrices U and are more convenient than U0 and 0 in practice. This can be applied for a real matrix, wher m is smaller than n (m < n). Considering above ideas SSL II performs the following singular value decomposition. A = UV T (3.22)
where: l = min (m, n) is assumed and U is an m l matrix, is an l l diagonal matrix where = diag (i ), and i 0, and V is an n l matrix. When l=n (m n), U T U = V TV = VV T = I n when l = m ( m n ), U TU = UU T = V TV = I m Matrices U, V and which are obtained by computing singular values of matrix A are used and described as follows; (For details, refer to reference [86],) Singular values i , i = 1, 2, ..., l are the positive square root upto l-th eigenvalue of matrices ATA and AAT starting with the large. The i-th column of matrix U is an eigenvector of matrix AAT for corresponding to eigenvalue i 2. The i-th column of matrix U is an eigenvector of matrix AAT for corresponding to eigenvalue i 2. This will be calculated by multiplying AT = V UT from the right and left sides of (3.22) and apply UT U = VT V = Il as follows: AT AV = V 2 AAT U = U 2 (3.23) (3.24)
(3.20)
The generalized inverse always exists uniquely. The generalized inverse A of a matrix X is denoted by A+ SSL II calculates the generalized inverse as above. SSL II can handle m n matrices in any cases like following: m is larger than n m is equal to n m is smaller than n Singular value decomposition Singular value decomposition is obtained by decomposing a real matrix A of m n as shown in (3.21). A = U 0 0 V T (3.21)
Condition number of matrix A If i > 0, i=1, 2, ..., l, then condition number of matrix A is given as follows;
cond( A) = 1 / l
(3.25)
33
GENERAL DESCRIPTION
Basic solution of homogeneous linear equations Ax = 0 and AT y = 0 The classes of linearly independent solutions (other than trivial of homogeneous linear equations Ax = 0 and AT y = 0 are expressed by those of matrices V and U corresponding to singular values i = 0. This can be easily obtained from equations AV = U and . Least squares minimal norm solution of Ax = b The solution x is represented by using singular solution A as follows; x = V +U T b where diagonal matrix + is defined as follows: (3.27)
obtained. This requires a great amount of calculation. It is advisable to use the subroutine for the least squares minimal norm solution, for the sake of high speed processing. This subroutine provides parameter ISW by which the user can direct to solve the equations with the same coefficient matrix with less calculation or to solve the single equation with efficiency. Equations with the identical coefficient matrix The least squares solution or least squares minimal norm solution of a system of linear equations can be obtained in the following procedures; Decomposition of coefficient matrices Reducing a matrix to an upper triangular matrix and singular value decomposition of a matrix are performed for the least squares solution and the least squares minimal norm solution respectively. Obtaining solution Backward substitution and multiplication of matrices or vectors are performed for the leastsquares solution and the least squares minimal norm solution respectively. When obtaining the least squares solution or least squares minimal norm solution of a number of systems with the identical coefficient matrices, it is not advisable to repeat the decomposition. Ax1 b1 Ax 2 b2
+ = diag( 1 , 2 , , l
+ +
)
+
(3.28) (3.29)
1 / i , i > 0 i + = 0 , i = 0
For details, refer to Method of subroutine LAXLM. Generalized inverse of a matrix Generalized inverse A+ of A is given after decomposing A into singular value as follows; A+ = V +U T (3.30)
Ax m x m In this state, user should decompose the matrix to solve only the forst system of equations only the procedures necessary to obtain the subsequent solution this results in the redution of number of calculations. SSL II provides parameter ISW which can controls whether matrix A is decomposed or not. Obtaining singular values The singular value will be obtained by singular value decomposition as shown in (3.31): A = U V T (3.31)
Comments on uses Systems of linear equations and the rank of coefficient matrices Solving the systems of linear equations (Ax = b) with an m n matrix as coefficient, the least squares minimal norm solution can be obtained regardless of the number of columns or rows, or ranks of coefficient matrix A. That is, the least squares minimal norm solution can be applied to any type of equations. However, this solution requires a great amount of calculation for each process. If the coefficient matrix is rectangular and number of rows is larger than that of columns and the rank is full (full rank, rank (A) = n), you should use the subroutine for least squares solution because of less calculation. In this state, the least squares solution is logically as least squares minimal norm solution. Least squares minimal norm solution and generalized inverse The solution of linear equations Ax = b with m n matrix A (m n or m < n, rank(A) 0) is not normally obtained. However, the least squares minimal norm solution always exists uniquely. This solution can be calculated by x = A+ b after generalized inverse A+ of coefficient matrix A is 34
As shown in (3.31), matrices U and V are contained in the equation along with matrix which consists of singular values. Since singular value decomposition requires a great amount of calculation, the user need not calculate it when matrices U and V are not required. SSL II provides parameter ISW to control whether matrices U or V should be obtained. SSL II can handle any type of m n matrices (m > n, m = n, m < n).
4.1
OUTLINE
Eigenvalue problems can be organized as show in Table 4.1 according to the type of problem (Ax= x, Ax= Bx) and the shape (dense, band), type (real, complex), and form (symmetric, unsymmetric) of the matrices. The reader should refer to the appropriate section specified in the table.
Table 4.1 Organization of eigenvalue problem Shape of matrix Dense matrix Type of problem Ax=x Explanation section 4.2 4.3 4.4 4.5 4.7 4.6 4.8
Matrix type and form Real matrix Complex matrix Real symmetric matrix Hermitian matrix Real symmetric matrix Real symmetric band matrix Real symmetric band matrix
Band matrix
Note: Refer to the section on a real symmetric matrix concerning a real symmetric tridiagonal matrix.
Table 4.2 Subroutines used for standard eigenproblem of a real matrix Level Standard routines Function Eigenvalues and eigenvectors of a real matrix Balancing of a real matrix Reduction of a real matrix to a Hessenberg matrix Component routines Obtaining the eigenvalues of a real Hessenberg matrix Obtaining the eigenvectors of a real Hessenberg matrix Back transformation to and normalization of the eigenvectors of a real matrix Normalization of the eigenvectors of a real matrix Subroutine name EIG1 (B21-11-0101) BLNC (B21-11-0202) HES1 (B21-11-0302) HSQR (B21-11-0402) HVEC (B21-11-0502) HBK1 (B21-11-0602) NRML (B21-11-0702)
35
GENERAL DESCRIPTION
In addition, obtaining the eigenvectors corresponding to specified eigenvalues can only be done by calling a series of component routines. Obtaining all eigenvalues In the following programs, all eigenvalues of the real matrix A are obtained through the use of the component routines shown in steps 1), 2), 3).
CAL BLNC (A, K, N, DV, ICON) 1) IF (ICON .EQ. 30000) GO TO 1000 CALL HES1 (A, K, N, PV, ICON) 2) CALL HSQR (A, K, N, ER, EI, M, ICON) 3) IF (ICON .EQ. 20000) GO TO 2000
1) A is balanced, if balancing is not necessary, this step is omitted. 2) Using the Householder method, A is reduced to a Hessenberg matrix. 3) By calculating the eigenvalues of the Hessenberg matrix using the double QR method, the eigenvalues of A are obtained. Obtaining all eigenvalues and corresponding eigenvectors (or selected eigenvectors) All eigenvalues and corresponding eigenvectors of real matrix A can be obtained by calling the component routines shown in 1) to 5) or by calling the standard routine shown in 6).
CALL BLNC (A, K, N, DV, IF (ICON .EQ. 30000) GO CALL HES1 (A, K, N, PV, DO 10 I = 1, N DO 10 J = 1, N AW (J, I) = A (J, I) 10 CONTINUE CALL HSQR (A, K, N, ER,
1) 2)
3) destroys parameter A, A must bestored in array AW after 2) so that contents of A before 3) can used in 4). 4) The eigenvectors corresponding to the eigenvalues are obtained using the inverse iteration method. The parameter IND is an index vector which indicates the eigenvalues from which eigenvectors are to be obtained. The user can select eigenvectors using this parameter. 5) Back transformation of the eigenvectors obtained in 4) is performed. The transformed eigenvectors are normalized at the same time. From the processing of 1) and 2), the eigenvectors of 4) are not the eigenvectors of real matrix A. The eigenvectors of A are obtained by performing the post-processing corresponding to 1) and 2). Each column (i.e., each eigenvector) of parameter EV is normalized such that its Euclidean norm is 1. 6) When obtaining all eigenvalues and corresponding eigenvectors of a real matrix, the functions of 1) to 5) can be performed by calling this standard routine, however, instead of using the inverse iteration method, all eigenvectors are obtained at a time by multiplying all the transformation matrices obtained successively. This calculation will not work if even one eigenvalue is missing. However, if eigenvalues are close roots or multiple roots, eigenvectors can be determined more accurately using this method than the inverse iteration method. The standard routine 6) does not always perform the process in step 1). The parameter MODE can be used to specify whether step 1) is performed or not. Balancing of matrices Errors on calculating eigenvalues and eigenvectors can be reduced by reducing the norm of real matrix A. Routine 1) is used for this purpose. By diagonal similarity transformation the absolute sum of row I and that of column I in A is made equal (this is called balancing). Symmetric matrices and Hermitian matrices are already balanced. Since this method is especially effective when magnitudes of elements in A differ greatly, balancing should be done. Except in certain cases (i.e. when the number of the order of A is small), balancing should not take more than 10% of the total processing time.
EI, M, ICON) 3) IF (ICON .GE. 20000) GO TO 2000 DO 20 I = 1, M IND (I) = 1 20 CONTINUE CALL HVEC (AW, K, N, ER, EI, IND, M, EV, MK, VW, ICON) 4) IF (ICON .GE. 20000) GO TO 3000 CALL HBK1 (EV, K, N, IND, M, A, PV, * DV, ICON) 5)
or standard routine.
1), 2), and 3) were explained in the preceding example Obtaining all eigenvalues. However since
36
Table 4.3 Subroutines used for standard eigenproblem of a complex matrix Level Standard routine Function Eigenvalues and eigenvectors of a complex matrix Balancing of a complex matrix Reduction of a complex matrix to a complex Hessenberg matrix Obtaining the eigenvalues of a complex Hessenberg matrix Obtaining the eigenvectors of a complex Hessenberg matrix Back transformation to the eigenvectors of a complex matrix Normalization of the eigenvectors of a complex matrix Subroutine name CEIG2 (B21-15-0101) CBLNC (B21-15-0202) CHES2 (B21-15-0302) CHSQR (B21-15-0402) CHVEC (B21-15-0502) CHBK2 (B21-15-0602) CNRML (B21-15-0702)
Component routine
SSL II provides the following: Standard routines by which the entire procedures for obtaining eigenvalues and eigenvectors of complex matrices may be performed at one time. Component routines decomposed by functions For details, see Table 4.3 User problems are classified as follows: Obtaining all eigenvalues Obtaining all eigenvalues and corresponding eigenvectors (or selected eigenvectors) In the first and second items that follow, the use of component routines and standard routines are explained by describing their procedures. When obtaining all eigenvalues and corresponding eigenvectors whether the standard routines only or the various corresponding component routines are used is up to the user. However it is recommended to call the former for its easy handling. Obtaining all eigenvalues In the following programs, all eigenvalues of the complex matrix A are obtained through the use of the component routines shown in steps 1), 2), and 3).
CALL CBLNC (ZA, K, N, DV, ICON) 1) IF (ICON. EQ. 30000) GO TO 1000 CALL CHES2 (ZA, K, N, IP, ICON) 2) CALL CHSQR (ZA, K, N, ZE, M, ICON) 3) IF (ICON. GE. 15000) GO TO 2000
Obtaining all eigenvalues and the corresponding eigenvectors (or selected eigenvectors) All eigenvalues and the corresponding eigenvectors of a complex matrix A can be obtained by calling the component routines shown in 1) to 6) or by calling the standard routine shown in 7).
CALL CBLNC (ZA, K, N, DV, ICON) 1) IF (ICON. EQ. 30000) GO TO 1000 CALL CHES2 (ZA, K, N, IP, ICON) 2) DO 10 J = 1, N DO 10 I = 1, N ZAW (I, J) = ZA (I, J) 10 CONTINUE CALL CHSQR (ZA, K, N, ZE, M, ICON)3) IF (ICON. GE. 15000) GO TO 2000 DO 20 I = 1, M IND (I) = 1 20 CONTINUE CALL CHVEC (ZAW, K, N, ZE, IND, * M, ZEV, ZW, ICON) 4) IF (ICON. GE. 15000) GO TO 3000 CALL CHBK2 (ZEV, K, N, IND, M, ZP, * IP, DV, ICON) 5) CALL CNRML (ZEV, K, N, IND, M, 1, * ICON) 6)
or standard routine
CALL CEIG2 (ZA, K, N, MODE, ZE, ZEV, VW, IVW, ICON) 7) * IF (ICON. GE. 20000) GO TO 1000
1) A is balanced. If balancing is not necessary, this step is omitted. 2) Using the stabilized elementary transformation, A is reduced to a complex Hessenberg matrix. 3) By calculating the eigenvalues of the complex Hessenberg matrix using the complex QR method, the eigenvalues of A are obtained.
1), 2), and 3) were explained in the preceding example Obtaining all eigenvalues. However since 3) destroys parameter ZA, ZA must be stored in array ZAW after 2) so that contents of ZA before 3) can be used in 4) and the subsequent routines. 4) The eigenvectors of the complex Hessenberg matrix corresponding to the eigenvalues are obtained using the inverse iteration method. The parameter IND is an index vector which indicates the eigenvalues from
37
GENERAL DESCRIPTION
which eigenvectors are to be obtained. The user can select eigenvectors using this parameter. 5) Back transformation of the eigenvectors obtained in 4) is performed to obtain the eigenvectors of A. 6) The eigenvectors transformed in 5) are normalized. When normalizing the eigenvectors (set norm to 1), the user can select whether an Euclidean or infinity norm should be used. Here the former is applied for normalization. 7) When obtaining all eigenvalues and corresponding eigenvectors of a complex matrix, the functions of 1) through 6) can be performed by calling this standard routine, however, instead of using the inverse iteration method, all eigenvectors are obtained at one time by multiplying all the obtained transformation matrices. This calculation will not work if even one of the eigenvalues is missing. The parameter MODE can be used to specify whether the matrix is to be balanced or not.
Obtaining selected eigenvalues. Obtaining all eigenvalues and corresponding eigenvectors. Obtaining selected eigenvalues and corresponding eigenvectors. In the above order, the first four items explain the use of component routines and standard routines. The last two items provide additional information. The choice of calling individual component routines or of calling a single standard routine for obtaining all eigenvalues and corresponding eigenvectors or selected eigenvalues and corresponding eigenvectors is up to the user. Normally, standard routines which are easier to use, are selected. Component routines TEIG1 or TEIG2 should be used if the real symmetric matrix is originally tridiagonal. SSL II handles the real symmetric matrix in symmetric matrix compressed mode (For details, refer to Section 2.8). Obtaining all eigenvalues All eigenvalues of a real symmetric matrix A can be obtained as shown below 1) and 2). A is handled in the compressed storage mode, i.e., as a one-dimensional array, for a real symmetric matrix.
CALL TRID1 (A, N, D, SD, ICON) IF (ICON .EQ. 30000) GO TO 1000 CALL TRQL (D, SD, N, E, M, ICON)
1) 2)
1) A is reduced to a tridiagonal matrix using the Householder method. Omit this step if A is already a tridiagonal matrix. 2) Using the QL method, the eigenvalues of A i.e. all the eigenvalues of the tridiagonal matrix are obtained.
Function Eigenvalues and eigenvectors of a real symmetric matrix Reduction of a real symmetric matrix to a real symmetric tridiagonal matrix Obtaining eigenvalues of a real symmetric tridiagonal matrix
Component routines Obtaining eigenvalues and eigenvectors of a real symmetric tridiagonal matrix Back transformation to the eigenvectors of a real symmetric matrix
Subroutine name SEIG1 (B21-21-0101) SEIG2 (B21-21-0201) TRID1 (B21-21-0302) TRQL (B21-21-0402) BSCT1 (B21-21-0502) TEIG1 (B21-21-0602) TEIG2 (B21-21-0702) TRBK (B21-21-0802)
38
Obtaining selected eigenvalues Selected eigenvalues of real symmetric matrix A can be obtained as shown:
CALL TRID1 (A, N, D, SD, ICON) 1) IF (ICON.EQ. 30000) GO TO 1000 CALL BSCT1 (D, SD, N, M, EPST, E, * VW, ICON) 2)
CALL TRID1 (A,N,D,SD,ICON) 1) IF(ICON .EQ. 30000)GO TO 1000 CALL TEIG2(D,SD,N,M,E,EV,K,VW,ICON) 2) IF(ICON .GE. 20000)GO TO 2000 CALL TRBK(EV,K,N,M,A,ICON) 3)
1) Same as step 1) in the first item Obtaining all eigenvalues. 2) The eigenvalues of the tridiagonal matrix are obtained using the Bisection method. Using the parameter M, the user specifies the number of eigenvalues to be determined by starting from the largest eigenvalue or starting from the smallest eigenvalue. If n/4 or more eigenvalues are to be determined for A, it is faster to use the procedure explained in item Obtaining all eigenvalues. Obtaining all eigenvalues and corresponding eigenvectors All eigenvalues and corresponding eigenvectors of real symmetric matrix A can be obtained by using 1) to 3) or by using step 4).
or standard routine
CALL SEIG2(A,N,M,E,EV,K,VW,ICON)
4)
CALL TRID1(A,N,D,SD,ICON) IF(ICON .EQ. 30000)GO TO 1000 CALL TEIG1(D,SD,N,E,EV,K,M,ICON) IF(ICON .GE. 20000)GO TO 2000 CALL TRBK(EV,K,N,M,A,ICON)
1) 2) 3)
1) Same as step 1) in item Obtaining all eigenvalues 2) Selected eigenvalues and corresponding eigenvectors of a tridiagonal matrix are determined using the Bisection method and the Inverse Iteration method. If the eigenvalues are close, it is not always true that the eigenvectors obtained using the Inverse Iteration are orthogonal. Therefore in 2), the eigenvectors of close eigenvalues are corrected to orthogonalize to those which have already been obtained. The obtained eigenvectors are normalized such that each Euclidean norm is 1. 3) From processing 1), the eigenvectors of 2) are not those of a real symmetric matrix A. Therefore the eigenvectors of a real symmetric matrix A are obtained by performing back transformation corresponding to 1). 4) This subroutine process steps 1) to 3). QL method 1) Comparison with the QR method The QL method used in 2) of the first and third paragraphs is basically the same as the QR method used to determine the eigenvalues of a real matrix. However, while the QR method determines eigenvalues from the lower right corner of matrices, the QL method determines eigenvalues from the upper left. The choice of these methods is based on how the data in the matrix is organized. The QR method is ideal when the magnitude of the matrix element is graded decreasingly, i.e., decreases from the upper left to the lower right. If the magnitude of the matrix element is graded increasingly, the QL method is better. Normally, in tridiagonal matrix output by TRID1 in 1) of the first paragraph and 2) of the second paragraph, the magnitude of the element tends to be graded increasingly. For this reason, the QL method is used following TRID1 as in 2) of the first and third paragraphs. 2) Implicit origin shift of the QL method There are explicit and implicit QL methods. The difference between the two methods is whether origin shift for improving the rate of convergence when 39
or standard routine
CALL SEIG1(A,N,E,EV,K,M,VW,ICON)
4)
1) Same as step 1) in item Obtaining all eigenvalues. 2) All eigenvalues and corresponding eigenvectors of the real symmetric tridiagonal matrix can be obtained by the QL method and by multiplying each of the transformation matrices obtained by the QL method. Each eigenvector is normalized such that the Euclidean norm is 1. 3) From step 1), the eigenvectors in 2) are not those of real symmetric matrix A. Therefore the back transformation in 1) is performed to obtain the eigenvectors of real symmetric matrix A. 4) All processing of 1) to 3) is performed. Obtaining selected eigenvalues and corresponding eigenvectors Selected eigenvalues and corresponding eigenvectors of
GENERAL DESCRIPTION
determining eigenvalues is performed explicitly or implicitly. (See subroutine TRQL.) The explicit QL method is suitable when the magnitude of the matrix element is graded increasingly. However, when the magnitude is graded decreasing, the precision of the smaller eigenvalues is affected. For this reason, the implicit QL method is used in 2) of the first and third paragraphs. Direct sum of submatrices When a matrix is a direct sum of submatrices, the processing speed and precision in determining eigenvalues and eigenvectors increase if eigenvalues and eigenvectors are obtained from each of the submatrices. In each 2) of the first four paragraphs, a tridiagonal matrix is split into submatrices according to (4.1), and then the eigenvalues and eigenvectors are determined.
ci u bi 1 + bi
(i = 2 ,3,n)
(4.1)
0 c C 0
b1 c2
2
i 1
ci 1
bi 1 bi ci +1
0 c 0
ci +1 cn
bn
Note: Element ci is regarded to be zero according to (4.1). Fig. 4.1 Example in which a tridiagonal matrix is the direct sum of two submatrices
Table 4.5 Subroutines used for standard eigenproblems of an Hermitian matrix Level Standard routine Function Obtaining eigenvalues and eigenvectors of an Hermitian matrix Reduction of an Hermitian matrix to a real symmetric tridiagonal matrix Obtaining eigenvalues of a real symmetric tridiagonal matrix Component routines Obtaining eigenvalues and eigenvectors of a real symmetric tridiagonal matrix Back transformation to the eigenvectors of an Hermitian matrix Subroutine name HEIG2 (B21-25-0201) TRIDH (B21-25-0302) TRQL (B21-21-0402) BSCT1 (B21-21-0502) TEIG1 (B21-21-0602) TEIG2 (B21-21-0702) TRBKH (B21-25-0402)
40
storage mode. (For details, see Section 2.8) Obtaining all eigenvalues All eigenvalues of an Hermitian matrix A can be obtained in steps 1) and 2) below.
1) 2)
1) An Hermitian matrix A is reduced to a real symmetric tridiagonal matrix 2) Eigenvalues of the real symmetric tridiagonal matrix (i.e., eigenvalues of A) and corresponding eigenvectors are obtained using the QL method. 3) The Eigenvectors obtained in 2) are transformed to the eigenvectors of A. 4) The standard routine HEIG2 can perform all the above steps 1) through3). In this case, the fourth parameter N of HEIG2 indicates to obtain the largest n number of eigenvalues. Obtaining selected eigenvalues and corresponding eigenvectors A selected number of eigenvalues (m) and corresponding eigenvectors of an Hermitian matrix can be obtained either by using steps 1) through 3)or by using step 4), (see below).
1) An Hermitian matrix A is reduced to a real symmetric tridiagonal matrix using the Householder method. 2) All eigenvalues of the real symmetric tridiagonal matrix are obtained using the QL method. Obtaining selected eigenvalues By using steps 1) and 2) below, the largest (or smallest) m eigenvalues of a matrix A can be obtained.
CALL TRIDH(A,K,N,D,SD,V,ICON) 1) IF(ICON .EQ. 30000)GO TO 1000 CALL TEIG2(D,SD,N,M,E,EV,K,VW,ICON) 2) IF(ICON .GE. 20000)GO TO 2000 CALL TRBKH(EV,EVI,K,N,M,P,V,ICON) 3) IF(ICON .EQ. 30000)GO TO 3000
1) An Hermitian metrics A is reduced to a real symmetric tridiagonal matrix by the Householder method. 2) The largest (or smallest) m number of eigenvalues of the real symmetric tridiagonal matrix are obtained using the bisection method. When obtaining more than n/4 number of eigenvalues of n order matrix A, it is generally faster to use subroutines TRIDH and TRQL as described in Obtaining all eigenvalues. Obtaining all eigenvalues and corresponding eigenvectors All eigenvalues and corresponding eigenvectors can be obtained either by using steps 1) through 3)or by using step 4), (see below).
or standard routine
CALL HEIG2(A,K,N,M,E,EVR,EVI,VW,ICON)
4)
1) An Hermitian matrix A is reduced to a real symmetric tridiagonal matrix. 2) The largest (or smallest) m number of eigenvalues and corresponding eigenvectors of the real symmetric tridiagonal matrix are obtained using the bisection method and the inverse iteration method. 3) Back transformation of the eigenvectors obtained in 2) are performed. 4) The standard routine HEIG2 can perform all the above steps 1) through 3).
CALL TRIDH(A,K,N,D,SD,V,ICON) 1) IF(ICON .EQ. 30000)GO TO 1000 CALL TEIG1(D,SD,N,E,EV,K,M,ICON) 2) IF(ICON .GE. 20000)GO TO 2000 CALL TRBKH(EV,EVI,K,N,M,P,V,ICON) 3) IF(ICON .EQ. 30000)GO TO 3000
or standard routine
41
GENERAL DESCRIPTION
where h is the band-width. Subroutine BSEGJ, which uses the Jennings method, is effective for obtaining less than n/10 eigenvalues. Obtaining of all eigenvalues and corresponding eigenvectors of a real symmetric band matrix is not required in most cases and therefore standard routines for some eigenvalues and corresponding eigenvectors are provided. Subroutines BSEG and BSEGJ are standard routines and BTRID and BSVEC are component routines of BSEG (see Table 4.6). Examples of the use of these subroutines are given below. SSL II handles the real symmetric band matrix in compressed mode (see Section 2.8). Obtaining selected eigenvalues Using standard routines
CALL BSEG(A,N,NH,M,0,EPST,E,EV,K,VW, * ICON) 1) IF(ICON.GE.20000)GO TO 1000
Obtaining all eigenvalues Using the standard routine All the eigenvalues can be obtained by specifying N as the fourth parameter in the example of BSEG used to obtain some eigenvalues. However, the following component routines are recommended instead. Using component routines
CALL BTRID(A,N,NH,D,SD,CON) IF(ICON.EQ.30000) GO TO 1000 CALL TRQL(D,SD,N,E,M,ICON)
1) 2)
1) Real symmetric band matrix A of order n and bandwidth h is reduced to the real symmetric tridiagonal matrix T by using the LutishauserSchwarz method. 2) All eigenvalues of T are obtained by using the QL method. Obtaining selected eigenvalues and corresponding eigenvectors Using standard routines The following two standard routines are provided.
1) The largest (or smallest) m number of eigenvalues of a real symmetric band matrix A of order n and bandwidth h are obtained. The fifth parameter, 0 indicates that no eigenvectors are required. Using component routines
CALL BTRID(A,N,NH,D,SD,ICON) 1) IF(ICON.EQ.30000) GO TO 1000 CALL BSCT1(D,SD,N,M,EPST,E,VW,ICON) 2) IF(ICON.EQ.30000) GO TO 2000
CALL BSEG(A,N,NH,M,NV,EPST,E,EV,K,VW, * icon) 1) IF(ICON.GE.20000)GO TO 1000 CALL BSEGJ(A,N,NH,M,EPST,LM,E,EV,K,IT, * VW, ICON) 1) IF(ICON.GE.20000)GO TO 1000
1) Real symmetric band matrix A or order n and bandwidth h is reduced to the real symmetric tridiagonal matrix T by using the LutishauserSchwarz method. 2) The largest (or smallest) m number of eigenvalues of T are obtained.
The subroutine indicated by 1) obtains eigenvalues by using the Lutishauser-Schwarz method, the bisection method and the inverse iteration method consecutively. The subroutine indicated by 1) obtains both eigenvalues and eigenvectors by using the Jennings method based on a simultaneous iteration.
Table 4.6 Subroutines used for standard eigenproblem of a real symmetric band matrix Level Standard routine Function Obtaining eigenvalues and eigenvectors of a real symmetric band matrix Reduction of a real symmetric band matrix to a tridiagonal matrix Component routine Obtaining eigenvalues of a real symmetric tridiagonal matrix Obtaining eigenvectors of a real symmetric ban matrix Subroutine name BSEG (B51-21-0201) BSEGJ (B51-21-1001) BTRID (B51-21-0302) TRQL (B21-21-0402) BSCT1 (B21-21-0502) BSVEC (B51-21-0402
42
Further, 1) obtains the largest (or smallest) eigenvalue and 1) obtains the largest (or smallest) absolute value of eigenvalues. The subroutine indicated by 1) is only recommended where a very small number of eigenvalues and eigenvectors (no more than n/10) compared to the matrix order n are to be obtained. 1) The m number of eigenvalues and nv, number of eigenvectors of a real symmetric band matrix A of order n and bandwidth h are obtained. 1) Eigenvectors of A as described above are obtained based on the m number of initial eigenvectors given. At the same time, the corresponding eigenvalues can be also obtained. Care needs to be taken when giving initial eigenvectors to EV and upper limit for the number of iterations to LM. Using component routines The following subroutines are called consecutively to achieve the same effect as executing subroutine BSEG.
NN = (NH + 1)(N + N -NH)/2 DO 10 I = 1, NN 10 AW (I) = A (I) CALL BTRID(A,N,NH,D,SD,ICON) 1) IF(ICON.EQ.30000) GOTO 1000 CALL BSCT1(D,SD,N,M,EPST,E,VW,ICON) 2) IF(ICON.EQ.30000) GO TO 2000 CALL BSVEC(AW,N,NH,V,E,EV,K,VW,ICON) 3) IF(ICON.GE.20000) GO TO 3000
CALL BTRID(A,N,NH,VW(N1),VW(N2),ICON) 1) IF(ICON.EQ.30000) GO TO 1000 CALL TRQL(VW(N1),VW(N2),N,E,ICON) 2) IF(ICON.GE.15000) GO TO 2000 CALL BSVEC(AW,N,NH,N,E,EV,K,VW,ICON) 3) IF(ICON.GE.20000) GO TO 3000
1) 2) These are the same as the component routines used when obtaining all of the eigenvalues. Since subroutine BTRID destroys the contents of parameter A, they need to stored in array AW for step 3). 3) The eigenvectors corresponding to all eigenvalues given in step 2) are obtained by using the inverse iteration method.
1) 2) These are the same paths taken when obtaining selected eigenvalues. Since BTRID destroys the contents of parameter A, they need to be stored in array AW for step 3). 3) The eigenvectors corresponding to the first nv eigenvalues of the m eigenvalues given by 2) are obtained by using the inverse iteration method. Obtaining all eigenvalues and corresponding eigenvectors Using standard routines By specifying N for the fourth and fifth parameters of the subroutine BSEG shown earlier in the example on obtaining selected eigenvalues and their corresponding eigenvectors, all eigenvalues and corresponding eigenvectors can be obtained. If a solution is desired more quickly, the following path using component routines is recommended. Using component routines
NN=(N+1)(N+NNH)/2 DO 10 I=1,NN 10 AW(I)=A(I) N1 = NN+1 N2 = N1 + N
GENERAL DESCRIPTION
Table 4.7 Subroutines used for generalized eigenproblems of a real symmetric matrix Level Standard routine Function Obtaining general eigenvalue and eigenvector of a real symmetric matrix Reduction of the generalized eigenproblem to the standard eigenproblem Reduction of a real symmetric matrix to a real symmetric tridiagonal matrix Obtaining eigenvalues of a real symmetric tridiagonal matrix Subroutine name GSEG2 (B22-21-0201) GSCHL (B22-21-0302) TRID1 (B21-21-0302) TRQL (B21-21-0402) BSCT1 (B21-21-0502) TEIG1 (B21-21-0602) TEIG2 (B21-21-0702) TRBK (B21-21-0802) GSBK (B22-21-0402)
Component routine
Obtaining eigenvalues and eigenvectors of a real symmetric tridiagonal matrix Back transformation to eigenvectors of a real symmetric matrix Back transformation to generalized eigenvectors
In the following paragraphs, the use of component routines and standard routine will be described. It is up to the user whether he successively calls the component routines one after another or users the standard routine to obtain all or selected eigenvalues and eigenvectors. Normally, using the latter routine is recommended since that method is easier to use. SSL II handles the real symmetric matrix in the compressed storage mode (see Section 2.8). Obtaining all eigenvalues All the eigenvalues can be obtained from the steps 1), 2), and 3) below.
1), 2) Same as step 1) and 2) in Obtaining all eigenvalues. 3) The largest (or smallest) m number of eigenvalues of the real symmetric tridiagonal matrix are obtained using the bisection method. When obtaining more than n/4 number of eigenvalues of n order matrix A, it is generally faster to use the example shown in Obtaining all eigenvalues. Obtaining all eigenvalues and corresponding eigenvectors From either steps 1) through 5), or from step 6), all of the eigenvalues and their corresponding eigenvectors can be obtained.
1) 2) 3)
1) The generalized eigenproblem (Ax = Bx) is reduced to the standard eigenproblem (Sy = y) 2) The real symmetric matrix S is reduced to a real symmetric tridiagonal matrix using the Householder method. 3) All the eigenvalues of the real symmetric tridiagonal matrix are obtained using the QL method. Obtaining selected eigenvalues From the following steps 1), 2), and 3), the largest (or smallest) m number of eigenvalues can be obtained.
CALL GSCHL(A,B,N,EPSZ,ICON) IF(ICON.GE.20000) GO TO 1000 CALL TRID1(A,N,D,SD,ICON) CALL TEIG1(D,SD,N,E,EV,K,M,ICON) IF(ICON.GE.20000)GO TO 3000 CALL TRBK(EV,K,N,M,A,ICON) CAL GSBK(EV,K,N,M,B,ICON)
1) 2) 3) 4) 5)
or standard routine
44
1), 2) Same as step 1), 2) in Obtaining all eigenvalues. 3) All engenvalues and corresponding eigenvectors of the real symmetric tridiagonal matrix are obtained by the QL method. 4) The eigenvectors of the real symmetric tridiagonal matrix are back-transformed to the eigenvectors of the real symmetric matrix S 5) The eigenvectors of the real symmetric matrix S are back-transformed to the eigenvectors of Ax= Bx. 6) The standard routine GSEG2 can perform steps 1) through 5) at a time. In this case, the fourth parameter N of GSEG2 indicates to obtain the largest n number of eigenvalues. Obtaining selected eigenvalues and corresponding eigenvectors From either steps 1) through 5), or from step 6), m number of eigenvalues and their corresponding eigenvectors can be obtained.
1), 2) Same as step 1), 2) in Obtaining all eigenvalues. 3) The largest (or smallest) m number of eigenvalues of the real symmetric tridiagonal matrix and the corresponding eigenvectors are obtained using the bisection and inverse iteration methods. 4), 5) Same as step 4), 5) in above paragraphs. 6) The standard routine GSEG2 can perform steps 1) through 5) at a time.
CALL GSCHL(A,B,N,EPSZ,ICON) 1) IF(ICON.GE.20000) GO TO 1000 CALL TRID1(A,N,D,SD,ICON) 2) IF(ICON.EQ.3000) GO TO 2000 CALL TEIG2(D,SD,N,M,E,EV,K,VW,ICON)3) IF(ICON.GE.20000) GO TO 3000 CALL TRBK(EV,K,N,M,A,ICON) 4) CAL GSBK(EV,K,N,M,B,ICON) 5)
or standard routine
1)
IF(ICON.GE.20000) GO TO 1000
The eigenvalues and eigenvectors are obtained by using the Jennings method of simultaneous iteration method. Parameter M is used to specify the largest (or smallest) m number of eigenvalues and eigenvectors to be obtained.
Table 4.8 Subroutines used for generalized eigenproblem of a real symmetric band matrix Level Standard routine Function Obtaining eigenvalues and eigenvectors of a real band generalized eigenproblem Subroutine name GBSEG (B52-11-0101)
45
5.1
OUTLINE
This chapter is concerned with the following types of problems. Roots of non-linear equations: Determining the roots of polynomial equation, transcendental equations, and systems of nonlinear equations (simultaneous nonlinear equations).
5.2
POLYNOMIAL EQUATIONS
The subroutines shown in Table 5.1 are used for these types of problems. When solving real polynomial equations of fifth degree or lower, LOWP can be used. When solving only quadratic equations, RQDR should be used. General conventions and comments concerning polynomial equations The general form for polynomial equations is
a0 x n + a1 x n 1 + + an = 0,
Unless specified otherwise, subroutines which solve polynomial equations try to obtain all of the roots. Methods and their use are covered in this section. Algebraic and iterative methods are available for solving polynomial equations. Algebraic methods use the formulas to obtain the roots of equations whose degree is four or less. Iterative methods may be used for equations of any degree. In iterative methods, an approximate solution has been obtained. For most iterative methods, roots are determined one at a time; after a particular root has been obtained, it is eliminated from the equation to create a lower degree equation, and the next root is determined. Neither algebraic methods nor iterative methods are better since each has merits and demerits. Demerits of algebraic methods Underflow or overflow situations can develop during the calculations process when there are extremely large variations in size among the coefficients of (5.1). Demerits of iterative methods Choosing an appropriate initial approximation presents problems. If initial values are incorrectly chosen, convergence may not occur no matter how many iterations are done, so if there is no
a0 0
(5.1)
where ai (i = 0, 1 ... n) is real or complex. If ai is real, (5.1) is called a real polynomial equation. If ai is complex, (5.1) is called a complex polynomial equation, and z is used in place of x.
Table 5.1 Polynomial equation subroutines Objective Real quadratic equations Complex quadratic equations Real low degree equations Real high degree polynomial equations Complex high degree polynomial equations Subroutine name RQDR (C21-11-0101) CQDR (C21-15-0101) LOWP (C21-41-0101) RJETR (C22-11-0111) CJART (C22-15-0101) Method Root formula Root formula Algebraic method and iterative method are used together. Jenkins-Traub method Jaratt method Fifth degree or lower Notes
46
NONLINEAR EQUATIONS
convergence, it is assumed that the wrong initial value was chosen. It is possible that some roots can be determined while others can not. Convergence must be checked for with each iteration, resulting in calculation problem. In order to avoid the demerits of algebraic methods, SSL II uses iterative methods except when solving quadratic equations. The convergence criterion method in SSL II is described in this section. When iteratively solving an polynomial equation: f ( x) a k x n k = 0
n k =0
5.3
TRANSCENDENTAL EQUATIONS
if the calculated value of f(x) is within the range of calculation error, it is meaningless to make the value any smaller. Let the upper limit for calculation errors for solving f(x) be (x), then
( x ) = u a k x n k
n k =0
(5.2)
If f(x) is a real function, the equation is called a real transcendental equation. If f(x) is a complex function, the equation is called a complex transcendental equation, and z is used in place of x. The objective of subroutines which solve transcendental equations is to obtain only one root of f(x) within a specified range or near a specified point. Table 5.2 lists subroutines used for transcendental equations. Iterative methods are used to solve transcendental equations. The speed of convergence in these methods depends mainly on how narrow the specified range is or how close a root is to the specified point. Since the method used for determining convergence differs among the various subroutines, the descriptions of each should be studied.
k =0
u ak x nk
k =0
(5.4)
is satisfied, convergence is judged to have occurred, and the solution is used as one of the roots. (For further information on equation (5.2), see reference [23].). As for the precision of roots, with both algebraic and iterative methods, when calculating with a fixed number of digits, it is possible for certain roots to be determined with higher precision than others. Generally, multiple roots and neighboring roots tend to be less precise than the other roots. If neighboring roots are among the solutions of an algebraic equation, the user can assume that those roots are not as precise as the rest.
Table 5.2 Transcendental equation subroutines Objective Subroutine name TSD1 (C23-11-0101)
where f(x) = (f1(x), f2(x),..., fn(x))T and 0 is an ndimensional zero vector. Nonlinear simultaneous equations are solved by iterative methods in which the user must gives an initial vector x0 and it is improved repeatedly until the final solution for (3.1) is obtained within a required accuracy. Table 5.3 lists subroutines used for nonlinear simultaneous equations. The best known method among iterative methods is Newton method, expressed as:
Method Bisection method, linear interpolation method and inverse second order interpolation method are all used. Mullers method Mullers method
No derivatives needed. Initial values specified. No derivatives needed. Initial values specified.
47
GENERAL DESCRIPTION
Table 5.3 Nonlinear simultaneous equation subroutines Objective Non-linear simultaneous equations Subroutine name NOLBR (C24-11-0101) Method Brents method Notes Derivatives are not needed.
xi +1 = xi Ji -1f(xi ), i = 0, 1, ...
(5.7)
f1 x 2 f 2 x 2
f n x 2
f1 x n f 2 x n f n x n x = xi
(5.8)
The Newton method is theoretically ideal, that is, its order of convergence is quadratic and calculations are simple. However, this method develops several calculation problems when it manipulates complex (or larger) systems of nonlinear equations. The major reasons are: It is often difficult to obtain the coefficients fi /xi in (5.8), (i.e., partial derivatives cannot be calculated because of the complexity of equations). The number of calculations for all elements in (5.8) are too large. Since a system of linear equations with coefficient matrix Ji must be solved for each iteration, calculation time is long. If the above problems are solved and the order of convergence is kept quadratic, this method provides short processing time as well as ease of handling. The following are examples of the above problems and their solutions. The first problem fi lxi can be approximated with the difference, i.e., by selecting an appropriate value for h, we can obtain f i ( x1 , fi x j
, x + h, , x ) f ( x , , x )
j n i 1 n
(5.9)
For the second and third problems, instead of directly calculating the Jacobian matrix, a pseudo Jacobian matrix (which need not calculate all the elements) is used to solve the simultaneous equations. All of the above means are adopted in SSL II. Several notes on the use of subroutines for nonlinear simultaneous equations follows. The user must provide the function subprograms to calculate a series of functions which define equations. These function subprograms should be provided taking the following points into consideration in order to use subroutines effectively and to obtain precise solution. Loss of digit should be avoided in calculating functions. This is especially important because values of functions are used in subroutines to evaluate derivatives. The magnitude of elements such as those of variable vector x or of function vector f (x) should be balanced. Since, if unbalanced the larger elements often mask the smaller elements during calculations. SSL II routines have the function of checking variance in the largest element to detect convergence. In addition, the accuracy of a solution vector depends upon the tolerance given by the user. Generally, the smaller the tolerance for convergence, the higher the accuracy for the solution vector. However, because of the round-off errors, there is a limit to the accuracy improvement. The next problem is how to select initial value x0. It should be selected by the user depending upon the characteristics of the problem to be solved with the equations. If such information is not available, the user may apply the cut-and-try method by arbitrarily selecting the initial value and repeating calculations until a final solution is obtained. Finally, due to the characteristics of equations, some equations can not be solved by single precision subroutines, but may be solved by double precision subroutines. Because double precision subroutines are more versatile, they are recommended for the users needs.
48
CHAPTER 6 EXTREMA
6.1
OUTLINE
The following problems are considered in this chapter: Unconstrained minimization of single variable function Unconstrained minimization of multivariable function Unconstrained minimization of sum of squares of functions (Nonlinear least squares solution). Constrained minimization of multivariable function (This is implemented later) Linear programming Nonlinear programming (Constrained minimization of multivariable function)
This means that it is desirable to specify values for end points a and b of an interval including minimum point x* to be closed to x*.
The iteration vector is modified based on the direction in which the function f(x) decreases in the region of xk by using not only the value of f(x) but also the gradient vector g and the Hessian matrix B normally. f f g= , , x 1 x2 B = bij
2
( ),b
f , xn
(6.2)
ij
= f x i x j
Comments on use Interval [a, b] In the SSL II, only one minimum point of f(x) is obtained within the error tolerance assuming that the f(x) is unimodal interval [a, b]. If there are several minimum points in interval [a, b], it is not guaranteed to which minimum point the resultant value is converged. 49
Formula based on Newton method If the function f(x) is quadratic and is concave, the global minimum point x* should be able to be obtained theoretically within at most n iterations by using iterative formula of the Newton method. A function can be expressed approximately as quadratic in the region of the local minimum point x*. That is,
GENERAL DESCRIPTION
f ( x ) f ( x* ) +
T 1 x x* ) B(x x* ) ( 2
(6.3)
Table 6.1 Subroutines for unconstrained minimization of a function with several variables Analytical definition f(x) f(x), g(x) Subroutine name MINF1 (D11-10-0101) MING1 (D11-20-0101) Notes Revised quasiNewton method Quasi-Newton method
Therefore, if the Hessian matrix B is positive definite, the iterative formula based on the Newton method which is applied to the quadratic function will be a good iterative formula for any function in general as shown in Eq. (6.3). Now let gk be a gradient vector at an arbitrary point xk in the region of the local minimum point x*, then the basic iterative formula of Newton method is obtained by Eq. (6.3) as follows: xk +1 = xk B 1 gk (6.4)
The SSL II, based on Eq. (6.4), introduces two types of iterative formulae. Revised quasi-Newton method Iterative formula Bk pk = gk x k +1 = x k + k pk Bk +1 = Bk + Ek
Comments on use Giving an initial vector x0 Choose the initial vector x0 as close to the expected local minimum x* as possible. When the function f(x) has more than one local minimum point, if the initial vector is not given appropriately, the method used may not converge to the expected minimum point x*. Normally, x0 should be set according to the physical information of the function f(x). Function calculation program Efficient coding of the function programs to calculate the function f(x), the gradient vector g is desirable. The number of evaluations for each function made by the SSL II subroutine depends on the method used or its initial vector. Ingeneral, it takes a majority in the total processing and takes effect on efficiency. In case that the subroutine is given only the function f(x), the gradient vector g is usually approximated by using difference. Therefore a efficient coding to reduce the effect of round-off errors should be considered, also. When defining function f(x), it should be scaled well so as to balance the variable x as much as possible. Convergence criterion and accuracy of minimum value f ( x* ) In an algorithm for minimization, the gradient vector g(x*) of the function f(x) at the local minimum point x* is assumed to satisfy g(x*) = 0 (6.6)
(6.5)
Where Bk is an approximate matrix to the Hessian matrix and is improved by the matrix Ek of rank two during the iteration process. pk is a searching vector which defines the direction in which the function value decreases locally.k is a constant by which f(xk+1) is locally minimized (linear search). These formulae can be used when the user cannot define the Hessian matrix analytically. Quasi-Newton method Iterative formula pk = H k gk x k +1 = x k + k pk H k +1 = H k + Fk Where Hk is an approximate matrix to inverse matrix B-1 of the Hessian matrix and is improved by the matrix Fk of rank 2 during the iterative process. pk is a searching vector which defines the direction in which the function value decrease locally. k is a constant by which f (xk+1) is locally minimized (linear search). Subroutines The subroutines are provided a shown in Table 6.1 depending on whether or not the user can analytically define a gradient vector g in addition to the function f(x).
, that is, the iterative formula approximates the function f(x) as a quadratic function in the region of the local minimum point x* as follows. 1 f ( x * + x) f ( x* ) + x T B x 2 (6.7)
Eq. (6.7) indicates that when f(x) is scaled appropriately, if x is changed by , function f(x) changes by 2. In SSL II, if xk +1 xk
max 10 . , xk
(6.8)
50
EXTREMA
where is a convergence criterion is satisfied for the iteration vector xk, then xk+1 is taken as the local minimum point x*. Therefore, if the minimum value f(x*) is to be obtained as accurate as the rounding error, the convergence criterion should be given as follows: = u where u is the unit round off. The SSL II uses 2. u for a standard convergence criterion.
T f(x ) F(xk ) = 2J k k
(6.12)
F(xk) is the steepest descent direction of F(x) at xk. The following is the method of steepest descent.
x k = F ( x k )
(6.13)
xk guarantees the reduction of F(x). However if iteration is repeated, it proceeds in a zigzag fashion.
Formula based on the Levenberg-Marquardt method Levenberg, Marquardt, and Morrison proposed to determine xk by the following equations combining the ideas of the methods of Newton-Gauss and steepest descendent.
6.4 UNCONSTRAINED MINIMIZATION OF SUM OF SQUARES OF FUNCTIONS (NONLINEAR LEAST SQUARES SOLUTION)
Given m number of real functions f1 (x), f2 (x), ..., fm (x) of n variables and an initial vector x0, the vector (local minimum) x* which minimize the following functions is obtained together with its function value F(x*), where, x is the vector of x = (x1, x2, ...xn)T and m n. F ( x ) = { f i ( x )}
i =1 m 2
{J
T k
(6.14)
(6.9)
If all the functions fi (x) are linear, it is a linear least squares solution problem. For detailed information on its solution, refer to Section 3.5. (For example subroutine LAXL). If all the functions fi (x) are nonlinear, the subroutines explained in this section may be used. When the approximate vector xk of x* is varied by x, F(xk + x) is approximated as shown in (6.10). F ( xk + x k ) = f T ( x k + x k ) f ( x k + x k ) f T (x k )f(x k ) + 2 f T ( x k )J k x k + x k T J k T J k x k
where vk is a positive integer (called Marquardt number). xk obtained in (6.14) depends on the value of vk that is, the direction of xk is that of the Newton-gauss method if vk 0: otherwise if vk , it is that of steepest descendent. SSL II uses iterative formula based on (6.14). It does not directly solve the equation in (6.14) but it obtains the solution of the following equation, which is equivalent to (6.14), by the least squares method (Householder method) to maintain numerical stability.
Jk vk I
x k = f(x k 0
(6.15)
(6.10)
The value vk is determined adaptively during iteration. Subroutines The subroutines are provided as shown in Table 6.2 depending on whether or not the user can analytically define a Jacobian matrix J in addition to the function f1 (x), f2 (x), ..., fm (x).
Table 6.2 Subroutines for unconstrained minimization of sum of squares of functions Analytical definition f1(x), f2(x),... , fm(x) f1(x), f2(x),... , fm(x), J Subroutine name NOLF1 (D15-10-0101) NOLF1 (D15-20-0101) Notes Revised Marquardt Method Revised Marquardt Method
Where | F(xk) | is assumed to be sufficiently small. And, f(x) equals to (f1 (x), f2 (x), ..., fm (x))T and Jk is a Jacobian matrix of f(x) at vector xk. xk which minimize this F(xk + xk) can be obtained as the solution of the system of linear equations (6.11) derived by differentiating the right side of (6.10).
T f(x ) k J k T J k x k = J k
(6.11)
The equation shown in (6.11) is called a normal equation. The iterative method based on the xk is called the Newton-Gauss method. In the Newton-Gauss method function value F(x) decrease along direction xk, however, xk itself may diverge. The gradient vector F(xk) at xk of F(x) is given by
51
GENERAL DESCRIPTION
Comments on use Giving an initial vector x0 Choose the initial vector x0 as close to the expected local minimum point x* as possible. When the function F(x) has more than one local minimum point, if the initial vector is not given appropriately, the method used may not converge to the expected minimum point x*. The user should set x0 after checking the feature of the problem for which this subroutine is to be used. Function calculation program Efficient coding of the function programs to calculate the function {fi (x)} value of Jacobian matrix J is desirable. The number of evaluations for each function made by the SSL II subroutine depends on the method used or its initial vector. In general, it takes a majority of the total processing and has an effect on the efficiency. When that subroutine is given only the function {fi (x)} Jacobian matrix J is usually approximated by using differences. Therefore, an efficient coding to reduce the effect of round-off errors should also be considered. Convergence criterion and accuracy of minimum value F(x*) In an algorithm for minimization, F(x) at the local minimum point x* is assumed to satisfy F ( x* ) = 2 J T f ( x* ) = 0 (6.16)
6.5
LINEAR PROGRAMMING
Linear programming is used for obtaining: Value of a variable to minimize (or maximize) the linear function Its minimum (or maximum) value which have been given under the constrained conditions represented by the combination of several variable related linear inequalities and equalities. The following is a standard linear programming problem: Minimize the following linear objective function: Ax = d x0 subject to z = c T x + c0 where, A is an m n coefficient matrix and the rank of A is: rank A = m n where, x = (x1, x2, ..., xn)T is a variable vector, d = (d1, d2, ..., dm)T is a constant vector, c = (c1, c2, ..., cn)T is a coefficient vector, and c0 is a constant term. aj is assumed to represent the j-th row (a coefficient vector of xj) of A. If m number of rows of A, ak1, ak2, ..., akm, are linearly independent, a group of the corresponding variables (xk1, xk2, .., xkm) are called bases. xki (i-th corresponding variable) is called a basic variable. A basic solution in (6.19) is obtained by setting all the values of non-basic variables to zeros. Those which satisfy the equation in (6.20) a feasible solution will be obtained and if the optimal solution is given which minimize the value of the objective function, the optimal solution can be obtained from the basic feasible solution (fundamental theorem of linear programming). Simplex method The optimal solution is calculated by starting from a basic feasible solution, changing basic variables one by one and obtaining basic feasible solution consecutively. Revised simplex method Using iterative calculation of the simplex method, coefficients and constant terms required for determining the basic variables to be changed are calculated from the matrix inversion of the basic matrix, B = [ak1, ak2, ..., akm], the original coefficient (6.19) (6.20)
that is, the iterative formula approximates the function F(x) as a quadratic function in the region of the local minimum point x* as follows: F ( x* + x) F ( x* ) + x T J T J x Eq. (6.17) indicates that when F(x) is scaled appropriately, if x is changed by , function F(x) changes by 2. In SSL II, if F ( xk +1 ) < F ( xk ) xk +1 xk
2
(6.17)
max(10 . , xk 2 )
(6.18)
where, is a convergence criterion is satisfied for the iteration vector xk, then xk+1 is taken as the local minimum point x*. Therefore, if the minimum value F(x) is to be obtained as accurately as the rounding-error, the convergence criterion should be given as follows:
u
where, u is the unit round-off. The SSL II uses 2. u for a standard convergence criterion. 52
EXTREMA
A, c, and constant term d. SSL II provides subroutine LPRS1 using this revised simplex method. If the constrained condition contains inequalities, add variables to change into equalities. For example, a11x1 + a12 x2 + ... + a1n x n d1
rank A < m and there is an x which satisfies the equation in (6.19), (m-r) number of the conditional equations are useless. (If r number of conditional equations are held, others can necessarily be held). Where r is r = rank A
is changed into a11x1 + a12 x2 + ... + a1n x n + xn+ 1= d1, xn+1 0 and, a21x1 + a22 x2 + ... + a2n x n d2 is changed into a21x1 + a22 x2 + ... + a2n x n xn+ 2 = d2, xn+2 0 Non-negative variables such as xn+1 or xn+2 which are added to change an inequality into an equality are called slack variables. Maximization is performed by multiplying the objective function by -1 instead. Subroutine LPRS1 performs these processes and thus enables the solution of problems containing inequalities or to maximize the problem. If a basic feasible solution has not been obtained, solve it in two stages: At the first stage, obtain the basic feasible solution At the second stage, obtain the optimal solution This is called the two-stage method. An example is shown below. At the first stage the optimal solution is obtained. Minimize the following equation. Ax + A(a) x(a) = d, x 0, x(a) 0 subject to z1 = xi ( a )
i =1 m
The optimal solution obtained at the first stage results in the basic feasible solution excepting the useless conditional equations. There remain (m-r) number of artificial variables in basic variables. The conditional equations corresponding to these artificial variables (i-th basic variable corresponds to the i-th conditional equation) are useless. Comments on use Coefficient relative zero criterion Subroutine LPRS1 performs the relative zero criterion in which if the absolute value of the elements during iterative process becomes, small, LPRS1 assumes it as zero Parameter EPSZ is used to specify the value of relative zero criterion. Suppose the following extended coefficient matrix consist of coefficient matrix A, constant vector d, coefficient vector c and constant term c0. A d c c 0 The absolute maximum element of this matrix is assumed to be amax. Then if the absolute value of a coefficient vector and constant term obtained by iteration is smaller than amax N EPSZ, it is assumed to be zero. If EPSZ does not give an appropriate value, although the feasible solution is obtained z1 may be larger than zero when the optimal solution is obtained at the first stage. Furthermore, the optimal solution at the first stage may have to be obtained before iteration. To keep accurate precision, you should multiply an appropriate constant to each row or column to enable the ratio of the maximum and minimum absolutes of the extended coefficient matrix elements. Number of iterations LPRS1 exchanges basic variables so that the same basic feasible solution does not appear twice. It can check whether the optimal solution can be obtained in a certain number of iterations or not. It also can terminate in the middle of processing. Parameter IMAX is used to specify the number of iterations. If the iteration terminates as specified by parameter IMAX, LPRS1 can continue calculation when the feasible basic solution has been obtained
x(a) is an m-dimensional vector of x(a) = (x1(a), x2(a), ..., xm(a))T A(a) is an m-order diagonal matrix of A(a) = (aij(a)) where, when di 0, aij(a) = 1 when di < 0, aij(a) = 1 (a ) xi is called an artificial variable. When the optimal solution is obtained, if z1 is larger than zero (z1 > 0), no x will satisfy the conditions in (6.19) and (6.20). If z1 is equivalent to zero (z1 = 0), that is x(a) = 0, the basic feasible solution of the given problem has been obtained, and so we proceed to the second stage. But if the rank A is as follows: where
53
GENERAL DESCRIPTION
adding certain procedures for constraints of (6.21), (6.22). That is, the algorithm minimizes f(x) by using the quatratic approximation for f(x) at approximate point xk : f ( x) f ( xk ) + y T gk + 1 T y By 2 (6.23)
where y = x xk and B is a Hessian matrix, under the constraints of linear approximation for (6.21), (6.22) at the same point xk as follows: ci ( x k ) + y T ci ( x k ) = 0, i = 1,2, ci ( x k ) + y T ci ( xk ) 0, i = m1 + 1, , m1 + m2
(6.21) (6.22)
, m
(6.24)
Where x is vector as (x1, x2, ...., xn) and m1 and m2 are the numbers of equality constraints and unequality constraints respectively. The algorithm for this problem is derived from that for unconstrained minimization explained in section 6.3 by
(6.25)
Where ci is a gradient vector of ci This is a quadratic programming with respect to y. The SSL II supplies the NLPG1 that gives minimum point by solving quadratic programming successively during iteration.
54
7.1
OUTLINE
This chapter is concerned with the following types of problems. Interpolation Given discrete points x1 < x2 < ...< xn and their corresponding function values y1 = f(xi ), i = 1, ...., n (in some cases yi = f(xi ) is given), an approximation to f(x) (hereafter called interpolating function) is determined such that it passes through the given points; or, that the interpolating function is used to determine an approximate value (hereafter called interpolated value) to f(x) at a point x = v other than xi . Least-squares approximation Given discrete points x1 < x2 < ... < xn and their corresponding observed values yi , i = 1, ..., n the approximation ym ( x) that minimizes
i =1
w( xi ) {yi y m( xi )} , w( xi ) 0
2
m
is determined; w(x) is a weight function, and y (x ) is a polynomial of degree m. In this type of problem yi is observed data. This method is used when the observation error varies among the data. Smoothing Given discrete points x1, x2, ..., xn and their corresponding observed values yi , i = 1, 2, ...n a new series of points {~ yi } which approximates the real function is obtained by smoothing out the observation errors contained in the observed value {yi }. Hereafter, this processing is referred to as smoothing. ~ y i ( or ~ { yi } )is called the smoothed value for yi (or {yi}),
yi ~ y i shows the extent of smoothing, and the
Series When a smooth function f(x) defined on a finite interval is expensive to evaluate, or its derivatives or integrals can not be obtained analytically, it is suggested f(x) be expanded to the Chebyshev series. The features of Chebyshev series expansion are described below. Good convergence Easy to differentiate and integrate term by term Effective evaluation owing to fast Fourier transformation, leading to numerical stability. Obtain the item number of n and the coefficient number of Chebyshev expansion depending upon the required precision. Then obtain the derivative and indefinite integral of f(x) by differentiating and integrating each item of the obtained series in forms of series. The derivative value, differential coefficient and definite integral can be obtained by summing these series. If the function f(x) is a smooth periodic function, it can be expanded to triangular series. Here the even function and odd function is expanded to the cosine series and the sine series depending upon the required precision. In the field of interpolation or smoothing in this chapter, and also in that of numerical differentiation or quadrature of a tabulated function, very powerful functions, what is called spline functions, are used. So, the definition and the representations of the functions are described below. Spline function Definition Suppose that discrete points x0 ..., xn divide the range [a, b] into intervals such that a = x0 < x1 < ... < xn = b (7.1)
Then, a function S(x) which satisfies the following conditions: a. DkS(x) = 0 for each interval (xi , xi +1) b. S ( x ) C k 2 [a ,b] , where Dd/dx 55 (7.2)
GENERAL DESCRIPTION
is defined as the spline function of degree (k-1) and the discrete points are called knots. As shown in (7.2), S(x) is a polynomial of degree (k1) which is separately defined for each interval (xi , xi +1) and whose derivatives of up to degree (k-2) are continuous over the range [a, b]. Representation-1 of spline functions Let aj, j = 0, 1, ...., k 1 and bi , i = 1, 2, ..., n 1 be arbitrary constants, then a spline function is expressed as
n1 S ( x ) = p( x ) + bi( x x i )+k 1 i =1 where , k 1 p( x ) = a j( x x 0 ) j j =0
Thus, S lim 0
(l)
( xi + ) lim S ( l ) ( xi ) 0 = lim ( k 1 )( k 2 ) e 0
( k l ) b
i
k 1 l
(7.5)
( xi + ) = lim S ( l ) ( xi ) 0
(7.6)
(7.3)
(7.5) shows the S(l)(x) is continuous at x = xi When l = k 1 the righthand side becomes (k 1) (k 1) bi Since generally bi 0 S lim 0
( k 1 )
( x xi ) ( x xi )+k 1 = 0
k 1
, x xi , x < xi
(x
+ ) lim S ( k 1 ) ( x i ) 0
(7.7)
(7.4)
The following illustration proves that (7.3) satisfies (7.2). Suppose that x is moved from x0 to the right in (7.3). For x0 x < x1, S(x) = p(x), so S(x) is a polynomial of degree (k-1). For x1 x < x2, S(x) = p(x) + b1(x x1)k-1, so S(x) is a polynomial of degree (k-1). In general, for xi x<xi+1
S ( x ) = p( x ) +
b ( x x )
i r r r =1
k 1
(7.7) shows that the (k-1)th derivative of S(x) becomes discontinuous at x = xi . Even in this case, if bi , i = 1, 2, ..., n 1 are all zero, the (k-1)th derivative of S(x) becomes continuous. Then, from (7.3), it can be found that S(x) = p(x) over the range [a, b]. This means that S(x) is virtually equal to the power series expanded at x = x0. Therefore, it can be said that an arbitrary polynomial of degree (k-1) defined on [a, b] is a special form of the spline function. Equation (7.3) is referred to as the expression of spline function by the truncated power function, it is in general numerically unstable because (x xi )k-1 tends to assume a large absolute value. Representation-2 of spline functions (introduction of B-splines) In contrast with the representation(7.3), the representation by B-splines, which are defined below, can avoid numerical difficulties. Let a series of points {tr} shown in Fig. 7.1 be defined as t k +1 t k +2 t 1 t 0 = x 0 < t1 = x1 < < t n = x n t n +1 t n+2 t n+ k 1
So, it is found that S(x) is a polynomial of degree (k-1) which is separately defined for each interval. From equation (7.3) we obtain
dl S ( x ) = S ( l )( x ) dx l
k 1
j( j 1) ( j l + 1) a ( x x ) + ( k 1 )( k 2 ) ( k l ) b ( x x )
=
j 0 j =1 n1 i i j =1
j l
k 1 l +
(7.8)
The l-th derivatives from the left and the right of S(x) at xi , are
lim S ( xi ) =
(l)
And define gk (t; x) as a function of t with parameter x. ( t x )k 1 k 1 gk ( t ; x ) = ( t x )+ = 0 See Fig. 7.2. , tx , t<x (7.9)
lim S
0
(l)
j( j 1 ) ( j l + 1 ) a ( x x ) + ( k 1 )( k 2 ) ( k l ) b ( x x ) ( x + ) = j( j 1 ) ( j l + 1 ) a ( x x )
K 1 j i 0 j =1 i 1 k 1 l r i r r =1 k 1 i j i 0
j l
j l
x0 t-k+1 t-1 t0
x1 t1
x2 t2
xn-1 tn-1
xn tntn+1 tntk-1
( k l ) b ( x x ) + lim( k 1 )( k 2 ) ( k l ) b ( x + x )
i 1
j =1
( k 1 )( k 2 )
k 1 l
r =1
k 1 l
56
S( x ) =
gk(t;x)
j = k +1
c N
j
n1
j ,k
(x)
(7.14)
Then, the k th order divided difference of gk (t ; x) with respect to t = tj, tj+1, ..., tj+k multiplied by a constant: N j ,k ( x ) = (t j+ k t j ) g k [t j , t j+1 ,
j = k +1
c N
j
n1
j ,k
(x)
(7.15)
, t
j+k
; x]
(7.10)
is called the normalized B-spline (or simply B-spline) of degree ( k 1). The characteristics of B-spline Nj,k (x) are as follows. Now, suppose that the position of x is moved with tj, tj+1, ..., tj+k fixed. When x tj since Nj,k(x) includes the k th order divided difference of a polynomial of degree (k-1) with respect to t, it becomes zero. When tj+k x, Njk(x) is zero because it includes the k th order divided difference of a function which is identically zero. When tj < x < tj+k, Nj,k(x) 0. In short, 0 , t j < x < t j + k N j ,k ( x ) = 0 , x t j or t j+ k x (7.11)
S ( y )dy
x x0
at the point x [xi , xi +1) is described hereafter. Calculating the function value The value of S(x) at x [xi , xi +1) can be obtained by calculating Nj,k(x). In fact, because of locality (7.12) of Nj,k(x), only non-zero elements have to be calculated. Nj,k(x) is calculated based on the following recurrence equation N r ,s ( x ) = x tr t r+s x N r ,s1 ( x ) + N r +1,s1 ( x ) t r + s1 t r t r + s t r +1 (7.16)
(actually, when tj < x < tj+k, 0 < Nj,k(x) 1) Next, suppose that j is moved with x fixed. Here, let ti = xi < x < xi +1 = ti +1. Then, in the same way as above, we can obtain 0 , i k + 1 j i N j ,k ( x ) = 0 , j i k or i + 1 j (7.12)
where, N r ,1 ( x ) = (t r +1 t r ) g1 t r , t r +1 ; x = (t r +1 t r )
g1 (t r +1 ; x ) g1 (t r ; x ) t r +1 t r 0 ( ) ( + + + = t r 1 x t r x) 0 1 , r = i = 0 , r i (7.17) By applying s = 2, 3, ....., k, r = i s + 1, i s + 2, ..., i to Eqs. (7.16) and (7.17), all of the Nr,s(x) given in Fig. 7.3 can be calculated, and the values in the rightmost column are used for calculating the S(x).
N i k +1, k 0 N i 2 ,3 Ni 1,3 N i ,3 0 r Ni 1, k Ni ,k
The characteristics (7.11) and (7.12) are referred to as the locality of B-spline functions. From (7.10), B-spline Nj,k(x) can be written as
N j ,k ( x ) = ( t j +k t j )
r= j
j +k
( tr t j )
( t r x )+k 1 ( tr t r 1 )( t r tr +1 )
(7.13)
(t
t j +k )
Therefore, Nj,k(x) is a polynomial of degree (k-1) defined separately for each interval (xi , xi +1) and its derivatives of up to degree k-2 are continuous. Based on this characteristic of Nj,k(x), it is proved that an arbitrary spline function S(x) satisfying equation (7.2) can be represented as
0 0 Ni 1,2 Ni ,1 Ni , 2 0 0
57
GENERAL DESCRIPTION
First, from Eq. (7.9), the indefinite integral of gk(t ; x) can be expressed by (7.18)
(t x) g ( t ; x )dx = 1 k
k k +
j = k +1
n1
cj
N j ,k ( x )
(l)
where an integration constant is omitted. Letting ek(t; x) = (t x)k+ and its divided difference of order k represent (7.19) Ij,k(x) = ek[tj, tj+1, ..., tj+k ; x] then the Ij,k(x) satisfies the following recurrence equation. 0 , r i 1 I r ,1 ( x ) = ( xi +1 x ) / ( xi+1 xi ) , r = i , r i +1 1 I r ,s ( x ) = ( x t r ) I r ,s1 ( x ) + (t r + s x ) I r +1,s1 ( x ) t r+s t r (7.23)
is the divided difference of order k at t = tj, so tj+1, ..., tj+k of Eq. (7.19). Now let ( t x )k 1 l , t x dk ( t ; x ) = ( t x )+k 1 l = ,t < x 0 and let Dj,k(x) be the divided difference of order k at t = tj, tj+1,, tj+k, i.e., D j ,k ( x ) = d k t j , t j+1 ,
(7.24) where x [xi , xi +1). If equation (7.24) is applied for s = 2, 3, ..., k and r = i s + 1, i s + 2, ..., i then a series of Ij,k (x) are obtained as shown in the rightmost column in Fig. 7.4. 0 I i k +1 0 I i 2 ,3 Ii 1, 3 Ii, 3 1
, t ; x ]
j +k
(7.20)
This Dj,k(x) can be calculated by the following recurrence equations. For x [xi , xi +1),
1 / ( x i+1 xi ) , r = i Dr ,1 ( x ) = , ri 0 Dr +1 ,s1 ( x ) Dr ,s1 ( x ) Dr ,s ( x ) = , 2 s l +1 t r +s t s ( x t r )Dr ,s1 ( x ) + ( t r + s x )Dr +1 ,s 1 ( x ) Dr ,s ( x ) = tr +s tr , l+2sk
0 0 Ii ,1 1 I i1, 2 Ii , 2 1
r Ii 1, k Ii, k 1
(7.21) and if s = 2, 3, ..., k, and r = i s + 1, i s + 2, ..., i are applied, Dj,k for i k + 1 j i, can be obtained. The objective Nj,k(l)(x) can be obtained as follows:
N (j ,k) ( x ) = ( t j +k t j ) ( 1 ) ( k 1 )! D j ,k ( x ) ( k 1 l )!
l
N
x x0
( y )dy =
j ,k
and S(l)(x) can then be obtained by using this equation. Next, the integral is expressed as
I=
( ti + k t j ) [I j ,k ( x ) I j ,k ( x 0 )] k ( t j +k t j ) = [I j ,k ( x0 ) I j ,k ( x )] k
S ( y )dy = N
x x cj x0 j = k +1 x0
n1
( y )dy
j ,k
(7.22)
1 k
c (t
j j = k +1
n1
j+ k
t j )[ I j ,k ( x 0 ) I j ,k ( x )]
N ( y )dy
j ,k
x0
Integration of. Nj,k(x) can be carried out by exchanging the sequence of the integration calculation with the calculation of divided difference included in Nj,k(x).
i 1 0 cj (t j+ k t j ) I j ,k ( x0 ) cj (t j +k t j ) I j ,k ( x ) k j = k +1 j= i k+1 i + cj t t j j + k j =1 (7.25)
58
The coefficients cj in Equation (7.15) has been so far assumed to be known in the calculation procedures for function values, derivatives, and integral values of the spline function S(x). cj can be determined from the interpolation condition if S(x) is an interpolation function, or from least squares approximation if S(x) is a smoothing function. In the case of interpolation, for example, since n + k 1 coefficients cj ( k + 1 j n 1) are involved in equation (7.15), cj will be determined by assigning n + k 1 interpolation conditions to Equation (7.15). If function values are given at n + 1 points (x = x0, x1, ...., xn ) in Fig. 7.1 function values must be assigned at additional (n + k 1) (n + 1) = k 2 points or k 2 other conditions (such as those on the derivatives) of S(x) must be provided in order to determine n + k 1 coefficients cj. Further information is available in 7.2 Interpolation. The SSL II applies the spline function of Eq. (7.15) to smoothing, interpolation, numerical differentiation, quadrature, and least squares approximation. Definition, representation and calculation method of bivariate spline function The bivariate spline function can be defined as an extension of the one with a single variable described earlier. Consider a closed region R = {(x,y) | a x b, c y d} on the x y plane and points (xi , yj), where 0 i m and 0 j n according to the division(7.26) a = x0 < x1 < c = y0 < y1 <
the B-splines of in x and y directions are defined in the same way as the B-spline with a single variable. N ,k(x)=(s+ks) gk[s, s+1, N ,k(y)=(t+kt) gk[t, t+1,
, s ; x] , t ; y]
+k +k
Then the bivariate spline function of dual degree k 1 defined above can be represented in the form
S( x , y ) =
= k +1
c
= k +1
n1
m1
N ,k ( x )N ,k ( y )
(7.28)
where, ca, sare an arbitrary constants. The calculation of function values, partial derivatives and indefinite integral of S (x,y) can be done by simply applying to it the calculation for a single variable, if using the expression (7.28). First of all, for 0 and 0, S ( , ) ( x , y ) =
n 1
+ S ( x, y) x y
m1
= k +1 = k +1
( ) ( ) N ,k ( x ) N ,k ( y )
(7.29)
< x = b < y = d
m n
(7.26)
Therefore, the calculation of the function values and partial derivatives are accomplished by separately ) () ( x ) , and N ( y ) which can be done by calculating N ( ,k ,k applying the previously described method for a single variable. Next, consider the value which is obtained by differentiating S(x,y) times with respect to y and then by integrating with respect to x, namely
S ( 1, ) ( x , y ) =
Denoting Dx=/x and Dy=/y, the function S(x, y) which satisfies a. Dxk S(x,y) = Dyk S(x,y) = 0 for each of the open regions Ri , j = ( x , y ) xi < x < xi+1 , y j < y < y j+1 b. S ( x , y ) C k 2 ,k 2 [ R] is called a bivariate spline function of fual degree k 1. (7.27) a. shows that S(x,y) is a polynomial in x and y on each of Rij and is at most (k 1)-th degree with repeat to both of x and y. Further, b. shows that on the entire R
(7.27)
x0
S( x , y ) dx y
(7.30)
This value is unchanged even when the order of differentiation and integration is reversed. Rewriting the right-hand side of Eq. (7.30) by using Eq. (7.28), we obtain
c
= k +1
x m1
n1
+ S ( x, y ) xy
exists and is continuous when = 0, 1, .., k2 and = 0, 1, ..., k2. If a series of points are taken as follows s-k+1s-k+2 s-1s0=x0<s1=x1< < <sm=xmsm+1 sm+k-1
= k +1
= k +1
c N
x0
m 1
x () N N ,k ( x )dx ,k ( y ) x0
,k
( x )dx c =
, where
= k +1
n 1
( ) N ,k ( y )
(7.31)
This is similar to Eq. (7.23) given previously. Therefore, calculation of Eq. (7.31) is performed first by calculating c and then by calculating the integral by using the method for a single variable. In addition S(1,)(x,y), 59
GENERAL DESCRIPTION
S ( ,1 ) ( x , y ) =
y0
S(x, y) dy x
y x
S ( 1,1 ) ( x , y ) = y dy x S ( x , y )dx
0 0
Type II ........... S(j)(x1), S(j)(xn), j = l, l+1, , 2l2 are specified by the user. Type III ......... No boundary conditions. Type IV ......... S(j)(x1), S(j)(xn), j = 0, 1, , 2l2 are satisfied. This type is suitable to interpolate periodic functions.
can be calculated by applying the method for calculating derivatives and integrals for a single variable each for x and y separately.
7.2
INTERPOLATION
The general procedure of interpolation is first to obtain an approximate function; ex., polynomial, piecewise polynomial, etc. which fits given sample points (xi ,yi ), then to evaluate that function. When polynomials are used for approximation, they are called Lagrange interpolating polynomials or Hermite interpolating polynomials (using derivatives as well as function values). The Aitken-Lagrange interpolation and Aitken-Hermite interpolation methods used in SSL II belong to this. As a characteristic, they find the most suitable interpolated values by increasing iteratively the degree of interpolating polynomials. While, piecewise polynomials are used for the approximate function when a single polynomial are difficult to apply. SSL II provides quasi-Hermite interpolation and spline interpolation methods. Interpolating splines are defined as functions which satisfies the interpolating condition; i.e fits the given points. Interpolating splines are not uniquely determined: they can vary with some additional conditions. In SSL II, four types of spline interpolation are available. As for the representation of splines, we mainly use B-spline representain because of its numerical stability. Interpolation by B-spline Subroutines using B-spline are divided into two types according to their objectives. (1) Subroutines by which interpolated values (or derivatives, integrals) are obtained (2) Subroutines by which interpolating splines are obtained. Since subroutines in (1) use interpolating splines, subroutines in (2) must be called first. SSL II provides various interpolating splines using Bspline. Let discrete points be xi , i = 1, 2, ..., n, then four types of B-spline interpolating function of degree m (=2l1, l2) are available depending on the presence/absence or the contents of boundary conditions. Type I ............ S(j)(x1), S(j)(xn), j = 1, 2, ..., l 1 are specified by the user.
Selection of the above four types depends upon the quantity of information on the original function available to the user. Typically, subroutines of type III (No boundary conditions) can be used. Bivariate spline function S(x,y) shown in (7.28) is used as an interpolation for a two-dimensional interpolation. In this case, different types could be used independently for each direction x and y. However, SSL II provides the interpolation using only type I or III in both directions of x and y. It will be a problem how the degree of spline should be selected. Usually m is selected as 3 to 5, but when using double precision subroutines, if the original function does not change abruptly, m may take a higher value. However, m should not exceed 15 because it may cause another problem. Table 7.1 lists interpolation subroutines. Quasi-Hermite interpolation This is an interpolation by using piecewise polynomials similar to the spline interpolation. The only difference between the two is that quais-Hermite interpolation does not so strictly require continuity of higher degree derivatives as the spline interpolation does. A characteristic of quasi-Hermite interpolation is that no wiggle appear between discrete points. Therefore it is suitable for curve fitting or surface fitting to the accuracy of a hand-drawn curve by a trained draftsman. However, if very accurate interpolated values, derivatives or integrals are to be obtained, the B-spline interpolation should be used.
7.3
APPROXIMATION
This includes least-squares approximation polynomials as listed in Table 7.2. The least squares approximation using B-spline is treated in Smoothing.
7.4
SMOOTHING
Table 7.3 lists subroutines used for smoothing. Subroutines SMLE1 and SMLE2 apply local leastsquares approximation for each discrete point instead
60
Table 7.1 Interpolation subroutines Objective Subroutine name AKLAG (E11-11-0101) AKHER (E11-11-0201) SPLV (E11-21-0101) BIF1 (E11-31-0101) BIF2 (E11-31-0201 BIF3 (E11-31-0301 BIF4 (E11-31-0401 BIFD1 (E11-32-1101) BIFD3 (E11-32-3301) AKMID (E11-42-0101) INSPL (E12-21-0101) AKMIN (E12-21-0201) BIC1 (E12-31-0102) BIC2 (E12-31-0202) BIC3 (E12-31-0302) BIC4 (E12-31-0402) BICD1 (E11-32-1102) BICD3 (E12-32-3302) Method Aitken-Lagrange interpolation Aitken-Hermite interpolation Cubic spline interpolation B-spline interpolation (I) B-spline interpolation (II) B-spline interpolation (III) B-spline interpolation (IV) B-spline two-dimensional interpolation(I-I) B-spline two-dimensional interpolation (III-III) Two-dimensional quasiHermite interpolation Cubic spline interpolation Type I Type II Type III Type IV Type I-I Type III-III Notes Derivatives not needed. Derivatives needed
Interpolated value
Two derivatives of the second order at both ends are neede needed
Quasi-Hermite interpolation B-spline interpolation (I) B-spline interpolation (II) B-spline interpolation (III) B-spline interpolation (IV) B-spline two-dimensional interpolation (I-I) B-spline two-dimensional interpolation (III-III) Type I Type II Type III Type IV Type I-I Type III-III
Interpolating function
Table 7.2 Approximation subroutine Objective Least squares approximation polynomials Subroutine name LESQ1 (E21-20-0101) Method Discrete point polynomial Notes The degree of the polynomial is determined within the subroutine.
of applying the identical least-squares approximation over the observed values. However, it is advisable for the user to use B-spline subroutines for general purpose. In B-spline smoothing, spline functions shown in (7.14) and (7.28) are used for the one-dimensional smoothing and two-dimensional smoothing respectively. Coefficients cj or c, are determined by the least squares method. The smoothed value is obtained by evaluating the obtained smoothing function. SSL II provides subroutines for evaluating the smoothing functions.
There are two types of subroutines to obtain B-spline smoothing functions depending upon how to determine knots. They are: The user specifies knots (fixed knots) Subroutines determine knots adaptively (variable knots) The former requires experience on how to specify knots. Usually the latter subroutines are recommen-
61
GENERAL DESCRIPTION
dable.
Table 7.5 lists subroutines used for cosine series expansion, sine series expansion and their evaluation, which are for periodic functions.
7.5
SERIES
SSL II provides subroutines shown in Table 7.4 for Chebyshev series expansion, evaluation of it, derivatives and indefinite integral.
Table 7.3 Smoothing subroutines Objective Subroutine name SMLE1 (E31-11-0101) SMLE2 (E31-21-0101) BSF1 (E31-31-0101) BSFD1 (E31-32-0101) BSC1 (E32-31-0102) BSC2 (E32-31-0202) BSCD2 (E32-32-0202) Method Local least-squares approximation polynomials Local least-squares approximation polynomials B-spline smoothing B-spline two-dimensional smoothing B-spline smoothing (fixed nodes) Unequally spaced discrete points B-spline smoothing (added nodes) B-spline two-dimensional smoothing (added nodes) Unequally spaced lattice points Notes Equally spaced discrete points Unequally spaced discrete points Unequally spaced discrete points Unequally spaced lattice points
Smoothed value
Smoothing function
Table 7.4 Chebyshev series subroutines Objective Series expansion Evaluation of series Derivatives of series Indefinite integral of series Subroutine name FCHEB (E51-30-0101) ECHEB (E51-30-0201) GCHEB (E51-30-0301) ICHEB (E51-30-0401) Method Fast cosine transformation Backward recurrence equation Differention formula for Chebyshev polynomials Integral formula for Chebyshev polynomials Notes Number of terms is (Power of 2) + 1.
Table 7.5 Cosine or sine series subroutines Objective series expansion Cosine series evaluation sine series expansion sine series evaluation
Cosine
Subroutine name FCOSF (E51-10-0101) ECOSP (E51-10-0201) FSINF (E51-20-0101) ESINP (E51-20-0201)
Method Fast cosine transformation Backward recurrence equation Fast sine transformation Backward recurrence equation
62
CHAPTER 8 TRANSFORMS
8.1
OUTLINE
This chapter explains discrete Fourier transforms and Laplace transforms. Characteristics For a discrete Fourier transform, subroutines are provided for each of the characteristics of transformed data. The data characteristics are classified as Real or complex data, and For real data, even or odd function
2 x j = x j , j = 0,1, , n 1 , in the closed interval n [0,2] and by applying the trapezoidal rule. Particularly, if x(t) is the (n/2 1)th order trigonometric polynomial, the transforms (8.1) are the exact numerical integral formula of the integrals (8.3). In other words, the discrete Fourier coefficients are identical to the analytical Fourier coefficients. If x(t) is an even or odd function, the discrete cosine and sine transforms are provided by using their characteristics.
(8.1)
Representing an even function x(t) by x = x j , j n j=0, 1, ..., n in the closed interval [0,] the transform (8.4) and the inverse transform (8.5) are performed.
ak =
, n 1
(8.2)
where ak and bk are called discrete Fourier coefficients. Corresponding to the integrals, 1 2 x (t )cos kt dt 0 1 2 x (t )sin kt dt 0
(8.4) (8.5)
(8.3)
which define Fourier coefficients of a real valued function x(t) with period 2, the transfomrs (8.1) can be derived by representing the function x(t) by n points
where denotes both the first and the last terms of the sam are faken with factor 1/2. The transform (8.4) can be derived by representing an even function x(t) by x j = x j , j = 0, 1, , n in the closed interval n [0,] and by applying the trapezoidal rule to
2 x (t )cos kt dt 0
(8.6)
63
GENERAL DESCRIPTION
which defining the Fourier coefficient of x(t). Discrete cosine transform (midpoint rule) Representing an even function x(t) by x j+1/2 =
1 x j + , n 2 j = 0,1,
(0,) the transform (8.12) and the inverse transform (8.13) are performed. bk = x j+ 1
2
(0,) , the transform (8.7) and the inverse transform (8.8) are performed.
a =
k
2 1 j + ,k = 01 ,, x cos n k n 2
n 1 j=0 j+ 1 2 n 1
,n 1
(8.7) (8.8)
The transform (8.12) can be derived by applying the midpoint rule with n terms to the integral (8.11).
j+
1 2
1 = ' a cos k j + , j = 01 , , ,n 1 n 2
k k =0
where denotes the sum of terms except for the first term which is multiplied by 1/2. The transform (8.7) can be derived by applying a midpoint rule with n terms to the integral (8.6).
8.4
=
k
If the function x(t) is an odd function, subroutines are provided to perform the two types of transforms. Similar to the discrete cosine transform, one of the transforms is performed based on the trapezoidal rule, and the other on the midpoint rule. Discrete sine transform (Trapezoidal rule) Representing an odd function x(t) by x j = x j , n j=1, 2, ..., n-1, in the closed interval [0,] the transform (8.9) and the inverse transform (8.10) are performed.
2 b = x sin kj ,k = 1,2, ,n 1 n n x = b sin kj , j = 1,2, , n 1 n
n 1 k j j =1 n 1 j k k =1
(8.14) (8.15)
Transform (8.14) can be derived by representing the complex valued function x(t) with period 2 by 2 x j = x j , j = 0, 1, , n, in the closed interval n [0,2] and by applying the trapezoidal rule to the integral
1 2
(8.16)
(8.9) (8.10)
The transform (8.9) can be derived by representing j=1, 2, ..., n-1, in the odd function x(t) by x j = x j , n the closed interval [0,] and by applying the trapezoidal rule to the integral
2 x (t ) sin ktdt
0
which defines Fourier coefficients of x(t). The discrete type Fourier transforms described above are all performed by using the Fast Fourier Transform (FFT). When transforms are performed by using the FFT, the internal processings are divided as follows: (a) Transforms are performed by repeating elementary transforms of the small dimension in place. (b) Arranging the data in the normal order. Subroutines (component routines) are provided for each of the above processings. The Fourier transform can be performed by using both subroutines for (a) and (b) above. Another subroutine (standard subroutine) which combines these subroutines is also provided and should usually be used. The amount of data should be expressed by number to the power of 2 in taking the processing speed into consideration. However, for the complex Fourier
(8.11)
which defining Fourier coefficients of x(t). Discrete sine transform (midpoint rule) Representing an odd function x(t) by x j +1/2 =
1 x j + , n 2 j = 0,1,
64
TRANSFORMS
transform, the following points are also considered: The amount of data can be expressed by either power of 2 or product of the powers of the prime numbers. Multi-variate transform can also be accomplished. Table 8.1 lists the subroutines for each data characteristic. Comments on use Sample point number (dimension) The number of sample points, n, of transformed data is defined differently depending on the (data) characteristic of the function x(t). That is, n corresponds The number of sample points taken in the half period interval, (0,), or [0,], for the cosine and sine transforms, or The number of sample points taken in the full period interval, [0,2], for the real and complex transforms. Real transform against cosine and sine transforms If the function x(t) is an ordinary real function, the subroutine for a real transform can be used, but if it is known in advance that the x(t) is either an even or odd function, the subroutine for cosine and sine transforms should be used. (The processing speed is about half as fast as for a real transform.) Even a real function x(t) can be calculated by using cosine and sine transforms, since it can be represented by an even and odd function, i.e., x(t) + x(t) and x(t) x( t) , respectively.
Table 8.1 Subroutines for discrete Fourier transform
Fourier coefficients in real and complex transforms The following relationships exist between the Fourier coefficients {ak} and {bk} used in a real transform (including cosine and sine transforms) and the Fourier coefficient {k} used in a complex transform. a0 = 2 0 , a n / 2 = 2 n / 2 a k = ( k + n k ) , k = 1,2, , n / 2 1 bk = i( k n k ) , k = 1,2, n / 2 1
(8.17)
where n denotes equally spaced points in a period [0,2]. Based on the above relationships, users can use both subroutines for real and complex transforms when necessary. In this case, however, attention must be paid to scaling and data sequence. Trigonometric functions For cosine and sine transforms, the necessary trigonometric function table for transforms is provided in the subroutine for better processing efficiency. The function table is output in the parameter TAB which can be used again for successive transforms. For each transform, two subroutines are provided based on the trapezoidal rule and the midpoint rule. For the former, the size of the trigonometric function table is smaller and therefore more efficient. Scaling Scaling of the resultant values is left to the user.
Type of transform Cosine Trapezoidal rule Midpoint rule sine Trapezoidal rule Midpoint rule Real transform Complex transform
Standard routine FCOST (F11-11-0101) FCOSM (F11-11-0201) FSINT (F11-21-0101) FSINM (F11-21-0201) RFT (F11-31-0101) CFT (F12-15-0101)
PNR (F12-15-0402)
Product of power of prime numbers Note: (a) and (b) given in the table are described in Section 8.5.
CFTM (F12-11-0101)
65
GENERAL DESCRIPTION
8.6
LAPLACE TRANSFORM
The Laplace transform of f(t) and its inverse are defined respectively as: F (s) = 0 f (t )e dt
st
where 0 < < 0/t is assumed. It follows that the integral of the right-hand side can be expanded in terms of integrals around the poles of Eec(st,0).
Imaginary axis
(8.18) (8.19)
f (t ) =
1 +i F (s)e st ds 2 i i
where > 0, 0 (: abscissa of convergence) and i = 1 . In these transforms, f(t) is called the original function and F(s) the image function. Assume the following conditions about F(s). 1) F ( s) is nonsingular for Re( s) > 0 2) lim F (s) = 0 for Re( s) > 0 s 3) F * ( s) = F ( s * ) for Re( s) > 0
Real axis
Re(s)=
(8.20)
where Re [ ] denotes the real part of [ ] and F*(s) the conjugate of F(s). Condition 1) is always satisfied, condition 2) is satisfied unless f(t) is a distribution and condition 3) is satisfied when f(t) is a real function. The subroutines prepared perform the numerical transformation of expression (8.19). The outline of the method is described below. Formula for numerical transformation Assume 0 0 for simplicity, that is F(s) is regular in the domain of Re(s) > 0, and the integral (8.19) exists for an arbitrary real value greater than 0. Since e s = lim e 0 2cosh 0 s
0
Since F(s) is regular in the domain of Re(s) > 0, the following is obtained according to Cauchys integral formula: f (t , 0 ) = + i(n 0.5) e 0 n n+1 ( 1) iF 0 2t n = t 0 + i(n 0.5) e 0 n = F ( 1) Im t n=1 t (8.22) where Im [ ] denotes the imaginary part of [ ]. If 0 > 0 the condition 0 < < 0/t cannot be satisfied for a certain value of t(0 < t < ). This means 0 0 is necessary for (8.22) to be used for 0 < t < . Function f(t,0) gives an approximation to function f(t) and is expressed as follows according to the error analysis in reference [98]: f t , 0 = f (t ) e 2 0 f (3t ) + e 4 0 f (5t )
)]
)]
(8.23)
Function Eec(st,0) is characterized as follows: There are an infinite number of poles on the line expressed by Re(s)=0/t. Figure 8.1 shows locations of the poles. This can be explicitly represented as: Eec (st , 0 ) = e 0 2t
s [
n =
( 1) i + i(n 0.5) ]
n
This means that function f(t,0) gives a good approximation to f(t) when 0 >> 1. Moreover, (8.23) can be used for estimating the approximation error. For numerical calculation, the approximation can be obtained principally by truncating (8.22) up to an appropriate term; however, the direct summation is often not practical. Euler transformation that can be generally applied in this case is incorporated in the subroutines. Define function Fn as follows: 0 + i (n 0.5) n Fn ( 1) Im F t (8.24)
Then, f(t,0) which denotes an approximation of the original function f(t) is: f (t , 0 ) 66 1 r + i F ( s) Eec (st , 0 )ds 2 i r i (8.21)
TRANSFORMS
Then, Euler transformation is applicable when the following condition is satisfied (reference [100]): 1) For an integer k1, the sign of Fn alternates when nk (8.25) 2) 1/2 | Fn+1/Fn | < 1 when n k When Fn satisfies these conditions, the series represented by (8.22) can be transformed as:
In the subroutines, the truncation error is output in the form of the following relation error: f N (t , 0 ) f N 1 (t , 0 ) = f N (t , 0 ) 1 p+1 D Fk 1 2 p +1 k 1 1 p Fn + p+1 Ap ,r Fk +r 2 r =0 n =1
F = F + 2
p n n n=1 n =1 q= 0
k 1
1
q+1
D q Fk + Rp +1 (k )
(8.26)
where Rp(k) is defined as: Rp(k) 2P(DpFk+DpFk+1+DpFk+2+) p D Fk is the pth difference defined as D 0 Fk = Fk , D p +1 Fk = D p Fk + D p Fk +1 In the subroutines, the following expression is employed: f N (t , 0 ) = e 0 t (8.27)
Dp+1Fk-1 is a linear combination of Fk-1, Fk, ..., Fk+p, and the coefficients are equal to the binomial coefficients. Ap, r can be calculated as the cumulative sum, as shown in (8.29). Thus, these coefficients can easily be calculated by using Pascals triangle. Figure 8.2 shows this calculation techniques (for p = 4)
1 1 1 1 1 1 5 4 10 3 6 10 2 3 4 5 1 1 1 1 1
coefficients of D5Fk-1
F =
N n n =1
p e0 k 1 D q Fk Fn + q+1 t n=1 2 q= 0
(8.28)
31 26 16 6 1
where N = k + p,
A4,r
1 p D q Fk = p +1 Ap ,r Fk +r q +1 2 2 r =0 q =0 p + 1 Ap ,p = 1, Ap ,r 1 = Ap ,r + r
(8.29)
Next, in the case of 0>0, since F(s) is not regular in the domain of Re(s) > 0; the above technique cannot be directly applied. Note, however, that the integral in (8.19) can be expressed as: f (t ) = 1 r + i F ( s + 0 ) e ( s+ 0 ) t ds 2 i r i er0t r + i = G( s ) e st ds 2 i r i = er0t g(t ) where r>0, G(s)=F(s+ro) (8.31) 1 r + i g (t ) = G ( s) e st ds 2 i r i
Determination of values for 0, k, and p is explained in each subroutine description. The following has been proved for the truncation error of fN(t,0). Suppose (n) Fn. If the p th derivative of (x), (p)(x), is of constant sign for positive x and monotonously decreases with increase of x (for example, if F(s) is a rational function), the following will be satisfied: f t , 0 f N t , 0 = f N +1
e R p+1 ( k ) t e0 1 t , 0 f N t , 0 = D p+1 Fk t 2 p +1
(8.30)
where fN+1(t,0) stands for (8.28) with k + 1 instead of k. To calculate Dp+1Fk in the above formula, Fk+p+1 is required, in addition to the set {Fn; n = k, k+1, ...., k+p} to be used for calculation of fN(t,0); hence, one more evaluation of the function is needed. To avoid that, the following expression is substituted for the truncation error of fN(t,0) in the subroutines; f N t , 0 f N 1 t , 0 =
e 0 1 D p +1 Fk 1 t 2 p +1 67
GENERAL DESCRIPTION
Since G(s) is regular in the domain of Re(s) > 0, g(t) can be calculated as explained above; then f(t) is obtained by multiplying g(t) by e 0t Transformation of rational functions A rational function F(s) can be expressed as follows using polynomials Q(s) and P(s) each having real coefficients: F(s) = Q(s) / P(s) (8.32)
Re(s) >0, the above procedure can be repeated increasing ( > 0) so that G(s)=F(s+) is regular in the domain of Re(s) > 0. The value of fN(t,0) is calculated by multiplying et by gN(t,0), the inverse of G(s). When F(s) is an irrational function or a distribution, there is no practical method that tests if F(s) is regular in the domain of Re(s) > 0, therefore, the abscissa of convergence of a general function F(s) must be specified by the user. Choice of subroutines Table 8.2 shows subroutines for the inversion of Laplace transforms. LAPS1 and LAPS2 are used for rational functions where LAPS1 for 0 0 and LAPS2 otherwise. HRWIZ judges the condition P(s), that is, examines if 0 > 0 in (8.32) is a Hurwitz polynomial; and if 0 > 0 is detected, the approximated value of 0 is calculated. The condition 0 > 0 means that the original function f(t) increases exponentially as t . So, HRWIZ can be used for examining such a behavior. Figure 8.3 shows a flowchart for choosing subroutines.
Table 8.2 Laplace transform subroutines Function type Subroutine name LAPS1 (F20-01-0101) LAPS2 (F20-02-0101) HAWIZ (F20-02-0201) LAPS3 (F20-03-0101) Remarks Rational functions regular in the right-half plane. General rational functions. Judgment on Hurwitz polynomials. Convergence coordinate 0 must be input.
To determine whether 00 or 0>0 , it is only necessary to check whether P(s) is a Hurwitz polynomial (that is, all zeros are on the left-half plane {s | Re(s)<0}. The procedure used for the check is described below (reference [94]): A polynomial P(s) of degree n with real coefficients is expressed as follows: P(s) = a1sn + a2 sn 1 + = m(s) + n(s)
+a s+a
n n1
n1
,a 0 +
1
The ratio of n(s) to m(s) is defined as: W ( s) m( s) n( s) Then, W(s) is expanded into continued fraction as:
Rational functions
General functions
W (s) = h1s +
1 1 1 + + + h2 s h3s h4 s
(8.33)
If all of h1, h2, are positive, P(s) is a Hurwitz polynomial. If F(s) has singularities in the domain of
68
TRANSFORMS
No
0 is requied
No
Yes
HRWIZ No 1
LAPS3
0 0
Yes Yes Inversion required
No
No
No LAPS1 LAPS2
END
69
GENERAL DESCRIPTION
9.1
OUTLINE
This chapter describes the following types of problems. Numerical differentiation: Given function values yi = f(xi ), i = 1, ... n at discrete points x1, x2, ..., xn (x1 < x2 < ... < xn), the l - th order derivative f(l)(v), at x = v in the interval [x1, xn] is determined, where l 1. In addition two-dimensional differentiation is included. Also, given function f(x), the following derivative is expanded to Chebyshev series. f ( l ) ( x ) = d l f ( x ) dx l , l 1 Numerical quadrature: Given function values yi = f(xi ), i = 1, ..., n at discrete points x1, x2, ..., xn, the integral of f(x) over the interval [x1, xn] is determined. Also, given function f(x), the integral S = f ( x ) dx
a b
Function input Given function f(x) and domain [a, b], f(x) is expanded to Chebyshev series within a required accuracy. That is, it is approximated by the following functions: f (x )
n 1 k =0
ck Tk
2 x (b + a ) ba
2 x (b + a ) c lk Tk ba
the derivatives are expanded to Chebyshev series. The derivative values are obtained by evaluating f(l)(v) at point x = v in the interval in which the function is defined, that is, by summing Chebyshev series. Table 9.1 lists subroutines used for numerical differentiation.
9.3
NUMERICAL QUADRATURE
Numerical Quadrature is divided into the following two types. Integration of a tabulated function Given function values yi = f(xi ), i = 1, ..., n at discrete points x1 < x2< .... <xn, the definite integral: S=
xn
9.2
NUMERICAL DIFFERENTIATION
When performing numerical differentiation, SSL II divides problems into the following two types: Discrete point input In numerical differentiation, an appropriate interpolation function is first obtained to fit the given sample point (xi ,yi ) where i = 1, 2, ..., n, then it is differentiated. Among several functions available, SSL II exclusively uses the spline function and we preferably use its Bspline representations. See Chapter 7 as for the spline function and B-spline representations. 70
x1
f ( x ) dx
(9.1)
is approximated using only the given function values yi . The bounds of error of the approximated value can not be calculated. Different subroutines are used depending on whether or not the discrete points are equally spaced. Integration of a function Given a function f(x) and the interval of integration
Table 9.1 Subroutine used for numerical differentiation Objective Derivative value Subroutine name SPLV (E11-21-0101) BIF1 (E11-31-0101) BIF2 (E11-31-0201) BIF3 (E11-31-0301) BIF4 (E11-31-0401) BSF1 (E31-31-0101) BIFD1 (E11-32-1101) BIFD3 (E11-32-3301) BSFD1 (E31-32-0101) FCHEB (E51-30-0101) GCHEB (E51-30-0301) ECHEB (E51-30-0201) Method Cubic spline interpolation B-spline interpolation (I) B-spline interpolation (IO) B-spline interpolation (III) B-spline interpolation (IV) B-spline smoothing B-spline 2-dimensional interpolation (I-I) B-spline 2-dimensional interpolation (III-III) B-spline two-dimensional smoothing Fast cosine transformation Backward recurrence equation Backward recurrence equation Discrete point input 2dimensional Remarks Discrete point input
Function input, Chebyshev series expansion Chebyshev series derivative Summing Chebyshev series
= a f
b
(x) dx
(9.2)
Names of the subroutine are based on this classification: 1-dimensional finite interval integration 1-dimensional infinite interval integration If a subroutine is characterized by other aspects or by its method, they are included in parentheses: 1-dimensional finite interval integration (unequally spaced discrete point input, trapezoidal rule) 1-dimensional finite interval integration (function input, adaptive Simpsons rule) Numerical integration methods differ depending on whether a tabulated function or a continuous function is given. For a tabulated function, since integration is performed using just the function values yi = f(xi ), i = 1, ...n it is difficult to obtain an approximation with high accuracy. On the other hand, if a function is given, function values in general can be calculated anywhere (except for singular cases), thus the integral can be obtained to a desired precision by calculating a sufficient number of function values. Also, the bounds of error can be estimated. Integrals of one-dimensional functions over finite interval The following notes apply to the subroutines which b compute f (x )dx
a
is calculated within a required accuracy. Different subroutines are used according to the form, characteristics, and the interval of integration of f(x). Besides (1. 2), the following types of integrals are calculated.
( x) dx , f ( x ) dx ,
0
f
a dx c f (x , y ) dy
b d
Subroutines used for numerical quadrature are shown in Table 9.2. General conventions and comments on numerical quadrature The subroutines used for numerical quadrature are classified primarily by the following characteristics. Dimensions of the variable of integration: 1 dimension or 2 Interval of integration: dimensions finite interval, infinite interval, or semi-infinite interval.
71
GENERAL DESCRIPTION
Table 9.2 Numerical quadrature subroutines Objective 1-dimensional finite interval (equally spaced) Subroutine name SIMP1 (G21-11-0101) TRAP (G21-21-0101) BIF1 (E11-31-0101) BIF2 (E11-31-0201) BIF3 (E11-31-0301) BIF4 (E11-31-0401) BSF1 (E31-31-0101) BIFD1 (E11-32-1101) BIFD3 (E11-32-3301) BSFD1 (E31-32-0101) SIMP2 (G23-11-0101) AQN9 (G23-11-0201) AQC8 (G23-11-0301) AQE (G23-11-0401) AQEH (G23-21-0101) AQEI (G23-31-0101) AQMC8 (G24-13-0101) AQME (G24-13-0201) Method Simpsons rule Trapezoidal rule B-spline interpolation (I) B-spline interpolation (II) B-spline interpolation (III) B-spline interpolation (IV) B-spline smoothing B-spline 2-dimensional interpolation (I-I) B-spline 2-dimensional interpolation (III-III) B-spline two-dimensional smoothing Adaptive Simpsons rule Adaptive Newton-Cotes 9 point rule Clenshaw-Curtis integration Integration of a function Double exponential formula Double exponential formula Double exponential formula Clenshaw-Curtis quadrature Double exponential formula Multi-variate function input Discrete point input Remarks
1-dimensional semiinfinite interval 1-dimensional infinite interval Multi-dimensional finite region Multi-dimensional region
Automatic quadrature routines Four quadrature subroutines, SIMP2, AQN9, AQC8, and AQE are provided for the integration
a f (x)dx
b
, as
shown in Table 9.2. All these subroutines are automatic quadrature routines. An automatic quadrature routine is a routine which calculates the integral to satisfy the desired accuracy when integrand f(x), integration interval [a, b], and a desired accuracy for the integral are given. Automatic quadrature is the algorithm designed for this purpose. Generally in automatic quadrature subroutines, an integral calculation starts with only several abscissas (where the integrand is evaluated), and next improves the integral by increasing the number of abscissas gradually until the desired accuracy is satisfied. Then the calculation stops and the integral is output.
In recent years, many automatic quadrature subroutines have been developed all over the world. These subroutines have been tested and compared with each other many times for reliability (i.e., ability to satisfy the desired accuracy) and economy (i.e., less calculation) by many persons. These efforts are well reflected in the SSL II subroutines. Adaptive method This is most (popularly) used for integral calculation as a typical method of automatic integration. This is not a specific integration formula (for example, Simpsons rule, Newton-Cotes 9 point rule, or Gauss rule, etc.), but a method which controls the number of abscissas and their positions automatically in response to the behavior of integrand. That is, it locates
72
abscissas densely where integrand changes rapidly, or sparsely where it changes gradually. Subroutines SIMP2 and AQN9 use this method. Subroutine selection As a preliminary for subroutine selection, Table 9.3 shows several types of integrands from the viewpoint of actual use. It is necessary in subroutine selection to know which subroutine is suitable for the integrand. The types of routines and functions are described below in conjunction with Table 9.3.
Table 9.3 Integrand type Code Smooth Peak Meaning Function with good convergent power series. Function with some high peaks and wiggles in the integration interval. Function with severe, short length wave oscillations. Function with algebraic singularity (x, 1 < ) or logarithmic singularity (log x). Function with discontinuities in the function value or its derivatives Example 0 sinxdx, x 1 0 e dx -1 dx / 6 2 (x + 10 )
1
AQE
0 sin100 xdx
1
series expansion of a function, the more effectively the routine can perform integration, the better convergence property the integrand has. For example, it can be used for smooth functions and oscillatory functions but is not suitable for singular functions and peak type functions. .....Method which extends the integration interval [a, b] to (-,) by variable transformation and uses the trapezoidal rule. In this processing, the transformation is selected so that the integrand after conversion will decay in a manner of a double exponential function (exp (-aexp|x|), where a>0) when x. Due to this operation, the processing is still effective even if the function change rapidly near the end points of the original interval [a, b]. Especially for functions which have algebraic singularity or logarithmic singularity only at the end points, processing is more successful than any other subroutine, but not so successful for functions with interior singularities.
SIMP2
AQN9
AQC8
.... Uses adaptive method based on Simpsons rule. This is the first adaptive method used in the SSL II, and is the oldest in the history of adaptive methods. More useful adaptive methods are now available. That is, SIMP2 is inferior to the adaptive routine AQN9 in many respects. .... Adaptive method based on Newton-Cotes 9-point rule. This is the most superior adaptive method in the sense of reliability or economy. Since this subroutine is good at detecting local actions of integrand, it can be used for functions which have singular points such as a algebraic singularity, logarithmic singularity, or discontinuities in the integration interval, and in addition, peaks. ... Since this routine is based on Chebyshev
Table 9.4 summarizes these descriptions. The subroutine marked by o is most suitable for corresponding type of function, and the subroutine marked by x should not be used for the type. No mark indicates that the subroutine is not always suitable but can be used. All these subroutines can satisfy the desired accuracy for the integral of smooth type. However, AQC8 is best in the sense of economy, that is, the amount of calculation is the least among the three. SSL II provides subroutines AQMC8 and AQME for up to three-dimensional integration. They are automatic quadrature routines as shown below. AQMC8 .... Uses Clenshaw-Curtis quadrature for each dimension. It can be used for a smooth and oscillatory functions. However, it is not applicable to functions having singular points or peaked functions. AQME ..... Uses double exponential formula for each dimension. Since this subroutines has all formulas used in AQE, AQEH and AQEI, it can be used for any type of intervals (finite, semifinite or infinite interval)
Table 9.4 Subroutine selection Function type Subroutine AQN9 AQC8 AQE Singular End point O O O O Interior O Discontinuous O
Smooth
Peak
Oscillatory
Unknown* O
73
GENERAL DESCRIPTION
and those combining these types. AQME can be used efficiently if the function has singular points on the boundary of a region. However, it
is not applicable to the function which has singular points in the region.
74
10.1
OUTLINE
x0 < x1 < x2 < ... <xe step by step as shown in Fig. 10.1.
y
This chapter describes the following types of problems. Ordinary differential equations (initial value problems) Initial value problems of systems of first order oridnary differential equations are solved.
y1 = f 1 ( x , y1 , y2 = f 2 ( x , y1 ,
n n 1
(10.1)
y0
x0
x1 x2
x3
x4
x5
Initial value problems of high order ordinary differential equations can be reduced to the form shown in (10.1). Namely, letting
y
(k )
xe
y10
, y ), = y( x ), y = y ( x ), , y = y ( x )
= f x , y , y , y ,
0 20
( k 1)
( k 1)
k0
and
y1 = y( x ), y2 = y ( x ),
, y
( ) = y k 1 ( x )
Then, the high order equations can be reduced to and expressed as:
y1 = y2 y2 = y3 y k1 = y k y k = f x , y1 , y 2 , y10 = y1 x 0 y 20 2 0 y k 10 = y k 1 x 0 y k 0 = y k x0
( ) = y (x )
Solution output In Fig. 10.1, solution output points x1, x2, x3, ... are either specified by the user or selected as a result of step size control by the subroutine. The purpose of solving the differential equations is to obtain: (a) the solution y(xe) only at xe (b) the solutions at the points selected as a result of stepsize control by the subroutine. In this case, the purpose is to know the behavior of solutions, and no restriction is necessary to the solution output points because the behaviour of the solutions is all that is needed (c) the solution at user-specified points {j} or at equally spaced points. The SSL II ordinary differential equation subroutines provide two output methods (timing to return to the user program from the subroutine) corresponding to the purposes described above, as follows: Final value output When the solution y(xe) is obtained, return to the user program. For the purpose of (c), set xe to i sequentially, where i = 1, 2, ..., and call the subroutine repeatedly.
, y )
k
( ) ( )
(10.2)
75
GENERAL DESCRIPTION
Step output Under step-size control, return to the user program after one step integration. The user program can call this subroutine repeatedly to accomplish (b) described above. SSL II provides subroutines ODRK1 and ODAM which incorporate final value output and step output. The user can select the manner of output by specifying a parameter. Stiff differential equations This section describes stiff differential equations, which appear in many applications, and presents definitions and examples. The equations shown in (10.1) are expressed in the from of vectors as shown below. y = f x, y , where
However, attempts to use methods such as Euler and classical Runge-Kutta encounter a phenomenon that errors introduced at a certain step increase from step to step. Therefore, when using these methods, the step sizes are substantially restricted. The larger the value of max ( |Re(i)| ) is, the smaller the step size must be. Although solution y(x) can be approximated numerically by the smoothing function (x), the step sizes must be small for integration. This causes an imbalance between two step sizes, one of which is enough to approximate the solution numerically, and the other is required for error protection. If (x)=0, that is, (x)=0 in (10.3), solution y(x) becomes smaller. Therefore, it is actually approximated by the term ki eix ui corresponding to the smallest | Re(i) |. In this case, if max | Re(i) | is large, the above mentioned difficulty occurs. The stiff differential equation is defined as follows: Definition 1 When the following linear differential equation y ' = Ay + ( x ) satisfies the following (10.8) and (10.9), Re(i )<0, i=1, 2, max Re i
i
( )
y x0 = y0
T
( )
(10.3)
(10.7)
, N
(10.8) (10.9)
where, A is a constant coefficient matrix and (x) is an appropriate function vector. Then, the solution for (10.3) can be expressed by using eigenvalues of A and the corresponding eigenvectors as follows: y( x ) = ki ei x ui + ( x )
i=1 N
(10.5)
they are called stiff differential equations. The left side of the equation in (10.9) is called stiff ratio. If this value is large, it is strongly stiff: otherwise, it is mildly stiff. Actually, strong stiffness with stiff ratio of magnitude 106 is quite common. An example of stiff linear differential equations is shown in (10.10). Its solution is shown in (10.11) (See Fig. 10.2). 1998 998 1 y' = y , y( 0) = 999 1999 0 1 2 y = e x + e 1000 x 1 1 Obviously, the following holds: when x , y1 2e-x , y2 e-x
2 y1 1
ki : constant Let us assume the following conditions for i and (x) in (10.5): (a) Re(i)<0, for i=1, 2, ..., N (b) (x) is smoother than any eix (that is, it has good convergent power expansion). Under these conditions, as x tends to infinity, the following can be seen.
(10.10) (10.11)
i =1
ki ei x ui 0
(10.6)
0 y2 -1 x
So, solution y(x) tends to (x). After (x) has become dominant, the solution can be obtained by the approximate solution for (x). The step sizes can be spaced rather roughly. 76
DIFFERENTIAL EQUATIONS 77
Suppose f(x, y) is nonlinear. The eigenvalue of the following Jacobian matrix determines stiffness.
J =
f ( x , y) y
where, the eigenvalues vary with x. Then, definition 1 is extended for nonlinear equations as follows. Definition 2 When the following nonlinear differential equation y = f(x , y ) (10.12)
stiffness can be checked directly by calculating the eigenvalues of A. When the equation is nonlinear, subroutine ODAM can be used to check stiffness. ODAM uses the Adams method by which non-stiff equations can be solved. ODAM notifies of stiffness via parameter ICON if the equation is stiff. Subroutine ODGE can be used to solve stiff equations. Subroutine selection Table 10.1 lists subroutines used for differential equations. ODGE for stiff equations ODRK1 or ODAM for non-stiff equations ODRK1 is effective when the following conditions are satisfied: The accuracy required for solution is not high. When requesting output of the solution at specific points of independent variable x, the interval of points is widse enough. The user should use ODAM when any of these conditions is not satisfied. Use ODAM at first when the equation is not recognized stiff. ODAM can be changed to ODGE if stiffness is detected.
satisfies the following (10.13) and (10.14) in a certain interval, it is said to be stiff in that interval. Re i ( x ) < 0 , i = 1, 2, ( x ) max Re i x min Re i
, N
xI
(10.13)
( (
) ())
>>1 , x I (10.14)
where i (x) are the eigenvalues of J. Whether the given equation is stiff or not can be checked to some extent in the following way: When the equation is linear as shown in (10.7), the
Table 10.1 Ordinary differential equation subroutines Objective Subroutine name RKG (H11-20-0111) HAMNG (H11-20-0121) ODRK1 (H11-20-0131) ODAM (H11-20-0141) ODGE (H11-20-0151) Method Runge-Kutta Gill method Hamming method Rung-Kutta-Verner method Adams method Gear method Comments Fixed step size Variable step size Variable step size Variable step size Variable order Variable step size Variable order (Stiff equations)
77
11.1
OUTLINE
The special functions of SSL II are functions not included in FORTRAN basic functions. The special functions are basically classified depending upon whether the variables and functions are real or complex.
Real type (variable and function are both real) Special functions Complex type (variable and function are both complex)
subroutines, single precision and double precision subroutines have been prepared also for interrelated special functions. For frequently used functions, both general and exclusive subroutines are available. ICON Special functions use FORTRAN basic functions, such as exponential functions and trigonometric functions. If errors occur in these basic functions, such as overflow or underflow, detection of the real cause of problems will be delayed. Therefore, to notice such troubles as early as possible, the detection is made before using basic functions in special function subroutines, and if detected, informations about them are returned in parameter ICON. Calling method Since various difficulties may occur in calculating special functions, subroutines for these functions have a parameter ICON to indicate how computations have finished. Accordingly,special functions are implemented in SUBROUTINE form which are called by using the CALL statements, while it is said that these functions should be implemented in FUNCTION form as basic functions.
The following properties are common in special function subroutines. Accuracy The balance between accuracy and speed is important and therefore taken into account when selecting calculation formulas. In SSL II, calculation formulas have been selected such that the theoretical accuracies (accuracies in approximation) are guaranteed to be within about 8 correct decimal digits for single precision versions and 18 digits for double precision versions. To insure the accuracy, in some single precision versions, the internal calculations are performed in double precision. However, since the accuracy of function values depends on the number of working digits available for calculation in the computer, the theoretical accuracy cannot always be assured. The accuracy of the single precision subroutines has been sufficiently checked by comparing their results with those of double precision subroutines, and for double precision subroutines by comparing their results with those of extended precision subroutines which have much higher precision than double precision subroutines. Speed Special functions are designed with emphasis on accuracy first and speed second. Though real type functions may be calculated with complex type function subroutines, separate subroutines are available with greater speed for real type calculations. Separate
11.2
ELLIPTIC INTEGRALS
Elliptic integrals are classified into the types shown in Table 11.1. A second order iteration method can be used to calculate complete elliptic integrals, however, it has the disadvantage that the speed changes according to the magnitude of variable. In SSL II subroutines, an approximation formula is used so that a constant speed is maintained.
78
SPECIAL FUNCTIONS
Table 11.1 Elliptic integral subroutines Mathematical symbol K(k) Subroutine name CELI1 (I11-11-0101) CELI2 (I11-11-0201)
Table 11.4 Subroutines for Fresnel integrals Item Sine Fresnel integral Cosine Fresnel integral Mathematical symbol S(x) C(x) Subroutine name SFRI (I11-51-0101) CFRI (I11-51-0201)
Item Complete Complete elliptic integral of the first kind Complete elliptic integral of the second kind
E(k)
Table 11.5 Subroutines for gamma functions Item Incomplete gamma function of first kind Incomplete gamma function of second kind Mathematical symbol (,x) (,x) Subroutine name IGAM1 (I11-61-0101) IGAM2 (I11-61-0201)
11.3
EXPONENTIAL INTEGRAL
Between the complete Gamma function () and the first and the second kind incomplete Gamma functions the relationship (v ) = (v , x ) + (v , x ) holds. As for (), the corresponding FORTRAN basic external function should be used.
Since exponential integral is rather difficult to compute, various formulas are used for various range of variable.
11.4
11.5
FRESNEL INTEGRALS
Between inverse error function and inverse complementary error function, the relationship erf-1 (x) = erfc-1 (1 x)
11.6
GAMMA FUNCTIONS
holds. Each is evaluated by using either function which is appropriate for that range of x. As for erf(x) and erfc(x), the corresponding FORTRAN basic external function used.
79
GENERAL DESCRIPTION
11.8
BESSEL FUNCTIONS
Table 11.8 Bessel function subroutines for complex variables Item Mathematical symbol Jn(z) Jv (z) (v 0.0) In (z) Subroutine name CBJN (I11-82-1301) CBJR (I11-84-0101) CBIN (I11-82-1101) CBYN (I11-82-1401) CBKN (I11-82-1201)
Bessel functions are classified into various types as shown in Table 11.7, and they are frequently used by the user. Since zero-order and first-order Bessel functions are used quite often, exclusive subroutines used for them which are quite fast, are provided.
Table 11.7 Subroutines for Bessel functions with real variable Item First kind Zero-order Bessel function First-order Bessel function Integer order Bessel function Real-order Bessel function Zero order modified Bessel function First order modified Bessel function Integer order modified Bessel function Real order modified Bessel function Zero-order Bessel function First-order Bessel function Integer order Bessel function Real-order Bessel function Zero order modified Bessel function First order modified Bessel function Integer order modified Bessel function Real order modified Bessel function Mathematical symbol J0 (x) J1 (x) Jn (x) Jv (x) (v 0.0) I0 (x) Subroutine name BJ0 (I11-81-0201) BJ1 (I11-81-0301) BJN (I11-81-1001) BJR (I11-83-0101) BI0 (I11-81-0601) BI1 (I11-81-0701) BIN (I11-81-0701) BIR (I11-83-0301) BY0 (I11-81-0401) BY1 (I11-81-0501) BYN (I11-81-1101) BYR (I11-83-0201) BK0 (I11-81-0801) BK1 (I11-81-0901) BKN (I11-81-1301) BKR (I11-83-0401)
First kind
Second kind
Integer order Bessel function Real order Bessel function Integer order modified Bessel function Integer order Bessel function Integer order modified Bessel function
Yn (z) Kn (z)
I1 (x)
In (x)
Item Normal distribution function Complementary normal distribution function Inverse normal distribution function Inverse complementary normal distribution
Second kind
Subroutine name NDF (I11-91-0101) NDFC (I11-91-0201) NDF (I11-91-0301) INDFC (I11-91-0401)
K1 (x)
Kn (x)
Kv (x)
80
12.1
OUTLINE
Table 12.1 List of subroutines for pseudo random number generation Type Uniform (0, 1) pseudo random numbers Shuffled uniform (0, 1) pseudo random numbers Exponential pseudo random numbers Fast normal pseudo random numbers Subroutine name RANU2 (J11-10-0101) RANU3 (J11-10-0201) RANE2 (J11-30-0101) RANN1 (J11-20-0301) RANN2 (J11-20-0101) RANP2 (J12-10-0101) RANB2 (J12-20-0101)
This chapter deals with generation of pseudo-random (real or integer) numbers with various probability distribution functions, and with the test of random numbers.
12.2
Random numbers with any given probability distribution can be obtained by transformation of the uniform (0, 1) pseudo-random numbers. That is, in generation of required pseudo random numbers let g(x) be the probability density function of the distribution. Then, the pseudo-random numbers y are obtained by the inverse function (12.1) of F ( y) = y =F-1 (u)
y 0 g ( x )dx
12.3
(12.1)
where: y is the required pseudo random number, F(y) is the cumulative distribution function of g(x) and u is uniform pseudo random number. Pseudo-random numbers with discrete distribution are slightly more complicated by intermediate calculations. For example subroutine RANP2 first generates a table of cumulative Poisson distribution and a reference table which refers efficiently for a generated uniform (0, 1) number and then produces Poisson pseudo-random integers. Table 12.1 shows a list of subroutines prepared for SSL II. These subroutines provide a parameter to be used as a starting value to control random number generation. (Usually, only one setting of the parameter will suffice to yield a sequence of random numbers.)
When using pseudo random numbers, the features of the random numbers must be fully recognized. That is, the random numbers generated arithmetically by a computer must be tested whether or not they can be assumed as realized values of the sequence of each probability variable depending upon specific probability distribution. SSL II generates pseudo random numbers with various probability distribution by giving appropriate transformation to the uniform (0, 1) pseudo random number. SSL II provides parameter IX to give the starting value for pseudo random number generation. This enables easier generation of some different random numbers. Generally to give the starting value, parameter IX is specified as zero. The results of testing the pseudo random numbers are described in comment on use for subroutines RANU2. The features of pseudo random numbers depend on the value of parameter IX. SSL II provides subroutines which are used to test the generated pseudo random numbers as shown in Table 12.2.
81
GENERAL DESCRIPTION
Table 12.2 Pseudo random number testing subroutines Item Frequency test Runs test of up-and-down subroutine name RATF1 (J21-10-0101) RATR1 (J21-10-0201) Notes Testing of probability unity Testing of randomness
Total n n
Test of statistical hypothesis The test of statistical hypothesis is used to determine whether a certain hypothesis is accepted or rejected by the realized value of the amount of statistics obtained by random sampling. Whether or not one of the dice is normal can be checked by throwing it for several times and checking the result. Say, for example, that the same face came up five times in a row. If the die is normal, that is, if the ratio of obtaining a particular roll is identical for each face, the probability that the same face will come up five times in a row is (1/6)5 which is 1/7776. This implies that if such testing is performed 7776 times repeatedly, the same combination is expected to come up once as an average. Therefore, if only 5 throws result in obtaining the same five numbers, the hypothesis that the die is normal, is assumed to be doubtful. Suppose an event is tested under a certain hypothesis and occurs at less than the probability of percent (generally 5 or 1 percent). In this state, if the event occurs by one testing, it is rejected because it is doubtful; otherwise it is received. This hypothesis has been tested whether or not it is accepted. It is called null hypothesis, where the region in which the probability is less than percent is called critical region. The region is rejected or accepted according to a significance level. When using this testing method, the hypothesis may be rejected despite the fact that it is true. This is expressed by percent which is the level of significance. Chi-square ( 2) testing Suppose the significance level at percent. Also suppose the population is classified into l number of exclusive class c1, c2, ..., cl, where when selecting n number of them, the actually corresponding frequencies are f1, f2, ..., fl and the expected frequencies are based on null hypothesis F1, F2, ...., F1 respectively.
Then the ratio of the actual frequency for the expected frequency is expressed as follows:
2 0 =
(f
Fi Fi
l=1
(12.2)
The larger the difference between the actual frequency and the expected frequency is, the larger the value of 2 0 becomes. Whether or not the hypothesis is accepted or rejected depends upon the ratio. The frequency varying for each n-size sampling is expressed by ~ ~ ~ f 1 , f 2 , ... , f l probability variables. The statistic is expressed as
2 =
f F) (~
i i
(12.3)
i =1
Fi
When expected frequency Fi is large enough, 2 is approximately distributed depending upon chi-square distribution of freedom l-1. Obtain point 02 equivalent to significance level percent in chi-square distribution of freedom l-1 for the following testing. When 2 < 02 , the hypothesis is rejected. When 2 02 , the hypothesis is accepted. This is called chi-square ( 2) testing. The value of actual frequency and expected frequency depend upon the contents (frequency testing, run testing) of testing. Comments on use Sample size The size of a sample must be large enough. That is, the statistic in (12.3) is approximated to chi-square distribution of freedom l-1 for large n. If n is small, the statistic cannot be sufficiently approximated and the test results may not be reliable. The expected frequency should be Fi > 10 , i=1, 2,
, l
(12.4)
If the conditions in (12.4) are not satisfied, freedom must be lower by combining several classes.
Acknowledgement
We are greatly indebted to prof. Wakimoto, Okayama University of Japan, for helpful suggestions in the development of this area of the library.
82
AGGM
Comments on use Subprograms used SSL II .....MGSSL FORTRAN basic function ... None Notes Saving the storage area: If there is no need to keep the contents on the array A or B, more storage area can be saved by specifing parameters C and KC as follows; When the contents of array A are not needed: CALL AGGM (A, KA, B, KB, A, KA, M, N, ICON)
Function These subroutines perform addition of two m n real general matrices A and B. C=A+B where C is an m n real general matrix. m, n 1. Parameters A .... Input. Matrix A, two-dimensional array, A (KA, N). KA .... Input. The adjustable dimension of array A, ( M). B .... Input. Matrix B, two-dimensional array B (KB, N). KB .... Input. The adjustable dimension of array B, (M). C .... Output. Matrix C, two-dimensional array C (KC, N). (Refer to Comment.) KC .... Input. The adjustable dimension of array C, ( M). M .... Input. The number of rows m of matrices A, B, and C N .... Input. The number of columns n of matrices A, B, and C. ICON. Input. Condition codes. Refer to Table AGGM-1.
Table AGGM-1 Condition code Code 0 30000 Meaning No error M<1, N<1, KA<M, KB<M or KC<M Processing Bypassed
When the contents of array B are not needed: CALL AGGM (A, KA, B, KB, B, KB, M, N, ICON) In this case, matrix C is stored in array A or B. Example The following shows an example of obtaining the addition of matrices A and B. Here, m, n 50.
C **EXAMPLE** DIMENSION A(50,50),B(60,60),C(100,100) DATA IA/1HA/,IB/1HB/,IC/1HC/ DATA KA/50/,KB/60/,KC/100/ 10 READ(5,100) M,N IF(M.EQ.0) STOP WRITE(6,150) READ(5,200) ((A(I,J),I=1,M),J=1,N) READ(5,200) ((B(I,J),I=1,M),J=1,N) CALL AGGM(A,KA,B,KB,C,KC,M,N,ICON) IF(ICON.NE.0) GOTO 10 CALL PGM(IA,1,A,KA,M,N) CALL PGM(IB,1,B,KB,M,N) CALL PGM(IC,1,C,KC,M,N) GOTO 10 100 FORMAT(2I5) 200 FORMAT(4E15.7) 150 FORMAT(1H1///10X, * 21H** MATRIX ADDITION **) END
The subroutine PGM in the example is for printing a real matrix. this program is shown in the example for subroutine MGSM.
85
AKHER
D j Z j Z j 1
j = 2,
, m
Function Given discrete points x1 < x2 < ... < xn, function values yi = f(xi ), and first derivatives yi = f(xi ), i = 1, ...., n this subroutine interpolates at a given point x = v using the Aitken-Hermite interpolation. n 1. Parameters X .... Input. Discrete points xi . X is a one-dimensional array of size n. Y .... Input. Function value yi . Y is a one-dimensional array of size n. DY .... Input. First order derivatives yi . DY is a one-dimensional array of size n. N .... Input. Number (n) of discrete points. V .... Input. The point to be interpolated. M .... Input. Number of discrete points to be used in the interpolation ( n). Output. Number of discrete points actually used. (See the comments) EPS .... Input. Threshold value. Output. Absolute error of the interpolated value. (See the comments) F .... Output. Interpolated value. VW .... Work area. One-dimensional array of size 5n ICON .. Output. Condition code. Refer to Table AKHER-1.
Table AKHER-1 Condition codes. Code 0 10000 30000 Meaning No error is equal to one of the discrete points xi. n < 1, M = 0, or xi xi+1 Processing F is set to yi. F is set to 0.0.
where m is the maximum number of discrete points to be used. Generally, as the order of an interpolation polynomial increases, |Dj| behaves as shown in Fig. AKHER-1.
|Dj|
Fig. AKHER-1
In Fig. AKHER-1, l indicates that the truncation error and the calculation error of the approximation polynomial are both at the same level. Usually, Zl is considered as numerically the optimum interpolated value. How to specify EPS: The following conditions are considered. Convergence is tested as described in Stopping criterion, but Dj exhibits various types of behavior depending on the tabulated function. As shown in Fig. AKHER-2 in some cases vacillation can occur.
|Dj|
Fig. AKHER-2
Comments Subprogram used SSL II ... AFMAX, MGSSL FORTRAN basic functions ... ABS, and IABS Notes Stopping criterion: Lets consider the effect of the degree of interpolation on numerical behavior first. Here, Zj denotes the interpolated value obtained by using j discrete points near x = v. Discrete points are ordered according to their closeness to x = v. The difference Dj is
In this case, Zl instead of Zs should be used for the interpolated value. Based on this philosophy the interpolated value to be output is determined as shown below. When calculating D2, D3, , Dm, If |Dj|>|EPS|, j=2, 3, , m l is determined such that
Dl = min D j
j
( )
(3.1)
86
AKHER
value of Zl, l, |Dl| and if |Dj| EPS occurs for a certain j, from then on, l is determined such that Dl Dl+1 (3.2)
value which satisfies the conditions (i, 0), (i, 1), i = 1, ..., m Before discussing general cases, an example in the case m = 2 is shown that determines an interpolated value which satisfies the four conditions (1,0), (1,1), (2,0), (2,1). Procedure 1 An interpolated value
If (3.2) does not occur, l is set to m, and Zm, m and |Dm| are output. If the user specifies EPS as 0.0, Zj corresponding the minimum |Dj| is output as the interpolated value. How to specify M: a) If it is known that in the neighbourhood of x = v the original function can be well approximated by polynomials of degree 2k-1 or less, it is natural to use a polynomial of the degree 2k-1 or less. In this parameter M should be se specified equal to k. b) If the condition in a) is unknown, parameter N should be entered in parameter M. c) It is possible that the user wants an interpolated value which is obtained by using exactly m points without applying the stopping criterion. In this case, the user can specify M equal to m. Example The values of the input parameters are read and the interpolated value F is determined n 30.
C **EXAMPLE** DIMENSION X(30),Y(30),DY(30),VW(150) READ(5,500) N,(X(I),Y(I),DY(I),I=1,N) WRITE(6,600) (I,X(I),Y(I),DY(I),I=1,N) 10 READ (5,510) M,EPS,V IF(M.GT.30) STOP CALL AKHER(X,Y,DY,N,V,M,EPS,F,VW, ICON) WRITE(6,610) ICON,M,V,F IF(ICON.EQ.30000) STOP GO TO 10 500 FORMAT(I2/(3F10.0)) 510 FORMAT(I2,2F10.0) 600 FORMAT(15X,I2,5X,3E20.8) 610 FORMAT(20X,6HICON=,I5,10X,3HM =,I2/ * 20X,12HV =,E20.8/ * 20X,17HCOMPUTED VALUES =,E20.8) END
PA1 (v ) y1,1 y1 + y1 v v1
) )
which satisfies (1,0), (1,1) is determined. An interpolated value v v2 PA 3 (v ) y 2 ,2 y 2 + y 2 Procedure 2 An interpolated value PA2 (v ) y1,2 y1 + y1 y 2 v v1 v1 v 2
which satisfies conditions (1,0), (2,0) is determined. Procedure 3 An interpolated value PA4 (v ) y1,1 ,2 PA1 (v ) + PA1 (v ) PA 2 (v ) v v1 v1 v 2
which satisfies conditions (1,0), (1,1), (2.0) is determined. An interpolated value PA5 (v ) y1,2 ,2 PA 2 (v ) + PA2 (v ) PA3 (v ) v v1 v1 v 2
Method Let discrete point xi be rearranged as v1, v2, ...., vn according to their distance from v with the closest value being selected first, and correspondingly yi = f(vi ) and yi = f(vi ) The condition yi = f(vi ) at point (vi ) is symbolized here as (i, 1). Now, lets consider how to obtain the interpolated value which is based on the (2m-1) th degree interpolating polynomial that satisfies the 2m conditions (1,0), (1,1), (2,0), (2,1), ...(m,0), (m,1). (Hereafter, this value will be referred as the interpolated
Which satisfies conditions (1,0), (2,0), (2,1) is determined. Procedure 4 An interpolated value PA 6 (v ) y1,1 ,2 , 2 PA4 (v ) + PA4 (v ) PA5 (v ) v v1 v1 v2
which satisfies condition (1,0), (1,1), (2,0), (2,1) is determined. Then PA6(v) is the objective interpolated value. For general cases, based on the following formulas
87
AKHER
yi yi +1 ( v vi ) vi vi +1
(i = 1, , m)
(4.1)
(i = 1, , m)
(4.2)
y1.1.2 y1.1.2.2 y1.1.2 2.3 y1.1.2.2.3.3 y1.1.2.2....m.m y1.2.2 y1.2.2.3 y1.2.2.3.3 y2.2.3 y2.2.3.3 y2.3.3
88
AKLAG
D j Z j Z j 1 j = 2,
, m
Function Given discrete points x1 < x2 < ... < xn and their corresponding function values yi = f(xi ), i = 1, ..., n, this subroutine interpolates at a given point x = v using the Aitken-Lagrange interpolation. n 1 Parameters X ... Input. Discrete points xi . X is a one-dimensional array of size n. Y .... Input. Function values yi . Y is a one-dimensional array of size n. N .... Input. Number of discrete points n. V .... Input. The point to be interpolated. M .... Input. Number of discrete points to be used in the interpolation ( n). Output. Number of discrete points actually used. (See the comments) EPS ... Input. Threshold value. Output. Absolute error of the interpolated value. (See the comments) F .... Output. Interpolated value. VW .... Work area. A one-dimensional array of size 4n. ICON .... Output. Condition code. Refer to Table AKLAG-1. Comments on use Subprograms used SSL II ... AFMAX, MGSSL FORTRAN basic functions ... ABS, and IABS
Table AKLAG-1 Condition codes Code 0 10000 30000 Meaning No error v matched a discrete point xi. n < 1, M = 0 or xi xi+1 Processing F is set to yi. F is set to 0.0.
where m is the maximum number of discrete points to be used. Generally, as the degree of an interpolation polynomial increases, |Dj| behaves as shown in Fig. AKLAG-1
|Dj|
Fig. AKLAG-1
In Fig. AKLAG-1,l indicates that the truncation error and the calculation error of the approximation polynomial are both at the same level. Zl is usually consided as the numerically optimum interpolated value. How to specify EPS: The following conditions are considered. Convergence is tested as described in Stopping criterion, but Dj exhibits various types of behavior depending on the tabulated function. As shown in Fig. AKLAG-2, vacillation can occur in some cases.
|Dj|
Fig. AKLAG-2
Notes Stopping criterion: Lets consider the effect of the degree of interpolation on numerical behavior first. Here, Zj denotes the interpolated value obtained by using j discrete points near x =v. (Discrete points are selected such that the points closest to x = v are selected first.) The difference Dj is defined:
In this case, Zl instead of Zs should be used for the interpolated value. Based on this, the interpolated value to be output is determined as shown below. When calculating D2, D3, ...., Dm, If |Dj| > |EPS| , j=2, 3, ..., m l is determined such that Dl = min ( Dj ) (3.1)
if |Dj| |EPS| occurs for a certain j, from then on l is determined such that
89
AKLAG
Dl Dl+1
(3.2)
and Zl, l, Di are output. If (3.2) does not occur, l is set to m, and Zm, m, and |Dm| are output. If the user specifies EPS as 0.0 Zj corresponding the minimum |Dj| is output as the interpolated value. How to specify M: a) If it is known that in the neighbourhood of x = v the original function can be well approximated by polynomials of degree k or less, it is natural to use interpolating polynomials of degree k or less. In this case parameter M should be specified equal to k + 1. b) If the condition in a) is unknown, parameter M should be the same as parameter N. c) It is possible that the user wants a interpolated value which is obtained by using exactly m points without applying the stopping criterion. In this case, the user can specify M equal to m. Example The input parameters are read, and the interpolated value F is determined. n 30
C **EXAMPLE** DIMENSION X(30),Y(30),VW(120) READ(5,500) N,(X(I),Y(I),I=1,N) WRITE(6,600) (I,X(I),Y(I),I=1,N) 10 READ(5,510) M,EPS,V IF(M .GT.30) STOP CALL AKLAG(X,Y,N,V,M,EPS,F,VW, ICON) WRITE(6,610) ICON,M,V,F IF(ICON.EQ.30000) STOP GO TO 10 500 FORMAT(I2/(2F10.0)) 510 FORMAT(I2,2F10.0) 600 FORMAT(23X,15HARGUMENT VALUES,15X, * 15HFUNCTION VALUES/(15X,I2,5X,E15.7,15X, * E15.7)) 610 FORMAT(20X,6HICON=,I5,10X,3HM=,I2/ * 20X,11HV =,E15.7/ * 20X,17HCOMPUTED VALUES =,E15.7) END
Method Let discrete points xi be rearranged as v1, v2, ..., vn according to their distance from v with the closest value being selected first, and corresponding yl = f(vi ). Usually, a subset of the sample points (vi , yj) = f(vi ); i = 1, ..., m) is used for interpolation as shown below. The interpolated values of the Lagrangian interpolation polynomial of degree i which passes through the discrete points (v1, v1), (v2, v2), ..., (vi , yi ), (vi , yj) are expressed here as y1, 2..., ij (where j > i). The Aitken-Lagrange interpolation method is based on: y1,2 ,,i , j = vi v 1 y1,2 ,,i v j vi y1,2 ,,i 1, j v j v y1,2 ,,i 1, j y = y1,2 ,,i + 1,2 ,,i (vi v) v j vi
As shown in Fig. AKLAG-3, calculation proceeds from the top to bottom of each column, starting at the first and ending at the mth column, row to the bottom row and from the left column to the right, such that y1.2, y1.3, y1.2.3, y1.4, y1.2.4, ...
1 2 3 4
1 2 3 4
y1 y2 y3 y4 ym y1,2 y1,3 y1,4 y1,m y1,2,3 y1,2, 4 y1,2, m y1,2 ,,m y1,2,3,4
Fig. AKLAG-3
The values y1, 2, ......, k on the diagonal line are interpolated values based on the Lagrangian interpolation formula which passes through the discrete points (vi , yj, i = 1, ..., k). Then, y1, 2, ......, m is the final value. For details, see Reference [46] pp.57-59.
90
AKMID
Function Given function values fij = f(xi , yj) at the node points (xi , yj), i = 1, 2, ..., nx, j = 1, 2, ..., ny(xl < xl < ... < xnx, y1 < y1 < ... < xny, an interpolated value at the point (P(vx, vy), is obtained by using the piecewise two-dimensional quasi-Hermite interpolating function of dually degree 3. See Fig. AKMID-1.
y yn y P( vx , vy )
ISW to zero again. Input. x-coordinate at the point P (vx, vy). Input. The i which satisfies xi vx < xi +1. When vx = xnx, IX = nx 1. Output. The i which satisfies xi vx < xi +1. See Note. VY .... Input. y-coordinate at the point P(vx, vy). IY .... Input. The j which satisfies yj vy < yj+1. When vy = yny, IY = ny 1. Output. The j which satisfies yi vy < yi +1 See Note. F .... Output. Interpolated value. VW .... Work area. One-dimensional array of size 50. While the subroutine is called repeatedly with identical input data (xi , yj, fij), the contents of VW must not be altered. ICON ... Output. Condition code. See Table AKMID1. VX .... IX ....
Table AKMID-1 Condition codes Code 0 10000 Meaning No error Either X(IX)VX<X(IX+1) or Y(IY)VY<Y(IY+1) is not satisfied. Processing IX or IY satisfying the relationship on the left is searched for in the subroutine and the processing is continued. Bypassed
y3 y2 y1 x x1 x2 x3 xn x
Parameters X .... Input. Discrete points xj s in the x-direction. One-dimensional array of size nx. NX .... Input. Number of xj s, nx Y . Input. Discrete points yjs in the y-direction. One-dimensional array of size ny. NY .... Input. Number of yj s, ny FXY .... Input. Function value fij. Two-dimensional array as FXY (K, NY) fij needs to be assigned to the element FXY (I, J). K .... Input. Adjustable dimension for array FXY (K NX). ISW .... Input. ISW = 0 (INTEGER *4) must be assigned the first time the subroutine is called with the input data (xi , yj, fij) given. When a series of interpolated values need to be obtained by calling the subroutine repeatedly, the ISW value must not be changed from the second time on. Output. Information on (i,j) which satisfies xi vx < xi +1 and yi vy < yi +1. When the user starts interpolation for the newly given data (xi , yi , fij), he needs to set the
30000
Either of the followings occurred: 1 X(I) which satisfies X(I)X(I+1) exists 2 Y(J) which satisfies Y(J) Y (J+1) exists 3 NX<3 or NY < 3 4 K< NX 5 VX < (1) or VX > X(NX) 6 VY < Y(1) or VY > Y(NY) 7 ISW specification is wrong.
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... IABS, ABS, and MOD Notes The interpolating function used in the subroutine and its first order derivative are continuous in the area R={(x,y)|xl x xnx , yl y yny}, but its second order and the higher order derivative of the function may not be continuous. On the other hand, this interpolating function has a characteristic that irregular points or planes do not appear. To obtain an interpolated value, derivative and integral value for a bivariate function, with accuracy
91
AKMID
subroutines BIFD3 or BIFD1, which use an interpolation method by the spline function, should be used. When obtaining more than one interpolated value with the identical input data (xi , yj, fij), the subroutine is more effective if it is called with its input points continuous in the same grid area. (See Example.) In this case parameters ISW and VW must not be altered. The parameters IX and IY should satisfy X(IX) VX < X(IX +1) and Y(IY) VY < Y(IY+1), respectively. If not, IX and IY which satisfy these relationships are searched for to continue the processing. The parameter error conditions accompanied with ICON = 30000 are listed in Table ADMID-1. Of the error conditions, 1 to 4 are checked only when ISW = 0 is specified, i.e., when the subroutine is called the first time with the input data (xi , yj, fij) given. Example By inputting points (xi , yj) and their function values fij: i = 1, 2, ..., nx, j = 1, 2, ..., ny, interpolated values at points (vil, vjk), shown below are obtained. nx 121 and ny 101. vij = xi + (xi +1 xi ) (l/4) i = 1, 2, ..., nx 1, l = 0, 1, 2, 3 vjk = yj + (yj+1 yj) (k/2) j = 1, 2, ..., ny 1, k = 0, 1
C **EXAMPLE** DIMENSION X(121),Y(101),FXY(121,101), * VW(50),XV(4),YV(2),FV(4,2) READ(5,500) NX,NY READ(5,510) (X(I),I=1,NX) READ(5,510) (Y(J),J=1,NY) READ(5,510) ((FXY(I,J),I=1,NX),J=1,NY) WRITE(6,600) NX,NY WRITE(6,610) (I,X(I),I=1,NX) WRITE(6,620) (J,Y(J);J=1,NY) WRITE(6,630) ((I,J,FXY(I,J),I=1,NX), * J=1,NY) ISW=0 NX1=NX1 NY1=NY1 DO 40 I=1,NX1 HX=(X(I+1)X(I))*0.25 DO 10 IV=1,4 10 XV(IV)=X(I)+HX*FLOAT(IV1) DO 40 J=1,NY1 HY=(Y(J+1)Y(J))*0.5 DO 20 JV=1,2 20 YV(JV)=Y(J)+HY*FLOAT(JV1) DO 30 IV=1,4 DO 30 JV=1,2 30 CALL AKMID(X,NX,Y,NY,FXY,121,ISW, * XV(IV),I,YV(JV),J,FV(IV,JV), * VW,ICON) 40 WRITE(6,640) I,J,((IV,JV,FV(IV,JV),
IV=1,4),JV=1,2) STOP 500 FORMAT(2I6) 510 FORMAT(6F12.0) 600 FORMAT(1H1//10X,10HINPUT DATA,3X, * 3HNX=,I3,3X,3HNY=,I3/) 610 FORMAT(1H0,1HX/(6X,6(I6,E15.7))) 620 FORMAT(1H0,1HY/(6X,6(I6,E15.7))) 630 FORMAT(1H0,3HFXY/(6X,5(1H(,2I4, * E15.7, 1H)))) 640 FORMAT(1H0,9HAPP.VALUE,2I5/(6X, * 5(1H(,2I4,E15.7,1H)))) END
Method The subroutine obtains interpolated values based on the dual third degree two-dimensional quasi-Hermite interpolating function which is a direct extension of the one-dimensional quasi-Hermite interpolating function obtained by subroutine AKMIN. Dual third degree two-dimensional quasi-Hermite interpolating function. The interpolation function S (x, y) described hereafter is defined in the area R = {(x,y)|xl x xny , yl y yny} and satisfies the following condition: (a) S (x, y) is polynomial at most of dually degree three within each partial region Ri,j = {(x,y)|xi x < xi +1, yi y < yi +1} degree three within each partial region Ri,j = {(x,y)|xi x < xi +1, yi y < yi +1}. (b) S (x,y) C1,1,[R], that is, the following values exist and are all continuous on R: S(
, )
( x, y) =
+ S ( x, y) , x y = 0, 1, = 0, 1
(c) S ( , ) xi , y j = f ( , ) xi , y j ,
= 0, 1, = 0, 1, i = 1, 2,
, n ,
x
j = 1, 2,
, n
It has been proved that the function S(x, y) exists uniquely and that it can be expressed, in partial region Rij, as follows: S x , y = Si , j (s, t )
1 1
( )
= ai b j f ij( , ) p (s)q (t )
=0 =0
( , ) ( ) ( ) + f i+ q s p t + f i ,(j+,1 ) p (s)q (t ) 1, j ( , ) ( ) ( ) + f i+ q s q t 1, j +1
(4.1)
92
AKMID
q0 (t ) = 3t 2 2t 3 q1 (t ) = t (t 1)
2
p0 (t ) = 1 3t 2 + 2t 3 p1 (t ) = t (t 1)
2
used, the first order partial derivatives both in x- and ydirections are as follows:
(1,0 ) = wx 2 c23 + wx 3c33 f 33
f ij( , ) = f ( , ) xi , y j =
+ f ( xi , yi ) x y
( 0,1) = wy 2 d 32 + wy 3d 33 f 33
) (w
) (w
x2
+ wx 3
y2
+ wy 3
(4.3)
Eq. (4.1) requires function values and derivatives at the four points (xi , yj), (xi +1, yj), (xi , yj+1) and (xi +1, yj+1). Therefore, if the derivatives can be obtained (or approximated in some way) an interpolated value in the area Rij can be obtained by using Eq. (4.1). The S(x, y) given in Eq. (4.1) which can be obtained by using approximated derivatives is called the dual thrid degree piecewise two-dimensional quasi-Hermite interpolating function. Determination of derivatives f ij(1,0 ) , f ij( 0,1) and f ij(1,1) at a node point This subroutine uses the Akimas geometrical method to obtain these derivatives. It applies the method used by the one-dimensional quasi-Hermite interpolating function (in subroutine AKMN) to that two-dimensional as follows: As a preparatory step the following quatities should be defined. ai = xi +1 xi , bj = yj+1 yj cij = (fi +1,j fij) /ai dij = (fi,j+1 fij) /bj eij = (ci,j+1 cij) /bj = (di +1,j dij) /ai
f33(1,0) and f33(0,1) are expressed as weighted means about c and d, respectively. Based on the similar assumption, f33(1,1) is determined as doubly weighted means of e in the directions of x and y as follows. f 33
( 1,1)
{(w
x2
+ wx 3 ) wy 2 + wy 3
)}
(4.4)
(4.2)
Determination of derivatives on the boundary Assuming that this is similar to the one-dimensional quasi-Hermite interpolating function, the partial derivatives, fij(0,1), fij(1,0) and fij(1.1); i = 1, 2, nx 1 1, nx, j = 1, 2, ny 1, ny, on the boundary are obtained by calculating cij, dij and eij outside the area and after that by applying Eqs. (4.3) and (4.4) Fig. AKMID-3 illustrates the situation for i = j = 1. The points marked by o are those given by assuming the same method as for the one-dimensional quasi-Hermite interpolating function.
y3 d12 y2
For simplicity, consider a sequence of five points, x1, x2, x3, x4 and x5 in the x-direction and y1, y2, y3, y4, and y5 in the y-direction to obtain partial derivatives at the point (x3, y3). Fig. AKMID-2 illustrates the needed c s, d s and e s.
y5 x34 d 4 y4 e23 y3 c13 c23 e22 y2 d31 x1 x2 x3 x4 x5 Fig. AKMID-2 Determination of derivative at the point (x3, y3) y1 x33 d 4 e33 c33 d32 e32 c43
d11 y 1
The quatities, cij s, dij s and eij s outside the area can be obtained as follows:
Assuming that the same method as for the onedimensional quasi-Hermite interpolating function is 93
AKMID
c11 = 3c11 2c21 c01 = 2c11 c21 d11 = 3d11 2d12 d10 = 2d11 d12 e01 = 2e11 e21 e00 = 2e01 e02 (e02 = 2e12 e22) e10 = 2e11 e12
(4.5)
Thus, the partial derivatives at the point (x1, y1) can be obtained by applying Eqs. (4.3) and (4.4) after calculating the necessary c, d and e.
Calculation of interpolated values The interpolated value at the point (vx, vy) can be obtained by evaluating Six,iy(s, t) in Eq. (4.1) which is constructed by using the coordinate area numbers (ix, iy) to which the poit (xx, vy) belongs. The subroutine uses available partial derivatives, if any, obtained when called previously, and calculates the other needed derivatives, which are also stored in the work area and kept for later use. For further details, see Reference [54].
94
AKMIN
responding to i = 1 or i = n 1 in (1.1) may be employed, though they does not yield good precision. Example A quasi-Hermite interpolating polynomial is determined by inputting the number n of discrete points, discrete points xi and function values yi , i = 1, ..., n, so that the interpolated value at a certain point x = v in a certain interval [xk, xk+1] is determined. n 10.
C **EXAMPLE** DIMENSION X(I0),Y(10),C(9),D(9),E(9) READ(5,500) N READ(5,510) (X(I),Y(I),I=1,N) CALL AKMIN(X,Y,N,C,D,E,ICON) WRITE(6,600) ICON IF (ICON.NE.0) STOP READ(5,500) K,V XX=VX(K) YY=Y(K)+(C(K)+(D(K)+E(K)*XX)*XX)*XX N1=N1 WRITE(6,610) WRITE(6,620(I,C(I),I,D(I),I,E(I),I=1,N1) WRITE(6,630)K,V,YY STOP 500 FORMAT(I5,F10.0) 510 FORMAT(2F10.0) 600 FORMAT(1H0,10X, * 19HRESULTANT CONDITION,6H CODE=,I5//) 610 FORMAT(1H0,10X, * 22HRESULTANT COEFFICIENTS//) 620 FORMAT(1H,15X,2HC(,I2,2H)=,E15.7, * 5X,2HD(,I2,2H)=,E15.7, * 5X,2HE(,I2,2H)=,E15.7) 630 FORMAT(1H0,10X,2(1H),5HRANGE,2(1H), * 5X,2(1H),13HDESIRED POINT,2(1H), * 5X,2(1H),18HINTERPOLATED VALUE, * 2(1H)//13X,I2,2X,2(8X,E15.7)) END
Function Given function values yi = f(x), i = 1, ..., n for discrete points x1, x2, ..., xn (x1 < x2 < ... < xn), this subroutine obtains the quasi-Hermite interpolating polynomial of degree 3, represended as (1.1) below. n 3 S ( x ) == yi + ci ( x xi ) + d i ( x xi ) + ei ( x x i ) xi x xi+1 , i = 1, 2, , n 1
2 3
(1.1)
Parameters X .... Input. Discrete points xi . One-dimensional array of size n. Y .... Input. Function values yi . One-dimensional array of size n. N .... Input. Number n of discrete points. C .... Output. Coefficient ci , in (1.1). One-dimensional array of size n 1. D .... Output. Coefficient di in (1.1). One-dimensional array of size n 1. E .... Output. Coefficient ei in (1.1). One-dimensional array of size n 1. ICON .... Output. Condition code. See Table AKMIN1.
Table AKMIN-1 Code 0 30000 Meaning No error n < 3 or xi xi+1 Processing Bypassed
Comments on use Subprograms used SSL II .... MGSSL FORTRAN basic function ... ABS Notes The interpolating function obtained by this subroutine is characterized by the absence of unnatural deviation, and thus produces curves close to those manually drawn. However, the derivatives of this function in interval (xl, xn) are continuous up to the first degree, but discontinuous above the second and higher degrees. If f (x) is a quadratic polynomial and xi , i = 1, ..., n are given at equal intervals, then the resultant interpolating function represents f (x) itself, provided there are no calculation errors. If interpolation should be required outside the interval (n < x1 or x > xn), the polynomials cor-
Method Given function values yi = f (xi ), i = 1, ..., n, for discrete points x1, x2, ..., xn (x1 < x2 < ....< xn), lets consider the determination of the interpolating function represented in (1.1). (1.1) represents a different cubic polynomial for each interval [xi , xi +1]. S (x) represented in (1.1) is piecewisely expressed as (4.1). S ( x ) = Si ( x ) = yi + ci ( x xi ) + di ( x xi ) + ei ( x xi )
2 3
xi x xi+1 , i = 1,
, n 1
(4.1)
Each Si (x) is determined by the following procedure: (a) The first order derivatives at two points xi and xi +1 are approximated. (They are taken as ti and ti +1).
95
AKMIN
( ) S ( x ) = t S (x ) = y S (x ) = y
Si xi = t i
i i +1 i i i i +1
i +1 i i +1
respectively designated as m1, m2, m3, and m4. If the slope of the curve at point 3 is t, t is determined so that it will approach m2 when m1 approaches m2, or will approach m3 when m4 approaches m3. One sufficient condition for satisfying this is given in (4.3.). (4.2) 2C 4D = CA DB (4.4) is derived from the relationship in (4.3)
(4.3)
The interpolating function thus obtained is called a quasi-Hermite interpolating polynomial. This subroutine features the geometric approximation method for first order derivatives in (a). In that sense, the interpolating function is hereinafter called a curve and the first order derivative the slope of the curve. Determination of the slope of a curve at each discrete point The slope of a curve at each discrete point is locally determined using five points; the discrete point itself and two on each side. Now let us determine the slope of the curve at point 3 from the five consecutive points 1 through 5. (See Fig. AKMIN-1)
5 1
t=
1 2
(4.4)
t obtained from (4.4) has the following preferable characteristics: (a) When m1 = m2 , m3 m4 , m2 m3 , t = m1 = m2 (b) When m3 = m4 , m1 m2 , m4 m2 , t = m3 = m4 (4.5) (c) When m2 = m3 , m1 m4 , m3 m4 , t = m2 = m3 However, (4.4) has the following drawbacks: (d) when w2 = w3 = 0, t is undifinite (e) when m2 = m4 , m3 m1 , m4 m3 , t = m2 or when m1 = m3 , m2 m4 , m3 m2 , t = m3
4 2 3 C A B D
(4.6)
This subroutine determines t based on (4.7), not on (4.4), to avoid these drawbacks. when m1 m2 or m3 m4 t= m4 m3 m2 + m4 m3 + m2 m1 m3 m2 m1 (4.7)
Fig. AKMIN-1
when m1 = m2 and m3 = m4 In Fig. AKMIN-1, the intersection of the extensions of segments 1 2 and 3 4 are taken as A and that the intersection of the extensions of segments 2 3 and 4 5 as B. Also, the intersections of the tangent line at point 3 of the curve and segments 2 A and 4 B are taken as C and D, respectively. The slopes of segments 1 2, 2 3, 3 4 and 4 5 are (4.7) satisfies the requirements of the characteristics (4.5) Determination of slope at both end points At points located at both ends (x1, y1), (x2, y2), (xn1, yn1), and (xn, yn), the following virtual discrete points are adopted to determine their slope. Take the left end for example, the five points shown in Fig. AKMIN-2 are set so that the slope t1 of the curve at (x1, y1) can be determined.
96
AKMIN
y 1 y3
If the slope of segments (x1, y1) and (x0,y0) is m1 and the slopes of the segments extending to the right are m2, m3, and m4, respectively, the following equations are obtained from (4.9): m2 = 2 m3 m4, m1 = 3 m3 2 m4 (4.10)
y0
y2 y1
x0 x 1 Fig. AKMIN-2
x1
x2
x3
The slope t1 at (x1, y1) is determined by applying these m1, m2, m3 and m4 to the method in a. In the determination of t2 at point (x2, y2), the five points (x0, y0), (x1, y1), (x2, y2), (x3, y3) and (x4, x4) are used. The slope tn-1, tn at right-end points (xn-1, yn-1) and (xn, yn) are similarly determined by assuming (xn+1, yn+1) and (xn+2, yn+2). Determination of curves The coefficient of Si (x) in (4.1), as determined by the conditions of (4.2), is represented in (4.11). ci = ti
The two points (x1, y1) and (x0, y0) are virtual points. x1 and x0 are determined from (4.8). x3 x1 = x2 x0 = x1 x1 (4.8)
y-1 and y0 are assumed to be the values obtained by evaluating a quadratic polynomial passing (x1, x1), (x2, y2) and (x3, y3) at x1 and x0. The five points satisfy the conditions of (4.9). y3 y2 y2 y1 y2 y1 = x3 x2 x2 x1 x2 x1 y y0 = 1 x1 x0 y1 y0 x1 x0 y0 y 1 x0 x 1
di = 3 ( yi +1 yi ) ( xi +1 xi ) 2t i t i +1 ei = t i + t i +1 2 ( yi +1 yi ) ( xi +1 xi )
(x (x
i +1
xi ) xi )
(4.11)
i +1
97
ALU
Function An n n nonsingular real matrix A is LU-decomposed using the Crouts method. PA = LU (1.1)
IP is a one-dimensional array of size n. (Refer to Notes.) IS ... Output. Information for obtaining the determinant of matrix A. If the n elements of the calculated diagonal of array A are multiplied by IS, the determinant is obtained. VW .... Work area. VW is one-dimensional array of size n. ICON .... Output. Condition code. Refer to Table ALU-1.
Table ALU-1 Condition codes Code 0 20000 Meaning No error Either all of the elements of some row were zero or the pivot became relatively zero. It is highly probable that the matrix is singular. K<N, N<1 or EPSZ<0.0 Processing Discontinued
P is the permutation matrix which performs the row exchanges required in partial pivoting, L is a lower triangular matrix, and U is a unit upper triangular matrix. n 1. Parameters A .... Input. Matrix A Output. Matrices L and U. Refer to Fig. ALU-1, A is a two-dimensional array, A (K, N).
Unit upper triangular matrix U 1 u12 u13 1 u23 u1n u2n 1 un 1 Arrary A
30000
Bypassed
Comments on use Subprograms used SSL II .... AMACH, MGSSL FORTRAN basic functions ... ABS Notes If EPSZ is set to 10-s, this value has the following meaning. In LU-decomposition, if the loss of over s significant digits occurred for the pivot, the LUdecomposition should be discontinued with ICON = 20000 regarding the pivot to be relatively zero. Let u be the unit round-off, and the standard value of EPSZ is 16 u. If the processing is to proceed at a low pivot value, EPSZ will be given the minimum value, but the result is not always guaranteed. The transposition vector corresponds to the permutation matrix P of LU decomposition in partial pivoting. In this subroutine, the elements of the array A are actually exchanged in partial pivoting. In the J th stage (J = 1, ..., n) of decomposition, if the Ith row (I J) has been selected as the pivotal row the elements of the Ith row and the elements of the Jth row are exchanged. Then, in order to record the history of this exchange, I is stored in IP (J). A system of linear equations can be solved by calling subroutine LUX following this subroutine. However, instead of these subroutines, subroutine LAX can be normally called to solve such equations in one step. Example An n n matrix is input and LU-decomposition is computed. n 100.
ln
Lower triangular matrix L l11 l21 l22 l31 l32 ln1n1 ln1 ln2 lnn1 lnn
ln1 ln2
IP ....
Input. Adjustable dimension of array A ( N) Input. Order n of matrix A Input. Tolerance for relative zero test of pivots in decomposition process of A ( 0.0) When EPSZ is 0.0, a standard value is used. (Refer to Notes.) Output. The transposition vector which indicates the history of row exchanging that occurred in partial pivoting.
98
ALU
**EXAMPLE** DIMENSION A(100,100),VW(100),IP(100) 10 READ(5,500)N IF(N.EQ.0)STOP READ(5,510) ((A(I,J),I=1,N),J=1,N) WRITE(6,600)N,((I,J,A(I,J),J=1,N),I=1,N) CALL ALU(A,100,N,0.0,IP,IS,VW,ICON) WRITE(6,610)ICON IF(ICON .GE.20000)GOTO 10 DET=IS DO 20 I=1,N DET=DETA(I,I) 20 CONTINUE WRITE(6,620) (I,IP(I),I=1,N) WRITE(6,630) ((I,J,A(I,J),J=1,N),I=1, N) WRITE(6,640) DET GOTO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(///10X,18H INPUT MATRIX * /12X,6HORDER=,I5//(10X,4(1H(,I3,1H,, * I3,1H),E16.8))) 610 FORMAT(1H0,10X,16HCONDITION CODE =,I5) 620 FORMAT(1H0,10X,20HTRANSPOSITION VECTOR * /(10X,10(1H(,I3,1H),I5))) 630 FORMAT(1H0,10X,15HOUTPUT MATRICES * /(10X,4(1H(,I3,1H,,I3,1H),E16.8))) 640 FORMAT(1H0,10X, * 27HDETERMINANT OF THE MATRIX =,E16.8) END
P is the permutation matrix which performs the row exchanging required in partial pivoting. The Crouts method is one method to obtain the elements of L and U. This subroutine obtains values in the jth column of L and jth column of U in the order (j = 1, ..., n) using the following equations.
i 1 uij = a ij lik u kj lii , i = 1, ... , j 1 k =1
(4.2) (4.3)
j 1
where, A = (aij), L = (lij) and U =(uij). Actually using partial pivoting, rows are exchanged. The Crounts method is a variation of the Gaussian elimination method. Both perform the same calculation, but the calculation sequence is different. With the Crouts method, elements of L and U are calculated at the same time using equations (4.2) and (4.3). By increasing the precision of the inner products in this step, the effects of rounding errors are minimized. Partial pivoting When matrix A is given as . 0.0 10 A= 10 . 0 .0 Though the matrix is numerically stable, it can not be LU decomposed. In this state, even if a matrix is numerically stable large errors would occur if LU decomposition were directly computed. So in this subroutine, to avoid such errors partial pivoting with row equilibration is adopted for decomposition. For more information, see References [1],[3], and [4].
Method Crouts method Generally, in exchanging rows using partial pivoting, an n n regular real matrix A can be decomposed into the product of a lower triangular matrix L and a unit upper triangular matrix U. PA = LU (4.1)
99
AQC8
Table AQC8-1 Condition codes Code 0 10000 Meaning No error The desired accuracy was not attained due to roundingoff errors. Processing Approximation obtained so far is output in S. The accuracy is the maximum attainable. Processing stops. S is the approximation obtained so far, but is not accurate. Processing stops.
Function Given a function f(x) and constants a, b, a and r this subroutine obtains an approximation S which satisfies
S a f (x)dx max b
a, r
20000
a f (x)dx
(1.1)
30000
The desired accuracy was not attained though the number of integrand evaluations has reached the upper limit. One of the followings occurred. 1 EPSA < 0.0 2 EPSR < 0.0 3 NMIN < 0 4 NMAX < NMIN
by a modified Clenshaw-Curtis rule which increases a fixed number of abscissas at a time. Parameters A .... Input. Lower limit a of the interval. B .... Input. Upper limit b of the interval. FUN .. Input. The name of the function subprogram which evaluates the integrand f(x) (see the example). EPSA .. Input. The absolute error tolerance a ( 0.0) for the integral. EPSR .. Input. The relative error tolerance r ( 0.0) for the integral. NMIN .. Input. Upper limit on the number of function evaluation ( 0). A proper value is 15. NMAX .. Input. Lower limit on the number of function evaluations (NMAX NMIN) A proper value is 511. (A higher value, If specified, is interpreted as 511.) (See Comments on use.) S ... Output. An approximation (see Comments on use). ERR .... Output. An estimate of the absolute error in the approximation. N .... Output. The number of function evaluations actually performed. ICON .... Output. Condition code. See Table AQC8-1. Comments on use Subprograms used SSL II ... MGSSL, AMACH FORTRAN basic functions ... ABS, AMAX1, FLOAT, MAX0, MIN0, SQRT Notes The function subprogram associated with parameter FUN must be defined as a subprogram whose argument is only the integration variable. Its function name must be declared as EXTERNAL in the calling program. If the integrand includes auxiliary variables, they must be declared in the COMMON statement for the purpose of communicating
with the main program. (See the example.) When this subroutine is called many times, 511 constants (Table of abscissas, weights for the integration formula) are determined only on the first call, and this computation is bypassed on subsequent calls. Thus, the computation time is shortened. This subroutine works most successfully when the integrand f(x) is a oscillatory type function. For a smooth function, it is best in that it requires less evaluations of f(x) than subroutines AQN9 and AQE. For a function which contains singularity points, subroutine AQE is suitable if the singularity points are only on the end point of the integration interval and subroutine AGN9 for a function whose singularity points are between end points, or for a peak type function. Parameters NMIN and NMAX must be specified considering that this subroutine limits the number of evaluations of integrand f(x) as NMIN Number of evaluation times NMAX This means that f(x) is evaluated at least NMIN times and not more than NMAX times regardless of the result of the convergence test. When a value of S that satisfies the expression (1.1) within NMAX evaluations cannot be obtained, processing stops with ICON code 20000. If the value of NMAX is less than 15, a default of 15 is used. Accuracy of the approximation S is obtained as follows. This subroutine obtains S to satisfy the expression (1.1) when constants a and r are given. Thus r=0 means to obtain the approximation with its absolute error within a, Similarly, a=0 means to obtain it with its relative error within r.
100
AQC8
This purpose is sometimes obstructed by unexpected characteristics of the function or unexpected value of a or r. For example, when a or r is extremely small in comparison with arithmetic precision in function evaluation, the effect of round-off error becomes greater, so it is no use to continue the computation, even though the number of integrand evaluation has not reached the upper limit. In this case, processing stops with the code 10000 in ICON. At this time, the accuracy of S becomes the attainable limit for computer used. The approximation sometimes does not converge within NMAX evaluations. In this case, S is an approximation obtained so far, and is not accurate and indicated by ICON code 20000. To determine the accuracy of integration, this subroutine always puts out an estimate of absolute error in parameter ERR, as well as the approximation S. Example Increasing the value of auxiliary variable p from 0.1 to 0.9 with increment 0.1, this example computes the integral
c **EXAMPLE** COMMON P EXTERNAL FUN A=-1.0 B=1.0 EPSA=1.0E-5 EPSR=1.0E-5 NMIN=15 NMAX=511 DO 10 I=1,10 P=FLOAT(I) CALL AQC8(A,B,FUN,EPSA,EPSR,NMIN, * NMAX,S,ERR,N,ICON) 10 WRITE(6,600) P,ICON,S,ERR,N STOP 600 FORMAT(1H ,30X,2HP=,F6.1,5X, * 5HICON=,I5,5X,2HS=,E15.7,5X, * 4HERR=,E15.7,5X,2HN=,I5) END FUNCTION FUN(X) COMMON P FUN=COS(P*X) RETURN END
For the purpose of avoiding this as much as possible, this subroutine increases 8 points at a time. Moreover, the costs of computations is reduced by using the Fast Fourier Transform algorithm (FFT). Clenshaw-Curtis integration which increases a fixed number of points at a time b The given integral a f ( x ) dx may be transformed by linear transformation: x= to
ba 1 ba a + b f t+ dt 2 1 2 2
ba a+b t+ 2 2
For simplicity, let's consider the integration(4.1) over the interval [-1,1] in what follows.
I=
1 f (x)dx
(4.1)
The original Clenshaw-Curtis rule is as follows. By an interpolation polynomial (i.e., Chebyshev interpolation polynomial), whose interpolating points are the series of points (Fig. AQC8-1) made by projecting the series of points equally-sectioned on the unit half circle over the interval [-1,1], f(x) is approximated, and this is integrated term by term to obtain the integral approximation. The number of data points will increase doubly to meet the required accuracy. This method sometimes wasted data points. The method which increases a fixed number of data points at a time is explained next. First, based on Van der Corput series uniformly distributed on (0,1), the series of points {j}(j=1,2,3,...) are made by the recurrence relation
1 = 1 4 , 2 j = j 2 , 2 j +1 = 2 j + 1 2
Method This subroutine uses an extended Clenshaw-Curtis integration method which increases a fixed number of abscissas (8 points) at a time. The original ClenshawCurtis rule sometimes wastes abscissas because it increases them doubly even when the desired accuracy could be attained by adding only a few abscissas.
( j = 1, 2, 3, )
The series of points on a unit circle {exp(2ij)} is symmetric to the origin and unsymmetric to the real axis (Fig. AQC8-2). Since those points {xj=cos2j for j=1,2,3,... } form the Chebyshev Distribution on (-1,1), they are used as data points (Fig. AQC8-2). As shown in Fig. AQC8-2, seven points are used first as abscissas. After that, eight points are added at a time repeatedly. When the total amount of abscissas reaches 2n-1, their locations match those of points which are made by projecting biseetional points placed on the unit half circle to the open interval(-1,1). Thus, they are regarded as a series of data points as used by the Clenshaw-Curtis rule on the open interval. The descriptions for forming the interpolation 101
AQC8
(4.2)
subject to
= 2 l (T8 ( x ) x k ),
k =1
(l 1)
x5
x3
x6
x1
x7
x2
x4
The notation ' on the right-hand side of (4.2) means to sum up the subsequent terms with the first term multiplied by 1/2. Coefficients. A-1,k and Aj,k of polynomial Pl(x) are determined by the interpolating conditions. First, using the first seven points of {cosj / 8}( j=1,2,...,7), A-l,k(k=1,2,...,7) is given as A1,k =
polynomials are given next. From the characteristics of j, the sequence {xj}}( j=1,2,...,7) matches {cos j / 8}. When N-th degree Chebyshev polynomial is expressed as TN (x) x8k+j( j=0, 1, ..., 7) corresponds to eight roots of T8(x)xk=0 (k=1,2,). Using these characteristics, seven points at firrst, eight points at each subsequent time, are added to make the series of interpolation polynomial Pl(x). In the expressions below, Po(x) is the interpolation which uses the first 7 points, and Pl(x) is the one which uses 8l+7 points as the result of adding 8 points l times. With a change of variable x=cos , the expression I=
1 f x 1
Next, using Aj,k (-1 i l-1) which is known, Al,k (l 0) which appears in Pl+1(cos) are obtained. At this stage, added data points are roots of T8(x)-xl+1=0, that is, cos jl+1 (jl+1 =2) 8( j+l+1) ( j=0,1,2,...,7). So, the interpolating conditions at this stage, f cos lj+1 sin lj+1 =
l
k =1
(0
j 7)
k=0
( ) dx = 0 f (cos ) sin d
are used to determine Al,k. To the left-hand side of (4.3) a cosine transformation including parameter l+1 is applied. f cos lj +1 sin lj +1 =
k =0
ak cos k lj +1
, (0 j 7)
102
AQC8
By regarding this as a system of linear equations with ak's being unknowns and by solving them we have ak = 2 7 f cos jl+1 sin jl+1 cos jl+1 8 j =0
(Only terms with odd value of k are summed.) where, the weight coefficient Wi ,k is defined as
Wi ,k =
(4.6)
In actual computations real FFT algorithm is used. Then, from (4.3), 1 ak = A cos 2 l+1 A1,k sin 2 l+1 1,8 k + sin 2 l+1 i cos 2 l+1 Ai ,k
i =0 l
2 1,k
0 sin 2
n+3
cos kd =
2n 4n
+3
+4
k2
(0k7) where, A-1,0=A-1,8=0. From 0(cos21)=1 when l=0, the value A0,k is obtained easily. For l1, letting l=m+2
n
Using this W2n-l,k as a starting value, the required N(=2m4) members of Wi,k(0 i 2m-1,k=1,3,5,7) are computed by the following recurrence formula: W2n-1+2 n -j+1 s+2 n -j,k=W2n-1+2n-j+1 s,2n-j.8+k +W2n-1+2n-j+1 s,2n1 8-k j 2cos22 +2sW2n-1+2n-j+1 s,k , n=1,2,...,m 1 , 1 j n, 0 s < 2j-1-1, 0 k 2n-j8 1(k is an odd number).
N N N N N
(0 m < 2 )
n
(4.7)
l+1)=1
To obtain these weight coefficients, N /2(log2N 2)+4 multiplications and divisions are required. Computing procedures Procedure 1 ... Initialization This procedure computes m=(a+b)/, r =(b a) /2, which are required to transform the integration interval [a,b] to [-1,1]. All the initializations required are performed here. Procedure 2 ... Determination of abscissas and weights In this subroutine the number of abscissas is limited to 511 (=29-1). Since points {xj}={cos2j ( j=1,2,...,511) are distributed symmetrically to the origin, a table of only 256(=28){cosj}( j=1,2,...,256) is needed. The table is generated by the recurrence formula. Also the weights {Wi ,2k+1}(0 i 63, 0 k 3) are computed by the recurrence formula (4.7) and stored in a vector. This procedure is performed only on the first call to the subroutine, but bypassed on the subsequent calls. Procedure 3 ... Integral approximation based on initial 7 points Integral approximation I0 is obtained Integral approximation I0 is obtained by multiplying the weights determined in procedure 2 and A-1,2k+1(0 k 3), which are obtained by using real FFT algorithm to data points cos j/8( j=1,2,...,7). Procedure 4 ... Trigonometric function evaluations Using data point table {cosj}, values of trigonometric functions cos2l+1, sin2l+1, sinl+1 to be required in procedure 5 are evaluated.
Al,k can be computed as shown below. Letting first: Bm+1 = a k ( A1,8 k cos 2 l +1 A1, k ) sin 2 l +1 sin 2 l +1 i (cos 2 l +1 ) Ai, k
i =0 2n 2
(4.4)
then computing each Bm-i 1 sequentially by Bm-i = (Bm+1-i A2n+i-i) / (cos2l+1 - cos22n+i ) i=0,1,2,...,m (4.5) And Al,k's are computed as Al,k=B0 Comparing this to that of Newton difference quotient formula, calculation in (4.4) and (4.5) are more stable because the number of divisions are reduced from l+2 to m+2. Using interpolation polynominal Pl+1(cos) computed so far, the integral approximation Il+1 is obtained by termwise integration.
I i +1 =
0 Pl+1(cos ) sind
7 k =0
= A1,k
2 l 7 + 'Ai ,k Wi ,k k i =1 k = 0
103
AQC8
Procedure 5 ... ak and Al,k After evaluating function values at the added 8 data points, a2k+1(0 k 3) are obtained by using real FFT to 8 terms. And Al,2k+1(0 k 3) are obtained based on (4.4) - (4.6). Procedure 6 ... Integration and convergence test Previous integral approximation Il(l 0) is added with 3 Al ,2 k +1Wl ,2 k +1 to obtain the updated integral
k =0
1
Fig. AQC8-3
approximation Il+1. Next, an estimate el+1 of truncation error in Il+1 is computed, and the convergence test is done to el+1 as well as to el. After the convergence test for el the computation stops if both tests are successful, otherwise goes back to procedure 4 with l increased by 1. Error estimation Letting Rl(x) denote the error when f(x) is approximated by an interpolation polynomial Pl(x) mentioned above it can be seen that f ( x ) = Pl ( x) + Rl ( x) = A1,k U k 1 ( x ) + U 7 ( x ) i ( T8 ( x ))
7 k =1 i =0 l 1
Tk (x )dx
(z x )
=
2
z z 2 1
k
1 x
z2 1
(k = odd number)
' Ai ,k Tk ( x ) + U 7 ( x ) l (T8 ( x ))
7
( ) 2 8 l+7 f [x , x1 , x 2 ,
k =0
If f(z) is a rational function having a poles at point zm where m=1,2,...M), the following is established: Cl ,k =
* 2 M U k zm Resf zm m=1 U z T z 7 8 m l m
, x
8 l +7
The coefficient 2-(8l+7) is used in order to match the conventional error term expression with the divided difference. Uk(x) is the k-th degree Chebyshev polynomial of the second kind defined as follows: Uk(x)=sin(k+1) / sin , x=cos Truncation error El for the approximation Il is expressed as
Ei =
( ) ( ) ( ) ( ( ))
( )
2 1 > 1 , rm = zm + zm
as far as zm is not too close to the interval [ 1,1] on a real axis, Cl ,1 > Cl ,k , (k3)
(8 l + 7 )
f x, x1 ,
, x ]dx
8l + 7
holds. The truncation error can be estimated by E l Cl ,1 Wl ,1 Al 1, 7 + Al 1,5 Wl ,1 el Al1,7 and Al1,5 are used instead of Cl ,1 , the value of which cannot be really evaluated. If zm is very close to [-1,1] or f (p)(x), derivative of order p(where p1) becomes discontinuous on [ 1,1], the error estimation above is no longer valid. To cope with this situation, take the following procedures. If Aj,k decreases rapidly, the error for l2n-1 can be estimated well by I 2n 1 I 2n 11
The divided difference can be expressed by the form of integration and also expanded to a Chebyshev series as follows:
8l + 7 2 ( ) f x , x1 ,
, x ] = 21 i C
8l + 7
f (z )dz
Figure AQC8-3 shows the integration path c, which is a simple closed curve.
104
AQC8
1 = max a , r 1 f ( x )dx ,
If the following condition is satisfied, el is used as an error estimation in 2 -1 l 2 otherwise the following is used instead.
n n+1
1;
el+1( or e'l+1) < Il+1 is output in parameter S as an approximation to the integral. In parameter ERR, el+1(ICON = 0) is put out if el+1 , or (ICON=10000) if el+1 < . I l substitutes for
e' l el I 2n 1 I 2n11 e2n 11 Convergence criterion As well as a truncation error, the integral approximation has a computation error. This subroutine estimates the upper bound of the computation error as
1 f (x)dx
which is used in .
= u(l + 1) f
= max j f x j .
( )
This assumption is reasonable in actual use because abscissas form the Chebysev distribution and FFT is used. Setting a tolerance for convergence test as
105
AQE
G23-11-0401 AQE,DAQE
Integration of a function by double exponential formula CALL AQE (A,B,FUN,EPSA,EPSR,NMIN,NMAX,S, ERR,N,ICON)
Table AQE-1 Condition codes Code 0 10000 Meaning No error The desired accuracy is not attained due to rounding-off errors. Processing Approximation obtained so far is output in S. The accuracy has reached the attainable limit. Processing continues with a relaxed tolerance. Processing stops. S is the approximation obtained so far, but is not accurate.
Function Given a function f(x) and constants a,b,a,r this subroutine obtains an approximation S that satisfies
S , a f (x )dx a f (x)dx max
a r
(1.1)
20000
by Takahashi-Mori's double exponential formula. Parameters A .... Input. Lower limit a of the interval. B .... Input. Upper limit b of the interval FUN .... Input. The name of the function subprogram which evaluates the integrand f(x) (see the example). EPSA .. Input. The absolute error tolerance a(0.0) for the integral. EPSR .. Input. The relative error tolerance r(0.0) for the integral. NMIN .. Input. Lower limit on the number of function evaluations. A proper value is 20. NMAX .. Input. Upper limit on the number of function evaluations. (NMAXNMIN) A proper value is 641 (a higher value, if specified, is interpreted as 641). S .... Output. An approximation to the integral. (See "Comments on use" and "Notes".) ERR .. An estimate of the absolute error in the approximation. N .... Output. The number of function evaluations actually performed. ICON .. Output. Condition code. See Table AQE-1. Comments on use Subprograms used SSL II... MGSSL, AMACH, AFMIN FORTRAN basic functions... MAX0, AMAX1,AMIN1, ABS, FLOAT, EXP, COSH, SINH Notes The function subprogram associated with parameter FUN must be defined as a subprogram whose argument is only the integration variable. Its function name must be declared as EXTERNAL in a calling program. If the integrand includes auxiliary variables, they must be declared in the COMMON statement for the purpose of communicating with the calling program. When this subroutine is called many times, 641 constants (table of abscissas and weights for the
1,2,3 at the place of 1000 mean that the function value increases steeply near the upper, lower, or both limits of the interval respectively The desired accuracy is not attained though the number of integrand evaluation has reached the upper limit
25000
After the occurrence of any even of code 11000 - 13000, the number of integrand evaluations has reached the upper limit. The table for abscissas(i.e. work area) has been exhausted.
30000
One of the followings occurred: 1 EPSA < 0.0 2 EPSR < 0.0 3 NMIN < 0 4 NMAX < NMIN
Processing stops. S is an approximation by using the smallest stepsize allowed in this subroutine. Processing stops.
integration formula) are determined only on the first call, and this computation is bypassed on subsequent calls. Thus, the computation time is shortened. This subroutine works most successfully when the integrand f (x) changes rapidly in the neighborhood of endpoints of the interval. Therefore, when f(x) has an algebraic or logarithmic singularity only at endpoint(s), the subroutine should be used with first priority. When f(x) has interior singularities, the user can also use the subroutine provided that the subroutine is applied to each of subintervals into which the original interval is divided at the singularity points, or he can use subroutine AQN9 directly for the original interval. Subroutine AQN9 is suitable also for peak type functions, and subroutine AQC8 for smooth functions or oscillatory functions. This subroutine does not evaluate the function at both endpoints. A function value ( f(x) ) of infinity is allowed at the end points, but not allowed between them. Parameters NMIN and NMAX must be specified considering that this subroutine limits the number of evaluations of integrand f(x) as
106
AQE
NMIN Number of evaluations NMAX This means that f(x) is evaluated at least NMIN times, but less than NMAX times, regardless of the result of the convergence test. When a value S that satisfies expression (1.1) is not obtained within NMAX evaluations, processing stops with ICON code 20000 23000. Accuracy of the integral approximation S. The subroutine tries to obtain an approximation S which hopely satisfies (1.1) when a and r are given. a = 0 means to obtain the approximation with its absolute error within r. Sumilarly, a=0 means to obtain it with its relative error within r. This purpose is sometimes obstructed by unexpected characteristics of the function, or an unexpected value of a or r. For example, when a or r is extremely small in comparison with arithmetic precision in function evaluations, the effect of roundingoff errors becomes greater, so it is no use to continue the computation even though the number of integrand evaluation has not reached the upper limit. In this case, the accuracy of S becomes the attainable limit for the computer used. The approximation sometimes does not converge within NMAX evaluations. In this case, S is an approximation obtained so far, and is not accurate. This is indicated by ICON within the code range 20000 - 23000. In addition, ICON is set to 25000 when the approximation does not converge though the smallest step-size defined in this subroutine is used. To determine the accuracy of integration, this subroutine always puts out an estimate of its absolute error in parameter ERR, as well as the integral approximation S. An alternative definition of function for avoiding numerical cancellation. For example, the integrand in the following integral has singularities at end points of x = 1,3,
3 dx I= 1 x(3 x )1 4 (x 1)3 4
Letting AA = min(a,b), and BB = max(a,b), when AA x <(AA+BB) / 2, X(2)=AA x when (AA+BB) / 2 x BB, X(2)=BB x In other words X(2) denotes the distance from either of the end points. The user can write his function using X(2) as follows: f ( AA X(2)) when X(2) < 0.0 f ( x) = f ( BB X(2)) when X(2) 0.0 The user can select either of X(1) or X(2) (See example). Example Two integrals
I1 =
1 dx x
, I2 =
1 x(3 x) (x 1)
dx
14
34
are computed. The integrand in I1 is defined in the function subprogram FUN1 and that in I3 is defined in FUN2 respectively. FUN2 uses the technique described in Note.
C **EXAMPLE** EXTERNAL FUN A=-1.0 B=1.0 EPSA=1.0E-5 EPSR=0.0 NMIN=20 NMAX=641 CALL AQE(A,B,FUN,EPSA,EPSR,NMIN, * NMAX,S,ERR,N,ICON) WRITE(6,600) ICON,S,ERR,N STOP 600 FORMAT(1H ,30X,5HICON=,I5,5X, * 2HS=,E15.7,5X,4HERR=,E15.7, * 5X,2HN=,I5) END FUNCTION FUN(X) P=(1.0+X)*(1.0-X) FUN=0.0 IF(P.GT.0.0) FUN=1.0/SQRT(P) RETURN END
and the function value diverges at that points. There, the integrand makes a great contribution to the integral. So, the function values near the end points must be accurately computed. Unfortunately, the function values cannot be accurately computed there since cancellation occurs in computing (3.0 - X) and X-1.0). This subroutine allows the user to describe the integrand in another form by variable transformation so that cancellation can be avoided. Parameters in subprograms are specified as follows: FUNCTION FUN(X) where, X... Input. One dimensional array of size 2. X(1) corresponds to integration variable x and X(2) is defined depending upon the value of integration variable x as follows:
Method This subroutine uses the automatic integration method based on Takahashi-Mori's double exponential formula. The principle of this method is given first, and next the computing procedures in this subroutine. Double exponential formula The given integral
a f (x)dx
may be transformed by
107
AQE
x= into
ba a+b t+ 2 2
As the transformation which enable the double exponential decay such as (4.5) to happen, this subroutine takes the following one. 3 x = (t ) = tanh sinh(t ) 2 3 ' (t ) = cosh(t ) cosh sinh(t ) 2
2
ba 1 ba a + b f t+ dt 2 1 2 2
(4.6)
For simplicity, let's consider the integration (4.1) over the finite interval [-1,1].
1 I= f (x )dx 1
Computing procedure Procedure 1 ... Initialization To transform the finite interval [a, b] to [-1,1], determine the constant. r=(b a)/2 All the initialization required are done in this procedure. Procedure 2 ... Determines the upper and lower limits of the infinite summation used to approximate the infinite summation (4.4). A very approximate integral S' is obtained. Procedure 3 ... By the summation of the finite number of products, approximations S(h), S(h/2), S(h/4)... for Ih, Ih/2, Ih/4,..., are computed by bisectioning the step-size, until it converges. Procedure 4 ... Sets values in S, ERR and ICON. Convergence criterion If a step-size h used in the equally spaced trapezoidal rule is sufficiently small, it is proved analytically that the error Ih = I Ih can be expressed
(4.1)
On condition that f(x) is analytical in the open interval (-1,1), it is allowed to have singularities at x=1 such as (1 x) (1 + x) , 1 <, By a variable transformation, x = (t) (4.2)
the interval [-1,1] is transformed to ( , ) and consequently the integral (4.1) is transformed to
I=
(4.3)
Remembering that the trapezoidal rule is best for integrals over the infinite interval, the following integration formula is obtained by applying that rule with step-size h to (4.3). I h = h f (nh) ' (nh)
n=
(4.4)
I h 2 I h
Based on an analysis on errors which arise in approximating the infinite sum above by the finite one, Takahashi and Mori showed the optimal transformation (t) with which the integrand in (4.3) will decay in a manner shown by (4.5) below as | t | increase (see Fig.AQE-1). f ( (t )) ' (t ) exp( aexp t ), a > 0 (4.5)
From this, letting denote the desired accuracy, I h 2 requires I h 1 2 . Since | Ih/2 | << || Ih || numerically, S (h) S (h 2) I h I h 2 = I h I h 2 I h holds takes the form. Thus, if the convergence criterion takes the form
Cancelation
S (h) S h 2 = =1/2 is allowed theoretically. From experience, this subroutine uses the following values of for security, where ' = max(a / |S'|, r) (or ' = r when S' = 0) When 10 When 10 When 10 10-4 ' 10-5 ' <10-4 10-10 ' <10-5 ' <10-10 =1.0 =0.9 =0.8 =0.75
( )
f ( (t)) (t)
n= n=
2 1
108
AQE
As the desired accuracy , max(a, r|S(h/2)|,) is used. Determination of initial step-size and threshold The step-size is initialized to 0.5 such an integer n (n= 1, ...., 10) as satisfies the condition. F = f (nh) ' (nh) ' continuously twice is searched for, where
)10
Detection of round-off error effect Letting eh = |S(h) S(h/2)|, then if h is satisfied, S(h/2) is put out in parameter S as an approximation to the integral and eh1/ is put out in parameter ERR. However, when eh but also any of the phenomena below occurs, it is regarded that the round-off error effect dominates over the truncation error effect, and processing stops with ICON=10000. Phenomenon1 eh/2 eh e2h Phenomenon 2 eh u |S(h/2)|, where u is round-off unit. In this case, eh or u|S(h/2)| put out in parameter ERR correspondingly to Phenomenon 1 or 2 respectively. For details, see References [67] and [68].
When F > ' even at n = 10, the convergence tolerance ' is replaced by F and procedure 3 is executed.
109
AQEH
G23-21-10101
AQEH, DAQEH
Table AQEH-1 Condition codes Code 0 10000 Meaning No error The desired accuracy is not attained due to rounding-off errors. Processing The approximation obtained so far is output in S. The accuracy has reached the attainable limit. Processing continues with a relaxed tolerance.
Integration of a function over the semi-infinite interval by double exponential formula CALL AQEH(FUN,EPSA,EPSR,NMIN,NMAX,S,ERR, N,ICON)
Function Given a function f(x) and constants a r this subroutine obrains an approximation that satisfies (1.1) by using the Takahashi-Mori's double exponential formula
S
f (x)dx max
a, r
f (x)dx
(1.1)
20000
Parameter FUN ... Input. The name of the function subprogram which evaluates the integrand f(x). (See the example.) EPSA .. Input. The absolute error tolerance a(0.0) for the integral. EPSR .. Input. The relative error tolerance r(0.0) for the integral. NMIN .. Input. Lower limit on the number of function evaluations (0.0). A proper value is 20. NMAX .. Input. Upper limit on the number of function evaluations (0). A proper value is 689 (a higher value, if specified, is interpreted to 689). (See "Comments on use" and "Notes".) S ..... Output. An approximation to the integral. (See "Comments on use" and "Notes".) ERR ... Output. An estimate of the absolute error in the approximation. N ..... Output. The number of function evaluations actually performed. ICON .. Output. Condition code. See Table AQEH1. Comments on use Subprograms used SSL II ... MGSSL, AMACH, AFMAX FORTRAN Basic Functions ... AMIN1, ABS, AMAX1, FLOAT, SINH, COSH, EXP Notes The function subprogram associated with parameter FUN must be defined as a subprogram whose argument is only the integration variable. Its function name must be declared as EXTERNAL in a calling program. If the integrand in cludes auxiliary variables, they must be declared in the COMMON statement for the purpose of communicating with the calling program. When this subroutine is called many times, 689 constants (table of abscissas and weights for the integration formula) are determined only on the first call and this computation is bypassed on subse-
25000
1, 2, 3 at the place of 1000 means respectively: 1 Function value increases steeply near at x=0. 2 Function value converges too late to 0 when X 3 Both 1 and 2 occur. The desired accuracy is not attained though the number of integrand evaluations has reached the upper limit. After the occurrence of any event of code 11000 - 13000, the number of integrand evaluations reaches the upper limit. The table for abscissas(i.e. work area) has been exhausted.
30000
One of the followings occurred: 1 EPSA < 0.0 2 EPSR < 0.0 3 NMIN < 0 4 NMAX < NMIN
Processing stops. S is an approximation by using the smallest stepsize allowed in this subroutine. Bypassed
quent calls. Thus the computation time is shortened. This subroutine works most successfully even for the integrand f(x) which converges relatively slowly to zero when x+ , or f(x) to which Gauss-Laguerre's rule cannot be applied. When the integrand f(x) severely oscillates, highly accurate integral value may not be obtained. This subroutine does not evaluate the function at the lower limit (origin). A function value is allowed to be infinite (f(x) +) at the lower limit. Since function values at large values of x will be required, the function subprogram FUN needs to have a defence against overflows and underflows if the high accuracy is desired. Parameters NMIN and NMAX must be specified considering that this subroutine limits the number of evaluations of integrand f(x) as NMINNumber of evaluationsNMAX This means that f(x) is evaluated at least NMIN times, but less than NMAX times, regardless of the result of the convergence test. When a value S that satisfies expression (1.1) is not obtained within NMAX evaluations, processing stops with ICON code 20000 23000. When an extremely small NMAX is given, for
110
AQEH
example NMAX=2, NMAX is automatically increased to a certain value which depends upon the behavior of f(x). Accuracy of the integral approximation S The subroutine tries to obtain an approximation S which satisfies (1.1) when a and r are given. When r = 0, the approximation is obtained with its relative error within r. This is sometimes obstructed by unexpected characteristics of the function or an unexpected value of a or r. For example, when a or r is extremely small compared to the arithmetic precision in function evaluations, the effect of the rounding-off errors becomes greater, so there is no use in continuing the computation even though the number of integrand evaluations has not reached the upper limit (NMAX). In this case, the accuracy of S becomes the attainable limit for the computer used. The approximation sometimes does not converge within NMAX evaluations. In this case, S is an approximation obtained up to that time and so is not accurate. This is indicated by ICON within the code range 20000 - 23000. In addition, ICON is set to 25000 when the approximation does not converge though the x smallest step-size defined in this subroutine is used. To determine the accuracy of integration, this subroutine always puts out an estimate of its absolute error in parameter ERR, as well as the integral approximation S. Example The integral
** EXAMPLE** EXTERNAL FUN EPSA=1.0E-5 EPSR=0.0 NMIN=20 NMAN=689 CALL AQEH(FUN,EPSA,EPSR,NMIN,NMAX, * S,ERR,N,ICON) WRITE(6,600) ICON,S,ERR,N STOP 600 FORMAT(1H ,30X,5HICON=,I5,5X, * 2HS=,E15.7,5X,4HERR=,E15.7, * 5X,2HN=,I5) END FUNCTION FUN(X) IF(X.GT.176.0)GO TO 10 FUN=EXP(-X)*SIN(X) RETURN 10 FUN=0.0 RETURN END
Method This subroutine uses an automatic integration method based on Takahashi-Mori's double exponential formula. For detailed information on this method, refer to the method of subroutine AQE. Here, the variable transformation applied to the integration variable is 3 x = (t ) = exp sinht 2 thus, to a weight function (t).
' (t ) =
is used.
e-xsinxdx
111
AQEI
Function Given a function f(x) and constants a, r this subroutine obtains an approximation that satisfies
S
f (x)dx max
a, r
f (x)dx
(1.1)
by using Takahashi-Mori's double exponential formula. Parameters FUN ... Input. The name of the function subprogram which evaluates the integrand f(x) (see the example). EPSA .. Input. The absolute error tolerance a(0.0) for the integral. EPSR .. Input. The relative error tolerance r(0.0) for the integral. NMIN .. Input. Lower limit on the number of function evaluations (0). A proper value is 20. NMAX .. Input. Upper limit on the number of function evaluations (NMAX NMIN). A proper value is 645 (a higher value, if specified, is interpreted as 645). (See "Comments on use" and Notes.) S ..... Output. An approximation to the integral. (See "Comments on use" and "Notes".) ERR ... Output. An estimate of the absolute error in the approximation. N ..... Output. The number of function evaluations actually performed. ICON .. Output. Condition code. See Table AQEI-1.
112
AQEI
Table AQEI-1 Condition codes Code 0 10000 Meaning No error The desired accuracy is not attained due to rounding-off errors. Processing The approximation obtained so far is put out in S. The accuracy has reached the attainable limit. Processing continues with a relaxed tolerance. Processing stops. S is an approximation obtained so far, but is not accurate.
1,2,3 at the place of 1000 means that the function value converges too late to 0 when x, x, x,respectively. The desired accuracy is not attained though the number of integrand evaluations has reached the upper limit.
25000
After the occurrence of any event of codes 11000 13000, the number of integrand evaluations reached the upper limit. The table for abscissas(i.e. work area) has been exhausted.
30000
Processing stops. S is an approximation by the smallest step-size allowed in this subroutine. Processing stops.
Comments on use Subprograms used SSL II ... MGSSL, AMACH FORTRAN basic functions ... AMIN1, ABS, AMAX1, FLOAT, SINH, COSH, EXP Notes The function subprogram associated with parameter FUN must be defined as a subprogram whose argument is only an integration variable. Its function name must be declared as EXTERNAL in a calling program. If this function includes auxiliary variables, they must be declared in the COMMON statement for the purpose of communicating with a main program. When this subroutine is called many times, 645 constants (tables of abscissas and weights for the integration formula) are determined only on the
first call. This computation is bypassed on subsequent calls. This subroutine works successfully even for integrand f(x) which converges relatively slowly to 0 when x, or f(x) to which Gauss-Hermite's rule cannot be applied. The accuracy is sometimes reduced when |x| has a high peak near the origin or is oscillatory. Since function values at large values of f(x) are required, the function subprogram FUN needs to have a defense against overflows and underflows if the desired accuracy is high. Parameters NMIN and NMAX This subroutine limits the number of evaluations of the integrand f(x) as follows: NMINNumber of evaluationsNMAX This means that f(x) is evaluated at least NMIN times but not more than NMAX times regardless of the result of the convergence test. When a value of S that satisfies (1.1) is not obtained within NMAX evaluations, processing stops with ICON code 20000 - 23000. Or when extremely small NMAX is given, for example NMAX=2, NMAX is increased automatically to a value
113
AQEI
which is determined by the behavior of f(x). Accuracy of the integral approximation S This subroutine obtains a value of S that satisfies the expression (1.1) when constants a and r are given. r=0 means to obtain the approximation with its absolute error within a. Similarly, r=0 means to obtain it with its relative error within r. This purpose is sometimes obstructed by unexpected characteristics of the function, or unexpected value of r. For example, when a or r is extremely small in comparison with arithmetic precision in function evaluation, the effect of rounding-off errors becomes greater, so it is no use to continue the computation even though the number of integrand evaluations has not reached the upper limit. In this case, processing stops with ICON code 10000. At this time, the accuracy of S has reached the attainable limit for the computer used. The approximation sometimes does not converge within NMAX evaluations. In this case, S is the approximation obtained so far, and is not accurate. This is indicated by ICON within the code range 20000 23000. In addition, ICON is set to 25000 when the approximation does not converge though the smallest step-size defined in this subroutine is used. To determine the accuracy of integration, this subroutine always puts out an estimate of its absolute error in parameter ERR, as well as the integral approximation S. Example The integral
**EXAMPLE** EXTERNAL FUN EPSA=1.0E-5 EPSR=0.0 NMIN=20 NMAX=645 CALL AQEI(FUN,EPSA,EPSR,NMIN,NMAX, * S,ERR,N,ICON) WRITE(6,600) ICON,S,ERR,N STOP 600 FORMAT(1H ,30X,5HICON=,I5,5X, * 2HS=,E15.7,5X,4HERR=,E15.7, * 5X,2HN=I5) END FUNCTION FUN(X) IF(ABS(X).GT.1.0E+35) GO TO 10 IF(ABS(X).LT.1.0E-35) GO TO 20 FUN=1.0/(1.0E-2+X*X) RETURN 10 FUN=0.0 RETURN 20 FUN=100.0 RETURN END
Method This subroutine uses the automatic integration method based on Takahashi-Mori's double exponential formula. As for the principles and computing procedures of this method, refer to the descriptions under the heading Method of subroutine AQE. To add a description for subroutine AQEI, the variable transformation applied to the integration variable x is 3 x = (t ) = sinh sinht 2 thus, to a weight function (t).
10
1 dx + x2
' (t ) =
is used.
114
AQMC8
(1.1)
1=a (constant) 2 = 2 (x 1 )
m= m(x1,x2,...,xm-1) , m=m(x1,x2,...,xm-1)
Then, this subroutine obtains an approximation S which satisfies S I max( a , r I ) for a, r given by a modified Clenshaw-Curtis rule applied to each dimension. Parameters M ..... Input. Dimension m of the integral LSUB .. Input. The name of the subroutine subprogram which evaluates the lower limit k and upper limit k. The form of the subroutine is as follows: SUBROUTINE LSUB(K,X,A,B) where, K ... Input. Index k of integration variable. 1 k m. X ... Input. One-dimensional array of size (M1) which corresponds to X(1)=x1, X(2)=x2,...,X(M-1)=xm-1 A ... Output. The value of the lower limit k(x1, x2, ..., xk-1) B ... Output. The value of the upper limit k(x1,x2,...,xk-1) FUN ... Input. The name of the function subprogram which evaluates the integrated f(x1,x2,...,xm) The form of the subroutine is as follows: FUNCTION FUN(X) Parameter X is a one-dimensional array of size M which corresponds to X(1)=x1, X(2)=x2, ..., X(M)=xm. EPSA ... Input. The absolute error tolerance a (0.0) for the integral. EPSR ... Input. The relative error tolerance r( 0.0) for the integral. (1.2)
, 1=b (constant) , 2 = 2 ( x 1 )
NMIN ... Input. Lower limit (0) on the number of evaluations of the integrand function when integrating in each integral variable. A proper value is 7. NMAX ... Input. Upper limit (NMAX NMIN) on the number of evaluations of the integrand function when integrating in each integral variable. A proper value is 511. (When a value larger than 511 is specified the value is assumed to be 511.) (See Note.) S .... Output. An approximation (See Note.) ERR ... Output. An estimate of the absolute error in the approximation. N ... Output. Total number of integrand evaluations actually performed. It must be a 4-byte integer variable ICON .. Output. Condition code. See Table AQMC81.
Table AQMC8-1 Condition code Code 0 100 1000 1100 10000 10100 11000 11100 Meaning No error When integrating the function in the direction of a certain coordinate axis, the requested accuracy in that direction could not be obtained because of round-off error. The third place indicates that during integration in the direction of axis x3, the difficulty occurred for various pairs of (x1,x2). The fourth place indicates that during integration in the direction of axis x2, the difficulty occurred for various values of x1. The fifth place indicates that the difficulty occurred in the direction of axis x1. When integrating the function in the direction of a certain coordinate axis, the number of evaluation of the integrand function reached the upper limit, but the requested accuracy in the direction of the axsis could not be obtained. The indication of the places is the same as condition codes 100 through 11100. Processing The obtained approximation is output to S. When the condition code is in the range of 100 through 1100, the accuracy satisfies the request or reaches the limit of arithmetic precition. When the condition code is in the range of 10000 through 11100 the accuracy reaches the limit. In either case, the error is output to ERR.
The obtained approximation is output to S. When the condition code is in the range of 200 through 2200, the required accuracy may be satisfied or not satisfied. In either case, the error is output to ERR. If a large value of NMAX is given, the precision may be modified (the limit of NMAX is 511).
115
AQMC8
Table AQMC8-1 - continued Code 300 23300 Meaning The events indicated in condition codes 100 through 11100 and those of 200 through 22200 occurred concurrently. Processing The obtained approximation is output to S. The required accuracy may be satisfied or may not be satisfied. In either case, the error is output to ERR. Bypassed
respectively. When NMAX is specified as less than seven, seven is assumed. Accuracy of the integral approximation S This subroutine tries to obtain an approximation S which satisfies (1.2) when a and r are given. When r=0, an approximation is obtained with an absolute error within a. Similarly, when a=0, an approximation is obtained with a relative error within r. This is sometimes obstructed by an unexpected characteristic of the function or an unexpected value of a or r. For example, when a or r is extremely small compared to the arithmetic precision in function evaluations, the effect of the rounding-off errors becomes greater, so there is no use in continuing the computation even though the number of integrand evaluations has not reached the upper limit(NMAX). In this case, ICON is set to 100 - 11100. The position of numeric character 1 indicates the type of axis x3, x2 and x1 corresponding to 100, 1000 or 10000 respectively. Generally speaking, even when ICON is set to 100 - 1100, that is the effect of round-off errors becomes greater on axis x3 and x2, this may not effect the total accuracy of integral S. It may satisfy the required accuracy. This should be checked depending on the error estimation ERR. As mentioned above, an approximation may not converge within NMAX times. In this case, ICON is set to 200 - 22200, the position of the number 2 indicating the type of axis. When ICON is set to 200 - 22200, the obtained integral may satisfy the required accuracy. When the events indicated by condition codes 100 11100 and 200 - 22200 occur, ICON is set to 300 23300. To determine the accuracy of the integration, this subroutine always outputs an estimate of its absolute error in parameter ERR, as well as the integral approximation S. Example Increasing the value of auxiliary variable from 1.0 to 3.0 by 1.0 at a time, this example computes the integral.
I=
30000
Comments on use Subprogram used SSL II ... MGSSL, AMACH FORTRAN basic functions ... ABS, AMAX1, FLOAT, MAX0, MIN0, SQRT Notes The function subprogram associated with parameter FUN must be defined as a subprogram whose argument is only the integration variable vector X. Its function name must be declared as EXTERNAL in a calling program. If the integrand includes an auxiliary variable, this must be declared in the COMMON statement for the purpose of communicating with the calling program (see the example). Also, the name of the subprogram associated with parameter LSUB must be declared as EXTERNAL in a calling program. When this subroutine is called many times, 511 constants (tables of abscissas and weights for the integration formula) are determined only on the first call and this computation is bypassed on subsequent calls, thus the computation time is shortened. This subroutine works successfully not only for smooth integrands f(x1,x2,...,xm) but also for oscillatory ones. This subroutine limits the number of evaluations ni where i=1,2,...,m in the direction of each coordinate axis of the integrand function in the range of: NMINni NMAX This means that f (x1,x2,...,xm) is evaluated at least NMIN times, but not more than NMAX times, regardless of the result of the convergence test. If the approximation does not converge within NMAX times in the direction of a certain coordinate axis, the processing stops with ICON code 200 22200. The position of numeric character 2 indicates the type of axis x3, x2 or x1 corresponding to 100, 1000 or 10000
**EXAMPLE** INTEGER*4 N COMMON P EXTERNAL FUN,LSUB EPSA=1.0E-5 EPSR=1.0E-5 NMIN=7 NMAX=511 M=3 DO 10 I=1,3 P=FLOAT(I) CALL AQMC8(M,LSUB,FUN,EPSA,EPSR,
116
AQMC8
* NMIN,NMAX,S,ERR,N,ICON) 10 WRITE(6,600) P,ICON,S,ERR,N STOP 600 FORMAT(1H ,30X,2HP=,F6.1,5X,5HICON=, * I5,5X,2HS=,E15.7,5X,4HERR=,E15.7,5X, * 2HN=,I5) END SUBROUTINE LSUB(K,X,A,B) DIMENSION X(2) GO TO (10,20,30),K 10 A=-1.0 B=1.0 RETURN 20 A=-2.0 B=2.0 RETURN 30 A=-3.0 B=3.0 RETURN END FUNCTION FUN(X) DIMENSION X(3) COMMON P FUN=1.0/(COS(P*X(1))*COS(P*X(2)) * *COS(P*X(3))+2.0) RETURN END
Therefore, I is obtained when the function I1is integrated for x1. In this state the function I1(x1) can be obtained by fixing x1 when the function I2(x1,x2) is integrated fixing x1 and x2 on [ 3(x1,x2),3((x1,x2)] for x3 of f(x1,x2,x3). This subroutine uses a modified Clenshaw-Curtis rule to integrate I along coordinate axis x1, x2, or x3. Computing procedures Procedure 1 ... Initialization Determine the initial value of various variables and constants used for tests. Procedure 2 ... Determination of abscissas and weights Obtain the abscissas and weights to be used for the Clenshaw-Curtis rule by a recurrence formula. Then put them into one-dimensional work arrays. Since the upper limit on the number of abscissas is 511(=291), each size of the one-dimensional array required for the abscissas and weights is 256(=28), respectively. Procedure 2 is performed only on the first call and this procedure is bypassed on subsequent calls. Triple integration is considered in the following procedure 3, 4, and 5. Procedure 3 ... Initialization for integration in the direction of axis x1 Set seven points on the interval [ 1,1] which are defined as x1i (i=1,2,3,...7). These are the first seven abscissas obtained in Procedure 2 and linearly transformed to the interval [ 1,1]. Procedure 4 ... Initialization for integration in the direction of axis x2 One of x1i (i=1,2,...,7) or one of the eight abscissas added on axis x1 is assumed to be X1. Set the seven points on interval [ 2(X1),2(X1)] of variable x2 for this X1. They are dencted by x2i (i = 1, 2, ..., 7). These are the points as in Procedure 3 which are obtained and linearly transformed to the interval [ 1,1]. Procedure 5 ... Initialization for integration in the direction of axis x3 Assume one of x2i (i=1,2,...,7) or one of the eight abscissas added on axis x2 to be x2. Set seven points on the interval [ 3(X1,X2),3(X1,X2)] of variable x3 for (X1,X2). They are denoted by x3i (i=1,2,...,7). These are the points as in Procedure 3 which are obtained in Procedure 2 and the first seven of them are linearly transformed. Procedure 6 ... Integration in the direction of axis x3 Compute the values of function f at the points (X1,X2,x3i ) (i=1,2,...,7) and obtain an approximation SI7(X1,X2). The obtained approximation is the initial approximation for (4.2) when fixing (x1,x2).
Method This subroutine uses a product formulas in which a modified Clenshaw-Curtis rule is applied repeatedly to each of dimension. Since AQC8 works successfully for smooth functions and oscillatory functions, this subroutine has the same characteristic with AQC8. For detailed information on the Clenshaw-Curtis rule, see AQC8. The product formula Consider the following triple integral.
I = 1 dx1 2 dx 2 3 dx 3 f (x1 , x2 , x 3 ) 1 2 3
(4.1)
The lower limit and upper limit of the integral are given by
1 I ( x )dx
1 1
2 I ( x , x )dx
2 1 2 1
3 f (x , x , x )dx
1 2 3 2
117
AQMC8
Furthermore, define x3i where i=8,9,...,15 from the points obtained in Procedure 2. Then compute the values of function f at (X1,X2,X3i ) for i=8,9,...15. The approximation SI15(X1,X2) for (4.2) is obtained based on the 15 points. Repeat this computation adding eight points each time until the approximation converges. If the approximation does not converge even with NMAX number of abscissas or the error cannot be improved any more because of round-off error, set the value of ICON depending upon the behavior of approximation. Procedure 7 ... Integration in the direction of axis x2 Execute procedures 5 and 6 for all x2i (i=1,2,...,7) defined in Procedure 4 and obtain approximation SI7(X1) of the integral in the direction of axis x2. This is an approximation to (4.3) when fixing x1. Furthermore, define x2i (i=8,9,...,15) from the points obtained in Procedure 2 and execute Procedure 5 and 6 to obtain SI15(X1). Repeat adding eight points each time until the approximation converges. When the approximation does not converge, set the value of ICON. Procedure 8 ... Integration in the direction of axis x1 Execute Procedures 4, 5, 6 and 7 for all x1i (i=1,2,...,7) defined in Procedure 3. Then obtain the approximation SI7 of the integral in the direction of axis x1. This is the initial approximation for the triple integration (4.4). Furthermore, define x1i (i=8,9,...,15) from the points obtained in Procedure 2 and execute procedure 4, 5, 6 and 7 to obtain SI15. Repeat adding eight points each time until the approximation converges. When the approximation does not converge, set the value of ICON and terminate the processing. Error evaluation In the triple integration (4.1), to transfer the integral interval [ 1,1] to [-1,1]. the following variable transformation is performed:
x1 =
1dx h(x )
'1 '1
(4.5)
'2 '1 , x ' 2
h x '1 = a2 x '1
( )
( )1dx g(x
1
)
1 '1 + 1 ,
(4.6)
2 (x '1 )x ' 2
1dx f ( x
'3
(4.7)
When the Clenshaw-Curtis rule is used for the integration on the righthand side in (4.7), and the discretization error is denoted by p(x1',x2'), the following holds: ~( x '1 , x ' 2 ) + 3 ( x '1 , x ' 2 ) p( x '1 , x ' 2 ) g ( x '1 , x ' 2 ) = g , where
7 P 7 ~( x '1 , x ' 2 ) = 3 ( x '1 , x ' 2 ) A1,k W1,k + Ai ,k Wi ,k g k =0 i =0 k =0 (4.9)
(4.8)
This is the approximation based upon (8P+7) points. And Ai,k is the value depending upon (x'1,x'2) and Wi,k is a weight. p(x'1,x'2) is estimated by p( x '1 , x '2 ) = A P,5 + A P,7 WP+1,1
(4.10)
( )
~x ( )1 g ( 1
3
'1
, x ' 2 dx ' 2
'1 , x ' 2
(4.11)
'1 , x ' 2
+ 2 x '1
( )1 (x
) p( x
)dx
'2
1 1 + 1 x '1 + 1 1x '1 + 1 2 2
When the Clenshaw-Curtis rule is used for the integration of the first item on the righthand side, and the discretization error is denoted by q(x'1), then the first item can be written as follows:
2 ( x1 )
The variable transformation for x2 and x3 is performed at one time to transfer the integral interval [2(x1),2(x1)], [ 3(x1,x2),3(x1,x2)] to [-1,1] as follows:
x2 = x '2 + 2 2 ( x'1 )x'2 + 2 (x'1 )
1 g (x , x )dx = h (x ) + ( x )q( x )
~
1 2 2 1 2 1 1
1 ~
, where
7 ~ h ( x '1 ) = 2 ( x '1 ) B1,kW1,k k =0
2 ( x1 ) 2 ( x1 )
2 (x1 ) + 2 ( x1 )
2
Q 7 + Bi ,kWi ,k i =0 k =0
(4.12)
x3 =
3 ( x1 , x2 ) 3 (x1 , x2 )
3 (x1 , x2 ) + 3 ( x1 , x2 )
2
(4.13)
Substitute the first equation of (4.12) in (4.11) and substitute the obtained equation in (4.5) to obtain the following:
118
AQMC8
I = 1
1h (x )dx
'1
1 ~
'1
+ 1
1 2 (x )q(x )dx
'1 '1
'1
~ ~( x1 , x 2 ) h I2n-1, I2n-1-1 corresponds to g ( x1 ) and I when using (4.14) 2n-1 or 2n-1 1 number of branch points respectively. Convergence criterion ~ In order I I a (an absolute error tolerance), it is sufficient that each term of the righthand side in (4.17) can be bounded as:
1r a 3 1
+ 1
Also, when the Clenshaw-Curtis rule is used for the integration of the first item on the righthand side of (4.14), and the discretization error is denoted by r, the following holds:
1 ~ ~ 1 h (x '1 )dx '1 = I + 1r 1
, where
7 ~ I = 1 C1,kW1,k k =0
R 7 + Ci ,kWi ,k i =0 k =0
(4.15)
1
1 (x )q(x )dx
2 '1 '1
'1
1 (x )1 (x
1 1
2 '1 3
'
(4.16)
~ Therefore I in (4.15) is the approximation to the ~ is obtained by triple integration and the error I I
q( x '1 )
p( x '1 , x '2 )
( 3) a
(4.20)
This indicates how the discretization errors p(x'1,x'2), q(x'1) and r effect the entire error. The estimations of p(x'1,x'2), q(x'1), and r can be obtained by (4.10), (4.13) and (4.16) respectively. These equations hold when the approximation converges rapidly. When the approximation does not converge rapidly, another estimation is considered. Define the approximation to the integral when using the Clenshaw-Curtis rule in which 2n 1 points are used, as I2n 1. The error for the approximation to the integral using the ClenshawCurtis rule in which 2 n-1 1 points are used can be evaluated by |I2n-1 I2n-1-1|. When the error evaluation of the Clenshaw-Curtis rule is assumed to be E(2n-1 1), it will be an underestimation if the approximation does not converge rapidly. Here the Clenshaw-Curtis rule contains 2n-1 1 number of branch points using expansion coefficients and weight coefficients as in (4.10), (4.13) and (4.16). Therefore the following equation holds: I2n 1 I2n11 > E (2
n 1
( 3)
( x'
, x ' 2 ) = 8u( P + 1) f
( 2 ) ( x '1 ) (1)
where, f ~ g ~ h
~ = 16u Q + 1 g ~ = 32u( R + 1) h
(4.21)
Summarizing the above discussions, the convergence criterion constants for each step are defined as follows:
~ ( x '1 , x ' 2 ) 3 ( x '1 , x ' 2 ) , ( 3 ) ( x ' 1 , x ' 2 ) (3) ( x '1 , x' 2 ) = max a(3) , r g ~ (2 ) ( x'1 ) = max a(2 ) , r h ( x'1 ) 2 ( x'1 ) , (2 ) ( x'1 )
1)
(4.18)
When (4.18) is met, the following is used as the error evaluation for P in 2n 1 8P+7 < 2n+1 1 instead of E(8P+7). E(8P + 7) I 2n 1 I2n 11 E(2n 1 1) (4.19)
(1)
( ( = max(
(1 ) a
~ ( ) , r I 1 , 1
~ ~ ~ where, g , and h , and I of the righthand sides are approximations which have been obtained so far. The convergence criterion is performed as follows:
119
AQMC8
When the following equation is satisfied, g(x'1,x'2) is assumed to have converged. p( x '1 , x ' 2 ) ( 3) ( x '1 , x ' 2 ) (4.22)
~ Then the following is satisfied, the obtained I is output to parameter S as an approximation to the multiple integral.
~ When the following is satisfied, h ( x '1 ) is assumed to have converged. q ( x '1 ) ( 2 ) ( x '1 ) (4.23)
r (1)
(4.24)
120
AQME
1
1
dx1
2
2
dx2
dxm f ( x1, x2 ,
xm )
(1.1)
Generally the lower limits and upper limits are given as follows:
2 = 2 ( x1 ) 1 = a (constant ) , 1 = b (constant )
, 2 = 2 ( x1 )
m 1
m = m ( x1 , x 2 ,
, x
) ,
= m ( x1 , x 2 ,
, x
m 1
This subroutine handles semi-infinite or infinite regions along with finite regions. In other words, the integral interval [ k,k] for xk can independently be [0,] or ( ,). Under these conditions, this subroutine obtains an approximation S that satisfies, for a, r given, S I max( a , r I ) (1.2)
by using Takahashi-Mori double exponential formula repeatedly. Parameters M ..... Input. Dimension m of the integral INT .... Input. Information indicating the type of intervals for each integration variable. Onedimensional array of size m. The k-th element INT(K) indicates the type of the integration interval for the k-th variable xk, and should be specified either of 1, 2, or 3 according to the following rule: 1 ... Finite interval 2 ... Semi-infinite interval 3 ... Infinite interval For example, for the triple integration
I=
Input. One-dimensional array of size (M1) which corresponds to X(1)=x1, X(2)=x2,.....,X(M1)=xm11. A ... Output. The value of the lower limit k(x1,x2,...,xk11) B ... Output. The value of the upper limit k(x1,x2,...,xk1) However if the interval [ k,k] is either [0,] or (,), it is not necessary to define values of A and B for corresponding k. FUN ... Input. The name of the function subprogram which evaluates the integrand f(x1,x2,...,xm) The form of subroutine is as follows: FUNCTION FUN(X) where, parameter X is a one-dimensional array of size M with the correspondence X(1)=x1,X(2)=x2,...,X(M)=xm. EPSA ... Input. The absolute error tolerance a (0.0) for the integral. ERSR ... Input. The relative error tolerance r (0.0) for the integral. NMIN ... Input. Lower limit (0) on the number of evaluations of the integrand function when integrating in each integration variable. A proper value is 20. NMAX ... Input. Upper limit (NMAXNMIN) on the number of the evaluation of the integrand function when integrating in each integration variable. A proper value is 705 (if the value exceeding 705 is specified, 705 is assumed). (See Notes) S ..... Output. An approximation (See Notes) ERR ... Output. An estimate of the absolute error in the approximation S. N ..... Output. Total number of integrand evaluations actually performed. It must be a 4byte integer variable. ISF ... Output. Information on the behavior of the integrand when the value of ICON is in 25000's. ISF is a 3-digit positive integer in decimal. Representing ISF by ISF=100j1+10j2+j3 j3, j2 or j1 indicates the behavior of the integrand function in the direction of axis x3, x2 or x1 respectively. Each j1 assumes 1, 2, 3 or 0 which is explained as follows: 1 ... The function value increases rapidly near the lower limit of integration or if the interval is infinite, the function values tend to zero very slowly as x . 2 ... The function value increases rapidly near the upper limit of integration or if the interval is semi-infinite or infinite, the function values tend to zero very slowly as x.
X ...
INT(1)=2, INT(2)=1 and INT(3)=1. LSUB ... Input. The name of the subroutine Subprogram which evaluates the lower limit k and upper limit k. The form of the subroutine is as follows: SUBROUTINE LSUB(K,X,A,B) where, K ... Input. Index k of integration variable. 1 k m.
121
AQME
3 ... The events indicated in the above 2 and 3 occur concurrently. 0 ... The above mentioned event does not occur. ICON ... Output. Condition code (See Table AQME-1).
Comments on use Subprograms used SSL II ... MGSSL,AMACH,AFMAX,AFMIN, UAQE1,UAQE2,UAQE3,UFN10,UFN20,UFN30,UFN 40 FORTRAN basic function ... ABS,ALOG,SQRT, EXP,FLOAT,COSH,SINH,MAX0,AMAX1,AMIN1,M OD
Table AQME-1 Condition code Code 0 10001 10077 Meaning No error When integrating in the direction of axis x3 or x2, the following events occur. The first place indicates the direction of axis x3 and the second place indicates the direction of axis x2. Each assumes the value of 0 through 7 (there is no case when both of them are zero). 1. The required accuracy in the direction of the axis cannot be obtained due to the round-off error. 2. The required accuracy cannot be obtained even if the number of the evaluations of the integrand function in the direction of the axis reaches the upper limit(NMAX). 4. The required accuracy in the direction of the axis cannot be obtained even if integrating by the minimum step size defined in the subroutine. 3. The events indicated above in 1 and 2 occur concurrently. 5. The events indicated above in 1 and 4 occur concurrently. 6. The events indicated above in 2 and 4 occur concurrently. 0. No events indicated above occur. When integrating in the direction of axis x1, the required accuracy cannot be obtained due to the round-off error. The lower two digits mean the same as those in codes 10001 - 10077. Processing The obtained approximation is output to S. The required accuracy may be satisfied. Code 20200 20277 Meaning When integrating in the direction of axis x1, even if the number of evaluations of the integrand function reaches the upper limit(NMAX), the required accuracy cannot be obtained. The lower two digits mean the same as those in codes 10001 - 10077. Processing The obtained approximation is output to S. The required accuracy is not always guaranteed. If the value of NMAX is taken as a larger one, the accuracy may be improved (up to NMAX=705). The obtained approximation is output to S.
20400 20477
25000 25477
When integrating in the direction of axis x1 even by the minimum step size defined in the subroutine, the required accuracy cannot be obtained. The lower two digits mean the same as those in codes 10001 - 10077. When integrating in the direction of a certain axis, the value of the function rapidly increases near the lower limit or upper limit of the integration interval, or when the integration interval is semi-infinite or infinite, the integrand function slowly converges to 0 as the integration variable tends to infinite. The lower three digits mean the same as those in codes 10001 - 10077.
30000
10100 10177
The obtained approximation is output to S. The accuracy almost reaches a limit attainable.
One of the following occurred: 1 EPSA<0.0 2 EPSR<0.0 3 NMIN<0 4 NMAX<NMIN 5 M0 or M4 6 Some value other than 1, 2, or 3 is input for the element containing INT.
Processing is continued after relaxing the required accuracy. The obtained approximation is output to S. Even when the integral does not exist theoretically, this range of code may be returned. For detailed information on the behavior of the integrand, refer to parameter ISF. Processing terminates.
122
AQME
Notes The function subprogram associated with parameter FUN must be defined as a subprogram whose argument is only the integration variable vector X. Its function name must be declared as EXTERNAL in a calling program. If the integrand includes auxiliary variables, they must be declared in the COMMON statement for the purpose of communicating with the calling program. When this subroutine is called many times, constants (table of abscissas and weights for the integration formula) are determined only on the first call, and this computation is bypassed on subsequent calls, thus the computation time is shortened. This subroutine works successfully even when the integrand function changes rapidly in the neighborhood of the boundary of integration region. This subroutine is most recommended when algebraic or logorithmic singularities are located on the boundary. If the integral domain is finite and the integrand is smooth or oscillatory, you should use subroutine AQMC8. This subroutine works successfully for the integrand f(x1,x2,...,xm) which converges to zero rather slowly when x. However, if the function is extremely oscillatory in the region, high accuracy may not be attained. This subroutine does not evaluate the function on the boundary, therefore it is possible for the function value to be infinity. However, points which tend to infinity must not be contained in the region. When the integration interval in the direction of a certain axis(say, i-th axis) is infinite, the function values for large |xi | is required, therefore if the desired accuracy is high, the function subprogram FUN needs to have a defence against overflows and underflows. Parameters NMIN and NMAX Parameters NMIN and NMAX must be specified considering that this subroutine limits the number of evaluations of integrand in the direction of each coordinate axis as NMIN ni NMAX This means that f(x1,x2,...,xm) is evaluated at least NMIN times in the direction of each coordinate axis, but not more than NMAX times, regardless of the result of the convergence test. When the integral does not converge within NMAX evaluations, this information is output to the first, second, or third digit of ICON corresponding to the axis x3, x2 or x1 respectively. When extremely small NMAX is given, for example NMAX=2, NMAX is increased automatically to a value which is determined by the behavior of f(x1,x2,...,xm).
Accuracy of the integral approximation S This subroutine tries to obtain an approximation S which satisfies (1.2) when a and r are given. When r=0, the approximation is obtained with its absolute error within a. Similarly, when a=0, the approximation is obtained with its relative error within r. This is sometimes obstructed by unexpected characteristics of the function or an unexpected value of a or r. For example, when a or r is extremely small compared to the arithmetic precision in function evaluation, the effect of rounding-off errors becomes greater, so there is no use in continuing the computation even though the number of integrand evaluations has not reached the upper limit (NMAX). Depending upon the axis, this information is output to the third, second or first place of ICON. Generally speaking, even when the effect of the rounding-off error on axis x3 or x2 is large, this may not effect the total accuracy of integral approximation S. It may satisfy the required accuracy. This must be checked depending on the estimate ERR. As mentioned in "Parameters NMIN and NMAX", the approximation sometimes does not converge within NMAX evaluations. In this case, this information is output to ICON. Therefore, even if this event occurs on axes x3 or x2, the obtained integral approximation sometimes will satisfy the required accuracy. In addition, the approximation may not converge though the smallest step-size defined in this subroutine is used. Although this information is output to ICON, even if this event occurs on axis x3 or x2, the required accuracy may be satisfied. To determine the accuracy of the integration, this subroutine always outputs an estimate of its absolute error in parameter ERR, as well as the integral approximation S. Example The integral
I=
0 dx10
x1
dx2
1 x
e x
x1 x2 + x3
dx3
123
AQME
NMIN,NMAX,S,ERR,N,ISF,ICON) WRITE(6,600) ICON,S,ERR,N IF(ICON.GE.25000) WRITE(6,610) ISF STOP 600 FORMAT(1H ,10X,5HICON=,I6,5X,2HS=, * E15.7,5X,4HERR=,E15.7,5X,2HN=,I6) 610 FORMAT(1H ,20X,4HISF=,I3) END SUBROUTINE LSUB(K,X,A,B) DIMENSION X(2) A=0.0 GO TO (10,20,30),K 10 RETURN 20 B=X(1) RETURN 30 B=1.0-X(2) RETURN END FUNCTION FUN(X) DIMENSION X(3) Y=X(2)+X(3) IF(Y.LT.1.0E-70) GO TO 20 IF(X(1).GT.174.0) GO TO 20 Y=X(1)*SQRT(Y) IF(Y.LT.1.0E-70) GO TO 20 FUN=EXP(-X(1))/Y RETURN 20 FUN=0.0 RETURN END
I=
dt1
(4.4)
(4.5) (4.6)
Using the trapezoidal rule to obtain infinite integration Ik-1(k=1,2,3) in (4.4), (4.5) and (4.6), the following integration formula can be obtained. I k 1 = hk I k 1 n1 h1 ,
nk =
( ( ) , (n h )) (n h )
k k k k k k
, k = 1, 2, 3 where, hk is the step size for tk. This subroutine uses the following as variable transformation of (4.2): 1) When k=A, k=B for finite A and B
(4.7)
Method This subroutine uses the direct product multiple integration method in which automatic integration method based upon Takahashi-Mori's double exponential formula is repeated in the direction of each axis. Since the methods used in the following subroutines are used for this, you should refer to each subroutine for details. The way to apply the double exponential formula to multiple integration and the way to compute it are described below. Multiple integration using the double exponential formula In m-multiple integration defined in (1.1), when m=3, the variable transformation I=
1 2 3 dx1 dx2 dx3 f 1 2 3
k (t k ) =
(4.8)
( x1 , x2 , x3 )
(4.1)
Multiple integration convergence criterion For each Ik in (4.4), (4.5) and (4.6), the following inequalities S2 I 2 max a , r I 2 S1 I 1
a r 1
is performed for each integral variable of the integration xk= k(tk) , k=1,2,3 (4.2)
S0 I 0
( ) max( , I ) max( , I )
a r 0
When the integration (4.1) is transformed and the interval [ k,k] is transformed to (,), the following integration will be obtained.
are solved for each Sk, and the last S0 is used as S in (1.2). For detailed information on how to set the step size in the equally spaced step-size trapezoidal rule, information on convergence criterion, information on how to get the threshold to approximate the finite sum (4.7) by using infinite sum, or information on how to detect the influence of the rounding-off error, refer to Method of subroutine AQE.
124
AQME
Computing procedure Procedure 1 ... Initialization Define the initial value of several variables and constants for criterions. Procedure 2 ... Computation of abscissas and weight coefficients Transforms the integral variables and compute abscissas ( k(tk)) and values of weight ( 'k(tk)) according to INT value. The number of abscissas and weights are calculated as 23523. This computation is performed only when this subroutine is called for the first time. It is bypassed on subsequent calls. Procedure 3 ... Integration in the direction axis x1-Computing I0
Approximation S0 for I0 in (4.6) is computed. Convergence is tested in (4.13). I1( 1(t1)) value required for computing I0 is computed in procedure 4. The obtained S0 and the error estimate are output to parameter S and ERR. Procedure 4 ... Integration in the direction of axis x2Computing I1( 1(t1)). Approximation S1 for I1 (1(t1)) in (4.5) is computed. The convergence is tested in (4.12). The value of I1( 1(t1)) is computed in Procedure 5. Procedure 5 ... Integration in the direction of axis x3Approximation S2 for I2( 1(t1), 2(t2)) in (4.4) which is used to compute I2 (1(t1), 2 (t2)) is computed. The convergence is tested in (4.11).
125
AQN9
Table AQN9-1 Condition codes Code 0 10000 13111 Meaning No error Irregular points such as singular points are found. 1000 means algebraic singularities 2000, Cauchy's singularities, and 3000, both of the two 100 means logarithmic singularities 10 means discontinuity points 1 means other irregular points The desired accuracy is not attained though the number of integrand evaluations has reached the upper limit. Meanings of last four digits are the same as those described above. One of the followings detected. 1 EPSA<0.0 2 EPSR<0.0 3 NMIN<0, NMIN150 4 NMAXNMIN Processing Processing continues. For algebraic singularity, or discontinuity points only, S will usually satisfy the desired accuracy.
Function Given a function f(x) and constant a, b, a, r, this subroutine obtains an approximation S that satisfies
S a , r a f ( x )dx a f (x)dx max b b
(1.1)
by adaptive Newton-Cotes 9 point rule. Parameters A ..... Input. Lower limit a of the interval. B ..... Input. Upper limit b of the interval. FUN ... Input. The name of the function subprogram which evaluates the integrand f(x). (See the example.) EPSA .. Input. The absolute error tolerance a(0.0) for the integral. EPSR .. Input. The relative error tolerance r(0.0) for the integral. NMIN .. Input. Lower limit on the number of function evaluations. A proper value is 21. 0NMIN<150. NMAX .. Input. Upper limit on the number of function evaluations. A proper value is 2000. (See Notes.) S ..... Output. An approximation to the integral (see "Notes".) ERR ... Output. An estimate of the absolute error in the approximation. N ..... Output. The number of function evaluations actually performed. ICON .. Output. Condition code. See Table AQN9-1. Comments on use Subprograms used SSL II ... MGSSL,AMACH FORTRAN basic functions ... ABS, MAX0, AMAX1, AMIN1, ALOG, DLOG, MOD, FLOAT Notes The function subprogram associated with parameter FUN must be defined as a subprogram whose argument is only the integration variable. Its function name must be declared as EXTERNAL in its calling program. If the integrand includes auxiliary variables, they must be declared in the COMMON statement for the purpose of communicating with the calling program (see the example).
20000 23111
30000
This subroutine may be used for a broad class of function: it can handle successfully even those integrands which have peaks, or irregular points such as algebraic singularities, logarithmic singularities, or discontinuities at places which can be accessed in the manner of bisection, such as endpoints, the midpoint or quartered points. Consequently this subroutine should be used with first priority for such class of integrands as well as ones whose properties are not clearly understood. However, in order to improve the accuracy of the solution, it is desirable to change the integration variable if necessary so that difficult points may be located only at endpoints. It should also be noted, however, that subroutine AQC8 will best handle oscillatory functions as well as smooth ones in the sense of efficiency, while AQE does for functions having singularities only at endpoints. When the value of the integrand f(x) goes to infinity (f(x)) at a certain point within the interval [a,b], it is necessary to replace the value of f(x) at that point with some finite value (such as 0), as shown in the example below. Parameters NMIN and NMAX This subroutine limits the number of evaluation of integrand f(x) as follows:
126
AQN9
NMINNumber of evaluationsNMAX This means that f(x) is evaluated at lease NMIN times and not more than NMAX times, regardless of the result of the convergence test. When a value of S that satisfies expression (1.1) is not obtained within NMAX evaluations, processing stops with ICON value 20000 21111. In addition, if the value of NMAX is less than 21, a default value of 21 is used. Accuracy of the approximation S This subroutine obtains a value of S satisfying (1.1) when constants a, r are given. Consequently, r=0 means to obtain the approximation with its absolute error within a, similarly, a = 0 means to obtain it with its relative error within r. This purpose is sometimes obstructed by unexpected characteristics of the function or unexpected values of a or r. For example, when a or r is extremely small in comparison with arithmetic precision in function evaluations, the number of function evaluations is increased and sometimes the approximation does not converge within NMAX times. In this case, S is only an interim approximation and not accurate. This is indicated by ICON within the code range from 20000 to 21111. As well as the integral approximation S, this subroutine puts out an estimate of the absolute error in parameter ERR for checking the actual accuracy of approximation. Example Increasing the value of the auxiliary variable p from 0.1 to 0.9 by 0.1 at a time, this example computes the integral
C **EXAMPLE** COMMON P EXTERNAL FUN A=0.0 B=1.0 EPSA=1.0E-4 EPSR=1.0E-4 NMIN=21 NMAX=2000 DO 10 I=1,9 P=FLOAT(I)/10.0 CALL AQN9(A,B,FUN,EPSA,EPSR,NMIN, * NMAX,S,ERR,N,ICON) 10 WRITE(6,600) P,ICON,S,ERR,N STOP 600 FORMAT(1H ,30X,2HP=,F6.3,5X, * 5HICON=,I5,5X,2HS=,E15.7,5X, * 4HERR=,E15.7,5X,2HN=,I5) END FUNCTION FUN(X) COMMON P FUN=0.0 IF(X.GT.0.0) FUN=X**(-P)+SIN(P*X) RETURN END
Method This subroutine uses an adaptive automatic integration based on the Newton-Cotes 9 point rule. Adaptive automatic integration is a method which automatically places abscissas densely where the integrand f(x) changes rapidly, or sparsely where it changes gradually. This is currently the best method for automatic integration in terms of reliability and economy. Computing procedures Procedure 1 ... Initialization Initializes the left end point x, width w, and approximation S to the integral as x=a, w=w0=(b a), and S=0; and initializes various variables and constants to be used for various judgment. Calculates function values to f0, f2, f3, f4, f5, f6, f7, f8, and f10, at octasectional points of the integration interval including both end points, and f1, and f9 at the hexadecasectional end points. (See Figure AQN9-1.) The average value f of f(x) in the integration interval is calculated with these 11 function values by means of the modified Newton-Cotes 9-point rule (expression 4.5). Procedure 2 ... Bisection and information string Bisects the current subinterval (left end point x, width w). Stores the function values f6, f7, f8, f9 and f10 relevant to the right-half portion, value of width w, and estimate e of the truncation error in the stack. Calculates the function value at the second right-most octasectional point (marked with x in Figure AQN9-1) in the left portion and let it be denoted by f8. Proceeds to procedure 3 to manipulate function values in the left portion. x w
9 10
Procedure 3 ... Convergence criterion Calculates those function values at octasectional points and at hexadecasectional end points which are not available yet, namely, four values f1, f4, f6, and f9. Then estimates the truncation error e by (4.4) of the approximate integral over the current subinterval, and makes convergence test to e. If the test is satisfactory proceeds to procedure 7, otherwise to procedure 4.
127
AQN9
Procedure 4 ... Detection of irregular points Checks whether there is an irregularity at the end points of the current subinterval. If there is an irregularity, control is passed to procedure 6, and when width w becomes less than the tolerable minimum value determined by input variables such as a, b, a, and r, control is passed to procedure 5. In other cases, control is passed back to procedure 2. Procedure 5 ... Confirmation of the existance of irregularity Checks irregularity using the relaxed criterion. If the test is satisfactory proceeds to procedure 6; otherwise to procedure 7. Procedure 6 ... Handling of irregular points Calculates the approximate integral over the current subinterval by an analytical formula depending on the type of detected irregularity. Procedure 7 ... Accumulation of the approximation retrieval Normally, the approximate integral over the current subinterval is calculated by means of the modified 9point rule(4.5) and accumulated to S. In the case of irregularity, the value obtained in procedure 6 is accumulated to S. The information stored in the stack is retrieved and the function value f2 in a new subinterval is calculated, then control is passed back to procedure 3. If the stack becomes empty, processing is stopped and the value of S is assumed to be the integral. Newton-Cotes 9-point rule and error estimation Expressions (4.1) and (4.2) give the approximation S(x,w) and the truncation error e when the NewtonCotes 9-point rule is applied to the interval with width w (Figure AQN9-1), where I is the true value of the integral and fi is the function value at point i. S ( x , w) = w 989( f 0 + f 10 ) + 5888( f 2 + f 8 ) 28350 928( f 3 + f 7 ) + 10496( f 4 + f 6 ) 4540 f 5 (4.1)
1024 S ( x , w) S ( x , w 2) + S ( x + w 2 , w 2) 1023
)}
(4.3)
In this case, however, eight function values must be additionally calculated. As is clear from expression (4.2), it is only necessary to estimate f(10), so only 11 function values are sufficient to do this; therefore, only two additional function values need be calculated. This subroutine estimates value e from the 10th order differentiation formula (4.4) based on the octasectional points and two hexadecasectional points 1 and 9 of the interval (Figure AQN9-1) as follows: e 2383w 3003( f 0 + f 10 ) 16384( f 1 + f 9 ) 468242775 + 27720( f 2 + f 8 ) 38220( f 3 + f 7 ) + 56056( f 4 + f 6 ) 64350 f 5
(4.4)
When the value e satisfies the convergence criterion (expression (4.7)), e is subtracted from S(x,w) to obtain a more accurate approximation. In this subroutine, however this is done directly by means of the modified Newton-Cotes formula shown below which is derived from the difference between the righthand sides of (4.1) and (4.4). w 18447429( f 0 + f 10 ) + 77594624( f 1 + f 9 ) 936485550 + 63216384( f 2 + f 8 ) + 150355296( f 3 + f 7 ) + 81233152( f 4 + f 6 ) + 154791780 f 5
(4.5)
In (4.5) the signs of weights to be multiplied by the function values are not constant, whereas the signs are constant in (4.5); thus, (4.5) is an good integration formula with high stability in numerical sense. Convergence criterion Unlike a global automatic integration method, an adaptive automatic integration requires convergence judgment for each subinterval. The following criterion has been used to make the resultant approximation S satisfy the requirement (1.1): e max a , r S w w0 where S' is an approximation to
(4.2)
where f(10) denotes the 10th derivative of f(x) at some point in the interval. Conventionally, value e has been estimated as follows: The Newton-Cotes 9-point rule is applied to both the bisected intervals to obtain S(x,w/2) and S(x+w/2,w/2) then e is estimated as
(4.6)
a f (x)dx
and w0 is the
width (b a) of the whole integration interval. This formula is based on a natural idea that the tolerable errors relevant to subintervals in proportion to each width. However, it is generally true that an approximation obtained by eliminating the dominant term in such a way done in the subroutine would be
128
AQN9
much more accurate than required. In this case, it seems to be too conservative to use (4.6) as it is. Instead it is advantageous to relax the criterion for short intervals having little effect on the total accuracy, to save the number of function evaluations. This subroutine employs (4.7) for this purpose:
e max a , r S w w0 log2 (w0 w)
homogeneous linear combination of function values at similar points with respect to the irregular point and has coefficients independent of interval width, moreover the sum of the coefficients is zero, the following can be seen:
Discontinuity point Logarithmic singularity Algebraic singularity Value ~ ei aproaches a constant value ~ e.
(4.7)
Although (4.7) is not based on a theoretical background, it is effective in practical use. The value S' in (4.7) is calculated using the average f of f(x) obtained in procedure 1 as follows: S = S + f (b x ) (4.8)
Detection and handling of irregular points Consider that the integration interval includes irregularities such as discontinuities, logarithmic singularities, and algebraic singularities. The Cauchy's singularities for which the integral diverges in the normal sense but converges as the Cauchy's principal integration is also considered. If the function value is infinite at these irregularities, the value shall be replaced with an appropriate finite value, for example, zero. Since the value e in (4.4) does not satisfy the convergence criterion when the subinterval includes a irregularity, subdivision will be repeated to produce a sequence of intervals each including the irregularity. Assume that the irregularity is at one of 2m -sectional point in the whole integration interval, where m is a positive integer. In this case, from some stage of repeated subdivision a sequence of subintervals {Ii , i=1,2,...} are generated which share the irregularity at a fixed end point, with the length of each subinterval being halved. For simplicity, assume the irregularity is at the origin (x=0) and at the left end point of the interval. (See Figure AQN9-2)
I1 I2 I4 I3 Fig. AQN9-2 Detection of irregularity
When ~ ei exhibits one of the above properties over the subinterval is calculated as follows: 1) Discontinuity point ... Let the jump at the irregular point be , then it is obtained from (4.4) as follows:
(4.8)
Since a discrepancy equal to has been added to the value of f0, it is only necessary to substitue f0 for f0 and perform calculation of (4.5). 2) Logarithmic singularity ... Assume the function in the vicinity of the irregular point to be: f(x)=logx+ Then, the value of is obtained from (4.4) as follows: (4.9)
(4.10)
Since
I=
0 f (x)dx = w(a(log w 1) + ),
w
f5 = f (w 2) = log(w 2) +
ei = e w derived from Consider a normalized error ~ normalizing the truncation error e by w. Let ~ ei denote the ~ ei is a e relevant to the interval Ii . Since ~
3) Algebraic singularity ... Assume the function in the vicinity of the irregular point to be: f ( x ) = x p + x p+1 + (4.12)
129
AQN9
Calculate , and using f0, f5=f(w/2), f10=f(w), , ~ e (~ e previous to ~ ei ); then, e (last ~ ei ), and ~ calculate the following analytically with these values:
w p w p +1 w I = f (x )dx = w + + p +1 0 p+2
zero, this point is assumed to be a Cauchy's singularity. The integral over this interval is calculated as the integral of the integrand minus the primary portion. Information storing In procedure 2, the following 10 items are stored in the stack: five function values f6, f7, f8, f9 and f10 relevant to the right-half portion f3, f5, f7, f8 of the interval (to be used as and f10 later; width w and the ei , ~ value of log2(w0/w); and three values of ~ ei , and ~ ei / ~ ei+1 , necessary to detect irregularities. In procedure 7, these items are retrieved in reverse order and processed again. The stack depth (the number of stack fields) is 60 in any case, that is, the required storage capacity is 600 elements. (See also references [96] and [97] for details.)
(4.14)
4) Cauchy's singularity ... Assume an algebraic singularity to be at the right end of an interval and order p of the singularity is equal to or less than -1. If the singularity is also an algebraic singularity at the left end of the interval on the right of the interval and its order is p, and the combination of the primary portion there of and that of the left interval results in
130
ASSM
Notes Saving the storage area: When the contents of array A or B are not required save the area as follows; When the contents of array A is not needed. CALL ASSM(A,B,A,N,ICON) When the contents of array B is not needed. CALL ASSM(A,B,B,N,ICON) In these cases, matrix C is stored in array A or B. Example The following shows an example of obtaining the addition of matrices A and B. Here, n100.
C **EXAMPLE** DIMENSION A(5050),B(5050),C(5050) DATA IA/1HA/,IB/1HB/,IC/1HC/ 10 READ(5,100) N IF(N.EQ.0) STOP WRITE(6,150) NT=N*(N+1)/2 READ(5,200) (A(I),I=1,NT) READ(5,200) (B(I),I=1,NT) CALL ASSM(A,B,C,N,ICON) IF(ICON.NE.0) GOTO 10 CALL PSM(IA,1,A,N) CALL PSM(IB,1,B,N) CALL PSM(IC,1,C,N) GOTO 10 100 FORMAT(I5) 200 FORMAT(4E15.7) 150 FORMAT(1H1///10X, * 21H** MATRIX ADDITION **) END
Function These subroutines perform addition of n n real symmetric matrices A and B. C=A+B where C is an n n real symmetric matrix. n1. Parameters A ..... Input. Matrix A, in the compressed mode, one-dimensional array of size n(n+1)/2. B ..... Input. Matrix B, in the compressed mode, one-dimensional array of size n(n+1)/2. C ..... Output. Matrix C, in the compressed mode, one-dimensional array of size n(n+1)/2. (Refer to "Comment on use".) N ..... Input. The order n of matrices A, B and C. ICON ... Output. Condition codes. Refer to Table ASSM-1.
Table ASSM-1 Condition code Code 0 30000 Meaning No error n<1 Processing Bypassed
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... none
Subroutine PSM in the example is for printing the real symmetric matrix. This program is shown in the example for subroutine MGSM.
131
ASVD1
U .....
Function Singular value decomposition is performed for m n real matrix A using the Householder method and the QR method. A=U V T (1.1)
Output. Matrix U. Two-dimensional array U(KU,N). (See "Comments on use".) KU ..... Input. Adjustable dimension (M) of array U. V ..... Output. Matrix V. Two-dimensional array V(KV,K), where K= min(M+1,N). (See "Comments on use".) KV .... Input. Adjustable dimension (N) of array V. VW ..... Work area. One-dimensional array of size n+1. ICON ... Output. Condition code. See Table ASVD1-1.
Table ASVD1-1 Condition code Code 0 15000 30000 Meaning No error Some singular values cannot be obtained. M<1,N<1,KA<M,KU<M,KV< N or ISW0,1,10,11. Processing Discontinued Bypassed
where U and V are matrices of m l and n l respectively, l=min(m,n). When l=n(mn), UTU=VTV=VVT=In When l=m(m<n), UT=UUT=VTV=Im is an l l diagonal matrix expressed by =diag(i ),i 0 and i is a singular value of A. Singular values i are the positive square root of the eigenvalues of matrix ATA and the i-th row of V is the eigenvector corresponding to the eigenvalue i . m1, n1. For dimensions of matrices A, U, , and V see Fig. ASVD1-1.
n (mn) n n m U n n n V
Comments on use Subprograms used SSL II ... AMACH, MGSSL FORTRAN basic functions ... MIN0, MOD, SIGN, SQRT, AMAX1, ABS Notes If you use decomposition factors U, , and V, from singular value decomposition, generalized inverse A+ of the original matrix A or least squares minimal norm solution of linear equations Ax=b can be obtained. (For details, see Section 3.5.) In this case, it is effective to use subroutine GINV or LAXLM. Although the singular value decomposition can be widely utilized (see Section 3.5), it requires a great amount of computation, this is a weak point. Therefore, U and V should be computed when they are required. When there is no need to compute them, since U and V are not referenced, the corresponding real arguments need not be two-dimensional array. ISW can control such requests. This subroutine allows rewriting of either U or V on A to reduce storage space. When A does not have to be saved, a real argument corresponding to U or V is written as a real argument and to reduce storage space. All singular values are non-negative and are stored in descending order. When ICON is set to 15000, only the non-negative values are singular values, and the rest are 1and are arranged randomly. The relationship of the number of columns m and the number of rows n of matrix A is not constrained in this subroutine. This subroutine can
n (m<n) m A m
m U
m m m
n V
Fig. ASVD1-1 Relationship between dimension of the matrices in singular value decomposition
Parameters A ..... Input. Matrix A. Two-dimensional array A(KA,N). (See "Comments on use".) KA ..... Input. Adjustable dimension (M) of array A. M ..... Input. Number of coumns in matrices A and U, and number of rows of V. ISW ... Input. Control information. ISW=10d1+d0 with 0d0 and d11, specified as follows: d1=0 ... Matrix U is not obtained. d1=1 ... Matrix U is obtained. d0=0 ... Matrix V is not obtained. d0=1 ... Matrix V is obtained. SIG .... Output. Singular values of matrix A. Onedimensional array of size l+1. (See "Comments on use".)
132
ASVD1
perform singular value decomposition for any types of m n matrices A's under any of the following conditions: m>n m=n m<n Example Singular value decomposition is performed for m n matrix A. All singular values and the corresponding columns of V are output. However, U is not computed and V is computed on A, where 1 n 100 and 1 m 100. Subroutine SVPRT in this example is used to print singular values and eigenvectors.
C **EXAMPLE** DIMENSION A(100,100),SIG(100),VW(100) 10 READ(5,500) M,N IF(M,EQ.0) STOP READ(5,510) ((A(I,J),I=1,M),J=1,N) WRITE(6,600) M,N DO 20 I=1,M 20 WRITE(6,610) (I,J,A(I,J),J=1,N) CALL ASVD1(A,100,M,N,1,SIG,A,100, * A,100,VW,ICON) WRITE(6,620) ICON IF(ICON.GE.15000) GO TO 10 CALL SVPRT(SIG,A,100,N,N) GO TO 10 500 FORMAT(2I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,20X,15HORIGINAL MATRIX, * 5X,2HM=,I3,5X,2HN=,I3/) 610 FORMAT(1H0,4(5X,2HA(,I3,1H,I3,2H)=, * E14.7)) 620 FORMAT(1H0,20X,5HICON=,I5) END SUBROUTINE SVPRT(SIG,V,K,N,M) DIMENSION SIG(N),V(K,M) WRITE(6,600) DO 20 INT=1,M,5 LST=MIN0(INT+4,M) WRITE(6,610) (J,J=INT,LST) WRITE(6,620) (SIG(J),J=INT,LST) DO 10 I=1,N 10 WRITE(6,630) I,(V(I,J),J=INT,LST) 20 CONTINUE RETURN 600 FORMAT(1H1,20X, * 30HSINGULAR VALUE AND EIGENVECTOR) 610 FORMAT(1H0,10X,5I20) 620 FORMAT(1H0,5X,2HSV,3X,5E20.7/) 630 FORMAT(5X,I3,3X,5E20.7) END
A=U V T
(4.1)
where U and V are m l and n l matrices respectively, l=min(m,n) and is an l l diagonal matrix expressed by =diag(i ),i 0, and when l=n(mn),UTU=V TV=VV T=In when l=m(m<n),UTU=UUT=VTV=Im The value of i is called the singular value of A. This subroutine does not constrain the size of m or n. It can decompose any type of matrices. Since m n matrix A, where mn, is generally used, it is shown below. Computation procedures This subroutine performs singular value decomposition of (4.1) by the following two stages. (a) Reduction to the upper bidiagonal matrix (the Householder method) Operating two finite sequences P1,...,Pn and Q1,...,Qn2 of Householder transformations from the right and left sides of matrix A alternatively J0=Pn
P AQ Q
1 1
n 2
(4.2)
0
ln qn
0 0
(m n) n
Ak l = Ak l2 Qk ,
, n k = 1, , n 2 , m , n
(4.3) (4.4)
Method The following singular value decomposition is performed for m n matrix A by using the Householder and QR methods.
133
ASVD1
Pk = I x k x kT bk Qk = I y k y ck
T k
, k = 1,
, n , k = 1, , n 2
k ( ) k ,k T ( k 12 ) ) k ,n ( k 12 ) k , k 1 )
(k) n ,k T
(4.5) (4.6)
where,
1 (4.7) 0 0
0 1
(k1) (k )
(b) Reduction to the diagonal matrix (the QR method) Choosing two orthogonal transformation sequences Si and Ti, for i=0,1,..., the matrix Ji +1 J i1= SiT J iTi (4.8)
can converge to the diagonal matrix . Namely, matrix can be repressed by using (4.9) for a certain integer q. = S qT
and Rk is defined in the same way using k instead of l. Angle k, k=2,...,n and angle k, k=3,...,n can be defined so that J can be an upper bidiagonal matrix for arbitrary 2 . Thus, the following steps should be taken with J=(jij). R2 generates non-zero element j21. L2T generates non-zero element j13 by eliminating j21. R3 generates non-zero element j32 by eliminating j13. Rn generates non-zero element jnn-1 by eliminating jn-2n. LnT eliminates jnn-1. Figure ASVD1-3 shows these steps with n=5.
1 1 2 3 4 5 q1 2 e2 q2 3 4 5
S J T T
T 0 0 0
(4.9)
*
e3 q3
(a) With these operations, matrix A will be transformed to a diagonal matrix and transformation matrices U and V are expressed as follows by using (4.1), (4.2) and (4.9)
*
e4 q4
*
e5 q5
P S S V = Q Q T T
U = P1
n 0 q 1 n2 0
(4.10) (4.11)
These can be generated by multiplying the transformation matrices from the right and left sides alternatively. In this case, matrix Ti in (4.8) must be defined such that symmetric tridiagonal matrix Mi = J iT J i converges to a diagonal matrix while matrix Si must be defined such that all Ji converges to bidiagonal matrices. How to select transformation matrices in QR method This section describes how to select transformation matrices Ti and Si in (4.8). For notation, use the following notation: J J i , J J i1 , S Si , T Ti , M J T J , M J T J J is transformed to J by alternatively operating the two-dimensional Givens rotation from left and right sides. Thus,
T n Ln 1 J = LT
Let
S=L2L3 T=R2R3
L
Rn
(4.13) (4.14)
then from (4.12), the following equation holds. J=STJT since J is an upper bidiagonal matrix, the M M=JTJ=TTMT (4.16) (4.15)
will be symmetric tridiagonal matrix such as M. The first rotating angle 2, that is, the first transformation R2 was not defined. 2 can be defined such that the transformation in (4.16) is a QR
L JR R R
T 2 2 3
(4.12)
134
ASVD1
transformation, with an origin shift s. Therefore, the following QR transformation can hold
T M s = Ts MTs
the matrix is split into direct sum of two submatrices, which will be processed independently. If the following holds for k (k1). qk 1 (4.21)
(4.17)
where M sI = Ts Rs RsTs + sI = M S TsT Ts = I Rs :upper triangular matrix To hold QR transformation, the first column of R2 should be proportioned to that of M sI. As the usual QR method, the origin shift s may be defined as the eigenvalue at the smallest absolute value, in the twodimensional submatrix in lower right of M. Actually Ts and T are equal. Convergence criterion and direct sum in QR method Convergence is tested as follows: When
en 1
operates the two-dimensional Givens rotation associated with the k-th column form the right side of J as follows: jk-2,k and jk,k-1 are generated when ek=jk-1,k is eliminated. jk-3,k and jk,k-2 are generated when jk-2,k is eliminated. .................................................................... Thus
q 1 e2
0 0
J=
1 2
ek 1 qk 10 k1 qk ek+1
(k ) en qn
0
(k1) (k)
(4.18)
12 + 22 + + k21 + q k2 = q k2 12
(4.22)
is satisfied, decrease the order of matrices by 1 after adopting as a singular value |qn|. where,
1 = J 0 u
and u is a unit round-off. If the following holds for some k (kn),
ek 1
(4.19)
All absolute values of 1, 2,..., k-1 are less than 1 then matrix J can be split into two submatrices. Every singular value is obtained within 30 times iteration of QR method. Otherwise, the processing is terminated and unobtained singular values are defined 1. For details, see Reference [11].
(4.20)
135
BDLX
Table BDLX-1 Condition code Code 0 10000 30000 Meaning No error The coefficient matrix was not positive-definite. NH<0 or NHN Processing Continued By passed
Comments on use Subprograms used SSL II .... MGSSL, FORTRAN basic functions ... None Notes This subroutine omits the operations concerning the elements out of the band so that the processing speed is faster than subroutine LDLX provided for a positive-definite symmetric matrix. Note that in this subroutine the decomposed matrices L and D-1 contained in the compressed mode for symmetric band matrix are required. A system of linear equations can be solved by calling this subroutine following the subroutine SBDL. However, subroutine LSBX can be usually called to solved such equations in one step. Example A system of linear equations is solved after first LDLT decomposition of n n coefficient matrix with band width h using subroutine SBDL. n100 and h50.
C **EXAMPLE** DIMENSION A(3825), B(100) 10 READ(5,500)N,NH IF(N.EQ,0)STOP NH1=NH+1 NT=N*NH1-NH*NH1/2 READ(5,510)(A(I),I=1,NT) WRITE(6,640) L=0 LS=1 DO 20 I=1,N L=L+MIN0(I,NH1) JS=MAX0(1,I-NH) WRITE(6,600)I,JS,(A(J),J=LS,L) 20 LS=L+1 CALL SBDL(A,N,NH,1.0E-6,ICON) WRITE(6,610)ICON IF(ICON.GE.20000)STOP READ(5,510)(B(I),I=1,N) CALL BDLX(B,A,N,NH,ICON) WRITE(6,610)ICON DET=A(1) L=1 DO 30 I=2,N L=L+MIN0(I,NH1) 30 DET=DET*A(L)
Where L is an n n unit lower band matrix with band width h, D is an n n diagonal matrix, b is an ndimensional real constant vector, x is an n-dimensional solution vector, and n>h0. Parameters B ..... Input. Constant vector b. Output. Solution vector x. One dimensional array with size n. FA .... Input. Matrices L and D-1. See Fig. BDLX-1. FA is a one-dimensional array of size n(h+1) h(h+1)/2 to contain L and D-1 in the compressed mode for symmetric band matrices.
Diagonal matrix D
d11 d 22 0
Array FA
1 d11
d nn
1 nn
l21
1 d 22
lh +1 1
h(h+1) 2 n(h+1)
1 l21 1 1 lh+11 0 l pn h
lnn h
1 d nn
Note: The diagonal and lower band portions of the matrix D-1+(L-1) are contained in one-dimensional array FA in the compressed mode for a symmetric band matrix. Fig. BDLX-1 How to contain matrices L and D-1
Input. Order n of matrices L and D. Input. Lower band width h. Output. Condition code. Refer to Table BDLX-1
136
BDLX
DET=1.0/DET WRITE(6,620)(B(I),I=1,N) WRITE(6,630)DET GO TO 10 500 FORMAT(2I5) 510 FORMAT(4E15.7) 600 FORMAT(1H ,1H(,I3,1H,,I3,1H)/(10X,5E17.8)) 610 FORMAT(/10X,5HICON=,I5) 620 FORMAT(/10X,15HSOLUTION VECTOR * //(10X,5E17.8)) 630 FORMAT(/10X, * 34HDETERMINANT OF COEFFICIENT MATRIX=, * E17.8) 640 FORMAT(/10X,12HINPUT MATRIX) END
Ly=b LTx=D-1y
(4.2) (4.3)
Solving Ly=b (Forward substitution) Ly=b can be serially solved using equations (4.4). yi = bi
i 1
k =max( 1,i h )
lik y k , i = 1, , n
(4.4)
Solving LTx=D-1y (Backward substitution) LTx=D-1y can be serially solved using equations (4.5). xi = yi d i1 lki x k , i = n, ,1
k =i +1 min(i+h,n)
(4.5)
(4.1) Where D-1 = diag(di -1), xT=(x1, ..., xn). For further details, see Reference [7].
137
BICD1
( l i +1, j n y l )
( 0 , j n y l )
Function Given function values fij=f(xi ,yj) at point (xi ,yj), (x1<x2<...<xnx,y1<y2<...<yny), on the xy plane, as well as partial derivatives fi,j(l,m), i=1,nx, j=1, ny, l=1, 2, ..., (m 1)/2, m=1,2, ..., (m 1)/2 at the boundary points, the interpolation coefficients c,s in the dual m-th (m:odd integer) degree B-spline two-dimensional interpolating function s x, y =
fi , j = f n x ,n y
( i n x l , j n y l )
( )
ny 1
nx 1
= m+1 = m +1
c , N ,m+1 ( x ) N ,m+1 y
()
(1.1)
are obtained with restriction m3, nx2 and ny2. For later use, we introduce below a notation fi , j with l=(m 1)/2 for convenience. And a matrix consisting of fi , j as elements is shown in Fig. BICD1-1.
( l i +1, l j +1) fi , j = f 11
f
i,j
= f
( 0 ,l j +1) i l ,1
fi , j = f
( i n x l ,l j +1) n x ,1
Parameters X ..... Input Discrete points xj's in the x-direction. NX .... Input. Number of the xi 's. Y ..... Input. Discrete points yj's in the y-direction. One-dimensional array of size ny. NY .... Input. Number of the yj's. FXY ... Input. Function values and partial derivatives, fi , j 's. Two-dimensional array as FXY (K,NY+M-1). FXY (I,J) is assigned fi , j . See Fig. BICD1-1. K ..... Input. Adjustable dimension for arrays FXY and C(KNX+M-1). M ..... Input. Degree of the B-spline. See Note. C ..... Output. Interpolation coefficients, c's. Two-dimensional array as C(K,NY+M-1) C-m+i ,-m+j is put out in C(I,J). VW .... Work area. One-dimensional array of size. {max(nx,ny)+1)(m+2)-3+(m+1)2/2. ICON .. Output. Condition code. See Table BICD1-1. Comments on use Subprograms used SSL II ... MGSSL, UMIO1, UCIO1, UBAS1 and ULUI1 FORTRAN basic functions ... MOD and FLOAT
fi , j = f i l , j 1
nx l , 0 ) fi , j = f n(xi , j 1
j=1
j=+1
j=+2
j=nr+-1 j=nr+
j=nr+2
Function value and partial derivatives at (x1,y1) Function value and partial derivatives at (xi,y1)
Function value and partial derivatives at (x1,yj) Function value at (xj,y j) ,where 2inx1, 2jny1 Function value and partial derivatives at (xnx,yj-)
Function value and partial derivatives at (x1,yny) Function value and partial derivatives at (xi,yny)
138
BICD1
Table BICD1-1 Condition codes Code 0 30000 Meaning No error Either of the followings occurred. (a) M is not an odd number. (b) xi which satisfies xixi+1 exists. (c) yi which satisfies yiyi+1 exists. (d) M<3 (e) NX<2 or NY<2 Processing Bypassed
with c's being arbitrary constants. The Nm1(x), Nm+1(y) are both m-th degree B-splines and represented respectively by N ,m+1 ( x ) = (s + m+1 s )gm+1 [s , s +1 , , s + m+1 ; x ] N ,m+1 ( y ) = t +m+1 t gm+1 t , t +1 , , t + m+1 ; y (4.2) (4.3)
) [
where sequences of {si } and {tj} are the same as for the one-dimensional B-spline interpolating function (I). Let's define N ,i and N ,i as follows: ( li+1) N ,m+1 x1 = N ,m+1 xil nx l ) N ( i, x nx m+1 ( li+1) N ,m+1 y1 = N ,m+1 yil ( i nx l ) N y nx ,m +1
Notes By calling the subroutine BIFD1 after subroutine BICD1, the interpolated values based on the B-spline interpolating function (1.1), as well as derivatives and/or integrals can be obtained. The parameter values of X, NY, Y, NY, K, M and C are passed from BICD1 to input to BUFD1. The degree m is preferably 3 or 5. In double precision, if the original function is smooth and fij's are given with high accuracy, the degree may be increased above 3 or 5, but not beyond 15. Example See the example given for subroutine BIFD1. Method The B-spline two-dimensional interpolating function S(x,y) to be obtained here is a direct extension of the B-spline interpolating function (I) obtained by subroutine BIC1. In other words, S(x,y) is defined in the region R =
N ,i
( ) ( )
: i = 1,2, , l + 1 : i = l + 2, l + 3, , nx + l 1
x x
( ): i = n + l, n + l + 1,
: i = 1,2,, l + 1
, nx
+ 2l
N ,i
( ) ( )
( ): i = n + l, n
x
: i = l + 2, l + 3,, nx + l 1
x
+ l + 1, , nx + 2l
Then the coefficients in (4.1) can be uniquely determined by the interpolation condition (c). By using (4.1), the condition (c) can be stated as
ny 1
, = m+1 = m+1
{ c
nx 1
,i N , j = f N i, j
(4.4)
{(x, y) x x < x
1
nx
, y x y y ny
} and
satisfies the following conditions: (a) The S(x,y) is a dual m-th degree, at most, polynomial in each of the partial region Ri , j =
{(x, y) x x < x
i
i +1
, y j y < y j+1
The dual m-th degree means that the function is of degree m with respect to both x and y. (b) S x , y C ml ,m1 [R] i.e., for =0, 1, ..., C m- l,m-1, and =0,1,...,m-1,
( )
and this can be further rewritten to a simpler form by defining several matrices as follows: F is an (nx+m 1) by (ny+m 1) matrix with the elements fi , j 's C is an (nx+m 1) by (ny+m 1) matrix with the elements C's is an (nx+m 1) by (ny+m 1) matrix whose i-th ,i 's, where = m+1, m+2,..., n row consists of N x 1 is an (nx+m-1) by (ny+m 1) matrix whose j-th row ,i 's, where = m+1, m+2,..., n -1 consists of N y By using these matrices, Eq.(4.4) can be rewritten to C T = F (4.5)
+ S ( x, y) xy
exists and also is continuous. (c) S xi , yi = f i , j , i = 1,2,, nx , j = 1,2,, ny S ( , ) xi , y j = f i ,(j , ) , i = 1, nx , j = 1, n y
= 1,2,, (m 1) 2 , = 1,2,, (m 1) 2 The S(x,y) which satisfies (a) and (b) above can be represented as
S x, y =
as (nx+m 1) systems of linear equations of order (ny+m 1) and then we can solve them for matrix X. Next, considering C = X T (4.7)
( )
ny 1
nx 1
= m+1 = m+1
c , N ,m+1 ( x ) N ,m+1 y
()
(4.1)
139
BICD1
as (ny+m 1) systems of linear equations of order (nx+m 1) then they can be solved for matrix C. Matrices and are of exactly the same form as the coefficient matrices in the linear equations when obtaining the onedimensional B-spline interpolating function (I). See the
explanation for subroutine BIC1. This subroutine solves the linear equations, (4.6) and (4.7), by using Crout method (LU decomposition method) in the slave subroutines UMIO1, UCIO1 and ULUI1.
140
BICD3
Here m3, nxm+2 and nym+2 Parameters X ..... Input. Discrete points xi 's in the x-direction. One-dimensional array of size nx. NX .... Input. Number of the xj's, nx. Y ..... Input. Discrete points yj's, in the y-direction. One-dimensional array of size ny NY .... Input. Number of the yj's, ny FXY ... Input. Function values fij Two-dimensional array as FXY(K,NY). FXY(I,J) is to be assigned fij K ..... Input. Adjustable dimension for arrays FXY and C(KNX). M ..... Input. Degree of the B-spline, m. See Note. C ..... Output. Interpolation coefficients c,. Two-dimensional array as C(K,NY). c-m+i,-m+i is put out to C(I,J). XT ... Output. Knots {i } and {j}. One dimensional array of size (nx m+1) + (ny m+1). {i } is put out first followed by {j}. VW .... Work area. One dimensional array of the following size: {max(nx,ny)-2}m + 2(m+1)+2max(nx,ny). ICON .. Output. Condition code. See Table BICD3-1.
Function Given function values fij=f(xi ,yj) at points (xi ,yj) (x1<x2<...<xnyy1<y2<...<yny), on the xy-plain, the interpolation coefficients c's of dual m-th degree (m odd integer) B-spline two-dimensional interpolationg function. S ( x, y) =
ny m nx m
= m +1 = m+1
c , N ,m+1 ( x ) N ,m+1 ( y )
(1.1)
are obtained. The knots of S(x,y) are as shown in (1,2) as for x-direction, and as shown in (1.3) as for ydirection. (See Fig. BICD3-1.) x ,i =1 1 i = xi + ( m1) /2 , i = 2,3, , nx m , i = nx m + 1 xnz y , j =1 1 j = y j +( m1) / 2 , j = 2,3, , n y m , j = ny m + 1 y ny
y
(1.2)
(1.3)
t8 t7 t6 t5
y7
y6
t4
y5
t3
3 2
y4
t2
y3
y2
t2 t1 t0 t1
y1
x1
x2
x3
x4
x5
x6
x7
1
s1 s0 s1 s2
2
s2
3
s3
4
s4
5
s5 s6 s7 s8
Fig. BICD3-1 Knots {i} and {ni} (for nx=ny=7 and m=3)
141
BICD3
Table BICD3-1 Condition codes Code 0 30000 Meaning No error One of the followings occurred: (a) M is not an odd integer. (b) NX<M+2 or NY<M+2 (c) xi which satisfies xixi+1 exists. (d) yi which satisfies yiyi+1 exists. (e) M<3 Processing Bypassed
with the c's being arbitrary constants. The N,m+1(x) and Nm+1(y) are both the m-th degree B-splines and represented respectively by N ,m+1 ( x ) = (s + m+1 s )gm+1 [s , s +1 , , s + m+1 ; x ] (4.2) N ,m+1 ( x ) = t + m+1 t gm+1 t , t +1 , , t + m+1 ; y
) [
(4.3)
Comments on use Subprograms used SSL II ... MGSSL, UMIO3, UCIO3, UBAS1 and ULUI3 FORTRAN basic functions ... MOD and FLOAT Notes By calling the subroutine BIFD3 after subroutine BICD3, the interpolated values based on the B-spline interpolating function (1.1), as well as derivatives and/or integrals can be obtained. The parameter values of X, NX, Y, NY, K, M, C and XT are passed from BICD3 to input to BIFD3. The degree m is preferably 3 or 5. In double precision, if the original function is smooth and fij's are given with high accuracy, the degree may be increased above 3 or 5, but not beyond 15. Example See the example given for subroutine BIFD3. Method The B-spline two-dimensional interpolating function S(x,y) to be obtained here is a direct extension of the Bspline interpolating function (III) obtained by subroutine BIC3. In other words, taking knots {i } and {j} in the x- and y-directions as shown in (1.2) and (1.3), S(x,y) is defined in the region R={(x,y) | x1 x xnx, y1 y yny}and satisfies the following conditions: (a) The S(x,y) is a dual m-th degree, at most, polynomial in each of the partial region Ri,j.=
where knots {si } and {tj} are the same as for the onedimensional B-spline interpolating function (III). An example is shown in Fig. BICD3-1. The coefficients in (4.1) can be uniquely determined by the interpolation condition (c). By using (4.1), condition (c) canbe stated as
n x m c , N ,m+1 ( xi ) N ,m+1 ( yi ) = f ij = m +1 = m +1 i = 1, 2, , nx , j = 1, 2, , n y ny m
(4.4)
and can be further rewritten to a simpler form by defining several matrices as follows: F is an nx ny matrix with the elements fij C is an nx ny matrix with the elements c is an nx ny matrix whose i-th row consists of N,m+1(xi ), where = m+1,..., nx m is an nx nx matrix whose j-th row consists of N,m+1(yi ), where = m+1,..., ny m By using these matrices above, Eq.(4.4) can be rewritten as C T = F (4.5)
as nx systems of linear equations of order ny and then we can solve them for the matrix X. Next, considering C = X T (4.7)
{(x, y) x
i
i +1, j
= 0, 1, , m 1,
continuous. (c) S(xi ,yj)=fiji=1,2,...,nxj=1,2,...,ny. The S(x,y) which satisfies (a) and (b) above, can be represented as S ( x, y) =
ny m nx m
as ny systems of linear equations of order nx then they can be solved for matrix C. The matrices and are exactly of the same form as the coefficient matrix in the linear equations when obtaining the one-dimensional Bspline interpolating function (III). (See the explanation for subroutine BIC3.) This subroutine solves the linear equations, (4.6) and (4.7), by using Crout method (LU decomposition method) in the slave subroutines UMIO3, UCIO3 and ULUI3.
= m +1 = m+1
c , N ,m+1 ( x ) N ,m+1 ( y )
(4.1)
142
BIC1
Table BIC1-1 Condition codes Code 0 30000 Meaning No error Either of the followings occurred: 1 M is not an odd integer. 2 xi which satisfies xixi+1 exists. 3 M<3. 4 N<2. Processing Bypassed
Function Given function values yi , f(x), i=1, 2, ..., n, at the discrete points x1, x2, ..., xn(x1 < x2 < ... <xn), , as well as derivatives yl(1) = f(x1) and yn(1) = f(xn), l=1, 2, ..., (m 1)/2, at both end points xi and xn, the interpolation coefficients, cj's, j= m+1, m+2, ..., n 1, in the interpolating function represented as a linear combination of B-splines of degree m(odd integer), S ( x ) = c j N j ,m+1 ( x )
n 1 j = m +1
(1.1)
Comments on use Subprograms used SSL II ... MGSSL, UMIO1, UCIO1, UBAS1 and ULUI1 FORTRAN basic functions ... MOD and FLOAT Notes By calling the subroutine BIF1 after subroutine BIC1, the interpolated values based on the B-spline interpolating function (1.1), as well as derivatives and/or integrals can be obtained. The parameter values of X, N, M and C are passed from BIC1 to input to BIF1. The degree m is preferably 3 or 5. In double precision, if the original function is smooth and yi 's are given with high accuracy, the degree may be increased above 3 or 5, but not beyond 15. Example See the example given for subroutine BIF1. Method The m-th degree B-spline interpolating function S(x) to be obtained here is a function defined in the interval [xl,xn] and satisfying the following conditions: (a) S(x) is polynomial at most of degree m in the subinterval [xi , xi +1] , i=1, 2, ..., n 1. (b) S(x) Cm-1[xl,xn],i.e., S(x) and its derivatives of up to order (m 1) are conditnous in the interval [xi ,xn]. (c) S(xj)=yn, i=2,3,...,n 1 (d) S(l)(xl) = yl(l), S(l)(xn) = yn(l), l=0, 1, ..., (m 1)/2 A m-th degree spline function defined with knots {tj}, j = m+1,m+2,...,n+m, taken as x1 t j = x j x n : j = m + 1,m + 2, ,1 : j = 2,3, , n 1 : j = n, n + 1, , n + m
Here m3 and n2. Parameters X ..... Input. Discreate points, xj's. One-dimensional array of size n. Y .... Input. Function values, yj's. One-dimensional array of size n. DY .... Input. Derivatives at end points x1 and xn. Two-dimensional array of DY(2,(m 1)/2)). DY(1,l) and DY(2, l) are assigned y1(l) and yn(l), respectively for l=1,2,...,(m 1)/2. N ..... Input. Number of the discrete points, n. M ..... Input. Degree of the B-spline, m See Note. C ..... Output. Interpolating coefficients cj's. One-dimensional array of size n+m 1. VW .... Work area. One-dimensional array of size (n 2)m+(m+1)2/2+(m+1). ICON .. Output. Condition code. See Table BIC1-1.
(4.1)
(4.2)
143
BIC1
where, Nj,m+1(x) is the m-th degree B-spline and given by N j ,m+1 ( x ) = t j +m+1 t j gm+1 t j , t j+1 , , t j + m+1 ; x (For details, see Chapter 7, 7.1) Considering locality of Nj,m+1(x),
) [
are given with cj's; j= m+1, m+2,...,n 1, unknown. By solving these equations all of the interpolation coefficients cj's can be obtained. The form of the coefficient matrix in the linear equations (4.4) is shown in Fig. BIC1-1 as an example for m=5 and n=8.
N j ,m+1
( )
> 0 : j = i m, i m + 1, , i 1 j = m + 1, m + 2, , i m 1 xi = = 0 : j = i , i + 1, , n 1
( )
( )
(4.3) and applying the interpolation conditions (c) and (d) described above to Eq. (4.2), a system of (n+m 1) linear equations m+1+l c N ( l ) x = y ( l ) : l = 0,1, , m 1 2 j j ,m+1 ( 1 ) ( ) 1 j = m +1 i 1 c j N j ,m+1 ( xi ) = yi : i = 2,3, , n 1 = j i m 1 ) (l) n c j N (j ,lm +1 ( xn ) = yn : l = ( m 1) 2 , ( m 1) j = n1 l 2 1 , ,0
Fig. BIC1-1 Coefficient matrix (in the case of m=5 and n=8)
The subroutine solves the linear equations by using the Crout method (LU decomposition). Subroutines UMIO1, ULUI1 and UCIO1 are called.
(4.4)
144
BIC2
Table BIC2-1 Condition codes Code 0 30000 Meaning No error Either of the followings happened. 1 M is not an odd integer. 2 xi which satisfies xixi+1 exists. 3 M<3 4 N<(M+1)/2 Processing Bypassed
Function Given function value yi =f(xj), i=1,2,...,n at the discrete points x1, x1, ..., xn(x1<x2<...<xn), as well as derivatives yn(l) = f(x1) and yn(l) = f(xn), l=(m+1)/2, (m+1)/2+1, ..., m 1 at both end points x1 and xn, the interpolating coefficients cj's, j= m+1, m+2, ..., n 1 in the interpolating function represented as a linear combination of B-splines of degree m (odd integer), S ( x ) = c j N j ,m+1 ( x )
n 1 j = m +1
(1.1)
Comments on use Subprograms used SSL II ... MGSSL, UMIO2, UCIO2, UBAS1 and ULUI1 FORTRAN basic functions ... MOD and FLOAT Notes By calling the subroutine BIF2 after subroutine BIF2, the interpolated values based on the B-spline interpolating function (1.1), as well as derivatives and/or integrals can be obtained. The parameter values of X, N, M and C are passed from BIC2 to input to BIF2. The degree m is preferably 3 or 5. In double precision, if the original function is smooth and yi 's are given with high accuracy, the degree may be increased above 3 or 5, but not beyond 15. Example See the example given for subroutine BIF2. Method The m-th degree B-spline interpolating function S(x) to be obtained here is a function defined in the interval [x1,xn] and satisfying the following conditions: (a) S(x) is a polynomial at most of degree m in the subinterval [xi ,xi +1], i=1, 2, ..., n 1. (b) S(x)Cm-1 [x1,xn] i.e., S(x) and its derivatives of up to order (m 1) are continuos in the interval [x1,xn]. (c) S(xi )=yi , i=1,2,..,n (d) S(l)(x1)=y1(l), S(l)(xn)=yn(l) l = (m+1)/2, (m+1)/2+1, ..., m 1 A m-th degree spline function defined with knots {tj}, j = m+1, m+2, ..., n+m, taken as
Here, m3, and n(m+1)/2. Parameters X ..... Input. Desecrate Points, xi 's. One-dimensional array of size n. Y ..... Input. Function values yj's. One dimensional array of size n. DY .... Input. Derivatives at end points x1 and xn Two-dimensional array of DY(2,(m 1)/2). DY(1,l-(m 1)/2) and DY(2,l(m 1)/2) are assigned y1(l) and yn(l), respectively, for l=(m+1)/2,(m+1)/2+1,...,m 1 N ..... Input. Number of the discrete points, n. M ..... Input. Degree of the B-spline, m. See Note. C ..... Input. Interpolation coefficients cj's. One-dimensional array of size n+m 1. VW .... Work area. One-dimensional array of size m(n+m 3)+2(m+1). ICON .. Output. Condition code. See Table BIC2-1.
x1 t j = x j x n
: j = m + 1, m + 2, : j = 2,3, , n 1 : j = n, n + 1,
,1
(4.1)
, n + m
(4.2)
145
BIC2
where, Nj,m+1(x) is the m-th degree B-spline and given by N j ,m+1 ( x ) = t j +m+1 t j gm+1 t j , t j +1 , , t j +m+1 ; x (For details, see Section 7.1) Considering locality of Nj,m+1(x), > 0 : j = i m, i m + 1, i 1 N j ,m +1 ( x i ) j = m + 1, m + 2 , , i m 1 = 0 : j = , i + 1, , n 1 0 : j = m + 1, m + 2, , m + 1 + l ) N (j l,m x +1 ( 1 ) = 0 : j = m + 2 + l , m + 3 + l , , n 1 = 0 : j = m + 1, m + 2 , , n 2 l ) N (j l,m +1 ( x n ) 0 : j = n 1 l , n l , , n 1 (4.3) and applying the interpolation conditions (c) and (d) described above to Eq. (4.2), a system of (n+m 1) linear equations
+1+l (l ) (l ) m c j N j ,m+1 ( x1 ) = y1 : l = ( m + 1) 2 , ( m + 1) 2 + 1, j= m+1 , m 1 (4.4) i1 c j N j,m+1 ( xi ) = yi :i = 1,2,, n j= i m n1 ) (l ) c j N (j,lm , m 2,, (m + 1) 2 +1 ( xn ) = yn : l = m 1 = 1 j n l
) [
(4.2)
are given with cj's; j= m+1, m+2,...,n 1, unknown. By solving these equations all of the interpolation coefficients cj's can be obtained. The form of the coefficient matrix in the linear equations (4.4) is shown in Fig. BIC2-1 as an example for m=5 and n=8.
The subroutine solves the linear equations by using the Crout method (LU decomposition). Subroutines UMIO2, ULUI2 and UCIO2 are called.
146
BIC3
Function Given function value S yi =f(xi ), i=1,2,...,n for discrete points x1, x2, ..., xn(x1<x2<...<xn) this subroutine obtains the interpolating spline S(x)of degree m represented as a linear combination of B-splines: S ( x ) = c j N j ,m+1 ( x )
j = m +1 nm
Notes The interpolated values or derivative or integrals based on the interpolating spline (1.1) may be determined by the subroutine BIF3 following this subroutine. In that case the values of parameters X, N, M, C, and XT are input to the subroutine BIF3. The preferred degree m is 3 or 5. In double precision, however, if the original function does not change obruptly and yi is given with high accuracy, the degree may be increased above 3 or 5, but not beyond 15. Example See the example for the subroutine BIF3. Method Given function values yi =f(xi ). i=1,2,...,n for discrete points x1,.x2,...,xn(x1<x2<...<xn) the interpolating spline of degree m to be obtained here is a function which is defined on the interval [ x1,xn] and satisfies the following requirements. (a) S(x) is polynomial of degree m at most on each subinterval [i , i +1], i=1, 2, , n m , 1=x1, i =xi +(m-1)/2 , i=2, 3, , n m , n-m+1=xn (b) S(x)Cm-1[xl,xn]. That is, S(x) and its derivatives of up to order m-1 are continuous on the interval [x1,xn]. (c) S(xi )=yi , i=1,2,..,n The S(x) satisfying (a), (b) and (c) can be given by S ( x ) = c j N j ,m+1 ( x )
j = m +1 nm
(1.1)
(4.1)
where cj's, j= m+1, m+2,...,n m, are constants, Nj,m+1(x) is a normalized m-th degree B-spline and defined by N j ,m+1 ( x ) = t j +m+1 t j gm+1 t j , t j +1 , , t j + m+1 ; x
) [
(4.2)
(For details, see Section 7.1) In this subroutine, the knots {tr} of the B-spline is given by 1 t r = r n m+1 , r = m + 1,m + 2, ,1 , r = 2,3, , n m , r = n m + 1, n m + 2, , n + 1
(4.3)
Comments on use Subprograms used SSL II ........ MGSSL, UMIO3, UCIO3, UBAS1 and ULUI3 FORTRAN basic function ........ MOD
A typical behavior of Nj,m+1(x) with the knots {tr} is shown in Fig. BIC3-1. The interpolation coefficients cj's can be determined by solving the linear equations:
147
BIC3
N1,4(x)
N0,4(x)
N2,4(x)
N3,4(x)
x1
x2
x3
x4
x5
x6
x7
1 t1 t0 t1 t2
2 t2
3 t3
4 t4
5 t5 t6 t7 t8
Fig.BIC3-1 Example of B-spline Nj,m+1(x) : = 3, with seven discrete points at equal intervals
S ( xi ) = c j N j ,m+1 ( xi ) = yi , i = 1,2, , n
j = m +1
nm
(4.4)
which satisfies the interpolation conditions. The coefficient matrix of the equations have many null elements because of locality of the B-spline and therefore, it has a similar form to a banded matrix. An example of the coefficient matrix is given in Fig. BIC3-2 for the case, n=7 and m=3.
0 0
Fig. BIC3-2 Coefficient matrix (n =7 and m =3)
The subroutine solves these linear equations by using Crout method (LU decomposition method). Subroutine ULUI3 is called.
148
BIC4
Comments on use Subprograms used SSL II ... MGSSL, UMIO4, UCIO4, UBAS4 ULUI4 and UPEP4 FORTRAN basic functions ... MOD and FLOAT Notes By calling the subroutine BIF4 after subroutine BIC4, the interpolated values based on the B-spline interpolating function (1.1), as well as derivatives and/or integrals can be obtained. The parameter values of X, N, M and C are passed from BIC4 to input to BIF4. The degree m is preferably 3 or 5. In double precision, if the original function is smooth and yj's are given with high accuracy, the degree may be increased above 3 or 5, but not beyond 15. Example See the example given for subroutine BIF4. Method The m-th degree B-spline interpolating function S(x) to be obtained here is a function defined in the interval [x1,xn] and satisfying the following conditions: Condition (c) is necessary for S(x) to be periodic and is peculiar to this subroutine. (a) S(x) is polynomial at most of degree m in the interval [xi ,xi +j], =1, 2, ... n 1. (b) S(x)Cm-1 [xi ,xn] , i.e., the S(x) and its derivatives of up to order m1 are continuous in the interval [xi ,xn]. (c) S(l)(x1) = S(l)(xn), l=0,1,...,m 1 (d) S(xj)=yi , i=2,3,..,n (y1=yn is assumed) First, the spline function satisfying condition (c) will be explained. We take the knots {tj} of the B-spline as follows (see Fig. BIC4-1): xn 1 j ( xn x1 ) , m + 1 j 0 t j = x j ,1 j n x n +1+ j + ( xn x1 ), n + 1 j n + m
Function Given periodic function values yi =f(x), i=1, 2, ..., n, (where y1=yn) at the discrete points x1, x2, ..., xn (x1<x2<...<xn) with the period (xnx1), the interpolation coefficients cj's, j=m+1, m+2, ..., n 1 in the interpolating function represented as a linear combination of B-splines of degree m (odd integer), S ( x ) = c j N j ,m+1 ( x )
n 1 j = m +1
(1.1)
are obtained. The obtained S(x) is a periodic function with the period (xnx1) similarly to f(x) and satisfies the boundary conditions: S ( l ) ( x1 ) = S ( l ) ( x n ), l = 0,1,, m 1 (1.2)
Here m 3 and n m + 2.
Parameters X ..... Input. Discrete points, xi 's. One-dimensional array of size n. Y ..... Input. Function values yj's. One dimensional array of size n. Must be y1=yn. If y1yn, yn is taken. N ..... Input. Number of the discrete points, n. M ..... Input. Degree of the B-spline, m. See Notes. C ..... Input. Interpolation coefficients cj. One-dimensional array of size n+m1. VW .... Work area. One-dimensional array of size (n1)(2m1)+m+1 ICON .. Output. Condition code. See Table BIC4-1.
Table BIC4-1 Condition codes Code 0 30000 Meaning No error Either of the followings occurred. (a) M is not an odd integer. (b) N<M+2 (c) xi satisfying xixi+1 exists. (d) M<3 Processing Aborted
(4.1)
The m-th degree spline function based on this knots can be expressed with cj's being arbitrary constants: S ( x ) = c j N j ,m+1 ( x )
n 1 j = m +1
(4.2)
where Nj,m+1(x) is the m-th degree B-spline and given by N j ,m+1 ( x ) = t j +m+1 t j gm+1 t j , t j+1 , , t j + m+1 ; x (For further details, see Section 7.1) Adding the condition:
) [
149
BIC4
c j = c j +n 1 , j = m + 1, ,0
(4.3)
to Eq. (4.2), the periodic condition (c) described above is satisfied. Next, the interpolation condition (d) is written as
n 1
j = m +1
c j N j ,m+1 ( xi ) = yi , i = 2, , n
(4.4)
can be obtained. Eq. (4.6) is a system of linear equations with (n 1) unknowns cj's ( j=l+2,l+3,...,n l ). Solving the equations and using the relationships (4.5), all of the interpolation coefficients cj's of the spline function (4.2) can be obtained. The coefficient matrix of equations (4.6) has a form similar to a banded matrix. An example is given in Fig. BIC4-2 for the case of m=5(l=3) and n=9.
0 0
j = l +2
{ ( ) + c {N i = 2,3, , n
( )} + c N ( x ) (x ) + N (x )} = y
n2 l j =1 j j ,2 l i j ,2 l i i
(4.6) The subroutine solves the linear equations given above by using Crout method (LU decomposition method). Subroutines UMIO4, ULUI4 and UCIO4 are called.
tm+1
t1
t0
x1 t1
x2 t2
x1+m
xnm
150
BIFD1
Function When, on the xy-plane, the function values fij= f(xi , yj) are given at the points (xi , yi ), (x1 < x2 < < xnx, y1 < y2 < < yny), and also the following partial derivatives are given at the boundary points, an interpolated value or a partial derivative at point P(vx, vy) or a double integral on the area {(x,y) | x1 x vy , y1 y vg}are obtained. (See Fig. BIFD1-1) f 1,( j , 0) = f ( ,0 ) x1 , y j f f
( 0 , ) i ,1 ( , ) 11
, f n(x, ,j0) = f ,f ,f
( 0, ) i ,n y
( ,0 )
= f = f
( 0 , )
( , )
(x , y ) (x , y )
i 1
= f = f
( 0, )
(x , y )
i
(x
nx
, yj
ny
( , ) nx ,1
( , )
(x
nx
, y1
i = 1,2, , nx , j = 1,2, , ny
= 1,2, , (m 1) 2 , = 1,2, , (m 1) 2
y yny
P(vx,vy)
y3 y2 y1 x x1 x2 x3 xn x Fig. BIFD-1 Point p in the area R={(x,y) | x1 xnx , yy1 y yny}
Parameters X ..... Input. Discrete points, xi 's in the x direction. One-dimensional array of size nx. NX .... Input. Number of xj's, nx. Y ..... Input. Discrete points yj's in the y direction. One-dimensional array of size ny. NY .... Input. Number of yl's, ny. M ..... Input. Degree of the B-spline. See Notes. C ..... Input. Interpolating coefficients C, (output from BICD1). Two-dimensional array as C(K,NY+M-1). K ..... Input. Adjustable dimension for array C. KNX+M-1). ISWX .. Input. An integer which specifies the type of calculation in the direction of x. 1ISWXm See the parameter F VX .... Input. x-coordinate at point P(vx,vy). IX .... Input. Value i which satisfies xi vx<xi +1. If vx=xnx then IX=nx-1 Output. Value i which satisfies xi vx<xi +1. ISWY .. Input. An integer which specifies the type of calculation in the direction of y. 1ISWYm(See the parameter F) VY .... Input. y-coordinate at point P(vx,vy). IY .... Input. Value j which satisfies yjvy<yj+1. If vy=yny, then IY=ny-1 Output. Value j which satisfies yjvy<yj+1. See Note (b). F ..... Output. Interpolated value, partial derivative or integral obtained. Setting ISWX= and ISWY=, one of the following values is put out depending on combination of and . When 0,
+ F = S vx , vy x y
However, subroutine BICD1 must be called before using subroutine BIFD1 to calculate the interpolating coefficients C, in the B-spline two-dimensional interpolating function, S x, y =
( )
n y 1
nx 1
= m +1 = m+1
c , N ,m+1 ( x ) N ,m+1 y
()
(1.1)
vx x1
S x , v y dx y
where m is an odd integer and denotes the degree of the B-splines, N,m+1(x) and N,m+1(y). Here x1xnx,y1yyny, m3 and ny2.
When 0, 1 F=
vy y1
S (v x , y )dy x
When ==1
F=
vy y1
dy
vx x1
S ( x , y )dx
151
BIFD1
VW ....
ICON ..
Work area. One-dimensional array of size 4(m+1) + max(nx,ny)+m 1 Output. Condition code. See Table BIFD1-1.
Table BIFD1-1 Condition codes Code 0 10000 Meaning No error Either X(lX)VX<X(lX+1) or Y(lY)VY<Y(lY+1) is not satisfied. Processing lX or lY shown on the left is searched for in the subroutine and the processing is continued. Bypassed
30000
Either of the followings occurred: 1 VX<X(1) or VX>X(NX) 2 VY<Y(1) or VY>Y(NY) 3 ISWX<-1 or ISWX>M 4 ISWY<-1 or ISWY>M
f f f f f f
f f f f f f
(0,2)
11 (0,1) 11
f f
(0,2) 21 (0,1) 21
... ...
31
11
f ,f
21
f f f f f f
f f f f f f
:
(1,2) 1,ny (1,1) 1,ny (1,2) 1,ny
:
1,ny (0,1) 1,ny (0,2)
:
nx,ny (0,1) nx,ny (0,2) nx,ny
:
(1,0) nx,ny (1,1) nx,ny (1,2) nx,ny
1,ny
f f f
Comments on use Subprograms used SSL II ... MGSSL, UCAD1 and UBAS1 FORTRAN basic function ... FLOAT Notes The subroutine, based on the B-spline two-dimensional interpolating function (1.1) given by using subroutine BICD1, obtains an interpolated value, a partial derivative or a double integral. Therefore subroutine BICD1 must be called to obtain the interpolating function (1.1) before calling this subroutine to obtain an interpolated value, etc. Also parameters X, NX, Y, NY, K, M and C must be directly passed from subroutine BICD1. Parameters IX and IY should satisfy the relationships X(IX)VX<X(IX+1) and Y(IY)VY<Y(IY+1), respectively. If not, IX and IY that satisfy those relationships are searched for to continue the processing. Example By inputting points (xi,yi), function values fij, i=1,2,...,nx, j=1, 2, ..., ny, partial derivatives fi,j( , ),i=1,nx, j=1,ny,=1, 2, ..., (m 1)/2, =1, 2, ..., (m 1)/2, and degree m, interpolated values or partial derivatives at points (vir,ujs); vir. xi+(xi+1 xi)(r/4),js=yi+(yi+1) (s/4), i=1, 2, ..., nx1, j=1, 2, ..., ny1 , r=0, 1, ..., 4, s=0,1,...,4, or integrals over the area {(x,y) | x1 x vir , y1 y ujs}) are obtained. Here nx30, ny30 and m5. Further, the data input to
"
# $ % & ' (
A`7IRHA @EIAPUEQP`# a# B`a#"#" 9#"#"XY"#"T%% TA7@%% P`PaI TA7@%%! `EE3!P`aF F3!Pa P`I3P`I! PaI3PaI! TA7@%%! B`aEFE3!P` F3!Pa YTEVA&& IE`EE3!P` YTEVA&&! FaFF3!Pa YTEVA&&" EFB`aEFE3!P` F3!Pa G3#" 97HH8E9@!`P`aPaB`aGI9XYE9QP EBE9QPAS CQVQ" YTEVA&&# UVQR P`!3P`! Pa!3Pa! I"3I! @Q( Ha"3!I" EUYa3H`"" @Q' H`"3!I" EUY`3H`"" YTEVA&&$ EUY`EUYa @Q& Ea3!Pa! Da3aEa!aEa "% aF3aEa @Q% E`3!P`! D`3`E`!`E` "% `E3`E` @Q$ F3!% Xa3aFDaBHQ7VF! @Q# E3!% X`3`ED`BHQ7VE! 97HH8EB@!`P`aPaI9GEUY`X`E` EUYaXaEaBXYE9QP TEF3B 9QPVEPWA 9QPVEPWA YTEVA&&% E`EaTEFE3!% F3!% 9QPVEPWA 9QPVEPWA 9QPVEPWA 9QPVEPWA UVQR
f f f
152
BIFD1
500 FORMAT(3I6) 510 FORMAT(2F12.0) 600 FORMAT(1H1//10X, 10H INPUT DATA,3X,2HM=, * I2//20X,3HNO,10X,1HX/(20X,I3,E18.7)) 610 FORMAT(//20X,3HNO,10X,1HY/(20X,I3, * E18.7)) 620 FORMAT(3(10X,RHFXY(,I2,1H,I2,2H)=, * E15.7)) 630 FORMAT(1H0,10X,5HERROR) 640 FORMAT(//5X,5HISWX=,I2,3X,5HISWY=,I2//) 650 FORMAT(10X,3HIX=,I3,2X,3HIY=,I3/ * (15X,5(5X,E15.7))) END
Method Suppose that the interpolating coefficient c, in the dual m-th degree B-spline two dimensional interpolating function. S ( x, y) =
ny 1 nx 1
= m +1 = m +1
c , N ,m+1 ( x ) N ,m+1 ( y )
(4.1)
is already obtained by subroutine BICD1. Subroutine BIFD1 calculates an interpolated value, partial derivative and/or an integral based on the interpolating function (4.1). The method is given in Section 7.1 "Definition, representation and calculation method of bivariate spline function".
153
BIFD3
Function Given the function values fij=f(xi ,yj ) at points (xi , yj), (x1 < x2 < < xnx, y1 < y2 < < yny) on the xy -plane, an interpolated value or a partial derivativee at the point P(vx,vy) and/or a double integral over the area [x1 x vx , y y vy], is obtained. (See Fig. BIFD3-1) Before using subroutine BIFD3, the knots {j} in the xdirection and the knots {j} in the y-direction, and also the interpolating coefficients c, in the B-spline twodimensional interpolating function S x, y =
( )
n y m
nx m
= m+1 = m+1
c , N ,m+1 ( x ) N ,m+1 y
()
(1.1)
must be calculated by subroutine BICD3, where m is an odd integer and denotes the degree of the B-splines N,m+1(x) and N,m+1(y). Here x1vxxnx
y yn y
from BICD3). One-dimensional array of size(nxm+1)+(ny m+1). ISWX .. Input. An integer which specifies type of calculation associated with x-direction. 1ISWXm. See parameter F. VX .... Input. x-coordinate of the point P(vx,vy). IX .... Input. The i which satisfies xi vx<xi +1. If vx=xnx, then IX=nx1. Output. The i which satisfies xi vx<xi +1. See Note. ISWY .. Input. An integer which specifies type of calcuration associated with y-direction. 1ISWYm. See the parameter F. VY .... Input. y-coordinate of the point P(vx,vy). IY .... Input. The j value which satisfies yjvy<yj+1. If vy=yny then IY=ny1 Output. The j which satisfies yjvy<yj+1. See Note. F ..... Output. Interpolated value, partial derivative or integral value. Setting ISWX= and ISWY=, one of the following value is put out depending on combination of and : When 0,
P(vx, vy)
+ F = S vx , v y x y
y3 y2 y1 x1 x2 x3 .. xn x x
S v x , v y dx y
When 0, 1
Parameters X ..... Input. Discrete points, xi 's in the x-direction. One-dimensional array of size nx. NX .... Output. Number of xj's, nx. Y ..... Input. Discrete points yj's in the y-direction. One dimensional array of size ny. NY .... Input. Number of yl's, ny. M ..... Input. The degree of the B-spline, m. See Note. C ..... Input. Interpolation coefficients c, (output from BICD3). Two-dimensional array as C(K,NY). K ..... Input. Adjustable dimension for array C. XT .... Input. Knots in the x- and y-direction (output
F= S (v x , y )dy x
vy y1
When = = 1
x F = yy1 dx v x1 S ( x , y )dx
VW ....
ICON ..
Work area. One-dimensional array of size 4(m+1) + max(nx,ny) Output. Condition code. See Table BIFD3-1.
Subprograms used SSL II ... MGSSL, UCAD1 and UBAS1 FORTRAN basic function ... FLOAT
154
BIFD3
Table BIFD3-1 Condition codes Code 0 10000 Meaning No error X(lX)VX<X(lX+1) or Y(lY)VY<Y(lY+1) is not satisfied. Processing lX or lY shown on the left is searched for in the subroutine and the processing is continued. Bypassed
30000
Either of the followings occurred: 1 VX<X(1) or VX>X(NX) 2 VY<Y(1) or VY>Y(NY) 3 ISWX<-1 or ISWX>M 4 ISWY<-1 or ISWY>M
Notes The subroutine, based on the B-spline twodimensional interpolating function (1.1) given by using subroutine BICD3, obtains an interpolated value, a partial derivative or a double integral. Therefore subroutine BICD3 must be called to obtain the interpolating function (1.1) before calling this subroutine to obtain an interpolated value, etc. Also parameters X, NX, Y, NY, K, M, C and XT must be directly passed from subroutine BICD3. Parameters IX and IY should satisfy the relationships X(IX)VX<X(IX+1) and Y(IY)VY<Y(IY+1). If not, IX and IY that satisfy those relationships are searched for to continue the processing. Example By inputting points (xi ,yj), function values fij, i=1,2,...,nx, j=1,2,...,ny, and the degree m, interpolated values or partial derivatives at the point (vir,ujs) ; vir=xi +(xi +1xi )(r/4), ujs=yj+(yj+1yj)(s/4), i=1,2,...,nx1, j=1,2,...,ny1, r=0,1,...,4 and s=0,1,...,4, and/or integrals over the area[x1 x vir, y1 y ujs] are obtained. Here nx30, ny30 and m5.
C **EXAMPLE** DIMENSION X(30),Y(30),FXY(30,30), * C(30,30),XT(52),VW(182),R(5,5) READ (5,500) NX,NY,M READ (5,510) (X(I),I=1,NX),(Y(J),J=1,NY) READ (5,510) ((FXY(I,J),J=1,NY),I=1,NX) WRITE (6,600) M,(I,X(I),I=1,NX) WRITE (6,610) (J,Y(J),J=1,NY) WRITE (6,620) DO 10 I=1,NX 10 WRITE(6,630) (I,J,FXY(I,J),J=1,NY) K=30 CALL BICD3(X,NX,Y,NY,FXY,K,M,C, * XT,VW,ICON) IF(ICON.EQ.0) GO TO 20
WRITE (6,640) STOP 20 NX1=NX-1 NY1=NY-1 M2=M+2 DO 80 LX2=1,M2 ISWY=LX2-2 DO 70 LY2=1,M2 ISWX=LY2-2 WRITE (6,650) ISWX,ISWY DO 60 IX=1,NX1 HX=(X(IX+1)-X(IX))*0.25 XI=X(IX) DO 50 IY=1,NY1 HY=(Y(IY+1)-Y(IY))*0.25 YJ=Y(IY) DO 40 I=1,5 VX=XI+HX*FLOAT(I-1) DO 30 J=1,5 VY=YJ+HY*FLOAT(J-1) CALL BIFD3(X,NX,Y,NY,M,C,K,XT, * ISWX,VX,IX,ISWY,VY,IY,F,VW,ICON) R(I,J)=F 30 CONTINUE 40 CONTINUE WRITE(6,660)IX,IY,((R(I,J),J=1,5),I=1,5) 50 CONTINUE 60 CONTINUE 70 CONTINUE 80 CONTINUE STOP 500 FORMAT(3I6) 510 FORMAT(2F12.0) 600 FORMAT(1H1//10X,10HINPUT DATA,3X, * 2HM=,I2//20X,3HNO.,10X,1HX/ * (20X,I3,E18.7)) 610 FORMAT(//20X,3HNO.,10X,1HY/ * (20X,I3,E18.7)) 620 FORMAT(//20X,3HFXY/) 630 FORMAT(3(10X,4HFXY(,I2,1H,,I2,2H)=, * E15.7)) 640 FORMAT (1H0,10X,5HERROR) 650 FORMAT(//5X,5HISWX=,I2,3X,5HISWY=,I2//) 660 FORMAT(10X,3HIX=,I3,2X,3HIY=,I3/ * (15X,5(5X,E15.7))) END
Method Suppose that the dual m-th degree B-spline twodimensional interpolating function. S x, y =
( )
n y m
nx m
= m+1 = m+1
c , N ,m+1 ( x ) N ,m+1 y
()
(4.1)
is already obtained by subroutine BICD3. Subroutine BIFD3 calculates interpolated values, partial derivative and/or an integrals based on the interpolating function (4.1). The method is described in Section 7.1 "Definition, representation and calculation method of spline function".
155
BIF1
Table BIF1-1 Condition codes Code 0 10000 Meaning No error X(l)V<X(I+1) is not satisfied. Processing The I given on the left is searched for in the subroutine and the processing is continued. Bypassed
Function Given function values yi =f(xi ), i=1,2,...,n at discrete points x1,x2...,xn(x1<x2<...<xn) and derivatives y1(l) = f (l ) (x) and yn(l) = f (l)(x), l=1,2,...,(m 1)/2 at the point x1 and xn, then an interpolated value, a derivative at the point x=v[x1, xn], or an integral from x1 to are obtained. However, subroutine BIC1 must be called before using subroutine BIF1 to calculate the interpolating coefficients cj, j=m+1, m+2, ..., n 1 in the B-spline interpolating function, S ( x ) = c j N j ,m+1 ( x )
n1 j = m+1
30000
Either of the followings occurred: (a) V<X(1) or V>X(N) (b) ISW<-1 or ISW>M
(1.1)
Comments on use Subprograms used SSL II ... MGSSL, UCAR1 and UBAS1 FORTRAN basic function ... FLOAT Notes The subroutine obtains an interpolated value, derivative or integral based on the B-spline interpolating function (1.1) which is obtained by using subroutine BIC1. Therefore, BIC1 must be called before calling this subroutine. Parameters, X, N, M and C must be directly passed from BCI1 to subroutine BIF1. Parameters I should satisfy the relationships X(I)V<X(I+1). If not, the value of I which satisfies the relationship is searched for to continue the processing. Example By inputting discrete points xi, function values yi, i=1,2,...; n derivatives y1(l), l=1,2,...(m 1)/2, and yn(l), l=1,2,...,(m 1)/2 at each end point, and the degree m, the following values are obtained; an integral value from x1 to vij=xi +(xi +1-xi )( j/5)=1,2,...,n 1, j=0,1,...,5, an interpolated value or derivatives of order one through m. Here n101, and m5.
C **EXAMPLE** DIMENSION X(101),Y(101),C(105),DY(2,2), * VW(519),R(6) READ (5,500) N,M LM1=(M 1)/2 READ (5,510) (X(I),Y(I),I=1,N) CALL BIC1(X,Y,DY,N,M,C,VW,ICON) IF(ICON.EQ.0) GO TO 10 WRITE (6,610) STOP 10 N1=N-1 M2=M+2 DO 40 L2=1,M2 ISW=L2-2 WRITE (6,620) ISW DO 30 I=1,N1
, where m is an odd integer and is the degree of the Bspline Nj,m+1(x) and x1vxn, m3 and n2. Parameters X ..... Input. Discrete points xi . One-dimensional array of size n. N ..... Input. Number of the discrete points, n. M ..... Input. Degree of the B-spline, m. See Note. C ..... Input. Interpolating coefficients cj(output from BIC1) One-dimensional array of size n+m1. ISW ... Input. An integer which specifies the type of calculation. If ISW=0, interpolated value F=S(v). If ISW=l (1 l m), l-th order derivative F=S(l)(v). If ISW=1, integral F= x1 S ( x ) dx are calculated, respectively. Input. The point v at which the interpolated value etc. is to be obtained. I ..... Input. Value of i which satisfies xi v<xi +1. If v=xn the parameter should be given n1. Output. Value of i which satisfies xi v<xi +1. See Note. F ..... Output. Interpolated value, l-th order derivative or integral. See parameter ISW. VW .... Work area. One-dimensional array of size m+1. ICON .. Output. Condition code. See Table BIF1-1. V .....
156
BIF1
H=(X(I+1)-X(I))/5.0 XI=X(I) DO 20 J=1,6 V=XI+H*FLOAT(J-I) CALL BIF1(X,N,M,C,ISW,V,I,F,VW,ICON) R(J)=F 20 CONTINUE WRITE (6,630) I,(R(J),J=1,6) 30 CONTINUE 40 CONTINUE STOP
500 FORMAT(216) 510 FORMAT(2J12.0) 600 FORMAT(1H1//10X,10HINPUT DATA,3X, * 2HN=,I3,3X,2HN=,I2//20X,3HN0.,10X, * 1HX,17X,1HY//(20X,I3,2E18.7)) 610 FORMAT(1H0,10X,5HERROR) 620 FORMAT(1H1//10X,2HL=,I2/) 630 FORMAT(6X,I3,6E18.7) END
157
BIF2
Table BIF2-1 Condition codes Code 0 10000 Meaning No error X(l)V<X(I+1) is not satisfied. Processing The I given on the left is searched for in the subroutine and the processing is continued. Aborted
Function Given function values yi =f(x), i=1,2,...,n at discrete points x1,x2...,xn(x1<x2<...<xn), and derivatives y1(l)=f (l)(x1) and yn(l)=f (l)(xn), l=(m+1)/2,(m+1)/2+1,...,m 1 at the point x1 and xn then an interpolated value, a derivative at the point x=v[x1, xn], or an integral from x1 to v are obtained. However, subroutine BIC2 should be called before using subroutine BIF2 to calculate the interpolating coefficients cj, j=m+1, m+2, ..., n 1 in the B-spline interpolating function, S ( x ) = c j N j ,m+1 ( x )
n1 j = m+1
30000
Either of the followings occurred: (a) V<X(1) or V>X(N) (b) ISW<-1 or ISW>M
(1.1)
Comments on use Subprograms used SSL II ... MGSSL, UCAR1 and UBAS1 FORTRAN basic function ... FLOAT Notes The subroutine obtains an interpolated value, derivative or integral based on the B-spline interpolating function (1.1) which is obtained by using subroutine BIC2. Therefore, BIC2 must be called before calling this subroutine. Parameters, X, N, M and C must be directly passed from BCI2 to subroutine BIF2. Parameters I should satisfy the relationships X(I)V<X(I +1). If not, the value I which satisfies the relationship is searched for to continue the processing. Example By inputting discrete points xi , function values yi , i=1,2,...,n, derivatives y1(l) and yn(l), = (m+1)/2,(m+1)/2+1,...,m 1, at each end point, and the degree m, the following values are obtained; an integral value from x1 to Vij=xi +(xi +1xi )( j/5)=1,2,...,n 1, through m. Here n101, and m5.
C **EXAMPLE** DIMENSION X(101),Y(101),C(105),DY(2,2), * VW(527),R(6) READ (5,500) N,M LM1=(M 1)/2 READ (5,510) (X(I),Y(I),I=1,N) * ,((DY(I,L),I=1,2),L=1,LM1) WRITE(6,600) N,M,(I,X(I),Y(I),I=1,N) CALL BIC2(X,Y,DY,N,M,C,VW,ICON) IF(ICON.EQ.0) GO TO 10 WRITE (6,610) STOP 10 N1=N-1 M2=M+2 DO 40 L2=1,M2 ISW=L2-2 WRITE (6,620) ISW DO 30 I=1,N1 H=(X(I+1)-X(I))/5.0
where m is an odd integer and is the degree of the Bspline Nj+1(x) and x1vxn, m and n(m+1)/2. Parameters X ..... Input. Discrete points xi . One-dimensional array of size n. N ..... Input. Number of the discrete points, n. M ..... Input. Degree of the B-spline, m. See Note. C ..... Input. Interpolating coefficients cj(output from BIC2) One-dimensional array of size n+m1. ISW ... Input. An integer which specifies the type of calculation. If ISW=0, interpolated value F=S(v). If ISW=l (1 l m), l-th order derivativeF=S(l)(v). v If ISW= 1, integral F= x1 S ( x )dx are calculated, respectively. Input. The point v at which the interpolated value etc. is to be obtained. I ..... Input. Value of i which satisfies xi v<xi +1. If v=xn the parameter should be given n1. Output. Value of i which satisfies xi v<xi +1. See Note. F ..... Output. Interpolated value, l-th order derivative or integral. See parameter ISW. VW .... Work area. One-dimensional array of size m+1. ICON .. Output. Condition code. See Table BIF2-1. V .....
158
BIF2
XI=X(I) DO 20 J=1,6 V=XI+H*FLOAT(J-I) CALL BIF2(X,N,M,C,ISW,V,I,F,VW,ICON) R(J)=F 20 CONTINUE WRITE (6,630) I,(R(J),J=1,6) 30 CONTINUE 40 CONTINUE STOP 500 FORMAT(216) 510 FORMAT(2F12.0) 600 FORMAT(1H1//10X,10HINPUT DATA,3X, * 2HN=,I3,3X,2HN=,I2//20X,3HN0.,10X, * 1HX,17X,1HY//(20X,I3,2E18.7)) 610 FORMAT(1H0,10X,5HERROR) 620 FORMAT(1H1//10X,2HL=,I2/) 630 FORMAT(6X,I3,6E18.7) END
The subroutine, based on Eq. (4.1), obtains an interpolated value, l-th order derivative and/or integral from Eqs. (4.2), (4.3) and (4.4), respectively S (v ) = c j N j ,m+1 (v )
j = m +1 n1
) S ( l ) (v ) = c j N (j ,lm v +1 ( )
j = m+1
n1
I = S ( x )dx
v x1
Method Suppose that the m-th degree B-spline interpolating function is already obtained by the subroutine BIC2 as follows: S ( x ) = c j N j ,m+1 ( x )
j = m+1 n1
The method of calculating these three values is explained in section 7.1 "Calculating spline function". The subroutine described here performs calculation of Nj,m+1(x) and its derivative and integral by using the subroutine UBAS1.
(4.1)
159
BIF3
Table BIF3-1 Condition codes Code 0 10000 Meaning No error X(l)V<X(I+1) is not satisfied. Processing I is searched for in the subroutine and the processing is continued. Aborte
Function Given function values yi =f(x), i=1,2,...,n at discrete points x1,x2...,xn(x1<x2<...<xn), this subroutine obtains interpolated value or derivative at x=v or integral over the interval x1v. Before using this subroutines, it is necessary a sequence of knots i , i=1,2,...,nm+1, and interpolating coefficients cj, j=m+1,m+2,...,n m of the B-spline interpolation: S ( x ) = c j N j ,m+1 ( x )
n m j = m+1
30000
Comments on use Subprograms used SSL II ... MGSSL, UCAR1 and UBAS1 FORTRAN basic function ... FLOAT Notes The subroutine determines interpolated values or derivative or integral based on the B-spline interpolating functions determined by the subroutine BIC3. Therefore, the subroutine BIC3 must be called to determine the interpolating function (1.1) before calling this subroutine to determine interpolated values, etc. Parameters, X, N, Y, C and XT must be identical with those of the BIC3. Parameters I should preferably satisfy X(I)V<(I+1). If the parameter does not satisfy the condition, I that satisfies X(I)V<X(I+1) is searched for to continue processing. Example Discrete point xi, function value yi , i=1,2,...,n and degree m are input, and integrals from x1, interpolated values and differentials of the first through the m-th degree in vij=xi +(xi +1xi )( j/5), i=1,2,...,n 1, j=0,1,...,5 are determined. n101, n5.
C **EXAMPLE** DIMENSION X(101),Y(101),C(101),XT(99), * VW(507),R(6) READ (5,500) N,M READ (5,510) (X(I),Y(I),I=1,N) WRITE(6,600) N,M,(I,X(I),Y(I),I=1,N) CALL BIC3(X,Y,N,M,C,XT,VW,ICON) IF(ICON.EQ.0) GO TO 10 WRITE(6,610) STOP 10 N1=N-1 M2=M+2 DO 40 L2=1,M2 ISW=L2-2 WRITE(6,620) ISW DO 30 I=1,N1 H=(X(I+1)-X(I))/5.0 XI=X(I) DO 20 J=1,6 V=XI+J*FLOAT(J-1)
have been given by the subroutine BIC3. Where m is an odd number which denotes the degree of B-spline Nj,m+1(x). x1vxn, m3 and nm+2
Parameters X ..... Input. Discrete points xi . X is a one-dimensional array of size n. N ..... Input. Number of the discrete points, n. M ..... Input. The degree of the B-spline: m. (See Note) C ..... Input. Interpolating coefficients cj (output from BIC3) C is a one-dimensional array of size n. XT .... Input. The knots i, (output from DIC3). XT is a one-dimensional array of size nm+1. ISW ... Input. An integer which specifies the type of calculation. When ISW=0, interpolated value F=S(v). When ISW=l (l=1,2,...,m), the derivative of order lF=S(l)(v), and When ISW=1, integral F = vx1 S ( x )dx are V ..... calculated, respectively. Input. The points v at which the interpolated value etc. is to be obtained. I ..... Input. Value of i which satisfies xiv<xi+1. When v=xn the parameter should be given n1. Output. An interger i which satisfies xi v<xi +1. (See Note.) F ..... Output. Interpolated value or derivative of order l or integral. (See ISW) VW .... Work area. VW is a one-dimensional array of size 2m+2. ICON .. Output. Condition code. Refer to Table BIF3-1.
160
BIF3
CALL BIF3(X,N,M,C,XT,ISW,V,I,F, VW,ICON) R(J)=F 20 CONTINUE WRITE(6,630) I,(R(J),J=1,6) 30 CONTINUE 40 CONTINUE STOP 500 FORMAT(216) 510 FORMAT(2F12.0) 600 FORMAT(1H1//10X,10HINPUT DATA,3X, * 2HN=,I3,3X,2HN=, I2//20X, 3HN0.,10X, * 1HX,17X,1HY//(20X,I3,2E18.7)) 610 FORMAT(1H0,10X,5HERROR) 620 FORMAT(1H1//10X,2HL=,I2/) 630 FORMAT(6X,I3,6E18.7) END *
S ( x ) = c j N j ,m+1 ( x )
j = m+1
n m
(4.1)
The subroutine, based on Eq. (4.1), obtains an interpolated value, l-th order derivative and/or integral by Eqs. (4.2), (4.3) and (4.4), respectively. S (v ) = c j N j ,m+1 (v )
j = m +1 n m
) S ( l ) ( v ) = c j N (jl,m ( v) +1
j = m +1
nm
I = S ( x )dx
v x1
Method Suppose that the m-th degree B-spline interpolating function is already obtained by the subroutine BIC3 as follows:
The method of calculating these three values is explained in section 7.1 "Calculating spline function". The subroutine described here performs calculation of Nj,m+1(x) and its derivative and integral by using the subroutine UBAS1.
161
BIF4
Table BIF4-1 Condition codes Code 0 10000 Meaning No error X(l)V<X(I+1) is not satisfied. Processing The l given on the left is searched for in the subroutine and the processing is continued. Bypassed
Function Given a periodic function values yi =f(x), i=1,2,...,n (where y1=yn), of period (xnxl) at the discrete points x1,x2...,xn(x1<x2<...<xn), then an interpolated value, a derivative or an integral from x1 to v are obtained. However, subroutine BIC4 must be called before using this subroutine BIF4 to calculate the interpolating coefficients cj, j= m+1,m+2,...,nm in the B-spline interpolation function, S ( x ) = c j N j ,m+1 ( x )
n m j = m+1
30000
Either of the followings occurred: (a) V<X(1) or V>X(N) (b) ISW<-1 or ISW>M
(1.1)
Comments on use Subprograms used SSL II ... MGSSL, UCAR4 and UPEP4 FORTRAN basic function ... FLOAT Notes The subroutine obtains an interpolated values, derivatives or integral based on the B-spline interpolating function (1.1) which is obtained by using subroutine BIC4. Therefore, BIC4 must be called before calling this subroutine. Parameters X, N, Y and C must be directly passed from BIC4 to subroutine BIF4. Parameters I should satisfy the relationship X(I)V<X(I+1). If not, the value of I which satisfies the relationship is searched for to continue the processing. Example By inputting discrete points xi , function values yi , i=1,2,...,n (with period (xnxl)), and degree m, the following values are obtained; integrals form x1 to vij=xi +(xi +1xi )N( j/5), i=1,2,...,n 1, and j=0,1,2,...,5 interpolated values, and derivatives of order one through m. Here n101, and m5.
C **EXAMPLE** DIMENSION X(101),Y(101),C(105) * VW(906),R(6) READ (5,500) N,M READ (5,510) (X(I),Y(I),I=1,N) WRITE(6,600) N,M,(I,X(I),Y(I),I=1,N) CALL BIC4(X,Y,N,M,C,VW,ICON) IF(ICON.EQ.0) GO TO 10 WRITE(6,610) STOP 10 N1=N-1 M2=M+2 DO 40 L2=1,M2 ISW=L2-2 WRITE(6,620) ISW DO 30 I=1,N1 H=(X(I+1)-X(I))/5.0 XI=X(I)
which satisfies the periodic condition, where m is an odd integer and denotes the degree of the B-spline Nj,m+1(x). Here x1vxn, m3 and nm+2 Parameters X ..... Input. Discrete points xi . One-dimensional array of size n. N ..... Input. Number of the discrete points n. M ..... Input. Degree of the B-spline, m. (See Note.) C ..... Input. Interpolating coefficients cj (output from BIC4) One-dimensional array of size n+m1. ISW ... Input. An integer which specifies the type of calculation. If ISW=0, the interpolated value F=S(v). If ISW=l (1 l m), l-th order derivative F=S(l)(v). v If ISW=1, integral F = x1 S ( x )dx are calculated, respectively. Input. The point v at which the interpolated value etc. is to be obtained. I ..... Input. Value of i which satisfies xi v<xi +1. If v=xn the parameter should be given n1. Output. Value of i which satisfies xi vxi +1. See Note. F ..... Output. Interpolated value, l-th order derivative or integral. See parameter ISW. VW .... Work area. One-dimensional array of size m+1. ICON .. Output. Condition code. See Table BIF4-1. V .....
162
BIF4
DO 20 J=1,6 V=XI+J*FLOAT(J-1) CALL BIF4(X,N,M,C,XT,ISW,V,I,F, * VW,ICON) R(J)=F 20 CONTINUE WRITE(6,630) I,(R(J),J=1,6) 30 CONTINUE 40 CONTINUE STOP 500 FORMAT(2I6) 510 FORMAT(2F12.0) 600 FORMAT(1H1//10X,10HINPUT DATA,3X, * 2HN=,I3,3X,2HN=,I2//20X,3HNO.,10X, * 1HX,17X,1HY//(20X,I3,2E18.7)) 610 FORMAT(1H0,10X,5HERROR) 620 FORMAT(1H1//10X,2HL=,I2/) 630 FORMAT(6X,I3,6E18.7) END
where the S(x) is a periodic function with period (xnxl) which satisfies S ( l ) x1 = S ( l ) xn , l = 0,1,, m 1
( )
( )
(4.2)
The subroutine, based on Eq. (4.1), obtaines an interpolated value, l-th order derivative or integral by using Eqs. (4.3), (4.4) and (4.5), respectively S (v ) = c j N j ,m+1 (v )
j = m +1 n1
) S ( l ) ( v ) = c j N (jl,m ( v) +1
j = m +1
n 1
I = S ( x)dx
v x1
Method Suppose that the m-th degree B-spline interpolating function has been already obtained by subroutine BIC4 as follows: S ( x ) = c j N j ,m+1 ( x )
j = m+1 n1
The method of calculating these three values is explained in Section 7.1 "Calculating spline function". Subroutine BIF4 perfoms calculation of Nj,m+1(x) and its derivatives and integral by using the subroutine UBAS4.
(4.1)
163
BIN
Integer order modified Bessel function of the first kind I n ( x) CALL BIN(X,N,BI,ICON)
259
Function This subroutine computes integer order modified Bessel function of the first kind
90
( x 2) I ( x) = k !(n + k )!
2 k +n n k =0
48
by the Taylor expansion and the asymptotic expansion. Parameters X ..... Input. Independent variable x. N ..... Input. Order n of In(x). BI .... Output. Function value In(x). ICON .. Output. Condition code. See Table BIN1. When N=0 or N=1, ICON is handled the same as in ICON of BI0 andBI1.
Table BIN-1 Condition codes Code 0 20000 Meaning No error One of the following was true with respect to the values of X and N: |X| > 100 1/8 |X| < 1 and |N| 19 |X|+29 1 |X| < 10 and |N| 4.7 |X| + 43 10 |X| 100 and |X| 1.83 |X| + 71 Processing
31
20
1/8
10
100 | X |
Example The following example generates a table of In(x) for range of from 0 to 10 with increment 1and for the range of N from 20 to 30 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 20 N=20,30 DO 10 K=1,11 X=K-1 CALL BIN(X,N,BI,ICON) IF(ICON.EQ.0) WRITE(6,610) X,N,BI IF(ICON.NE.0) WRITE(6,620) X,N,BI,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,5X,1HN,8X,5HIN(X)/) 610 FORMAT(1H ,F8.2,I5,E17.7) 620 FORMAT(1H ,11H** ERROR **,5X,2HX=, E17.7, * 5X,2HN=,I5,5X,3HBI=,E17.7,5X,10HCONDITION=, * I10) END
BI is set to 0.0.
Comments on use Subprograms used SSL II ... AFMAX, AFMIN AMACH, BI0, BI1, MGSSL, ULMAX FORTRAN basic functions ... ABS, IABS, FLOAT, EXP, MAX0, AND SQRT. Notes The ranges of |X| and |N| are indicated by the null area in Fig. BIN-1. These limits are provided to avoid overflow and underflow in the calculations. (See "Method".) When calculating I0(x) and I1(x), subroutines BI0 and BI1 should be used instead.
Method With |x|=1/8 as the boundary, the formula used to calculate Bessel function In(x) changes. Since In(x)=In(x), In(x)=(1)nIn(x), n and x will be used instead of |n| and |x| in the following. For 0x<1/8 The computation is based on the Taylor expansion: In ( x) = xn x2 1 + n 2 n! 2( 2n + 2)
x4 + + 2.4(2n + 2)(2n + 4)
(4.1)
164
BIN
The value of In(x) is computed as a partial sum of the first N terms with N being taken large enough so that the last term no longer affects the value of the partial sum significantly. For 1/8 x 100 Letting M be a certain integer sufficiently greater than n and x the recurrence formula: Fk 1 ( x ) = 2k Fk ( x ) + Fk +1 ( x ) x (4.2)
[{
} ]
(4.4)
is evaluated for k=M, M 1,...,1 where FM+1(x) =0, FM(x) =flmin Then, In(x) is computed as I n ( x ) = e x Fn ( x ) / F0 ( x ) + 2 Fi ( x )
M i =1
(4.3)
where [ ] denotes the Gaussian notation, and m0 is taken as follows: (a) For 1/8x<1 Single precision: m0=4.8x+6.1 n0=3.6x+2.1 (4.5) Double precision: m0=9.4x+9.5 (4.6) n0=5.0x+4.5 (b) For 1x<10 Single precision: m0=1.4x+9.6 n0=0.9x+5.1 (4.7) Double precision: m0=2.5x+15.5 (4.8) n0=1.4x+8.6 (c) For 10 x 100 Single precision: m0=0.75x+17.5 (4.9) n0=0.28x+11.2 Double precision: m0=0.77x+32.3 (4.10) n0=0.45x+17.5 For more information, see References [81] and [82].
165
BIR
Function This subroutine computes the value of real order modified Bessel function of the first kind 1 2 x 4 1 I v ( x ) = x 2 k =0 k ! ( v + k + 1)
v k
**EXAMPLE** DO 20 K=1,11 X=K-1 DO 10 NV=40,60 V=FLOAT(NV)/100.0 CALL BIR(X,V,BI,ICON) IF(ICON.EQ.0) WRITE(6,600) X,V,BI 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H,F8.2,F8.3,E17.7) END
by using the power series expansion (above expression) and the recurrence formula. Parameters X ..... Input. Independent variable x(x0). V ..... Input. Order v of Iv(x) (v0). BI .... Output. Value of function Iv(x). ICON .. Output. Condition code. See Table BIR-1.
Table BIR-1 Condition codes Code 0 20000 30000 Meaning No error X>log(flmax) X<0 or V<0. Processing BI is set to 0.0. BI is set to 0.0.
Method When it is known that the value of Iv(x) will be the underflowed value, the following computations are skipped and the result 0.0 is output. The computation of Iv(x) depends on the range of x. 0x1 With the power series expansion 1 2 x 4 k = 0 k ! ( v + k + 1)
k
1 I v ( x ) = x 2
(4.1)
, it is computed until the k-th term is less than the unit round-off in relative to the first term. 1<xlog( flmax) Recurrence formula is used. Let's suppose that m is a sufficiently large integer (determined by x, v, and the desired precision), and that is a sufficiently small constant (positive smallest number allowed for the computer used) and moreover that n and are determined by v=n+(n;integer,0<1) Initial values G+m+1(x)=0, G+m(x)= are set, and recurrence formula Ga + k 1 ( x ) = 2(a + k ) x Ga + k ( x ) + Ga + k +1 ( x ) (4.2)
Comments on use Subprograms used SSL II ... AFMAX, AMACH, AFMIN, MGSSL, ULMAX FORTRAN basic function ... FLOAT, ABS, GAMMA, AMAX1, EXP Notes 0 X log(flmax) and V0. When computing I0(x) and I1(x), subroutines BI0 and BI1 are used instead. When a set of function values Iv(x),Iv+1(x),Iv+2(x),...,Iv+M(x) is needed at the same time, Iv+M(x) and Iv+M-1(x) are computed with this subroutine, and next, Iv+M-2(x),Iv+M-3(x),...,Iv(x) should be computed in sequence from high order to low order, by using the recurrence formula continuously. Conversely, it should be avoided in computing Iv+2(x) and Iv+3(x),...,Iv+M(x) by the recurrence formula, after computing Iv(x) and Iv+1(x) with this subroutine, in sequence from low order to high order. Example The following example generates a table of Iv(x) for the range of x from 0 to 10 with increment 1 and for the range of v from 0.4 to 0.6 with increment 0.01.
is repeatedly applied to k=m,m 1,...,1. Then the value of function Iv(x) is obtained as I v ( x)
a 1 x (2a + 1) x e Ga + n ( x ) 2 2 (a + 1)
m (a + k ) (2a + k ) Ga + k ( x ) k! k =0
(4.3)
For the method of determining of m and other details, see Reference [4]. 166
BI0
I11-81-0601 BI0,DBI0
Zero order modified Bessel function of the first kind I0(x) CALL BI0(X,BI,ICON)
600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HI0(X)/) 610 FORMAT(1H,F8.2,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBI=,E17.7,5X,10HCONDITION=,I10) END
Function This subroutine computes the zero order modified Bessel function of the first kind I0(x) I 0 ( x) =
k =0
( x 2) ( k !)
2k
Method With |X| = 8 as the boundary, the approximation formula used to calculate modified Bessel function I0(x) changes. Since I0(x)=I0(x), x is used instead of |x| in the following. For 0x<8 The power series expansion of I0(x) I0
by polynomial approximations and the asymptotic expansion. Parameters X ..... Input. Independent variable x. BI .... Output. Function value I0(x). ICON .. Output. Condition code. See Table BI0-1.
Table BI0-1 Condition code Code 0 20000 Meaning No error |X| > log (flmax) Processing BI is set to flmax.
( x 2) ( x) = (k !)
k =0
2k
(4.1)
is calculated using the approximation formulas in (4.2) and (4.3). Single precision: I 0 ( x ) = ak x 2 k
11 k =0
(4.2)
Comments on use Subprograms used SSL II ... AFMAX, MGSSL, ULMAX FORTRAN basic function ... ABS, EXP, and SQRT Notes [The range of argument X] |X| log ( flmax) If |X| exceeds the limits, an overflow will occur during the calculation of ex. This limit is provided for that reason. (See "Method".) Example The following example generates a table of I0(x) from 0 to 100 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,101 X=K-1 CALL BI0(X,BI,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BI IF(ICON.NE.0) WRITE(6,620) X,BI,ICON 10 CONTINUE STOP
Double precision: I 0 ( x ) = ak x 2 k
k =0 1
(4.3)
(4.4)
is calculated using the approximation formulas in (4.5) and (4.6) Single precision: I 0 ( x) = ex 5 akz k z =8/ x , x k =0 (4.5)
Double precision: I 0 ( x) =
11 ex 5 , a k z k / bk z k k =0 x k =0 z = ( x 8) / x
(4.6)
167
BI1
I11-81-0701 BI1,DBI1
First order modified Bessel function of the first kind I1(x) CALL BI1(X,BI,ICON)
600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HI0(x)/) 610 FORMAT(1H,F8.2,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBI=,E17.7,5X,10HCONDITION=,I10) END
Function This subroutine computes the first order modified Bessel function of the first kind I1 ( x ) =
k =0
( x 2) ( k !)( k + 1)!
2 k +1
Method With |x| as the boundary, the approximation formula used to calculate the modified Bessel function I1(x) changes. Since I1(x)=I1(x), x is used instead of |x| in the following. For 0x<8 The power series expansion of I1(x)
by polynomial approximations and the asymptotic expansion. Parameters X ..... Input. Independent variable x. BI .... Output. Function value I1(x). ICON .. Output. Condition code. See Table BI1-1.
Table BI1-1 Condition code Code 0 20000 Meaning No error X>log(flmax) or X<log(flmax) Processing BI is set to flmax or BI is set to flmax.
( x 2) I ( x) = ( k !)( k + 1)!
2 k +1 1 k =0
(4.1)
is calculated using the approximation formulas in (4.2) and (4.3). Single precision: I1 ( x ) = a k x 2 k +1
10 k =0
(4.2)
Double precision: I1 ( x ) = a k x 2 k +1
16 k =0
Comments on use Subprograms used SSL II ... AFMAX, MGSSL, ULMAX FORTRAN basic function ... ABS, EXP, and SQRT Notes [Range of argument X] |X| log( flmax) If |X| exceeds the above limits, an overflow will occur during the calculation of x. This limit is provided for that reason. (See "Method".) Example The following example generates a table of I1(x) from 0 to 100 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,101 X=K-1 CALL BI1(X,BI,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BI IF(ICON.NE.0) WRITE(6,620) X,BI,ICON 10 CONTINUE STOP
(4.3)
3 ( 5) ( 21) 1 3 + (8 x) 3!
(4.4)
is calculated using the approximation formulas in (4.5) and (4.6) Single precision: I1 ( x ) = ex 5 , z =8/ x ak z k x k =0 (4.5)
Double precision: I1 ( x ) =
11 e x 11 a k z k / bk z k , z = ( x 8) / x = k =0 x k0
(4.6)
168
BJN
|N| 259
Function This subroutine computes integer order Bessel function of the first kind Jn ( x) =
90
k =0
( 1) ( x / 2) ( k !)( n + k )!
k
2 k +n
48
by Taylor expansion and the asymptotic expansion. Parameters X ..... Input. Independent variable x. N ..... Input. Order n of Jn(x). BJ .... Output. Function value Jn(x). ICON .. Output. Condition code. See Table BJN-1. When N=0, or N=1, the same handling as for the ICON of BJ0 and BJ1 applies.
Table BJN-1 Condition code Code 0 20000 Meaning No error One of the following conditions was true with respect to the value of X and N. |X| > 100 1/8 |X| < 1 and |N| 19 |X| + 29 1 |X| < 10 and |N| 4.7 |X| + 43 10 |X| 100 and |N| 1.83 |X| + 71 Processing BJ is set to 0.0.
31 20 1/8 1 10 100 | X |
Example The following example generates a table of Jn(x) for the range of x from 0.0 to 10.0 with increment 1.0 and for the range of N from 20 to 30 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 20 N=20,30 DO 10 K=1,11 X=K-1 CALL BJN(X,N,BJ,ICON) IF(ICON.EQ.0) WRITE(6,610) X,N,BJ IF(ICON.NE.0) WRITE(6,620) X,N,BJ,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,5X,1HN,8X,5HJN(x)/) 610 FORMAT(1H,F8.2,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HN=,I5,5X,3HBJ=,E17.7,5X, 10HCONDITION=, * I10) END
Comments on use Subprograms used SSL II ... AFMIN, AFMACH, BJ0, BJ1, MGSSL and UTLIM FORTRAN basic function ... ABS, IABS, FLOAT, MAX0, DSIN, DCOS, and DSQRT Notes The range of |X| and |N| are indicated by the null area in Fig. BJN-1. These limits are provided to avoid overflow and underflow during calculations (refer to "Method"). When calculating J0(x) and J1(x), subroutines BJ0 and BJ1 should be used instead.
Method With |x| = 1/8 as the boundary, the calculation formula of Bessel function Jn(x) changes. Since J-n (x)=Jn( x)=(1)nJn(x), n and x will be used instead of |n| and |x| in the following. For 0x<1/8 The computation is based on the Taylor expansion: J n ( x) = xn x2 1 2 n n! 2( 2n + 2)
x4 + + 2 4(2n + 2)( 2n + 4)
(4.1)
169
BJN
The value of Jn(x) is computed as a partial sum of the first N terms with N being taken large enough so that the last term no longer affects the value of the partial sum significantly. For 1/8 x 100 Letting M be a certain integer sufficiently greater than n and x the recurrence formula: Fk 1 ( x ) = 2k Fk ( x ) Fk +1 ( x ) x (4.2)
[Determination of M] m + x M = 2 m0 + 1 + max n 0 ,0 / 2 2
(4.4)
is evaluated for k=M,M 1,..., where FM+1X.FM+1(x)=0, FM(x)=flmin Then, Jn(x) is computed as
[ M 2] J n ( x ) = Fn ( x ) / F0 ( x ) + 2 F2 i ( x ) i =1
(4.3)
where [ ] denotes the Gaussian notation, and m0 is taken as follows: (a) For 1/8x<1 (4.5) Single precision: m0=5.5x+5 (4.6) Double precision: m0=8x+10 (b) For 1x<10 (4.7) Single precision: m0=1.8x+9 (4.8) Double precision: m0=2x+19 (c) For 10 x 100 (4.9) Single precision: m0=1.25x+18 (4.10) Double precision: m0=1.3x+34 For more information, see References [81] and [82].
170
BJR
Function This subroutine evaluates real order Bessel function of the first kind 1 2 x 4 1 J v x = x 2 k =0 k ! (v + k + 1)
k v
15
10
100
1000 tmax
by using power series expansion (above expression), recurrence formula, and asymptotic expansion. Parameters X ..... Input. Independent variable x (x0). N ..... Input. Order v of Jv(x) (v0). BJ .... Output. Value of function Jv(x). ICON .. Output. Condition code. See Table BJR-1.
Table BJR-1 Condition code Code 0 20000 Meaning No error Any of these errors. X>100 and V>15 Xtmax X<0 or V<0 Processing BJ is set to 0.0.
To evaluate J0(x) or J1(x), it is better to use BJ0 or BJ1 respectively rather than this subroutine. When a set of function values Jv(x), Jv+1(x), Jv+2(x), ..., Jv+M(x) is needed at the same time, Jv+M(x) and Jv+M1(n) are computed with this subroutine first, and next, Jv+M-2(x), Jv+M-3(x), ..., Jv(x) should be computed in sequence from high order to low order, by using the recurrence formula continuously. Conversely, it should be avoided in computing Jv+2(x), Jv+3(x), ..., Jv+M(x) by recurrence formula after computing Jv(x) and Jv+1(x) with this subroutine, in sequence from low order to high order. Example The following example generates a table of Jv(x) for the range of x from 0 to 10 with increment 1 and for the range of v from 0.4 to 0.6 with increment 0.01.
C **EXAMPLE** DO 20 K=1,11 X=K-1 DO 10 NV=40,60 V=FLOAT(NV)/100.0 CALL BJR(X,V,BJ,ICON) IF(ICON.EQ.0) WRITE(6,600) X,V,BJ 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H,F8.2,F8.3,E17.7) END
30000
BJ is set to 0.0.
Comments on use Subprograms used SSL II ... AMACH, AFMIN, MGSSL, UTLIN FORTRAN basic function ... FLOAT, ABS, GAMMA, AMAX1, MOD, SQRT, COS, SIN Notes X0, V0. X, V, must be within in the range shown as the white part in Fig. BJR-1. And, X<tmax are required since values of sin(X1/2V+1/4)) and cos(X(1/2V+1/4) in the asymptotic expansion are not computed accurately when X is great. See Method (4.4) expression.
Method When it is known that the value of Jv(x) will underflow (has a value less than about 1075), the following computations are skipped and the result 0.0 is output. Different computations of Jv(x) are used corresponding to ranges of x and v.
171
BJR
x J v ( x ) Fa + n ( x ) 2
Fa + 2 k ( x )) (4.1)
m / 2 (a + 2k ) (a + k ) k! k =0
(4.3)
, it is computed until the k-th term becomes less than unit round-off, in relative to the first term. Single precision: 1 x 16, or 16< x 100 and v>0.115x+4 Double precision: 1 x <30, or 30 x 100 and v>0.115x+4 The recurrence formula is used for the computation. Let's suppose that m is a sufficiently large integer (determined by x, v, and the desired precision), and that is a sufficiently small constant (positive smallest number allowed for the computer used), and moreover that n and are determined by v=n+(n integer,0 <1) Initial values F +m+1 ( x ) = 0, F +m ( x ) = are set, and recurrence formula F + k 1 ( x ) = 2(a + k ) F + k ( x ) Fa + k +1 ( x ) x (4.2)
For the method of determining of m and other details, see Reference [81]. Single precision: 100<x<tmax and v15, or 16<x100 and v0.115x+4 Double precision: 100<x<tmax and v15, or 30 x 100 and v0.115x+4 The asymptotic expansion J v ( x) = 2 1 1 P( x , v ) cos x v + x 2 4
(4.4)
( v, 2 k ) ( 2 x) ( v, 2 k + 1) Q( x , v ) = ( 1) ( 2 x)
P( x , v ) = ( 1)
k =0 k 2k k k =0 2k
(4.5) (4.6)
2 2 1 2 2 3 2 2 k 1 v v v 2 2 2 2 (v , k ) = k!
is repeatedly applied to k=m,m 1,...,1. Then the value of function Jv(x) is obtained as
P(x,v) and Q(x,v) is computed until each k-th term relative to the first term is less than Single precision: max (unit round-off, 10-10) Double precision: max (unit round-off, 10-20)
172
BJ0
I11-81-0201 BJ0,DBJ0
Zero order Bessel function of the first kind J0(x) CALL BJ0(X,BJ,ICON)
Function This subroutine computes zero order Bessel function of the first kind J0 ( x ) =
IF(ICON.NE.0) WRITE(6,620) X,BJ,ICON 10 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HJ0(x)/) 610 FORMAT(1H,F8.2,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBJ=,E17.7,5X,10HCONDITION=,I10) END
( 1) ( x 2)
k
2k
k =0
( k !)
Method With |x|=8 as the boundary, the form of the approximation formula used for calculating Bessel function J0(x) changes. Since J0(x)=J0(x), x is used instead of |x| in the following. For 0 x 8 The expansion of J0(x) into power series
by rational approximations and the asymptotic expansion. Parameters X ..... Input. Independent variable x. BJ .... Output. Function value J0(x). ICON .. Output. Condition code. See Table BJ0-1
Table BJ0-1 Condition code Code 0 20000 Meaning No error |X| tmax Processing BJ is set to 0.0.
( 1) ( x 2) J ( x) = ( k !)
k 0 k =0 2
2k
(4.1)
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... ABS, DSIN, DCOS, and DSQRT Notes [Range of argument] |X| tmax The limits are set since sin(x/4) and cos(x/4) lose accuracy if |X| becomes large. (See (4) in the Method section.) Example The following example generates a table of J0(x) from 0.0 to 100.0 with increment 1.0.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,101 X=K-1 CALL BJ0(X,BJ,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BJ
(4.2)
(4.3)
Theoretical precision = 19.22 digits For x>8 The asymptotic expansion of J0(x) J0 ( x) = 2 P0 ( x ) cos( x 4) x
Q0 ( x ) sin ( x 4)
(4.4)
is evaluated through use of the following approximate expressions of P0(x) and Q0(x): Single precision: P0 ( x ) = ak z 2 k bk z 2 k , z = 8 x
2 2 k =0 k =0
(4.5)
173
BJ0
Q0 ( x ) = ck z 2 k +1 d k z 2 k , z = 8 x
1 2 k =0 k =0
(4.6)
(4.8)
Theoretical precision = 18.33 digits (4.7) For more information, see Reference [78]pp.141~149.
174
BJ1
600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HJ1(x)/) 610 FORMAT(1H,F8.2,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBJ=,E17.7,5X,10HCONDITION=,I10) END
Function This subroutine computes first order Bessel function of the first kind J1 ( x ) =
k =0
( 1) ( x 2) k !( k + 1)!
k
2 k +1
Method With |X as the boundary, the form of the approximation used to calculate Bessel function J1(x) changes. Since J1(x)=J1(x), x is used instead of |X| in the following. For 0 x 8 The expansion of J1(x) into power series
by rational approximations and the asymptotic expansion. Parameters X ..... Input. Independent variable x. BJ .... Output. Function value J1(x). ICON .. Output. Condition code. See Table BJ1-1
Table BJ1-1 Condition code Code 0 20000 Meaning No error |X| tmax Processing BJ is set to 0.0.
( 1) ( x 2) J ( x) = k !( k + 1)!
k 1 k =0
2 k +1
(4.1)
(4.2)
Comments on use Subprograms used SSL II ... MGSSL, UTLIM FORTRAN basic function ... ABS, DSIN, DCOS, and DSQRT Notes [Range of argument] |X| tmax The range limits are set since sin(x3/4) and cos(x 3/4) lose accuracy if |X| becomes too large. (See "Method".) Example The following example generates a table of J1(x) from 0.0 to 100.0 with increment 1.0.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,101 X=K-1 CALL BJ1(X,BJ,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BJ IF(ICON.NE.0) WRITE(6.620) X,BJ,ICON 10 CONTINUE STOP
(4.3)
Theoretical precision = 18.68 digits For x>8 The asymptotic expansion of J1(x) J1 ( x ) = 2 P1 ( x ) cos ( x 3 4) x
Q1 ( x ) sin ( x 3 4)
(4.4)
is evaluated through use of the following approximate expressions of P0(x) and Q0(x): Single precision: P1 ( x ) = ak z 2 k bk z 2 k , z = 8 x
2 2 k =0 k =0
(4.5)
(4.6)
(4.7)
175
BJ1
(4.8)
Theoretical precision = 18.28 digits For more information, see Reference [78]pp.141~149.
176
BKN
Function This subroutine computes integer order modified Bessel function of the second kind Kn ( x ) = ( 1) I n ( x ) + log x 2
n+1
Notes [Range of the argument X] 0<Xlog(flmax) If X is outside of the above range, overflow and underflow will occur in the calculation of e-x. The limit is provided for that reason. (See (4.4) and (4.5) in the Method sections of BK0 and BK1.) When calculating K0(x) and K1(x), BK0 and BK1 should be used. Example The following example generates a table of Kn(x) for the range of x from 1 to 10 with increment 1 and for the range of N from 20 to 30 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 20 N=20,30 DO 10 K=1,10 X=K CALL BKN(X,N,BK,ICON) IF(ICON.EQ.0) WRITE(6,610) X,N,BK IF(ICON.NE.0) WRITE(6,620) X,N,BK,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,5X,1HN,8X,5HKN(x)/) 610 FORMAT(1H,F8.2,I5,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,2HN=,I5,5X,3HBK=,E17.7,5X, 10HCONDITION=, * I10) END
( )}
2 k n
+ +
k 1 n 1 ( 1) (n k 1)! x 2 2 k =0 k!
( )
( 1)n
2
(x 2)
n +2 k
for x>0 by the recurrence formula, where, In(x) is integer order modified Bessel function of the first kind, and denotes the Euler's constant, and also the assumption
m=1
1 m = 0 is made.
Parameters X ..... Input. Independent variable x. N ..... Input. Order n of Kn(x). BK .... Output. Function value Kn(x). ICON .. Output. Condition code. See Table BKN-1. When N=0 or N=1, ICON is handled the same as the ICON of BK0 and BK1.
Table BKN-1 Condition codes Code 0 20000 30000 Meaning No error N>log(flmax) X0 Processing BK is set to 0.0. BK is set to 0.0.
Method Bessel function Kn(x) is calculated using the following recurrence formula Kk +1 ( x ) = 2k k ( x ) + k k 1 ( x ), k = 1,2, , n 1 x k (4.1)
Comments on use Subprograms used SSL II ... BK0, BK1, MGSSL, and ULMAX FORTRAN basic function ... IABS, FLOAT, ALOG, EXP, and SQRT
where, both K0(x) and K1(x) are calculated by using BK0 and BK1.
177
BKR
Example The following example generates a tale of Kv(x) for the range of x from 1 to 10 with increment 1 and for the range of v from 0.4 to 0.6 with increment 0.01.'
C **EXAMPLE** DO 20 NV=40,60 V=FLOAT(NV)/100.0 DO 10 K=1,10 X=FLOAT(K) CALL BKR(X,V,BK,ICON) WRITE(6,600) V,X,BK,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H ,F8.3,F8.2,E17.7,I7) END
Function This subroutine computes real order modified Bessel function of the second kind: Kv ( x ) =
I v ( x ) I v ( x ) 2 sin(v )
by the method by Yoshida and Ninomiya. Iv(x) is modified Bessel function of the first kind. Where x>0. Parameters X ..... Input. Independent variable x. N ..... Input. Order v of Kv(x). BK .... Output. Value of function Kv(x). ICON .. Output. Condition code. See Table BKR-1.
Table BKR-1 Condition codes Code 0 20000 Meaning No error X=0.0. Or BK was large enough to overflow. Processing The maximum value of the floating point is output to BK. BK=0.0.
Method The vth-order modified Bessel function of the second kind Kv(x) is defined as Kv ( x ) =
I v ( x ) I v ( x ) 2 sin(v )
(4.1)
using modified Bessel function of the first kind Iv(x) and I-v(x). When the order v is an integer n, the function is defined as the limit as vn. Since K-v(x)=Kv(x) (4.2)
30000
X<0.0
Comments on use Subprograms used SSL II ... AMACH, AFMAX, MGSSL, ULMAX FORTRAN basic functions ... FLOAT, ALOG, AMAX1, ALGAMA, GAMMA, ABS, SQRT, EXP Notes X>0.0 must be satisfied. When computing K0(x) or K1(x), BK0 or BK1 should be used for efficiency instead of this subroutine. When the values of Kv(x), Kv+1(x), Kv+2(x),..., Kv+M(x) are required at one time, first obtain Kv(x) and Kv+1(x) by this subroutine and obtain others in sequence from low order to high order as Kv+2(x), Kv+3(x), ..., Kv+M(x). When the subroutine is called repeatedly with a fixed value of v but with various, large values of x in magnitude, the subroutine computes Kv(x) efficiently by bypassing a common part of computation.
holds, computation is required only for v0. This subroutine directly computes the value of Kv(x) when 02.5. When v2.5, let denote the fractional part of v. When 0.5, this subroutine directly obtains K+1(x) and K+2(x) and when >0.5, it directly obtains K(x) and K+1(x). And then it computes the value of Kv(x) by Kv +1 ( x ) = 2v K ( x ) + Kv 1 ( x ) x v (4.3)
The Yoshida-Ninomiya method for the computation of Kv(x) when 0v2.5 is explained below. The method for computing Kv(x) depends on x and v. In Fig. BKR-1, one method is used in the domain A and another in the domain B. Method in the domain A The method here uses the series expansions of I-v(x) and Iv(x).
2 4 x x 1 x 2 2 I v ( x ) = + + + 2 (1 v ) 1! (2 v ) 2! (3 v ) (4.4) v
178
BKR
When 1/2(x/2)v2, that is log2vlog(x/2)log 2, cancellation may occurs (where, in the addition of a+b, when max (|a|, |b|)/|a+b| 2, a round-off error occurs. This is equivalent to having a binary round-off error of one digit or more). To compute 1(v,x) and 2(v,x) without any cancellation, it is sufficient to find the best approximation in relative sense to the function in the range of log 2 t log 2. f (t ) = et 1 1 t t 2 = + + + t 1! 2! 3! (4.9)
v v x 1 2 2 (v , x ) = v
1 (v , x ) =
(4.6)
qk t
2k
t pk t 2 k
k =0
(4.11)
The approximation formula depends on whether 0v0.5, 0.5<v1.5 or 1.5<v2.5. Here, an example with 0v0.5 is explained. From (4.4), (4.5) and (4.6), the following equation can be obtained: I v ( x ) I v ( x ) = v Ak (v , x ) + Bk (v , x )
k =0
(For detailed information on concrete values of M, N, pk and qk, refer to [88]) Also, as for Ak(v,x) in (4.8), to avoid cancellations in computing the value of (1/ (k+1v)1/ (k+1+v))/(k!v), the best approximation in relative sense should be provided. ~ If we denote the expression in { } by Ak (v ) we can find, ~ Ak (v ) = 1 1 1 + (k + v)(k v) ( k v) ( k + v) k! ~ ( ) (k 1) + Ak 1 v (4.12) 1
(4.7)
where, 1 1 1 x Ak (v , x ) = 2 k !v ( k + 1 v ) (k + 1 + v ) 2k 2 (v , x ) 1 1 (v , x ) x Bk (v , x ) = 2 k! ( k + 1 v ) (k + 1 + v ) (4.8)
2k
~ This means that only an approximation to A0 (v ) should be provided. However, for k=1, (4.12) causes cancellation. Therefore it can be used for k2. As a ~ ~ result, the best approximation to A0 (v ) and A1 (v ) in the range of 0 v0.5 is required. This subroutine uses the best approximation polynomials of the form
M ~ A0 (v) pn v 2 k k =0 N ~ A1 (v ) qn v 2 k k =0
When these values are computed, cancellation of digits may occur when v 0 . To avoid this, take the following procedures. First, in the computation of Bk(v,x), since 1(v,x) and 2(v,x) are of the same sign, no cancellation occurs in the addition. However, 1(v,x) and 2(v,x) can be computed according to their definitions only when (x/2)v<1/2 or when (x/2)>2.
(4.13)
(For detailed information on M, pk, N, qk, refer to [88].) Thus Ak(v,x) and Bk(v,x) can be obtained without cancellations. If 0v0.5, then A0(v,x)0 and Ak(v,x)0 (k=1,2,...) if x2, then Bk(v,x)0 and if x>2, then Bk(v,x)<0 (k=0,1,2,...). Therefore, in the addition in 179
BKR
(4.7), cancellations may occur. Testing results imply that no cancellation occurs in the domain A when 0 v0.5 in Fig.BKR-1. The items used in the sum in (4.7) becomes small enough as k becomes large. Therefore, the items used for convergence to the required accuracy is less. Consequently, if we use the best approximation (for detailed information on M and pk, refer to [88]), g(v ) = to g ( v) 2 sin ( v ) v (4.15)
When adding the shifted Ultraspherical polynomial orthogonal on the interval [0,] multiplied by on the right of (4.20), 1 * t t 2 f v(t ) + 2(t + 1) f v(t ) v 2 f v (t ) = Cm( ) (4.21) 4 where,
*( Cm
(t ) = C ( ) t
m * i =0 mi
(4.22)
is the shifted Ultraspherical polynomial. Equation (4.21) has the following mth degree polynomial solution.
k =0
pk v 2k
(4.14) f vm (t ) =
m k =0
*( a ) ai t i Cmk
(k + 1)ak 1 k
i =0
(4.23)
where, a0 = 1
k =0
Ak (v , x ) + Bk (v , x ) g(v )
ak = (4.16)
(4v
(k 1)
(4.24)
When v=0, K0(x) can be computed more efficiently from the expression, x 2
2k
Here fvm(t) is considered as the approximation polynomial to f(t). From the initial condition fvm(0)=1 (as t0, fv(t)1) can be determined. Then
m m
K0 ( x ) =
k =0
(k !)
x + log + k 2
(4.17) f vm (t ) =
( ) i Cmk ai t
* a k
k =0
which is the limit of (4.1) as v0,. instead of using (4.16). In (4.17), denotes the Euler's constant, k 1 = 0, k = (k 1) m=0 m If the required relative accuracy is assumed to be , when v < 1723 . x 2
1
( ) Cmk k =0 ( k + 1)a k k +1
*a
(k + 1)a
i =0
k 1
(4.25)
can be obtained. Although (4.25) contains and as *( a ) unknown, when =0.5 ( Cm ( t ) is a shifted Legendre polynomial) and =t, the accuracy reaches the best. In this case,
m m * Pmk ai t i k
(4.18) f vm (t ) =
k =0
Kv(x) and K0(x) are the same in the sense of relative accuracy. Then Kv(x) is computed by using (4.17). For the calculation when 0.5<v1.5 and 1.5<v2.5, the methods are almost the same as that above. Method in the domain B The method below is a generalization of the -method for computing Kn(x) of integer order. The method is based on the expression for Kv(x) of the form
(k + 1)a
i =0
k +1
tk
* Pmk k =0 (k + 1)a tk k +1
(4.26)
(4.27)
x 1 Kv ( x ) = e fv x 2x
(4.19)
By multiplying both the numerator and the denominator by tm, we obtain f vm (t ) = Gi (m, v )t i
m i =0 i =0 m
and uses the approximation to fv(1/x). Letting t=1/x, and fv(x) satisfies 1 (4.20) t 2 f v(t ) + 2(t + 1) f v(t ) v 2 f v (t ) = 0 4 180
Hi (m, v )t i
(4.28)
BKR
where, Gi (m, v ) =
i
ak k = 0 ( m + 1 i + k )a m+1i + k
* m ,mi + k
ci = (4.29) (4.30)
(m i )! P (m + 1)!( 2)
* m ,m i i
(4.38)
0 = 1
i 1 1 2 i = m l + v (i 1) = l 0 2
2
(4.39)
Equation (4.29) can be expressed using the power of v2 as follows: Gi (m, v ) = where, bij = 2 2 j 3i
i il
1 am+ I
bij (v
i j =0
(4.31)
v ( x)
Pm*,m k pi k ,l qk , j l
1 x e x
1 e i i i =0 x
j =0 i
dij v 2
( )
(4.40)
l =0 k = j l
(i k )! (m n + 1)
n= 0
(4.41)
pk,l and qk,l can be computed using the following recurrence formulas. pk , 0 = ( 2k 1) pk 1,0
2
pk ,l = pk 1,l 1 (2 k + 1) pk 1,l
2
pk ,k = pk 1,k 1 qk , 0 = ( 2m 2k + 3) qk 1,0
2
(1 l k 1)
In (4.40), when m is fixed, the relationship is such that the larger the x, the higher the accuracy. Also when x is fixed, the relationship is such that the larger the m, the higher the accuracy. Equation (4.40) is used for the domain B in Fig. BKR-1. This subroutine sets m as follows in consideration of efficiency. (4.35) Single precision: when x < 2, m=9 when 2 x < 10, m = 6 (4.42) when 10 x , m=4 Double precision: when x < 2, m = 28 when 2 x < 10, m = 16 (4.43) when 10 x , m = 11 This subroutine contains a table in which constants dij and ei are stored in the data statement.
181
BK0
Function This subroutine computes the values of zero order modified Bessel function of the second kind K0 ( x ) =
IF(ICON.NE.0) WRITE(6,620) X,BK,ICON 10 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HK0(x)/) 610 FORMAT(1H,F8.2,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBK=,E17.7,5X,10HCONDITION=,I10) END
k =1
( x 2)
2k
(k !)
k 1 m m=1 I 0 ( x ) + log x 2
( )}
Method With x=2 as the boundary, the approximation formula used to calculate modified Bessel function K0(x) changes. For 0<x<2 The power series expansion of K0(x) K0 ( x ) =
(where I0(x): zero order modified Bessel function of the first kind and : Euler's constant) by polynomial approximations and the asymptotic expansion. Where, x>0. Parameters X ..... Input. Independent variable x. BK .... Output. Function value K0(x). ICON .. Output. Condition code. See Table BK0-1.
Table BK0-1 Condition codes Code 0 20000 30000 Meaning No error X>log(flmax) X0 Processing BK is set to 0.0. BJ is set to 0.0.
k =1
( x 2)
2k
I 0 ( x ) + log x 2
1 (k !)2 m=1 m
(4.1)
( )}
(where I0(x): zero order modified Bessel function of the first kind, : Euler's constant) is calculated using the approximation formulas (4.2) and (4.3). Single precision:
5 x 5 K0 ( x ) = log a k x 2 k + bk x 2 k 2 k =0 k =0
(4.2)
Comments on use Subprograms used SSL II ... MGSSL, ULMAX FORTRAN basic function ... ALOG, EXP, and SQRT Notes [Range of argument X]. 0<Xlog(flmax) If X exceeds the limits, and underflow will occur during the calculation of e-x. This limit is provided for that reason. (See (4.5) and (4.6) in "Method".) Example The following example generates a table of K(x) from 1 to 100 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,100 X=K CALL BK0(X,BK,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BK
Double precision:
9 x 9 K0 ( x ) = log a k x 2 k + bk x 2 k 2 k =0 k =0
(4.3)
x ( 1) ( 1)( 9) + e 1 + 2x 8x 2!
(4.4)
is calculated using the approximation formulas (4.5) and (4.6) Single precision: K0 ( x ) = e x 8 z=2 x ak z k , x k =0 (4.5)
Double precision: K0 ( x ) =
8 e x 8 ak z k bk z k k =0 x k =0
(4.6)
182
BK1
Function This subroutine computes first order modified Bessel function of the second kind K1(x) K1 ( x ) = I 1 ( x ) + log( x 2) + 1 2
IF(ICON.NE.0) WRITE(6,620) X,BK,ICON 10 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HK1(x)/) 610 FORMAT(1H,F8.2,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBK=,E17.7,5X,10HCONDITION=,I10) END
k =0
k k +1 1 m + 1 m = =1 1 m m k !( k + 1)!
( x 2)
1 x
2 k +1
Method With x=2 as the boundary, the approximation formula used to calculate modified Bessel function K1(x) changes. For 0<x<2 K1 ( x ) = I 1 ( x ) + log( x 2) + 1 x 1 2
k k +1 1 m + 1 m k =0 k !( k + 1)! m=1 m=1
(where I1(x): first order modified Bessel function of the first kind, : Euler's constant) by polynomial approximations and the asymptotic expansion. Where, x>0. Parameters X ..... Input. Independent variable x. BK .... Output. Function value K1(x). ICON .. Output. Condition code. See Table BK1-1.
Table BK1-1 Condition codes Code 0 20000 30000 Meaning No error X>log(flmax) X0 Processing BK is set to 0.0. BK is set to 0.0.
( x 2)
2 k +1
(4.1)
(where I1(x): first order modified Bessel function of the first kind, : Euler's constant) is calculated using the approximation formulas (4.2) and (4.3). Single precision: x 5 K1 ( x ) = log a k x 2 k 2 k =0 5 1 + bk x 2 k x + k =0 x
} }
(4.2)
Comments on use Subprograms used SSL II ... MGSSL, ULMAX FORTRAN basic function ... ALOG, EXP, and SQRT Notes [Range of argument X]. 0< Xlog(flmax) If X exceeds the limits, and underflow will occur in the calculation of e-x. This limit is provided for that reason. (See (4.5) and (4.6) in "Methods".) Example The following example generates a table of k1(x) from 1 to 100 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,100 X=K CALL BK1(X,BK,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BK
(4.3)
1 x+ x
3 ( 5) ( 21) 1 + 3 + (8 x) 3!
x 3 3 ( 5) 1 + e 1 + (8 x)2 2 x 8x 2!
(4.4)
is calculated using the approximation formulas (4.5) and (4.6) Single precision: K1 ( x ) = e x 8 ak z k z=2 x , x k =0 (4.5)
Double precision: K1 ( x ) =
8 e x 8 a k x k bk x k =0 =0 k k x
(4.6)
183
BLNC
~ x = Dx
(3.1)
The back transformation of (3.1) can be performed using subroutine HBK1. (See the section on HBK1.) Example After balancing an n-order real matrix A, it is reduced to a real Hessenburge matrix H using subroutine HES1, then the eigenvalues are determined using subroutine HSQR. n100.
C **EXAMPLE** DIMENSION A(100,100),DV(100),PV(100),ER(100) * ,EI(100) 10 CONTINUE READ(5,500)N IF(N.EQ.0) STOP READ(5,510) ((A(I,J),I=1,N),J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610) (I,J,A(I,J),J=1,N) CALL BLNC(A,100,N,DV,ICON) WRITE(6,620) ICON IF(ICON.NE.0) GO TO 10 CALL HES1(A,100,N,PV,ICON) CALL HSQR(A,100,N,ER,EI,L,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) GO TO 10 WRITE(6,630) (ER(I),EI(I),I=1,L) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,5X,15HORIGINAL MATRIX,5X, 2HN=, * I3/) 610 FORMAT(/4(5X,2HA(,I3,1H,I3,2H)=,E14.7)) 620 FORMAT(1H0,20X,5HICON=,I5) 630 FORMAT(1H0,5X,10HEIGENVALUE/1H0,20X, * 4HREAL,16X,4HIMAG/(1H0,15X,2(E15.7, * 5X))) END
Function The diagonal similarity transformation shown in (1.1) is applied to an n-order matrix A. By this transformation, sums of the norms of elements in the corresponding i-th row and i-th column (i=1,...,n) are almost equalized for ~ the transformed real matrix A .
~ A = D 1 AD
(1.1)
D is a diagonal matrix. n1. Parameters A ..... Input. Real matrix A. ~ Output. Balanced real matrix A . A(K,N) is a two-dimensional array. K ..... Input. Adjustable dimension of array A. ~ N ..... Input. Order n on A and A . DV .... Output. Scaling factor (diagonal elements of D). DV is a one-dimensional array of size n. ICON .. Output. Condition code. See Table BLNC-1.
Table BLNC-1 Condition codes Code 0 10000 30000 Meaning No error N=1 N<1 or K<N Processing Balancing was not performed. Bypassed
Comments on use Subprograms used SSL II ... IRDIX and MGSSL FORTRAN basic function ... ABS Notes If there are large differences in magnitude of elements in a matrix, the precision of the computed eigenvalues and eigenvectors on that matrix can be adversely affected. This routine is used to avoid the adverse effects. If each element of a matrix is nearly the same magnitude, this routine should be omitted. If all elements of a row or column (except the diagonal element) are zero, balancing of the row and corresponding column is bypassed. In order to obtain the eigenvectors x of real matrix A, the back transformation of (3.1) must be applied to ~ ~ of matrix A eigenvectors x which has been balanced by this routine.
Method An n-order real matrix A is balanced through iterations of the diagonal similarity transformation. As=Ds-1As-1Ds s = 1,2,... (4.1)
Where A0=A.Ds is the diagonal matrix shown in (4.2), and s is the number of iterations. d1( s) Ds = d n( s )
d2
( s)
0
(4.2)
In the balancing of (4.1), excluding the diagonal elements, the sum of the magnitude of elements in the ith row of As is made almost equal to that of the magnitude of elements in the i-th column. Letting As
184
BLNC
k =1 k i
(4.8)
is saturated. If Dsi is defined as shown in (4.4), Ds of (4.2) can be expressed as (4.5). 1 1 Dsi = d i( s) 0 Ds=Ds1Ds2Dsn i i 1
di (s) is defined di (s)= k 2 for binary digits where = 16 for hexadecimal digits k is defined to satisfy the condition R FC 2 k R (4.10) (4.9)
(4.4)
1
(4.5)
From (4.10), when C< R/, k >, and when C R/, k0. Whether or not transformation is necessary is determined by
The equation (4.5) shows that the transformation of (4.1) can be performed by executing the transformation of (4.6) for i=1,2,...,n. Asi = Ds11 Asi1 Dsi where As 0 = As1 and As = Asn Dsi that is di (s) is defined such that the transformed i-th row and corresponding column satisfy the equation (4.3) at the time of transformation di (s)=1. Iterations of (4.1) continue until (4.3) is satisfied for all rows and corresponding columns. A brief description of this procedure follows: Excluding the diagonal element, the sums of magnitudes of elements in i-th row and corresponding column are computed. C aki
k =1 k i n
(4.6)
(C
2k
+ R ) < 0.95(C + R )
(4.11)
If (4.11) is satisfied, transformation is performed where d i( s) = k . If (4.11) is not satisfied, transformation is bypassed. Balancing ends when transformation can no longer be performed on any row or column. Then, the diagonal elements of D shown in (4.12) are stored as the scaling factor in the array DV. D=D1D2...Ds (4.12)
185
BLUX1
Array FA
u11 h u1h u2 2 h u2 h+1 unh nh unh n un1 n1 un1 n * * un n * * h h nh h
0
unh n
unh nh
un 1n1 un1 n un n
where L is a unit lower band matrix with band width h1, U is an upper band matrix with band width h(=min(h1+h2+1,n) and b is an n-dimensional real constant vector. Further, the order, the lower and upper band widths of the original matrix which has been LUdecomposed are n, h1 and h2 respectively, where n>h10 and n>h20. Parameters B ..... Input. Constant vector b. Output. Solution vector x. One-dimensional array of size n. FA .... Input. Matrix U. See Figure BLUX1-1. One-dimensional array of size nh. N ..... Input. Order n of matrices L and U. NH1 ... Input. Lower band width h1 of the LUdecomposed original matrix. NH2 ... Input. Upper band width h2 of the LUdecomposed original matrix. FL .... Input. Matrix L. One-dimensional array of size (n 1)h1. See Fig. BLUX1-2. IP .... Input. Transposition vector which indicates the history of the row exchange in partial pivoting. One-dimensional array of size n. ICON .. Output. Condition code. See Table BLUX1-1.
Table BLUX1-1 Condition codes Code 0 20000 30000 Meaning No error The coefficient matrix was singular. NNH1, NNH2, NH1<0, NH2<0 or there was error in IP. Processing Discontinued Bypassed Fig. BLUX1-2 Storage of elements of L in array FL Note:
Note:
Fig. BLUX1-1 Storage of elements of U in array FA Unit lower band matrix L Array FL m21
1 m2 1 1 mh +11
1
0
mh +11
1
h1
h1 1 mn nh
1
0
mn n h
1
mn1 n 2 1 mn n2 mn n1 1
(n 1) h1
h1
mn 1n 2 mn n 2 mn n1 * * h1 * *
The diagonal elements are not stored. The elements marked by ** are arbitrary values.
Comments on use Subprograms used SSL II .... MGSSL FORTRAN basic function ... MIN0 Notes A system of linear equations can be solved by calling this subroutine following subroutine BLU1. At this case, this subroutine requires the output parameters from subroutine BLU1 as the input parameters (except
186
BLUX1
for the constant vector). However, such equations can be solved by calling subroutine LBX1 in one step. This subroutine, by making use of band matrix characteristics, saves a data storage area. In some cases, however, depending on the size of the band width, a larger data storage area may be required than used by subroutine LUX provided for real general matrices. If that is the case, subroutine LUX may be used to more save data storage area. This subroutine is especially useful for the case where the upper and lower band widths of the coefficient matrix of order n are approximately less than n/3, provided both the band widths are equal. Example This example shows that the subroutine BLU1 is once called to decompose the n n matrix with lower band width h1 and upper band width h2 and then l systems of linear equations with the decomposed coefficient matrix are solved. n100, h120 and h220.
C **EXAMPLE** DIMENSION A(4100),B(100),FL(1980), * IP(100),VW(100), * NT1(6),NT2(6),NT3(6) DATA NT1/2HCO,2HEF,2HFI,2HCI, * 2HEN,2HT /, * NT2/2HCO,2HNS,2HTA,2HNT, * 2*(2H )/, * NT3/2HSO,2HLU,2HTI,2HON, * 2*(2H )/ READ(5,500) N,NH1,NH2,L NT=N*MIN0(NH1+NH2+1,N) READ(5,510) (A(I),I=1,NT) M=1 WRITE(6,600) N,NH1,NH2 CALL PBM(NT1,6,A,N,NH1,NH2) CALL BLU1(A,N,NH1,NH2,1.0E-6, * IS,FL,IP,VW,ICON) WRITE(6,610) ICON IF(ICON.EQ.0) GO TO 10 WRITE(6,620) STOP 10 READ(5,510) (B(I),I=1,N) CALL PGM(NT2,6,B,N,N,1) CALL BLUX1(B,A,N,NH1,NH2, * FL,IP,ICON) CALL PGM(NT3,6,B,N,N,1) M=M+1 IF(L.GT.M) GO TO 10 WRITE(6,630) STOP 500 FORMAT(415) 510 FORMAT(4E15.7) 600 FORMAT(1H1///5X, * 22HLINEAR EQUATIONS AX=B * /5X,6HORDER=,I4
* /5X,19HSUB-DIAGONAL LINES=,I4 * /5X,21HSUPPER-DIAGONAL LINES=,I4) 610 FORMAT(1H ,4X,5HICON=,I5) 620 FORMAT(1H /5X,18H** ABNORMAL END **) 630 FORMAT(1H /5X,16H** NORMAL END **) END
Subroutines PBM and PGM in these example are used to print out a band matrix and a real matrix, respectively. Those programs are described in the examples for subroutines LBX1 and MGSM. Method A system of linear equations LUx=b can be solved by solving two following equations Ly=b Ux=y (4.2) (4.3) (4.1)
where L is an n n unit lower band matrix with band width h1 and U is an n n upper band matrix with band width h (=min(h1+h2+1,n)). This subroutine assumes that the triangular matrices L and U have been formed using the Gaussian elimination method. Particularly, L is represented by L=(Mn-1Pn-1...M1P1)-1 (4.4)
where Mk is the matrix to eliminate the elements below the diagonal element in the k-th column at the k-th step of the Gaussian elimination method, and Pk is the permutation matrix which performs the row exchanging required in partial pivoting. (For further details, refer to method for subroutine BLU1). Solving Ly=b (Forward substitution) The equation (4.5) can be derived from the equation (4.4) by the equation (4.2). y=Mn-1Pn-1...M1P1b (4.5)
(n)
= M n1 Pn1 b ( n1)
y = b (n)
187
BLUX1
Then b1( k
+1)
0
) L = (m ),
T , ij
1 m k +1k mk + 2 k
1 0
Solving Ux=y (Backward substitution) Ux=y can be serially solved using equation (4.6). xk = y k
min ( n , k +h ) i = k +1
mnk
uki xi
, k = n, n 1,,1
In this subroutine, b(k+1) (k=0,1,...,n 1) are successively obtained by the following sequence: Corresponding to the row exchange at the k-th step of the Gaussian elimination process, the elements of constant vector b(k) are exchanged such that
~ b ( k ) = Pk b ( k )
By increasing the precision of the inner products in the equation (4.6), the effects of rounding errors is minimized.
188
BLU1
Array A u11
0
u1 h unh n u2 2
unh nh
Function An n n real general band matrix with lower band width h1 and upper band width h2 is LU decomposed using the Gaussian elimination method. A=LU (1.1)
un1n 1 un1 n un n
Where L is an unit lower band matrix and U is an upper band matrix. n>h10 and n>h20. Parameters A ..... Input. Matrix A. Output. Matrix U. See Fig. BLU1-1. Matrix A is stored in a one-dimensional array of size nNmin (h1+h2+1,n) in the compressed mode for band matrices. N ..... Input. Order n of matrix A. NH1 .... Input. Lower band width h1 of matrix A. NH2 .... Input. Upper band width h2 of matrix A. EPSZ .. Input. Tolerance for relative zero test of pivots in decomposition process of matrix A (0.0). When EPSZ is 0.0, the standard value is used. (See Notes.) IS .... Output. Information for obtaining the determinant of matrix A. (See Notes.) FL .... Output. The matrix L. See Fig. BLU1-2. One-dimensional array of size (n 1)h1. IP .... Output. The transposition vector which indicates the history of row exchanging that occurred in partial pivoting. One dimensional array of size n. (See Notes.) VW .... Work area. One-dimensional array of size n. ICON .. Output. Condition code. See Table BLU1-1.
Table BLU1-1 Condition codes Code 0 20000 Meaning No error The relatively zero pivot occurred. It is highly probable that the matrix is singular. NNH1, NNH2, NH1<0, NH2<0 or EPSZ<0.0 Processing Discontinued
Note:
m21
0
mh +11
1
h1
h1 1 mn nh
1
0
mn n h
1
mn1 n 2 1 mn n2 mn n1 1
(n 1) h1
h1
mn 1n 2 mn n 2 mn n1 * h1 * *
Note:
* The diagonal elements are not stored. The elements marked by ** may have invalid data.
30000
Bypassed
Comments on use Subprograms used SSL II .... AMACH, MGSSL FORTRAN basic functions .... ABS, MIN0 Notes This subroutine assumes that the relatively zero pivot occurs when the absolute value of the pivot is smaller than the largest absolute value of the elements, in the
189
BLU1
coefficient matrix, multiplied by EPSZ in the LUdecomposition using the Gaussian elimination method. In such a case, the processing is discontinued with ICON=20000. The standard value of EPSZ is 16 u, u being the unit round off. If the processing is to proceed at a low pivot value, EPSZ will be given the minimum value, but the result is not always be guaranteed. The elements of matrix U are stored in array A as shown in Fig. BLU1-1. Therefore, the determinant of matrix A can be obtained by multiplying the product of the n diagonal elements, i.e., n array elements A(i.h+1), i=0,1,...,n 1, by the IS value, where h=min(h1+h2+1,n). In this subroutine, the elements of array A are actually exchanged in partial pivoting. That is, if the Ith row ( I J ) has been selected as the pivotal row in the Jth stage (J=1,2,...,n 1) of decomposition, the elements of the Ith and Jth rows of matrix A are exchanged. Then, I is stored into IP(J) in order to record the history of this exchange. It is possible to solve a system of linear equations by calling subroutine BLUX1 following this subroutine. However, instead of these subroutines, subroutine LBX1 can be called to solve such an equations in one step. This subroutine, by making use of band matrix characteristics, saves data storage area. In some cases, however, depending on the size of the band width, a larger data storage area may be required (including work area) than used by subroutine ALU provided for real general matrices. If that is the case, subroutine ALU may be used to save more data storage area. This subroutine is especially useful for the case where the upper and lower band widths of the matrix of order n are approximately less than n/3, provided both the band widths are equal. Example For an n n matrix with lower band width h1 and upper band width h2, the LU-decomposition is computed. n100, h120 and h220.
C **EXAMPLE** DIMENSION A(4100),FL(1980),IP(100), * VW(100),NT1(6),NT2(15),NT3(10), DATA NT1/2HMA,2HTR,2HIX,3*(2H )/, * NT2/2HLU,2H-D,2HEC,2HOM,2HPO, * 2HSE,2HD,2HMA,2HTR,2HIX, * 5*(2H )/, * NT3/2HTR,2HAN,2HSP,2HOS,2HIT,2HIO, * 2HN,2HVE,2HCT,2HOR/ READ(5,500) N,NH1,NH2 NT0=MIN0(NH1+NH2+1,N) NT=N*NT0 READ(5,510) (A(I),I=1,NT) WRITE(6,600) N,NH1,NH2
CALL PBM(NT1,6,A,N,NH1,NH2) CALL BLU1(A,N,NH1,NH2,1.0E-6, * IS,FL,IP,VW,ICON) WRITE(6,610) ICON IF(ICON.EQ.0) GO TO 10 WRITE(6,620) STOP 10 CALL PBM(NT2,15,A,N,NH1,NH2) CALL PGM(NT3,10,IP,N,N,1) DET=IS DO 20 I=1,NT,NT0 DET=DET*A(I) 20 CONTINUE WRITE(6,630) DET WRITE(6,640) STOP 500 FORMAT(315) 510 FORMAT(4E15.7) 600 FORMAT(1H1 * ///5X,23HDETERMINANT COMPUTATION * /5X,6HORDER=,I4 * /5X,19HSUB-DIAGONAL LINES=,I4 * /5X,21HSUPER-DIAGONAL LINES=,I4) 610 FORMAT(1H,UX,5HICON=,I5) 620 FORMAT(1H/5X,18H** ABNORMAL END **) 630 FORMAT(1H,4X,4HDET=,E16.8) 640 FORMAT(1H/5X,16H** NORMAL END **) END
Subroutines PBM and PGM are used to print out a general band matrix and a real general matrix, respectively. Those programs are described in the examples for subroutines LBX1 and MGSM, respectively. Method Gaussian elimination method Generally, n n non-singular matrix A can be decomposed, with partial pivoting, into a unit lower triangular matrix L and an upper triangular matrix U as equation (4.1). A=LU (4.1)
Now, let A(k) represent the matrix at the k th step of Gaussian elimination method, where A(1)=A. The first step of the elimination is to obtain A(2) by eliminating the elements below the diagonal element in the first column. This process can be described as the form (4.2) in a matrix expression, A(2)=M1P1A(1) (4.2)
where P1 is a permutation matrix which performs the row exchanging required for partial pivoting and M1 is a matrix to eliminate the elements below the diagonal element in the first column of the permuted matrix. Similarly, the k th step of the elimination process can be described as the form (4.3). A(k+1)=MkPkA(k) (4.3)
190
BLU1
where 1 1 Mk = 0
(k ) (k ) mik = aik akk ,
0
1 mk +1k mk +2 k mnk
1 0
k (k ) A( ) = aij
( )
Procedure performed in the subroutine In the k-th step (k=1,...,n 1) of the elimination process, this subroutine obtains each element of the kth column of matrix L and the k-th row of matrix U using equations (4.10) and (4.11). (4.4) mik =
(k) aik (k) a kk
(4.5)
The principal minor A(k+1) which is eliminated in the (k+1)-th step is obtained using equation (4.12),
( k +1) (k ) a kl = a kl mkj u jl
and then matrix A (=A(1)) has been transformed into the upper triangular matrix A(n). Let matrices U and L represent the forms (4.6) and (4.7). U=A(n) L=(Mn1Pn1...M1P1)1 (4.6) (4.7)
l = j + 1, j + 2, , min( j + h1 + h2 , n)
k = j + 1, j + 2,, min( j + h1 , n)
(4.12)
Then, the equation (4.5) can be represented by the equation (4.8). A=LU Since 1 1 = 0 1 (4.8)
where A(k)=(aij(k)), L=(mij), U=(uij) Prior to each step of the elimination process, the pivotal element akk(k) in equation (4.10) is selected to minimize the effect of rounding errors as follows: That is, the first step is to select the largest value in the equation (4.13),
(k ) V a lk , l = k , k + 1,, min(k + h1 , n)
(4.13)
0
M k1
1 mk +1k mk + 2 k
and the next step is to regard the element alk(k) as the pivotal element, when Vl is the inverse of the largest absolute element in the l-th row of the matrix A, and then the elements of the l-th and k-th rows are exchanged. If the selected pivotal element akk(k) satisfies (4.9)
(k ) a kk max aij 16u
1 0
mnk
matrix L shown in the equation (4.7) is a lower triangular matrix. Thus matrix A is decomposed into unit lower triangular matrix L and upper triangular matrix U.
where A=(aij) and u is a unit round off, matrix A(1) is regarded as numerically singular and the processing is discontinued with ICON=20000. For more information, see References [1], [3], [4] and [8].
191
BMDMX
Array FA d11
0
d 33 d4 4
0 Function This subroutine solves a system of linear equations with a MDMT-decomposed real symmetric band matrix. P-1MDMTP-Tx=b (1.1)
1 0 0 1
The diagonal portion and the band portion corresponding to the maximum tolerable band width d11 d11d 2 1
d 21 d2 2 0 m32 d3 3 0 m4 3 d4 4
where M is an n n, unit lower band matrix having ~ band width h , D is a symmetric block diagonal matrix comprising symmetric blocks each at most of order 2, P is a permutation matrix to be used to interchange rows in the pivoting procedure when the coefficient matrix pivoting procedure when the coefficient matrix is MDMT-decomposed, b is an n-dimensional real constant vector, and x is an n-dimensional solution vector. Further, mk+1,k=0 if dk+1,k0, where M=(mij) and D=(dij) ~ for n> h 0. Parameters B ..... Input. Constant Vector b. Output. Solution vector x. One-dimensional array of size n. FA .... Input. Matrices M and D given in the compressed mode for symmetric band matrix assuming M to have band width hm. (See Figure BMDMX-1) One-dimensional array of size n(hm+1)hm(hm+1)/2. N ..... Input. Order n of the matrices M and D, constant vector b, and solution vector x. ~ NH .... Input. Band width h of matrix M. (See "Comments on Use".) MH .... Input. Maximum tolerable band width hm (N>MHNH) of matrix M. (See "Comments on Use".) IP .... Input. Transposition vector indicating the history of row interchange in the pivoting procedure. One dimensional array of size n. (See "Comments on Use".) IVW ... Work area. One-dimensional array of size n. ICON .. Output. Condition code. (See Table BMDMX1.)
0 0
Only the lower traiangular portion
m32 d 33 m4 3d 4 4
0
Note:
m3 2 1 m4 3 1
In this example, orders of blocks in D are 2, 1, and 1; band width of M is 1, and the maximum tolerable band width is 2.
Fig. BMDMX-1 Storing method of matrices M and D Table BMDMX-1 Condition codes Code 0 20000 30000 Meaning No error The coefficient matrix is singular. NH<0, NH>MH, NMH, or IP error. Processing Bypassed. Bypassed.
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... MIN0 Notes Simultaneous linear equations can be solved by calling this subroutine after decomposing the coefficient matrix into factors M, D, and MT using subroutine SBMDM; however, the solution is obtained by calling subroutine LSBIX in an ordinary case. Input parameters FA, NH, IP, and MH of this subroutine are the same as output parameters A, NH, IP, and input parameter MH of subroutine SBMDM. Example Simultaneous linear equations are solved after decomposing an n n real symmetric band matrix having band width h with subroutine SBMDM. Where ~ n100 and h hm50.
C **EXAMPLE** DIMENSION A(3825),B(100),IP(100),IVW(100) READ(5,500) N,NH,MH WRITE(6,600) N,NH,MH
192
BMDMX
NT=(N+N-MH)*(MH+1)/2 READ(5,510) (A(J),J=1,NT) EPSZ=0.0 CALL SBMDM(A,N,NH,MH,EPSZ,IP,IVW,ICON) WRITE(6,610) ICON IF(ICON.GE.20000) STOP READ(5,510) (B(I),I=1,N) CALL BMDMX(B,A,N,NH,MH,IP,IVW,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) STOP WRITE(6,630) (B(I),I=1,N) STOP 500 FORMAT(3I4) 510 FORMAT(4E15.7) 600 FORMAT(1H1/10X,2HN=,I3,5X,3HNH=,I3,5X, * 3HMH=,I3) 610 FORMAT(1H,5X,14HICON OF SBMDM=,I6) 620 FORMAT(1H,5X,14HICON OF BMDMX=,I6) 630 FORMAT(11X,15HCOLUTION VECTOR * /(15X,5E15.6)) END
(Pb)T=(b1',...,bn') Solving Dx(2)=x(1) For 1 1 pivot, the solution is obtained serially from xi 2 = xi 1 dii , i = 1, , n
( ) ( ) ( )
(4.8)
If 2 2 pivot is used in itenation i, xi+21 is obtained ( ) after xi 2 from (4.9), then iteration i+2 is processed.
1) xi( 2 ) = xi(1) di+1,i +1 di +1,i xi(+ d 1
xi +1
( 2)
( = (x
i +1
( 1)
dii di+1,i xi
(1 )
)d
(4.9)
where D = (dij ) , x ( 2 ) = ( x1( 2 ) , , xn( 2 ) ) Solving MTx(3)=x(2) by forward substitution For 1 1 pivot, the solution is obtained serially from xi( 3 ) = xi( 2 ) mki x k(3 )
n k =i +1
having coefficient expressed in MDMT-decomposed real symmetric band matrix is reduced to solve Mx(1)=Pb Dx(2)=x(1) MTx(3)=x(2) (PT)-1x=x(3) (4.2) (4.3) (4.4) (4.5)
, i = n,,1
3
(4.10)
(4.11)
where M is an n n unit lower band matrix, D is a symmetric block diagonal matrix comprising symmetric blocks each at most of order 2, b is a constant vector, and x is a solution vector. In this subroutine, it is assumed that M and D are matrices decomposed by the block diagonal pivoting method, where P is a permutation matrix. (See "Method" for subroutine SBMDM.) Solving Mx(1)=Pb by backward substitution. For the 1 1 pivot (the order of blocks in matrix D is 1), the solution is obtained serially from (4.6).
( 1) xi(1) = b i mik x k
k =1 i 1
where. x ( 3) = ( x1( 3) , , x n( 3) )
T
Solving (PT)-1x=x(3) Elements xi of solution vector x are obtained by multiplying the permutation matrix by vector x(3). Actually, however, these elements are obtained by exchanging elements of vector x(3) using values in transposition vector IP. The band structure of the coefficient matrix has been ignored for simplifying explanations above, however, the band structure is effectively used to efficiently process calculations in the actual program.
, i = 1, , n
(4.6)
If 2 2 pivot (the order of blocks in matrix D is 2) is (1) 1) used in iteration i, xi(+ from 1 is obtained after x i (4.7), then iteration i+2 is processed.
1 1 +1 mik x k xi + 1 = bi k =1
( )
i 1
( )
( ) ( ) M = (mij ) , x 1 = ( x1 1 , , xn1 ),
T
( )
(4.7)
193
BSCD2
Function Given observed value fij=f(xi ,yj), observation error i,j=xiyj, at lattice points (xi ,yj); i=1,2,...,nx, j=1,2,...,ny, a tolerance for the square sum of residuals t2 and initial sequence of knots 1,2,...,ns; 1,2,...,ls in the x- and y-directions, this subroutine obtains a bivariate B-spline smoothing function of degree m to the data in the sense of least squares in which the square sum of residuals is within the tolerance, by adding knots appropriately on the x- and y-axis. Namely, letting the numbers of knots in the x- and ydirections be nt and lt, the subroutine obtains the coefficients C, in the B-spline smoothing function (1.2), subject to (1.1).
n2t +lt =
j =1 i =1
n y nx
( xi y j )
nt 1
{f
i, j
S ( xi , y j )
t2
(1.1) (1.2)
S ( x, y ) =
lt 1
= m+1 = m+1
C , N ,m+1 ( x ) N ,m+1 ( y )
This subroutine outputs knots 1,2,...,nt, in the xdirection, 1,2,...,lt, in the y-direction, square sum of residuals (1.3) at each step of adding knots and statistics (1.4) and (1.5), along with coefficient C,.
n2r +lr =
j =1 i =1
n y nx
( x y )
i j
{f
i,j
S ( xi , y j )
(1.3)
(where, S ( x , y ) denotes m th degree B-spline smoothing function with knots 1,2,...,nr and 1,2,...,lr)
{n n (n
x y
+ m 1)(lr + m 1) ,
(1.4)
Here, xi>0, yj>0, m1, ns2, ls2 and the initial knots i , i=1,2,...,ns; j, j=1,2,...,ls should be satisfied. Parameters X ..... Input. Discrete points xi in the x-direction. One-dimensional array of size nx. NX .... Input. Number of xi , namely nx. Y ..... Input. Discrete points yj in the y-direction. NY .... Input. Number of yj, namely ny. FXY ... Input. Observed values fij.
Two-dimensional array of FXY(KF,NY). Input. Adjustable dimension (NX) of array FXY. SX .... Input. Observation errors xi in the xdirection. One-dimensional array of size nx. SY .... Input. Observation errors yj in y-direction. One-dimensional array of size ny. M ..... Input. Degree m of B-spline (See Notes). XT .... Input. Initial knots i , i=1,2,...,ns in the xdirection (See Notes). Output. Final knots i , i=1,2,...,nt in the xdirection. The results are output in the order 1<2<...<nt. One dimensional array of size NXL. NXT ... Input. The number of initial knots ns in the xdirection. Output. The number of knots nt finally used in the x-direction. YT .... Input. Initial knots j, j=1,2,...,ls in the ydirection (See Notes). Output. j, j=1,2,...,lt in the y-direction. The results are output in the order 1<2<...<lt. One-dimensional array of size NYL. NYT ... Input. The number of initial knots ls in the ydirection. Output. The number of knots lt finally used in the y-direction. NXL ... Input. Upper limit (ns) on the number of knots in the x-direction (See Notes). NYL ... Input. Upper limit (ls) on the number of knots in the y-direction (See Notes). RNOT .. Input. The tolerance t2 for square sum of residuals. A proper value is t2=nxny. C ..... Output. Smoothing coefficients C,, = m+1,m+2,...,lt1; =m+1,m+2,...,nt1. These are stored in C(+m, +m). Two-dimensional array of C(KC,NYL+M1) if array C. RNOR .. Output. Values of (1.3), (1.4) and (1.5) at each step of adding knots. Two-dimensional array of RNOR(3,KR), where KR=(NXLns)+(NYLnl)+1 Letting nr+lr=ns+ls, ns+ls+1, ... nt+lt, 2nr+jr is 2 stored in RNOR (1,Pr), nr +lr is stored in RNOR (2,Pr), and AICr is stored in RNOR (3,Pr), where Pr=(nrns)+(lrls)+1. (See Notes). VW .... Work area. One-dimensional array of size max (s1, s2), KF ....
194
BSCD2
where
s1 = n x + n y + 2m (m + 1)
+ max max n x + m, n y + m , s2 = min(nx , n y ) + 3 (m + 1) + nx + n y IVW ... + NXL + NYL + 2 Work area. One-dimensional array of size nx+ny+max(NXL,NYL)m Output. Condition code. See table BSCD2-1.
{ (
2 + min nx + m, n y + m (m + 1)
because the normal equation with respect to C, becomes ill-conditioned as degree m is increased. Initial knots i , j, (i=1,2,...,ns; j=1,2,...,ls) can be typically given by
1 = min( x i ), ns = max( xi )
i j
ns = ls = 2
1 = min y j , ls = max y j ,
j
( )
( )
ICON ..
Table BSCD2-1 Condition code Code 0 10000 Meaning No error Although the number of knots in the x-direction reached the upper limit, the convergence criterion (1.1) was not satisfied. Although the number of knots in the y-direction reached the upper limit, the convergence criterion (1.1) was not satisfied. One of the following occurred: 1 xi0 2 yi0 3 M<1 4 XT(I)=XT(k), where IK or YT(I)=YT(k), where IK 5 ns<2 or s<2 6 NXL<ns or NYL< s 7 Processing Outputs the most recently obtained smoothing function.
11000
30000
Bypassed
The upper limit NXL and NYL on the number of knots in the x- and y-directions should preferably be given by nx/2 and ny/2 respectively. (If the number of knots increases, the normal equation becomes illconditioned.) This subroutine terminates when the number of knots reaches the upper limit regardless of satisfying equation (1.1), setting ICON=10000 (for the x-direction) or ICON=11000 (for the y-direction). The information output to RNOR is the history of various criteria in the process of adding knots at each step. The history can be used for checking the obtained smoothing function. These criteria generally decrease according to the addition of knots, the change becoming slow as step goes. Particularly when 2nr+lr and AICr are virtually unvarying the smoothing function exhibits good one. The user can check the obtained smoothing functions by printing out the contents of RNOR. Example The bivariate third degree B-spline smoothing function is obtained by inputting lattice points (xi ,yi ): i=1,2,...,80, j=1,2,...,60, observed values fij, and observation errors xi and yj in x- and y-directions. Initial knots are given as (3.1) and (3.2) in x- and ydirections respectively. The upper limit on the number of knots are 20 for the x-direction and 15 for the ydirection.
max j
j
( ) > max (y )
j j
( )
(3.1) (3.2)
( )
Then, letting VXr and VYs denote (3.3) and (3.4), subroutine BSFD1 computes the smoothing value at each point and the first-order partial derivatives in the xand y-directions. VX r = x min + ( xmax xmin )r 10 VYs = ymin + ( ymax ymin )s 10 r = 0, 1, , 10 (3.3) (3.4)
s = 0, 1, , 10
C
195
BSCD2
NX=80 NY=60 READ(5,500) (X(I),SX(I),I=1,NX), * (Y(J),SY(J),J=1,NY) DO 10 I=1,NX DO 10 J=1,NY READ(5,510) FXY(I,J) 10 CONTINUE M=3 NXT=2 NYT=2 XMAX=X(1) XMIN=X(1) YMAX=Y(1) YMIN=Y(1) DO 20 I=2,NX IF(X(I).GT.XMAX) XMAX=X(I) IF(X(I).LT.XMIN) XMIN=X(I) 20 CONTINUE DO 30 J=2,NY IF(Y(J).GT.YMAX) YMAX=Y(J) IF(Y(J).LT.YMIN) YMIN=Y(J) 30 CONTINUE XT(1)=XMIN XT(2)=XMAX YT(1)=YMIN YT(2)=YMAX NXL=20 NYL=15 RNOT=FLOAT(NX*NY) C CALL BSCD2(X,NX,Y,NY,FXY,80,SX,SY, * M,XT,NXT,YT,NYT,NXL,NYL,RNOT,C,22, * RNOR,VW,IVW,ICON) WRITE(6,600) ICON IF(ICON.EQ.30000) STOP WRITE(6,610) NT=NXT+NYT DO 40 I=4,NT IADD=I-3 WRITE(6,620) I,(RNOR(J,IADD),J=1,3) 40 CONTINUE C HX=(XMAX-XMIN)/10.0 HY=(YMAX-YMIN)/10.0 DO 70 I=1,11 VX=XMIN+HX*FLOAT(I-1) WRITE(6,630) VX WRITE(6,640) DO 60 J=1,11 VY=YMIN+HY*FLOAT(J-1) DO 50 K=1,3 KM1=K-1 ISWX=MOD(KM1,2) ISWY=KM1/2 CALL BSFD1(M,XT,NXT,YT,NYT,C,22, * ISWX,VX,IX,ISWY,VY,IY,RR(K),VW,ICON) 50 CONTINUE WRITE(6,650) VY,(RR(K),K=1,3) 60 CONTINUE 70 CONTINUE STOP 500 FORMAT(2F10.0) 510 FORMAT(F10.0) 600 FORMAT(10X,5HICON=,I5//) 610 FORMAT(8X,12HNO. OF KNOTS,9X, * 9HRNOR(1,*),11X,9HRNOR(2,*),11X, * 9HRNOR(3,*)/)
620 FORMAT(10X,I2,8X,3(5X,E15.8)) 630 FORMAT(//5X,3HVX=,E15.8) 640 FORMAT(16X,2HVY,13X,14HSMOOTHED VALUE, * 8X,10HDS(X,Y)/DX,10X,10HDS(X,Y)/DY) 650 FORMAT(5X,4(5X,E15.8)) END
Method This subroutine obtains bivariate m-th degree B-spline smoothing function by adding knots so that square sum of residuals may become less than the given tolerance t2. Now, let us assume 1, 2, ..., nr and 1, 2, ..., lt are given in the x- and y-direction respectively which satisfy the following: 1<2<.....<nr 1<2<.....<tr At the initial step, nr=ns and lr=ls. The coefficient C, of the bivariate m-th degree spline function S ( x, y ) =
lr 1 nr 1
= m+1 = m+1
C , N ,m+1 ( x ) N ,m+1 ( y )
(4.1)
in which the above knots are used, is determined so that the square sum of residuals
n y nx
1 f i , j S ( xi , y j ) 2 j =1 i =1 x y j
2 i
(4.2)
assumes the minimum. Such C, can be obtained by solving the system of linear equations (normal equations) resulting from partially differentiating (4.2) with respect to C, and equating it to zero. The value of (4.2) corresponding to the obtained C, is assumed to be 2nr+lr. If 2nr+lr 2t, (4.1) can be taken as the bivariate m-th degree B-spline smoothing function. If 2nr+lr >2t, determine the new knots to be added under the following procedures. Compute residuals ij=fij S xi , y j j=1,2,...,ny at each point. Using these values, compute ui = 1 ny r , s 2 {r i xr < i +1} x r n y s=1 y s
2
i=1,2,...nx,
1 nx r ,s vj = 2 {s j ys < j +1 } y s nx r =1 x r
(4.4)
The maximum values of { ui |1 i nr1}, { uj|1 j lr1} are assumed to be ui and vj. When ui is greater than vj, nr is increased by 1 assuming =(i +i+1)/2 to be added. On the other hand, when vj greater than ui , lr is increased by 1 assuming =(j+j+1)/2 to be added.
196
BSCD2
Replacing the updated knots in the x- or y-direction in the ascending order, repeat the above mentioned procedures. This is repeated until the square sum of square
becomes less than the given value t2, updating knots and increasing the number of knots subsequently.
197
BSCT1
Function Using the bisection method, the m largest or m smallest eigenvalues of an n-order real symmetric tridiagonal matrix T are determined. 1 m n . Parameters D ..... Input. Diagonal elements of tridiagonal matrix T. D is a one-dimensional array of size n. SD .... Input. Subdiagonal elements of tridiagonal matrix T. SD is a one-dimensional array of size n. The elements are stored in SD(2) to SD(N). N ..... Input. Order n of the tridiagonal matrix. M ..... Input. M=m ... The number of largest eigenvalues desired. M=m ... The number of smallest eigenvalues desired. EPST .. Input. The absolute error tolerance used to determine accuracy of eigenvalues (refer to equation (4.9) in the Method section). when a negative value is given, an appropriate default value is used. E ..... Output. m eigenvalues. Order in descending order if M is positive and in ascending order if M is negative. E is a one-dimensional array of size m. VW .... Work area. VW is a one-dimensional array of size n+2m. ICON .. Output. Condition code. Refer to Table BSCT1-1.
Table BSCT1-1 Condition codes Code 0 10000 30000 Meaning No error N=1 N<|M| or M=0 Processing E(1)=D(1) Bypassed
routine or TRQL can be used to determine the eigenvalues. If n/4 or more eigenvalues are being determined, computation time is generally better using TRQL instead of this routine. If the possibility of an eigenvalue being zero exists, refer to "Convergence criterion and EPST parameter" in the Method section, then specify EPST accordingly. Example After an n-order real symmetric matrix is first reduced to a triagonal matrix using TRID1, m eigenvalues are calculated. n100.
C **EXAMPLE** DIMENSION A(5050),D(100),SD(100),E(100), * VW(300) 10 READ(5,500) N,M,EPST IF(N.EQ.0) STOP NN=N*(N+1)/2 READ(5,510) (A(I),I=1,NN) WRITE(6,600) N,M NE=0 DO 20 I=1,N NI=NE+1 NE=NE+1 20 WRITE(6,610) I,(A(J),J=NI,NE) CALL TRID1(A,N,D,SD,ICON) WRITE(6,620) ICON IF(ICON.EQ.30000) GO TO 10 CALL BSCT1(D,SD,N,M,EPST,E,VW,ICON) WRITE(6,630) WRITE(6,620) ICON IF(ICON.EQ.30000) GO TO 10 MM=IABS(M) WRITE(6,640) (I,E(I),I=1,MM) GO TO 10 500 FORMAT(2I5),E15.7) 510 FORMAT(5E15.7) 600 FORMAT(1H1,10X,18H** ORIGINAL MATRIX/ * 11X,10H**ORDER =,I5,10X,6H** M=,I3/) 610 FORMAT(1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT(/11X,19H** CONDITION CODE =,I5/) 630 FORMAT(1H0/11X,14H** EIGENVALUES) 640 FORMAT(5X,2HE(,I3,2H)=,E15.7) END
Comments on use Subprogram used SSL II ... AMACH and MGSSL FORTRAN basic function ... IABS,ABS and AMAX1 Notes Normally, when determining the eigenvalues of a real symmetric matrix, the subroutine TRID1 is used first to reduce that matrix to a tridiagonal matrix, then this
Method Using the bisection method, the m largest or m smallest eigenvalues are determined from n-order real symmetric tridiagonal matrix T. If a subdiagonal element of real symmetric tridiagonal matrix T shown in Fig. BSCT1-1 is zero, that matrix can be split, into submatrices at that point. If T can be split the eigenvalues of T can be obtained by determining the eigenvalues of each submatrix. Since the bisection method is applied to each submatrix, in the explanation below, T is assumed not to be split, i.e., bi 0.
198
BSCT1
For the matrix (TI) shown in Fig. BSCT1-2, the value that satisfy det(TI)=0 (4.1)
are the eigenvalues of T. Let the leading principle minor of the matrix (TI) be Pi (), then the recurrence formula in (4.2) can be developed. P0 ( ) = 1, P1 ( ) = c1
where, u is the unit round-off. Using this method overflow and underflow can be avoided, and L() can still be calculated even if bi=0. Now consider determining the largest k-th eigenvalue. Suppose the eigenvalues have the relationship 12.....k.....n (4.6)
(4.2)
1) Using Gershgorin's Method, interval [l0,r0] which includes all n eigenvalues is determined. r0 = max ci + bi + bi+1 i n
1
The polynomials P0(), P1(), ..., Pn() of (4.2) is a Sturm sequence. Let L() be the number of agreements in sign of consecutive members of this sequence, then L() is equal to the number of eigenvalues which are smaller than . However, if Pi ()=0, the sign of Pi -1() is used. In the actual calculations, (4.2) is replaced by the sequence: qi ( ) = Pi ( ) Pi1 ( ) , i = 1,2, , n (4.3)
l0
)} { ( = min{c ( b + b )}
1i n i i i +1
(4.7)
where b1=0, bn+1=0. 2) Iterations of (4.8) are continued until k is approximately in the midpoint of interval [lj,rj] hj = (l j + rj ) 2 If L(hj ) < k then take I j +1 = I j and rj +1 = hj If L(hj ) < k then take I j +1 = hj and rj+1 = rj j = 0,1,2,
Using (4.3), L() is easily determined. L() is the number of cases that the sequence qi () yields a positive or zero value. From (4.2) and (4.3) qi () is q1 ( ) = cl qi ( ) = (ci ) b qi1 ( ) , i = 2,3,, n
2 i
(4.8)
(4.4)
c1 b2
b2 c2 b3 b3 c3 b4 bn cn
Interval [lj,rj] in which k lies is bisected with each interation of (4.8). Using 1) and 2), this routine determines the interval in which the m largest eigenvalues lie. Then in that interval, eigenvalues are determined for each submatrix. When m eigenvalues have been obtained, processing is terminated. Convergence criterion and EPST Parameters In this routine, convergence is determined by rj li 2u( l j + rj ) + EPST (4.9)
c1
b2 b3 c3 b4 bn cn
b2 c2 b3
EPST is specified as the allowable absolute error tolerance in determining the eigenvalues. When (4.9) is satisfied, (lj+rj)/2 is considered an eigenvalue. If EPST=0.0, (4.9) becomes rj li 2u( l j + rj
bn
(4.10)
In this case, bisection of the interval is continued until the least significant digits of lj and rj become approximately equal, such that it takes a long time to compute the eigenvalue. EPST is used to indicate the precision at which this computation is terminated. EPST
199
BSCT1
is also a safeguard, since (4.10) would never be satisfied for eigenvalues which are zero. When a negative EPST is specified, for each submatrix, the following default value is used. EPST = u max( l0 , r0 ) (4.11)
Where l0 and r are the upper and lower limits of the range obtained by the Gerschgorin method which includes eigenvalues of each submatrix. For further information see References [12] pp.299-302, [13] pp.249-256, and [15].
200
BSC1
E32-31-0102
BSC1, DBSC1
B-spline smoothing coefficient calculation (with fixed knots) CALL BSC1(X, Y, W, N, M, XT, NT, C, R, RNOR, VW, IVW, ICON) Function Given observed values y1, y2, ..., yn at points x1, x2, ..., xn, weighted function values wi=w(xi ), i=1,2,...,n, and knots of the spline function 1, 2, ..., ni, the B-spline smoothing function in the sense of least squares is obtained. In other words, 1et S ( x ) = c j N j ,m+1 ( x )
j = m +1 nt 1
(1.1)
be the m-th (m: either an odd or even integer) degree Bspline smoothing function to be obtained, and then the smoothing coefficients cj's which minimize the sum of squares of the weighted residual:
2 m = wi yi S ( xi ) n i =1
Parameters X ..........Input. Discrete points xj's. One-dimensional array of size n. Y ..........Input. Observed values yi . One-dimensional array of size n. W .........Input. Weighted function values. One-dimensional array of size n. N ..........Input. Number of the discrete points. M .........Input. Degree of the B-spline. See Notes. XT........Input. Knots j's. See Notes. One-dimensional array of size nt. Output. If on input XT(1)<XT(2)<...<XT(nt) was not satisfied, XT's are aligned to satisfy it on output. NT........Input. Number of the knots, nt. C ..........Output. Smoothing coefficients cj's. One-dimensional array of size nt+m-1, R ..........Output. Residuals yi S ( xi ) , i=1,2,...,n. RNOR ..Output. Square sum of the weighted residual, m2. VW.......Work area. One-dimensional array of size (nt+m)(m+1). ICON....Output. Condition code. See Table BSC1-1.
Table BSC1-1 Condition codes Code 0 30000 Meaning No error Either of the followings occurred: (a) At least one wi is negative. (b) M<1 (c) XT(I)=XT(K) (IK) (d) NT<3 (e) Ne<NT+M-1 Processing Bypassed
(1.2)
are obtained. The interval I=[min(j),max(j)] spanned by the knots {i } does not always have to contain all of the n discrete points. For example, as shown in Fig. BSC1-1, the I can be specified as a part of the interval Ix=[min(xi ),max(xi ) which is spanned by all of the discrete points. If so, S ( x ) given by (1.1) such discrete points, (whose number is, say, ne) as contained in the interval so, when taking the summation in (1.2), only the discrete points contained in the interval I have to be taken into consideration. Here, wi 0, m1, ni 3, jk (jk+) and nent+m-1.
Comments on use Subprograms used SSL II ... MGSSL, UREO1, UNCA1, UCDB1, UCAO1 and UBAR1 FORTRAN basic function ... DSQRT Notes By calling subroutine BSF1 after subroutine BSC1, the interpolated values as well as derivatives or integrals can be obtained based on the B-spline smoothing function (1.1). The parameter values of M, XT, NT and C are passed from BSC1 to input to BSF1. The degree m is preferably 3 but no greater than 5, because the normal equation (see "Method") used when obtaining the smoothing coefficients cj's become
201
BSC1
ill-conditioned as m becomes large. It is important for the knots i to be located according to the behavior of observed values. In general, a knot should be assigned to the point at which the observed values have a peak or change rapidly. Any knot should not be assigned in an interval where the observed values change slowly. (See Fig. BSC1-2.)
1 , m + 1 j 0 t j j , 1 j nt ,n + 1 j n + m t nt t
(4.3)
1
t1 t0
2
t2
3
t3
nt
tnt tnt+1
Tnt+m
3 4 2 1 Fig.BSC1-2 Knots i
x 6
Among all the spline functions represented as (4.1), the one which minimizes (4.2) can be obtained by solving so-called a normal equation with respect to cj's. That is, taking partial derivatives of m2 in (4.2) with respect to cj's and setting them to zero, the normal equation with respect to cj's can be obtained as follows.
nt 1 j = m+1
Example See the example given for subroutine BSF1. Method By setting the m-th degree B-spline smoothing function as S ( x ) = c j N j ,m+1 ( x )
j = m +1 nt 1
{ w N
n i =1 i
k ,m+1
(x ) N
i
j ,m+1
(x ) c
i
= wi yi N k ,m+1 ( xi )
n i =1
(4.4)
(4.1)
The above is a system of linear equations of order (nt+m-1) and the coefficient matrix is of the form of a symmetric band matrix. Fig. BSC1-4 shows an example of the matrix for m=3 an nt=5. * * * * 0 * * * * * * * * * * * * * * * * * * 0 * * * *
the subroutine obtains the smoothing coefficients cj's which minimize the sum of squares of the weighted residuals.
2 m = wi yi S ( xi ) n i =1
(4.2)
The interval in which S ( x ) is defined is I = [min(j), max(j)] spanned by the user specified knots {j}. For simplicity let's assume the knots {j} satisfy the relationship j<j+1 (j=1,2,...,nt-1), and all of the n discrete points xi 's are contained in the interval [l,m]. First, the knots {tj} of the B-spline Nj,m+1(x) are taken by using {j} as follows (see Fig. BSC1-3):
* * * * * *
* * * * *
Therefore, solving Eq. (4.4) gives cj's. This subroutine solves the linear equations above by using Cholesky method (LTL decomposition method) with the slave subroutines UNCA1 and UCDB1.
202
BSC2
E32-31-0202 BSC2, DBSC2 B-spline smoothing coefficient calculation (variable knots) CALL BSC2(X,Y,S,N,M,XT,NT,NL,RNOT,C,RNOR,VW,I VW,ICON) Function Given observed values y1, y2, ..., yn at discrete points x1, x2, ..., xn, observation errors 1, 2, ..., n, a tolerance t2 for the square sum of residuals, and initial knots 1, 2, ...,ns, then this subroutine obtains a B-spline smoothing function of degree m to the data in the sense of least squares, by adding knots so that the square sum of residuals becomes within the tolerance. Namely, letting nt denote the number of knots finally used, and n2t the corresponding square sum of residuals, the subroutine obtain the coefficients cj in the B-spline smoothing function (1.1), subject to (1.2).
N ..........Input. Number n of the discrete points. M .........Input. Degree m of the B-spline. (See Notes.) XT........Input. Initial knots j, j=1,2,...,ns. (See Notes.) Output. Knots j, j=1,2,...,nt finally used. The results are output in the order of 1<2<...<nt. One-dimensional array of size NL. NT........Input. Number ns of initial knots. Output. Number nt of knots finally used. NL........Input. The upper limit on the number of knots. (See Notes.) RNOT...Input. The tolerance t2 for the square sum of residuals. A proper value is t2 =n. C ..........Output. Smoothing coefficients Cj, j=-m+1, m+2, ..., nt-1. Cj is stored in C(j+m). One-dimensional array of size (NL+M-1) RNOR ..Output. Values of (1.3), (1.4) and (1.5) at each step in which knots are added. Two-dimensional array RNOR(3,NL-ns+1). Letting nr=ns,ns+1,...,nt, n2r is stored in RNOR(1,nr-ns+1),
n2t =
2 1 t2 y S x ( ) i i 2 i =1 i n
(1.1)
S ( x ) = c j N j ,m+1 ( x )
j = m +1
nt 1
(1.2)
This subroutine outputs final knots 1, 2, ..., nt, square sum of residuals (1.3) at each step in which knots are added and the statistics (1.4) and (1.5).
n2r =
1 yi S ( xi ) 2 i =1 i
n
(1.3)
(where S ( x ) is an m-th degree B-spline smoothing function in which 1, 2, ..., nr are knots.)
nr = n2r
2
{n (n
+ m 1)
30000
(1.4)
(1.5)
Here, i >0, m1, ns2 and initial knots j must satisfy min j min( xi ), max j max( xi )
j
( )
( )
Parameters X ......... Input. Discrete points xi . One-dimensional array of size n. Y ......... Input. Observed values yi . One-dimensional array of size n. S .......... Input. Observation errors i . (See Notes.) One-dimensional array of size n.
Comments on use Subprograms used SSL II ... AFMAX, MGSSL, UPOB1, UPCA1, UREO1, UBAS0, UCDB2 FORTRAN basic function ... SQRT, IFIX, ABS, FLOAT, ALOG
203
BSC2
Notes By calling subroutine BSF1 after this subroutine, smoothed values, derivatives, or integrals can be obtained based on (1.2). At that time, the parameter values of M, XT, NT and C must be the same as those used in BSF1. An appropriate value for degree m (either even or odd) is 3, but the value should not exceed 5. This is because the normal equation with respect to smoothing coefficient Cj becomes ill-conditioned as degree m increases. Initial knots j, j=1,2,...,ns can be generally given by
NT=2 XMAX=X(1) XMIN=X(1) DO 10 I=2,N IF(X(I).GT.XMAX) XMAX=X(I) IF(X(I).LT.XMIN) XMIN=X(I) 10 CONTINUE XT(1)=XMIN XT(2)=XMAX NL=20 RNOT=FLOAT(N) C CALL BSC2(X,Y,S,N,M,XT,NT,NL,RNOT, * C,RNOR,VW,IVW,ICON) WRITE(6,600) ICON IF(ICON.EQ.30000) STOP WRITE(6,610) DO 20 I=2,NT IADD=I-1 WRITE(6,620) I,(RNOR(J,IADD),J=1,3) 20 CONTINUE C H(XMAX-XMIN)/50.0 WRITE(6,630) DO 40 J=1,51 V=XT(1)+H*FLOAT(J-1) DO 30 L=1,4 ISW=L-1 CALL BSF1(M,XT,NT,C,ISW,V,I, * RR(L),VW,ICON) 30 CONTINUE WRITE(6,640) V,(RR(L),L=1,4) 40 CONTINUE STOP C 500 FORMAT(3F10.0) 600 FORMAT(10X,5HICON=,I5//) 610 FORMAT(8X,12HNO. OF KNOTS,9X, * 9HRNOR(1,*),11X,9HRNOR(2,*),11X, * 9HRNOR(3,*)/) 620 FORMAT(10X,I2,8X,3(5X,E15.8))
1 = min ( xi ), ns = max ( xi )
i i
ns = 2
Observation error i is an estimate for the error contained in the observed value yi . For example, if yi has di significant decimal digits, the value 10-di yi can be used as i . i is used to indicate how closely S ( x ) should be fit to yi . The larger i is, the less
closely S ( x ) is fit to yi .
Upper limit NL on the number of knots should be given a value near n/2 (if the number of knots increases, the normal equation becomes illconditioned). This subroutine terminates processing by setting ICON=10000 when the number of knots reaches the upper limit regardless of (1.1). The information output to RNOR is the history of various criteria in the process of adding knots at each step. The history can be used for checking the obtained smoothing function. Example By inputting 100 discrete points xi , observed values yi and observation errors i , a third degree B-spline smoothing function is obtained. Here, the initial knots are taken as
Method This subroutine obtain the m-th degree B-spline smoothing function such that the square sum of residuals is less than a given tolerance t2 , by adding knots adaptively. Suppose that knots 1, 2, ..., nr have already been determined and arranged in the order 1<2<.....<nr where, initially nr=ns. The coefficients Cj in m-th degree spline with the knots above S ( x ) = c j N j ,m+1 ( x )
j = m +1 nr 1
and the upper limit on the number of knots to be 20. Subsequently smoothed values and 1st through 3rd order derivatives are computed at each point of v j = 1 + ( xmax xmin ) j / 50 j = 0,1, ,50 by using subroutine BSF1.
C **EXAMPLE** DIMENSION X(100),Y(100),S(100),XT(20), * C(25),RNOR(3,20),VW(120), * IVW(125),RR(4) N=100 READ(5,500) (X(I),Y(I),S(I),I=1,N) M=3
(4.1)
i =1
1 yi S ( xi ) i2
(4.2)
204
BSC2
if , (4.1) can be taken as the m-th degree Bspline smoothing function. 2 If nr > t2 , the square sum of residuals
2 nr 2 t
2 ( j , nr ) =
j xi < j +1
1 yi S ( xi ) i2
(4.3)
for each subinterval [j,j+1] is computed. Then we add, to the current set of knots, the midpoint =(i +i+1)/2 of the interval in which 2(j,nr) takes the maximum. The updated knots are arranged in ascending order, and letting this be 1, 2, ..., nr+1, then the above process is repeated. This processing is repeated until the square sum of squares becomes less than the tolerance t2 .
205
BSEG
B51-21-0201
BSEG, DBSEG
Eigenvalues and eigenvectors of a real symmetric band matrix (Lutishauser-Schwarz method, bisection method and inverse iteration method) CALL BSEG (A, N, NH, M, NV, EPST, E, EV, K, VW, ICON) Function This subroutine obtains the largest or smallest m eigenvalues of a real symmetric band matrix A of order n and band width h by using the Lutishauser-Schewarz method and the bisection method and also obtains the corresponding n eigenvectors by using the inverse iteration method. The eigenvectors are normalized so as to satisfy x 2 = 1 . Here, 1mn, 0nm and 0h<<n. Parameters A ..........Input. Real symmetric band matrix A. Compressed mode for a symmetric band matrix. One-dimensional array of size n(h+1)-h(h+1)/2 When n0, the contents are not destroyed after computation When n=0, the contents are altered on output. N ..........Input. Order n of the matrix A. NH .......Input. Bandwidth h. M .........Input. The m number of eigenvalues to be obtained. M=+m ... The largest eigenvalues are obtained. M=-m ... The smallest eigenvalues are obtained. NV .......Input. The n number of eigenvectors are obtained When NV=-n, replaced as NV=+n in the subroutine. When n=0, no eigenvectors are calculated. EPST....Input. Upper limit of absolute error used for convergence cirterion to eigenvalues obtained. See "Method" for the subroutine BSCT1. If EPST<0, a standard upper limit is set. E ..........Output. Eigenvalues. One-dimensional array of size m. EV........Output. Eigenvectors. The eigenvectors are stored in the column-wise direction. Two dimensional arrays as represented by EV(K,NV). K ..........Input. Adjustable dimension of the array EV. When n=0, this is an arbitrary number. VW.......Work area. One-dimensional array of size max(3n+2m,2n(h+1)). When n=0, the size is as large as 3n+2m.
20000
30000
Comments on use Subprograms used SSL II ... BTRID, BSCT1, BSVEC, AMACH and MGSSL FORTRAN basic function ... IABS Notes This subroutine is provided for a real symmetric band matrix, and is suitable for obtaining eigenvalues, from either the largest or smallest eigenvalues, to a matrix whose ratio of its bandwidth h to order n, (i.e., h/n), is no larger than 1/6. Although the eigenvectors corresponding to the obtained eigenvalues can be calculated at the same time, since the inverse iteration method used in this subroutine is applied not for a real symmetric tridiagonal matrix, but for directly processing the input band matrix, the method is relatively ineffective. Consequently, unnecessary eigenvectors should not be calculated. If NV=0 is set, no eigenvectors have to be obtained. If a very small number of eigenvalues of a real symmetric band matrix of high order needs to be obtained, from either the largest or smallest eigenvalues in absolute value, and at the same time the corresponding eigenvectors are to be calculated as well, either this method or simultaneous iteration method by Jennings, whichever is better, should be adopted. Example The largest or smallest m eigenvalues of a real symmetric band matrix A of order n and bandwidth h and also the corresponding nv eigenvectors are obtained in this example below for n100, h10, and m10.
206
BSEG
**EXAMPLE** DIMENSION A(1100),E(10),EV(100,10),VW(2100) 10 READ(5,500) N,NH,M,NV,EPST IF(N.EQ.0) STOP NN=(NH+1)*(N+N-NH)/2 READ(5,510) (A(I),I=1,NN) WRITE(6,600) N,NH,M,NV NE=0 DO 20 I=1,N NI=NE+1 NE=MIN0(NH+1,I)+NE 20 WRITE(6,610) I,(A(J),J=NI,NE) CALL BSEG(A,N,NH,M,NV,EPST,E,EV,100, * VW,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) GO TO 10 MM=IABS(M) NNV=IABS(NV) IF(NNV.EQ.MM) GO TO 40 NNV1=NNV+1 DO 30 J=NNV1,MM DO 30 I=1,N 30 EV(I,J)=0.0 40 CALL SEPRT(E,EV,100,N,MM) GO TO 10 500 FORMAT(4I5,E15.7) 510 FORMAT(5E15.7) 600 FORMAT(1H1,10X,18H** ORIGINAL MATRIX/ * 11X,10H** ORDER =,I5,10X,3HNH=,I3, * 10X,2HM=,I3,10X,3HNV=,I3/) 610 FORMAT(1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT(/11X,19H** CONDITION CODE =,I5/) END
given by
T T = QS AQS
(4.1)
where Qs is an orthogonal matrix and can be produced as a product of an orthogonal matrix shown in the Fig. BSEG-1. Its operation is carried out by using the subroutine BTRID. Secondly, m egenvalues of T are obtained by using the bisection method in the subroutine BSCT1. Thirdly, the corresponding eigenvectors x of A are obtained by using the inverse iteration method. The inverse iteration is a method to obtain eigenvectors by iteratively solving
( A I )x
= xr 1 , r = 1,2,
(4.2)
when an approximate eigenvalue solution is given. where is obtained by the bisection method and x0 is an appropriate initial vector. This operation is performed by using the subroutine BSVEC. The eigenvectors are to be normalized so that x 2 = 1 . For further details, see "Method" for the subroutines BTRID, BSCT1 and BSVEC, and References [12] and [13]. i i +1 1 i i + 1
For subroutine SEPRT, see the example of the subroutine SEIG1. Method The largest or smallest m eigenvalues of a real symmetric band matrix A of order n and bandwidth h as well as the corresponding n eigenvectors are obtained. First, the matrix A is reduced to a tridiagonal matrix T by the Lutishauser-Schwarz method. Its operation is
Fig. BSEG-1 General form of orthogonal similarity transformation matrix used in the Lutishauser-Schwarz method
207
BSEGJ
B51-21-1001 BSEGJ, DBSEGJ Eigenvalues and eigenvectors of a real symmetric band matrix (Jennings method) CALL BSEGJ (A, N, NH, M, EPST, LM, E, EV, K, IT, VW, ICON) Function The m eigenvalues of a real symmetric band matrix of order n and bandwidth h are obtained starting with the eigenvalue of the largest (or smallest) absolute value first, and also the corresponding eigenvectors are obtained for the given m initial vectors by using the Jennings' simultaneous iteration method with the Jennings' acceleration. When starting with the smallest absolute value, matrix A must be positive definite. The eigenvectors should be normalized such that x 2 = 1 . Here 1m<<n and 0h<<n. Parameters A ..........Input. Real symmetric band matrix A. When obtaining the eigenvalues of the smallest absolute value first, the contents are altered on output. Compressed mode for symmetric band matrix. One-dimensional array of size n(h+1)-h(h+1)/2. N ..........Input. Order n of matrix A. NH .......Input. Bandwidth h of matrix A. M .........Input. The number of eigenvalues and eigenvectors obtained, m. M=m ... the m largest absolute value of eigenvalues are desired. M=-m ... the smallest absolute value of eigenvalues are desired. EPST....Input. Constant used for convergence criterion for the eigenvectors. If this value is zero or negative, a standard value is set. See "Comments on use". LM .......Input. Upper limit for the number of iterations. If the number of iterations exceeds this number, the processing is terminated. See "Comments on use". E ..........Output. Eigenvalues. Stored in the sequence as specified by parameter M. One-dimensional array of size m. EV........Input. The m initial vectors stored in columnwise direction. See "Comments on use". Output. Eigenvectors. Two-dimensional array of EV(K,m+2) with the elements stored in column wise direction. K ..........Input. Adjustable dimension of EV. IT .........Output. The number of iterations performed until eigenvalues and eigenvectors are obtained.
VW ...... Work area. One-dimensional array of a size no less than max(n,2m)+m(3m+1)/2. ICON ... Output. Condition code. See Table BSEGJ-1.
Table BSEGJ-1 Condition codes Code 0 20000 Meaning No error The number of iterations exceeded upper limit LM. Processing Terminated. E and EV contain the approximations of the so far obtained eigenvalues and eigenvectors, respectively. Discontinued
28000
29000 30000
Orthogonalization of eigenvectors at each iteration cannot be attained. Matrix A is not positive definite, or possibly singular. NH<0, NHN, N>K, M=0 or |M|>N
Discontinued Bypassed
Comments on use Subprograms used SSL II ... AMACH, MSBV, SBDL, BDLX, TRID1, TEIG1, TRBK, UCHLS, USERT, MGSSL FORTRAN basic function ... MAX0, AMAX1, ABS, IABS, FLOAT and SQRT Notes It is desirable for the initial eigenvectors to be a good approximation to the eigenvectors corresponding to the obtained eigenvalues. If approximate vectors are not available, the standard way to choose initial vectors is to use the first m column vectors of the unit matrix I. The number of eigenvalues and eigenvectors, m had better be smaller than n such that m/n<1/10. The numbering of the eigenvalues is from the largest (or smallest) absolute value of eigenvalue such as 1, 2, ..., n. It is desirable, if possible, to choose m in such a way that m+1 m <<1(orm+1/m>> 1) to achieve convergence faster. The parameters EPST is used to examine the convergence of elements of the eigenvector normalized so that x 2 = 1 . Whenever an eigenvector converges for the convergence criterion constant , the corresponding eigenvalue converges at least with accuracy A and in most cases is higher. It is therefore better to choose somewhat a larger EPST value. When defining unit round off as u, the standard value is set =16u. When the eigenvalues are very close to each other, however, convergence may not be
208
BSEGJ
attained. If so, it is safe to choose such that 100u. The upper limit LM for the number of iterations is used to forcefully terminate the iteration when convergence is not attained. It should be set taking into consideration the required accuracy and how close the eigenvalues are to each other. The standard value is 500 to 1000. SSL II is provided with eigenvectors of a real symmetric band matrix by using a direct method. If the same problem is to be solved, a direct method is generally faster except that it needs more storage space in computation of the eigenvectors. Choose an appropriate subroutine after considering the size of the problem, required accuracy, amount of storage and the execution time. Example This example obtains eigenvalues and eigenvectors of a real symmetric band matrix A of order n and bandwidth h, when n100, h10 and m10.
C **EXAMPLE** DIMENSION A(1100),E(10),EV(100,12),VW(300) 10 READ(5,500) N,NH,M,EPST IF(N.EQ.0) STOP MM=IABS(M) NN=(NH+1)*(N+N-NH)/2 READ(5,510) (A(I),I=1,NN), * (EV(I,J),I=1,N),J=1,MM) WRITE(6,600) N,NH,M NE=0 DO 20 I=1,N NI=NE+1 NE=MIN0(NH+1,I)+NE 20 WRITE(6,610) I,(A(J),J=NI,NE) CALL BSEGJ(A,N,NH,M,EPST,500,E,EV, * 100,IT,VW,ICON) WRITE(6,620) ICON,IT IF(ICON.GE.20000) GO TO 10 CALL SEPRT(E,EV,100,N,MM) GO TO 10 500 FORMAT(3I5,E15.7) 510 FORMAT(5E15.7) 600 FORMAT(1H1,20X,15HORIGINAL MATRIX,5X,2HN=, * I3,5X,3HNH=,I3,5X,2HM=,I3/) 610 FORMAT(1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT(1H0,20X,5HICON=,I5,5X,3HIT=,I5) END
1 , 2 , , n
where diagonal matrix and orthogonal matrix V are defined by
V = (1 , 2 , , n ) then AV = V
= diag(1 , 2 , , n )
(4.1)
The simultaneous iteration method is the extension of the power method. Starting from an appropriate n m matrix X1 Xi +1 = AX i i = 1,2, (4.2)
is iterated and Xi is to be converged towards the m eigenvectors, that is the first m rows of V, corresponding to the largest absolute value first. However, if iteration is performed only for (4.2), each row of Xi converges towards the vector corresponding to the first row 1 of V, thus the purpose is not achieved. In the simultaneous iteration method, iteration matrix Xi is always orthonormalized based upon the properties of the eigenvalues and eigenvectors. Assume that eigenvectors 1,...,k-1 corresponding to eigenvalues 1,...,k-1 have been obtained. The largest value for T A is obtained when =k, and then the following condition is satisfied
T i = 0, i = 1, , k 1
Now
k = kT A k
is the eigenvalue containing the k-th largest absolute value and k is the corresponding eigenvector. Jennings simultaneous iteration method proceeds as follows: (indexes used for iteration matrices are omitted) 1) Y is obtained by multiplying A by X from the right. Y=AX 2) m-order symmetric matrix B is obtained by multiplying XT by Y form the right. B=XTY 3) The eigenvalues i , i=1,2,...,m of B and the 209 (4.4) (4.3)
The subroutine SEPRT is used in this example to print eigenvalues and eigenvectors of a real symmetric matrix. For details, refer to the example of the subroutine SEIG1. Method Jennings simultaneous iteration method Letting the eigenvalues of a real symmetric band matrix of order n, and of the largest absolute value first be as
1 , 2 , , n
BSEGJ
= 1 2
(4.14)
Based on the preparation of procedures 1) through 7) above, C is tested as follows. 1) Substituting (4.11) in (4.3), equation (4.1) becomes, Y=AX=AVC=VC (4.15)
5) Z is multiplied by ZT from the left to obtain an morder symmetric positive-definite matrix and this matrix is LLT decomposed (this is called LLT decomposition). ZTZ=LLT 6) X* is obtained by solving the equation X*LT=Z X*=ZL-T X* is a normal orthogonal matrix. X*TX*=Im (4.9) (4.8) (4.7)
The i-th column of the coefficient matrix is multiplied by i. This means that the elements of the eigenvector corresponding to the eigenvalue in which the absolute value is large in (4.15) are focused and compressed. 2) Substituting (4.11) and (4.15) in (4.4), considering V to be orthogonal, B=XTY=CTC (4.16)
(4.17)
where, Im is an m-order unit matrix. 7) Convergence is tested for X*. Return to procedure 1) setting X* as a new X, administering to the speed up as required basis. The coefficient matrix when expanding iteration matrix X by eigenvector V is shown below. When expanding each column of matrix X by eigenvectors, the following is assumed:
3) In this procedure, no solution can be obtained if no assumptions are made regarding C. Assume that in (4.13), C2=0 is given. This means that X represents all the first m vectors of V. Where (4.17) is expressed as,
B = C1T 1C1
(4.18)
x j = cij i , j = 1,..., m
i =1
(4.10)
From (4.12) C is an m-order orthogonal matrix. Since (4.5) and (4.18) are performed by orthogonal similar transformation for the same m-order matrix B, they are expressed by selecting an appropriate V (for example, by changing the sign of eigenvector i or selecting the corresponding eigenvector for multiple eigenvalues) as:
Equation (4.10) can be expressed by coefficient matrix C=(cij) of n m matrix as X=VC Since X is orthogonal, XTX=Im and V is orthogonal, C can be orthogonal. C C=Im
T
C1 P = I m M = 1
4) From (4.6) and (4.15), Z can be expressed as,
(4.19) (4.20)
(4.11)
Z YP = V CP
When C2=0, (4.12)
(4.21)
C is divided into two parts; the first m rows and the remaining n-m rows, C1 C = (4.13) C2 210
1 Z = V O
5) From (4.12) and orthogonality of V,
(4.22)
BSEGJ
Y = A1 X
(4.28)
from L = 1 = diag 1 ,, m 6)' From (4.8) and (4.21), X * = VCPL T When C2=0, then X* =V Therefore, when C2=0, an eigenvalue and eigenvector can be obtained by one iteration. When I E C = m 1 E2 (4.26) (4.25) (4.24)
( ) ( )
(4.23)
A is decomposed into LDLT using subroutine SBDL. If A is not a positive definite matrix or it is singular, the processing is terminated with ICON=29000. (b) When obtaining B in 2), it is processed along with 1) to reduce storage space as follows, where row vector yi of Y is computed in (4.29).
= xi
yi = A or yi = A1 i = 1, , m (4.29
Equation (4.29) is computed by subroutine MSBV or BDLX. Since B is an m-order real symmetric matrix, its diagonal and lower triangular elements can be computed as bii = T yi bii = x T y, j i j = i + 1, ,. m
and the elements of E1 and E2 are the first order least value, (4.19) and (4.20) hold if the second-order least value is omitted. And therefore, Im X* = V 1 C 2 1 1 (4.27)
This indicates that the element of eigenvector j j ( >m) contained in xi (im) of X is reduced in each iteration by the ratio j/ i This means that C2 of C is approaching the least value. In procedure 1), the elements of an eigenvector corresponding to the eigenvalue of the largest absolute value is compressed. In procedures 2), 3), and 4), the eigenvectors are refined along with obtaining eigenvalues. In procedures 5) and 6), the eigenvectors are made orthonormal. Computation procedures This subroutine obtains the m eigenvalues of the largest (or the smallest) absolute values of a real symmetric band matrix of order n and bandwidth h and also the corresponding eigenvectors based upon m given initial vectors, using the Jennings simultaneous iteration method. (a) When obtaining the eigenvalues starting with the smallest absolute value and the corresponding eigenvector, the following is used instead of equation (4.3) in procedure 1).
Thus, Y is produced directly in the area for X by taking xi for each column of X and obtaining yi and bji. (c) 3) is performed sequentially by subroutine TRID1, TEIG1 and TRBK. Arrange the eigenvectors corresponding to the eigenvalues in the order of the largest absolute value to the smallest using subroutine UESRT. (d) 5) is performed by subroutine UCHLS. If LLT decomposition is impossible, processing is terminated with ICON=28000. * (e) In 7), the m-th columns xm and xm of X and X* are examined to see if
* d = xm xm
EPST
(4.30)
is satisfied. If satisfied, the diagonal elements of M obtained in 3) become eigenvalues (when obtaining the smallest absolute values first, the inverse numbers of the diagonal elements become the eigenvalues) and each column of X* becomes the corresponding eigenvector. Jennings' acceleration This subroutine uses the original Jennings' method explained above, incorporating the Jennings' acceleration for vector series. Principle of acceleration A vector series x(k) where k=1,2,... that converges to vector x is expressed as a linear combination of vectors j where j=1,2,...,n that are orthogonal to each other and constant j such as j < 1 where j=1,2,...,n as follows: 211
BSEGJ
x ( k ) = x + p kj v j
j =1
(4.31)
A new vector is generated from three subsequent vectors x(k), x(k+1), and x(k+2) as follows: x=x where s=
( k + 2)
Computation procedure 1) Assume the initial value of the constant as the criterion for adopting the acceleration to be:
+s x
( k + 2)
( k + 1)
)
x(k
( k +1)
+2 )
1 2 n
(4.39)
(4.32)
(x
(x
(k )
(k )
x (k
( k +1)
+1)
) (x
T
) (x
T
( k +1)
)
( k+2)
(k)
2x
+x
(4.33)
= max( 15 ,)
(4.40)
Substituting (4.31) to (4.33) and using the orthogonal relation of j , s is expressed as: pj zj 1 pj zj
j =1 n n
3) 4) 5) 6)
s=
j =1
(4.34)
Then, vector number ja of the vector to be processed is set in m and the following acceleration cycle starts: Stores every other vector obtained from the latest values of xja in columns (m+1) and (m+2) of the EV. Performs simultaneous iteration of Jennings' method. Judges convergence of (4.30) only for ja=m If (4.41) is satisfied, proceeds to step 10) : x ja x* ja (4.41)
where
k z j = p2 1 pj j
vj
2 2
, j = 1,2, , n
(4.35)
x ja x* ja
(4.42)
8) Calculates x ja by performing Jennings' acceleration with every other iterated vector of x ja (4.36) 9) Orthogonalizes the x ja to satisfy the following: xi = 0, xT ja x ja (4.37)
2
j ja
=1
(4.43)
10) Decrements ja by one, then proceeds to step 3) if ja1 11) If the convergence condition is satisfied in step 5), iteration is stopped; otherwise, changes to:
It is known from (4.36) that p is the average of Pj with respect to the positive weight zj. Assuming p1 > p2 > , then following is satisfied for a sufficiently large value k: z1
= max( 1000, , 10 )
then proceeds to step 2).
(4.44)
zj
, j >1
Thus, p p1 is obtained, and this proves xx This is a brief explanation of the Jennings' acceleration principle. Assuming, xi( k ) to be vector of column i of the iteration matrix xk in Jennings' method, the vector is expressed as follows for a sufficiently large value k:
k xi( ) = vi + ( n j =m +1 j
i ) c ji v j
k
Notes on the algorithm In Jennings' acceleration, every other vectors are used for the following reasons: It is clear from (4.37) that Jennings' acceleration is effective when weighted average p (the weight is positive) of pj is close to p1. If all values of pj have the same sign, this condition is to be satisfied ordinarily; however, if there is a value having a sign opposite that of p1 and the absolute value close to that of pj, considerable effect of Jennings' acceleration cannot be expected. If every other vectors are used in place of , the successive vectors, that is, pj is substituted for p2 j difficulty explained above caused by different signs of pj is eliminated.
(4.38)
where
i < 1
BSEGJ
Jennings' acceleration is effective for the eigenvalue problem having almost same eigenvalues in magnitude. (See references [18] and [19] for simultaneous iteration of Jennings' method, and reference [18] for acceleration.)
213
BSFD1
E-31-32-0101
BSFD1, DBSFD1
B-spline two-dimensional smoothing CALL BSFD1 (M, XT, NXT, YT, NYT, C, KC, ISWX, VX, IX, ISWY, VY, IY, F, VW, ICON) Function Given observed value fi,j=f(xi ,yj), observation error ij=xi yj at lattice points (xi ,yj); i=1,2,...,nx, j=1,2,...,ny, this subroutine obtains a smoothed value or a partial derivative at the point P(x,y), or a double integral over the range [1xx, 1yy] based on the bivariate m-th degree B-spline smoothing function. However, subroutine BSCD2 must be called before using subroutine BSFD1 to determine the knots 1, 2,..., nt in the x-direction, the knots 1, 2,..., lt the ydirection, and the smoothing coefficients C, in the mth degree B-spline smoothing function. S ( x, y) =
lt 1 nt 1
F .............Output. Smoothed value, partial devivative or integral. Suppose ISWX= and ISWY=, one of the following values is output depending upon the combination of and . When 0, F=
+ S x ,y x y
) dx
= m +1 = m+1
c , N ,m1 ( x ) N ,m+1 ( y )
(1.1)
m1, 1x<mt, 1ylt Parameters M ........... Input. Degree of the B-spline. XT.......... Input. Knots i in the x-direction. One-dimensional array of size nt. NXT ....... Input. Number nt of knots i in the xdirection. YT.......... Input. Knots i in the y-direction. One-dimensional array of size lt. NYT ....... Input. Number lt of knots i in the y-direction. C ............ Input. Smoothing coefficient C,. Two-dimensional array of C(KC,lt+m-1) KC.......... Input. Adjustable dimension (nt+m-1) for array C. ISWX ..... Input. Type of computations in the xdirection. -1ISWXM (See parameter F.) VX ......... Input. Coordinate x at points P(x,y) IX........... Input. i satisfying i x<i+1. When x=nt, IX=nt-1. Output. i satisfying jx<i +1. (See Notes.) ISWY ..... Input. Type of computations in the ydirection. -1ISWYM (See parameter F.) VY ......... Input. Coordinate y at points P(x,y). IY........... Input. j satisfying jy<j+1. When y=lt, IY=lt-1. Output. j satisfying jy<j+1 (See Notes.)
VW .........Work area. One-dimensional array of size 5(m+1)+max(nt,lt) ICON ......Output. Condition code. See Table BSFD1-1.
Table BSFD1-1 Condition code Code 0 10000 Meaning No error XT(IX)VX<XT(IX+1) or YT(IY)VY<YT(IY+1) is not satisfied. Processing The IX or IY shown on the left is searched for in the subroutine and processing continues. Bypassed
30000
One of the following occurred: 1)VX<XT(1) or VX>XT(NXT) 2)VY<YT(1) or VY>YT(NYT) 3)ISWX<-1 or ISWX>M 4)ISWY<-1 or ISWY>M
Comments on use Subprogram used SSL II ... MGSSL, UCAR2, UBAS1 FORTRAN basic function ... FLOAT Notes This subroutine obtains the smoothed value, partial derivative or double integral based upon B-spline two dimensional smoothing function (1.1)
214
BSFD1
obtained by subroutine BSCD2. Therefore, subroutine BSCD2 must be called to obtain the smoothing function (1.1) before calling this subroutine. The values of parameters M, XT, NXT, YT, NYT, C, and KC must be directly passed from BSCD2. Parameters IX and IY should satisfy XY(IX)VX<XT(IX+1) and YT(IY)VY<YT(IY+1) respectively. If not, IX and IY which satisfy the relationship is found and the processing is continued. Example Refer to Example of subroutine BSCD2.
Method Suppose that by subroutine BSCD2, the bivariate m-th degree B-spline smoothing function S ( x, y) =
lt 1 nt 1
= m+1 = m+1
c , N ,m+1 ( x ) N ,m+1 ( y )
(4.1)
is obtained. This subroutine computes smoothed values, partial derivatives or integrals based upon the smoothing function of (4.1). For detailed information, see Section 7.1 in Part I.
215
BSF1
E31-31-0101 BSF1, DBSF1 B-spline smoothing, differentiation and integration (with fixed knots) CALL BSF1(M,XT,NT,C,ISW,V,I,F,VW,ICON) Function Given observed values y1, y2, ..., yn at points x1, x2, ..., xn, weighted function values wi =w(xi ), i=1,2,...,n and knots of the spline function, 1, 2, ...,nt (1<2<...<nt) then a smoothed value, or derivative at x = i [1 ,nt ] or integral from 1 to is obtained based on the B-spline smoothing function. One condition is that the smoothing coefficients cj's, j=-m+1, -m+2, ..., nt-1 in the B-spline smoothing function S (x ) =
nt 1
Table BSF1-1 Condition code Code 0 10000 Meaning No error XT(I) V<XT(I+1) is not satisfied. Processing I satisfying the left relationship is searched for and the processing is continued. Bypassed
30000
Comments on use Subprograms used SSL II ... MGSSL, UCAR1and UBAS1 FORTRAN basic function ... FLOAT Notes This subroutine obtains a smoothed value, derivative or integral based on the B-spline smoothing function (1.1) obtained by subroutine BSC1 or BSC2. Therefore, subroutine BSC1 or BSC2 must be called to obtain the smoothing function (1.1) before calling subroutine BSF1. The parameter values M, XT, NT, and C must be the same as those used in BSC1 or BSC2. Parameter I should satisfy the relationship XT(I)V<XT(I+1). If not, the I which satisfies the relationship is searched for to continue the processing. Example By inputting discrete points xi 's, observed values yi 's, i=1,2,...,n, knots j's j=1,2,...,nt and the degree m, smoothed values, the 1st to m-th order derivatives at and integrals from 1 to the point. vij = i + (i+1 i ) ( j 5), i = 1,2,, nt 1, j = 01 , , ,5 are obtained. Here, the weighted function values wi , i=1,2,...,n to each of the observed values are all set to 1.0, and also min(j)xi max(j), i=1,2,...,n, n101, ni 10 and m5.
C **EXAMPLE** DIMENSION X(101),Y(101),W(101), *XT(10),C(14),R(101),VW(66),IVW(101), *RR(6) READ(5,500) N,M READ(5,510) (X(I),Y(I),I=1,N) READ(5,500) NT READ(5,520) (XT(I),I=1,NT) WRITE(6,600) N,M,(I,X(I),Y(I),I=1,N) WRITE(6,610) NT,(I,XT(I),I=1,NT)
j = m+1
c j N j ,m+1 ( x )
(1.1)
must be calculated in subroutine BSC1 or BSC2 before using subroutine BSF1, where m is the degree of the Bspline Nj,m+1(x). Also 1m, m1, nt3, must be satisfied. Parameters M ..... Input. Degree of the B-spline m. See Notes. XT .... Input. Knots j's. One-dimensional array of size ni . NT ... Input. Number the of knots i 's, ni C ..... Input. Smoothing coefficient Cj's (output from BSC1 or BSC2) One-dimensional array of size ni +m-1. ISW ... Input. An integer which specifies the type of calculation. If ISW=0, the smoothing value, F = S (v ) If ISW= l (1 l m) ,the l-thorder derivative, F = S ( l ) ( v ). If ISW=-1, the integral value, F = 1 S ( x )dx
v
are obtained, respectively. V ..... Input. The point at which the smoothing value, etc.are obtained. I .. Input. The i which satisfies i <i +1. If = ni,I=nt-1. Output. The I which satisfies I < i +1. See Notes. F ..... Output. Smoothed value, the l-th order derivative or integral value depending on ISW. See parameter ISW. VW ... Work area. One-dimensional array of size m+1. ICON .. Output. Condition code. See Table BSF1-1.
216
BSF1
DO 10 I=1,N 10 W(I)=1.0 CALL BSC1 (X,Y,W,N,M,XT,NT,C,R, *RNOR,VW,IVW,ICON) IF(ICON.EQ.0) GO TO 20 WRITE(6,620) STOP 20 WRITE(6,630) RNOR N1=NT-1 M2=M+2 DO 50 L2=1,M2 ISW=L2-2 WRITE(6,640) ISW DO 40 I=1,N1 H=(XT(I-1)-XT(I))/5.0 XI=X(I) DO 30 J=1,6 V=XI+H*FLOAT(J-1) CALL BSF1(M,XT,NT,C,ISW,V, *I,F,VW,ICON) RR(J)=F 30 CONTINUE WRITE(6,650) I,(RR(J),J=1,6) 40 CONTINUE 50 CONTINUE STOP 500 FORMAT(2I6) 510 FORMAT(2F12.0) 520 FORMAT(F12.0) 600 FORMAT(1H1//10X,10HINPUT DATA,3X, *2HN=,I3,3X,2HM=,I2//20X,3HNO.,10X, *1HX,17X,1HY//(20X,I3,2E18.7)) 610 FORMAT(/10X,11HINPUT KNOTS,3X, *3HNT=,I3/20X,3HNO.,10X,2HXT// *(20X,I3,E18.7)) 620 FORMAT(1H0,10X,5HERROR) 630 FORMAT(10X,13HSQUARE SUM OF,1X, *10HRESIDUALS=,E18.7) 640 FORMAT(1H1//10X,2HL=,I2/) 650 FORMAT(6X,I3,6E18.7) END
Method Suppose that the m-th degree B-spline smoothing function S ( x ) = c j N j ,m+1 ( x )
j = m+1 nt 1
(4.1)
has been obtained by subroutine BSC1 or BSC2. Subroutines BSF1, based on the smoothing function (4.1), obtains a smoothed value, l-th order derivative or integral by using the (4.2), (4.3) and (4.4), respectively. S (v ) = c j N j ,m+1 (v )
j = m+1 nt 1
) S ( ) (v ) = c j N (j ,m v +1 ( )
l l j = m+1
nt 1
I = S(x )dx
v
The calculation method for the above is described in Section "Calculating spline function." This subroutine calculates Nj,m+1(x), its derivative and integral by calling subroutine UBAS1.
217
BSVEC
B51-21-0402
BSVEC, DESVEC
CALL BSVEC(A,N,NH,NV,E,EV,K,VW,ICON) Function When n number of eigenvalues are given for a real symmetric band matrix A of order n and bandwidth h the corresponding eigenvectors are obtained by using the inverse iteration method. Parameters A ..... Input. Real symmetric band matrix A. Compressed mode for symmetric band matrix. One-dimensional array of size n(h+1)h(h+1)/2. N ..... Input. Order n of matrix A. NH .... Input. Bandwidth h NV .... Input. Number of eigenvectors to be obtained. For NV=-n set as NV=+n. E ..... Input. Eigenvalues. One-dimensional array of size at least n. EV .... Output. Eigenvectors. The eigenvectors are stored in column wise direction. Two-dimensional array of EV(K,NV) K ..... Input. Adjustable dimension of the array EV. VW .... Work area. One-dimensional array of size 2n(h+1). ICON .. Output. Condition code. See Table BSVEC-1.
Table BSVEC-1 Condition codes Code 0 10000 15000 Meaning No error NH=0 All of the eigenvectors could not be obtained. Processing Executed normally. The eigenvector is set to zerovector. All of the eigenvectors become zerovectors. Bypassed
Notes This subroutine is for a real symmetric band matrix. For obtaining eigenvalues and eigenvectors of a real symmetric matrix, use subroutine SEIG1 or SEIG2. Further, for a real symmetric tridiagonal matrix, use subroutine TEIG1 or TEIG2. If the eigenvalues are close to each other in a small range, the inverse iteration method used to obtain the corresponding eigenvectors may not converge. If this happens, ICON is set to 15000 or 20000 and unobtained eigenvectors become zero-vectors. Example When a real symmetric band matrix A of order n and bandwidth h and also its n number of eigenvalues are given, the corresponding eigenvectors are obtained in this example by using the inverse iteration method for the case n100, h10 and n10.
C **EXAMPLE** DIMENSION A(1100),E(10),EV(100,10),VW(2100) 10 READ(5,500) N,NH,NV IF(N.EQ.0) STOP NN=(NH+1)*(N+N-NH)/2 READ(5,510) (E(I),I=1,NN) WRITE(6,600) N,NH,NV NE=0 DO 20 I=1,N NI=NE+1 NE=MIN0(NH+1,I)+NE 20 WRITE(6,610) I,(A(J),J=NI,NE) NNV=IABS(NV) READ(5,510) (E(I),I=I,NNV) CALL BSVEC(A,N,NH,NV,E,EV,100,VW,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) GO TO 10 CALL SEPRT(E,EV,100,N,NNV) GO TO 10 500 FORMAT(3I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,10X,18H** ORIGINAL MATRIX/ *11X,10H** ORDER =,I5,3HNH=,I3, *10X,3HNV=,I3/) 610 FORMAT(1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT(/11X,19H** CONDITION CODE =,I5/) END
20000
For subroutine SEPRT, see the example of the subroutine SEIG1. Method When a real symmetric band matrix A of order n and bandwidth h and also its n number of eigenvalues are given, the corresponding eigenvector are obtained by using the inverse iteration method. Suppose the true eigenvalues have the relation. 1>2>...>n (4.1)
30000
Comments on use Subprograms used SSL II ... AMACH, MGSSL FORTRAN basic function ... MAX0, MIN0, ABS, SIGN and SQRT
218
BSVEC
n n 1 ik uk x1 = A j I (i 0 ) i=1 k =1
( A I )x
j
= xr1
r = 1,2,
(4.2)
= A jI
n
1 n
k =1
u ik k i=1
n
( 0) i
with an appropriate initial vector x0, and chooses xr as eigenvector when it has satisfied convergence criteria. First, A-jI is decomposed to a unit lower triangular matrix L and upper triangular matrix U P A j I = LU and the resulting equation LUxr = Px r 1 (4.4)
Rewriting i( 0 ) ik to k(1) ,
i =1
x1 = A j I
1 n
(1 ) i ui
i =1 n
(4.3)
xr = A j I xr is given by xr =
r n
( r) i ui
i =1
r = 1,2,
(4.10)
is solved, where P is a permutation matrix which performs row interchange for a partial pivoting. To solve Eq. (4.4), the following two equations Ly r1 = Px r 1 Uxr = yr 1 (forward substitution) (backward substitution) (4.5) (4.6)
1 j j
n (r ) i( r )ui j j j u j + i =1 i j
( ) }
r i j r
(4.11)
The constant 1/(j-j) r can be eliminated by normalizing xr at each iteration step. Therefore xr = (j r )u j + i( r ) ui j j
i =1 i j n
are to be solved. The method described above is the general inverse iteration, but if it is applied to a real symmetric band matrix, the handwidth becomes large because of the row interchange in the Eq. (4.3), and the storage space for and LU-decomposed matrix increases substantially compared to the space for the original matrix A. This subroutine, in order to minimize this increase, discards the L component leaving only the U component. Uxr = xr 1 Since an appropriate initial eigenvector x0 can be represented as x0 = i( 0) ui
n i =1
) ( )
i j j
(4.12)
In general, j j
(r )
) ( ) 1, so Eq. (4.12)
i
indicates that if j 0 , the larger r becomes, the closer xr approaches eigenvector (j r ) u j . Initial vector and convergence criteria This subroutine normalize xr-1 at each step such that xr1 1 = n2 3u A and if xr satisfies (4.13)
(4.7)
(4.8)
xr 1 1
(4.14)
by the true eigenvectors u1,u2,...,un which correspond to the true eigenvalues, from Eq. (4.7), let x1 = U 1 x0 (4.9)
then xr is accepted as an eigenvector, where u is the unit round off, and A is represented by A = 2 a n i j ij (4.15)
which is close to A 1 and is easy to calculate. The reason that Eq. (4.15) can be used is as follows: from Eqs. (4.3) and (4.7).
( ) P L u = ( A I ) P Lu
1 T n
( 0)
i =1
1 n
( 0)
( A I)x
j
xr 1 = P T Lxr 1 xr
(4.16)
i=1
If P Lui = ik uk , then
T k =1
The right hand side of Eq. (4.16) is the residual vector when considering xr xr 1 as an eigenvector.
219
BSVEC
Since L is a lower triangular matrix whose diagonal elements are 1 and absolute values of other off-diagonal elements are less than 1, and P is a permutation matrix, the norm of the vector is assumed not to be increased by the linear transformation PTL. Therefore, if xr 1 1 , the norm in the right hand side of Eq.(4.16) is very small, so there is no objection to accept xn as an eigenvector. For the initial vector x0 a vector which consists of the continuous n elements Ri = i [i ] i = 1,2, (4.17)
If convergence is still not accomplished, the iteration is assumed to be non-convergent and the corresponding column of EV are all set to zero and ICON is given 15000. Orthogonalizing the eigenvectors All eigenvectors of a real symmetric matrix should be orthogonal to each other, but once the eigenvalues become close to each other, the orthogonal nature of the eigenvectors tend to collapse. Therefore, this subroutine, to insure the eigenvectors orthogonal, performs the following: first it examines to see if the eigenvalue i to which the corresponding eigenvector is obtained and the eigenvalue at one step before, i -1, satisfies the relationship
is used, where Ri 's are not pseudo random numbers in a statistical sense but are increasingly uniformly distributed random numbers in the interval [0,1], and
5 1 2
(4.18)
i i 1 103 A
(4.19)
By doing this, there is no need to alter the way of choosing an initial vector for multiple eigenvalues, and/or to give any perturbation to the eigenvalues, so that the computation becomes simpler. This subroutine initializes the first random number to be R1= every time it is called in order to guarantee consistency with its computed results. If five iterations of Eq, xr is still not enough to satisfy the convergence criterion (4.14), this subroutine tries another five more iterations after relaxing the criterion by setting the coefficient of A in Eq. (4.13) to 10n3/2u.
If the relationship is satisfied, the eigenvector xi corresponding to the eigenvalue i is modified to the eigenvector xi -1 corresponding to i -1 in such a way that
(x , x ) = 0
i i 1
(4.20)
In a similar way, for a group of eigenvalues which successively satisfy the relationship (4.19), their corresponding eigenvectors are reorthogonalized.
220
BTRID
B51-21-0302
BTRID, DBTRID
Reduction of a real symmetric band matrix to a real symmetric tridiagonal matrix (Lutishauser-Schwarz method)
CALL BTRID(A,N,NH,D,SD,ICON) Function A real symmetric band matrix A of order n and bandwidth h is reduced to a real symmetric tridiagonal matrix T by using the Lutishauser-Schwarz's orthogonal similarity transformation, such as T = QST AQS , where Qs is an orthogonal matrix, and also 0h<<n. Parameters A ..... Input. Real symmetric band matrix A. Its contents are destroyed an output. Compressed mode for a symmetric band matrix. Onedimensional array of size n(h+1)-h(h+1)/2 N ..... Input. Order n of the matrix A. NH .... Input. Bandwidth h. D ..... Output. Diagonal elements of the tridiagonal matrix. One-dimensional array of size n. SD .... Output. Subdiagonal elements of the tridiagonal matrix T. One-dimensional array of size n. In the subroutine, only SD(2) to SD(N) are used and SD(1) is set to zero. ICON .. Output. Condition code. See Table BTRID-1.
Table BTRID-1 Condition codes Code 0 10000 30000 Meaning No error NH=0 or NH=1 NH<0 or NHN Processing No reduction performed. Bypassed
Example This example computes eigenvalues by using subroutine BSCT1 after reduction of a real symmetric band matrix of order n and bandwidth h to a tridiagonal matrix under conditions n100 and h10.
C **EXAMPLE** DIMENSION A(1100),D(100),SD(100),E(100), * VW(300) 10 READ(5,500) N,NH,M,EPST IF(N.EQ.0) STOP NN=(NH+1)*(N+N-NH)/2 READ(5,510) (A(I),I=1,NN) WRITE(6,600) N,NH NE=0 DO 20 I=1,N NI=NE+1 NE=MIN0(NH+1,I)+NE 20 WRITE(6,610) I,(A(J),J=NI,NE) CALL BTRID(A,N,NH,D,SD,ICON) WRITE(6,620) WRITE(6,630) ICON IF(ICON.EQ.30000) GO TO 10 WRITE(6,640) (I,D(I),SD(I),I=1,N) CALL BSCT1(D,SD,N,M,EPST,E,VW,ICON) WRITE(6,650) WRITE(6,630) ICON IF(ICON.EQ.30000) GO TO 10 MM=IABS(M) WRITE(6,660) (I,E(I),I=1,MM) GO TO 10 500 FORMAT(3I5,E15.7) 510 FORMAT(5E15.7) 600 FORMAT(1H1,10X,18H** ORIGINAL MATRIX/ * 11X,10H** ORDER =,I5,10X,3HNH=, * I3,2HN=,I3/) 610 FORMAT(1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT(1H0/11X,21H** TRIDIAGONAL MATRIX) 630 FORMAT(/11X,19H** CONDITION CODE =,I5/) 640 FORMAT(5X,I5,2E16.7) 650 FORMAT(1H0/11X,14H** EIGENVALUES) 660 FORMAT(5X,2HE(,I3,2H)=,E15.7) END
Comments on use Subprograms used SSL II ... AMACH and MGSSL FORTRAN basic functions ... MIN0, ABS and SQRT When compared to the Householder method which reduces the matrix to a real symmetric tridiagonal matrix, the Lutishauser method used in this subroutine is better both in terms of the amount of storage and computations if the ratio of the bandwidth to the order number, r=h/n, is small. If the ratio r exceeds 1/6, the Householder method is better.
Method Although the Householer method is often used for reduction of a real symmetric matrix to a tridiagonal matrix (see"Method" for the subroutine TRID1), if this method is applied to a band matrix, however, its nonzero elements spread over the matrix during the reduction, and therefore it cannot be used only in the range of band area. On the other hand, in the Lutishauser-Schwarz method, sub diagonal lines can be eliminated one by one from outside first by processing the band part of the band matrix A (of order n, band width h, and each element aij). Consider lower part of matrix A including its diagonal elements since the matrix is symmetric. First, in order to eliminate ah + 1,1 , transform matrix A into A1 = R1 AR1T , where R1 is an orthogonal matrix
221
BTRID
associated with the h-th and (h+1)-th rows of A, and tan 1 = a h +1,1 a h ,1 . h h +1 1 R1 =
1
h h +1 1
The element ah+1.1 becomes zero by this operation, but another new non-zero element a2h+1,h is generated. In order to eliminate it, perform A1=R2A1R2T by using the orthogonal matrix, 2h 2h + 1 1 R2 =
1
2h 2h + 1 1
The bandwidth can be reduced further by one by applying the same procedure as done to the original matrix to this newly produced matrix. Fig. BTRID-1 shows the non-zero elements (indicated by in the diagram) that are generated successively when eliminating the element ah+1,1, i.e., a31 (indicated by * in the diagram) for n=10 and h=2 and the lines of influence of the orthogonal similarity transformation to eliminate the non-zero elements. The number of multiplications necessary for eliminating the most outward subdiagonal elements of a matrix of bandwidth h is approximately 4n2, so that the number of necessary multiplications for a tridiagonalization is about 4hn2 (See Reference [12]). On the other hand, in Householder method the number of necessary multiplications for tridiagonalization of a real symmetric matrix of order n is 2n3/3. Therefore, for r=h/n<1/6, the Lutishauser method is better in respect to the number of multiplications carried out. The orthogonal matrix Qs used to reduce the original matrix A to a tridiagonal matrix (T=QsAQsT) can get denoted as a product of orthogonal matrices R1,R2,... such as Qs=Rs...R2R1. However, since it is not a good idea to have the Qs as an n n matrix as far as amount of storage and computations are concerned, this subroutine does not carry out such an computation.
0 | * | | | | | A= | | | | 0
associated with the 2h-th and (2h+1)-th rows of the matrix, where tan 2 = a 2 h +1,h a 2 h ,h . By this operation, a2h+1,h becomes zero, but again another new non-zero element a3h+1,2h is generated. By using this similarity transformation (orthogonal similarity transformation) repeatedly by an appropriate orthogonal matrix, element ah+1,1 can be eliminated entirely. To eliminate ah+2,2 an appropriate orthogonal transformation is repeatedly performed to eliminate non-zero elements generated during the transformation. Then element ah+2,2 can be entirely eliminated. By repeatedly performing this operation, all the most outward subdiagonal elements can be eliminated and the bandwidth is reduced to h-1.
222
BYN
I11-81-1101
BYN, DBYN
CALL BYN(X,N,BY,ICON) Function This subroutine computes the integer order Bessel function of the second kind Yn ( x ) = 2 J n ( x ) log( x 2) +
Notes [Range of argument X] 0<X<tmax If X becomes large enough, sin(x-/4) and cos(x-/4) , which are used in calculating Y0(x) and Y1(x), will lose accuracy. The limit is provided for that reason. (See (4.4) in the Method section of BY0 and BY1) When calculating Yo ( x ) and Y1 , ( x ), use subroutines BY0 and BY1 instead.
}]
k
2 k n 1 n 1 (n k 1)! 1 ( 1) x 2) ( k =0 k = 0 k!(n + k )! k!
( x 2)
2 k +n
k n +k 1 m + 1 m m=1 m =1
Example The following example generates a table of Yn(x) for range of x from 1 to 10 with increment 1 and for the range of N from 20 to 30 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 20 N=20,30 DO 10 K=1,10 X=K CALL BYN(X,N,BY,ICON) IF(ICON.EQ.0) WRITE(6,610) X,N,BY IF(ICON.NE.0) WRITE(6.620) X,N,BY,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// *6X,1HX,5X,1HN,8X,5HYN(X)/) 610 FORMAT(1H,F8.2,I5,E17.7) 620 FORMAT(1H,11H** ERROR **,5X,2HX=,E17.7, *5X,2HN=,I5,5X,3HBY=,E17.7,5X,10HCONDITION=, *I10) END
for x>0, by the recurrence formula. Where, Jn(x) is the integer order Bessel function of the first kind, and denotes the Euler's constant and also the assumption 0 1 m = 0 is made.
m =1
Parameters X ..... Input. Independent variable x. N ..... Input. Order n of Yn(x). BY .... Output. Function value Yn(x). ICON .. Output. Condition code. See Table BYN-1. When N=0 or N=1, ICON is handled the same as in ICON for BY0 and BY1.
Table BYN-1 Condition code Code 0 20000 30000 Meaning No error Xtmax X0 Processing BY is set to 0.0. BY is set to 0.0.
Method Bessel function Yn(x) is calculated using the following recurrence formula. Yk +1 ( x ) = 2k Y ( x ) Yk 1 ( x ), k = 1,2, , n 1 x k (4.1)
Comments on use Subprograms used SSL II ... BY0, BY1, UBJ0, UBJ1, MGSSL, and UTLIM FORTRAN basic function ... IABS, FLOAT, DSIN, DCOS, DLOG, and DSQRT
where, both Y0(x) and Y1(x) are calculated by using BY0 and BY1.
223
BYR
I11-83-0201
BYR, DBYR
CALL BYR(X,V,BY,ICON) Function This subroutine evaluates a real order Bessel function of the second kind Y ( x ) = J ( x )cos( ) J ( x ) sin( )
**EXAMPLE** DO 20 NV=50,80 V=FLOAT(NV)/100.0 DO 10 K=1,10 X=FLOAT(K) CALL BYR(X,V,BY,ICON) WRITE(6,600) V,X,BY,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H,F8.3,F8.2,E17.7,I7) END
by using a modified series expansion and the method. In the above expression, J (x) is the Bessel function of the first kind. Parameters X ..... Input. Independent variable x. V ..... Input. Order of Y (x). BY .... Output. Value of function Y (x). ICON .. Output. Condition code. (See Table BYR-1.)
Table BYR-1 Condition codes Code 0 20000 Meaning No error X=0.0 or the value of BY was large almost to overflow. Xtmax Processing The negative infinite value of the floating point expression is output to BY. BY is set as 0.0. BY is set as 0.0.
Method A -order Bessel function of the second kind is defined using Bessel functions of the first kind J(x) and J_(x) as follows: Y ( x ) = J ( x )cos( ) J ( x ) sin( ) (4.1)
If the value of order is expressed as integer n, this is defined as the limit value for n . In this subroutine, the value of Y(x) is calculated directly for 02.5. For >2.5, if fraction part of is equal to or less than 0.5, values of Y+1(x) and Y+2(x) are calculated directly; and if is greater than 0.5, values of Y(x) and Y+1(x) are calculated directly. These values are used to calculate Y(x) form the recurrence formula: Y +1 ( x ) = 2 Y ( x ) Y 1 ( x ) x (4.2)
30000
X<0.0 or V<0.0
Comments on use Subprograms used SSL II ... AMACH, AFMAX, MGSSL, ULMAX, and UTLIM FORTRAN basic function ... FLOAT, ALOG, AMAX1, ALGAMA, ABS, GAMMA, SQRT, SIN, and COS Notes X>0.0 and 0.0 must be satisfied. To evaluate Y0(x) or Y1(x), it is better to use BY0 or BY1 respectively rather than this subroutine. If values Y(x), Y+1(x), Y+2(x), ... Y+M(x) are necessary at the same time, calculate Y(x) and Y+1(x) and with this subroutine , then use recurrence formula((4.2) in "Method") repeatedly to obtain the values of higher order as Y+2(x), Y+3(x), ..., Y+M(x). If this subroutine is called repeatedly with the same value of for large values of x, the common procedure is bypassed to calculate the value of Y(x) effectively. Example The following example calculates the value of Y(x) for from 0.5 to 0.8 with increment 0.01 and for x from 1 to 10 with increment 1.
For 02.5, calculation method of Y(x) is explained below. The method varies depending on the value of x. For x3.66 (4.3)
the calculation method for a small value of x is used; whereas, for x>3.66 (4.4)
the calculation method for a large value of x is used. The method for a small value of x Series expansion of the following functions J(x) and J(x) is used: 1 x2 x 1 4 + J ( x) = 2 (1 + ) 1! (2 + )
2 1 2 x 4 + + 2! (3 + )
(4.5)
224
BYR
1 x2 x 1 4 + J (x ) = 2 (1 ) 1! (2 ) 1 2 x 4 + + 2! (3 )
2
This is because 1(,x) and 2(,x) can be calculated with a high accuracy using the best approximation as follows: x x 1 ( , x ) = f log log 2 2 x x 2 ( , x ) = f log log 2 2
(4.11)
(4.6)
The following best approximation of function f(t) is incorporated in this subroutine: f (t ) (4.7) 2 pk t 2 k
k =0 k =0 M
qk t
2k
t pk t 2 k
k =0
(4.12)
The calculation method varies depending on the interval of : 0 0.5, 0.5< 1.5, and 1.5< 2.5. Explanations of the calculation method for 0 0.5 follow. The following is obtained from expressions (4.5), (4.6), and (4.7): J ( x )cos( ) J ( x ) = { Ak ( , x )
k =0
To calculate (1/(k+1-)-cos()/(k+1+))/(k!) for Ak(,x) in expression (4.9) without cancellation, it is only necessary to obtain the best approximation having the required accuracy. In this case, since the following is satisfied for the part enclosed in braces in Ak(,x) of expression (4.9).
~ Ak ( ) = ~ cos( ) 1 1 + Ak 1 ( ) + k! (k + )(k ) (k ) (k + ) (k 1) 1
+ Bk ( , x ) where
}
k
(4.13) (4.8) ~ it is only necessary to obtain an approximation of A0 ( ) for 00.5. In this subroutine,
M ~ A0 ( ) ( 0 ) pk k k =0
cos( ) 1 1 k! (k + 1 ) (k + 1 ) k 1 Bk ( , x ) = x 2 4 2 ( , x )cos( ) 1 1 ( , x ) + + + + ! k k k 1 1 ( ) ( ) 1 Ak ( , x ) = x 2 4
(4.14)
(4.9)
If Ak(,x) and Bk(,x) are calculated as they are, cancellation occurs for 0. This is prevented as follows: Since 1(,x) and 2(,x) have the same sign in Bk(,x),cancellation does not occur even when they are added; however, if 1(,x) and 2(,x) defined in expression (4.7) are calculated as they expressed in the right sides, cancellation occurs if (x/2) is close to 1. To calculate 1(,x) and 2(,x) as accurate as binary rounding error, it is only necessary to obtain the best approximation of the following function f(t) having the required accuracy for -log2tlog2: f (t ) = et 1 1 t t 2 = + + + t 1! 2! 3! (4.10)
is used as the best approximation. Values of Ak(,x) and Bk(,x) can be obtained without cancellation in this way, buy all values do not have the same sign; consequently, cancellation may occur in the addition to be processed in expression (4.8). Since function Y(x) is an oscillating function with respect to x for constant and has a zero point, it is impossible to obtain the value of such a function with a relative accuracy. This means that the absolute accuracy must be used. (except for the case if the value of x is small and the value of Y(x) takes a great negative value.) Examining the range for x in which the value of Y(x) can be calculated with an absolute accuracy applicable in principle, x3.66 (4.15)
is found to be valid in this method. Since values of the terms comprising the sum in expression (4.8) become sufficiently small as the value of k becomes greater, it is only necessary to calculate a relatively small number of terms until the resultant value converges according to the required accuracy. Therefore, the value of Y(x) is obtained from
225
BYR
J ( x )cos( ) J (x ) Y (x ) = sin( ) =
k =0
{ Ak ( , x ) + Bk ( , x )}
(4.23)
g( )
(4.17)
of g( ) = sin( ) (4.18)
1 of (4.21) in Let us obtain the approximation of f x the following paragraph. If the approximation is known, the real and imaginary parts of expression (4.22) are 1 1 obtained as P , and Q , . With these values, x x Y(x) is obtained. The Hankel function of the first kind H(1) ( x ) satisfies the following differential equation: d 2w dw x2 +x + ( x 2 2 )w = 0 (4.24) dx 2 dx 1 Assuming t = and substituting H(1) ( x ) of (4.21) to x 1 (4.24), f or f (t ) satisfies the following x differential equation. 1 t 2 f(t ) + 2(t i) f (t ) + 2 f (t ) = 0 4 (4.25)
For = 0, the value of Y(x) is calculated with the limit value obtained from expression (4.1) for 0 as follows. 1 2 x 2 4 x Y0 ( x ) = + log k 2 k = 0 (k!) 2
k
(4.19)
This is more efficient than the calculation of (4.16). Where is the Euler's constant, 0=1, and k 1 k = (k 1) . m=0 m The calculation method for 00.5 has been explained. Calculation methods for 0.5<1.5 and 1.5<2.5 are omitted because the same concept applies to these ranges. The method for a large value of x Bessel function of the second kind Y(x) is given as the imaginary part of the Hankel function of the first kind H(1) ( x ) = J ( x ) + iY ( x ) (4.20)
Applying the method to this differential equation, the approximation of f(t) is obtained for a small value of t. For this purpose, let us consider the following differential equation derived from (4.25) by adding the shifted ultraspherical polynomial on the orthogonal interval [0,] to the right side by multiplying . 1 t 2 f t + 2(t i) f t + 2 f m (t ) m( ) m( ) 4 =C
*( ) m
Where i is the imaginary unit i = 1 , J ( x ) is the 1 Bessel function of the first kind. And f is defined x as follows: 1 x 2 i x f = e 2 4 H(1) ( x ) x 2
1 1 1
(4.26)
(4.21)
Cm( ) a l t l
* a k
k =0
2(k + 1)a k +1 k
l =0
(4.27)
1 where, f is an imaginary function, and assume x 1 whose real part is p and whose imaginary part is x 1 1 Q , . In this case, f is expressed as: x x 1 1 1 f = P , + iQ , x x x (4.22)
where a0 = 1 al = i l
(4
)(4
)(
l
l!8
4 (2l 1) (4.28)
2 2
*( a ) *( a ) Cm is the k-th order coefficient of Cm (t). If the value of in the right side of (4.26) is sufficiently small, fm(t) can be regarded as the approximation polynomial of f(t). Determining the value of (the value of decreases as the value of m increases) by the initial condition fm(0)=1(f(t) 1 for t 0), we obtain the following approximation polynomial fm(t) of f(t) for 0t:
226
BYR
f m (t ) =
k =0 m
* ( ) Cmk al t l
d0 = (4.29)
* ( ) Cmk k k =0 ( k + 1)a k +1
(k + 1)a
l=0
2
*1
k +1
() 2 Cm ,l 1 dl = l 1l
* (1 ) e0 = 2 Cmn
1 l ( ) (n 1)
(4.33)
The value of is assumed to be 1 based on the results of experiments conducted for the accuracy of fm(t) with various values. 1 1 Since P , and Q , are the real and x x 1 imaginary parts of f , they can be expressed as x 1 P , x Re 1 Im Q , x
k 1 *( a ) Cmk al m = x l 0 k = 0 ( k + 1)a k k +1 l
en =
2n C C
* (1 ) m0 * (1) m ,n1
(4.34)
*( 1) Cmk k = 0 ( k + 1)a k k +1
(4.30)
As explained at the beginning of explanations, this method is applied to the range of x>3.66; thus the calculation formula can be determined with a minimum value for the required accuracy assuming =1/3.66. Since the value of m decreases in proportion to that of , it is best to change the values of and m depending on intervals of x. It is known 1 1 that the values of P , and Q , can be efficiently x x calculated from the following: For single precision: for 3.66 < x < 10, = for 1 , m = 8 3.66 1 ,m = 5 x 10, = 10
(4.35)
For double precision: for 3.66 < x < 10, = for 1 , m = 24 3.66 1 , m = 15 x 10, = 10
1 For efficient calculation formulas of P , and x 1 Q , , these expressions are transformed to x m 1 l m 1 l d P , ( i ) l i kWk +1 x Wl k = l Re 2 l =0 x m k Im 1 i W k +1 Q , k =0 x (4.31) where W0 = 1 Wk =
k 1
(4.36)
en n + 1 2 2
2
n=0
(k 1)
(4.32)
227
BY0
I11-81-0401
BY0, DBY0
CALL BY0(X,BY,ICON) Function This subroutine computes the zero order Bessel function of the second kind Y0(x) Y0 ( x ) = 2 J 0 ( x ) log(x 2) +
k 2k k =1 2
( 1) ( x 2) (k!)
k 1 m m =1
**EXAMPLE** WRITE(6,600) DO 10 K=1,100 X=K CALL BY0(X,BY,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BY IF(ICON.NE.0) WRITE(6.620) X,BY,ICON 10 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HY0(X)/) 610 FORMAT(1H ,F8.2,I5,E17.7) 620 FORMAT(1H ,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBY=,E17.7,5X,10HICONDITION=,I10) END
Method With x=8 as the boundary, the approximation formula used to calculate Bessel function Y0(x) changes. For 0<x8 The expansion of Y0(x) into power series Y0 ( x ) = 2 J 0 ( x ) log(x 2) +
k =1
(where J0(x): zero order Bessel function of the first kind and : Euler's constant) by rational approximations and the asymptotic expansion. Where, x>0. Parameters X ..... Input. Independent variable x. BY .... Output. Function value Y0(x). ICON .. Output. Condition code. See Table BY0-1.
Table BY0-1 Condition code Code 0 20000 30000 Meaning No error Xtmax X0 Processing BY is set to 0.0. BY is set to 0.0.
{
k
}
(4.1)
( 1) ( x 2) (k!)
2
2k
k 1 m m =1
(where J0(x): Zero-order Bessel function of the first kind and : Euler's constant) is calculated using the following rational approximations. Single precision: Y0 ( x ) = ak x 2 k bk x 2 k +
5 5 k=0 k =0
Comments on use Subprograms used LLS II ... UBJ0,MGSSL, and UTLIM FORTRAN basic function ... DSIN, DCOS, DLOG and DSQRT Notes [Range of argument X] 0<X<tmax These limits are used because sin(x-/4) and cos(x/4) lose accuracy if X becomes large. (See "Method".) Example The following example generates a table of Y0(x) from 1 to 100 with increment 1.
2 J (x )log(x ) 0
(4.2)
2 J (x )log(x ) 0
(4.3)
Theoretical precision = 18.78 digits For x>8 The asymptotic expansion of Y0(x) Y0 ( x ) = 2 P ( x )sin( x 4) x 0
+ Q0 ( x )cos( x 4)
(4.4)
is evaluated through use of the following approximate expressions of P1(x) and Q1(x) Single precision: P0 (x ) = ak z 2 k bk z 2 k , z = 8 x
2 2 k =0 k=0
(4.5)
228
BY0
(4.8)
Theoretical precision = 18.33 digits For more information, see Reference [78] pp.141 - 149. (4.7)
229
BY1
I11-81-0501
BY1, DBY1
CALL BY1(X,BY,ICON) Function This subroutine computes the first order Bessel function of the second kind Y1 ( x ) = 2 / J1 ( x ) log(x / 2) + 1 / x
CALL BY1(X,BY,ICON) IF(ICON.EQ.0) WRITE(6,610) X,BY IF(ICON.NE.0) WRITE(6.620) X,BY,ICON 10 CONTINUE STOP 600 FORMAT(1H1,26HEXAMPLE OF BESSEL FUNCTION/// * 6X,1HX,9X,5HY1(X)/) 610 FORMAT(1H ,F8.2, E17.7) 620 FORMAT(1H ,11H** ERROR **,5X,2HX=,E17.7, * 5X,3HBY=,E17.7,5X,10HICONDITION=,I 10) END
Method With x=8 as the boundary, the approximation formula used to calculate Bessel function Y1(x) changed. For 0<x8 The power series expansion of Y1(x). Y1 ( x ) = 2 / J1 ( x ) log( x / 2) + 1 / x ( 1) ( x / 2) 1 / k =0 k !(k + 1)!
k 2 k +1
(where J1(x): first order Bessel function of the first kind and : Euler's constant) by rational approximations and the asymptotic expansion. Where, x>0. Parameters X ..... Input. Independent variable x. BY .... Output. Function value Y1(x). ICON .. Output. Condition code. See Table BY1-1.
Table BY1-1 Condition code Code 0 20000 30000 Meaning No error Xtmax X0 Processing BY=0.0 BY=0.0
(4.1) k k +1 + 1 / 1 / m m m=1 m =1
(where J1(x): first order Bessel function of the first kind and : Euler's constant) is calculated using the following rational approximations. Single precision: Y1 ( x ) = ak x 2 k +1 / bk x 2 k
7 2 k =0 k =0
Comments on use Subprograms used LLS II ... UBJ1 and MGSSL FORTRAN basic function ... DSIN, DCOS, DLOG and DSQRT Notes The range of argument X 0<X<tmax These limits are set because sin(x-3/4) and cos(x3/4) can not be calculated accuracy if X becomes large. (See "Method".) Example The following example generates a table of Y1(x) from 1 to 100 with increment 1.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,100 X=K
2 + J1 ( x ) log( x ) 1 / x
(4.2)
2 J1 ( x ) log( x ) 1 / x
(4.3)
Theoretical precision = 18.24 digits For x>8 The asymptotic expansion of Y1(x) Y1 ( x ) = 2 sin( x 3 / 4) P 1 ( x) x + Q1 ( x ) cos( x 3 / 4)
(4.4)
is calculated through use of the following approximate expression P1(x) and Q1(x): Single precision: P x = ak z 2 k / bk z 2 k , z = 8 / x 1( )
2 2 k =0 k =0
(4.5)
BY1
Q1 ( x ) = ck z 2 k +1 d k z 2 k , z = 8 x
1 2 k =0 k =0
(4.6)
(4.8)
k =0
(4.7)
231
CBIN
I11-82-1101
CBIN, DCBIN
Integer order modified Bessel function of the first kind In(z) with complex variable
Example The value of In(z) is computed for n=1,2, where z=10+5i. Method If it is known beforehand that the absolute value of In(z) will underflow, the following computation is not performed with setting the result as (0.0,0.0). In(z) is computed in different ways depending upon the value of z. 1) When Re( z ) + Im( z ) 1, The power series expansion, 1 2 z n 1 4 I n ( z ) = z 2 k = 0 k !(n + k )!
k
CALL CBIN(Z,N,ZBI,ICON) Function This subroutine computes integer order modified Bessel function of the first kind In(z) with complex variable 1 2 z 4 1 I n ( z ) = z 2 k = 0 k !(n + k )!
k n
by the power series expansion of the above form and recurrence formula. Parameters Z ..... Input. Independent variable z. Complex variable. N ..... Input. Order n of In(z). ZBI .... Output. Function value In(z). Complex variable. ICON .. Output. Condition code. See Table CBIN-1.
Table CBIN-1 Condition code Code 0 20000 Meaning No error Processing ZB1=(0.0,0.0)
(4.1)
is evaluated until the k-th item becomes less than the round-off level of the first term. 2) When Re( z ) + Im( z ) > 1, Re( z ) log( flmax ) and Im( z ) log( flmax ) . The recurrence formula is used. Suppose m to be an appropriately large integer (which depends upon the required precision, z and n) and to be an appropriately small constant (10-38 in this subroutine). With the initial values. Gm+1(z)=0, Gm(z)= repeat the recurrence equation, G k 1 ( z ) = 2k G ( z ) + G k +1 ( z ) z k (4.2)
Comments on use Subprograms used SSL II ... AMACH, MGSSL, ULMAX FORTRAN basic function ... REAL, AIMAG, ABS, IABS, FLOAT, CEXP, MAX0 Notes The range of argument should, be Re( z ) log( flmax ) and Im( z ) log( flmax ) . When a set of function values In(z), In+1(z), In+2(z), ..., In+M(z), is required at the same time, first, obtain In+M(z) and In+M-1(z) with this subroutine. Then the others can be obtained in sequence from high order to low order, that is, In+M-2(z), In+M-3(z), ..., In(z), by using repeatedly the recurrence formula. Obtaining of the values in the reverse order, that is In+2(z), In+3(z), ..., In+M(z), by the recurrence formula after obtaining In(z) and In+1(z) by this subroutine, must be avoided because of its unstableness.
(4.3)
where
1 k = 2
(k = 0) (k 1)
Equation (4.3) can be used when Re(z) 0. When Re(z)<0, cancellation will take place in the above computations. Therefore, using the relation In(-z)=(-1)n In(z), the problem can be reduced to the computation above. For detailed information, for example, on how to determine m, see Reference [81] and [83].
232
CBJN
I11-82-1301
CBJN, DCBJN
Integer order Bessel function of the first kind Jn(z) with complex variable
CALL CBJN(Z,N,ZBJ,ICON) Function This subroutine computes the integer order Bessel function of the first kind with complex variable 1 2 z n 1 4 J n (z ) = z 2 k =0 k !(n + k )!
k
Z=(10.0,5.0) DO 10 N=1,2 CALL CBJN(Z,N,ZBJ,ICON) WRITE(6,600) Z,N,ZBJ,ICON 10 CONTINUE STOP 600 FORMAT(1H,2F8.2,I6,5X,2E17.7,I7) END
Method If it is known beforehand that the absolute value of Jn(z) will underflow the following computation is bypassed with the result as (0.0,0.0). The method for computing Jn(z) depends upon the value of z. When Re( z ) + Im( z ) 1, The power series expansion 1 2 z 4 1 = J n ( z ) z 2 k = 0 k !(n + k )!
k n
by evaluating the power series expansion of the form above and recurrence formula. Parameters Z ..... Input. Independent variable z. Complex variable. N ..... Input. Order n of Jn(z). ZBJ .... Output. Value of function Jn(z). Complex variable. ICON .. Output. Condition code. See Table CBJN-1.
Table CBJN-1 Condition code Code 0 20000 Meaning No error Processing ZBJ=(0.0,0.0)
(4.1)
is evaluated until the k-th term becomes less than the round-off level of the first term. When Re( z ) + Im( z ) > 1, Re( z ) log( flmax ) and Im( z) log( flmax ) The recurrence formula is used for the computation. Suppose m to be an appropriately large integer (which depends upon the required accuracy, z and n) and to be an appropriately small constant (10-38 in this subroutine). With the initial values, Fm+1(z)=0, Fm(z)= and repeating the recurrence equation, Fk 1 ( z) = 2k F ( z) Fk +1 ( z ) z k (4.2)
Comments on use Subprograms used SSL II ... AMACH, MGSSL, ULMAX FORTRAN basic function ... REAL, AIMAG, ABS, IABS, MOD, FLOAT, CEXP, CONJG, MAX0, CMPLX Notes The range of argument z should be Re(z ) log( flmax ) and Im( z ) log( flmax ) . When all the values of Jn(z), Jn+1(z), Jn+2(z), ..., Jn+M(z) are required at the same time, first obtain Jn+M(z) and Jn+M-1(z), by this routine. Then the others can be obtained in sequence from high order to low order, that is, Jn+M-2(z), Jn+M-3(z), ..., Jn(z), by repeating the recurrence formula. Obtaining of values in the reverse order, that is, Jn+2(z), Jn+3(z), ..., Jn+M(z), by the recurrence formula after obtaining Jn(z) and Jn+1(z) by this subroutine, is not recommended because of its unstableness. Example The value of Jn(z) is computed for n=1 and n=2, where z=10+5i.
C **EXAMPLE** COMPLEX Z,ZBJ
(4.3)
where 1 k = 2
(k = 0) (k 1)
Equation (4.3) can be used only when 0arg z. When -<arg z<0 cancellation will take place. Therefore, using the relation J n (z ) = J n ( z) it is, reduced to be within the condition 0arg z. For detailed information, for example, on how to determine m, see References [81] and [83].
233
CBJR
I11-84-0101
CBJR, DCBJR
Real order Bessel function of the first kind J(z) with complex variable
CALL CBJR(Z,N,ZBJ,ICON) Function This subroutine computes the value of real order Bessel function of the first kind with complex variable z 1 2 z 4 1 J v ( z) = z 2 k = 0 k ! (v + k + 1)
k v
Example The following example generates a table of J(z) at z=10+5i for the range of from 0.1 to 10 with increment 0.1.
C **EXAMPLE** COMPLEX Z,ZBJ Z=(10.0,5.0) DO 10 NV=1,100 V=FLOAT(NV)/10.0 CALL CBJR(Z,V,ZBJ,ICON) IF(ICON.EQ.0) WRITE (6,600) Z,V,ZBJ 10 CONTINUE STOP 600 FORMAT(1H ,2F8.2,F10.3,5X,2E17.7) END
using the power series expansion (above expression) and the recurrence formula. In the above expression, the value of (1/2z) adopt the principal value. Though the principal value of
(1 2 z)
log(z/2) is selected, it is determined by FORTRAN basic function CLOG. Usually, the principal value of (z 2) = log z 2 + i arg z , -<arg z Parameters Z ..... Input. Independent variable z. (complex variable). V ..... Input. Order of J(z) (0). ZBJ .... Output. Value of function J(z). (complex variable). ICON .. Output. Condition code. See Table CBJR-1.
Table CBJR-1 Condition code Code 0 20000 Meaning No error Processing Set ZBJ=(0.0,0.0)
Method When it is known the value of J(x) will underflow, the following computations are bypassed and the result 0.0 is output. The computation of J (z) depends on z Re( z ) + Im( z ) 1 With the power series expansion 1 2 z v 4 1 J v (z) = z 2 k = 0 k ! (v + k + 1)
k
(4.1)
it is computed until the k-th term is less than the unit round-off in relative to the first term. Re( z ) + Im( z ) > 1 and Re( z ) log( flmax ) and Im( z) log( flmax ) Recurrence formula is used. Let's suppose that m is a certain large integer (determined by z, , and the desired precision), and that is set to a certain small constant (10-38) and moreover that n and are determined by v = n + (n:integer, 0 < 1) Initial values F + m +1 (z ) = 0, F + m (z ) = are set, and recurrence formula F + k 1 (z) = 2( + k ) z F + k (z) F + k +1 (z ) (4.2)
30000
V<0
Set ZBJ=(0.0,0.0)
Comments on use Subprograms used SSL II ... MGSSL, AMACH, ULMAX FORTRAN basic function ... REAL, AIMAG, ABS, FLOAT, CEXP, CLOG, GAMMA, CONJG, AMAX1, CMPLX Notes Re(z ) log( flmax ) , Im( z ) log( flmax ) , and 0. When a set of function values J(z), J+1(z), J+2(z), ..., J+M(z), is needed at the same time, J+1(z) and Jn+M1(z) are computed with this subroutine, and next J+M2(z), J+M-3(z), ..., J(z) are computed by using the recurrence formula repeatedly, it should be avoided in computing J+2(z), J+3(z), ..., J+M(z) by the recurrence formula, after computing J(z) and J+1(z) with this subroutine, in sequence from low order to high order. 234
CBJR
The above expression is suitable in the range of 0arg z. Since cancellation occurs in the above expression when -arg z<0, the problem is returned to that of 0arg z using the relation of J v ( z ) = J v (z ) . For the method of determining of m and other details, see References [81] and [83].
m ( + k ) (2 + k )i k F + k ( z ) k=0 k!
(4.3)
235
CBKN
I11-82-1201
CBKN, DCBKN
Integer order modified Bessel function of the second kind Kn(z) with complex variable.
CALL CBKN(Z,N,ZBK,ICON) Function This subroutine computes the value of integer order modified Bessel function of the second kind with complex variable z Kn ( z) = K n ( z) = ( 1)
n +1
Comments on use Subprograms used SSL II ..... AMACH, CBIN, MGSSL, ULMAX, UTLIM FORTRAN basic function ... REAL, AIMAG, ABS, IABS, MOD, CSQRT, CEXP, CLOG, FLOAT, CMPLX Notes - z 0 - Re(z ) log( flmax ) - When Re(z)>0, Im( z ) < t max Otherwise the value of exp(-z) used in the computations cannot be correctly computed. - When Re(z)<0, Im( z ) log( flmax ) is required. When Re(z)0 and all the values of Kn(z), Kn+1(z), Kn+2(z), ..., Kn+M(z) are required at the same time, first obtain Kn(z) and Jn+1(z) by this routine. Then the others can be obtained in the order of Kn+2(z), Kn+3(z), ..., Kn+M(z), by repeating the recurrence formula (See (4.1) in Method). When Re(z)<0, since this is not stable, this subroutine must be called for each required order. Example The value ov K1(1+2i ) is computed.
C **EXAMPLE** COMPLEX Z,ZBK Z=(1.0,2.0) N=1 CALL CBKN(Z,N,ZBK,ICON) WRITE (6,600) Z,N,ZBK,ICON STOP 600 FORMAT(1H ,2F8.2,I6,5X,2E17.7,I7) END
z + log I n (z) 2
k
+ +
( 1)n
2 1 z 2 2
z2 n 4 z ( + k + n ) 2 k = 0 k !(n + k )! k
n n 1 k =0
(n k 1)! z2
k! 4
by using the recurrence formula and the -method. Here, when n=0, the last term is zero, is the Euler's constant. In(z) is the modified Bessel function of the first kind, and
0 = 0 k =
k m=1
1 m
(k 1)
Parameters Z ..... Input. Independent variable z. Complex variable. N ..... Input. Order n of Kn(z). ZBK .... Output. Value of function Kn(z). Complex variable. ICON .. Output. Condition code. See Table CBKN-1.
Table CBKN-1 Condition code Code 0 20000 Meaning No error One of the following occurred Re(z) log(fl max ) Processing ZBK=(0.0,0.0)
Method Since K-n(z)=Kn(z) when n<0, it is reduced to the case n0. The method for computing Kn(z) depends on whether Re(z)0 or Re(z)<0. When Re( z) 0 Kn(z) can be computed by the recurrence formula, Kn +1 (z) = 2k Kk (z ) + K k 1 (z) z k = 1, 2,
Re(z) 0 and
Im(z) t max 30000
z = 0.0
ZBK=(0.0,0.0)
, n 1
(4.1)
with the starting values K0(z) and K1(z) Computational procedures for K0(z) and K1(z) depend on the value of z.
236
CBKN
For: Single precision: Im( z ) < 2.25 Re( z ) 4.5 and Double precision: Im(z ) < 4 Re( z ) 8 K0(z) and K1(z) are computed as follows
I ( z) z K0 (z ) = + log I 0 ( z) + 2 2 k 2 k k =0 1 K1( z) = I1( z) K0 ( z) I 0 ( z) z
If is determined from the initial condition fnm(0)=1 (as t 0,fn(t) 1) we can obtain
m
(4.2) (4.3)
f nm (t ) =
k =0
Cmk ai t i
*( ) k
(k + 1)ak +1 k (k + 1)ak +1 k
Cmk
*( )
i =0
(4.10)
k =0
where, Ik(z) is obtained by the recurrence formula. For: Single precision: Im( z ) 2.5Re(z ) + 4.5 and Double precision: Im( z ) 4Re( z ) + 8 The -method is used. (See Reference [84]). In this method, Kn(z) is obtained from Kn (z) =
This equation contains and as unknowns. It has been seen when =0.5 (the shifted Ultraspherical polynomial) and =t, the highest accuracy can be obtained. (See Reference [84]). In this case,
m m * Pmk ai t i k i =0
f nm (t ) =
k =0
(k + 1)a
* mk
k +1
tk
z 1 e fn z 2z
(4.4)
P k = 0 ( k + 1)a tk k +1
(4.11)
and fn(1/z) is approximated. Assume t=1/z, then fn(t) satisfies 1 t 2 f n " (t ) + 2(t + 1) f n(t ) n2 f n (t ) = 0 4 (4.5)
(4.12)
Adding on the righthand side of (4.5) times a shifted Ultraspherical polynomial orthogonal over the interval [0, ], then t 1 * ( ) t 2 f n(t ) + 2(t + 1) f n(t ) n 2 f n (t ) = Cm (4.6) 4 where Cm
*( )
By multiplying the denominator and numerator by tm and expressing as powers of t. f nm (t ) = where, Gi (m, n) =
i i =0 m
Gi (m, n)t i
m
i =0
Hi (m, n)t i
(4.13)
(t ) = C
m i =0
*( ) i mi
(4.7)
denotes the shifted Ultraspherical polynomial (when =0, it is equivalent to the shifted Chebyshev polynomial and when =0.5, it is equivalent to the shifted Legendre polynomial). Equation (4.6) contains the solution of the following m-th degree polynomial
m
(4.14) (4.15)
Then ~ 1 Gi (m, n) z i =0
m i
K n ( z) =
1 z e z
f nm (t ) = where, a0 = 1 ak =
Cmk
*( )
k k = 0 (k + 1)a k +1
i=0
ai t i
(4.8)
~ 1 H i (m, n) = z i 0
m
(4.16)
(4n
1 )(4n 3
2 2
)(4n (2 k 1) )
2 2
k ! 8k
(k 1) (4.9)
can be obtained as a computational expression for Kn(z) from (4.4) and (4.13). Where ~ Gi (m, n) = Gi (m, n) Gm (m, n) (4.17) ~ 2 (4.18) H i (m, n) = H i (m, n) G m (m, n) This subroutine sets m in case n equal 0 or 1 as follows in consideration of efficiency. Single precision: 237
CBKN
when z 17 ,
m=3
otherwise, m=7 Double precision: when (Re(z))2+0.425(Im(z))2152 , m=10 otherwise , m=19 This subroutine contains a table in which constants Gi (m, n) and Hi (m, n) are stored in the data statement. When Re(z)<0 The cut of Kn(z) is selected on the negative real axis. Therefore, when Im(z)0, the relation (4.19) Kn(z)=(-1)nKn(-z)-iIn(-z) when Im(z)<0, the relation (4.20) Kn(z)=(-1)nKn(-z)-iIn(-z) are used, where the value of Kn(-z) can be obtained by using the calculation for Re(z)0 mentioned previously, and the value of In(-z) can be obtained by subroutine CBIN. Thus the additional computations for In(-z) are required when Re(z)<0, as is not the case when Re(z)>0.
238
CBLNC
Function An n -order complex matrix A is balanced by the diagonal similar transformed shown in (1.1).
~ A = D -1 AD
diagonal elements are zero. When obtaining eigenvector x of matrix A , the back transformation of (3.1) must be applied to the ~ eigenvector ~ x of matrix A balanced by this subroutine. x = D~ x (1.1) (3.1)
The back transformation of (3.1) can be performed by subroutine CHBK2 (See the selection on CNBK2). Example After balancing the n-order complex matrix A, it is transformed to the complex Hessemberg matrix by subroutine CHES2 and the eigenvalue is obtained by the subroutine CHSQR. When n 100.
C **EXAMPLE** COMPLEX ZA(100,100),ZE(100) DIMENSION DV(100),IP(100) 10 READ (5,500) N IF(N.EQ.0) STOP READ(5,510) ((ZA(I,J),I=1,N),J=1,N) WRITE (6,600) N DO 20 I=1,N 20 WRITE(6,610)(I,J,ZA(I,J),J=1,N) CALL CBLNC(ZA,100,N,DV,ICON) WRITE(6,620) ICON IF(ICON,NE,0) GO TO 10 CALL CHES2(ZA,100,N,IP,ICON) CALL CHSQR(ZA,100,N,ZE,M,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) GO TO 10 WRITE(6,630) (ZE(I),I=1,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1,5X,15HORIGINAL * MATRIX,5X,2HN=,13/) 610 FORMAT(/2(5X,2HA(,I3,1H,,I3,2H)=, * 2E15.7)) 620 FORMAT(1H0,20X,5HICON=,I5) 630 FORMAT(1H0,5X,10HEIGENVALUE/1H0,20X, * 4HREAL,16X,4HIMAG/(1H0,15X, * 2(E15.7, 5X))) END
Balancing means to almost completely equalize the sum of norm of the i-th column (i = 1, ..., n) and that of the i-th row for the transformed complex matrix. The norm of the elements is ||z||1=|x|+|y| for complex number z = x + iy. D is a real diagonal matrix, and n 1. Parameters ZA... lnput. Complex matrix A. ~ Output. Balanced complex matrix A . ZA is a two-dimensional array, ZA (K,N) K... Input. Adjustable dimension of array ZA. ~ N... Input. Order n of complex matrix A and A . DV... Output. Scaling factor (Diagonal elements of D) One-dimensional array of size n. ICON... Output. Condition code. See Table CBLNC- 1 .
Table CBLNC-1 Condition code Code 0 10000 30000 Meaning No error N=1 N < 1 or K < N. Processing No balancing. Bypassed
Comments on use Subprograms used SSL II ... IRADIX, MGSSL FORTRAN basic functions ... REAL, AIMAG, ABS Notes If there are large difference in magnitude of elements in a matrix, the precision of the computed eigenvalues and eigenvectors on this matrix may not be computed accurately. This subroutine is used to avoid the adverse effects. When each elements of a matrix is nearly the same magnitude, this subroutine performs no transformation. Therefore this subroutine should not be executed . This subroutine omits balancing of the column (or row) and the corresponding row (or column) in which all the elements of a column or row except the
Method An n -order complex matrix A is balanced by performing iterative diagonal similar transformation in (4.1). As = Ds1 As1 Ds s = 1, 2,
(4.1)
Where A0 = A and Ds is a real diagonal matrix expressed in (4.2) and s is the number of iterations.
239
CBLNC
d1( s ) d2( s ) Ds = 0
0 (s) dn
(4.2)
Iteration of (4.1) terminates when (4.3) is satisfied for all column and rows. This subroutine executes this operation in the following steps: 1) The sum of norms of each element in the i-th column and row is computed excluding the diagonal element. C = aki
k =1 ki n
In the balancing of (4.1), excluding the diagonal element, the sum of the magnitude of elements in the ith row of As is made almost equal to that of the magnitude of elements in the i-th column. ( s) , balancing is performed such that Assuming As = aij
(4.7)
( )
1
k =1 k i
( s) ( s) aik 1 aki
n n k =1 k i
(4.3)
(4.8)
should be satisfied. If Dsi is defined as shown in (4.4), Ds of (4.2) can be expressed as (4.5). i 1 0 1 (s) di Dsi = i 1 0 1 Ds = Ds1 Ds 2 Dsn
2 for binary digits where p = 16 for hexadecimal digits k is defined to satisfy the following condition. R > C 2k R (4.10)
(4.4)
From (4.10), k > 0 when C < R/p and k 0 when C R/p. 3) By the condition shown in (4.11), whether or not transformation is required is determined.
(C
(4.5)
2k
+ R) k < 0.95(C + R)
(4.11)
From (4.5), (4.1) can be transformed by sequentially performing transformation of (4.6) for i = l, 2, ..., n.
1 Asi =Dsi Asi1 Dsi
(4.6)
When (4.11) is satisfied, transformation is performed where d i( s ) = p k and if not satisfied, transformation is bypassed. 4) When transformation has been performed for all columns and rows, the balancing process terminates. Then, the diagonal elements of D shown in (4.12) are stored as the scaling factor in array DV. D = D1 D2
where, Diagonal element ai( s ) of Dsi is defined so that the transformed i-th column and corresponding row satisfy (4.3). If they satisfy (4.3) before transformation, d i( s ) = 1, that is Dsi = I.
D
(4.12)
240
CBYN
Notes |z|0 Re( z ) log( flmax ) and Im( z ) log( flmax ) When all the values of Yn(z), Yn+1(z), Yn+2(z), , Yn+M(z) are required at a time, the procedure to be mentioned below under Method is most recommendable. Example The value of Y1(1+2i) is computed.
C **EXAMPLE** COMPLEX Z,ZBY Z=(1.0,2.0) N=1 CALL CBYN(Z,N,ZBY,ICON) WRITE(6,600)Z,N,ZBY,ICON STOP 600 FORMAT(lH ,2F8.2,I6,5X,2E17.7,I7) END
Function This subroutine computes the value of integer order Bessel function of the second kind with complex variable. Yn ( z ) = ( 1) Y n ( z )
n
by using the recurrence formula and the -method. In the definition when n = 0, the last item is zero, denotes the Eulers constant Jn(z) is Bessel function of the second kind and
(4.1)
0 = 0 k =
k m=1
the computation for n < 0 can be reduced to that for n > 0 Also, because Yn ( z ) = Yn (z ) (4.2)
1 m
(k 1)
Parameters Z ... Input. Independent variable z. Complex variable. N ... Input. Order n of Yn(z). ZBY ... Output. Value of function Yn(z). Complex variable. ICON ... Output. Condition code. See Table CBYN-1.
Table CBYN-1 Condition code Code 0 20000 Meaning No error Proceccisng ZBY = (0.0, 0.0)
when Im (z) < 0, this is reduced to that wen Im (z) 0. Yn(z) is computed using the relation.
Yn (z ) = i n+1 I n ( iz )
n 2 n i ( 1) K n ( iz )
(4.3)
, i = 1 where, the value of In(iz) is computed by subroutine CBIN which uses the recurrence formula, and the value of Kn ( iz) is computed by subroutine CBKN which uses the recurrence formula and -method. When all the values of Yn(z), Yn+1(z), Yn+2(z), , Yn+M(z) are required at a time, they are obtained efficiently in the way indicated below. First the value of In+M ( iz) and In+M-1 ( iz) are obtained by CBIN, and then repeating the recurrence formula, the values are obtained sequentially in the order of the highest value first until In ( iz), is obtained. Kn ( iz) and Kn+1 ( iz) are obtained by CBKN and then repeating the recurrence formula the values are obtained sequentially in the order of the lowest value first until Kn+M(z) is obtained. Then, by the relation in (4.3), the required computation is done.
30000
|z| = 0.0
Comments on use Subprograms used SSL II ... AMACH, CBIN, CBKN, MGSSL, ULMAX, UTLIM FORTRAN basic functions ... REAL, AIMAG, IABS, CONJG, CMPLX, MOD
241
CEIG2
Function This subroutine computes the eigenvalues and the corresponding eigenvectors of an n-order complex matrix A. The eigenvectors are normalized so that ||x||2=1. n 1. Parameters ZA ... Input. Complex matrix A. ZA is a complex two-dimensional array, ZA (K, N) The contents of ZA are altered on output. K ... Input. Adjustable dimension ( n) of arrays ZA and ZEV. N ... Input. Order n of complex matrix A MODE ... Input. Specifies whether or not balancing is required. When MODE = 1, balancing is omitted. When MODE 1, balancing is included. ZE ... Output. Eingenvalues. Complex two-dimensional array of size n. ZEV ... Output. Eigenvectors. The eigenvectors are stored in the rows corresponding to the eigenvalues. ZEV is a complex two-dimensional array, ZEV (K, N) VW ... Work area. One-dimensional array of size n. IVW ... Work area. One-dimensional array of size n. ICON ... Output. Condition code. See Table CEIG2-1.
Table CEIG2-1 Condition code Code 0 10000 Meaning No error N=1 Processing ZE (1) = ZA (1,1) ZEV (1) = (1.0, 0.0) Discontinued
Notes When the magnitude in each element of a complex matrix varies greatly, the precision of the results can be improved by valancing the matrix with subroutine CBLNC. When the magnitude in each element of a matrix is about the same, balancing will produce minimal improvement. In this state, by specifying MODE = 1, the balancing procedure should be skipped. This subroutine obtains all eigenvalues and eigenvectors of a complex matrix. When only eigenvalues are required, they must be obtained by subroutines CBLNC, CHES2 and CHSQR. When a subset of eigenvectors is required, they must be obtained by subroutines CBLNC, CHES2, CHSQR, CHVEC, CHBK2, CNRML. Example All eigenvalues and eigenvectors of an n-order complex matrix A are determined. n 100.
C **EXAMPLE** COMPLEX ZA(100,100),ZE(100), * ZEV(100,100) DIMENSION IND(100),VW(100),IVW(100) 10 READ(5,500) N IF(N.EQ.0) STOP READ(5,510) ((ZA(I,J),I=1,N),J=1,N) WRITE(6,600) N DO 20 I=1,N 20 WRITE(6,610) (I,J,ZA(I,J),J=1,N) CALL CEIG2(ZA,100,N,0,ZE,ZEV,VW, * IVW,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) GO TO 10 DO 30 I=1,N 30 IND(I)=1 CALL CEPRT(ZE,ZEV,100,N,IND,N) GO TO 10 500 FORRMAT(I3) 510 FORMAT(4E15.7) 600 FORMAT(1H0,5X,15HORIGINAL MATRIX, * 5X,2HN=,I3) 610 FORMAT(/2(5X,2HA(,I3,1H,,I3,2H)=, * 2E15.7)) 620 FORMAT(1H0,5X,5HICON=,I5) END
20000
30000
The eigenvalues and eigenvectors could not be determined since reduction to trangular matrix was not possible. N < 1 or K < N.
In the above example, subroutine CEPRT prints all the eigenvalues and eigenvectors of a complex matrix. The contents are:
SUBROUTINE CEPRT(ZE,ZEV,K,N,IND,M) COMPLEX ZE(M),ZEV(K,M) DIMENSION IND(M) WRITE(6,600) MM=0 DO 20 J=1,M IF(IND(J).EQ.0) GO TO 20 MM=MM+1
Bypassed
Comments on use Subprograms used SSL II ... AMACH, CBLNC, CHES2, CSUM, CNRML, IRADIX, MGSSL FORTRAN basic functions ... ABS, REAL, AIMAG, AMAX1, CSQRT, SIGN, SQRT, CONJG
242
CEIG2
ZE(MM)=ZE(J) DO 10 I=1,N ZEV(I,MM)=ZEV(I,J) 10 CONTINUE 20 CONTINUE IF(MM.EQ.0) GO TO 50 DO 40 INT=1,MM,3 LST=MIN0(INT+2,MM) WRITE(6,610) (J,J=INT,LST) WRITE(6,620) (ZE(J),J=INT,LST) DO 30 I=1,N WRITE(6,630) (ZEV(I,J),J=INT,LST) 30 CONTINUE 40 CONTINUE 50 RETURN 600 FORMAT(1H1,30X,16H** EIGENVECTORS**) 610 FORMAT(1H0,26X,I3,29X,I3,29X,I3) 620 FORMAT(1H0,12H EIGENVALUES, * 3(2X,2E15.7)) 630 FORMAT(12X,3(2X,2E15.7)) END
Q R = Q1Q2
Q
(4.6)
which is the product of transformation matrix Q1, Q2, , QL used in the complex QR method. For details, refer to subroutine CHSQR. The eigenvectors can be obtained as column vectors in matrix X obtained by (4.8) if matrix F which transforms upper triangle matrix R into a diagonal matrix D by a similarity transformation (4.7) is available. D = F 1 RF X = BSQR F (4.7) (4.8)
To verify that column vectors of matrix X given by (4.8) are the eigenvectors of matrix A, substitute (4.1), (4.2) and (4.5) to obtain (4.7). D = F 1Q* S 1 B 1 ABSQR F = X 1 AX R (4.9)
Method This subroutine determines the eigenvalues and the correspondng eigenvectors of an n -order complex matrix A. The eigenvalues of an n-order complex matrix are determined as diagonal elements of upper triangle matrix R by processing the following three steps: An complex matrix A is balanced by the diagonal similar transformation,
~ A = B 1 AB
S
n 2
Q1Q2
Q
(4.10)
As shown in (4.10), Q can be computed by sequentially taking the product of the transformation matrices. F can be determined as a unit upper triangular matrix. From (4.7), FD = RF (4.11)
(4.1)
where B is the diagonal matrix whose element is a scaling factor. For details, refer to subroutine CBLNC. ~ The complex matrix A is reduced by the stabilized elementary transformation into the complex Hessemberg matrix H.
~ H = S AS
1
Let the elements of D, R, and F be represented as D=diag(i ), R=(ij) and F=(fij) respectively, then elements fij can be obtained from (4.11) for j=n, n-1, , 2 as follows f ij = ik f kj
k =i +1 j
i = j 1, j 2,
, 1
(4.12)
(4.2) where,
where S is obtained by the product of transformation matrices S1, S2, , Sn2, S = S1S2
ij = 0(i > j ), ii = i
f ij = 0(i > j ), f ii = 1
S
n 2
(4.3)
, n 2
(u A )
(4.13)
(4.4)
For details, refer to subroutine CHES2. The complex Hessemberg matrix H is reduced by the complex QR method into the complex upper triangle matrix R. R = Q* HQR R Where QR is an unitary matrix given by, (4.5)
(4.14)
where A=(aij). Therefore, norm ||z||1 for complex number z = x + iy is defined by z1= x+ y For details, see References [12] and [13] pp.372 - 395. 243
CELI1
Function This subroutine computes the complete elliptic integral of the first kind K ( x) = 2
0
d 1 x sin2
using an approximation formula for 0 x < 1 . Parameter X ...... Input. Independent variable x CELI ... Output. Function value K(x). ICON ... Output. Condition code. See Table CELI1-1.
Table CELI1-1 Condition code Code 0 30000 Meaning No error X < 0 or X 1 Processing CELI is set to 0.0.
**EXAMPLE** WRITE(6,600) DO 10 K=1,100 A=K-1 X=A/100.0 CALL CELI1(X,CELI,ICON) IF(ICON.EQ.0)WRITE(6,610)X,CELI IF(ICON.NE.0)WRITE(6,620)X,CELI,ICON 10 CONTINUE STOP 600 FORMAT(1H1,28HEXAMPLE OF COMPLETE ELLIPTIC, * 27H INTEGRAL OF THE FIRST KIND/// * 6X,1HX,9X,4HK(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,11H** ERROR **,5X,2HX=,E17.7,5X, * 5HCELI=,E17.7,5X,10HCONDITION=,I10) END
Method For 0 x < l, the complete elliptic integral of the first kind K (x) is calculated using the following approximations. Single precision: K ( x ) = a k t k log(t ) bk t k
4 4 k =0 k =0
(4.1)
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... DLOG Example The following example generates a table of the function values from 0.00 to 1.00 with increment 0.01.
(4.2)
where t = 1 x Theoretical precision = 17.45 digits For further information, see Reference [78] pp.150 ~ 154.
244
CELI2
Function This subroutine computes the complete elliptic integral of the second kind E ( x ) = 2 1 x sin 2 d
0
using an approximation formula for 0 x 1. Parameters X ..... Input. Independent variable x. CELI Output. Function value E(x). ICON Output. Condition code. See Table CELI2-1.
Table CELI2-1 Condition codes Code 0 30000 Meaning No error X < 0 or X > 1 Processing CELI is set to 0.0.
**EXAMPLE** WRITE(6,600) DO 10 K=1,101 A=K-1 X=A/100.0 CALL CELI2(X,CELI,ICON) IF(ICON.EQ.0)WRITE(6,610)X,CELI IF(ICON.NE.0)WRITE(6,620)X,CELI,ICON 10 CONTINUE STOP 600 FORMAT(1H1,28HEXAMPLE OF COMPLETE ELLIPTIC, * 28H INTEGRAL OF THE SECOND KIND/// * 6X,1HX,9X,4HE(X)/) 610 FORMAT(lH ,F8.2,E17.7) 620 FORMAT(1H ,11H** ERROR **,5X,2HX=,E17.7,5X, * 5HCELI=,E17.7,5X,10HCONDITION=,I10) END
Method For 0 x 1, the value of complete elliptic integral of the second kind E(x) is calculated using the following approximations. Single precision: E (x ) = a k t k log(t ) bk t k
4 4 k =0 k =1
(4.1)
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... DLOG Example The following example generates a table of the function values from 0.00 to 1.00 with increment 0.01.
(4.2)
where t = 1 x Theoretical precision = 17.42 digits However, when x =1, E(x) is set to 1. For more information, see Reference [78] pp.150 ~ 154.
245
CFRI
600 FORMAT(1H1,27HEXAMPLE OF FRESNEL INTEGRAL/// * 6X,1HX,9X,4HC(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,11H** ERROR **,5X,2HX=,E17.7, * 5X,2HC=,E17.7,5X,10HCONDITION=,I10) END
x cos
(t ) dt =
t
2 x
cos t 2 dt 2
Method Two different approximation formulas are used depending on the ranges of xdivided at x = 4. For 0 x < 4 The power series expansion of C(x)
by series and asymptotic expansion, where x 0. Parameters X ..... Input. Independent variable x CF .... Output. Value of C(x). ICON.. Output. condition codes. See Table CFRI-1.
Table CFRI-1 Condition codes Code 0 20000 30000 Meaning No error X tmax X<0 Processing CF = 0.5 CF = 0.0
(4.1)
(4.2)
Comments on use Subprograms used SSL II ... MGSSL, UTLIM FORTRAN basic functions ... SIN, COS, and SQRT. Notes Teh valid range of parameter X are: 0 X < tmax This is provided because sin(x) and cos(x) lose their accuracy if X exceeds the above ranges. Example The following example generates a table of C(x) from 0.0 to 100.0 with increment 1.0.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,101 X=K-1 CALL CFRI(X,CF,ICON) IF(ICON.EQ.0)WRITE(6,610)X,CF IF(ICON.NE.0)WRITE(6,620)X,CF,ICON 10 CONTINUE STOP
(4.3)
For x 4 The asymptotic expansion of C(x) C(x ) = 1 + sin( x )P( x ) + cos( x )Q( x ) 2 (4.4)
is calculated through use of the following approximate expression for P(x) and Q(x): Single precision: P(x ) = Q (x ) = 2 x 2 x ak z k ,
10 11
k =0
z=4 x
(4.5) (4.6)
k=0
+ bk z k 1 , z = 4 x
Double precision: P( x ) = Q( x ) = 1 x 1 x a k z k bk z k , z = 4 x
k =0 10 10
k =0 10
(4.7) (4.8)
k =0
ck z k
+1
k=0
dk z k , z = 4 x
11
246
CFT
Function When M -variate (where the dimension of each variable is Nl , N2 ,, NM) complex time series data {xJ1,,JM} is given, this subroutine performs a discrete complex Fourier transform or its inverse transform using the Fast Fourier Transform (FFT) method. Ml , M2 , , NM must be equal to 2l each (where l = 0 or positive integer), and M 1 . Fourier transform When {xJ1,,JM} is input, this subroutine determines {N1 NMK1,,KM} by performing the transform defined in (1.1).
M-dimensional array. (See Notes.) N ..... Input. The dimensions of the M-variate transform are specified as N (1) = N1, N (2) = N2, N(M) = NM. N is a one-dimensional array of size M. M ... Input. Number (M) of variables. ISN ... Input. Specifies normal or inverse transform ( 0). Transform: ISN = +1 Inverse transform: ISN = 1 (See Notes.) ICON .. Output. Condition code. See Table CFT-1.
Table CFT-1 Condition codes Code 0 30000 Meaning No error M < 1, ISN = 0 or either of N1, N2, , or NM is not 2 ( = 0 or positive integer) Processing Aborted
N1 NM K1 ,...,KM =
N 11 J 1=0
x , K1 = 0, 1, , N1 1 , KM = 0, 1, , NM 1
NM 1 JM = 0 J 1,..., JM J 1.K 1 1 JM .KM M
(1.1)
,1 = exp(2i N 1)
, M = exp(2i NM )
Comments on use Subprograms used SSL II ... CFTN, PNR, and MGSSL FORTRAN basic functions ... ATAN, ALOG, SQRT, SIN, and IABS Notes General definition of discrete complex Fourier transform: Multi-variate discrete complex Fourier transform and inverse Fourier transform are generally defined as:
Inverse Fourier transform When {K1,,KM} is input, this subroutine determines {xJ1,,JM} by performing the inverse transform defined in (1 .2) .
x J 1 ,...,JM =
N 11
K 1= 0
NM 1 KM = 0
K 1,..., KM
, J 1 = 0, 1, , N1 1 , JM = 0, 1, , NM 1
J 1.K 1 1 JM KM M
K 1,...,KM =
N 1 NM
NM 1 JM = 0 N 11
x J 1,..., JM
N 11 J 1=0
J 1 K 1 1
x J 1,..., JM = (1.2)
K 1= 0
NM 1 KM =0
K 1,..., KM
J 1K 1 1
(3.1)
JM KM M
JM KM M
(3.2)
,1 = exp(2i N1)
, M = exp(2i NM )
Parameters A ..... Input. Real parts of {xJ1,,JM} or {K1,,KM} . Output. Real parts of {N1 NMK1,,KM} or {xJ1,,JM}. M-dimensional array. (See Notes.) B . Input. Imaginary parts of {xJ1,,JM} or {K1,,KM}. Output. Imaginay parts of {N1 NMK1,,KM} or {xJ1,,JM}.
K1,,KM,J1,,JM,1, ,M are defined in (1.1) and (1.2). This subroutine determines {N1 NMK1,,KM} or {xJ1,,JM} in place of {K1,,JM} of (3.1) or {xJ1,...,JM} of (3.2). Scaling of the resultant values is left to the user. Notice that a normal transform followed by an iverse transform returns the original data multipled by the value N1 NM. Data storage: User must store the real parts of input { xj1,,JM} in Mdimensional array A as shown in Fig. CFT-1, and store the imaginary parts in M-dimensional array B in the same way. On output, this subroutine stores {N1 NMK1,,KM} or {xJ1,,JM} in this manner.
247
CFT
The two-dimensional array A(N1, N2) which contains {xJ1,J2}. x0,0 x1,0 N1 x0,1 x1,1 x0 N2-1
x1 N2-1
xN1-1,0
xN1-1,1 N2
xN1-1, N2-1
In general, when performing M-variate -variate transform, if the data sequence is the same as given in FORTRAN for an M-dimensional array, array, parameters A and B can each be a one-dimensional array. Specifying ISN: ISN is used to specify normal or inverse transform. It is also used as follows: If the real and imaginary parts of {xJ1,,JM} or {K1,,KM} are each stored with an interval I, the ISN parameter is speified as follows: Transform : ISN = +I Inverse transform: ISN = I In this case, the results of transform are also stored in intervals of I. Examples (a) l-variable transform Complex time series data {xJ1} of dimensional Nl is put, and the result {N1K1 is determined using this routine. In case of Nl 1024 (= 210)
C **EXAMPLE** DIMENSION A(1024),B(1024) READ(5,500)N,(A(I),B(I),I=1,N) WRITE(6,600)N,(I,A(I),B(I),I=1,N) CALL CFT(A,B,N,1,1,ICON) WRITE(6,610)ICON IF(ICON.NE.0)STOP WRITE(6,620)(I,A(I),B(I),I=1,N) STOP 500 FORMAT(I5/(2E20.7)) 600 FORMAT(1H0,10X,13HINPUT DATA N=,I5/ * (15X,I5,2E20.7)) 610 FORMAT(1H0,10X,12HRESULT ICON=,I5) 620 FORMAT(15X,I5,2E20.7) END
Method This subroutine performs a multi-variate discrete complex Fourier transform using the radix 8 and 2 Fast Fourier Transform (FFT) method. Multi-variate transform The multi-variate transform defined in (3.1) can be reduced to simpler form by rearranging common terms. For example, the two-variate transform can be reduced to as shown in (4.1).
K1, K 2 =
N 11 J 1= 0
J 2 ,K 2 1 J 1,K1 x J 1, J 2 2 J 2=0
N 21
(4.1)
(4.1) is performed on Nl groups l-variable transforms of dimension N2 with respect to J1. Then based on the results, is performed on N2 groups l-variable
J1
(b) 2-variate transform Complex time series data {xJ1,J2,J3} of dimension Nl, N2 and N3 is put, a Fourier transform is performed, and then by performing an inverse
transforms of dimension N1 with respect to J2. In the same way, a mult-variate discrete complex Fourier transform is achieved by performing 1 variable transforms on complex number groups in each variable.
248
CFT
In this routine, the 8 and 2 radix Fast Fourier Transform is used to perform 1 -variable transforms on each variable. Principles of the Fast-Fourier Transform (FFT) method l-variable discrete complex Fourier transform is defined as
If the right side of (4.4) is re-organized according to j0 and j1 and common terms are rearranged, we obtain
r 1 j k k 0+rk = exp 2i 0 1 j0 = 0 r
j k r1 j k exp 2i 0 2 1 x j0 + r j1 exp 2i 1 0 j r r = 1 0
(4.5)
K = x j jk
j=0
n1
, k = 0, 1,
, n 1
, = exp(2i n)
In (4.2), the scaling factor 1/ n is omitted. If (4.2) is calculated directly, n2k complex multiplications will be required. While, when (4.2) is calculated by the FFT method, if n can be factored into rr, the number of multiplications is reduced to the order of 2 nr by taking account of the characteristics of the exponential function jk. This is illustrated below. Since k and j of (4.2) can be expressed as j = j0 + r j1 ,0 j0 r 1, 0 j1 r 1 k = k0 + r k1 ,0 k0 r 1, 0 k1 r 1 (4.3) when (4.3) is substituted in (4.2), it results
of elementary Fourier transforms of dimension r and j k exp 2i 0 2 0 is the rotation factor for the results of . r j1 Therefore, the number of multiplications involved in the calculation of (4.5) is as shown in (4.6); when n is large, the calculation load decreases. Cn = r (r 2 ) + r (r 2 ) + (r 1)(r 1) = 2nr + (r 1)
2
(4.6)
If r is factored into smaller numbers, the calculation efficiency can be further increased. See the specific example given in the section CFTN. For further information, refer to References [55], [56], and [57].
k 0+rk1 = x j0 +r j1
( j + r j1 )(k0 + r k1 ) exp 2i 0 r2
j0 = 0 j = 0
r 1 r 1
(4.4)
249
CFTM
Function When M-variate (where the dimenstion of each variable is N1, N2, , NM) complex time series data {xJ1,,JM} is given. This subroutine performs a discrete complex Fourier transforms or its inverse transform by using the Fast Fourier Transform (FFT). The dimension of each variable must be 1 or satisfy the following conditions: It must be expressed by a product of prime factors p (p = {4, 3, 5, 7,11,13,17,19,23,2}). (The same prime factor can be duplicated.) The maximum number of prime factors used must be eleven. The product of the square free factors (i.e., the remainder obtained when divided by the square factor) must be less than or equal to 210. Also M 1. Fourier transform By inputting {xJ1,,JM} and performing the transform defined by (1.2), {N1 NMK1,,KM} is obtained. N1 NM K 1,...,KM =
N 11 J 1= 0 NM 1 JM = 0
N ..
M .. ISN ...
ICON ..
See Notes. Input. Imaginary part of {xJ1,,JM} or {K1,,KM} Output. Imaginary part of {N1 NMK1,,KM} or {xJ1,,JM} M-dimensional array. See Notes. Input. Dimensions for the M-variate transform are given such as N(1) = N1, N(2) = N2 , N(M) = NM. One-dimensional array of size M. Input. Number of variate: M Input. Either transform or inverse transform is specified ( 0) as follows: for transform: ISN = +1 for inverse transform: ISN = 1 See Notes. Output. Condition code See Table CFTM-1.
Table CFTM-1 Condition codes Code 0 29100 Meaning No error Either of the the dimension dimensions, N satisfies N1, , NM, N (mod 2) =0 has a prime The dimension factor that is N satisfies no less than N (mod ) = 0 23, and Number of prime factors exceeds 11 Product of square free factors exceeds 210 M 0, ISN = 0 or one of the dimension 0 Processing Bypassed
29200
Comments on use Subprograms used SSL II UCFTM and MGSSL FORTRAN basic functions ATAN, COS, SIN, SQRT, MOD and FLOAT Notes General definition of Fourier transform: The multi-variate discrete complex Fourier transform and its inverse transform are generally defined by (3.1) and (3.2). aK 1,...,KM = x J 1,,JM
Fourier inverse transform By inputting {K1,,KM} and performing the transform defined by (1.3), {xJ1,,JM} is obtained. x J 1,..., JM =
(1.3)
Parameters A .. Input. Real part of {xJ1,,JM} or {K1,,KM} Output. Real part of {N1 NMK1,,KM} or {xJ1,,JM} M-dimensional array.
x N1 NM = a
1
N 11 J 1=0
NM 1 JM =0
J 1,..., JM
J 1 K 1 1
JM KM M
(3.1) (3.2)
N 11
NM 1
K 1= 0
KM = 0
k 1, , KM
J 1K 1 1
JM KM M
250
CFTM
where definitions of K1, , KM, J1, , JM, and 1,,M are given in (1.2) and (1.3). The subroutine obtaines {N1 NMK1,,KM} or {xJ1,,JM} corresponding to the left-hand side of (3.1) and (3.2), respectively, and the user must scale the results, if necessary. If the transform and/ or inverse transform are executed without being scaled by calling the subroutine successively, each element of the input data is output and multiplied by N1 NM. Determination of dimension and processing speed: When determining the dimension in each variable, the conditions given in paragraph "Function" need to be satisfied, but if possible, it is desirable that the prime factors chosen are no larger than 5 (i.e., p 5). In this way, the processing speed is generally faster than the case where the prime factors are greater than 5 (i.e., p > 5). Table CFTM-2 lists all numbers up to 10000 which can be expressed only by using prime factors less than or equal to 5. Further, if the dimension is expressed to the power of 2 (2l, l 0 and also integer), the processing speed is faster if subroutine CFT is used. Table CFTM-2 all numbers up to 10000
2 3 4 5 6 8 9 10 12 15 16 18 20 24 25 27 30 32 36 40 45 48 50 54 60 64 72 75 80 81 90 96 100 108 120 125 128 135 144 150 160 162 180 192 200 216 225 240 243 250 256 270 288 300 320 324 360 375 384 400 405 432 450 480 486 500 512 540 576 600 625 640 648 675 720 729 750 768 800 810 864 900 960 972 1000 1024 1080 1125 1152 1200 1215 1250 1280 1296 1350 1440 1458 1500 1536 1600 1620 1728 1800 1875 1920 1944 2000 2025 2048 2160 2187 2250 2304 2400 2430 2500 2560 2592 2700 2880 2916 3000 3072 3125 3200 3240 3375 3456 3600 3645 3750 3840 3888 4000 4050 4096 4320 4374 4500 4608 4800 4860 5000 5120 5184 5400 5625 5760 5832 6000 6075 6144 6250 6400 6480 6561 6750 6912 7200 7290 7500 7680 7776 8000 8100 8192 8640 8748 9000 9216 9375 9600 9720 10000
The two-dimensional array A(N1, N2) storing {xJ1,J2} x0,0 x1,0 N1 x0,1 x1,1 x0,N2-1 x1, N2-1
xN1-1,0
xN1-1,1 N2
xN1-1, N2-1
In general, when performing M-variate transform, if its data sequence is the same as given in FORTRAN for an M-dimensional array, parameters A and B can be each a one-dimensional array. Giving the parameter ISN: The parameter ISN specifies whether transform or inverse transform is performd, and it can also specify the interval I with which the real and imaginary parts of {xJ1,,JM} or {K1,,KM} are stored in array A and B. Transform: ISN = I Inverse transform: ISN = I The transformed results are also stored with the interval I. Example (a) For a one-variable transform By inputting complex time series data {xj1} of dimension N1 and performing Fourier transform, {N1K1} is obtained. Here N1 1000.
C **EXAMPLE** DIMENSION A(1000),B(1000) READ(5,500)N,(A(I),B(I),I=1,N) WRITE(6,600)N,(I,A(I),B(I),I=1,N) CALL CFTM(A,B,N,1,1,ICON) WRITE(6,610)ICON IF(ICON.NE.0)STOP WRITE(6,620)(I,A(I),B(I),I=1,N) STOP 500 FORMAT(15/(2E20.7)) 600 FORMAT(1H0,10X,13HINPUT DATA N=,I5/ * (15X,I5,2E20.7)) 610 FORMAT(1H0,10X,14HRESULT ICON =,I5) 620 FORMAT(1H0,10X,11HOUTPUT DATA/ * (15X,I5,2E20.7)) END
Data storing method: All the real parts of the input {xJ1,,JM} are stored into the M-dimensional array A as shown in Fig. CFTM-1. The imaginary parts are stored likewise into the Mdimensional array B, as are the input {K1,,KM} and the output {N1 NMK1,,KM} and {xJ1,,JM}
251
CFTM
(b) For three-variate transform By inputting complex time series data {xJ1,J2,J3} of dimensions Nl , N2 and N3 , performing Fourier transform, and by using the results performing Fourier inverse transform, {xJ1,J2,J3} is obtained. Here Nl = 5, N2 = 12 and N3 = 7.
C **EXAMPLE** DIMENSION A(5,12,7),B(5,12,7),N(3) DATA N/5,12,7/ READ(5,500)(((A(I,J,K),B(I,J,K),I=1,N(1)), * J=1,N(2)),K=1,N(3)) WRITE(6,600)N,(((I,J,K,A(I,J,K),B(I,J,K), * I=1,N(1)),J=1,N(2)),K=1,N(3)) C NORMAL TRANSFORM CALL CFTM(A,B,N,3,1,ICON) WRITE(6,610) ICON IF(ICON.NE.0)STOP C INVERSE TRANSFORM CALL CFTM(A,B,N,3,-1,ICON) NT=N(1)*N(2)*N(3) DO 10 K=1,N(3) DO 10 J=1,N(2) DO 10 I=1,N(1) A(I,J,K)=A(I,J,K)/FLOAT(NT) B(I,J,K)=B(I,J,K)/FLOAT(NT) 10 CONTINUE WRITE(6,620)(((I,J,K,A(I,J,K),B(I,J,K), * I=1,N(1)),J=1,N(2)),K=1,N(3)) STOP 500 FORMAT(2E20.7) 600 FORMAT(1H0,10X,10HINPUT DATA,5X, * 1H(,I3,1H,,I3.1H,,I3,1H)/ * (15X,1H(,I3,1H,,I3,1H,,I3,1H), * 2E20.7)) 610 FORMAT(1H0,10X,12HRESULT ICON=,I5) 620 FORMAT(1H0,10X,11HOUTPUT DATA/ * (15X,1H(,I3,1H,,I3,1H,,I3,1H), * 2E20.7)) END
N1 with respect to J2. Similary, the multi-variable discrete complex Fourier transform is achieved by performing a multi-set of onevariable transforms in each variable. The subroutine applies the mixed radix Fast Fourier Transform with the prime factor p to perform one-variable transforms in each variable. Principle of mixed radix Fast Fourier Transform A one-variable discrete complex Fourier transform is defined as
k = x j jk , k = 0,1, , n 1
j =0
n1
, = exp(2i n)
(4.2)
In (4.2), an ordinary scaling factor 1/ n is omitted. When calculating (4.2) directly, the multiplications of complex numbers are required as many as n2. If n is expressed by n = rq with arbitrary factors r and q, and the characteristics of the exponential function -jk are considered, then the number of multiplication is reduced to about n (r + q) . Let k and j in (4.2) be as follows: k = k 0 + k1 q , 0 k 0 q 1 , 0 k1 r 1 (4.3) j = j 0 + j1 r , 0 j 0 r 1 , 0 j1 q 1 Substituting (4.3) into (4.2),
k 0+k 1q = x j0 + j1r
(k + k q)( j0 + j1 r ) exp 2j 0 1 r q
j0 =0 j1=0
r 1 q1
Method The multi-variate discrete complex Fourier transform is performed by using the mixed radix Fast Fourier Transform (FFT) with the prime factor p (2 p 23). Multi-variate transform The multi-variate transform defined in (1.2) can be reduced by rearranging common terms. For example, the two-variate transform can be reduced to as shown in (4.1)
J 1K 1 N1 N 2 K 1,K 2 = 1 x J 1J 2 2 J 2 K 2 J 1=0 J 2= 0 N 11 N 21
(4.4)
Rearranging the right side of (4.4) with respect to j0 and j1 and putting the common terms together, (4.5) is obtained
r 1 kj k j k0 + k1q = exp 2i 1 0 exp 2i 0 0 j0 =0 r r q1 k j exp 2i 0 1 x j0 + j1r j1=0 q
(4.5)
(4.1)
dimension r with respect to j1. The exp{2ik0j0/r} is a rotation factor for the result of Therefore, the
j1
number of multiplications, Cn, done in (4.5) can be given in (4.6), and for a large n , it is smaller than n2 which is the computation amount needed when (4.2) is calculated directly.
252
CFTM
Cn = r q 2 + q r 2 + (q 1)(r 1) = n(r + q + 1) (r + q) + 1
(4.6)
prime factors, the computation efficiency will be increased. The subroutine uses the mixed radix Fast Fourier Transform with prime factors of up to 23. For further details, refer to Reference [57].
This type of transform is called a radix r and q Fast Fourier Transform. If r and q can be factored further to
253
CFTR
ICON ..
Inverse transform: ISN = 1 (Refer to "Notes".) Output. Condition code. See Table CFTN-1.
Table CFTN-1 Condition code Code 0 30000 Meaning No error ISN = 0, NS < 1, NT < N, NT < NS, or N 2 ( = 0 or positive integer) Processing Bypassed
Function When one-variable complex time series data {xj} of dimension n is given. this subroutine performs discrete complex Fourier transforms or inverse transforms using the Fast Fourier Transform (FFT) method. The value n must be equal to 21(l = 0 or positive integer) . Fourier transform ~k } When {xi } is input, this subroutine determines {n by performing the transform defined in (1.1). ~ = x jk n j k
j =0 n 1
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... ATAN, ALOG, SQRT and SIN Notes General definition of discrete complex Fourier transform: Discrete complex Fourier transform and inverse Fourier transform are generally defined as: ak = and x j = ak jk
k =0 n1
, k = 0,1, , n 1,
= exp(2 i n)
(1.1)
Inverse Fourier transform When {k} is input, this subroutine determines { ~ xk } by performing the inverse transform defined in (1.2). ~ x j = a k jk
k =0 n1
1 n1 x j jk n j =0
, k = 0,1,
, n 1
(3.1)
, j = 0,1,
, n 1,
(
= exp 2i n
(1.2)
~k } and { ~ x j } indicate that the transformed data is { not in ascending order, since transform is performed in the area that the data was input. Let the results {k} and {xj} of the Fourier transform or inverse Fourier transform defined in (3.1) and (3.2) be ordered in ~k } , { ~ x j } are in reverse binary ascending order, { order. Parameters A .. Input. Real parts of {xj} or {k}. ~ or ~ Output. Real parts of {n {x j } . k} B.. One-dimensional array of size NT. Input. Imaginary part of {xj} or {k}. ~ or ~ Output. Imaginary parts of {n {x j } . k} One-dimensional array of size NT. Input. The total number of data, including {xj} or {j}, to be transformed ( N, NS) . Normally, NT = N is specified. (See "Notes".) Input. Dimension n. Input. The interval of the consecutive data or to be transformed of dimension n in the NT data ( 1 and NT) . Normally, NS = 1 is specified. (See "Notes".) Input. Specifies normal or inverse transform ( 0). Transform : ISN = +1
, j = 0,1,
, n 1
(3.2)
where
= exp(2 i n)
~ or ~ This subroutine determines {n { x j } in place of k} ~ x j } indicate {k} of (3.1) or {xj} of (3.2). { k } and { ~ that the transformed data is not in normal ascending order, since transform is performed in the area that data ~ is in reverse binary order and was input. That is, {n k} its elements are multiplied by the value n compared to{k}. x k } is also in reverse binary order compared to {xk}. {~ Scaling and permutation of the result data are left to the user. Data can be permuted using subroutine PNR. Refer to Example (a). Use of this subroutine: Usually, when performing a Fourier transform or an inverse Fourier transform, the subroutine CFT may be used. When normal and inverse transforms are performed successively, using this subroutine and subroutine CFTR together will increase efficiency. That ~ is obtained by this routine. After a is, at first {n k} ~ can certain process is carried out, then processed n
NT....
N .. NS
ISN ...
{ }
k
254
CFTN
without permutation. So, by the deletion of permutation, the processing speed can be reduced. In subroutine CFTR. the Fourier transform and inverse Fourier transform defined in (3.3) or (3.4) are performed. ~ jk n k = x j
j =0 n1
a) User must store {xj1,j2,j3} in the two-dimensional array A and B as shown in Fig. CFTN-1.
The two-dimensional array A(N1, N2) which contains {xJ1,J2} x0,0 x0,1 x1,1 x0,N2-1 x1, N2-1
~ jk x j = k
k =0
n 1
, n 1 , j = 0,1,, n 1
, k = 0,1,
(3.3) (3.4)
N1
x1,0
Refer to Example (b). Multi-variate transform: With this subroutine, multi-variable transforms are possible. For the 2-variate transform, the Fourier transform and inverse Fourier transform are defined as:
xN1-1,0
xN1-1,1 N2
xN1-1, N2-1
K 1, K 2 =
N 21 J 2=0
1 N 11 N 1 N 2 J 1=0
J 1 K 1 J 2 K 2 x J 1,J 2 1 2
, K1 = 0, , N1 1, K 2 = 0, , N 2 1 and x J 1,J 2 =
N 21 K 2=0 N 11
(3.5)
K 1= 0
K 1,K 2
(
J 2K 2 2
(3,6)
K 1, K 2 =
N 11 N 2 1 1 1 J 1K 1 x J 1, J 2 2 J 2K 2 = J 1 0 J 2=0 N 1 N 2
(3.7)
The multi-variate transform of (3.7) is achieved by first performing on Nl group 1-variable transforms of
J2
variable transforms, scaling and permutation of the data should be performed yhen necessary. Data permutation can be done with subroutin PNR. The inverse transform defined in (3.6) can be processed similarly. Processing is possible for more than two variates. Refer to example (c) for threevariate applications. Specifying ISN: ISN is used to specify normal or inverse transform. It is also used as follows: If the real parts and imaginary parts of NT data are each stored in areas of size NTI in intervals of I, the following specification is made. Transform : ISN = +I Inverse transform : ISN = I In this case, the results of transform are also store, in intervals of I. Examples (a) 1-variable transform Complex time series data {xj} of dimension n is put, and a Fourier transform is performed. The results are permuted using subroutine PNR and {nk} obtained. In case of n1024 (=210).
performed with the results on N2 groups l-variable transforms of dimension Nl with respect to J2. With calling this subroutine once, on N1 groups 1-variable
J2
transforms of dimension N2 is performed. And with another calling, on N2 groups l-variable transforms
J1
255
CFTR
**EXAMPLE** DIMENSION A(1024),B(l024) READ(5,500)N,(A(I),B(I),I=1,N) WRITE(6,600)N,(I,A(I),B(I),I=1,N) CALL CFTN(A,B,N,N,1,1,ICON) WRITE(6,610)ICON IF(ICON .NE. 0)STOP CALL PNR(A,B,N,N,1,1,ICON) WRITE(6,610)ICON IF(ICON .NE. 0)STOP WRITE(6,620)(I,A(I),B(I),I=1,N) STOP 500 FORMAT(I5 /(2E20.7)) 600 FORMAT(lH0,10X,13HINPUT DATA N=,I5/ * /(15X,I5,2E20.7)) 610 FORMAT(lH0,10X,12HRESULT ICON=,I5) 620 FORMAT(15X,I5,2E20.7) END
In case of NlN2N3 1024 (= 210). The data can be stored in a one-dimensional array as shown in Fig. CFTN-2.
One-dimensional array A (NT) which contains { x J 1, J 2, J 3 } x 0,0,0 x 1,0,0 x 2,0,0
x N 1-1,1,0 x 0,2,0 x N 1-1, N 2-1,0 x 0,0,1 x 1,0,1 x 2,0,1 x N 1-1, N 2-1, N 3-1
(= N 1 N 2 N 3)
NT
(b) Successive transform/inverse transform Complex time series data {xj} of dimension n is put, and this routine performs a Fourier transform to ~ . Processing is done without obtain {n k} permutation of the data, then the subroutine CFTR performs an inverse Fourier transform on the results. In case of n l024 (= 210) .
C **EXAMPLE** DIMENSION A(1024),B(1024) READ(5,500)N,(A(I),B(I),I=1,N) WRITE(6,600)N,(I,A(I),B(I),I=1,N) NORMAL TRANSFORM CALL CFTN(A,B,N,N,1,1,ICON) IF(ICON .NE. 0)STOP
Note: When stored in this way, NS can be specified in the order of the three ca1ls --- 1. N1, N1*N2. Fig. CFTN-2 Storage of {xJ1,J2,J3}
INVERSE TRANSFORM CALL CFTR(A,B,N,N,1,-1,ICON) IF(ICON .NE. 0)STOP DO 10 I=1,N A(I)= A(I)/FLOAT(N) B(I)=B(I)/FLOAT(N) 10 CONTINUE WRITE(6,610)(I,A(I),B(I),I=1,N) STOP 500 FORMAT(I5/(2E20.7)) 600 FORMAT(lH0,10X,13HINPUT DATA N=,I5/ * /(15X,I5,2E20.7)) 610 FORMAT(1H0,l0X,11HOUTPUT DATA/ * /(15X,I5 ,2E20.7)) END
**EXAMPLE** DIMENSION A(l024),B(l024),N(3) READ(5,500)N NT=N(1)*N(2)*N(3) READ(5,510)(A(I),B(I),I=1,NT) WRITE(6,600)N,(I,A(I),B(I),I=1,NT) C NORMAL TRANSFORM NS=1 DO 10 I=1,3 CALL CFTN(A,B,NT, N(I),NS,l,ICON) IF(ICON .NE. 0 )STOP NS=NS *N(I) 10 CONTINUE
(c) 3-variate transform Complex time series data {xj1,j2,j3} of dimension Nl , N2 and N3 is put, and this subroutine performs a ~ Fourier transform to obtain {N 1. N 2. N 3 K1K 2 K 3} . Processing is done without permulation of the data, then subroutine CFTR performs a Fourier inverse transform on the results.
INVERSE TRANSFORM NS=1 DO 20 I=1,3 CALL CFTR(A,B,NT,N(I),NS,-1,ICON) IF(ICON.NE. 0)STOP NS=NS*N(I) 20 CONTINUE C NORMALIZATION DO 30 I=1,NT A(I)=A(I)/FLOAT(NT) B(I)=B(I)/FLOAT(NT) 30 CONTINUE WRITE(6,610)(I,A(I),B(I),I=1,NT) STOP 500 FORMAT(3I5) 510 FORMAT(2E20.7) 600 FORMAT(lH0,l0X,13HINPUT DATA N=,3I5/ * /(15X,I5,2E20.7)) 610 FORMAT(lH0,10X,11HOUTPUT DATA/ * /(15X,I5,2E20.7)) END
256
CFTN
Method This subroutine performs discrete complex Fourier transforms using the radix 8 and 2 Fast Fourier Transform (FFT) method, or performs the inverse transforms. Refer to the section on subroutine CFT for the principles of FFT. In this section, a specific example in which n = 16 will be discussed. In this case, the Fourier transform is defined as
(4.4) is executed. The elementary Fourier transform of dimension 8 corresponding to are performed initially
j1
k = x j jk
j =0
15
, k = 0,1, 15,
with respect to j0=0 , that is, the data x0 x2 x4 x6 x8 x10 xl2, and xl4 are transformed. Then the transform of dimension 8 is performed with respect to j0=1, that is the data xl x3 x5 x7 x9 x11 xl3, and xl5 are transformed. The results are multiplied by the rotation factor j0 k 0 exp 2i 16 This multiplication is not necessary for j0=0 because the rotation factor is 1 when j0=0. When j0=1 , with the exception of k0=0, the following rotation factors are multiplied together in order , 123456, and 7 , =exp(2i/16). The above results are stored in x(j0+k0.2) . Process 2: x(k1 + k 0 2 )
1 jk exp 2 i 0 1 x ( j0 + k0 2) j0 =0 2
= exp(2 i 16)
(4.1)
The scaling factor l/16 is omitted in (4.1). In this routine, n is factored into factors 8 and 2 (n =8 2). k and j can be expressed as k = k 0 + k1 8 ,0 k 0 7, 0 k1 1 j = j0 + j1 2 ,0 j0 1, 0 j1 7 (4.2)
If (4.2) is substituted in (4.1) and common terms are rearranged, (4.3) results. Where, ( k0 + k1 8) ak0 + k18
1 jk ( k0 + k1 8) = exp 2 i 0 1 j =0 2
0
(4.5)
j k 7 jk exp 2 i 0 0 exp 2 i 1 0 = 16 j1 0 8 x ( j0 + j1 2)
(4.3)
is executed. With the results of process 1 , the Fourier transform of dimension 2 corresponding to is
j0
In this routine, (4.3) is successively calculated. The results are stored in the same area that data was input. The procedure follows, see Fig. CFTN-3. Process l: x j 0 + k 0 2 jk 7 jk exp 2 i 0 0 exp 2 i 1 0 16 j1 =0 8 x ( j0 + j1 2)
performed with respect to k0=0, that is data x0 and xl are transformed. Similarly, with respect to k0=1,...,7 , the Fourier transform of dimension 2 is performed for each. It is not necessary to multiply these results by the rotation factor.The above results are stored in x(k1+k02). Since the x(k1+k02) obtained in this way is in reverse digit order compared to the (k0+k18) to be obtained as the discrete complex Fourier transform of dimension 16, ~ k + k 2 . In this routine, since the it is expressed as (1 0 ) results of elementary Fourier transform of dimension 8 ~ k + k 2 are in reverse binary order, the final result (1 0 )
(4.4)
is also in reverse binary order compared to (k0 + k1 8) . For further information, see References [55], [56], and [57].
257
CFTR
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
7
Fourier transform of dimension 8 j0 = 1,
j 1
0 8
Fourier transform of dimension 8 j0 = 0,
j 1
*1 j1 = 0,
j 0
0 8 4 12 2 10 6 14 1 9 5 13 3 11 7 15
4
4
12 2
*1 j1 = 1,
j 0
10 6
*1 j1 = 2 ,
j 0
14 1
*1 j1 = 3,
j 0
9 5
*1 j1 = 4,
j 0
13 3
*1 j1 = 5,
j 0
11 7 15
*1 j1 = 6,
j 0
*1 j1 = 7,
j 0
Note: The circled numbers represent the order of the data. =exp(2i/16). Since the results of Fourier transforms of dimension 8 are in ~ ( k 1 + k 0 2) is in reverse binary order reverse binary order,
Fig. CFTN-3 Flow chart of a complex Fourier transform of dimension 16 (reverse binary order output)
258
CFTR
Table CFTR-1 Conditions codes Code 0 30000 Meaning No error ISN 0. NS < 1, NT < N, NT = NS, or N2 ( = 0 or positive integer) Processing By pessed
Function When the one-variable complex time series data {xj} of x j} , dimension n is given in reverse binary order as { ~ the discrete complex Fourier transform or its inverse transform is performed by using the Fast Fourier Transform (FFT). Here n = 2 ( = 0 or positive integer). Fourier transform x j } is input and the transform defined by (1.1) is {~ carried out to obtain {nk} . n k = ~ x j jk , k = 0,1, , n 1
j =0 n1
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... ATAN, ALOG, SQRT and SIN Notes General definition of Fourier transform: The discrete complex Fourier transform and its inverse transform are generally defined as given in (3.1) and (3.2).
, = exp(2 i n)
(1.1)
k =
1 n 1 x j jk , k = 0,1, , n 1 n j =0
n 1 k =0
Fourier inverse transform ~k } is input and the transform defined by (1.2) is { carried out to obtain {xj}. ~ jk , j = 0,1, , n 1, x j = k
k =0 n 1
x j = k jk ,
j = 0,1, , n 1
(3.1) (3.2)
= exp(2 i n)
= exp(2 i n)
(1.2)
~ x j } or { The subroutine performs transform for { ~ k} ~ whose sequence is reverse binary order. The { x j } and {nk} correspond to {xj} and {nk} in the right-hand side of (3.1) and (3.2), respectively. The transformed results, {nk} or {xj}, are obtained each corresponding to {nk} and {xj} in the left-hand side of (3.1) and (3.2), respectively. That is, the obtained result sequence is normal order and the elements of {nk} are given multiplied by n . The normalization of the results must be carried out by the user, if necessary. Use of the subroutine: For Fourier transform or inverse Fourier transform, the subroutine CFT is normally used, but if the transform and inverse transform are to be executed one after another, the subroutine CFTN and CFTR described in this section should be used for better efficiency. Refer to "Comments on use" of subroutine CFTN. Application of multi-variate transform: This subroutine, CFTR, can be applied to a multi-variate transform. For exarnple, a two-variate Fourier transform and its inverse transform are defined as follows:
The sequence of the transformed {nk} and {xj} are given in the normal sequence. Parameters ~ . x j } or { A ..... Input. Real part of { ~ k} Output. Real part of {nk} or {xj}. One-dimensional array of size NT x j } or {n k } . B ..... Input. Imaginary part of { ~ Output. Imaginary part of {nk} or {xj} . One-dimensional array of size NT. x j } or NT ... Input. Total number of data in which { ~ ~ to be transformed are contained. (NT { k } N and NS) Normally, NT = N. See "Notes". Input. Dimension: n x j} Input. Interval of the consecutive data { ~ or {nk} to be transformed of dimension n in the NT data. (NS 1 and NT) Normally, NS = 1. See "Notes". Input. Either transform or inverse transform is specified ( 0) as follows: for transform: ISN = +l for inverse transform: ISN = l See "Notes". Output. Condition code See Table CFTR-1 .
N .. NS ..
ISN ..
K 1, K 2 =
(3.5)
ICON ..
259
CFTR
N 11 N 21
, J 1 = 0,1, , N1 1, J 2 = 0,1,
, N 2 1
)
~J J } {x
1, 2
(3.6)
~ x 0, 0 ~ x1,0 N1 ~ x0,1 ~ x1,1 ~ x0, N 2 1 ~ x1, N 21
K 1,K 2 =
1 N 11 J 1K 1 N 21 J 2 K 2 1 x J 1, J 2 2 J 2= 0 N1 N 2 J 1=0
(3.7)
~ x N 11,1
~ x N 11,1 N2
~ x N 11,N 21
The two-variate transform (3.7) above is achieved such that Nl sets of one-variable transforms of dimension N2 are performed with respect to J1, and for that result. N2 sets of one-variable transforms of dimension N1 performed with respect to J2 . The subroutine is capable of performing N1 sets of onevariable transforms of dimesnsion N2 simultaneously once it is called. In this way computational load is reduced compared to the case where the one-variable transforms of dimension N2 are calculated one by one, so that a multi-variate transform can be accomplished efficiently. In practice, specify as shown below and then call the subroutine. x J 1, J 2 } are stored in the two-dimensional array A a) { ~ and B as illustrated in Fig. CFTR-1. b) the subroutine is called twice as follows:
Note:
x . The imaginary parts are stored Array A contains the real parts of ~
likewise in the two-dimensional array B (N1, N2). Fig. CFTR-1 Storing method
{}
Example (a) One-variable transform The complex time series data {xj} of dimension n are input, and permuted by subroutine PNR in reverse binary order. x j } is subjected to Fourier transform The result { ~ by the subroutine to obtain {nk} . Here n 1024 (= 210).
C **EXAMPLE** DIMENSION A(1024),B(1024 ) READ(5,500) N,(A(I),B(I),I=1 ,N) WRITE(6,600) N,(I,A(I),B(I),I=1 ,N) CALL PNR(A,B,N,N,1,1,ICON) WRITE(6,610)ICON IF(ICON.NE.0)STOP CALL CFTR(A,B,N,N,1,1,ICON) WRITE(6,620) (I,A(I),B(I),I=1 ,N) STOP 500 FORMAT(I5/(2E20.7)) 60 FORMAT(lH0,10X,13HINPUT DATA N=,I5/ * /(15X,I5 ,2E20.7)) 610 FORMAT(1H0,10X,12HRESULT ICON=,I5) 620 FORMAT(lH0,10X,11HOUTPUT DATA// * (15X,I5 ,2E20.7)) END
The obtained result is {N1 N 2 K 1,K 2 } , so normalization must be done by the user, if necessary, in the same way as for a one-variable transform. The inverse transform defined in (3.6) can be similarly performed. Transforms with more than two variate are also possible and example (b) shows a case of three variates. Giving ISN: The parameter ISN specifies whether transform or inverse transform is performed. and can be also used for the following case. That is, when the real and imaginay ~k } are stored in the x j } or { parts of NT number of { ~ area of size NTI with an interval I between each other, the ISN is specified as follows: for transform: ISN = +I for inverse transform: ISN = I The transformed results are stored also with an interval I.
(b) Three-variate transform The three-variate complex time series data {xJ1,J2,J3} of dimension N1, N2 and N3 are input and permuted by subroutine PNR in reverse binary order. x J 1, J 2 , J 3 } are subjected to Fourier The results { ~ transform by the subroutine to obtain {N1N2K1,K2}. The data {xJ1,J2,J3} may be stored in a onedimensional array as illustrated in Fig.CFTR-2.
260
CFTR
~ x 0, 0, 0 ~ x
1, 0, 0
where the scaling factor 1/16 is omitted. The subroutine factors n by using 2 and 8 (n = 2 8). k and j are expressed as follows:
~ x N 11,1,0 ~ x
0, 2 , 0
~ x 2,0 ,0
k = k 0 2 + k1 , 0 k 0 7, 0 k 1 1 j = j0 8 + j1 , 0 j0 1, 0 j1 7 Substituting (4.2) into (4.1) and rearranging the common terms, (4.3) is obtained.
7 jk (k0 2 + k1 ) = exp 2 j 1 0 j =0 8 jk exp 2 i 1 1 16 1 j0 k1 exp 2 i x( j0 8 + j1 ) j =0 2
0 0
(4.2)
(= N 1 N 2 N 3)
NT
~ x N 11,0,0 ~ x
0,1, 0
~ x N 11, N 21,0 ~ x
0, 0,1
~ x1,1,0 ~ x
2 ,1, 0
~ x1,0,1 ~ x
2 , 0,1
*
Note
~ x N 11, N 21, N 31
(4.3)
x . The imaginary parts are contained Array A contains the real part of ~
likewise in the one-dimensional array B (NT). Parameter NS, when contained in this way, is given 1, N1 and N1N2 for each of the three times the subroutine is called. Fig. CFTR-2 Storage of
{}
where (k 0 2 + k1 ) k02+ k1 The subroutine is given its input data in reverse binary order, i.e., ~ x j + j 2 is given instead of x( j 8+j ),
{~ x
J 1, J 2 , J 3
**EXAMPLE** DIMENSION A(1024),B(1024),N(3) READ(5,500) N NT=N(1)*N(2)*N(3) READ(5,510)(A(I),B(I),I=1,NT) WRITE(6,600)N,(1,A(I),B(I),I=1,NT) NS=1 DO 10 I=1,3 CALL PNR(A,B,NT,N(I),NS,1,ICON) WRITE(6,610) ICON IF(ICON.NE.0)STOP CALL CFTR(A,B,NT,N(I),NS,1,ICON) NS=NS*N(I) 10 CONTINUE WRITE(6,620) (I,A(I),B(I),I=1,NT) STOP 500 FORMAT(3I5) 510 FORMAT(2E20.7) 600 FORMAT(1H0,10X,13HINPUT DATA N=,3I5/ * /(15X,I5 ,2E20.7)) 610 FORMAT(1H0,10X,12HRESULT ICON=,I5) 620 FORMAT(lH0,10X,11HOUTPUT DATA// * (15X,I5 ,2E20.7)) END
then Eq. (4.3) is calculated successively. The results are stored in the same area. The procedure is explained below, in conjunction with Fig. CFTR-3. Step l: ~ x ( k1 + j1 2)
1 jk x ( j0 + j1 2) exp 2 i 0 1 ~ j0 =0 2
(4.4)
First of all, Fourier transforms of dimension 2 are with respect to j0=0, that is, transform performed by j0 ~ and ~ x . Similarly, the Fourier transforms is done for x
0 1
of dimension 2 are performed with respect to j0=1 to 7 and the results are stored in ~ x k1 + j1 2 .
Step 2: ~ x ( k1 + k 0 2)
7 jk jk exp 2i 1 0 exp 2i 1 1 j1=0 8 16 ~ x k1 + j1 2
Method The discrete complex Fourier transform is performed by using the radix 8 and 2 Fast Fourier Transform (FFT) . The input data is to be given in reverse binary order. For the principle of the Fast Fourier Transform, refer to the section of subroutine CFT. In this section, the transform is explaind for n = 16. 15 k = x j jk , k = 0,1, ,15, j =0 (4.1) = exp(2 i 16)
(4.5)
The results obtained at step 1 are multiplied by the jk rotation factors, exp 2i 1 1 and Fourier transforms 16 of dimension 8 are performed by with respect to k0=0
j1
261
CFTR
multiplication is necessary, and the transform is done for ~ ,x ~ ,x ~ ,~ ~ ~ ~ ~ x 0 2 4 x 6 , x 8 , x10 , x12 , and x14 when k1=1 the ~ ,x ~ ,x ~ ,x ~ ,x ~ ,~ ~ ~ transform is done after x 1 3 5 7 9 x 11 , x13 , x15 are multiplied by the rotation factor. The rotation factors are 0 , 1 , 2 , 3 , 4 , 5 , 6 and 7 , where = exp( 2i / 16) . Since each of the input data sequence for these two sets of Fourier transforms of dimension 8 is in reverse binary order, each of the
transformed results is permuted in the normal order and stored in ~ x ( k + k 2) . ~ The obtained ~ x (k1 + k 0 2) agrees with (k1 + k0 2) which is the result of the "discrete complex Fourier transform of dimension 16". For further information, see References [55], [56], and [57].
1 0
~ x j 0 + j1 2
Step 1 *1 j1 = 0 ,
j0
~ x k 1 + j1 2
Step 2
k 0 2 + k1
0 8 4 12 2 10 6 14 1 9 5 13 3 11 7 15
0 8 4 12 2 10 6 14 1 9 5 13 3 11 7 15
7 5 1
Fourier transform of dimension 8 k1 = 1 ,
j1
0
Fourier transform of dimension 8
1 2 3 4
*1 j1 = 1 ,
j0
k1 = 0 ,
j1
*1 j1 = 2 ,
j0
5 6
*1 j1 = 3 ,
j0
7 8 9 10 11 12
*1 j1 = 4 ,
j0
*1 j1 = 5 ,
j0
*1 j1 = 6 ,
j0
13 14 15
*1 j1 = 7 ,
j0
Note: Numbers inside O marks indicate the data sequence, and = exp{2i / 16} . *1: Complex Fourier transform of dimension 2
Fig. CFTR-3 Flow chart of a complex Fourier transform of dimension 16 (reverse binary order input)
262
CGSBM
Functions This subroutine converts an n n real symmetric band matrix with band width h stored in the general mode into one stored in the compressed mode for symmetric band matrix, where n > h 0. Parameters AG .... Input. The symmetric band matrix stored in the general mode. Two-dimensional array, AG (K, N). (See "Comments on Use.") K .... Input. The adjustable dimension ( N) of array AG. N ..... Input. The order (n) of the matrix. ASB ... Output. The Symmetric band matrix stored in the compressed mode. One-dimensional array of size n(h+1) h(h+1)/2. NH ..... Input. Band width h of the matrix. ICON .. Output. Condition code. (See Table CGSBM-1.)
Table CGSBM-1 Condition codes Code 0 30000 Meaning No error. NH < 0, N NH, or K<N Processing By passed
Given an n n positive-definite symmetric band matrix with band width h in the general mode, this example converts it into one stored in the compressed mode for symmetric band matrix, then performs decomposition. Subroutine SBDL is used for the decomposition, whereas this subroutine and subroutine CSBGM are used to convert the mode, where n 100 and h 20.
C **EXAMPLE** DIMENSION AG(100,100),ASB(1890) EQUIVALENCE(AG(l,1),ASB(1)) 10 READ(5,500)N,NH IF(N.EQ.0)STOP K=100 READ(5,510)((AG(I,J),I=1,N),J=1,N) WRITE(6,600)N,NH,((I,J,AG(I,J),I=1,N),J=1,N) CALL CGSBM(AG,K,N,ASB,NH,ICON) WRITE(6,610)ICON IF(ICON.EQ.30000)GO TO 10 EPSZ=0.0 CALL SBDL(ASB,N,NH,EPSZ,ICON) WRITE(6,620)ICON IF(ICON.GE.20000)GO TO l0 CALL CSBGM(ASB,N,NH,AG,K,ICON) WRITE(6,630)N,NH,((I,J,AG(I,J),J=l,N),I=l,N) GO TO l0 500 FORMAT(2I5) 510 FORMAT(4E15.7) 600 FORMAT(//10X,18H ** INPUT MATRIX **/ * 10X,6HORDER=,I5,5X,l0HBANDWIDTH=,I5/ * (2X,4(1H(,I3,1H,I3,1H),E17.8))) 610 FORMAT(1H1/l0X,11HCGSBM ICON=,I5) 620 FORMAT(/l0X,l0HSBDL ICON=,I5) 630 FORMAT(lHl//l0X,17HDECOMPOSED MATRIX/ * l0X,6HORDER=,I5,5X,l0HBANDWIDTH=,I5/ * (2X,4(1H(,I3,1H,,I3,1H ),E17.8))) END
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... MAX0 Notes Storing method of the symmetric band matrix in the general mode: Only the elements of the lower band and the diagonal portions can be stored in array AG. The elements of the lower band portion are copied into those of the upper band portion in this subroutine. Saving the storage area: If the contents of array AG need not be retained, the storage area can be saved using an EQUIVALENCE statement as follows: EQUIVALENCE (AG (1,1), ASB (1)) (See "Example" for details.) Example
Method A real symmetric band matrix stored in a twodimensional array AG in the general mode is processed as follows to be a symmetric band matrix in a onedimensional array in the compressed mode. The elements of the lower band portion are moved to the upper band portion using the diagonal as the axis of symmetry. AG(I,J)AG(J,I), I h J I 1 The elements of the diagonal and upper band AG (I,J) are moved to the ASB, beginning from column 1 of AG, as follows:
Elements in the general mode Matrix Elements Elements in the compressed mode
AG (1, J) aij ASB (J (J1)/2+I) , I = 1, 2, , J , J = l, 2, , h+1 AG (1, J) aij ASB (hJ h (h+1)/2+I) , I = Jh, Jh+1, , J , J = h+2, h+3, ,N
263
CGSM
Functions This subroutine converts an n n real symmetric matrix stored in the general mode into a symmetric matrix stored in the compressed mode. n 1. Parameters AG .. Input. The symmetric matrix stored in the general mode. AG is a two-dimensional array, AG (K, N). (See "Comments on use".) K .. Input. The adjustable dimension ( N) of array AG. N ... Input. The order n of the matrix. AS ... Output. The symmetric matrix stored in the compressed mode. AS is a one-dimensional array of size n (n +1)/2. ICON ... Output. Condition codes. Refer to Table CGSM-1.
Table CGSM-1 Condition code Code 0 30000 Meaning No error N < 1 or K < N Processing By passed
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... None Notes Storage method of the symmetric matrix in the general mode: Only the elements of the diagonal and lower triangular portions need be given to array AG. The subroutine copies the lower triangular portion to the upper triangular portion. If there is no need to keep the contents on the array AG, more atorage can be saved by using the EQUIVALENCE statement as follow; EQUIVALENCE (AG(1,1), AS(1)) Refer to the example shown below. Example Given an n n positive-definite symmetric matrix in the general mode, the inverse matrix is obtained by subroutines SLDL and LDIV as shown in the example. In this case, the required mode conversion is
Methods This subroutine converts an n n real symmetric matrix stored in a two-dimensional array AG in the general mode to in a one-dimensional array in the compressed mode through the following procedures. With the diagonal as the axis of symmetry, the elements of the lower triangular portion are transferred to the upper triangular portion. AG(I,J) AG(J,I), J<I The diagonal and upper triangular elements AG (I,J) is transferred to the J (J-1)/2 + I position in AS. Here, J I. Transfer begins with the first column of AG and continues column by column. The correspondence between locations is shown below, where NT = n (n + 1)/2 .
264
CGSM
Elements in the compressed mode AS (1) AS (2) AS (3) AS (J (J 1)/2+I) AS (NT 1) AS (NT)
AG (I, J)
aji
AG (N-1, N) AG (N, N)
ann1 ann
265
CHBK2
Table CHBK2-1 Condition Code Code 0 10000 30000 Meaning No error N=1 N <M,M < 1 or K < N Processing ZEV(1,1)=(1.0,0.0) By passed
Function This subroutine back-transforms m eigenvectors of an n order Hessenberg matrix H to eigenvectors of a complex matrix A. H is assumed to be obtained from A using the stabilized elementary similarity transformation method. No eigenvectors of complex A are normalized. n 1. Parameters ZEV ... Input. m eigenvectors of complex Hessenberg matrix H. Output. ml eigenvectors of complex matrix A. The ml indicates the number of IND elements whose value is 1. ZEV is a two-dimensional array, ZEV (K,M) K .. Input. Adjustable dimension of arrays ZEV and ZP. ( n). N .. Input. Order n of complex matrices A and H. IND ... Input. IND (J) = 1 implies that the eigenvector corresponding to the j-th eigenvalue of ZEV is to be back-transformed. IND (J) = 0 implies that the eigenvector corresponding to the j-th eigenvalue of ZEV is not to be back-transformed. IND is onedimensional array of size M . See "Comments on use" M ... Input. Total number of eigenvalues corresponding to eigenvectors of complex Hessenberg matrix H. ZP ... Input. Information necessary for a transformation matrix (A to H). ZP (K,N) is a twodimensional complex array. See "Comments on use". IP ... Input. Information necessary for a transformation matrix (A to H) . IP is a onedimensional array of size n. See "Comments on use". DV ... Input. Scaling factor applied to balance complex matrix A. DV is a one-dimensional array of size n. If balancing of complex matrix A was not performed, DV=0.0 can be specified. Therefore, DV does not necessarily have to be a one-dimensional array. See "Comments on use". ICON ... Output. Condition code. See Table CHBK2-l
Comments on use Subroutines used SSL II ... MGSSL FORTRAN basic function ... None Notes After subroutine CHVEC is executed, parameters ZEV, IND and M can be used as input parameters for this subroutine. Parameters ZA and IP for subroutine CHES2 correspond to parameters ZP and IP for this subroutine and can be used as input parameters for this subroutine. For information about the contents of parameters ZP and IP, refer to the section on CHES2. For information about the contents of scaling factor DV, refer to the section on CBLNC. Example Eigenvectors and eigenvalues of an n -order complex matrix are calculated by using the following subroutines: CBLNC ..... Balancing of a complex matrix CHES2 ..... Reduction to a complex Hessenberg matrix CHSQR ..... Determination of eigenvalues of a complex Hessenberg matrix CHVEC ..... Determination of eigenvectors of a complex Hessenberg matrix. CHBK2 ..... Back-transformation of eigenvectors of a complex Hessenberg matrix to eigenvectors of a complex matrix CNRML ..... Nomalization of eigenvectors of a complex matrix. However eigenvectors are calculated in the order in which eigenvalues are determined. When n 100:
C **EXAMPLE** COMPLEX ZA(100,100),ZE(l00), * ZAW(100,101),ZEV(100,100) DIMENSION IND(l00),DV(100),IP(100) 10 READ(5,500)N IF(N.EQ 0)STOP READ(5,510)((ZA(I,J),I=1,N),J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610)(I,J, ZA(I,J),J=1,N) CALL CBLNC(ZA,100,N,DV,ICON) WRITE(6,620)ICON IF(ICON. NE. 0)GO TO 10
266
CHBK2
CALL CHES2(ZA,100,N,IP,ICON) DO 30 J=1,N IM=MIN0(J+1,N) DO 30 I=1,IM 30 ZAW(I,J)=ZA(I,J) CALL CHSQR(ZAW,100,N,ZE,M,ICON) WRITE(6,620)ICON IF(ICON. GE. 20000)GO TO 10 DO 40 I=1,M 40 IND(I)= l CALL CHVEC(ZA,100,N,ZE,IND,M, * ZEV,ZAW,ICON) WRITE(6,620)ICON IF(ICON. GE. 20000)GO TO 10 CALL CHBK2(ZEV,100. N,IND,M,ZA,IP, * DV,ICON) CALL CNRML(ZEV,100,N,M,2,ICON) CALL CEPRT(ZE,ZEV,100,N,IND,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(lHl,10X,15HORIGINAL MATRIX * //11X,6HORDER=,I5) 610 FORMAT(/2(5X,2HA(,I3,1H,,I3,2H)= , * 2E15.7)) 620 FORMAT(/11X,15HCONDITION CODE=,I5/) END
~ A = D 1 AD ~ 1 H = Sn S21S11 AS1S2 2
S
n 2
(4.1) (4.2)
Where D is a diagonal matrix and Si is represented by permutation matrix Pi and elimination matrix Ni as shown in (4.3). Si = Pi N i1 i = 1,2,
, n 2
(4.3)
Let eigenvalues and eigenvectors of H by and y respectively and then obtain Hy = y From (4.1) and (4.2), (4.4) becomes: Sn12 (4.4)
S
S11 D 1 ADS1 S2
S
n 2
y = y
(4.5)
In this example, subroutine CEPRT is used to print the eigenvalues and corresponding eigenvectors of a complex matrix. For further information see the example of CEIG2. Method This subroutine back-transforms the eigenvectors of an n-order complex Hessenberg matrix H to the eigenvectors of balanced complex matrix A and then back-transforms the resultant eigenvectors to eigenvectors of an original complex matrix A. An complex matrix A is balanced by using the diagonal similarity transformation method shown in (4.1). The balanced complex matrix is reduced to a complex Hessenberg matrix H by using the (n 2) stabilized elementary similarity transformations as shown in (4.2).
S
n 2
y = DS1S2
S
S
n-2.
n 2
(4.6)
S
n 2
(4.7)
x is calculated as shown in (4.8) and (4.9) starting with y=xn-1. xi = Si xi+1 = Pi N i1 xi+1 , i = n 2, ,2,1 x = Dx1
(4.8) (4.9)
For further information about stabilized elementary similarity transformation and balancing, see the section on CBLNC and CHES2. For details see Reference [13] pp.339 - 358.
267
CHES2
Comments on use Subroutines used SSL II ... CSUM, AMACH, MGSSL FQRTRAN basic functions ... REAL, AIMAG, ABS, AMAX1 Notes Output arrays ZA and IP are required to determine the eigenvectors of matrix A. The precision of eigenvalues is determined in the complex Hessenberg transformation process. For that reason this subroutine has been implemented so that complex Hessenberg matrices can be determined as accurately as possible. However, if a complex matrix contains very large and very small eigenvalues, the precision of smaller eigenvalues is liable to be more affected by the reduction process some smaller eigenvalues are difficult to determine precisely. Example This example transforms an n -order complex matrix to a complex Hessenberg matrix and determines its eigenvalues through use of the subroutine CHSQR. n 100
C **EXAMPLE** COMPLEX ZA(100,100),ZE(100) DIMENSION IP(100) 10 READ(5,500)N IF(N.EQ.0)STOP READ(5,510)((ZA(I,J),I=1,N),J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610)(I,J ,ZA(1,J),J=1,N) CALL CHES2(ZA,100,N,IP,ICON) WRITE(6,620) WRITE(6,630)ICON IF(ICON. EQ. 30000)GO TO 10 WRITE(6,610)((I,J,ZA(I,J), * J=1,N),I=1,N) CALL CHSQR(ZA,100,N,ZE,M,ICON) WRITE(6,640) WRITE(6,630)ICON IF(ICON. GE. 20000)GO TO 10 WRITE(6,650)(I,ZE(I),I=1,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1,10X,15HORIGINAL MATRIX * //11X,6HORDER= ,I5/) 610 FORMAT(/2(5X,2HA(,I3,1H,,I3, * 2H)=,2E15.7)) 620 FORMAT(lH0//11X, * 17HHESSENBERG MATRIX) 630 FORMAT(/11X,15HCONDITION CODE=,I5/) 640 FORMAT(lH0/11X,11HEIGENVALUES) 650 FORMAT(5X,2HE(,I3,2H)=,2E15.7) END
Function This subroutine reduces an n -order complex matrix A to a complex Hessenberg matrix H using the stabilized elementary similarity transformation method (Gaussian elimination method with partial pivoting) . H = S 1 AS where S is a transformation matrix. n l. Parameters ZA ... Input. Complex matrix A. Output. Complex Hessenberg matrix H and transformation matrix. See Figure CHES2-1. ZA is a complex two-dimentional array, ZA (K, N). K .. Input. Adjustable dimension of array ZA. ( n) N ... Input. Order n of complex matrix A. IP ... Output. Information required by permutation matrix S. (See Fig. CHES2-1.) IP is a one-dimensional array of size n. ICON... Output. See Table CHES2-1. ZA a (1 ) 31 (1 ) a41 (1 ) an 1 m IP m1 2 mn2
) a k( k +2 k ( n2 ) an n2
(k) an k
Note: The section indicated with is the Hessenberg matrix. The rest contains some information for the transformation matrix. indicates a work area. Fig. CHES2-1 Array ZP and IP after transformation
Table CHES2-1 Condition codes Code 0 10000 30000 Meaning No error N =1 or N = 2 K < N or N < 1 Processing No transformation Bypassed
268
CHES2
Method An n -order complex matrix A is reduced to a complex Hessenberg matrix H through n -2 iterations of the stabilized elementary similarity transformation method. Ak = Sk1 Ak 1Sk , k = 1,2,
Sk1 = N k Pk , Sk = Pk N k1
(4.5)
, n 2
(4.1)
result. Where, Pk-1 is equal to Pk, and Nk-1 is obtained by reversing all signs of non-diagonal elements of Nk. Pk 1 k + 1 mk k +1 1 0 1 1 1 0 1 1 mk 1
where A0=A. When transformation is completed An-2 is in the complex Hessenberg matrix. The k -th transformation is performed according to the following procedure:
( k 1) Let Ak 1 = aij
( k 1) 1) The elements aik , i=k+1,..., n in the k-th column are searched for the element of the maximum norm. The following is assumed as the norm of complex number z = x + iy : z1= x+ y ( k 1) is the element of the maximum norm, If a am kk number mk is stored as the k -th element of IP. 2) If mk = k+1 is satisfied the next step is executed immediately. If mk > k+1 is satisfied the k -th and subsequent columns elements in the mk -th row are exchanged by the elements in the ( k + 1 )-th row of Ak-1 +1) 3) Using ak( k +1, k as a pivot. all elements of the (k+2)-th
and subsequent rows in the k -th column are eliminated through use of:
1 aikk = aikk 1 ak k+ i = k + 2, 1, k ,
( )
, n
(4.2)
1 k + 1 0
Note: a ij
( k 1)
k +1 0
1) a( k +2 , k k( k 1) ak +1 ,k
a ( k 1) nk 1) ak( k +1,k
1 0
4) If mk=k+1 is satisfied the next step is executed. If mk > k+1 is satisfied, all elements in the (k +1)-th column are exchanged by the mk -th column. 5) At this step, each element in the (k +1)-th and ~(k) . subsequent columns is assumed as a ij All elements in the (k +1)-th column are modified as follows:
(k) ~( k ) ~(k ) (k ) aik +1 = aik +1 aij aik , i = 1,2,
n j = k +2
Information mk necessary for Pk is stored as the k -th element of IP and all elements of the (k +2)-th and subsequent rows in the (k +1)-th columun of Nk are (k) stored as aij of the (k +2)-th and subsequent rows in the k -th column of A. If n = 2 or n = 1 is satisfied, no transformantion is performed. For further information see Reference [13] pp.339 358.
, n
(4.4)
The row exchanging at the second step is performed by premultiplying Ak-1 by permutation matrix Pk shown in Fig. CHES2-2. The elimination of elements at the third step performed by premultiplying Pk by elimination matrix Nk shown in Fig. CHES2-3. Therefore,
269
CHSQR
complex Hessenberg matrix through use of CHES2 and then determines its eigenvalues. n 100.
C **EXAMPLE** COMPLEX ZA(100,100),ZE(100) DIMENSION IP(100) 10 READ(5,500)N IF(N.EQ.0)STOP READ(5,510)((ZA(I,J),I=1,N),J=1,N) WRITE(6,660)N DO 20 I=1,N 20 WRITE(6,610)(I,J,ZA(I,J),J=1,N) CALL CHES2(ZA,100,N,IP,ICON) WRITE(6,620)ICON IF(ICON.EQ.30000)GO TO 10 CALL CHSQR(ZA,100,N,ZE,M,ICON) WRITE(6,630) WRITE(6,620)ICON IF(ICON.GE.20000)GO TO 10 WRITE(6,640)(I,ZE(I),I=1,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(lHl,10X, * 18H** ORIGINAL MATRIX//11X, * 10H** ORDER=,15/) 610 FORMAT(/2(5X,2HA(,I3,1H,,I3, * 2H)=,2E15.7)) 620 FORMAT(/11X,19H** CONDITION CODE=, * I5/) 630 FORMAT(lH0/11X,14H** EIGENVALUES) 640 FORMAT(5X,2HE(,I3,2H)=,2E15.7) END
Function This subroutine determines all eigenvalues of an n order complex Hessenberg matrix A by using the QR method. n l. Parameters ZA ... Input. Complex Hessenberg matrix A. The contents of A are altered on output. ZA is a two-dimensional complex array, ZA (K,N) K .. Input. Adjustable dimension of array ZA.( n) N ... Input. Order n of the complex Hessenberg matrix A. ZE ... Output. Eigenvalues. The J-th eigenvalue is ZE (J) ( J = 1 ,2,...M) . ZE is a one-dimensional complex array of size n. M ... Output. Number of determined eigenvalues. ICON ... Output. Condition code. See Table CHSQR-1.
Table CHSQR-1 Condition codes Code 0 10000 15000 Meaning No error N=1 Any of the eigenvalues could not be determined. Processing ZE (1) = ZA (1, 1) The number of eigenvalues that were obtained is set to M. M is set to zero. Bypassed
Method In the QR method, the diagonal elements become eigenvalues by making the lower subdiagonal elements of comfplex Hessenberg matrix A converge to zero. To accomplish this the unitary similarity transformation shown in (4.1) is applied repeatedly. As+1 = Qs* AsQs , s = 1,2,
20000 30000
(4.1)
Comments on use Subroutines used SSL II ... AMACH, MGSSL FORTRAN basic function ... REAL, AIMAG, CONJG, ABS, SIGN, AMAXl, SQRT, CSQRT Notes Normally, this subroutine is used to determine all eigenvalues after CHES2 has been executed. If eigenvectors are also needed array ZA should be copied onto another area before this subroutine is called. Example This example reduces an n -order complex matrix to a
where A1=A. Qs is a unitary matrix which is uniquely determined in the QR decomposition shown in (4.2). As = Qs Rs (4.2)
where Rs is an upper triangular matrix whose diagonal elements are positive real numbers. To improve the rate of convergence, QR decomposition is normally applid to origin-shifted matrix (As - ksI) instead of As. ks is the origin shift. Qs and Rs are obtained from (4.3) instead of (4.2).
As k s I = Q s Rs
(4.3)
270
CHSQR
The process for the complex QR methods is described below. ( s) , A = aij . Let As = aij
( )
( )
1) (4.4) determines whether there are elements which can be regarded as relative zero among lower ( s) (s) , ..., a21 of As. subdiagonal elements an , n1 al(,sl)1 < u A , l = n, n 1, ,2 1
2) Origin shift ks corresponds to the eigenvalue of lowest norm || ||1 in the lowest 2 2 principle submatrix of As . As ksI is obtained by subtracting ks from diagonal elements of As. 3) By applying two-dimensional Givens unitary transformation Pl* (for l =1, 2, . .., n 1) to As ksI is transformed to upper triangular matrix Rs: Pn*1 Pn*2
(4.4)
P P ( A k I) = R
* 2 * 1 s s
(4.7)
u is the unit round-off. || ||1 is a norm defined for complex number z= x + iy as: z1= x+ y ||A|| is a norm defined as: A = max aij j
i =1 n
Therefore ,
Qs = P1 P2
(4.5)
P
n1
(4.8).
Unitary matrix Pl is determined by using the l -th diagonal element x of matrix As - ksI and its subdiagonal element y as shown below: (4.6) l l+1 1 O 1 c s l Pl = s c l +1 1 O 1
) al(,sl 1 is relative zero if it satisfies (4.4). If it does not satisfy (4.4), step 2) is performed. (a) If l = n , an( sn) is adopted as an eigenvalue, order n
of the matrix is reduced to n 1 , and the process returns to step 1). If n = 0, the process is terminated. (b) When 2 l n 1, the matrix is split as shown in Fig. CHSQR-1, and the process proceeds to step 2) assuming submatrix D as As . * * * * * * * * * * * * * * * * * * * B C l * * * * * 0 D * * ** * * * * *
Note: Element is regarded as zero. Fig. CHSQR-1 A direct sum of submatrices for a Hessenbert matrix
where : c=x r c= y r r= x + y
2 2
4) After two-dimensional unitary transformation Pl is applied to Rs , As+1 is obtained by adding origin shift ks to diagonal elements.
As+1 = Rs P1 P2
P
n 1
+ ks I
(4.12)
This subroutine executes step 3) in combination with step 4) to increasse computational speed and reduce storage requirements. For further information see References [12] and [13] pp.372-395.
271
CHVEC
B21-15-0502 CHVEC,DCHVEC
Eigenvectors of a complex Hessenberg matrix (Inverse iteration method) CALL CHVEC (ZA, K, N, ZE, IND, M, ZEV, ZAW, ICON )
Comments on use Subroutines used SSL II ... AMACH, CSUM, MGSSL FORTRAN basic functions ... RAL, AIMAG, ABS, MIN0, AMAXl, FLOAT, SQRT Notes The number of eigenvectors (MK) indicates the number of IND elements whose value is 1. Since IND elements are set to zero if any eigenvector cannot be determined, MK indicates the number of eigenvectors which does not exceed the number of eigenvectors specified before computation. The eigenvalues used by this subroutine can be obtained by the CHSQR subroutine. When they are determined by CHSQR, the parameters ZE and M can be used as input parameters for this subroutine. This subroutine can be used to determine eigenvectors of complex Hessenberg matrices only. When selected eigenvectors of a complex Hessenberg matrix are to be determined: (a) The complex matrix is first reduced into a complex Hessenberg matrix by the subroutine CHES2. (b) The eigenvalues of the complex matrix are determined by the subroutine CHSQR. (c) The eigenvectors of the complex Hessenberg matrix are determined by this subroutine. (d) The above eigenvectors are back-transformed to eigenvectors of the complex matrix by the subroutne CHBK2. However the subroutne CEIG2 should be utilized to determine all eigenvalues and corresponding eigenvectors of a complex matrix for convenience. This subroutine can be used to determine some of the eigenvectors of a complex matrix according to the procedure described above. Therefore, the eigenvectors are not normalized. If necessary, they must be normalized by the subroutine CNRML subsequently When the subroutines CHBK2 and CNRML are used, the parameters IND, M and ZEV can be used as input parameters for the subroutines CHBK2 and CNRML. Example This example determines eigenvalues of an n-order complex matrix through use of the subroutines CHES2 and CHSQR and obtains eigenvectors through use of the subroutines CHVEC and CHBK2. The obtained eigenvectors are normalized by the subroutine CNRML (||x||2=1). n 100.
Function This subroutine determines eigenvector x which corresponds to selected eigenvalue of an n -order complex Hessenberg matrix by using the inverse iteration method. However no eigenvectors are normalized. n l. Parameters ZA ... Input. Complex Hessenberg matrix A. ZA is a two-dimensional array, ZA (K, N). K ... Input. Adjustable dimension of arrays ZA, EV and ZAW. N ... Input. Order n of the complex Hessenberg matrix A. ZE ... Input. Eigenvalue . The j-th eigenvalue j is stored in ZE ( j). ZE is a one-dimensional complex array of size M. IND ... Input. Indicates whether or not eigenvectors are to be determined. If the eigenvector corresponding to the j-th eigenvalue j is to be determined, IND ( j) = 1 must be specified. If it is not to be determined IND ( j) = 0 must be specified. IND is a one-dimensional array of size M. M .. Input. Total number of eigenvalues stored in array ZE ( n ) ZEV ... Output. Eigenvectors are stored in columns of ZEV. ZEV is a two-dimensional complex array, ZEV (K, MK). MK indicates the number of eigenvectors to be determined. See "Comments on use". ZAW ... Work area. ZAW is a two-dimensional array, ZAW (K, N + 1) . ICON ... Output. condition code. See Table CHVEC- 1 .
Table CHVEC-1 Condition codes Code 0 10000 15000 Meaning No error N=1 An eigenvector corresponding to a specified eigenvalue could not be determined. Processing ZEV (1, 1) = (1.0, 0.0) IND information about the eigenvector that could not be determined is set to zero. All IND information are set to zero. Bypassed
20000
30000
272
CHVEC
**EXAMPLE** COMPLEX ZA(100,100),ZAW(100,101), * ZE(100),ZEV(100,100) DIMENSION IND(100),IP(100),VW(100) 10 READ(5,500)N IF(N.EQ.0)STOP READ(5,510)((ZA(I,J),I=1,N),J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610)(I,J,ZA(I,J),J=1,N) CALL CHES2(ZA,100,N,IP,ICON) WRITE(6,620)ICON IF(ICON.EQ.30000)GO TO 10 DO 30 J=1,N IM=MIN0(J + l,N) DO 30 I=1,IM 30 ZAW(I,J)=ZA(I,J) CALL CHSQR(ZAW,100,N,ZE,M,ICON) WRITE(6,620)ICON IF(ICON.GE.20000)GO TO 10 DO 40 I=1,M 40 IND(I)= 1 CALL CHVEC(ZA,100,N,ZE,IND,M,ZEV, * ZAW,ICON) WRITE(6,620)ICON IF(ICON.GE.20000)GO TO 10 CALL CHBK2(ZEV,100,N,IND,M,ZA, * IP,0.0,ICON CALL CNRML(ZEV,100,N,IND,M,2,ICON) CALL CEPRT(ZE,ZEV,100,N,IND,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(lHl,5X,15HORIGINAL MATRIX, * 5X,2HN=,I3) 610 FORMAT(/2(5X,2HA(,I3,1H,,I3,2H)=, * 2E15.7)) 620 FORMAT(lH0,20X,5HICON=,I5) END
as shown in (4.2), xr can be written as shown in (4.3) if all eigenvalues i are different. x0 = i ui
i =1 n
(4.2)
xr = 1 j j n j j + i ui j j i =1 i j
) ( )
r r i i
(4.3)
Since
j ) ( i i ) 10 .
is established if i is not equal to j, (4.3) indicates that if j 0, xr tends rapidly to approach a multiple of uj as r grows greater. The system of linear equations shown in (4.1) is solved by using (4.4) after decomposition of (A j I) to a lower triangular matrix L and an upper triangular matrix U.
LUx r = Px r1
(4.4)
where P is the permutation matrix used for pivoting (4.4) can be solved as follows: Ly r 1 = Pxr 1 Ux r = y r 1 (Forward substitution) (4.5) (Backward substitution) (4.6)
The subroutine CEPRT used in this example prints the eigenvalues and eigenvectors of the complex matrix. For further information see an example of subroutine CEIG2. Method The inverse iteration method is used to determine eigenvector x corresponding to eigenvalue of an n order complex Hessenberg matrix. In the inverse iteration method, if matrix A and approximation j for eigenvalue j of are given, an appropriate initial vector x0 is used to solve equation (4.1) iteratively. When convergence conditions have been satisfied, xr is determined as the resultant eigenvector.
Since any vector may be used for initial vector x0 , x0 may be given such that y0 of (4.7) has a form such as y0=(1,1,...,1)T y 0 = L1 Px 0 (4.7)
Therefore, for the first iteration, the forward substitution in (4.5) can be omitted. In general, the eigenvectors can be obtained by repeating forward substitution and backeard substitution for the second and following iterations. This subroutine uses the inverse iteration method as described below: Selection of the initial vector y0 in (4.8) is used for the initial vector. y 0 = EPS1 r (4.8)
( A I )x
j
= x r 1 , r = 1,2,
(4.1)
where vector r is defined as shown in (4.9) and is a golden section ratio shown in (4.10). rk = k [ k ], k = 1,2,
Now let the eigenvalue of n-order matrix A be i (i=1,2,...,n), and the eigenvector corresponding to i be ui. Since the appropriate initial vector x0 can be expressed by the linear combination of eigenvect or ui of matrix A
5 +1 2
(4.9) (4.10)
EPS1 can be expressed as shown in (4.11). EPS1 = u A where u is the unit round-off. 273 (4.11)
CHVEC
xr 1 01 .
(4.15)
(4. 12)
For complex number z = x + iy , norm ||z|| is assumed as shown in (4.13). z1= x+ y Normalization of the iterated vector Let xr = ( xr1 , xr 2 , , xrn ) (4. 13)
If (4.15) is satisfied, xr is accepted as the eigenvectors. If it is not satisfied, normalization described in second step is repeated up to five times. When convergence is not successful, the eigenvector is ignored and the next eigenvector is processed. Measures to be taken when eigenvalues have multiple roots or close roots Since this subroutine produces initial vector y0 using random numbers, you need not take special measures when an eigenvalue has multiple roots or close roots. To make a reproduction of numerical solutions, the random numbers are initialized each time this subroutine is called. For further information see Reference [13] pp.418439.
then the iterated vector is normalized as shown in (4.14) for r l. xr 1 = xri 1 = EPS1
i =1 n
(4.14)
Method for convergence criterion After backward substitution, xr (before normalization) is tested by (4.15) to determine whether the eigenvectors have been accepted.
274
CJART
parameters ICON and N on output to confirm that all of roots were found. Example The degree n and complex coefficients ai are input, and the roots are calculated. 1 n 50.
C **EXAMPLE** DIMENSION ZA(51),Z(50) COMPLEX ZA,Z READ(5,500)N Nl=N+1 READ(5,510)(ZA(I),I=l,N1) DO 10 I=1,Nl K=I -l WRITE(6,600)K,ZA(I) CALL CJART(ZA,N,Z,ICON) WRITE(6,610)N,ICON IF(ICON.EQ.30000)STOP WRITE(6,620)(1,Z(I),I=1,N) STOP FORMAT(I2) FORMAT(2F10.0) FORMAT(10X,2HA(,I2,2H)=,2 E20.8) FPRMAT(10X,2HN=,I2,5X,5HICON=,I5) FORMAT(10X,2HZ(,I2,2H)=,2E20.8) END
Function This subroutine finds zeros of a polynomial with complex coefficients a0 z n + a1z n 1 +
+a
=0
(1.1)
by the Jarratt method. Parameters ZA ..... Input. Coefficients of the equation. ZA is a complex one-dimensional array of size n + 1 , Where ZA (1) = a0, ZA (2) = a1, ... , ZA(N+1)=an , The contents of ZA are altered on output. N ..... Input. Order n of the equation. Output. Number of roots that were obtained. (See "Comments on use"). Z ... Output. n roots. Z is a complex one-dimensional array of size n. The roots are output in Z (1), Z (2), ... in the order that they were obtained. Thus. if N roots are obtained, they are stored in Z (1) to Z (N). ICON ... Output. Condition code. See Table CJART-1.
Table CJART-l Condition codes Code 0 10000 Meaning No error All n roots could not be obtained. Processing The number of roots which were obtained is output to the parameter N and the roots are output to Z(1) through Z(N). Bypassed
Method This subroutine uses a slightly modified version of Garside-Jarratt-Mack method (an iterative method). Let the polynomial equation be f (z) a0 z n + a1 z n1 +
+a
=0
(4.1)
This subroutine makes use of the faster convergence property of (4.2) since it has only simple roots. The iterative formula Suppose that z1, z2, and z3 are three initial values to a root and they satisfy | f(a3)| | f(a2)| | f(a1)|. Then the following three methods are used as iterative formulas. In the following, let Fi F( Zi ) for i = l, 2, and 3. Method 1: Near a root of a n-th degree polynomial f(z) , we can write 1 F ( z) ( z a ) (b + cz ) (4.3)
30000
n < 1 or [a0]=0.
Comments on use Subprogram used SSL II ... AMACH, CQDR, UCJAR, and MGSSL FORTRAN basic functions ... CMPLX, SQRT, CABS, CONJG, AIMAG, REAL and ABS. Notes For arrays ZA and Z, COMPLX must be declared in a program which calls this subroutine. When n is 1 or 2, instead of Jarratts method. the root formula is used. An n -th degree polynomial equation has n roots, however it is possible, though rare, that all of these roots can not be found. The user must check the
where a, b, and c are constants Thus, a new root can be obtained by choosing a such that (4.3) is true for z1, z2, and z3. Namely, a is obtained as
275
CJART
a = z3 +
( z z )( z z )(F F ) z z ( )( F F ) + (z z )(F F )
2 3 3 1 2 1 3 2 2 1 1 2 3 2
(4.4)
They are ordered such that | f(z3)| | f(z2)| | f(z1)| If convergence does not occur after 50 iterations, new initial values are selected as follows: 3w + 2iw,2w + 2iw,3w + 3iw
Method 2 (Newtons method): The following a can be used as a new root. a = z3 1 F3 Method 3 (modified Newtons method): Suppose that . f ( z3 ) < u1 an (4.6) (4.5)
When a root is obtained, the degree of the equation is reduced by setting. g( z ) = f ( z ) ( z a ) Using g(z) as the new f(z), w is recalculated and w iw, w 2iw, a (4.10)
is satisfied, where u1= u and u is the round-off unit. Let m be the rough multiplicity of current root, then we can write m (z 3 a) F3 and the following a = z3 m F3 (4.7)
are used as initial values for solving f(z)=0. The sign is selected to match the sign of the imaginary part of . Preventing overflows To prevent overflow when evaluating f(z) and f (z), the coefficients of f(z) are normalized by dividing them with the arithmetic mean of their absolute values. Convergence criterion If f ( z3 ) u ai z3ni
n i =0
Usually, Method 1 and Method 2 are both used, and the result with the smallest adjustment is used as the new approximate root a4. The Method 3 is used to increase the speed of convergence. Choosing initial values an a0
1n
= 5w
(4.8)
(4.11)
With (4.8), initial values z1, z2, z3 are setected according to iw, w + iw,2iw (4.9)
is satisfied, z3 is then taken as a root of f(z). For further information, see References [26] and [27].
276
CLU
Function An n n complex general matrix A is LU-decomposed using the Crouts method PA = LU (1.1)
Array ZA
Where P is a permutation matrix which performs the row exchanged required in partial pivoting, L is a lower triangular matrix, and U is a unit upper triangular matrix. n l. Parameter ZA .... Input. Matrix A Output. Matrices L and U. See Fig. CLU-1. ZA is a complex two-dimensional array, ZA(K, N). K .... Input. Adjustables dimension of array ZA ( N). N ..... Input. Order n of matrix A. EPSZ .. Input. Tolerance for relative zero test of pivots in decomposition process of A (0.0). When EPSZ is 0.0, a standard value is used. (See Notes.) IP.... Output. The transposition vector which indicates the history of row exchanging that occurred in partial pivoting. IP is a one-dimensional array of size n. (See to Notes.) . IS.... Output. Information for obtaining the determinant of matrix A. If the n calculated diagonal elements of array ZA are multiplied by IS, the determinant is obtained. ZVW ... Work area. ZVW is a complex onedimensional array of size n. ICON .. Output. Condition code. See Table CLU-1.
Table CLU-l Condition codes Code 0 20000 Meaning No error Either all of the elements of some row in matrix A were zero or the pivot became relatively zero. It is highly probable that the matrix is singular. K < N, N < 1 or EPSZ < 0.0 Processing Discontinued
1n
2n
N K
n1n nn
Comments on use Subprograms used SSL II ..... AMACH, CSUM, MGSSL FORTRAN basic functions ..... REAL, AIMAG, ABS Notes If EPSZ is set to 10-s, this value has the following meaning: while performing the LU-decomposition by Crouts method, if the loss over s significant digits occured for both real and imaginaty parts of the pivot, the LU-decomposition should be discontinued with ICON = 20000 regarding the pivot to be relatively zero. Let u be the unit round-off, then the standard value of EPSZ is l6u. If the processing is to proceed at a lower pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. The transposition vector corresponds to the permutation matrix P of LU decomposition in partial pivoting. In this subroutine, with partial pivoting, the elements of array ZA are actually exchanged. In other words, if the Ith row has been selected as the pivotal row in the J-th stage ( J = 1 , ..., n ) of decomposition, the elements has the Ith and Jth rows of array ZA are exchanged. The history of this exchange is recorded in IP by storing I in IP(J). A system of linear equations can be solved by calling subroutine CLUX following this subroutine. However, instead of calling these two subroutines, subroutine LCX is usually called to solve such equations in one step. Example An n n complex matrix is LU decomposed. n 100.
30000
By passed
277
CLU
**EXAMPLE** DIMENSION ZA(100,100),ZVW(100),IP(100) COMPLEX ZA,ZVW,ZDET READ(5,500)N IF(N .LE. 0)STOP READ(5,510)((ZA(I,J),I=1,N),J=1,N) WRITE(6,600)N,((I,J,ZA(I,J),J=1,N),I=1,N) CALL CLU(ZA,100,N,0.0,IP,IS,ZVW,ICON) WRITE(6,610)ICON IF(ICON .GE. 20000)STOP ZDET=CMPLX(FLOAT(IS),0.0) DO 10 I=1,N ZDET=ZDET*ZA(I,I) 10 CONTINUE WRITE(6,620)(I,IP(I),I=1,N) WRITE(6,630)((I,J,ZA(I,J),J=1,N),I=1,N) WRITE(6,640)ZDET STOP 500 FORMAT(I5) 510 FORMAT(5(2F8.3)) 600 FORMAT(1H1//10X.17H**INPUT MATRIX **, * /12X,6HORDER=,I5/(5X,2(lH(,I3,1H,,I3,1H), * 2E15.8,2X))) 610 FORMAT(1H0,10X.16HCONDITION CODE =,I5) 620 FORMAT(1H0,10X,20HTRANSPOSITION VECTOR, * /(10X,7(1H(,I3,1H),I5,5X))) 630 FORMAT(1H0,10X,13HOUTPUT MATRIX, * /(5X,2(1H(,I3,1H,I3,1H),2E15.8,2X))) 640 FORMAT(1H0,10X, 21HDETERMINANT OF MATRIX, * 2E20.8) END
P is the permutation matirx which performs the rowexchanging required in partial pivoting. The Crouts method is one method to obtain the elements of L and U. This subroutine obtains values in the j th column of L and j th column of U in the order ( j = l, ... , n) using the following equations. uij = aij lik ukj
k =1 j 1 k =1
i1
) l , i = 1,, j 1
ij
(4.2) (4.3)
, n
where, A = ( aij ) , L = ( lij ) and U = ( uij ) Actually, using partial pivoting, rows are exchanged. The Crouts method is a variation of the Gaussian elimination method. The same caluculations are involved, but the seqnece is differenct. In the Crout method, the elements of L and U are calculated at the same time using equations (4.2) and (4.3). By increasing the precision of the inner products in this step, the effects of rounding errors are minimized. Partial pivoting When the matrix A is given as 0.0 + i 0.0 10 . + i 0.0 A = 10 . + i 0.0 0.0 + i 0.0 Though this matrix is numerically stable, LU decomposition can not be performed. In this state, even if a matrix is numerically stable, large errors would occur if LU decomposition were directly computed. To avoid these errors, partial pivoting with row equalibration is used. For more details, see References [1], [3], and [4].
Method Crouts method Generally, in exchanging rows using partial pivoting, an n n non-singular complex general matrix A can be decomposed into a lower triangular matrix L and a unit upper triangular matrix U. PA = LU (4.1)
278
CLUIV
Table CLUIV-1 Condition codes Code 0 20000 30000 Meaning No error Matrix was singular. K < N or N < 1 or there was an error in IP. Processing Discontinued Bypassed
CALL CLUIV (ZFA, K, N, IP, ICON) Function The inverse A-1 of an n n complex general matrix A given in decomposed form PA = LU is computed. A1 = U 1 L1 P Where L and U are respectively an n n lower triangular and a unit upper triangular matrices and P is a permutation matrix which performs the row exchanges in partial pivoting for LU decomposition. n l. Parameters ZFA .... Input. Matrices L and U Output. Inverse A-1. ZFA is a two-dimensional array, FA (K, N). See Fig. CLUIV-1. K ..... Input. Adjustable dimension of array ZFA ( N ). N ...... Input. Order n ofthe matrices L and U. IP ..... Input. Transposition vector which indicates the history of row exchanges in partial pivoting. One-dimensional array of size n ICOM .. Output. Condition code. See Table LUIV-1.
Unit upper triangular matrix U
Comments on use Subprogram used SSL II ..... CSUM, MGSSL FORTRAN basic functions ..... None. Notes Prior to calling this subroutine, LU-decomposed matrix must be obtained by subroutine CLU and must be input as the parameters ZFA and IP to be used for this subroutine. The subrotine LCX should be used for solving a system of linear equatons. Obtaining the solution by first computing the inverse requires more steps of calculation, so subroutine CLUIV should be used only when the inverse is inevitable. The transposition vector corresponds to the permutation matrix Pof PA = LU when performing LU decomposition with partial pivoting, refer to Notes of the subroutine CLU. Example The inverse of an n n complex general matrix iscomputed. n 100.
C * * EXAMPLE * * DIMENSION ZA(100,100),ZVW(100),IP(100) COMPLEX ZA, ZVW, ZDET READ (5,500) N IF (N .EQ. 0) STOP READ (5,510)((ZA(I,J),I=l,N),J=1,N) WRITE (6,600)N,((1,J,ZA(I,J),J=l,N),I =l,N) CALL CLU(ZA,100,N,0.0,IP,IS,ZVW,ICON) WRITE (6,610) ICON IF (ICON. GE. 20000) STOP CALL CLUIV (ZA, 100, N, IP, ICON) WRITE (6,620) ICON IF (ICON.GE. 20000) STOP WRITE (6,630) ((I,J,ZA(I,J),I=1,N),J=1,N) STOP 500 FORMAT (I5) 510 FORMAT (4E15 . 7) 600 FORMAT (//11X, 16H**INPUT MATRIX**/12X, * 6HORDER=,I5/(2X,4(lH(,I3,1H,,I3,1H),2E16.8) 610 FORMAT(lH0,10X,20HCONDITION CODE (CLU)=,I5) 620 FORMAT(lH0,10X,22HCONDITION CODE (CLUIV)=,I5) 630 FORMAT(lH0,10X,18H**INVERSE MATRIX**; * /(2X,4 (lH (,I3,1H,,I3,1H),2E16.8))) END
u1n 1 u 1 2 u 1 3 1 u 23 u2n 1 u n 1 n 0 1
u u l u l l l l
l11 u12 u13 l21 l22 u23
n1n1 nn1 n1 n2
1n
2n
N K
n1n nn
279
CLUIV
Method The subroutine computes the inverse of an n n complex general matrix A, giving the LU-decomposed matrices L, U and the permutation matrix P which indicates row exchanges in partial pivoting. Since PA = LU (4.1)
Calculating U-1 Since the inverse U-1 of a unit upper triangular matrix U is also a unit upper triangular matrix, if we represent U-1 by ~ U 1 = u ij
( )
(4.7)
then, the inverse A-1 can be represented using (4.1) as follows: the inverse of L and U are computed and then the inverse A-1 is computed as (4.2). A =U L P
1 1 1
(4.2)
(4.8)
L and U are as shown in Eq. (4.3) for the following explanation. L = l ij ,U = uij
( )
( )
(4.3)
Calculating L-1 Since the inverse L-1 of a lower triangular matrix L is also a lower triangular matrix, if we represent L-1 by ~ L1 = lij
~ =1, the elements u ~ of the jth column Considering u jj jj (j=n,...2) of U-1 are obtained as follows: ~ = u u u ~ , i = j 1, u ij ij ik kj
j 1
()
(4.4)
-1
k =i +1
,1
(4.9)
Calculating U-1L-1P Let the product of matrices U-1 and L-1 be B, then its elements are obtained by
n ~~ bij = u l , i = 1, ik kj
(4.5)
, j 1 ~~ b = u l , i = j ,, n
k =i n ij k=i ik kj
~ =1, the element b of the jth column Considering u ij ii (j=1, ...,n) of B are obtained by
n ~~ bij = u l , i = 1, , j 1 ik kj k= j n ~ ~~ bij = lij + u l , i = j, , n ik kj k =i +1
~ and the elements I jj of the jth column (j=1,...,) of the matrix L are obtained as follows: ~ i1 ~ lij = lik lkj lii , i = j + 1, , n k= j ~ l jj = 1 l jj where, l jj 0(i = j ,
-1
(4.10)
(4.6)
, n)
Next, matrix B is multiplied by the permutation matrix to obtain the inverse A-1. Actually however, based on the values of the transposition vector IP, the elements of A-1 are obtained simply by exchanging the column in the matrix B. The precison of the inner products in (4.6), (4.9) and (4.10) has been raised to minimize the effect of rounding errors. For more invormation, see Reference [1].
280
CLUX
CALL CLUX (ZB, ZFA, K, N, ISW, IP, ICON) Function This subroutine solves a system of linear equations. Lux = Pb (1.1)
u 1n 1 u 1 2 u 1 3 1 u23 u2n 1 u n 1 n 0 1
Lower triangular matrix L
Array ZFA
L and U are, respectively, the n n lower triangular and unit upper triangular matrices, P is a permutation matrix which performs row exchange with partial pivoting for LU decomposition of the coefficient matrix, b is an n-dimensional complex constant vector, and x is the n-dimensional solution vector. Also, one of the following equations can be solved instead of (1.1). Ly = Pb Uz= b (1.2) (1.3)
u u l u l l l l
l11 u12 u13 l21 l22 u23
n1n1 nn1 n1 n2
1n
2n
N K
n1n nn
Parameters ZB .... Input. Constant vector b. Output. One of the solution vectors x, y, or z. ZB is a one-dimensional array of size n. ZFA .... Input. Matrix L and matrix U. Refer to Fig. CLUX-1. ZFA is a complex two-dimensional array, ZFA (K, N). K .... Input. Adjustable dimension of the array ZFA ( N). N .... Input. The order n of the matrices L and U. ISW .... Input. Control information ISW = I ... x is obtained. ISW = 2 ... y is obtained. ISW = 3 ... z is obtained. IP .... Input. The transposition vector which indicates the history of row exchange in partial pivoting. IP is a one-dimensional array of size n. (See Notes of subroutine CLU.) ICON .. Output. Condition code See Table COSI-I
Table CLOX- 1 Condition codes Code 0 20000 30000 Meaning No error The coefficient matrix was singular. K<N. N<1, ISW = 1, 2, 3, or there was an error in IP. Processing Aborted Aborted
Comments on use Subprograms used SSL II ..... CSUM, MGSSL FORTRAN basic functions ..... None Notes A system of linear equations can be solved by first calling the subroutine CLU to decompose the coefficient into L and Uand then by calling this routine. However, instead of calling these two routines, subroutine LCX is usually called to solve such equations in one step. Example A system of linear equations is solved by first using subroutine CLU to decompose the n n coefficient matrix into L and U. n 100.
C **EXAM PLE** DIMENSION ZA(100, 100), ZB(100), ZVW(l00), * IP(100) COMPLEX ZA, ZB, ZVW READ(5,500) N READ(5,510) ((ZA(1, J), I=1, N), J=1, N) READ(5.510) (ZB(I), I=1, N) WRITE(6,600) N, ((1, J, ZA(I, J), J=1, N), I=1, N) WRITE(6,610) (I, ZB(I), I=1, N) CALL CLU(ZA, 100, N, 0.0, IP, IS, ZVW, ICON) WRITE(6,620) ICON IF(ICON .GE. 20000) STOP CALL CLUX(ZB, ZA, 100, N, l, IP, ICON) WRITE(6,630) ICON IF(ICON .GE. 20000) STOP WRITE(6,640) (I, ZB(I), I=1, N) STOP 500 FORMAT(I5) 510 FORMAT(5(2F8. 3))
281
CLUX
600 FORMAT(///l0X, 19H**COMPLEX MATRIX **, * /12X, 6HORDER=, 15/(5X, 2(lH(, I3, 1H,, I3, * 1H), 2E15.8, 2X))) 610 FORMAT(1H0, 10X, 15HCONSTANT VECTOR, * /(5X, 3(1H(,I3, 1H), 2E15.8, 2X))) 620 FORMAT(lH0, l0X, 20HCONDITION CODE(CLU)=,I5) 630 FORMAT(lH0, l0X, 21HCONDITION CODE(CLUX) =, * I5) 640 FORMAT(1H0, l0X, 15HSOLUTION VECTOR, * /(5X, 3(1H(, I3, 1H) , 2E15.8, 2X))) END
, n
(4.4)
where, L=(lij),yT=(y1,,yn),(Pb)T=(b1,,bn). Solving Ux = y (backward substitution) Ux = y can be serially solved using equations
Method A system of linear equations LUx = Pb can be solved by solving the two equations: Ly = Pb Ux= y (4.2) (4.3) (4.1)
xi = yi uik xk , i = n, ,1
k =i+1
(4.5)
where, U=(uij),xT=(x1,,xn) The precision of the inner products in (4.4) and (4.5) has heen raised to minimize the effect of rounding errors. For more information, see References [1], [3], and [4].
282
CNRML
CALL CNRML (ZEV, K, N, IND, M, MODE, ICON) Function This subroutine normalizes m eigenvectors xi of an norder complex matrix using either (1.1) or (1.2). yi = xi xi yi = xi xi n 1. Parameters ZEV ... Input. m eigenvectors xi (i= l, 2, ..., m). Eigenvectors xi are stored in columns of ZEV. See Comments on use. Output. m normalized eigenvectors yi . Normalized eigenvectors yi are stored into the corresponding eigenvector xi . ZEV is a two-dimensional array. ZEV(K, M). K ... Input. Adjustable dimension of array ZEV ( n). N ... Input. Order n of the complex matrix. IND ... Input. Specifies eigenvectors to be normalized. If IND (j) = 1 is specified the eigenvector corresponding to the j -th eigenvalue is normalized. If IND (j)=0 is specified the eigenvector corresponding to the j-th eigenvalue is not normalized. IND is a one-dimensional array of size M. See Comments on use. M ... Input. Size of array IND. See Notes. MODE ...Input. Indicates the method of normalization. When MODE=1 ... (1.1) is used. When MODE=2 ... (1.2) is used. ICON ... Output. Condition code. See Table CNRML-1.
Table CNRML-1 Condition codes Code 0 1000 3000 Meaning No error N=1 N<M, M<1, K<N, MODE was neither 1 nor 2 or IND specification was invalid. Processing ZEV(1, 1) = (1.0. 0.0) Bypassed
Comments on use Subroutines used SSL 11 ... MGSSL FORTRAN basic functions ... REAL, AIMAG, AMAXl, SQRT Notes When the CHVEC or CHBK2 subroutine is called before this subroutine, parameters ZEV, IND and M can be used as input parameters for this subroutine. Example This example normalizes the eigenvectors of an norder complex matrix obtained by the subroutine CEIG2 so that the resultant eigenvectors ean be x =1. n 100.
C **EXAMPLE** COMPLEX ZA(l00,100) , ZE(l00) ,ZEV(l00,l00) DIMENSION IND(100) , VW(l00) , IVW(100) l0 READ(5,500) N IF(N. EQ. 0) STOP READ(5,510) ( (ZA(1, J) , I= l, N) , J =1, N) WRITE(6,600) N DO 20 I=1, N 20 WRITE(6,610) (I, J, ZA (I,J), J=1, N) CALL CEIG2(ZA, 100, N, ZE, ZEV, * VW, IVW, ICON) WRITE(6,620) ICON IF(ICON. GT. 10000) GO TO l0 DO 30 I=1, N 30 IND(I) =1 CALL CNRML(ZE, ZEV, 100, N, IND, N, 1, ICON) CALL CEPRT(ZE, ZEV, 100, N, IND, N) GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(lHl,5X, 15HORIGINAL MATRIX, * 5X, 2HN= , I3/) 610 FORMAT(/2(5X, 2HA(,I3,1H, ,I3,2H) =, 2E15.7)) 620 FORMAT(lHO, 20X, 5HICON=, I5) END
(1.1) (1.2)
The subroutine CEPRT used in this exampl, prints the eigenvalues and corresponding eigenvectors of a complex matrix. For further information see an example of using the subroutine CEIG2. Method Given m eigenvectors xi (i=1, ..., m) ofan n-order complex vector, normalized eigenvectors yi are computed. Where xi = (xli , , xni)T When MODE=1 is specified. each vector xi is normalized such that the maximum absolute valui among the elements of each vector becomes 1 .
283
CNRML
yi = xi xi
, xi
= max xki k
(4.1)
When MODE=2 is specified, each vector xi is normalized such that the sum of the square of absolute values corresponding to its elements is 1. yi = xi xi 2 , xi = xki
k =1 n 2
(4.2)
284
COSI
CALL COSI (X, Cl, ICON) Function This subroutine computes Cosine integral Ci ( x) =
STOP 600 FORMAT(1Hl, 27HEXAMPLE OF COSINE INTEGRAL , * 8HFUNCTION///6X, 1HX, 9X, 5HCI (X) / ) 610 FORMAT(lH , F8.2, E17.7) 620 FORMAT(lH ,llH** ERROR **, 5X, 2HX= ,E17.7, * 5X, 3HCI = , E 17.7, 5X, l0HCONDITION = , I10) END
cos(t ) dt t
Methods Two different approximation formulas are used depending on the ranges of x divided at x= 4. Since Ci(x)=Ci(-x), the following discussion is limited to the case in whic x > 0. For 0 < x< 4 The power series expansion of Ci (x), Ci ( x ) =
by series and asymptotic expansions. where x 0. If x < 0, cosine integral Ci (x) is assumed to take a principal value. Parameters X ..... Input. Independent variable x. CI ..... Output. Value of Ci (x). ICON ... Output. Condition codes. See Table COSI-I
Table COSI-1 Condition codes Code 0 20000 30000 Meaning No error |x| tmax x=0 Processing CI = 0.0 CI = 0.0
( 1) x + log(x ) + (2n)!2n
n n=1
2n
(4.1)
(4.2)
Comments on use Subprograms used SSL II ... MGSSL, UTLIM FORTRAN basic functions . .. ABS, SIN, COS, and ALOG Notes The valid ranges of parameter X are: X < tmax This is provided because sin (x) and cos (x) lose their acduracy, if X exceeds the above ranges. Example The following example generates a table of Ci (x) from 0.1 to l0.0 with increment 0.1.
C **EXAMPLE** WRITE (6, 600) DO 10 K=1,100 X=FLOAT (K) /10.0. CALL COSI (X,CI, ICON) IF (TCON.EQ. 0) WRITE (6,610) X,CI IF (ICON.NE. 0) WRITE (6,620) X,CI, ICON 10 CONTINUE
(4.3)
is calculated through use of the following approximate expression for P(x) and Q(x): Single precision: P( x ) = a k z k , z = 4 x
11 k =0 11
(4.5) (4.6)
Q( x ) = bk z k , z = 4 x
k =0
Double precision: P( x ) = a k z k bk z k , z = 4 x
11 11 k =0 k =0
(4.7) (4.8)
Q( x ) = ck z k +1 d k z k , z = 4 x
10 11 k =0 k =0
285
CQDR
Method The roots of complex quadratic equation a0x2 + a1z + a2 = 0 can be obtained from
2 2 P P 4P2 , P 4P2 P 1 + 1 1 1
CALL CQDR (Z0, Z1, Z2, Z,ICON) Function This subroutine finds zeros of a quadratic equation with complex coefficients: a 0 z 2 + a1 z + a 2 = 0 a 0 0
where P1 = a1 a0 and P2 = a2 a0 If
2 P 1 >> 4 P 2
Parameters Z0, Zl, Z2 ..Input. Coefficients of the quadratic equation. Complex variables where Z0 = a0, Zl = a1 and Z2 = a2 Z ..... Output. Roots of the quadratic equation. Z is a complex one-dimensional array of size 2. ICON .. Output. Condition code.
Table CQDR-1 Condition codes Code 0 10000 Meaning No error |a0| = 0.0 Processing -a2/a1 is stored in Z (1). Z(2) may be invalid. Bypassed
formulas with rationalized numerators, as shown below, are used in calculations. Let D = P12 4 P2 When D = 0 z1=P1/2 z2=P1/2 When D 0 let the real part of P1 be x and the imaginary part be y. for x > 0 z1 = P1 D 2 z 2 = 2 P2 for x < 0 z1 = 2 P2 z2
1
30000
Comments on use Subprograms used SSL II ...MGSSL FORTRAN basic functions ... CSQRT, REAL, AIMAG, and ABS Example. Complex coefficients are entered and the roots z are determined.
C **EXAMPLE** DIMENSION Z(2) COMPLEX Z0, Z1, Z2,Z READ(5,500) Z0, Zl, Z2, CALL CQDR(Z0, Zl, Z2, Z,ICON) WRITE(6,600) ICON, Z0, Z1, Z2 IF(ICON.EQ.30000) STOP WRITE(6,610) (Z(I), I=1,2) STOP 500 FORMAT(6F10.0) 600 FORMAT(l0X,5HICON=, 15/l0X, 2HA=, 2E15.6/ * (12X, 2E15, 6)) 610 FORMAT(10X, 2HZ=, 2E15.6/12X, 2E15.6) END
(P + D )
1
( P + D ) = ( P + D ) 2
1
(4.1)
for x= 0 z1 = P1 D 2 z2 = 2 P2 z1 = 2 P2 z2
( P + = ( P + D ) 2
1 1
y 0 P D 1 +
) D ) y < 0
(4.3)
In the calculation of discriminant D=P124P2 if |P1| is very large, P12 may cause an overflow. In order to avoid this situation, the real and imaginary parts of Pl are tested to see if they are greater than l035. The above methods are used when those conditions are not satisfied, otherwise the following used. D = P1 1 4 P2 P1 P1
286
CSBGM
CALL CSBGM (ASB, N, NH, AG, K, ICON) Function This subroutine converts an n n real symmetric band matrix with band width h stored in the compressed mode into that stored in the general mode, where n > h 0. Parameters ASB .... Input. The symmetric band matrix stored in the compressed mode One-dimensional array of size n(h+1) h(h+1)/2 N....... Input. The order n of the matrix. NH..... Input. The width h of the matrix. AG..... Output. The symmetric band matrix stored in the general mode Two-dimensional array, AG (K, N). (See Comments on Use.) K ........ Input. The adjustable dirmension ( N) of array AG. ICON . Output. Condition code. (See Table CSBGM1.)
Table CSBGM-1 Condition codes Code 0 30000 Meaning No error. NH < 0, N NH, or K < N. Processing Bypassed.
Example Given an n n real symmetric band matrix with band width h , the inverse matrix is obtained using subroutines ALU and LUIV, where mode conversion is performed by this subroutine, where n 100 and h 20.
c **EXAMPLE** DIMENSION ASB(1890),AG(l00,100),VW(l00),IP(l00) EQUIVALENCE(ASB(1), AG(l,1)) 10 READ(5,500) N, NH IF(N. EQ.0) STOP NT= (NH+ 1)*(N+N-NH)/2 READ(5,510) (ASB(1),I =1,NT) K = 100 CALL CSBGM(ASB, N, NH, AG, K, ICON) WRITE(6, 600) ICON IF(ICON. EQ. 30000) GO TO l0 WRITE(6,610)N,NH,((I,J,AG(I, J),J=l,N),I=l,N) EPSZ = 0. 0 CALL ALU(AG,K,N,EPSZ,IP,IS,VW,ICON) WRITE(6, 620) ICON IF(ICON. GE. 20000) GO TO 10 CALL LUIV(AG, K, N, IP, ICON) WRITE(6, 630) ICON WRITE(6, 6 4 0 )N ,N H ,( ( I ,J ,A G ( I ,J ) ,J =l ,N ) ,I =l ,N ) GO TO l0 500FORMAT(215) 510FORMAT(4E15. 7 ) 600FORMAT(lHl/l0X,11HCSBGM ICON = , 15) 610FORMAT(//l0X, 18H** INPUT MATRIX * */ * l0X, 6HORDER=,I5,5X,l0HBANDWIDTH=,I5/ * (2X, 4(1H(, I3, 1H), E17. 8))) 620FORMAT(/l0X, 9HALU ICON = , I5 ) 630FORMAT(/l0X, l0HLUIV ICON=, I5) 640FORMAT(lHl//l0X, 20H** INVERSE MATRIX ** / * l0X,6HORDER=,I5,5X,l0HBANDWIDTH=,I5/ * (2X, 4(1H(,I3,1H, ,I3,1H),E17. 8))) END
Comments on use Subprograms used SSLII ... MGSSL FORTRAN basic functions ... None Notes Storing method of the symmetric band matrix in the general mode: The symmetric band matrix in the general mode transformed by this subroutine contains not only the lower band and diagonal portions but also the upper band portion and other elements (zero elements). Saving the storage area: If there is no need to keep the contents on the array ASB, more storage area can be saved by using the EQUIVALENCE statement as follows.; EQUIVALENCE (ASB (1), AG (1, 1)) (See Example for details.)
Method A real symmetric band matrix stored in a onedimensional array ASB in the compressed mode is converted as follows to be a symmetric band matrix in a two-dimensional array in the general mode : The elements of the ASB are moved to the diagonal and upper triangular portions of the AG in descending element number order, beginning from the last element (of column n). The correspondence between locations is shown below.
Elements in the compressed mode Matrix elements Elements in the general mode
ASB (hJ h(h + 1) 2 + I) aij AG(I,J) I = J,J 1, , J h, J = N, N 1, h + 2 aij AG(I, J) ASB (J(J 1) 2 + I) I = J,J 1,
,1
, J = h + 1, h, ,1
287
CSBGM
The lower triangular portion is copied by the upper triangular portion using the diagonal as the axis of symmetry so as to be AG (I, J) = AG(J, I), where I>J.
288
CSBSM
All-50-0201 CSBSM, DCSBSM Storage mode conversion of matrices (real symmetric band to real symmetric) CALL CSBSM (ASB, N, NH, AS, ICON) Function This subroutine converts an n n symetric band matrix with band width h stored in the compressed mode for symmetric band matrix into that stored in the compressed mode for symmetric matrix, Where n>h0. Parameters ASB .... Input. The symmetric band matrix stored in the compressed mode for symmetric band matrix. One-dimensional array of size n(h+1) h(h+1)/2. N ...... Input.The order n ofthe matrix. NH ..... Input. Band width h of the symmetric band matrix. AS ..... Output. The symmetric band matrix stored in the oompressed mode for symmetric matrix. One-dimensional array of size n(n +1)/2 . (See Comments on Use.) ICON Output. Condition code. (See Table CSBSMI.)
Table CSBSM-1 Condition codes Code 0 30000 Meaning No error. NH < 0 or NH N. Processing Bypassed.
matrix with band width h stored in the compressed mode, for symmetric band matrix the inverse matrix is obtained using subroutines SLDL and LDIV, where the mode conversion is performed by this subroutihe. Where n 100 and h 20.
c **EXAMPLE** DIMENSION AS(5050), ASB(1890) EQUIVALENCE(AS (1), ASB(1)) l0 READ(5,500) N, NH IF(N. EQ. 0) STOP NS=(N+1)*N/2 NT=(NH+1)*(N+N-NH)/2 READ(5,510) (ASB(I), I=1, NT) CALL CSBSM(ASB,N,NH,AS,ICON) WRITE(6,600) ICON IF(ICON.EQ. 30000) GO TO l0 WRITE(6,610)N, NH,(I,AS(I),I =1,NS) EPSZ = 0.0 CALL SLDL(AS,N,EPSZ,ICON) WRITE,(6,620) ICON IF(ICON. GE. 20000) GO TO 10 CALL LDIV(AS, N, ICON) WRITE(6,630) ICON IF(ICON. GE. 20000) GO TO 10 WRITE(6,640) N, NH, (I,AS(I),I=1,NS) GO TO 10 500 FORMAT(2I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1/lOX,11HCSBSM ICON=,I5) 610 FORMAT(//l0X,18H** INPUT MATRIX **/ * l0X,6HORDER=,I5,5X,l0HBANDWIDTH=,I5/ * (2X, 5(lH(,I4,1H),E17.8))) 620 FORMAT(/10X, 10HSLDL ICON=, I5) 630 FORMAT(/10X. 10HLDIV ICON=, I5) 640 FORMAT(lHl//l0X, 20H** INVERSE MATRIX**/ * 10X, 6HORDE=,I5,5X,l0HBANDWIDTH=,15/ * (2X,5(1H(,I4,1H),E17.8))) END
Comments on use Subprograms used SSL II ...MGSSL FORTRAN basic functions ... None Notes Saving the storage area: If there is no need to keep the contents on the array ASB, more storage can be saved by using the EQUIVALENCE statement as follows ; EQUIVALANCE (ASB (1), AS (1)) (See Example for details.) Example Given an n n positive-definite symmetric band
Method A real symmetric band matrix stored in a onedimensional array ASB in the compressed mode for symmetric band matrix is converted as follows to be stored in one-dimensional array AS in the symmetric matrix compressed mode for symmetric matrix. The elements are moved in column wise, where zero elements are stored outside the band portion. The correspondence between locations other than these zero elements are shown below.
Elements in the compressed mode for symmetric band matrix Matrix elements Elements in the compressed mode for symmetric matrix
ASB (I(I 1) 2 + J ) aij AS(I(I 1) / 2 + J) ,J = 1,2, , I = 1,2, , h + 1 ASB (I h + J h( h + 1) / 2) aij AS(I(I 1) / 2 + J)) ,J = I, I 1 , I h, I = N, N + 1,
h + 2
289
CSGM
CALL CSGM (AS, N, AG, K, ICON) Function This subroutine converts an n n real symmetric matrix stored in the compressed mode into a symmetric matrix stored in the general mode. n l. Parameters AS ... Input. The symmetric matrix stored in the compressed mode. AS is a one-dimensional array of size n (n+1) / 2. N ... Input. The order n of the matrix. AG ... Output. The symmetric matrix stored in the general mode. AG is a two dimensional array, AG (K,N). K ... Input. The adjustable dimension ( N) of array AG ICON.. Output. Condition codes. See Table CSGM-1.
Table CSGM-1 Condition code Code 0 30000 Meaning No error N < 1 or K < N Processing Bypassed
** EXAM PLE ** DIMENSION A(5050),B(100,100), VW(100),IP(100) EQUIVALENCE (A(1),B(1,1)) 10 READ(5,500)N IF(N.EQ.0)STOP NT= N *(N+1)/2 READ(5,510) (A(I),I=1,NT) K=100 CALL CSGM(A,N,B,K,ICON) WRITE(6,600)ICON IF(ICON.EQ.30000)GOTO 10 WRITE(6,610)N,((I,J,B(I,J),J=1,N),I=1,N) EPSZ =0 .0 CALL ALU(B,K,N,EPSZ,IP,IS,VW,ICON) WRITE (6,620)ICON IF(ICON .GE. 20000)GOTO l0 CALL LUIV(B, K, N, IP, ICON) WRITE (6,630) ICON WRITE(6,640)N,((I,J,B(I,J),J=1,N),I=1,N) GOTO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1/10X. l0HCSGM ICON=, I5) 610 FORMAT(//10X, 18H** INPUT MATRIX **/ * 10X,6HORDER=,15/(2X,4(1H(,I3,1H,,I3,1H), * E17 .8))) 620 FORMAT(/10X, 9HALU ICON=, I5) 630 FORMAT(/10X, 10HLUIV ICON=, I5) 640 FORMAT(1H1//l0X,20H** INVERSE MATRIX **/ * 10X,6HORDER=,I5/(2X,4(1H(,I3,1H,,I3,1H), * E17.8))) END
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... none Note The symmetric matrix in the general mode: The symmetric matrix in the general mode transformed by the subroutine contains not only the lower trianguler portion and the diagnoal portion but also the upper triangular portion. Saving the storage area: If there is no need to keep the contents on the array AS, more storage area can be saved by using the EQUIVALENCE statement as follows; EQUIVALENCE (AS(1), AG(1,1)) Refer to the example shown below. Example Given an n n real symmetric matrix in the compressed mode, the inverse matrix is obtained by subroutines ALU and LUIV as shown in the example. In this case, the required mode conversion is performed by this subroutine. Here, n l00.
Method This subroutine converts an n n real symmetric matrix stored in a one-dimensional array AS in the compressed mode to in a two-dimensional array in the general mode acccording to the following procedures. The elements stored in AS are transferred to the diagonal and upper triangular portions serially from the largest address, i.e. the n th column. The correspondence between locations is shown below, where NT = n (n + 1 ) / 2.
Elements in compressed mode AS(NT) AS(NT-1) . . . AS(I(I-1)/2+J) . . . AS(2) AS(1) Elements of matrix ann ann-1 . . . aij . . . a21 a11 Elements in general mode AG(N,N) AG(N-1,N) . . . AG(J,I) . . . AG(1,2) AG(1,1)
With the diagonal as the axis of symmetry, the elements of the upper triangular portion are transferred to the lower triangular portion so that AG(I,J) = AG(J,I). Here, I>J.
290
CSSBM
performed using subroutine SBDL in the compressed mode for symmetric band matrix, where the mode conversion is performed by this subroutine. Where n 100 and h 20.
* * EXAMPLE* * DIMENSION AS(5050). ASB(1890) EQUIVALENCE(AS(1), ASB(1)) 10 READ(5,500) N,NH IF(N.EQ.0) STOP NT= (N+ l) * N/2 READ(5,510) (ASI), I=1, NT) WRITE(6,600) N, NH, (1, ASI), I=1, NT) CALL CSSBM (AS, N, ASB. NH, ICON) WRITE(6,610) ICON IF(ICON. EQ. 30000) GO TO 10 EPSZ=0.0 CALL SBDL(ASB, N, NH, EPSZ, ICON) WRITE(6,620) ICON IF(ICON. GE.20000) GO TO 10 CALL CSBSM (ASB, N, NH, AS, ICON) WRITE(6,630) N, NH, (I, ASI), I=l, NT) GO TO 10 500 FORMAT (2I5) 510 FORMAT(4E15.7) 600 FORMAT(//l0X, 18H** INPUT MATRIX ** / * 10X, 6HORDER=, I5 , 5X, l0HBANDWIDTH=, I5/ * (2X, 5 (1H(,I4, 1H), E11.8))) 610 FORMAT (1Hl//10X. 11HCSSBM ICON=, I5) 620 FORMAT (10X. 10HSBDL ICON=,I5) 630 FORMAT(1H1/l0X, 11HDECOMPOSED MATRIX/ * 10X, 6HORDER=, I5, 5X, 10HBANDWIDTH=, I5/ * (2X, 5(1H(, I4, 1H) , E17.8))) END
Function This subroutine converts an n n real symmetric band matrix with band width h stored in compressed mode for symmetric matrix into one stored in compressed mode for symmetric band matrix, where n h 1. Parameters AS ..... Input. The symmetric band matrix stored in compressed mode for symmetric matrix. One-dimensional array of size n (n + 1)/2. N ...... ASB ... Input. The order n of the matrk. Output. The symmetric band matrix stored in compressed mode for symmetric band matrix One-dimensional array of size n (h + 1 ) - h (h + 1)/2. Input. Band width h of the symmetric band matrix. Output. Condition code. (See Table CSSBM1).
NH ... ICON ..
Table CSSBM-1 Condition codes Code 0 30000 Meaning No error NH < 0 or NH N. Processing Bypassed.
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... None. Notes Saving the storage area: If there is no need to keep the contents on the array AS, more storage area can be saved by using the EQUIVALENCE statement as follows; EQUIVALENCE (AS (1), ASB (1)) (See Example for details.) Example Given an n n positive-definite symmetric band matrix vith band width h stored in compressed mode for symmetric band matrix, the LDLT decomposition is
Method A real symmetric band matrix stored in onedimensional, array AS in the compressed mode for symmetric matrix is converted as follows to be stored in one-dimensional array ASB in the compressed mode for symmetric band matrix. The elements are moved in column wise as follows:
Elements in the compressed mode for symmetric matrix Matrix elements Elements in the compressed mode for symmetric band matrix
ASB(I h + J h(h + 1) 2)
,J = I h, I h + 1, , I ,I = h + 2, h + 3, , N
291
CTSDM
Table CTSDM-1 Condition codes Code 1 2 10 11 Meaning Zi satisfied Criteria I. (See parameter ISW.) Zi satisfied Criteria II. (See aprameter ISW.) The iteration was repeated m times (M=-m) Although M=-m on input the iteration stopped because |f (zi)|=0 was satisfied during iterations and zi was taken as a root. Although M=-m on input the iteration stopped because |zj-zj-1|u|zj|was satisfied during iteration and zi was taken as a root. Specified criterion was not met during the specified number of iteration. A certain difficulty occurred, so iteration could not be continued. (See notes.) Error(s) in parameter setting. When M>0. 1 ISW=1 and EPS<0, or 2 ISW=2 and ETA<0, or 3 ISW=3 and EPS<0 and/or ETA<0. or when M = 0, or ISW1, 2 or 3. Processing Normal return Normal return Normal return Normal return
CALL CTSDM (Z, ZFUN, ISW, EPS, ETA, M, ICON) Function This subroutine finds a zero of a complex function f (z) = 0 by Mullers method An initial approximation to the zero must be given. Parameters Z ..... Input. An initial value to the zero to be obtained. ZFUN .. Input. The name of the complex function subprogram which evaluates the function f(z). ISW ... Input. Control information. The user assigns one value from ISW= 1,2 and 3 to define the convergence criterion. ISW = l. When ISW=1, zi becomes the root if it satisfies the condition f ( zi ) EPS: Criterion I When ISW=2, zi becomes the root if it satisfies zi zi 1 ETA zi : Criterion II When ISW=3, zi becomes the root if either of the criteria described obone are satisfied. EPS ... Input. The tolerance used in Criteria l. (See parameter ISW.) EPS 0.0. ETA .... Inpuf. The tolerance used in Criteria II. (See parameter ISW.) ETA 0.0. M ..... Input. The upper limit of iterations ( > 0) (See Notes.) Output. The number of iterations executed. ICON ... Output. Condition codes. See Table CTSDM-1. Comments on use Subprograms used SSL II ... MGSSL,, AMACH, AFMAX and AFMIN FORTRAN basic functions ... CABS, CMPLX, EXP, ALOG, CSQRT, SQRT, REAL and AIMAG Notes The complex function subprogram associated with argument ZFUN must be declared by the EXTERNAL statement in the calling program. Iterations are repeated m times unconditionally, when M is set equal to M = -m (m > 0). However, the iteration will stop during iterations
12
Normal return
10000
20000
30000
Bypassed
when the lefthand side of the Criteria I is equal to 0.0, or the lefthand side of the Criteria II is smaller than or equal to the round-off level. Example One root of f(z) = ez-i is obtained with initial value z0 = 0.
C **EXAMPLE** COMPLEX Z, ZFEXP EXTERNAL ZFEXP Z=CMPLX(0.0, 0.0) ISW=3 EPS=0.0 ETA= 1.0E-6 M=100 CALL CTSDM(Z, ZFEXP, ISW, EPS, ETA, M, * ICON) WRITE(6,600) ICON, M, Z STOP 600 FORMAT(10X, 5HICON=, I5/13X, 2HM= , I5/ * 13X, 2HZ=, 2E15.7) END FUNCTION ZFEXP(Z) COMPLEX Z, ZFEXP ZFEXP= CEXP (Z) - CMPLX (0.0, 1.0) RETURN END
292
CTSDM
Method The subroutine uses Mullers method. The method uses a interpolating polynomial P(z) of degree two which approximates f(z) near a root. This algorithm has the following features. Derivatives of f(z) are not required. The function is evaluated only once at each iteration. The order of convergence is 1.84 (for a single root). Muller method Let be a root of f(z) and let three values zi -2,zi -1 and zi be approximations to the root (See later for initial values z1, z2,and z3). According to Newtons interpolation formula of degree two, f(z) is approximated around the three values as follows: P( z ) = f1 + f [zi , zi1 ]( z z i )
In (4.1), wheh the both terms of z and z2are null, P(z) reduces to a constant and defeats the Muller algrorithm (See later Considerations of Algorithm.) Initial values. zl, z2and z3 Let the initial value set by the user in input parameter Z be z when |z| 0. z1 = 0.9 z z2 = 1.1 z z 3 = z when |z|0 z1 = 1.0 z2 = 1.0 z = 0.0 3 When f(zi -2) = f(zi -1) = f(zi ) In this case, Mullers method will fail to continue iterations because both terms of z2 and z in (4.1) vanish. The subroutine perturbs zi -2, zi -1 and zi so that the subroutine may get out of the situation f(zi -2) =.f(zi -1 ) = f (zi ) zi2 = (1 + p n )zi2 zi1 = (1 + p n )zi1 zi = (1 + p n )zi
(4.1)
where fi =f(zi ) and f[xi ,zi -1],f[zi, zi -1,zi -2] are the first and the second order divided differences of .f(z) respectively and defined as follows. f f i1 f [zi , zi1 ] = i zi zi1 f [zi , zi1 ] f [zi 1 , zi2 ] f [zi , zi1 , zi 2 ] = zi zi2 P(z) = 0 is then solved and the two roots are z = zi
(4.2)
2 fi
(4.3)
where p = -u-1/10, and u is the round-off unit, and n is the number of times of perturbation. If the perturbation continues more than five times, this subroutine will terminate unsuccessfully with ICON =20000. Convergence criterion Two condition are considered. Condition I When zi satisfies f ( zi ) EPS. it is taken as a root. Condition II When zi satisfies zi zi 1 ETAN zi , it is taken as a root. When the root is a multiple root or very close to another root, ETA must be set sufficiently large. When EPS < u (u is the round-off unit), the subroutine will increase EPS as equal to u. For further details, see Reference [32]
Of these two roots of P(z)= 0, the root closer to zi is taken as the next approximation zi +1. In (4.1) when the term of z2 js zero, that is when f[zi,zi -1,zi -2] = 0, in stead of (4.3) the following formula is used. z = zi fi f [zi , zi1 ]
z z = zi i i1 f i f i f i1
(4.4)
293
ECHEB
CALL ECHEB (A, B, C, N, V, F, ICON) Function Given an n-terms Chebyshev series f(x) defined on interval [a, b] 2x (b + a) f ( x ) = ' ck Tk k =0 b a
n 1
Example This example uses the subroutine FCHEB for series expansion of the sine function x 2 n +1 n f ( x ) = sin x = ( 1) (2n + 1)! n =0 in the interval [0, ]. Precision requirements ... Absolute error 5N10-5. By using the resultant expanded coefficients this subroutine evaluate Chebyshev series at 32 Chebyshev points as follows: xj =
(1.1)
this subroutine obtains value f(v) at arbitrary point v in the interval. Symbol denotes the initial term only is taken with factor 1/2. ab, v [a,b] and n l. Parameters A Input. Lower limit a of the interval for the Chebyshev series. B Input. Upper limit b of the interval for the Chebyshev series. C Input. Coefficients {ck}. C is a one dimensional array of size n. Coefficients are stored as shown below: C(1) = c0, C(2)=c1, ..., C(N)= cn-1 N Input. Number of terms n of the Chebyshev series. V Input. Point v which lies in the interal [a, b]. F Output. Value f(v) of the Chebyshev series. ICON Output. Condition code. See Table ECHEB1.
Table ECHEB-1 Condition codes Code 0 30000 Meaning No error One of the following occurred: 1 N<1 2A=B 3 v [a, b] Processing Bypassed
Comments on use Subroutine used SSL II ... MGSSL FORTRAN basic functions ... None Notes This subroutine obtains value f(v) of a Chebyshev series. The subroutine FCHEB can be utilized for Chebyshev series expansion of arbitrary smooth function f(x).
294
ECHEB
XP=X*p XN=-6.0 N=3 10 TERM=XP/XN SUM=SUM+TERM IF(DABS(TERM).LE.EPS) GO TO 20 N=N+2 XP=XP*P XN=-XN*FLOAT(N)*FLOAT(N-1) GOTO 10 20 FUN=SUM RETURN END
bn + 2 = bn +1 = 0 bk = 2vbk +1 bk + 2 + c k , k = n, n 1,
(4.1)
the value f(v) of the Chebyshev series can be obtained by the following expression: f (v ) = (b0 b2 ) 2 (4.2)
Method The value of an n -terms Chebyshev series (1.1) is obtained by the backward recurrence formula. Backward recurrence formula To obtain the value f(v) of Chebyshev series f ( x ) = ' ck Tk ( x )
k =0 n 1
at the interval [-1,1], the following adjoint sequence {bk} is effective. If {bk} is defined as:
Then it obtains Chebyshev series value f(v) by using (4.1) and (4.2). The number of multiplications required to evaluate the value of an n-terms Chebyshev series is approximately n.
295
ECOSP
CALL ECOSP (TH, A, N, V, F, ICON) Function Given an n-terms cosine series with period 2T f (t ) =
when x= h , 2h , ..., l0h . However h = /(10). Since this integrand is an odd function with period 2/ it is expanded at first in a sine series by the subroutine FSINF according to the required precision of a = r = 5N10-5 : f (t ) bk sin kt
k =0 n 1
(3.2)
1 a 0 + a k cos kt k =1 T 2
n 1
this subroutine obtains the value f(v) for arbitrary point v. T> 0 and n l. Parameters TH..... Input. Half period T of the cosine series. A..... Input. Coefficients {ak}. A is a one-dimensional array of size N. Each coefficient is stored as shown below: A(1) = a0, A(2) = al, ..., A(N) = an-1 N..... Input. Number of terms n of the cosine series. V..... Input. Point v. F..... Output. Value.f (v) of the cosine series. ICON... Output. Condition code. See Table ECOSP-1.
Table ECOSP-1 Condition codes Code 0 30000 Meaning No error Either the two occurred. 1 N<1 2 TH 0 Processing Bypassed
b ak = k , k = 1,2, k
,n 1
(3.3)
However the initial term a0 is determined to satisfy F(0) = 0. At this stage the subroutine ECOSP can be called to obtain an approximate value for indefinite integral (3.1) when x = h , 2h , ..., 10h . Since this analytical solution is F ( x) = 1 1 sin cos t 4
Comments on use Subroutine used SSL II ... MGSSL FORTRAN basic functions ... COS, ATAN Notes This subroutine obtains value f(v) of a cosine series. The FCOSF subroutine can be utilized when smooth even function f(t) with period 2 T is subject to cosine series expansion. Example This example integrates an odd function with parameter F ( x ) = 0 dt 1 + sin2 t , = , , ,2 ,4 4 2
x
sin t
(3.1)
296
ECOSP
Q=TRFN(X) WRITE(6,611) X,P,Q 3 CONTINUE W=W+W 1 CONTINUE STOP 10 WRITE(6,620) ICON STOP 600 FORMAT(1H0,5X,12HEXPANSION OF, * 10H INTEGRAND,3X,2HN=,I4,5X,4HERR=, * E15.5,5X,5HICON=,I5,5X,2HW=,E15.5) 601 FORMAT(/ (5E15.5)) 610 FORMAT(1H0,5X,13HEVALUATION OF, * 14H COSINE SERIES/1H0.6X, * 8HAUGUMENT,7X,8HCOMPUTED,11X,4HTRUE) 611 FORMAT(3E15.5) 620 FORMAT(1H0,5X,14HCONDITION CODE,I6) END FUNCTION FUN(T) COMMON W X=W*T P=SIN(X) FUN=P/SQRT(P*P+1.0) RETURN END FUNCTION TRFN(T) COMMON W,PI TRFN=(PI*.25-ASIN(CQS(W*T)*SQRT(0.5)))/W RETURN END
Method This subroutine obtains a value of an n-terms cosine series (1.1) by using a backward recurrence formula. Upon choosing
t T
f(t) = g () leads to a cosine series with peritd 2. Therefore the value of g() can be obtained when
v T
is satisfied it can be calculated efficiently throuhg use of the backward recurrence formula (4.1). bn+ 2 = bn+1 = 0 bk = 2 cos bk +1 bk +2 + a k k = n, n 1, ,1,0
(4.1)
The value of an n-terms cosine series can be obtained by (4.2). f (v ) = g( ) = (b0 b1 ) 2 (4.2)
The number of multiplications required to evaluate the value of an n-terms cosine series is approximately n. The cosine function is evaluated only once.
297
EIG1
CALL EIGl (A, K, N, MODE, ER, EI, EV, VW, ICON) Function All eigenvalues and corresponding eigenvectors of an norder real matrix A are determined. The eigenvectors are normalized such that x 2 = l. n l. Parameters A ....... Input. Real matrix A. A is a two-dimensional array, A (K, N). The contents of A are altered on output. K ....... Input. The adjustable dimension of arrays A and EV. N ....... Input. Order n of A. MODE ... Input. Specifies balancing. MODE=1... Balancing is omitted. MODE1... Balancing is included. ER,EI ..... Output. Eigenvalues Eigenvalues are divided into their real and imaginary parts. The real part is stored in ER, and the imaginary part is stored in EI. If the jth eigenvalues is complex, the (j+1)th eigenvalues is its complex conjugate (refer to Fig. EIG1-1). ER AND EI are onedimensional arrays of size n. EV ....... Output. Eigenvectors. Eigenvectors are stored in the columns which correspond to their eigenvalues. If an eigenvalue is complex, its eigenvector is also complex; such eigenvectors are stored as shown in Fig. 4.2. For details see Comments on use. EV is a two-dimensional array, EV (K,N). VW ....... Work area. Used during balancing and reducing matrix A to a real Hessenberg matrix. VW is a one-dimensional array of size n. ICON ..... Output. Condition code. Refer to Table 4.6.
Table 4.6 Condition codes Code 0 10000 Meaning No error N=1 Processing ER (1) = A (1, 1), EV (1,1) = 1.0 Discontinued
Comments on use Subprograms used SSL II ... AMACH, BLNC, IRADIX, HES1, and MGSSL FORTRAN basic functions ... ABS, SQRT, SIGN, and DSQRT.
1 2 3 4 5 6 (1) (2) (3) (4) (5) ( 6)
Array ER
4 4
Array EI
0.0
0.0
0.0
0.0
Array EV The real eigenvector for 1. The real eigenvector for 2. The real eigenvector for 3. The real part of the complex eigenvector for 4. (u4) The imaginary part of the complex eigenvector for 4.( v4) The real eigenvector for 5.
Notes Complex eigenvalues and corresponding eigenvectors In general, real matrices have real eigenvalues and complex eigenvalues. Complex eigenvalues become pairs of conjugate complex eigenvalucs. In this routine, if the jth eigenvalue (j ) is a complex eigenvalue, and *j are stored in ER and EI in the following way.
20000
30000
Eigenvalues and eigenvectors could not be determined since reduction to a triangular matrix was not possible. N < 1 or K < N
Bypassed
298
EIG1
Therefore if real part uj and imaginary part vj of x are obtained, x can easily be determined. Consequently, in this subroutine, only eigenvector xj which corresponds to j is calculated. Real part uj of xj is stored in the Jth column of EV, and imaginary part vj is stored in the (J+1)th column. Refer to Fig. 4.2. If the magnitude of each element in a real matrix varies greatly, the precision of the result can be improved by balancing the matrix with subroutine BLNC. Balancing will produce minimal improvement if the magnitude of each element in a matrix is about the same and should be skipped by setting MODE=1. This subrotine is used to obtaine all eigenvalues and corresponding eigenvectors of a real matrix. If all the eigenvalues of a real matrix are desired, BLNC, HES1 and HSQR should be used. If a subset of the eigenvectors of a real matrix is desired, BLNC, HES1, HSQR, HVEC, and HBK1 should be used. Example All eigenvalues and corresponding eigenvectors of a real matrix A of order n are determined. n l00.
C **EXAMPLE** DIMENSION A(100, 100), ER(100), EI(100), * EV(100, 100), VW(100), IND(100) 10 CONTINUE READ(5, 500)N IF(N .EQ. 0) STOP READ(5, 510) ( (A(I,J),I=1,N), J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610)(I,J,A(I,J),J=1,N) CALL EIG1(A,100,N,0,ER,EI,EV,VW,ICON) WRITE(6,620)ICON IF(ICON.GE.20000) GO TO 10 IND(1)=0 CALL EPRT(ER,EI,EV,IND,100,N,N) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT(1H0,5X,15HORIGINAL MATRIX, 5X,2HN=, * I3) 610 FORMAT(/4(5X,2HA(,I3,1H,,I3,2H)=, E15.7)) 620 FORMAT(1H0,5X,5HICON=,I5) END
10 20 30 40
50
IND(I)=0 J=0 GO TO 30 IF(EI(I).NE.0.0) GO TO 20 IND(I)=1 GO TO 30 IND(I)=-1 J=1 CONTINUE MM=0 DO 50 I=1,M IF(IND)(I).EQ.0) GO TO 50 MM=MM+1 ER(MM)=ER(I) IND(MM)=IND(I) IF(EI(I).EQ.0.0) GO TO 50 MM=MM+1 ER(MM)=EI(I) IND(MM)=IND(I+1) CONTINUE KAI=(MM-1)/5+1 LST=0 DO 70 L=1, KAI INT=LST+1 LST=LST+5 IF(LST .GT. MM) LST=MM WRITE(6,610) (J,J=INT,LST) WRITE(6,620) (ER(J),J=INT,LST) WRITE(6,630) (IND(J),J=INT,LST) DO 60 I=1,N WRITE(6,640) I,(EV(I,J),J=INT,LST) CONTINUE CONTINUE RETURN FORMAT(1H1,10X,16H**EIGENVECTORS**) FORMAT(1H0,5I20) FORMAT(1H0,1X,10HEIGENVALUE,5E20.8) FORMAT(2X,3HIND,6X,I10,4I20) FORMAT(6X,I5,5E20.8) END
Method All eigenvalues and corresponding eigenvectors of an norder real matrix A are determined as follows: Using the following two-stage transformation process, the eigenvalues of an n-order real matrix are determined by obtaining the diagonal elements of upper triangular matrix R. Reduction of real matrix A to real Hessenberg matrix H using the Householder method.
T H = QH AQH
In the above example, the subroutine EPRT prints all eigenvalues and corresponding eigenvectors of a real matrix. The contents of EPRT are:
SUBROUTINE EPRT(ER,EI,EV,IND,K,N,M) DIMENSION ER(M),EI(M),EV(K,M),IND(M) WRITE(6,600) IF(IABS(IND(1)).EQ.1) GO TO 40 J=0 DO 30 I=1,M IF(J.EQ.0) GO TO 10
(4.1)
QH is an orthogonal matrix which is the product of the transformation matrices P1, P2, ....., Pn2 used in the Householder method. QH = P1 P2 Pn 2
(4.2)
299
EIG1
Reduction of a real Hessenberg matrix H to an upper triangular matrix R using the double QR method.
T R = QR HQ R
(4.3)
QR is an orthogonal matrix which is the product of the transformation matrices Q1, Q2, ..., Qs used in the double QR method. Q R = Q1 Q2 Qs
where u is the unit round-off The above computations are performed only when all the eigenvalues are real. However, if real matrix A has complex eigenvalues, R cannot become a complete triangular matrix. The elements of matrix R which has complex eigenvalues l1 and l( = l1) are shown in Fig. 4.3. r12 r12 r22 r1l1 r1l r1n rl1n rln rnn
(4.4)
For further information on the double QR method, refer to HSQR. If matrix F, which transforms upper triangular matrix R to diagonal matrix D, in the similarity transformation of (4.5) is available, eigenvectors can be obtained as the column vectors of matrix X in (4.6). D = F 1 RF X = Q H QR F (4.5) (4.6)
To verify that the column vectors of amtrix X in (4.6) are the eigenvectors of real matrix A, substitute (4.1) and (4.3) in (4.5) to obtain (4.7).
T T AQ H Q R F D = X 1 AX = F 1Q R QH
In this case, the procedure to obtain fij becomes complicated. When, in the course of computation fij in (4.10), if a complex eigenvalue i (i = l) is encountered, fij and fj-1j are obtained by solving a system of linear equations (4.12).
(4.7)
(r
(4.12)
P
n 2
Q1 Q2
Q
(4.8)
As shown in (4.8), Q can be computed by repeatedly taking the product of the transformation matrices. X can be obtained by taking the product of Q from (4.8) and matrix F. Transformation matrix F can be determined as an upper triangular matrix as follows: From (4.5), FD = RF (4.9)
In addition, the lth and (l1)th column elements of F becomes complex vectors. However, since l and l-1 are conjugates, their complex vectors are also conjugates of each other. Since, if one of them is determined the other need not be computed, only fij1 (i=l,l1,,1) is obtained corresponding to l1 in this routine. fij1 is determined as follows: That is, for i=land 11, fij1 is determined from (4.13) and for i=12, 13, ...1, fij1 is determined from (4.10). rl 1l (rl1l 1 l 1 ) f l 1l1 = (rll l1 ) rll1 f ll 1 = 1
Let the elements of D, R, and F be represented as D = diag(i ), R = (rij), F=(fij), then elements fij are obtained from (4.9) as in (4.10) for j = n, n- 1, ..., 2. f ij = rik f kj
k =i +1 j
(r (r
ll 1
ll 1
> rl1l )
rl1l ) (4.13)
i )
(i = j 1, j 2,,1)
(4.10)
On computation of fij1 in (4.10), if i and I1 are furthermore a pair of complex conjugate eigenvalues, corresponding fij1 and fi 1j1 are obtained from (4.12). The real part of fij1 is stored in the (l1)th column of F and the imaginary part of fij1 is stored in the lth column.
(4.11)
300
EIG1
From matrix F thus obtained and transformation matrix Q, eigenvectors x of brief description of this procedure follows: X = QF (4.14)
2=
1.
Also, in this routine, a real matrix is balanced using BLNC before it is reduced to a Hessenberg matrix unless MODE=1. For further information, see References [12] and [13] pp 372-395.
301
ESINP
CALL ESINP (TH, B, N, V, F, ICON) Function Given an n-terms sine series with period 2T f (t ) = bk sin
n 1 k =0
(3.2)
kt , b0 = 0 T
this subroutine obtains value f () for arbitrary point . T > 0 and n 1. Parameters TH..... Input. Half period T for the sine series. B..... Input. Coefficients {bk}. B is a one-dimensional array of size N. Each coefficient is stored as shown below: B(1)=0.0, B(2)=bl, ..., B(N)=bn-1 N..... Input. Number of terms n of the sine series. V..... Input. Arbitrary point v. F..... Output. Value f () of the sine series. ICON... Output. Condition code. See Table ESINP-1.
Table ESINP-1 Condition codes Code 0 30000 Meaning No error Either the tow occurred: 1 N<1 2 TH 0 Processing Bypassed
b0 = 0, bk =
ak , k = 1,2, , n 1 k
(3.3)
At this time the subroutine ESINP is called to obtain the approximate value of indefinite integration (3.3) upon choosing x = h, 2h, ..., 10h. Since this analytical solution is F ( x) = sin t 1 sin 1 2 (3.4)
Comments on use Subroutine used SSL II ... MGSSL FORTRAN basic functions ... COS, ATAN, SIN Notes This subroutine obtains value f () of a sine series. The subroutine FSINF should be utilized when smooth odd function f (t) with period 2T is subject to sine series expansion. Example This example integrates an even function having parameter . F ( x ) = 0
x
C *
C 2 C
cos t 1 + cos2 t
dt (3.1)
3 1 10
, = , , ,2 ,4 4 2
when x = h, 2h, ..., 10h. However h = /(10). Since this integrand is an even function with period 2/ it is expanded at first in a cosine series shown in (3.2) by
302
ESINP
600 FORMAT (1H0, 5X, 12HEXPANSION OF, * 10H INTEGRAND, 3X, 2HN=, I4, 5X, 4HERR=, * E15.5, 5X, 5HICON=, I5, 5X, 2HW=, E15.5) 601 FORMAT (/(5E15.5)) 610 FORMAT (1H0, 5X, 13HEVALUATION OF, * 12H SINE SERIES/1H0, 6X, * 8HAUGUMENT, 7X, 8HCOMPUTED, 11X, 4HTRUE) 611 FORMAT (3E15.5) 620 FORMAT (1H0, 5X, 14HCONDITION CODE, I6) END FUNCTION FUN(T) COMMON W X=W*T P=COS(X) FUN=P/SQRT (P*P+1.0) RETURN END FUNCTION TRFN (T) COMMON W TRFN=ASIN (SIN(W*T)*SQRT (0.5))/W RETURN END
(4.1)
Therefore the value of an arbitrary point in the sine series can be obtained by (4.2). f ( ) = g( ) = c1sin (4.2)
Method This subroutine obtains a value of an n-terms sine series shown in (1.1) by using the backward recurrence formula.
The number of multiplications required for evaluation of an n-terms sine series is approximately n. The cosine and sine functions are evaluated only once respectively.
303
EXPI
X 0 Ei (x) and Ei (x) are undefined for x=0. Example The following example generates a table of the function values from 0.01 to 0.50 with increment 0.01.
C **EXAMPLE** WRITE (6,600) DO 10 K=1,50 X=FLOAT(K)/100.0 CALL EXPI(X,EI,ICON) IF(ICON.EQ.0)WRITE(6,610)X,EI IF(ICON.NE.0)WRITE(6,620)X,EI,ICON 10 CONTINUE STOP 600 FORMAT(1H1,31HEXAMPLE OF EXPONENTIAL INTEGRAL, *9H FUNCTION///6X,1HX,9X,5HEI(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,11H** ERROR **,5X,2HX=,E17.7, *5X,3HEI=,E17.7,5X,10HCONDITION=,I10) END
CALL EXPI (E, EI, ICON) Function This subroutine computes the exponential integrals Ei (x) and Ei (x) defined as follows using an approximation formula. For x < 0: E i ( x ) = For x > 0: E i ( x) = P.V.
x t x e e t dt = P. V. dt t t t x e et dt = dt x t t
P.V. means that the principal value is taken at t=0. Where, x0. Parameters X..... Input. Independent variable x. EI..... Output. Function value Ei (x) or Ei (x). ICON..... Output. Condition code. See Table EXPI-1.
Table EXPI-1 Condition codes Code 0 20000 Meaning No error X > log(flmax) or X < log(flmax) Processing EI is set to flmax or EI is set to 0.0. EI is set to 0.0.
Method The approximation formulas to compute Ei (x) and Ei (x), differs depending on the following ranges of x. [-174.673, -4), [-4, -1), [-1, 0), (0, 6], (6, 12], (12, 24], (24, 174.673]. In the following, s= x , t=1/ x . For log(flmax) x < 4 Single precision: 1 + ak t k +1 bk t k Ei ( x ) = te x k =0 k =0
3 3
(4.1)
30000
X=0
Comments on use Subprograms used SSL II ... AFMAX, MGSSL, ULMAX FORTRAN basic functions ... EXP, ALOG, and ABS Notes [Range of argument] X log( flmax ) If X exceeds the above limit, Ei (x) and Ei (x) respectively cause underflow or overflow in calculating ex. The limitation is made so that these difficulties can be avoided beforehand in the subroutine.
(4.2)
(4.3)
304
EXPI
k =0
bk t k
b + + 8 a9 + x
(4.10)
bk s k
(4.5)
(4.11)
(4.6)
bk z k
(4.7)
(4.12)
Theoretical precision = 9.94 digits Where z = x/6, x0=0.37250 7410 Double precision: Ei (x ) = log(x x 0 ) + ( x x 0 ) ak z k
9 k=0 k=0
bk z k
(4.8)
(4.13)
Theoretical precision = 20.76 digits Where z = x/6, x0=0.37250 7410 81366 63446 For 6 < x 12 Single precision: Ei ( x ) = b0 b1 ex + a + x 0 a1 + x a 2 + x b2 b3 + + a3 + x a4 + x
+ +
(4.14)
(4.9)
Theoretical precision = 18.11 digits For more information, see Reference [79] and [80].
305
FCHEB
ERR.... TAB....
CALL FCHEB (A, B, FUN, EPSA, EPSR, NMIN, NMAX, C, N, ERR, TAB, ICON) Function Given a smooth function f(x) on the interval [a, b] and required accuracy and , this subroutine performs Chebyshev series expansion of the function and determines n coeffieients {ck} which satisfy (1.1). 2 x (b + a ) f ( x ) ' c k Tk ba max a , r f ( x ) k =0
n 1
ICON...
Output. Estimate of the absolute error of the Chebyshev series. Output. The trigonometric function table used for series expansion is stored. One-dimensional array whose size is greater than 3 and equal to the following: If a 0 ..... (NMAX-3)/2. If a = 0 ..... NMAX-2. See Notes. Output. Condition code. See Table FCHEB-1.
Code 0 10000
(1.1) Symbol denotes to make sum but the initial term only is multipled by factor 1/2. f can be defined as (1.3) by using function values taken at sample points xj (shown in (1.2)) on the interval [a, b].
xj =
20000
Meaning No error The required accuracy was not satisfied due to roundingoff errors. The required accuracy was far too high.
Processing C contains resultant coefficients. The accuracy of the series is the maximum attainable. Bypassed. C contains coefficients obtained at that time. ERR contains an estimate of absolute error obtained at that time. Bypassed
(1.2) (1.3)
30000
The required accuracy was not satisfied through the number of terms of the series has reached the upper limit.
f = 0max f xj j n 1
( )
Where a b and 0 and 0. Parameters A..... Input. Lower limit a of the interval. B..... Input. Upper limit b of the interval. FUN..... Input. Name of the function subprogram which calculates the function f(x) to be expanded. See Notes. EPSA... Input. The absolute error tolerance . EPSR... Input. The relative error tolerance . Lower limit. NMIN... Input. Lower limit of terms of Chebyshev series (0). The value of NMIN should be specified as (power of 2) + 1. The default value is 9. See Notes. NMAX. Input. Upper limit of terms of Chebyshev series (NMIN). The value of NMAX should be specified as (power of 2) + 1. The default value is 257. See Notes. C..... Output. Coefficients {ck}. Each coefficient is stored as shows below: C(1) = c0, C(2) = c1, ..., C(N) = cn-1 One-dimensional array of size NMAX. N..... Output. Number of terms n of the Chebyshev series (5) The value of N takes as (power of 2) + 1.
One of the following conditions occurred: 1A=B 2 EPSA < 0.0 3 EPSR < 0.0 4 NMIN < 0 5 NMAX < NMIN
Comments on use Subprograms used SSL II ... MGSSL, AMACH, UTABT, UCOSM FORTRAN basic function ... ABS, AMAX1, AMIN1, FLOAT Notes The function subprogram specified by the FUN parameter must be defined as a subprogram having independent variable x only as the argument. The program calling this subroutine must include an EXTERNAL statement specifying the corresponding function name. If a given function contains auxiliary variable, they must be declared by a COMMON statement, which is used to establish an interface with the calling program. Use of the trigonometric function talbe The trigonometric function table is produced only once even when this subroutine is called repeatedly. If it does not contain the
306
FCHEB
trigonometric function values necessary for series expansion, only the necessary values are calculated and added. Therefore, this subroutine should be called without making a change in the trigonometric function table without changing the contents of TAB. This subroutine normally changes the interval of variable from [a, b] to [-1, 1] and expands function f(x) base on the chebyshev polynomials. When the end point a of the interval is zero, this subroutine expands function f(x) base on the shifted Chebyshev polynomials to avoid making an error in calculation (loss of significant digits) while making a change of the variable. However, the coefficients {ck} used the shifted Chebyshev polynomials are the same as those used the Chebyshev polynomials. On such reason, the size of trigonometric function table used internally is (NMAX-3)/2 in case of using the Chebyshev polynomials, on the other hand, (NMAX-2) in case of using the shifted Chebyshev polynomials. If the value of NMIN or NMAX is not equal to power of 2 plus one, the following value is assumed: (maximum power of 2 not exceeding that value) + 1 However, NMAX = 5 is assumed if NMAX is less than 5. The degree of error decrement depends on the smoothness of f(x) and the width of interval [a, b] as the number of terms n increases. When f(x) is an analytical function, the error decreases depending on the exponential function order O (rn), 0 < r < 1. When f(x) has up to k-th continuous derivatives, the error decreases depending on the the rational k a b ). When k = 0 or k = 1, the function order O ( n error cannot be estimated accurately because the number of terms to be expanded in a series increases. Therefore the function to be processed by this subroutine should have, at least, up to 2nd continuous derivatives. Accuracy of the series This subroutine tries to obtain a Chebyshev series which satisfies (1.1) when and are given, = 0 means that f(x) is expanded in a Chebyshev series with its absolute error within . Similarly = 0 means that f(x) is expanded in a Chebyshev series with its relative error within . This purpose is sometimes obstructed by unexpected characteristics of f(x) or an unexpected value of or . For example, when or is extremely small in comparison with computational error in function
evaluations, the effect of rounding-off errors becomes grater, so it is no use to continue the computation even though the number of terms subject to series expansion has not reached the upper limit. In this case, the processing is bypassed after a condition code of 10000 is set to ICON. At this time, the accuracy of the Chebyshev series becomes the attainable limit for the computer used. The Chebyshev series sometimes does not converge within NMAX evaluations. In this case, the coefficient value is an approximation obtained so far and is not always accurate. The processing is bypassed after a condition code of 20000 is set to ICON. To determine the accuracy of Chebyshev series, this subroutine always sets an estimate of absolute error in ERR. When inverse transform is required for Chebyshev series expansion, the subroutine FCOST should be utilized for cosine transform. The inverse transform mean to obtain the function value. n 1 2 x j (b + a ) , j = 0,1, , n 1 f ( xi ) = ' 'ck Tk k =0 ba for a sample point xj, which lies in the interval [a, b] indicated by (1.2). Where symbol denotes the initial and last terms are multiplied by factor 1/2. Therefore only the coefficient cn-1 of the last term must be doubled before the FCOST subroutine is called. During inverse transform, the contents of TAB must be kept intact because the trigonometric function table produced by this subroutine is used by the subroutine FCOST. See Example 2. Examples Example 1 expands exponential function
xn f (x ) = e x = n! n=0
on the interval [-2, 2] in Chebyshev polynomials {Tk(x/2)} according to the required accuracy of = 0 and = 5.10-5. NMIN = 9 and NMAX = 257 is assumed.
C EXAMPLE 1 DIMENSION C (257), TAB (127) EXTERNAL FUN EPSA = 0.0 EPSR = 5.0E-5 NMIN = 9 NMAX = 257 A = -2.0
307
FCHEB
B = 2.0 CALL FCHEB(A, B, FUN, EPSA, EPSR, * NMIN, NMAX, C, N, ERR, TAB, ICON) IF (ICON. GT. 10000) GOTO 10 WRITE(6, 600) N, ERR, ICON WRITE(6, 601) (C(I), I=1, N) STOP 10 WRITE(6, 602) ICON STOP 600 FORMAT(1H0, 5X, 12HEXPANSION OF, *16H FUNCTION OF FUN(X), 3X, 2HN=, I4, *5X, 4HERR=,E15.5, 5X, 5HICON=,I5) 601 FORMAT(/5E15.5)) 602 FORMAT(1H0, 5X, 14HCONDITION CODE, I8) END FUNCTION FUN(X) REAL*8 SUM, XP, TERM EPS=AMACH(EPS) SUM=1.0 XP=X XN=1.0 N=1 10 TERM=XP/XN SUM=SUM+TERM IF(DABS(TERM). LE. 1 DABS(SUM)*EPS)GOTO 20 N=N+1 XP=XP*X XN=XN*FLOAT(N) GOTO 10 20 FUN=SUM RETURN END
Example 2 Inverse transform for Chebyshev series expansion Example 2 expands since function x 2 n+1 n f ( x ) = sin x = ( 1) (2n + 1)! n =0 on the interval [0, ] in Chebyshev polynomials {Tk(x/2)} according to the required accuracy of = 5.10-5 and = 0. NMIN = 9 and NMAX = 513 is assumed. Example 2 then checks the values taken by the Chebyshev series at n sample points.
x j = 2 + 2 cos
B = ATAN(1.0)*4.0 CALL FCHEB(A, B, FUN, EPSA, EPSR, * NMIN, NMAX, C, N, ERR, TAB, ICON) IF (ICON. GT. 10000) GOTO 10 WRITE (6, 600) N, ERR, ICON C(N) = C(N)*2.0 NM1 = N-1 WRITE (6, 601) (C(I), I=1, N) CALL FCOST (C, NM1, TAB, ICON) WRITE (6, 602) WRITE (6, 601) (C(I), I=1, N) STOP 10 WRITE (6, 603) ICON STOP 600 FORMAT (1H0, 5X, 12HEXPANSION OF, *16H FUNCTION FUN (X), 3X, 2HN =, I4, *5X, 4HERR =, E15.5, 5X, 5HICON =, I5) 601 FORMAT (/(5E15.5)) 602 FORMAT (1H0, 5X, 13HINVERSE TRANS, *15HFORM BY FCOST) 603 FORMAT (1H0, 5X, 14HCONDITION CODE,I8) END FUNCTION FUN (X) REAL*8 SUM, XP, TERM EPS = AMACH (EPS) SUM = X P = X*X XP = X*P XN = -6.0 N = 3 10 TERM = XP/XN SUM = SUM + TERM IF (DABS(TERM). LE. EPS) GOTO 20 N = N + 2 XP = XP*P XN = -XN*FLOAT(N)*FLOAT(N-1) GOTO 10 20 FUN = SUM RETURN END
Method This subroutine uses an extended Clenshaw-Curtis method for Chebyshev series expansion enhanced the speed by using fast cosine transform. Chebyshev series expansion method For simplicity, the domain of f(x) subject to Chebyshev series expansion is assumed to be [-1, 1]. The Chebyshev series expansion of f(x) can be expressed as:
f (x ) =
j , j = 0,1, , n 1 n 1
k =0
' ck Tk ( x ) 1
1
(4.1) dx (4.2)
ck =
f ( x )Tk ( x ) 1 x2
Upon choosing x = cos, (4.2) consequently gives 2 (4.3) ck = f (cos ) cos kd 0 Therefore, ck is regarded as coefficients for the cosine
308
FCHEB
series of the continuous even function f(cos) with period 2. To obtain coefficients (4.2) for Chebyshev series expansion through use of the Gauss-Chebyshev numerical integration formula means to determine fourier coefficients (4.3) for even functions based on the midpoint rule. The Gaussian integral formula is the best in the sense that it can be utilized to integrate correctly a polynomial of degree up to 2n-3 based on n-1 sample points. The trapezoidal rule for (4.3) can be utilized to integrate correctly a polynomial of degree up to 2n-3 based on n sample points. That is, the trapezoidal rule is almost the best. Since input to this subroutine is a function, this subroutine obtains a Chebyshev series consisting of terms whose number is specified by doubling the number of sample points according to the required accuracy. Therefore this subroutine uses the best trapezoidal rule for this purpose. The resultant n-terms Chebyshev series satisfies interpolatory condition. f x j = ' ' ck Tk x j
k =0
f j+ cos n p
1 , j = 0,1, , n p 1 2
(4.7)
The discreate cosine transform (using the midpoint rule) can be defined as shown in (4.8):
n p 1 1 ~p = c f cos j + k cos n j =0 n 2 p p
1 k j + , 2
(4.8)
k = 0,1, , n p 1
Then coefficients { ckp+1 } can be determined by the recurrence formula as show in (4.9): ~p ckp +1 = ckp + c k cnpp++11 k = ckp ~ ck p , k = 0,1, , n p 1 cnpp+1 = cnpp
(4.9)
As described above the coefficients { ckp } of discrete Chebyshev series. f ( x ) " ckp Tk ( x )
np k =0
( )
n 1
( )
(4.4)
(4.10)
j , j = 0,1, , n 1 n 1
by which f(x) is expanded can be determined by increasing a value of p gradually based on (4.6), (4.8) and (4.9). When the convergence criterion is satisfied each coefficient { ckp } is normalized by multipling by factor 2/np. Error evaluation for Chebyshev series The following relationship exists between the coefficients {ck} associated with Chebyshev series expansion shown in (4.1) and the coefficients { ckp } associated with discreate Chebyshev series expansion at the p-th stage shown in (4.10): ckp = ck + c2 mn p k + c2 mn p + k ,
m=1
In order to keep unity of the Chebyshev series notations, the last coefficient of (4.4) is multiplied by factor 1/2, and express the series as (4.1). Based on the error evaluation of series expansion described below, this subroutine determines the number of terms n which satisfies f ( x ) ' ck Tk ( x ) < max a , r f
n 1 k =0
(4.5)
k = 0,1, , n p1
(4.11)
on the interval [-1, 1] as well as series coefficients {ck} by using the Fast Fourier Transform (FFT) method. Coefficients { ckn } for terms n (=np+1, np=2p) are determined by the trapezoidal rule for as shown in (4.6):
p = ck
From (4.11), the error evalution formula for the pstage Chebyshev series is introduced as f ( x ) " ckp Tk ( x ) 2 ck
k =0 k = n p +1 np
(4.12)
cos " f np
j=0
np
However the ordinary scaling factor 2/np is omitted. Coefficients { ckp+1 } for terms n = np+1+1 whose number is doubled can efficiently be obtained by making a good use of complementary relation between the midpoint rule and the trapezoidal rule. That is, function f(x) be sampled at each midpoint of sample points at which { ckp } are determined as shown in (4.7):
If f(x) is analytical function on the interval, its series coefficients {ck} decreases according to exponential function order O (rk), 0 < r < 1 as subscript k increases. As a result r can be estimated based on the p-th stage discrete Chebyshev series coefficients ckp . Let ckp to be Ark (A: Constant). Since k is at most np, rnp/4 can be obtained based on the ration of the coefficient corresponding to the last np to that corresponding to 3/4np. This subroutine estimates r by using not only the cn p -th and 3/4np-th but also the (np -1)-th and (3/4np -1)-th coefficients in order to avoid a state that cn p or c3 4n p becomes zero by accident as shown below: 309
FCHEB
c p + 1 c p n p 1 2 n p r = min c p + c 3p 3 n p 1 np 4 4
4 np
,0.99
The upper limit of r is defined as 0.99 because the convergence rate of the series become slow and Chebyshev series expansion of f(x) is virtually impossible when r is greater than 0.99. By using the resultant r, the error ep at the p-th stage can be estimated by (4.12) and (4.13). ep = r p 1 p cn p 1 + cn p 1 r 2 (4.13)
The last coefficient cnpp only is multipled by factor 1/2 because (4.13) is a discreate Chebyshev series using a trapezoidal rule. Computational process Step 1: Initialization 1) Initialization of the trigonometric function table Three cosine function values are determined in reverse binary order corresponding to equispaced three sample points in the interval [0, /2]. Each entry of the trigonometric function table can be used as a sample point during sampling of f(x). 2) Initial Chebyshev series expansion This subroutine determines c02 , c12 , c22 , c32 , and c42 , as a result of 5-terms Chebyshev series expansion (upon choosing np=4 in (4.6)). It also determines the norm f of f(x) based on (1.3). Step 2: Convergence criterion If np+1 NMIN is satisfied this subroutine bypasses a convergence test and unconditionally executes step 3. If np+1 > NMIN is satisfied this subroutine performs a convergence test as described below: This subroutine estimates a computational error limit
This is because the accuracy of computation can not increase any longer. If < is satisfied this subroutine terminates normally after a condition code of 0 is set to ICON. If is satisfied this subroutine terminates abnormally after a condition code of 10000 is set to ICON, assuming that the required accuracy of or is too small. If coefficients of the last two terms consist of significant digits, this subroutine estimates absolute error ep based on (4.13). When ep < is satisfied this subroutine terminates normally after a condition code of 0 is set to ICON. When ep < is not satisfied but 2np+1 NMAX is satisfied, this subroutine unconditionally executes Step 3. When ep < is not satisfied but 2np+1 > NMAX is satisfied, this subroutine terminates abnormally after a condition code of 20000 is set to ICON, assuming that the required accuracy is not satisfied when the number of terms to be expanded in a Chebyshev series reaches the upper limit. ep < (4.17)
Note that resultant coefficients are normalized whether this subroutine terminates normally or abnormally. Step 3: Sampling of f(x) and calculating the norm of f(x) At each midpoint of np+1 sample points which have previously determined, this subroutine samples f(x) in reverse binary order as shown in (4.18):
a +b ba f j+ 2 + 2 cos n p 1 , 2
(4.18)
j = 0,1, , n p 1
However, in case of a = 0, this subroutine samples f(x) to avoid loss of significant digits while changing its variables as shown in (4.19):
1 2 f j + , b cos 2n 2 p j = 0,1, , n p 1
= n p f (2u)
and a tolerance for convergence test as
(4.14)
(4.19)
= max{ a , r f
(4.15) At this time, this subroutine adds a new trigonometric function table entry and determines the norm of f(x) by using (1.3). Step 4: Discrete cosine transform (using the midpoint rule) This subroutine performs discrete cosine transform using the Fast Fourier Transform (FFT) method to determine {~ ckp } for sample points obtained by
If the coefficients c p n p1 and cnpp of the last two terms at the p-th stage have been lost significant digits, that is, if the coefficients satisfy (4.16). 1 cnpp 1 + cnpp < (4.16) 2 this subroutine assumes that the series has
310
FCHEB
Step 3. Step 5: Computing { ckp+1 } ~ p } obtained By using { ckp } obtained previously and { c k by Step 4, this subroutine determines of 2np+1 terms based on the recurrence formula shown in (4.9). Then, this subroutine executes Step 2 after it increases a value of p by one.
Step 3 and 4 consumes most of the time required to execute this subroutine. The number of multiplications required to determine coefficients for an n-terms Chebyshev series is approximately nlog2 n except for that required for sampling of f(x). For further information, see Reference [59]. For detailed information about discrete cosine transform, see an explanation of the subroutines FCOST and FCOSM.
311
FCOSF
TAB....
CALL FCOSF (TH, FUN, EPSA, EPSR, NMIN, NMAX, A, N, ERR, TAB, ICON) Function This subroutine performs cosine series expansion of a smooth even function f(t) with period 2T according to the required accuracy of and . It determines n coefficients {ak} which satisfy f (t ) ' a k cos
k =0 n 1
ICON...
Output. TAB contains a trigonometric function table used for series expansion. Onedimensional array whose size is greater than 3 and equal to (NMAX-3)/2. Output. Condition code. See Table FCOSF-1.
Table FCOSF-1 Condition codes Code 0 10000 Meaning No error The required accuracy was not satisfied due to roundingoff errors. The required accuracy is too high. Processing A contains resultant coefficients. The accuracy of the series is the maximum attainable. Bypassed. A contains resultant coefficients and ERR contains an estimate of absolute error. Bypassed
kt max{ a , r f T
(1.1)
20000
where symbol denotes to make sum but the initial term only is multiplied by factor 1/2. The norm f of f(t) is defined as shown in (1.3) by using function values taken at sample points shown in (1.2) within the half period [0, T].
The required accuracy was not satisfied though the number of terms of the series has reached the upper limit.
30000
T tj = j , j = 0,1, , n 1 n 1 f max f t j 0 f n 1
(1.2) (1.3)
()
Where T > 0, 0, 0. Parameters TH..... Input. Half period T of the function f(t). FUN.... Input. Name of the function subprogram with calculates f(t) to be expanded in a cosine series. See an example of using this subroutine. EPSA... Input. The absolute error tolerance . EPSR... Input. The relative error tolerance . NMIN... Input. Lower limit of terms of cosine series (0). NMIN should be taken a value such as (power of 2) + 1. The default value is 9. See Notes. NMAX... Input. Upper limit of terms of cosine series. (NMAX NMIN). NMAX should be taken a value such as (power of 2) + 1. The default value is 257. See Notes. A..... Output. Coefficient {ak}. One-dimensional array of size NMAX. Each coefficient is stored as shown below: A(1) = a0, A(2) = a1, ..., A(N) = an-1 N..... Output. Number of terms n of the cosine series (5). N takes a value such as (power of 2) + 1. ERR.... Output. Estimate of the absolute error of the series.
One of the following cases occurred: 1 TH 0 2 EPSA < 0.0 3 EPSR < 0.0 4 NMIN < 0 5 NMAX < NMIN
Comments on use Subroutines used SSL II ... MGSSL, AMACH, UTABT, UCOSM, UNIFC FORTRAN basic function ... ABS, AMAX1, AMIN1, FLOAT Notes The function subprogram specified by the FUN parameter must be a subprogram defined at the interval [0, T] having independent variable t only as the argument. The name must be declared by the EXTERNAL statement in the program which calls this subroutine. If the function contains auxiliary variable, they must be declared by a COMMON statement to establish an interface with the calling program. See Example of using this subroutine. Use of the trigonometric function table When this subroutine is repeatedly called, the trigonometric function table is produced only once. A new trigonometric function table entry is made on an as-required basis. Therefore the contents of TAB must be kept intact when this subroutine is called subsequently. If NMIN or NMAX does not take a value such as (power of 2) + 1, this subroutine assumes
312
FCOSF
the maximum value of (power of 2) + 1 which does not exceed that value. Howeger NMAX = 5 is assumed if NMAN < 5 is satisfied. The degree of error decrement greatly depends on the smoothness of f(t) in the open interval (-,) as the number of terms n increases. If f(t) is an analytical periodic function, the error decreases according to exponential function order O (rn), 0 < r < 1. If it has up to k-th continuous derivatives, the error decreases according to rational function order O (n-k). When k=0 or k=1, an estimate of absolute error is not always accurate because the number of terms to be expanded increases greatly. Therefore, the function used by this subroutine should have, at least, up to 2nd continuous derivatives. Accuracy of the series This subroutine determines a cosine series which satisfies (1.1) according to the required accuracy of and . If = 0 is specified, this subroutine expands f(t) in a cosine series within the required accuracy of absolute error . Similarly = 0 is specified, this subroutine expands f(t) in a cosine series within the required accuracy of relative error . However cosine series expansion is not always successful depending on the specification of and . For example, when or is too small in comparison with computational error of f(t), the effect of rounding-off errors becomes greater on the computational result even if the number of terms to be expanded does not reach the upper limit. In such a case, this subroutine abnormally terminates after a condition code of 10000 is set to ICON. At this time, the accuracy of the cosine series becomes the attainable limit for the computer used. The number of terms to be expanded in a cosine series sometimes does not converge within NMAX evaluations depending on the characteristics of f(t). In such a case, this subroutine abnormally terminates after a condition code of 200000 is set to ICON. Each coefficient is an approximation obtained so far, and is not accurate. To determine the accuracy of cosine series this subroutine always set an estimate of absolute error in ERR. When inverse transform is attempted by the subroutine FCOST, the coefficient an-1 of the last term must be doubled in advance. Note that the content of TAB must be kept intact whether normal or inverse transform is attempted. See Example 2.
When f(t) is only a periodical function, this subroutine can be used to perform cosine series expansion for even function as (f(t) +f(-t))/2. If f(t) has no period and is absolutely integrable, its theoretical cosine transform can be defined as shown in (3.1): F ( ) =
f (t ) cos tdt
(3.1)
If f(t) is dampted according to order of O (e-at) (a < 0), an approximation of the Fourier integral can be obtained as described below: Assume that f (t ) can be ignored on the interval [T,) when T is sufficiently large. By defining T which satisfies (3.2) f (t ) < u, t T (3.2)
where u is the unit round off. This subroutine can be used to determine cosine series coefficients {ak} for f(t), assuming that f(t) is a function with period 2T. Since {ak} can be expressed as
ak = 2 T
0 f (t ) cos T ktdt
T
(3.3)
Based on this relationship this subroutine can calculate an approximation of cosine transform shown in (3.1) by using discrete cosine transform. When inverse transform
f (t ) = 2 F ( ) cos td 0
(3.5)
is to be calculated, the subroutine FCOST can be called for n pieces of data as follows: 2 F k , k = 0,1, , n 2 T T 4 F (n 1) T T The subroutine FCOST can obtain an approximation of: T f j , j = 0,1, , n 1 n 1
313
FCOSF
See Example 2. Examples Example 1 This example expands the following even function with period 2 having auxiliary variable p f (t ) = 1 p2 1 2 p cos t + p 2
C
in a cosine series according to the required accuracy of = 5.10-5 and = 5.10-5 and compares the results with analytical solution F() = sech . Then, this example performs inverse transform of the function by using the subroutine FCOST and check the accuracy of the results.
**EXAMPLE** DIMENSION A(257), TAB(127), ARG(257), T(257) EXTERNAL FUN COMMON HP HP = ATAN(1.0)*2.0 TH = ALOG(1.0/AMACH(TH))/HP EPSA = 0.5E-04 EPSR = EPSA NMIN = 9 NMAX = 257 C COSINE TRANSFORM CALL FCOSF (TH,FUN,EPSA,EPSR, * NMIN,NMAX,A,N,ERR,TAB,ICON) IF (ICON. GT. 10000) GO TO 10 TQ = TH*0.5 H = (HP + HP)/TH DO 1K = 1, N ARG(K) = H*FLOAT (K-1) A(K) = A(K)*TQ T(K) = TRFN (ARG(K)) 1 CONTINUE WRITE (6,600) N,ERR,ICON WRITE (6,610) WRITE (6,601) (ARG(K),A(K),T(K), K = 1,N) C INVERSE TRANSFORM Q = 1.0/TQ DO 2 K=1,N A(K) = A(K)*Q 2 CONTINUE A(N) = A(N)*2.0 NM1 = N-1 CALL FCOST (A,NM1 TAB,ICON) IF (ICON. NE. 0) GO TO 10 H = TH/FLOAT (NM1) DO 3 K = 1,N ARG(K) = H*FLOAT (K-1) T(K) = FUN(ARG(K)) 3 CONTINUE WRITE (6,620) WRITE (6,610) WRITE (6,601) (ARG(K),A(K),T(K), K=1,N) STOP 10 WRITE (6,602) ICON STOP 600 FORMAT (1H0,5X,16HCHECK THE COSINE, *29H TRANSFORM OF FUNCTION FUN(T), *3X, 2HN=,I4,5X,4HERR=,E15.5,5X, *5HICON=,I5) 610 FORMAT (1H0,6X,8HARGUMENT,7X, *8HCOMPUTED,11X,4HTURE) 620 FORMAT (1H0,5X,17HCHECK THE INVERSE *,10H TRANSFORM) 601 FORMAT (/(3E15.5)) 602 FORMAT (1H0,5X,14HCONDITION CODE, I6) END
in a cosine series according to the required accuracy of = 5.10-5 and = 5.10-5. Where NMIN = 9 and NMAX = 257 are assumed. The theoretical cosine series expansion of f(t) is as follows: f (t ) = 1 + 2 p k cos kt
k =1
This example prints cosine series coefficients when p = 1/4, 1/2 and 3/4.
C **EXAMPLE** DIMENSION A (257), TAB (127) EXTERNAL FUN COMMON P TH = ATAN (1.0)*4.0 EPSA = 0.5E-4 EPSR = EPSA NMIN = 9 NMAX = 257 P = 0.25 1 CALL FCOSF (TH,FUN,EPSA,EPSR, * NMIN, NMAX,A,N,ERR,TAB,ICON) IF (ICON. GT. 10000) GO TO 10 WRITE (6,600) N,ERR,ICON,P WRITE (6,601) (A(I),I=1,N) P = P + 0.25 IF (P. LT. 1.0) GO TO 1 STOP 10 WRITE (6,602) ICON STOP 600 FORMAT (1H0,5X, 12HEXPANSION OF, * 16H FUNCTION FUN(T),3X,2HN=,I4, * 5X, 4HERR=,E15.5,5X,5HICON=,I16,5X, * 2HP =, E15.5) 601 FORMAT (/5E15.5)) 602 FORMAT (1H0,5X,14HCONDITION CODE, I8) END FUNCTION FUN(T) COMMON P FUN = (1.0-P*P)/(1.0-2.0*P*COS(T)+P*P) RETURN END
Example 2 Cosine transform and inverse transform This example transforms even function
F ( ) = 0 sec h
x cosx dx 2
314
FCOSF
FUNCTION FUN(T) COMMON HP FUN = 1.0/COSH(T*HP) RETURN END FUNCTION TRFN(W) TRFN = 1.0/COSH(W) RETURN END
Method This subroutine applies discrete fast cosine transform (based on the trapezoidal rule) to cosine transform for entry of functions. Cosine series expansion For simplicity, an even function f(t) with a period of 2. The function can be expanded in a cosine series as shown below:
1 f (t ) = a0 + a k cos kt k =1 2 2 a k = f ( x ) cos kt dt 0
Where the ordinary scaling factor 2/np is omitted from (4.5). When the number of terms is doubled as np+1 = 2np each coefficient can efficiently be determined by making a good use of complementary relation between the trapezoidal rule and the midpoint rule. At each midpoint between sample points used by the trapezoidal rule (4.5), f(t) can be sampled as shown below:
1 f j + , j = 0,1, , n p 1 n 2 p
(4.6)
Discrete cosine transform (using the midpoint rule) for (4.6) can be defined as shown below:
n p 1 1 1 ~p = a f cos k j + , j + k j =0 np 2 2 np
(4.1) (4.2)
(4.7)
k = 0,1, , n p 1
This subroutine uses the trapezoidal rule to compute (4.2) by dividing the closed interval [0, ] equally. By using resultant coefficients {ak}, this subroutine approximates (4.1) by finite number of terms. If this integrand is smooth, the number of terms is doubled as far as the required accuracy of aw and is satisfied. If sampling is sufficient, (4.3) will be satisfied.
f (t )
n 1
(4.8)
k =0
" a k cos kt
< max a , r f
(4.3)
where n indicates the number of samples (power of 2+1). Where symbol denotes to make sum but the initial and last terms only are multipled by factor 1/2. The resultant trigonometric polynomial is a trigonometric interpolation polynominal in which each breakpoint used by the trapezpidal rule is an interpolation point as shown below:
T f n 1
By using this recurrence formula for { a kp }, f(t) can be expanded in a cosine series of higher degree while the number of terms is doubled as far as the required accuracy is satisfied. Then { a kp } is normalized by multipling by factor 2/np. Note that the coefficient of the last term is multipled by factor 1/np so that all cosine series can be expressed in the same manner as shown in (4.1). Error evaluation for cosine series The following relationship exists between the theoretical cosine coefficients ak of f(t) and discrete cosine coefficient { a kp } taken at the p-th stage: a kp = a k + a 2 mn p k + a 2 mn p + k ,
m =1
(4.4)
k = 0,1, , n p
(4.9)
The cosine series expansion is explained in detail below. Assume that coefficients obtained by the trapezoidal rule using n sample points (n = np+1, np = 2p) are
a kp = " f n j =0 p
np
This results from (4.2) and (4.5) as well as orthogonality of trigonometric functions. The error evaluation for a cosine series at the p-th stage f (t ) " akp cos kt 2 ak
np
j cos n kj , k = 0,1, , n p p
(4.5)
k =0
k =n p +1
(4.10)
315
FCOSF
periodic function its series coefficients {ak} decrease according to exponential function order O (rk) (0 < r < 1) as k increases. The r can be estimated from a discreate cosine coefficient at the p-th stage. Let a kp = Ark (A: constant). Since k is at most np, rnp/4 can be estimated from the ratio of the coefficient of the last term np to the coefficient of term 3/4np. This subroutine does not allow the two coefficients to be zero by accident. Therefore it uses the (np-1)-th and (3/4np-1)-th coefficients together with those coefficients to estimate a value of r as shown below. a p + 1 a p n p 1 2 n p r = min a p + a 3p 3 np n p 1 4 4
4 np
where u is the unit round off. and a tolerance for convergence test as
= max{ a , r f
(4.13)
If the last two terms at the p-th stage have been lost significant digits, that is, if the coefficients satisfy (4.14). anpp 1 + 1 p an < 2 p (4.14)
,0.99
If r is greater than 0.99, this subroutine cannot actually expand f(t) in a cosine series because the convergence rate of the series becomes weak. By using the resultant r, the p-th stage error ep = r p 1 p an p 1 + an p 1 r 2 (4.11)
the computational accuracy cannot be increased even if this computation continues. Therefore this subroutine replaces the absolute error ep of the cosine series by the computational error p, assuming that the cosine series is converged. If < is satisfied this subroutine sets a condition code of 0 to ICON. If is satisfied this subroutine sets a condition code of 10000 to ICON assuming that or is relatively smaller than unit round off u If (4.14) is not satisfied, this subroutine estimates error ep based on (4.11). If ep < is satisfied this subroutine sets a condition code of 0 to ICON and terminates normally. If ep < is not satisfied but 2np + 1 NMAX is satisfied, this subroutine immediately executes Step 3. Otherwise this subroutine sets a condition code of 20000 to ICON and terminates abnormally assuming that the required accuracy is not satisfied even when the number of terms to be expanded is reached the upper limit. Note that each coefficient is normalized whether this subroutine terminates normally or abnormally. Step 3: Calculation of sample points Sample points to be used for sampling of f(t) at the p-th stage can be expressed as follows: tj =
can be estimated from (4.10). The last coefficient anpp only is multipled by factor 1/2 since this coefficient is a discrete cosine coefficient using the trapezoidal rule. Computational process Step 1: Initialization Initialization of Trigonometric function table At three points which divides in interval [0, /2] equally, three values for the cosine function is obtained in reverse binary order. The trigonometric function table is not initialized if this subroutine is called in advance. The trigonometric function table is used for discrete cosine transform. Initial cosine series expansion This subroutine performs 5-terms cosine series expansion whose np is 4(p=2) in (4.5) and calculates a 02 , a12 , a 22 , a 32 , a 42 . At this time it also obtains f based on the norm definition shown in (1.3). Step 2: Convergence criterion If np + 1 NMIN is satisfied this subroutine does not perform a convergence test and executes step 3. If np + 1 > NMIN is satisfied this subroutine performs a convergence test as described below: This subroutine estimates computational error limit
1 j + , j = 0,1,, n p 1 np 2
They can be obtained in reverse binary order through use of the recurrence formula shown below: t0 =
( )
(4.16)
= n p f (2u)
Step 4: Sampling of f(t) and calculation of the norm This subroutine obtains values of f(t) for n sample points based on (4.16). and overwrites them on the sample points. It also calculates norm f based on the norm definition shown in (1.3).
(4.12)
316
FCOSF
Step 5: Trigonometric function table creation This subroutine produces the trigonometric function table required by step 6. The trigonometric function table is not recalculated each time this subroutine is called. Step 6: Discrete cosine transform (using the midpoint rule) For sample points obtained by Step 4, this subroutine performs discrete cosine transform using the Fast Fourier ~p . Transform (FFT) method to determine {a k }
by using (4.8) to obtain the coefficients a kp+1 of the discrete cosine series consisting of 2np + 1 terms. Then, this subroutine executes Step 2 after it increases a value of p by one. Step 4 and 6 consume most of the time required to execute this subroutine. Then number of multiplications required to determine the coefficients of a cosine series consisting of n terms is about nlog2n. To save storage this subroutine overwrites sample points, samples and expansion coefficients onto a onedimensional array A. For further information, see Reference [59]. For detailed information about discrete cosine transfom, see an explanation of the subroutines FCOST and FCOSM.
{ }
317
FCOSM
ISN...
CALL FCOSM (A, N, ISN, TAB, ICON) Function Given n same point {xj+1/2}, 1 x j +1 2 = x j + , j = 0,1, , n 1 2 n (1.1)
Input. Transform or inverse transform is indicated. For transform: ISN = +1 For inverse transform: ISN = -1 TAB..... Output. Trigonometric function table used in the transform is stored. One-dimensional array of size n-1. See Notes. ICON.. Output. Condition code. See Table FCOSM-1.
Table FCOSM-1 Condition codes
by equally dividing the half period of the even function with period 2 , a discrete cosine transform or its inverse transform based on the midpoint rule is performed by using the Fast Fourier Transform (FFT). Here n = 2l (l = 0 or positive integer). Cosine transform By inputting {xj+1/2} and performing the transform defined in (1.2), the Fourier coefficients {n/2.ak} are obtained
n =1 n 1 a k = x j +1 2 cos k j + , k = 0,1, , n 1 j 0 = 2 2 n
Code 0 30000
Processing Aborted.
Comments on use Subprograms used SSL II ... UPNR2 UTABT, UCOSM and MGSSL FORTRAN basic functions ... SQRT and MAX0 Notes General definition of Fourier transform: The discrete cosine transform and its inverse transform based on the midpoint rule are generally defined by (3.1) and (3.2). ak =
(1.2)
Cosine inverse transform By inputting {ak} and performing the transform defined in (1.3), the values of the Fourier series {xj+1/2} are obtained. x j +1 2 = ' a k cos
k =0 n 1
1 k j + , j = 0,1, , n 1 2
(3.1)
(1.3)
where denotes the first term only is taken with factor 1/2. Parameters A..... Input. {xj+1/2} or {ak}. Output. {n/2.ak} or {xj+1/2}. One-dimensional array of size n. See Fig. FCOSM-1. N..... Input. Sample point number n.
One-dimensional array A(N) {xj+1/2} x1/2 x1+1/2 x2+1/2 N {ak} n a0 a1 a2 a n 2 an1 xn3/2 xn1/2
1 k j + , n 2 j = 0,1,, n 1
(3.2)
The subroutine obtains {n/2.ak} and {xj+i/2} which correspond to the left-hand side of (3.1) and (3.2), respectively, and the user has to scale the results, if necessary. Use of the trigonometric function table: When the subroutine is called successively for transforms of a fixed dimension, the trigonometric function table is calculated and created only once. Therefore, when calling the subroutine subsequently, the contents of the parameter TAB must be kept intact. Even when the dimension differs, the trigonometric function table need not be changed. A new trigonometic function table entry can be made on an as-required basis.
Note: {
a k } is handled the same way as for {ak}. 2 Fig. FCOSM-1 Data storing method
318
FCOSM
Example By inputting n sample points { xj+1/2}, performing the transform by the subroutine and scaling the results, the discrete Fourier coefficients {ak} are obtained. By performing the inverse transform after that, {xj+1/2} are obtained. Here n 512.
C **EXAMPLE** DIMENSION X(512),TAB(511) C COSINE TRANSFORM ISN=1 READ (5,500) N,(X(I),I = 1,N) WRITE (6,600) N WRITE (6,601) (X(I),I=1,N) CALL FCOSM (X,N,ISN,TAB,ICON) IF (ICON. NE. 0) GO TO 20 C NORMALIZE CN=2.0/FLOAT (N) DO 10 K=1, N X(K)=X(K)*CN 10 CONTINUE WRITE (6,602) ISN WRITE (6,601) (X(I),I = 1,N) C COSINE INVERSE TRANSFORM ISN=-1 CALL FCOSM (X,N,ISN,TAB,ICON) IF (ICON.NE. 0) GO TO 20 WRITE (6,602) ISN WRITE (6,601) (X(I),I = 1,N) 20 WRITE (6,603) ICON STOP 500 FORMAT (I5/6F12.0)) 600 FORMAT (1H0,5X,13HINPUT DATA N =,I5) 601 FORMAT (5F15.7) 602 FORMAT (1H0,5X,11HOUTPUT DATA,5X, * 4HISN=,I2) 603 FORMAT (1H0,5X,14HCONDITION CODE, * I8) END
The basic idea of the FFT is to accomplish the objective transform by repeating the elementary discrete Fourier transform by repeating the elementary discrete Fourier transform of small dimension (i.e., if the radix is 2, the dimension is 2). In other words, considering sample data which consist of (j+1) th element and subsequent ones ~ , (= 2l+1-p, P = 1, 2, ...) and defining with the interval n p the transform x p ( j, k ) = ~ 1 x rn p + j + n 2 r=0 1 j+ i 2 2 r + exp ~ n p np ~ 1, k = 0,1, , n p 1 j = 0,1, , n p
n p 1
k , (4.2)
of dimension np = 2p, then the transform (4.2) can be satisfied with the FFT algorithm (4.3) of radix 2. Initial value 1 x 0 ( j ,0) = x j + , j = 0,1, ,2n 1 n 2 p p 1 ~ ,k x ( j , k ) = x ( j , k ) + x p1 j + n
~ , k) ( j, k + n ) = {x ( j, k ) + x ( j + n }
p 1 p 1 p 1 p
(4.3)
Method The discrete cosine transform based on the midpoint rule of dimension n (=2l, l = 0, 1, ...) is performed by using the radix 2 Fast Fourier Transform (FFT). The transform based on the midpoint rule can be accomplished by considering the even function x(t) to be a complex valued function and performing the discrete complex Fourier transform for the even function based on the midpoint rule of dimension 2n. In this case, however, it is known that the use of the characteristics of the complex transform permits efficient transform For the complex value function x(t) with period 2, the discrete Fourier transform based on the midpoint rule of dimension 2n (= 2+1, = 0, 1, 2, ...) is defined as
2 n 1 i 1 1 2nak = x j + exp k j + , j =0 n 2 2 n
The values obtained in the final step of these recurrence equations are the discrete Fourier coefficients (4.4).
2na k = x l +1 (0, k ), k = 0,1, ,2n 1
(4.4)
If x(t) is an even function, the fact that x(t) is real, i.e., x(t) = x (t) ( x (t) is a complex conjugate of x(t)), and symmetric, i.e.,
x(2 t ) = x (t )
k = 0,1,,2n 1
affects the intermediate results {xp(j,k)} of the FFT as follows: Real property: xp(j, 0) is real (4.1)
~ j 1, k = x p ( j , k ), x p (n p ) ~ 1 j = 0,1, , n , k = 0,1, , n p 1 p
319
FCOSM
(4.5)
On the other hand, the relationship ak=2ak , k=0,1,,n-1 can be satisfied between the complex Fourier coefficients {ak} for the even function x(t) and the Fourier coefficients defined by the following discrete cosine transform ak =
Normally, the area to store the intermediate results {xp(j, k)} needs one-dimensional array of size n, but if the input data is permuted in advance by reverse binary transformation, the above computation can be carried out by using the same area in which the data was input. The number of real number multiplications necessary for the cosine transform of dimension n is about nlog2n. Transform procedure in the subroutine (a) The necessary trigonometric function table (size n1) for the transform is created in reverse binary order. (b) The sample points {x(/n(j+1/2))} (size n) are permuted in reverse binary order. (c) The FFT algorithm (4.7), which takes into consideration the symmetric property of the input data is performed in the same area to obtain the Foruier coefficients {ak} in normal order. Inverse transform procedure (a) The necessary trigonometric function table for the inverse transform procedure. This table is the same one as used in the transform procedure ca). (b) By inputting the n Fourier coefficients {ak} for the even function {x(/n(j+1/2))}, and tracing backwards the recurrence equations (4.7) with respect to p, the function values {x(/n(j+1/2))} are obtained in reverse binary order. (c) By permuting the obtained n data by reverse binary transformation, the function values {x(/n(j+1/2))} are obtained in normal order. For further details, refer to Reference [58].
2 n1 1 1 x j + cos k j + j 0 = n n n 2 2
k = 0,1,, n 1
Therefore by using the characteristic (4.5) in the FFT algorithm (4.3) as well as the relationship above, the number of computations and the memory using them. That is, the range of j and k used in (4.3) are halved, so the FFT algorithm of radix 2 for the discrete cosine transform (4.6) can be represented by ~ j 1, k x p ( j , k ) = x p 1 ( j , k ) + x p1 n p
) {
)}
(4.7)
320
FCOST
CALL FCOST (A, N, TAB, ICON) Function Given n+1 sample points {xj}, by equally dividing the half period of the even function with period 2 into n, x j = x j , j = 0,1,, n n (1.1)
Note: {
a k } is handled in the same way as for {ak}. 2 Fig. FCOST-1 Data storing method
a discrete cosine transform or its inverse transform based on the trapezoidal rule is performed by using the Fast Fourier Transform (FFT). Here, n = 2l (l = 0 or positive integer). Cosine transform By inputting {xj} and performing the transform defined in (1.2), the Fourier coefficients {n/2.ak} are obtained.
n n ak = x j cos kj , k = 0,1,, n j= 0 2 n
Comments on use Subprograms used SSL II ... UPNR2, UTABT, UCOSM and MGSSL FORTRAN basic functions ... SQRT and MAX0 Notes General definition of Fourier transform: The discrete cosine transform and its inverse transform based on the trapezoidal rule are generally defined by (3.1) and (3.2).
ak =
(1.2)
where denotes both the first and last terms of the sum are taken with factor 1/2. Cosine inverse transform By inputting {ak} and performing the transform defined in (1.3), the values of the Fourier series {xj} are obtained
x j = "ak cos
j= 0 n
(3.1) (3.2)
kj , j = 0,1,, n n
The subroutine obtains {n/2 ak} and {xj} which correspond to the left-hand side of (3.1) and (3.2), respectively and the user has to scale the results, if necessary. Calculating trigonometric polynomial: When obtaining values of the n-th order trigonometric polynomial
x(t ) = 1 a0 + a1 cos t ++ an cos nt 2
(1.3) (3.3)
Parameters A..... Input. {xj} or {ak} Output. {n/2 ak} or {xj} One-dimensional array. See Fig. FCOST1. N..... Input. Sample point number-1 TAB... Output. Trigonometric function table used by the transform is stored. One-dimensional array of size n/2-1. See Notes. ICON.. Output. Condition code. See Table FCOST-1.
N
Table FCOST-1 Condition codes Code 0 30000 Meaning No error N 2 (: 0 or positive integer) Processing Bypassed
at x j , j = 0,1,, n, by using the inverse n transform, the highest order coefficient an must be doubled in advance. Refer to example (b). Use of the trigonometric function table: When the subroutine is called successively for transforms of a fixed dimension, the trigonometric function table is calculated and created only once. Therefore, when calling the subroutine subsequently, the contents of parameter TAB must be kept intact. Even when the dimension differs, the trigonometric function table need not be changed. A new trigonometric function table entry can be made on an asrequired basis.
321
FCOST
Example (a) By inputting n+1 sample points {xj}, performing the transform by the subroutine and scaling the results, the discrete Fourier coefficients {ak} are obtained. By performing its inverse transform after that, {xj} are obtained. Here n 512.
C **EXAMPLE** DIMENSION X(513),TAB(255) READ(5,500) N NP1=N+1 READ(5,501) (X(I),I=1,NP1) C COSINE TRANSFORM WRITE(6,600) N WRITE(6,601) (X(I),I=1,NP1) CALL FCOST(X,N,TAB,ICON) IF(ICON.NE.0) GO TO 20 C NORMALIZE CN=2.0/FLOAT (N) DO 10 K=1,NP1 X(K)=X(K)*CN 10 CONTINUE WRITE(6,602) WRITE(6,601) (X(I),I=1,NP1) C COSINE INVERSE TRANSFORM CALL FCOST(X,N,TAB,ICON) IF(ICON.NE.0) GO TO 20 WRITE(6,602) WRITE(6,601) (X(I),I=1,NP1) 20 WRITE(6,603) ICON STOP 500 FORMAT(I5) 501 FORMAT(6F12.0) 600 FORMAT(1H0,5X,13HINPUT DATA N=,I5) 601 FORMAT(5F15.7) 602 FORMAT(1H0,5X,11HOUTPUT DATA) 603 FORMAT(1H0,5X,14HCONDITION CODE, * I8) END
**EXAMPLE** DIMENSION A(513),TAB(255) READ(5,500) N NP1=N+1 READ(5,501) (A(K),K=1,NP1) WRITE(6,600) N WRITE(6,601) (A(K),K=1,NP1) A(NP1)=A(NP1)*2.0 CALL FCOST(A,N,TAB,ICON) IF (ICON. NE. 0) GO TO 20 WRITE (6,602) WRITE (6,601) (A(K),K=1,NP1) 20 WRITE (6,603) ICON STOP 500 FORMAT(I5) 501 FORMAT(6F12.0) 600 FORMAT(1H0,5X,13HINPUT DATA N=,I5) 601 FORMAT(5F15.7) 602 FORMAT(1H0,5X,11HOUTPUT DATA) 603 FORMAT(1H0,5X,14HCONDITION CODE, * I8) END
Method The discrete cosine transform based on the trapezoidal rule of dimension n+1 (=2l+1, l = 0, 1, ...) is performed by using the radix 2 Fast Fourier Transform (FFT). The transform based on the trapezoidal rule can be accomplished efficiently by using the transform based on the midpoint rule. The subroutine uses this method. Dividing equally into np (=2P, p = 0,1, ...) the half period [0, ] of an even function x(t) with period 2, the discrete cosine transform based on the trapezoidal rule is defined as
np akp = " x n j =0 p
j cos n kj , k = 0,1,, n p p
(4.1)
(b) By inputting cosine coefficients {ak}, the values {x(j/n)} of the n-th order trigonometric polynomial 1 x(t ) = a0 + a1 cos t ++an 1 cos(n 1)t 2 + an cos nt at the sample points {j/n} are obtained. The coefficient of the last term must be doubled before it is input. Here n 512.
Also the discrete cosine transform based on the midpoint rule of dimension np is defined as
n p 1 p k = x a j+ n j= 0 p
1 cos k j + 2 np
1 , 2
(4.2)
k = 0,1,, n p 1
In Eqs. (4.1) and (4.2), however, the ordinary scaling factor 2/np is omitted. Doubling the division number to np+1, the {akp+1} can be expressed as follows by using { a kp } and { a kp } both of
p +1 k }. which have half as many dimension as { a
(4.3)
p +1 np
=a
p np
322
FCOST
The equations shown in (4.3) can be considered as recurrence equations with respect to p to obtain { a kp +1 } from { a kp }. Therefore, when performing transform with division number 2l, if the initial condition { akl ; k = 0, 1, 2} is given and the discrete cosine transform based on the midpoint rule of dimension 2p is performed each at the p-th stage (p = 1, 2, ..., l -1), then the discrete cosine transform series { a kp , k = 0, 1, ..., np} ( p = 1, 2, ..., l ) based on the trapezoidal rule can be obtained by using equations (4.3). The number of multiplications of real numbers executed is about nlog2n, which means the calculation method described above to obtain { a kl } is fast. Procedural steps taken in the subroutine Taking the first n points out of the sequenced n+1 sample points x0, x1, ..., xn and permuting them in reverse binary order representing x(0), x(1), ..., x(n). In this way, all the necessary data for the recurrence equations (4.3) can be gained successively. Next, the trigonometric function table (size n/2-1) necessary for the transform is made in reverse binary order corresponding to the sample point numbers. Finishing with the preparatory processing, the cosine transform is performed as follows:
(a) Initialization { a kl , k = 0, 1, 2} with p=1 are obtained by using x(0), x(1), x(n) and stored in x(.), respectively. (b) Cosine transform based on the midpoint rule of dimension 2p. By inputting np sample points, x(np), x(np+1), ..., x(np+1), and performing the cosine transform based on the midpoint rule, { a kp ) are obtained in the same area. For the cosine transform based on the midpoint rule, see method for subroutine FCOSM. (c) Calculation of recurrence equations with respect to { a kp } All of the intermediate results are overwritten, so no supplementary work area is needed. That is, the four p p k and a n , at the (p+1) th elements, a kp , anpp k , a p k step are calculated according to the recurrence equations by using the four elements, a kp +1 , anpp+1k , a kpp++1k and anpp++11 k at the p-th stage, and are stored in the same positions corresponding to the ones at the pth stage. Repeating stages (b) and (c) with p = 1, 2, ..., l-1, {ak} can be obtained. For further details, see Reference [58].
323
FSINF
ICON...
CALL FSINF (TH, FUN, EPSA, EPSR, NMIN, NMAX, B, N, ERR, TAB, ICON) Function This subroutine performs sine series expansion of a smooth odd function f(t) with period 2T according to the required accuracy of a and . It determines n coefficients {bk} which satisfy f (t ) bk sin
k =0 n 1
One-dimensional array whose size is greater than 3 and equal to NAMX/2-1. Output. Condition code. See Table FSINF-1.
Table FSINF-1 Condition codes Code 0 10000 Meaning No error The required accuracy was not satisfied due to roundingoff errors. The required accuracy is too high. Processing B contains resultant coefficients. The accuracy of the series is the maximum attainable. Bypassed. B contains resultant coefficients and ERR contains an estimate of absolute error. Bypassed
kt max{ a , r f T
(1.1)
20000
Since {bk} contains trivial coefficient b0 = 0, the number of coefficients to be expanded actually is n-1. The norm f of f(t) is defined as shown in (1.3) by using function values taken at sample points shown in (1.2) within the half period [0, T].
tj = T j , j = 0,1, , n 1 n 1
30000
The required accuracy was not satisfied though the number of terms of the series has reached the upper limit.
(1.2) (1.3)
f max f t j 0 j n 1
( )
One of the following cases occurred: 1 TH 0 2 EPSA < 0.0 3 EPSR < 0.0 4 NMIN < 0 5 NMAX < NMIN
Where T > 0, a 0, 0. Parameters TH..... Input. Half period T of the function f(t). FUN.... Input. Name of the function subprogram which calculates f(t) to be expanded in a sine series. See Example of using this subroutine. EPSA... Input. The absolute error tolerance a. EPSR... Input. The relative error tolerance . NMIN... Input. Lower limit of terms of sine series (>0). NMIN should be taken a value such as power of 2. The default value is 8. See Notes. NMAX... Input. Upper limit of terms of sine series. (NMAX > NMIN). NMAX should be taken a value such as power of 2. The default value is 256. See Notes. B..... Output. Coefficients {bk}. One-dimensional array of size NMAX. Each coefficient is stored as shown below: B(1)=b0, B(2)=b1, ..., B(N)=bn-1, N..... Output. Number of terms n of the sine series (4). N takes a value such as power of 2. ERR.... Output. Estimate of the absolute error of the series. TAB.... Output. TAB contains a trigonometric function table used for series expansion. 324
Comments on use Subroutines used SSL II ... MGSSL, AMACH, UTABT, USINM, UNIFC FORTRAN basic function ... ABS, AMAX1, AMIN1, FLOAT Notes The function subprogram specified by the FUN parameter must be a subprogram defined at the interval [0, T] having independent variable t only as the argument. The name must be declared by the EXTERNAL statement in the program which calls this subroutine. If the function contains auxiliary variable, they must be declared by a COMMON statement to establish an interface with the calling program. See Example of using this subroutine. Use of the trigonometric function table When this subroutine is repeatedly called, the trigonometric function table is produced only once. A new trigonometric function table entry is made on an as-required basis. Therefore the contents of TAB must be kept intact when this subroutine is called subsequently. If NMIN of NMAX does not take a value such as power of 2, this subroutine assumes the maximum value of power of 2 which does not exceed that value. However NMAX = 4 is assumed if NMAX < 4 is satisfied.
FSINF
The degree of error decerement greatly depends on the smoothness of f(t) in the open interval (- ) as the number of terms n increases. If f(t) is an analytical periodic function, the error decreases according to exponential function order O (rn) (0 < r < 1). If it has up to k-th continuous derivatives, the error decreases according to rational function order O(n-k). When k = 0 or k = 1, an estimate of absolute error is not always accurate because the number of terms to be expanded increases greatly. Therefore, the function used by this subroutine should have, at least, up to 2-nd continuous derivatives. Accuracy of the series This subroutine determines a sine series which satisfies (1.1) according to the required accuracy of a and . If = 0 is specified, this subroutine expands f(t) in a sine series within the required accuracy of absolute error a. Similarly a = 0 is specified, this subroutine expands f(t) in a sine series within the required accuracy of relative error . However sine series expansion is not always successful depending on the specification of a and . For example, when a or is too small in comparison with computational error of f(t), the effect of rounding-off errors becomes greater on the computational result even if the number of terms to be expanded does not reach the upper limit. In such a case, this subroutine abnormally terminates after a condition code of 10000 is set to ICON. At this time, the accuracy of the sine series becomes the attainable limit for the computer used. The number of terms to be expanded in a sine series sometimes does not converge within NMAX evaluations depending on the characteristics of f(t). In such a case, this subroutine abnormally terminates after a condition code of 20000 is set to ICON. Each coefficient is an approximation obtained so far, and is not accurate. To determine the accuracy of sine series, this subroutine always set an estimate of absolute error in ERR. Any inverse transform can be attempted by the subroutine FSINT. Note that the contents of TAB must be kept intact whether normal or inverse transform is attempted. See Example 2. When f(t) is only a periodical function, this subroutine can be used to perform sine series expansion for odd function as (f(t) - f(-t))/2. If f(t) has no period and is absolutely integrable, its theoretical sine transform can be defined as shown in (3.1):
F ( ) = f (t )sin tdt
0
(3.1)
If f(t) is damped according to order of O (e-at) (a > 0), an approximation of the Fourier integral can be obtained as described below: Assume that f (t ) can be ignored on the interval [T, ) when T is sufficiently large. By defining T which satisfies (3.2). f (t ) < u, t T (3.2)
Where u is the unit round off. This subroutine can be used to determine sine series coefficients {bk} for f(t), assuming that f(t) is a function with period 2T. Since {bk} can be expressed as bk =
2 T 0 f (t )sin kt dt T T
(3.3)
Based on this relationship this subroutine can calculate an approximation of sine transform shown in (3.1) by using discrete sine transform. When inverse transform
f (t ) = 2 F ( )sin td 0
(3.5)
is to be calculated, the subroutine FSINT can be called for n pieces of data as follows: 2 T F T k , k = 0,1,, n 1
See Example 2. Examples Example 1: This example expands the following odd function with period 2 having auxiliary variable p f (t ) = sin t 1 2 p cos t + p 2
in a sine series according to the required accuracy of a = 5 .10-5 and = 5 .10-5. Where NMIN = 8 and NMAX = 256 are assumed.
325
FSINF
This example prints sine series coefficients when p = 1/4, 1/2 and 3/4.
C **EXAMPLE** DIMENSION B(256),TAB(127) EXTERNAL FUN COMMON P TH=ATAN(1.0)*4.0 EPSA=0.5E-04 EPSR=EPSA NMIN=8 NMAX=256 P=0.25 1 CALL FSINF(TH,FUN,EPSA,EPSR, * NMIN,NMAX,B,N,ERR,TAB,ICON) IF(ICON.GT.10000) GO TO 10 WRITE(6,600) N,ERR,ICON,P WRITE(6,601) (B(I),I=1,N) P=P+0.25 IF(P.LT.1.0) GO TO 1 STOP 10 WRITE(6,602) ICON STOP 600 FORMAT(1H0,5X,12HEXPANSION OF, * 16H FUNCTION FUN(T),3X,2HN=,I4, * 5X,4HERR=,E15.5,5X,5HICON=,I6,5X, * 2HP =, E15.5) 601 FORMAT(/(5E15.5)) 602 FORMAT(1H0,5X,14HCONDITION CODE, I8) END FUNCTION FUN(T) COMMON P FUN=SIN(T)/(1.0-2.0*P*COS(T)+P*P) RETURN END
Example 2: Sine transform and inverse transform This example transform odd function F ( ) = te x 2 sin tdt
0
in a sine series according to the required accuracy of a = 5 N10-5 and = 5 10-5 and compares the results with analytical solution F ( ) =
2 4 e 4
**EXAMPLE** DIMENSION B(256),TAB(127),ARG(256),T(256) EXTERNAL FUN COMMON PI,SQPI PI=ATAN(1.0)*4.0 SQPI=SQRT(PI) TH=SQRT(ALOG(4.0/AMACH(TH))) EPSA=0.5E-04 EPSR=0.0 NMIN=8 NMAX=256 C SINE TRANSFORM CALL FSINF(TH,FUN,EPSA,EPSR,NMIN, * NMAX,B,N,ERR,TAB,ICON) IF(ICON.GT.10000) GO TO 10 TQ=TH*0.5 H=PI/TH DO 1 K=1,N ARG(K)=H*FLOAT(K-1) B(K)=B(K)*TQ T(K)=TRFN(ARG(K)) 1 CONTINUE WRITE(6,600) N,ERR,ICON WRITE(6,610) WRITE(6,601) (ARG(K),B(K),T(K), K=1,N) C INVERSE TRANSFORM Q=1.0/TQ DO 2 K=1,N B(K)=B(K)*Q 2 CONTINUE CALL FSINT(B,N,TAB,ICON) IF(ICON. NE. 0) GO TO 10 H=TH/FLOAT(N) DO 3 K=1, N ARG(K)=H*FLOAT(K-1) T(K)=FUN(ARG(K)) 3 CONTINUE WRITE(6,620) WRITE(6,610) WRITE(6,601) (ARG(K),B(K),T(K),K=1,N) STOP 10 WRITE(6,602)ICON STOP 600 FORMAT(1H0, 5X, 15H CHECK THE SINE, * 29H TRANSFORM OF FUNCTION FUN(T), * 3X,2HN=,I4,5X,4HERR=,E15.5,5X, * 5HICON=,I5) 610 FORMAT(1H0,6X,8HARGUMENT,7X, * 8HCOMPUTED,11X,4HTRUE) 620 FORMAT(1H0,5X,17HCHECK THE INVERSE * ,10H TRANSFORM) 601 FORMAT (/(3E15.5)) 602 FORMAT (1H0,5X,14HCONDITION CODE, I6) END FUNCTION FUN(T) FUN=T*EXP(-T*T) RETURN END FUNCTION TRFN(W) COMMON PI,SQPI TRFN=W*EXP(-W*W*0.25)*SQPI*0.25 RETURN END
Then, this example performs inverse transform of the function by using the subroutine FSINT and checks the accuracy of the results.
326
FSINF
Method This subroutine applies discrete fast sine transform (based on the trapezoidal rule) to sine transform for entry of functions. Sine series expansion For simplicity, an odd function f(t) with a period of 2. The function can be expanded in a sine series as shown below: f (t ) = bk sin kt
k =1
n p 1 1 1 ~ bk p = bk f sin k j + , j + j =0 np 2 2 np
(4.7)
Since (4.8) is satisfied wt this stage {bkp +1 } can be determined. ~ bkp+1 = bkp + bk p ~ bnpp++11 k = bk p bkp , k = 1, 2, , n p 1 ~ p+1 bnpp+1 = bn p
(4.8)
(4.1) (4.2)
2 bk = f (t )bk sin kt dt 0
By using this recurrence formula for {bkp } , f(t) can be expanded in a sine series of higher degree while the number of terms is doubled as far as the required accuracy is satisfied. Then {bkp } is normalized by multipling by factor 2/np. Error evaluation for sine series The following relationship exists between the theoretical sine coefficients {bk} of f(t) and discrete sine coefficients {bkp } , taken at the p-th stage: bkp = bk + b2 mn p k + b2 mn p + k ,
m1
This subroutine uses the trapezoidal rule to compute (4.2) by dividing the closed interval [0, ] equally. By using resultant coefficients {bk} this subroutine approximates (4.1) by finite number of terms. If this integrand is smooth, the number of terms is doubled as far as the required accuracy of a and is satisfied. If sampling is sufficient, (4.3) will be satisfied. f (t ) bk sin kt < max a , r f
n 1 k =0
(4.3)
where n indicates the number of samples (power of 2+1) and b0=0. The resultant trigonometric polynomial is a trigonometric interpolation polynomial in which each breakpoint used by the trapezoidal rule is an interpolation point as shown below: f n
k = 1, 2, , n p 1
(4.9)
n1 j = bk sin kj , k =0 n
j = 0, 1, , n 1
This results from (4.2) and (4.5) as well as orthogonality of trigonometric functions. The error evaluation for a sine series at the p-th stage f (t ) bkp sin kt bnp + 2 bk
k =0 k = n p +1 n p 1
(4.4)
(4.10)
The sine series expansion is explained in detail below. Assume that coefficients obtained by the trapezoidal rule using n sample points (n=np, np=2p) are
n p 1 bkp = bk f j Sin kj , j =0 nk nk
(4.5)
can be deduced from (4.9). If f(t) is an analytical periodic function, its series coefficients {bk} decrease according to exponential function order O (rk) (0 < r < 1) as k increases. Then r can be estimated from a discrete sine coefficient at the pth stage. Let bkp = Ark (A: constant). Since k is at most n p 1, r
n p /4
k = 1, 2, , n p 1 Where the ordinary scaling factor 2/np is omitted from (4.5). When the number of terms is doubled as np+1 = 2np each coefficient can efficiently be determined by making a good use of complementary relation between the trapezoidal rule and the midpoint rule. At each midpoint between sample points used by the trapezoidal rule (4.5), f(t) can be sampled as shown below:
1 f j + n 2 p , j = 0, 1, , n p 1
coefficient of the last term np-1 to the coefficient of term 3/4np-1. This subroutine does not allow the two coefficients to be zero by accident. Therefore it uses the (np-2)-th and (3/4np-2)-th coefficients together with those coefficients to estimate a value of r as shown below. p p bn p 2 + bn p 1 r = min b p + b 3p 3 np 2 n p 1 4 4
4 np , 0.99
(4.6)
Discrete sine transform (using the midpoint rule) for (4.6) can be defined as shown below:
If r is greater than 0.99, this subroutine cannot actually expand f(t) in a sine series because the convergence rate of the series becomes weak. By using the resultant r,
327
FSINF
(4.11)
can be estimated from (4.10). Computational process Step 1: Initialization Initialization of Trigonometric function table At three points which divides interval [0, /2] equally, three values for the cosine function is obtained in reverse binary order. The trigonometric function table is not initialized if this subroutine is called in advance. The trigonometric function table is used for discrete sine transform. Initial sine series expansion This subroutine performs 4(p=2) in (4.5) and calculates 0.0, b12 , b22 , b32 . At this time, it also obtains
f
condition code of 20000 to ICON and terminates abnormally assuming that the required accuracy is not satisfied even when the number of terms to be expanded its reached the upper limit. Note that each coefficient is normalized whether this subroutine terminates normally or abnormally. Step 3: Calculation of sample points Sample points to be used for sampling of f(t) at the pth stage can be expressed as follows:
tj =
j+ np
1 , j = 0, 1, , n p 1 2
They can be obtained in reverse binary order through use of the recurrence formula shown below:
t 0 = / 2 p+1 t 2 j+1 2 pl1 = t j 2 pl + 2 p+l ,
( )
(4.16)
j = 0, 1, ,2 l 1, l = 0, 1, , p 1,
Step 2: Convergence criterion If np < NMIN is satisfied this subroutine does not perform a convergence test but immediately executes Step 3. If np > NMIN is satisfied, this subroutine performs a convergence test as described below: This subroutine estimates computational error limit
where np = 2p. Step 4: Sampling of f(t) and calculation of the norm This subroutine obtains values of f(t) for n sample points based on (4.16) and overwrites them on the sample points. It also calculates norm f based on the norm definition shown in (1.3). Step 5: Trigonometric function table creation This subroutine produces the trigonometric function table required by Step 6. The trigonometric function table is not recalculated each time this subroutine is called. Step 6: Discrete sine transform (using the midpoint rule) For sample points obtained by Step 4, this subroutine performs discrete sine transform using the Fast Fourier ~ Transform (FFT) method to determine { bk p }. Step 7: Calculation of { bkp+1 } This subroutine combines { bkp } obtained previously ~ with { bk p } by using (4.8) to obtain the coefficients { bkp+1 } of the discrete sine series consisting of 2np + 1 terms. Then, this subroutine executes Step 2 after it increases a value of p by one. Step 4 and 6 consume most of the time required to execute this subroutine. The number of multiplications required to determine the coefficients of a sine series consisting of n
= n p f (2u),
where u is the unit round off. and a tolerance for convergence test as
(4.12)
= max a , f
(4.13)
If the last two terms at the p-th stage have been lost significant digits, that is, if the coefficients satisfy (4.14). bnpp 2 + 1 p bn 1 < 2 p (4.14)
the computational accuracy cannot be increased even if this computation continues. Therefore, this subroutine replaces the absolute error ep of the sine series by the computational error p, assuming that the sine series is converged. If < is satisfied, this subroutine sets a condition code of 0 to ICON. If is satisfied, this subroutine sets a condition code of 10000 to ICON assuming that a or is relatively smaller than unit round off u. If (4.14) is not satisfied, this subroutine estimates absolute error ep based on (4.11). If ep is satisfied, this subroutine sets a condition code of 0 to ICON and terminates normally. If ep < is not satisfied but 2np NMAX is satisfied, this subroutine immediately executes Step 3. Otherwise this subroutine sets a 328
FSINF
terms is about nlog2 n. To save storage this subroutine overwrites sample points, samples and expansion coefficients onto a onedimensional array B.
For further information, see Reference [59]. For detailed information about discrete sine transform, see an explanation of the subroutines FSINT and FSINM.
329
FSINM
ISN...
CALL FSINM (A, N, ISN, TAB, ICON) TAB... Function Given n sample points {xj+1/2},
x j+1/ 2 = x j+ n 1 , j = 0, 1,, n 1 2
ICON.. (1.1)
Input. Transform or inverse transform is indicated. For transform: ISN = +1 For inverse transform: ISN = -1 Output. Trigonometric function table used in the transform is stored. One-dimensional array of size n-1. See Notes. Output. Condition code See Table FSINM-1.
by equally dividing the half period of the odd function x(t) with period 2, a discrete sine transform or its inverse transform based on the midpoint rule is performed by using the Fast Fourier Transform (FFT). Here n = 2l (l = 0 or positive integer). Sine transform By inputting {xj+1/2} and performing the transform defined in (1.2), the Fourier coefficients {n/2.bk} are obtained.
Code 0 30000
Processing Bypassed
Comments on use Subprograms used SSL II ... UPNR2, UTABT, USINM and MGSSL FORTRAN basic functions ... SQRT and MAX0 Notes General definition of Fourier Transform: The discrete sine transform and its inverse transform based on the midpoint rule are generally defined by (3.1) and (3.2) bk =
n bk = x j +1/ 2 sin j =0 n 2
n 1
1 k j + , k = 1, 2,, n 2
(1.2)
Sine inverse transform By inputting {bk} and performing the transform defined in (1.3), the value of the Fourier series {xj+1/2} are obtained. x j +1/ 2 = bk sin
k =0 n 1
(3.1)
1 1 1 k j + + bn sin j + , 2 2 2 (1.3) j = 0, 1, , n 1
x j+1/ 2 = bk sin
Parameters A..... Input. {xj+1/2} or {bk} Output. {n/2Nbk} or {xj+1/2} One-dimensional array of size n See Fig. FSINM-1. N..... Input. Sample point number n
One-dimensional array A(N) {xj+1/2} x1/2 x1+1/2 x2+1/2 N {bk } b1 b2 b3 b n 1 bn xn3/2 xn1/2
The subroutine obtains {n/2Nbk} and {xj+1/2} which correspond to the left-hand side of (3.1) and (3.2), respectively, and the user has to scale the results, if necessary. Calculation of trigonometric polynomial: When obtaining the values x(/n(j+1/2)) of the n-th order trigonometric polynomial
x(t ) = b1 sin t + b2 sin 2t + bn sin nt
Note: /2Nbk] is handled in the same way as for {bk}. Fig. FSINM-1 Data storing method
by using the inverse transform, the highest order coefficient bn must be doubled in advance. See example (b). Use of the trigonometric function table: When the subroutine is called successively for transforms of a fixed dimension, the trigonometric function table is calculated and created only once. Therefore, when calling the subroutine subsequently, the contents of the parameter TAB must be kept intact.
330
FSINM
Even when the dimension differs, the trigonometric function table need not be changed. A new trigonometric function table entry can be made on an asrequired basis. Example (a) By imputing n sample point {xj+1/2} performing the transform in the subroutine and scaling the results, the discrete Fourier coefficients {bk} are obtained. By performing the inverse transform after that, {xj+1/2} are obtained. Here n 512.
C **EXAMPLE** DIMENSION X(512),TAB(511) C SINE TRANSFORM ISN = 1 READ(5,500) N,(X(I),I = 1,N) WRITE(6,600) N WRITE(6,601) (X(I),I = 1,N) CALL FSINM (X,N,ISN,TAB,ICON) IF(ICON.NE.0) GO TO 20 C NORMALIZE CN=2.0/FLOAT(N) DO 10 K = 1,N X(K)=X(K)*CN 10 CONTINUE WRTIE(6,602) ISN WRTIE(6,601) (X(I),I = 1,N) C SINE INVERSE TRANSFORM INS=-1 CALL FSINM (X,N,ISN,TAB,ICON) IF(ICON.NE.0) GO TO 20 WRITE(6,602) ISN WRTIE(6,601) (X(I),I = 1,N) 20 WRITE(6,603) ICON STOP 500 FORMAT (I5/(6F12.0)) 600 FORMAT (1H0,5X,13HINPUT DATA N=,I5) 601 FORMAT (5F15.7) 602 FORMAT (1H0,5X,11HOUTPUT DATA,5X, * 4HISN =,I2) 603 FORMAT (1H0,5X,14HCONDITION CODE, * I8) END
READ(5,500) N,(B(I),I=1,N) WRITE(6,600) N WRITE(6,601) (B(I),I=1,N) B(N)=B(N)*2.0 CALL FSINM (B,N,ISN,TAB,ICON) IF (ICON.NE.0) GO TO 20 WRTIE(6,602) ISN WRTIE(6,601) (B(I),I=1,N) 20 WRITE(6,603) ICON STOP 500 FORMAT(I5/(6F12.0)) 600 FORMAT(1H0,5X,13HINPUT DATA N=,I5) 601 FORMAT(5F15.7) 602 FORMAT(1H0,5X,11HOUTPUT DATA,5X, * 4HISN=,I2) 603 FORMAT(1H0,5X,14HCONDITION CODE, * I8) END
Method The discrete sine transform based on the midpoint rule of dimension n(= 2l, l=0, 1, ...) is performed by using the Fast Fourier Transform (FFT). The transform based on the midpoint rule can be accomplished by considering the odd function x(t) to be a complex valued function and performing the discrete complex Fourier transform for the odd function based on the midpoint rule of dimension 2n. In this case, however, it is known that the use of the characteristics of the complex transform permits efficient transform. For the complex valued function x(t) with period 2, the discrete Fourier transform based on the midpoint rule of dimension 2n (=2l+1, l=0, 1, 2, ...) is defined as 2 n k =
2 n 1 j =0
k j + exp x 2 n
i 1 k j + n 2 (4.1) k = 0, 1, ,2n 1
(b) By inputting sine coefficients {bk} based on the midpoint rule, the values {x((j+1/2)/n)} of the nth trigonometric polynomial.
x(t ) = b1 sin t + b2 sin 2t +bn sin nt
The basic idea of the FFT is to accomplish the objective transform by repeating the elementary discrete Fourier transform of small dimension (i.e., if the radix is 2, the dimension is 2). In other words, considering sample data which consist of (j+1)th element and subsequent ones ~ = 2l +l p , p = 1, 2, and defining the with the interval n ) p( transform x p ( j, k ) =
n p 1 j =0
are obtained at the sample points {(j+1/2)/n}. The coefficient of the last term bn must be doubled before it is input. Here n 512.
C **EXAMPLE** DIMENSION B(512), TAB(511) ISN = -1
~ rn p + j + x 2 n
(4.2)
of dimension np = 2p, then the transform can be satisfied with the FFT algorithm (4.3) of radix 2.
331
FSINM
Initial value
1 x 0 ( j , 0) = x j + , 2 n j = 0 , 1 , 2n 1
is, the range of j and k used in (4.3) are halved, so the FFT algorithm of radix 2 for the discrete sine transform (4.6) can be represented by ~ j 1 , k x p ( j , k ) = x p1 ( j , k ) x p1 n p
~ ,k x p ( j , k ) = x p1 ( j , k ) + x p1 j + n p
) )}
i 1 ~ , k exp x p j , k + n p1 = x p1 ( j , k ) x p1 j + n j + p ~ n 2 p ~ j = 0 , 1, , n 1 , k = 0 , 1 , , n 1
p = 1 , 2 , l 1
p
) {
~ j 1, k x p j , n p1 k = x p 1 ( j , k ) x p1 n p i 1 j + exp ~ n 2 p 2 p = 1 , 2 , , l j = 0 , 1, , ~ n p 1 , k = 0 , 1 , n p1 2 1
) {
)}
(4.7)
p 1
(4.3) The values obtained in the final step of these recurrence equations are the discrete Fourier coefficients (4.4).
2n k = x l +1 (0 , k ) , k = 0 , 1 , , 2 n 1
(4.4)
If x(t) is an odd function, the fact that x(t) is real, i.e., x(t ) = x (t ) x (t ) is a complex conjugate of x(t))and skewsymmetric, i.e.,
x(2 t ) = x (t )
Normally, the area to store the intermediate results {xp(j, k)} needs one-dimensional array of size n, but if the input data is permuted in advance by reverse binary transformation, the above computation can be carried out by using the same area in which the data was input. The number of real number multiplications necessary for the sine transform of dimension n is about nlog2n. Transform procedure in the subroutine (a) The necessary trigonometric function table (size n1) for the transform is created in reverse binary order. (b) The sample points {x(/n(j+1/2))} (size n) are permuted in reverse binary order. (c) The FFT algorithm (4.7) which takes into consideration the skew-symmetric property of the input data is performed in the same area to obtain the Fourier coefficients in the order, bn, bn-1, ..., b1. (d) The Fourier coefficients {bk} are rearranged in ascending order. Inverse transform procedure (a) The necessary trigonometric function table for the inverse transform is created. This table is the same one as used in the transform procedure (a). (b) Rearranging the Fourier coefficients {bk} in the order, bn, bn-1, ..., b1, {bn-k} is obtained. (c) By inputting {bn-k} and tracing back words the recurrence equations (4.7) with respect to p, the function value {x(/n(j+1/2)} of the odd function x(t) is obtained in reverse binary order. (d) By permuting the obtained n data by reverse binary transformation, the function values {x(/n(j+1/2)} are obtained in normal order. For further details, refer to the Reference [58].
affects the intermediate results {xp(j, k)} of the FFT as follows: Real property: xp(j, 0) is real
2 i 1 x p j , n p k = x p ( j , k ) exp j + , ~ n 2 p ~ 1 , k = 0 , 1 , , n 1 j = 0 , 1 , n
(4.5)
Skew-symmetric property:
~ j 1, k = x p j , k xp n ( ) p ~ j = 0 , 1 , n p 1 , k = 0 , 1 , , n p 1
can be satisfied between the complex Fourier coefficients {ak} for the odd function x(t) and the Fourier coefficients defined by the following discrete sine transform bk = 2 n1 1 1 x j + sin k j + n j= 0 n n 2 2 (4.6)
Therefore, by using the characteristic (4.5) in the FFT algorithm (4.3) as well as the relationship above, the number of computations and the memory used can be reduced to a quarter of those without using them. That
332
FSINT
CALL FSINT (A, N, TAB, ICON) Function Given n sample points {xj}, x j = x n j , j = 0 , 1 , , n 1 (1.1)
Input. Sample point number n Output. Trigonometric function table used in the transform is stored. Output. Condition code. See Table FSINT-1.
Table FSINT-1 Condition codes Code 0 30000 Meaning No error N 2 (: positive integer) Processing Bypassed
by dividing equally into n the half period of the odd function x(t) with period 2 , a discrete sine transform or its inverse transform based on the trapezoidal rule is performed by using the Fast Fourier Transform (FFT). Here n = 2l (n: positive integer) Sine transform By inputting {xj} and performing the transform defined in (1.2), the Fourier coefficients {n/2.bk} are obtained.
n 1 n bk = x j sin kj , k = 0 , 1 , , n 1 0 j = n 2
Comments on use Subprograms used SSL II ... UPNR2, UTABT, USINM and MGSSL FORTRAN basic functions ... SQRT and MAX0 Notes General definition of Fourier transform: The discrete sine transform and its inverse transform based on the trapezoidal rule are generally defined by (3.1) and (3.2), bk =
(1.2)
2 n 1 x j sin kj , k = 1 , 2 , , n 1 0 j = n n n 1 x j = bk sin kj , j = 1 , 2 , , n 1 j =0 n
N
(3.1) (3.2)
Sine inverse transform By inputting {bk} and performing the transform defined in (1.3), the values of the Fourier series {xj} are obtained.
n 1 x j = bk sin kj , j =0 n b0 = 0.
j = 0 , 1 , , n 1
(1.3)
Parameters A..... Input. {xj} or {bk}. Output. {n/2 bk} or {xj}. One-dimensional array of size n. See Fig. FSINT-1.
N
The subroutine obtains {n/2 bk} and {xj} which correspond to the left-hand side of (3.1) and (3.2), respectively, and the user has to scale the results, if necessary. Use of the trigonometric function table: When the subroutine is called successively for transforms of a fixed dimension, the trigonometric function table is calculated and created only once. Therefore when calling the subroutine subsequently, the contents of parameter TAB must be kept intact. Even when the dimension differs, the trigonometric function table need not be changed. A new trigonometric function table entry can be made on an asrequired basis. Example By inputting n sample points { xj}, performing the transform by the subroutine and scaling the results, the discrete Fourier coefficients {bk} are obtained. Also by performing the inverse transform after that, {xj} are obtained. Here n 512.
C C **EXAMPLE** DIMENSION X(512),TAB(255) SINE TRANSFORM READ(5,500) N,(X(I),I=1,N) WRITE(6,600) N
bk } is handled the same way as for {bk}. 2 Fig. FSINT-1 Data storing method
Note: {
333
FSINT
WRITE(6,601) (X(I),I=1,N) CALL FSINT (X,N,TAB,ICON) IF (ICON.NE.0) GO TO 20 C NORMALIZE CN=2.0/FLOAT(N) DO 10 K=1,N 10 X(K)=X(K)*CN WRITE(6,602) WRITE(6,601)(X(I),I=1,N) C SINE INVERSE TRANSFORM CALL FSINT(X,N,TAB,ICON) IF(ICON.NE.0) GO TO 20 WRITE(6,602) WRITE(6,601) (X(I),I = 1,N) 20 WRITE(6,603) ICON STOP 500 FORMAT(I5/(6F12.0)) 600 FORMAT(1H0,5X,13HINPUT DATA N=,I5) 601 FORMAT(5F15.7) 602 FORMAT(1H0,5X,11HOUTPUT DATA) 603 FORMAT(1H0,5X,14HCONDITION CODE, * I8) END
p + bp bkp+1 = b k k
bnpp++11 k
k = 1 , 2 , , np 1 p p = bk + bk
(4.3)
p bnp+1 = b n
The equations shown in (4.3) can be considered as recurrence formula with respect to p to obtain { b kp +1 } from { bkp }. Therefore, when performing transform with division number 2l, if the initial condition bll = x(/2) is given and the discrete sine transform based on the midpoint rule of dimension np is performed each at the p-th stage (p=1, 2, ..., l-1) then the discrete sine transform series { bkp ; k = 1, 2, ..., np-1} (p = 1, 2, ..., l) based on the trapezoidal rule can be obtained by using equations (4.3). The number of multiplications of real numbers executed is about nlog2n (n = 2 ). Procedural steps taken in the subroutine Permuting the sample points, x0, x1, ..., xn-1, in reverse binary order, they are denoted as x(0), x(1), ..., x(n-1), where x(0) = x0 = 0. Next, the trigonometric function table (size n/2 -1) 1)necessary for the transform is made in reverse binary order corresponding to the sample point number. Finishing with the preparatory processing, the sine transform is performed as follows: (a) Initialization bll = x(1) and p = 1 (b) Sine transform based on the midpoint rule of dimension np By inputting np sample points x(np), x(np+1), ..., x(np+1-1) and performing the sine transform based on the midpoint rule, { b kp } are obtained in the same
p ,b p ,, b p . For the sine area in the order b 1 np n p 1
Method The discrete sine transform based on the trapezoidal rule of dimension n(= 2l, l = 1, 2, ...) is performed by using the radix 2 Fast Fourier Transform (FFT). The transform based on the trapezoidal rule can be accomplished efficiently by using the transform based on the midpoint rule. The subroutine uses this method. Dividing equally into np (= 2, p = 1, 2, ...) the half period [0, ] of an odd function x(t) with period 2, the discrete sine transform based on the trapezoidal rule is defined as
n p 1 b kp = x n j=0 p
j sin n kj , k = 1 , 2 , , n p 1 (4.1) p
Also the discrete sine transform based on the midpoint rule of dimension np is defined as
n p 1 1 1 p = x b k j + sin k j + k j =0 np 2 2 np
(4.2)
transform based on the midpoint rule, see Method for subroutine FSINM. (c) Calculation of recurrence equations with respect to p } {b k At the p-th stage, the intermediate results, x(0) , b1p , b2p ,bnpp 1 ,
p , , b p are stored in the array elements, x(0), x(1), b np 1
k = 1 , 2 , , n p
In Eqs. (4.1) and (4.2), however, the ordinary scaling factor 2/np is omitted. Doubling the division number to np+1 the { b kp +1 } can be expressed as follows by using { b k } and
p
p {b
k p +1
} both of
at the (p+1)th stage are calculated from the two p k = 1,2, , n 1 at the p-th elements bkp and b p k
stage, according to the recurrence equations (4.3), and they are stored in the corresponding array elements of the p-th stage. By repeating procedure (b) and (c) above with p = 1, 2, ..., l-1 the {bk} can be obtained. For further details, refer to the Reference [58].
334
GBSEG
CALL GBSEG (A, B, N, NH, M, EPSZ, EPST, LM, E, EV, K, IT, VW, ICON) Function This subroutine obtains m eigenevalues and corresponding eigenvectors of a generalized eigenproblem
Ax = Bx
EPST..
LM...
(1.1) E....
consisting of real symmetric matrices A and B of order n and bandwidth h in the ascending or descending order of absolute values by using m given initial vectors. It adopts the Jennings simultaneous iteration method with the Jennings acceleration. When starting with the largest or smallest absolute value, matrix B or A must be positivedefinite respectively. The eigenvectors is normalized such that:
X T BX = I
EV...
or
X AX = I
T
1 m << n and 0 h << n Parameters A..... Input. Real symmetric band matrix A. When eigenvalues are obtained in the ascending order of absolute values, the contents of A are altered on output. Compressed mode for symmetric band matrices. A is a one-dimensional arrays of size n (h+1) h (h+1)/2. B..... Input. Real symmetric band matrix B. The contents of B are altered on output. Compressed mode for symmetric bank matrices. B is a one-dimensional array of size n (h+1) h(h+1)/2. See Comments on use. N..... Input. Order n of matrices A and B. NH... Input. Bandwidth h of matrices A and B. See Comments on use. M.... Input. Number of eigenvalues and eigenvectors to be obtained, m. M = m ... m eigenvalues are obtained in the descending order of absolute values. M = m .. m eigenvalues are obtained in the ascending order of absolute values. EPSZ.. Input. Relative zero criterion for pivoting associated with LLT decomposition of matrix A or B.
If zero or negative value is given, an appropriate default value is used. See Comments on use. Input. Constant used for convergence criterion of eigenvectors. If zero or negative value is given, an appropriate default value is used. See Comments on use. Input. Upper limit for the number of iterations. If the number of iterations exceeds the limit, the processing is terminated. See Comments on use. Output. Eigenvalues. Each eigenvalue is stored in the sequence as specified by the M parameter. E is a one-dimensional array of size m. Input. m initial vectors stored in the m-th columns (in columnwise direction). See Comments on use. Output. Eigenvectors. Eigenvectors are stored in the m-th columns (in columnwise direction). EV (K, m+2) is a two-dimensional array. Input. Adjustable dimension of EV. Output. Number of iterations which are made until eigenvectors are obtained. Work area. VW is a on-dimensional array of size 2n+m(3m+1)/2. Output. Condition code. See Table GBSEG-1.
Table GBSEG-1 Condition codes Code 0 20000 Meaning No error The number of iterations exceeded upper limit LM. Processing Terminated. E and EV contain the approximations of eigenvalues and eigenvectors obtained so far. Discontinued.
25000
Orthogonalization of eigenvectors at each interation cannot be attained. Matrix A or matrix B is not positive-definite. Matrix A or matrix B is singular. NH < 0, NH N, N > K, M = 0 or M > N
Comments on use Subprograms used SSL II ... AMACH, MSBV, TRID1, TEIG1, TRBK, UCHLS, UBCHL, UBCLX, UERST, MGSSL FORTRAN basic functions ... IABS, ABS, AMAX1, FLOAT, SQRT
335
GBSEG
Notes When eigenvalues are obtained in the ascending order of absolute values, the contents of matrix B are saved into array A. When this subroutine handles several generalized eigenproblems involving the identical matrix B, it can utilize the contents of matrix B in array A. The bandwidth of matrix A must be equal to that of matrix B. If the bandwidth of matrix A is not equal to that of matrix B, the greater band-width is assumed; therefore zeros are added to the matrix of smaller band-width as required. The EPSZ default value is 16 u when u is the unit round off. When EPSZ contains 10-s this subroutine regards the pivot as zero if the cancellation of over s significant digits occurs for the pivot during LLT decomposition of matrix A or B. Then this subroutine sets a condition code ICON to 29000 and terminates abnormally. If the processing is to proceed at a low pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. If the pivot becomes negative during LLT decomposition of matrix A or B, the matrix is regarded as singular and a condition code ICON to 28000. This subroutine terminates abnormally. The parameter EPST is used to examine the convergence of eigenvector normalized as x 2 = 1 . Whenever an eigenvector converges for the convergence criterion constant , the corresponding eigenvalue converges at least with accuracy A and in most cases is higher. It is therefore better to choose somewhat a larger EPST value. When defining the unit round off as u, the default value is = 16u. When the eigenvalues are very close to each other, however, conveygence may not be attained. If so, it is safe to choose such that 100u. The upper Limit LM for the number of iteration is used to forcefully terminate the iteration when convergence is not attained. It should be set taking into consideration the required accuracy and how close the eigenvalues are to each other. The standard value is 500 to 1000. It is desirable for the initial eigenvectors to be a good approximation to the eigenvectors corresponding to the obtained eigenvalues. If approximate vectors are not available, the standard way to choose initial vectors is to use the first m column vectors of the unit matrix I. The number of eigenevalues and eigenvectors, m had better be smaller than n such that m/n < 1/10. The numbering of the eigenvalues is from the largest (or smallest) absolute value of eigenvalues such as 1, 2, ..., n. It is desirable if possible, to choose m in such a way that m+1 / m << 1 (or m+1 /
Example This example obtains eigenvalues and corresponding eigenvectors of generalized eigenproblem Ax = Bx consisting of real symmetric matrices A and B of order n and bandwidth h. n 100, h 10 and m 10.
C **EXAMPLE** DIMENSION A(1100), B(1100), E(10), * EV(100,12), VW(400) 10 READ(5,500) N, NH, M, EPSZ, EPST IF(N. EQ. 0) STOP MM=IABS(M) MN=(NH + 1)* (N+N-NH)/2 READ(5,510) (A(I), I=1, NN), * (B(I), I=1, NN), * ((EV(I, J), I=1, N), J=1, MM) WRITE (6,600) N, NH, M NE=0 DO 20 I=1, N NI=NE+1 NE=MIN0(NH+1, I)+NE 20 WRITE (6,610) I, (A(J), J=NI, NE) WRITE (6,620) N, NH, M NE=0 DO 30 I=1, N NI=NE+1 NE=MIN0(NH+1, I) + NE 30 WRITE (6,610) I, (B(J), J=NI, NE) CALL GBSEG (A, B, N, NH, M, EPSZ, * EPST, 500, * E, EV, 100, IT ,VW, ICON) WRITE (6, 630) ICON, IT IF (ICON. GE. 20000) GO TO 10 CALL SEPRT (E, EV, 100, N, MM) GO TO 10 500 FORMAT (3I5, 2E15.7) 510 FORMAT (5E15.7) 600 FORMAT (1H1, 20X, 17HORIGINAL MATRIX A, * 5X, 2HN=,I3, 5X, 3HNH=,I3, 5X, 2HM=, I3/) 610 FORMAT (1H0, 7X, I3, 5E20.7/(11X, 5E20.7)) 620 FORMAT (1H0, 20X, 17HORIGINAL MATRIX B, * 5X, 2HN=,I3, 5X, 3HNH=,I3, 5X, 2HM=, I3/) 630 FORMAT (1H0, 20X, 5HICON=,I5, * 5X, 3HIT=,I5) END
The SEPRT subroutine used in this example prints eigenvalues and eigenvectors of a real symmetric matrix. For further information see an example of using the subroutine SEIG1. Method This subroutine obtains m eigenvalues and corresponding eigenvectors of generalized eigenproblem. Ax = Bx (4.1)
consisting of real symmetric band matrices A and B of order n and bandwidth h in the ascending of descending
336
GBSEG
order of absolute values of the eigenvalues by using m given initial vectors. It adopts the Jennings simultaneous iteration method with Jennings acceleration. For detailed information about the Jennings simultaneous iteration method see the Method of the subroutine BSEGJ. Computational procedures If m eigenvalues 1, 2, ..., m are to be determined in the ascending order of absolute values, (4.1) must be transformed as shown in (4.2)
1 Bx = Ax = Ax
to save storage as follows: For i=1, 2, ..., m (4.9) results by using auxiliary vector y. y = ui ~ ~ v i = B 1 AB T y (4.9)
This processing can be performed by using the subroutines UBCLX and MSBV. Since C is an m-dimensional symmetric matrix, its lower triangular portion can be denoted by: cii = y T v i ,
c ji = u v i ,
T j
(4.2)
j = i +1,
, m
(4.10) (4.11)
i = 1 / i
, i = 1,
, m
Thus, by taking ui for each column of U and obtaining vi, cii and cji, V is produced directly in the area for U. 3) Solving the eigenproblem for C, C is decomposed to the form
C = PMP T
Therefore, the following explanation is concerned about only the case when m eigenvalues are to be determined in the descending order of absolute values. 1) Matrix B is decomposed into LLT by the subroutine UBCHL. ~~ B = BB T This procedure transforms a general eigenproblem shown in (4.1) to a standard eigenproblem such that:
~ ~ B 1 AB T u = u where ~ u = B T x
(4.12)
(4.3)
(4.4) (4.5)
where M is a diagonal matrix using eigenvalues of C as diagonal elements and P is a m-dimensional orthogonal matrix. This processing is performed by using the subroutines TRID1, TEIGI and TRBK, which are called successively. Then the eigenvectors corresponding to the eigenvalues are sorted such that the largest absolute values comes first using the subroutine UESRT. 4) Multiply V by P form the right, and produce an n m matrix W shown below:
W = VP
(4.13)
2) Let m approximate eigenvectors u1, u2, ..., um be formed into m columns of U which is an n m matrix. These vectors are assumed to be formed into an orthonormal matrix as shown in (4.6): U TU = I m (4.6)
5) To orthogonalize each column of W, produce an m - dimensional real symmetric positive-definite matrix WT W and decompose it into LLT shown below: WTW = LLT (4.14)
where Im indicates an m-order unit matrix. ~ ~ By multiplying U by B T , A and B 1 in this order from the left, ~ ~ V = B 1 AB T U results. Multiplying V by UT from the left, ~ ~ C = U T V = U T B 1 AB T U (4.8) (4.7)
This processing is performed by using the subroutine UCHLS. If LLT decomposition is not possible this subroutine sets a condition code ICON to 25000 and terminates abnormally. 6) Solve the equation U*LT = W to compute U*=WL-T (4.15)
U* has an orthonormal system as in equation (4.6). The m-th columns um and um* of U and U* are examined to see if
* um d = um
(4.16)
337
GBSEG
is satisfied. If this convergence condition is not satisfied, see U* as a new U and go to Step 2). 7) If it is satisfied, the iteration is stopped and the diagonal elements of M obtained in Step 3) become eigenvalues, and the first m row of ~ X = B T U * (4.17)
become the corresponding eigenvectors. This processing is performed by using the subroutine UBCLX. These steps given above are a general description of the Jenningss method. For further information see References [18] and [19]. Jennings acceleration To accelerate the simultaneous Jennings iteration method previously explained, the Jennings acceleration method for vector series in incorporated in this subroutine. See explanations about subroutine BSEGJ for the principle and application of Jennings acceleration.
338
GCHEB
E51-30-0301
GCHEB, DGCHEB
CALL GCHEB (A, B, C, N, ICON) Function Given an n-terms Chebyshev series defined on the interval [a, b]
f (x ) =
n 1
k =0
' ck Tk
2 x (b + a ) ba
(1.1)
Notes When a derivative of an arbitrary function is required, this subroutine can be used together with the subroutine FCHEB for Chebyshev series expansion. When a differential coefficient is determined at arbitrary point, this subroutine should be used together with the subroutine ECHEB for evaluation of the Chebyshev series. See Example. This subroutine can be called repeatedly to compute a derivative of higher order. The error of a derivative can be estimated from the absolute sum of the last two terms. Note that the error of a derivative increases as order increases. If only one term is entered this subroutine produces only one term. Example This example expands exponential function
xn f ( x) = e x = n=0 n !
Tk ' c k
2 x (b + a ) ba
(1.2)
and determines its coefficients { ck }. Symbol denotes to make sum but the initial term only is multipled by factor 1/2. Where a b and n 1. Parameters A..... Input. Lower limit a of the interval for the Chebyshev series. B..... Input. Upper limit b of the interval for the Chebyshev series. C..... Input. Coefficients{ck} . Each coefficient is stored as shown below: C(1) =c0, C(2) =c1, ..., C(N) =cn-1 Output. Coefficients {ck} for the derivative. Each coefficient is stored as shown below: C(1) =c0, C(2) =c1, ..., C(N-1) =cn-2 C is a one-dimensional array of size N. N..... Input. Number of terms n. Output. Number of terms of the derivative n1. See Notes. ICON.. Output. Condition code. See Table GCHEB-1.
Table GCHEB-1 Condition codes Code 0 30000 Meaning No error Either of the two conditions occurred: 1N<1 2A=B Processing Bypassed
defined on the interval [-2, 2] in a Chebyshev series according to the required accuracy of = 0 and = 5N10-5 by using the subroutine FCHEB. It then computes the derivative from the resultant Chebyshev series by using this subroutine. It also evaluates differential coefficients by using the ECHEB subroutine while increasing the value of x from 2 to 2 with increment 0.05 and compares them with the true values.
C **EXAMPLE** DIMENSION C(257), TAB(127) EXTERNAL FUN EPSR = 5.0E-5 EPS = 0.0 NMIN = 9 NMAX = 257 A = -2.0 B = 2.0 CALL FCHEB (A, B, FUN, EPSA, EPSR, NMIN, * NMAX, C, N, ERR, TAB, ICON) IF (ICON. NE. 0) GOTO 20 WRITE (6, 600) N, ERR, ICON WRITE (6, 601) (C(K), K=1, N) CALL GCHEB (A, B, C, N, ICON) IF (ICON. NE. 0) GOTO 20 WRITE (6, 602) WRITE (6, 601) (C(K), K=1, N) WRITE (6, 603) H = 0.05 X = A 10 CALL ECHEB (A, B, C, N, X, Y, ICON) IF (ICON. NE. 0) GOTO 20 ERROR = FUN(X)-Y WRITE (6, 603) X, Y, ERROR X = X + H
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... FLOAT
339
GCHEB
IF (X. LE. B) GOTO 10 STOP 20 WRITE (6, 604) ICON STOP 600 FORMAT (1H0, 3X, 12HEXPANSION OF, 116H FUNCTION FUN(X),3X,2HN =,I4, 3X, 26HERROR=, E13.3, 3X, 5HICON=, I6) 601 FORMAT (/(5E15.5)) 602 FORMAT(1H0, 5X, 13HDERIVATIVE OF, 117H CHEBYSHEV SERIES) 603 FORMAT (1H0, 10X, 1HX, 7X, 112HDIFFRENTIAL, 6X, 5HERROR/) 604 FORMAT(1X,3E15.5) 605 FORMAT(1H0,5X,14HCONDITION CODE, I8) END FUNCTION FUN(X) REAL*8 SUM, XP, TERM EPS = AMACH (EPS) SUM = 1.0 XP = X XN = 1.0 N = 1 10 TERM = XP/XN SUM = SUM + TERM IF (DABS (TERM). LE. 1 DABS (SUM) * EPS) GOTO 20 N = N + 1 XP = XP*X XN = XN*FLOAT (N) GOTO 10 20 FUN = SUM RETURN END
Method This subroutine performs termwise differentiation of an n-terms Chebyshev series defined on the interval [a, b] and expresses its derivative in a Chebyshev series. Let a derivative to be defined as follow:
2 x (b + a ) n 2 2 x (b + a ) d n 1 Tk ' ck Tk = ' ck (4.1) dx k =0 b a k =0 ba
The following relationships exist between coefficients for the derivative: cn 1 = 0 4 2 = cn ( n 1)cn 1 b a 4 +1' 2 = cn kck + ck b a k = n 2, n 3, , 1
(4.2)
This subroutine determines coefficients { ck } by using differential formula (4.2) for Chebyshev polynomials. The number of multiplications required to compute a derivative from an n-terms series is about 2n. For further information about recurrence formula (4.2), see explanation of the subroutine ICHEB.
340
GINV
CALL GINV (A, KA, M, N, SIG, V, KV, EPS, VW, ICON) Function This subroutine obtains the generalized inverse A+ of an m n matrix A using the singular value decomposition method. m 1 and n 1. Parameters A..... Input. Matrix A. Output. Transposed matrix of A+ . A is a two-dimensional array A (KA, N). See Notes. KA.... Input. Adjustable dimension of array A. KA M. M..... Input. Number of rows in matrix A, m. N..... Input. Number of columns in matrix A or number of rows in matrix V, n. SIG... Output. Singular values of matrix A. One-dimensional array of size n. See Notes. V..... Output. Orthogonal transformation matrix produced by the singular value decomposition. V is a two-dimensional array V (KV, K). K = min (M + l, N). KV..... Input. Adjustable dimension of array V. KV N. EPS... Input. Tolerance for relative zero test of the singular value. EPS 0.0 If EPS is 0.0 a standard value is used. See Notes. VW..... Work area. VW is a one-dimensional array of size n. ICON.. Output. Condition code. See Table GINV-1.
Table GINV-1 Condition code Code 0 15000 30000 Meaning No error Any singular value could not be obtained. KA < M, M < 1, N < 1, KV < N or EPS < 0.0 Processing Discontinued Bypassed
Notes Note that the transposed matrix (A+)T instead of the generalized inverse A+ is placed on A. Singular values are non-negative. They are stored in descending order. When ICON is set to 15000, unobtained singular values are -1. In this case, resultant singular values arent arranged in descending order. Since the EPS has direct effects on the determination of the rank of A, it must be specified carefully. The least squares minimal norm solution of a system of linear equations Ax = b can b expressed as X = A+ b by using the generalized inverse A+. However this subroutine should not be used except when generalized inverse A+ is required. The subroutine LAXLM is provided by SSL II for this purpose. Example This example obtains a generalized inverse of an m n real matrix. 1 n m 100
C **EXAMPLE** DIMENSION A(100,100),SIG(100), * V(100,100),VW(100) 10 READ(5,500) M,N IF(M.EQ.0) STOP READ(5,510) ((A(I,J),I=1,M),J=1,N) WRITE(6,600) M,N, * ((I,J,A(I,J),J=1,N),I=1,M) CALL GINV(A,100,M,N,SIG,V,100,0.0, * VW, ICON) WRITE(6,610) ICON IF(ICON.NE.0) GO TO 10 WRITE(6,620) N,M. * ((I,J,A(J,I),I=1,M),J=1,N) GO TO 10 500 FORMAT(2I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,5X,15HORIGINAL MATRIX/ * 6X,11HROW NUMBER=,I4,5X, * 14HCOLUMN NUMBER=,I4/ * (10X,4(1H(,I3,1H,,I3,1H),E17.7, * 3X))) 610 FORMAT(1H ,10X,15HCONDITION CODE= * ,I6) 620 FORMAT(1H1,5X, * 19HGENERALIZED INVERSE/6X, * 11HROW NUMBER=,I4,5X, * 14HCOLUMN NUMBER=,I4/(10X, * 4(1H(,I3,1H,,I3,1H),E17.7,3X))) END
Comments on use Subprograms used SSL II ... ASVD1, AMACH, MGSSL FORTRAN basic functions ... None
Method The n m matrix satisfying all conditions listed in (4.1) with regard to an m n real matrix A is called (MoorePenrose matrix) the generalized inverse of A.
341
GINV
The matrix obtained by adding an n (m-n) zero + . matrix to the right of + is equal to c (4.1)
+ LetX = V c U cT
A generalized inverse is uniquely defined for a real matrix A and is denoted by A+. If matrix A is a square and nonsingular matrix, A+ is equal to A-. Based on the uniqueness of generalized inverse (4.2) and (4.3) can be established from (4.1).
Substituting such a X and (4.5) into (4.1), (4.1) is repressed as shown in (4.9) due to orthogonality of Uc and V.
+ c c c = c + + + c c c = c T ( c c+ ) = c c+ T + + = ( c c) c c
(4.9)
(A ) = A , ( A ) = (A )
+ + T + +
(4.2)
T
(4.3) Thus, due to the uniqueness of the generalized inverse, A+ can be defined as
+ A+ = V c U cT
Therefore m n can be assumed without loss of generality. Singular value decomposition and a generalized inverse Let the singular value decomposition of A be defined as follows:
A = U V T
(4.10)
+ By using the characteristics of c and definitions of Uc, (4.10) can be rewritten as follows:
(4.4)
A+ = V + U T
(4.11)
When U is an m n matrix satisfying UT U = I, V is an n n orthogonal matrix and is an n n diagonal matrix. By adding mn column vectors to the right of U to produce an orthogonal matrix Uc of order m and adding a zero matrix with the (mn)-th row, the n-th column to the lower portion of to obtain a matrix c, then the singular value decomposition of A can be expressed as follows: A = Uc c V T If is determined as follows:
= diag( 1 , 2 ,
Computational procedures This subroutine determines matrices U, and V by performing the singular value decomposition of A. The resultant matrix U is placed in the area containing matrix A by subroutine ASVD1. For detailed information, see an explanation of subroutine ASVD1. A transposed matrix (A+)T corresponding to A+ is placed in the area containing matrix A through use of
(4.5)
(A )
+ T
= U + V T
(4.12)
, )
n
(4.6)
, )
+ n
(4.7)
This subroutine tests the zero criterion for singular value i when producting +. The zero criterion is 1 EPS, where 1 is the maximum singular value. If a singular value is less than the zero criterion, it is regarded as zero. If EPS contains 0.0, this subroutine assumes a value of 16u as the standard value, where u is the unit round off. For further information, see Reference [11] and an explanation of the subroutine ASVD1.
342
GSBK
Array B
l11
Lower triangular matrix L
l21 l22
CALL GSBK (EV, K, N, M, B, ICON) Function m number of eigenvectors y1, y2, ..., ym, of n order real symmetric matrix S are back transformed to eigenvectors x1, x2, ..., xm for the generalized eigenproblem Az = Bx, where S is a matrix given by S=L-1AL-T B = LLT, L is a lower triangular matrix and n 1. Parameters EV..... Input. m number of eigenvectors of real symmetric matrix S. Output. Eigenvectors for the generalized eigenproblem Ax = Bx. Two dimensional array, EV (K, M) (See Comments on use). K..... Input. Adjustable dimension of input EV. N..... Input. Order n of real symmetric matrix S, A and B. M..... Input. The number of eigenvalue, m (See Comments on use). B..... Input. Lower triangular matrix L. (See Fig. GSBK-1). One dimensional array of size n (n+1)/2 (See Comments on use). ICON.. Output. Condition code. See Table GSBK-1.
Table GSBK-1 Condition codes Code 0 10000 30000 Meaning No error N=1 N < |M|, K < N or M = 0 Processing EV (1, 1) = 1.0 / B(1) Bypassed
n (n+1) 2
(1.1)
Notes Output parameter B of subroutine GSCHL can be used as input parameter B of this subroutine. If input vectors y1, y2, ..., ym are normalized in such a way that YTY = I is satisfied, then eigenvectors x1, x2, ..., xm are output in such a way that XTBX = I is satisfied, where Y = [y1, y2, ..., ym] and X = [x1, x2, ..., xm]. When parameter M is negative, its absolute value is used. Example All eigenvalues and corresponding eigenvectors of the generalized eigenproblem with n order real symmetric matrix A and n order positive definite symmetric matrix B are obtained using subroutines
343
GSBK
* I3/46X,5HEPSZ=,E15.7,5HEPST=,E15.7) 610 FORMAT(1H0,7X,I3,5E20.7/(11X, 5E20.7)) 620 FORMAT(1H1,10X,21H**ORIGINAL MATRIX B**) 630 FORMAT(/11X,19H** CONDITION CODE=, I5/) END
This process is shown in eqs. (4.3) to (4.6). Decomposing positive symmetric matrix B into B = LLT and substituting this into eq. (4.1), we get Ax = LLT x L-1 Ax = LT x L-1 A(L-T LT )x = LT x (4.4) (4.3)
Subroutine SEPRT in this example is used to print eigenvalues and eigenvectors of a real symmetric matrix. For details, refer to the example of subroutine SEIG1. Method Eigenvector y of n order real symmetric matrix S is back transformed to eigenvector x of the generalized eigenvalue problem. Ax = Bx (4.1)
L-1 AL-T (LT x) = ( LT x) therefore, S = L-1AL-T y = LTx Since L is know, x can be obtained from eq. (4.6) as follows: x = L-T y For details see Reference [13] pp. 303-314. (4.7) (4.5) (4.6)
where A is a symmetric matrix and B is a positive definite symmetric matrix. In this case, reduction of eq. (4.1) to the standard form (4.2) must be done in advance. Sy = y (4.2)
344
GSCHL
Table GSCHL-1 Condition codes Code 0 10000 28000 Meaning No error N=1 Pivot became negative in LL decomposition of matrix B. Input matrix B is not positivedefinite. Pivot was regarded as T relatively zero in LL decomposition of matrix B. The input matrix B is possible singular. N<1
T
CALL GSCHL (A, B, N, EPSZ, ICON) Function For n order real symmetric matrix A and n order positive definite symmetric matrix B, the generalized eigenvalue problem Ax = Bx is reduced to the standard form. (1.1)
29000
Bypassed
30000
Bypassed
Array B
(1.2)
Lower triangular matrix L
Parameter A..... Input. Real symmetric matrix A. Output. Real symmetric matrix S. In the compressed storage mode for a symmetric matrix. One dimensional array of size n (n+1)/2. B..... Input. Positive definite symmetric matrix B. Output. Lower triangular matrix L (See Fig. GSCHL-1). In the compressed storage mode for a symmetric matrix. One dimensional array of size n(n+1)/2. N..... Input. The order n of the matrices. EPSZ.. Input. A tolerance for relative accuracy test of pivots in LLT decomposition of B. When specified 0.0 or negative value, a default value is taken (See Comments on use). ICON.. Output. Condition code. See Table GSCHL1. Comments on use Subprograms used SSL II ... AMACH, UCHLS, and MGSSL FORTRAN basic function ... SQRT Note The default value for parameter EPSZ is represented as EPSZ = 16N u where u is the unit round-off. (Refer to subroutine LSX) If EPSZ is set to 10-S, when a pivot has cancellation of more than s decimal digits in LLT decomposition of positive definite symmetric matrix B, the subroutine considers the pivot to be relative zero, sets condition code ICON to 29000 and terminates the processing. To continue the processing even when the pivot becomes smaller, set a very small value into EPSZ. When the pivot becomes negative in LLT decomposition of B, B is considered not to be a
positive definite matrix. This subroutine, in this case, sets condition code ICON to 28000 and terminates the processing. Example The generalized eigenvalue problem Ax = Bx with n order real symmetric matrix A and n order positive definite symmetric matrix B is reduced to a standard form for the eigenvalue problem using the subroutine GSCHL, and the standard form is reduced to a real symmetric tridiagonal matrix using subroutine TRID1. After that, the m number of eigenvalues are obtained by using the subroutine BSCT1. This is for n 100.
C ** EXAMPLE** DIMENSION A (5050),B(5050,VW(300), * E(100),D(100),SD(100) 10 CONTINUE READ (5,500) N,M,EPSZ,EPST
345
GSCHL
IF (N.EQ.0) STOP NN=N*(N+1)/2 READ (5,510) (A(I),I=1,NN) READ (5,510) (B(I),I=1,NN) WRITE (6,600) N,M,EPSZ,EPST NE=0 DO 20 I=1,N NI=NE+1 NE=NE+I 20 WRITE (6,610) I,(A(J),J=NI,NE) WRITE (6,620) NE=0 DO 30 I=1,N NI=NE+1 NE=NE+I 30 WRITE (6,610) I,(B(J),J=1,NI,NE) CALL GSCHL (A,B,N,EPSZ,ICON) WRITE (6,630) ICON IF (ICON.GE.20000) GO TO 10 CALL TRID1 (A,N,D,SD,ICON) CALL BSCT1 (D,SD,N,M,EPST,E,VW,ICON) WRITE (6,630) ICON IF (ICON.EQ.30000) GO TO 10 WRITE (6,640) MM=IABS (M) WRITE (6,650) (IE(I),I=1,MM) GO TO 10 500 FORMAT (2I5,2E15.7) 510 FORMAT (5E15.7) 600 FORMAT (1H1,10X,20H** OROGINAL MATRIX A/ * 11X,10H**ORDER=,15,10X,6H**M=,I3, * 10X,9H**EPSZ=,E15.7,10X,6HEPST =,E15.7) 610 FORMAT (1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT (1H0,10X,21H**ORIGINAL MATRIX B**) 630 FORMAT (/11X,19H**CONDITION CODE =,I5/) 640 FORMAT (1H0/11X,14H**EIGENVALUES) 650 FORMAT (5X,2HE (,I3,2H)=,E15.7) END
as shown in eqs. (4.3) to (4.6) Since B is a positive definite symmetric matrix, it can be decomposed to B = LLT (4.3)
where L is a lower triangular matrix. This decomposition can be uniquely determined if the diagonal elements of L are chosen positive. From (4.1) and (4.3) L-1 AL T ( LT x ) = (LT x ) where L-T means (L-1)T or (LT)-1 Therefore, putting
S = L-1 AL T y = L T x
(4.4)
(4.5) (4.6)
then eq. (4.2) can be derived. The decomposition in (4.3) is done by the Cholesky method, that is , the elements of matrix L are successively obtained for each row as shown in eqs. (4.7) and (4.8)
l11 = (b11 ) 2
1
Method When A is an n order symmetric matrix and B is a positive definite symmetric matrix, the generalized engenvalue problem Ax = Bx (4.1)
(4.7)
j 1 l jj , j = 1, , i 1 lij = b l l ij ik jk k =1 1 i = 2, i 1 2 2 lii = b l ii ik k =1
, n (4.8)
346
GSEG2
Input. Adjustable dimension of array EV. Work area. One dimensional array of size 7n. Output. Condition code. See Table GSEG21.
CALL GSEG2 (A, B, N, M, EPSZ, EPST, E, EV, K, VW, ICON) Function The m largest or m smallest eigenvalues of the generalized eigenvalue problem Ax = Bx (1.1)
Table GSEG2-1 Condition codes Code 0 10000 Meaning No error N=1 Processing E(1)=A(1)/B(1) X(1, 1)=1.0/SQRT (B(1)) The eigenvectors are set to zero vectors. All the eigenvectors are set to zero vectors. Discontinued.
15000
20000
are obtained by bisection method, and the corresponding m number of eigenvectors x1, x2, ..., xm are obtained by the inverse iteration method, where A is an n order real symmetric matrix and B an n order positive definite symmetric matrix. The eigenvectors satisfy. XTBX = I where X = [x1, x2, ..., xm] and n m 1. Parameters A..... Input. Real symmetric matrix A in the compressed mode storage for a symmetric matrix. One dimensional array of size n (n + 1)/2. The contents will be altered on output. B..... Input. Positive definite matrix B in the compressed storage mode for a symmetric matrix. One dimensional array of size n (n + 1)/2. The contents will be altered on output. N..... Input. Order n of real symmetric matrix A and positive definite symmetric matrix B. M..... Input. The number m of eigenvalues obtained. M = + m .... The number of largest eigenvalues desired. M = m .... The number of smallest eigenvalues desired. EPSZ.. Input. A tolerance for relative accuracy test of pivots in LLT decomposition of B. If specifying 0.0 or negative value, a default value is taken. (See Comments on use). EPST... Input. An absolute error tolerance used as a convergence criterion for eigenvalues. If specifying 0.0 or negative value, a default value is taken. (See Comments on use). E..... Output. m eigenvalues, Stored in the sequences as specified by parameter M. One dimensional array of size m. EV..... Output. Eigenvectors. The eigenvectors are stored in columnwise direction. Two dimensional array, EV (K, M) (1.2)
28000
29000
30000
Pivot became negative in LL decomposition of B. Input matrix B is not positivedefinite. Pivot was regarded as relative zero in LL decomposition of B. Input matrix B is possible singular. M = 0 or N < IMI or K < N
Discontinued.
Bypassed.
Comments on use Subprogram used SSL II ... GSCHL, TRID1, UTEG2, TRBK, GSBK, AMACH, UCHLS, and MGSSL FORTRAN basic functions ... IABS, SQRT, SIGN, ABS, AMAX1, and DSQRT Notes The default value for parameter EPSZ is represented as EPSZ = 16Nu where u is the unit round-off. If EPSZ is set to 10-S, when a pivot has cancellation of more than s decimal digits in LLT decomposition of positive definite symmetric matrix B, the subroutine considers the pivot to be relative zero, sets condition code ICON to 29000 and terminates the processing. If the processing is to proceed even at a low pivot value, EPSZ has to be given the minimum value but the result is not always guaranteed. When the pivot becomes negative in LLT decomposition of B, B is considered not to be positive definite. This subroutine, in this case, sets condition code ICON to 28000 and terminates the processing. The default value for parameter EPST is EPST = u max max min , where u is the unit round-off, and max and min
347
GSEG2
are upper and lower limits, respectively, of the existing range (given by the Gershgorins theorem) of eigenvalues obtained from Ax = Bx. When both very large and small eigenvalues exist, it may be difficult to obtain the smaller eigenvalues with good accuracy. It is possible, though, by setting a small value into EPST, but the computation time may increase. For details of the method to enter a value into EPST, refer to subroutine BSCT1. Example This example obtains the m largest or m smallest eigenvalues and corresponding eivenvectors for the generalized eigenproblem Ax = Bx which has n order real symmetric matrix A and n order positive definite symmetric matrix B. n 100, m 100
C ** EXAMPLE** DIMENSION A (5050),B(5050),E(10), * EV(100,10),VW(700) 10 CONTINUE READ (5,500) N,M,EPSZ,EPST IF (N.EQ.0) STOP NN=N*(N+1)/2 READ (5,510) (A(I),I=1,NN) READ (5,510) (B(I),I=1,NN) WRITE (6,600) N,M,EPSZ,EPST NE=0 DO 20 I=1,N NI=NE+1 NE=NE+I WRITE (6,610) I,(A(J),J=NI,NE) 20 CONTINUE WRITE (6,620) NE=0 DO 30 I=1,N NI=NE+1 NE=NE+I WRITE (6,610) I,(B(J),J=1,NI,NE) 30 CONTINUE CALL GSEG2 (A,B,N,M,EPSZ,EPST, * E,EV,100,VW,ICON) WRITE (6,630) ICON IF (ICON.GE.20000) GO TO 10 MM=IABS(M) CALL SEPRT (E,EV,100,N,MM) GO TO 10 500 FORMAT (2I5,2E15.7) 510 FORMAT (5E15.7) 600 FORMAT (1H1,17HOROGINAL MATRIX A,5X, * 2HN=,I3,3H M=,I3,6H EPSZ=, * E15.7,6H EPST=,E15.7) 610 FORMAT (1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT (1H1,17H OROGINAL MATRIX B) 630 FORMAT (1H0,20X 5HICON=,I5) END
Subroutine SEPRT in this example is used to print eigenvalues and eigenvectors of a real symmetric matrix. For details, refer to the Example of subroutine SEIG1. Method Eigenvalues and eigenvectors of the generalized eigenvalue problem Ax = Bx (4.1)
which has n order real symmetric matrix A and n order positive definite symmetric matrix B are obtained as follows: Reduction of the generalized eigenvalue problem into the standard form. Since B in eq. (4.1) is a positive definite symmetric matrix, it can be decomposed as follows: B = LLT (4.2)
where L is an n order lower triangular matrix. This decomposition can be uniquely determined when the diagonal elements of L are chosen positive values. From eqs. (e.1) and (4.2), if eq. (4.1) is multiplied by L-1 from the left of A and by LTLT from the right, the following eq.
-1 -T T T L AL L x = L x
( )
(4.3)
(4.4) (4.5)
then S becomes a real symmetric matrix and eq. (4.3) becomes Sy = y (4.6)
which is the standard form for the eigenvalue problem. Eigenvalues and eigenvectors of a real symmetric matrix. Real symmetric matrix S is reduced to real symmetric tridiagonal matrix, and eigenvlalue and corresponding eigenvector y of T are obtained by the bisection method and inverse iteration method. y is further back transformed to eigenvector y of S. Eigenvectors of a generalized eigenvalue problem. Eigenvector x in eq. (4.1) can be obtained from the eigenvector y determined above, such as x = LTy (4.7)
348
GSEG2
The above processing are accomplished using subroutine GSCHL for the 1-st step., TRID1 and UTEG2 for the 2nd step and GSBK for the last step. For details see Reference [13] pp. 303-314.
349
HAMNG
CALL HAMNG (Y, N1, H, XEND, EPS, SUB, OUT, VW, ICON) Function This subroutine solves a system of first order differential equations: y ' 1 = f 1 ( x , y1 , y 2 , y' 2 = f 2 ( x, y1 , y 2 ,
y' n = f n ( x, y1 , y 2 ,
, y ), y , y ), y
n
= y1 ( x 0 ) = y 2 ( x 0 ) n 20 , y n ), y n 0 = y n ( x 0 )
10
(1.1)
with initial values y1(x0), y2(x0), ..., yn(x0) throughout the interval [x0, xe], by Hammings method. Initially a specified stepsize is used, however it may be made smaller to achieve the specified accuracy, or larger so that the computation will proceed more rapidly, while still meeting the desired accuracy. Parameters Y..... Input. Initial values x0, y10, y20, ..., yn0. Onedimensional array of size n+1. The contents of Y are altered on exit. N1... Input. n+1, where n is the number of equations in the system. H..... Input. Initial step size H 0.0. The value of H is changed during the computations. XEND.. Input. Final value xe, of independent variable x. Calculation is finished when the approximation at xe is obtained. ESP... The relative error tolerance. If 0.0 is specified, the standard value is used. (See the Comments and Method sections.) SUB... Input. The name of subroutine subprogram which evaluates fi (i = 1, 2, ..., n) in (1.1). The subprogram is provided by the user as follows: SUBROUTINE SUB (YY, FF) Parameters YY: Input. One-dimensional array of size n + 1, where YY(1) = x, Y(2) = y1, YY(3) = y2, ..., YY(n+1) = yp FF: Output. One-dimensional array of size n + 1, where FF(2) = f1, FF(3) = f2, FF(4) = f3, ..., FF(n+1) = fp (See the example.)
VW..... ICON..
Nothing may be substituted in FF(1). Input. The name of subroutine subprogram which receives the approximations. In other words, at each integration step with stepsize HH (not necessarily the same as the initial stepsize), subroutine HAMNG transfers the results to this subprogram. This subprogram is provided by the user as follows: SUBROUTINE OUT (YY, FF, NI, HH, IS) Parameters YY: Input. Calculated results of x, y1, ..., yn One-dimensional array of size n+1 where YY(1) = x, YY(2) = y1, ..., YY(n+1) = yn FF: Input. Calculated results of y1, ..., yn ..., y2, ..., FF(n+1) = ynFF(1) is usually set to 1. N1: Input. n+1. HH: Input. The stepsize with which yi and yi were determined. IS: Input. Indicator that gives relative magnitude of HH to the initial stepsize H. i.e. HH is related to H as HH = 2IS*H (See the Comments section.) If IS is set equal to -11 in the subprogram, calculation can terminate at that moment. In this subprogram, except for parameter IS, the contents of the parameters must not be changed. Work area. One-dimensional array of size 18 (n+1). Output. Condition code. See Table HAMNG-1.
Table HAMNG-1 Condition codes Code 0 10000 Meaning No error 0.0 < EPS < 64 u, where u is the unit round off. Processing The standard value (64u) is used for EPS, and processing is continued. Terminated
20000
30000
Calculation was performed with a stepsize 2-10 times the specified stepsize H, however, a relative error less than or equal to EPS could not be achieved. N1 < 2, EPS < 0.0, 1.0 < EPS, or (XEND-Y(1)*H 0.0.
Bypassed
350
HAMNG
Comments Subprogram used SSL II...RKG,AMACH FORTRAN basic functions...ABS,AMAX1 Note SUB and OUT must be declared as EXTERNAL in the program from which this subroutine is called. If IS becomes less than -10, ICON is set to 20000 and calculation is terminated. ICON is set to 0 when the user sets IS = -11 in subroutine OUT.EPS must satisfy the condition 64nEPS<1 Example Initial value problem (3.1) is obtained for H=0.1, XEND=5.0 and EPS=10-4
4 2 y2 = 2 y1 + y2 , y20 = y2 (1) = 3 x x y1 = y2 , y10 = y1 (1) = 5
initial value problem of a system of first order ordinary differential equations (1.1) can be rewritten as:
= f 0 (y0 , y1 ,......, yn ), y00 = x0 y0 = f1 (y0 , y1 ,......, yn ), y10 = y1 (x0 ) y1 = f 2 (y0 , y1 ,......, yn ), y20 = y2 (x0 ) y2 : : y , yn 0 = yn (y0 ) n = f n (y0 , y1 ,......, yn ) where f 0 (y0 , y1 ,......, yn ) = 1
(4.2)
(3.1)
y = (y0 , y1 , y2 ,......, yn ) T y 0 = (y00 , y10 , y20 ,......, yn 0 ) T f (y ) = ( f 0 ( y ), f1 ( y ),......, f n (y )) with f i ( y ) = f i (y 0 , y1 ,......, yn ) i = 0,1,......, n
T
(4.3)
'
)<%140) (-1)27-32 =:; )<8)62%0 79&398 =! =! =! ,! )47!) ;6-8) '%00 ,%12+=,)4779&398:;-'32 ;6-8) -'32 7834 *361%8,, <,<<,=<,=< ,*<,*<,,,<,-7 *361%8, <,-'32!- )2( 79&6398-2) 79&==** (-1)27-32 ==** **!== **! ==== == ==== 6)8962 )2( 79&6398-2) 398==**2,,-7 (-1)27-32 ==2**2 ;6-8) ==--!2**--!2 ,,-7 6)8962 *361%8, <)- )2(
Let the vector whose elements are yi (i=0,1,......,n) be represented as y. Then (4.2) can be simplified to
y = f ( y ), y0 = f (x0 )
(4.4)
Hammings formula Let the approximation and true solution at x=xj, be yj and y(x), respectively, and their corresponding derivatives be yj=f(yj) and y(xj)=f(y(xj). 2h,xk, the calculated solutions and derivatives
yk 3 , y k 2 , y k 1 , y k yk 3 , yk 2 , yk 1 , yk
are known. yk+1 is determined from quantities pk+1,mk+1 and ck+1 through the following procedures. Calculating pk+1
pk +1 = yk 3 + 4h (2 yk yk 1 + 2 yk 2 ) 3
(4.5)
In(4.5), value Pk+1 roughly predicts yk+1,to a degree and is called the predictor. By the Taylor theorem, it can be expanded as:
y x k +1 = y x k 3 + + 2 y x k 2
( ) ( ) ( )]
4h 2 y x k - y x k 1 3
[ ( ) ( )
( )
14 5 (5) + h y 1 45
(4.6)
y0 (x ) = x , y00 = y0 (x0 ) = x0
(4.1)
351
HAMNG
where, n1 depends on the elements of y and it lies between xk-3and xk+1. In (4.6), the term (14/45) h5y(5)( 1) is called the truncation error of pk+1. This means that even if yn and yi were true solution and derivative and there were no round-off errors, pk+1 has an error of(14/45)h5y(5)(1). Calculation mk+1 mk + 1 = pk + 1 + 112 (ck pk ) 121 (4.7)
y(x k +1 ) = pk +1 +
(4.9)
Furthermore, if it can be assumed that y(5)(x) does not change greatly been 1 and 2, from (4.9) we obtain h 5 y (5) (1 ) h5 y (5) (2 ) 360 (ck +1 pk +1 ) 121
(ck will be described later.) In(4.7), mk+1 is a "modified" value of pk+1, called the modifier. The second term on the right hand side of (4.7) is the estimated truncation error of pk+1(its derivation is not shown here.). Calculating ck+1 With mk + 1 = f (mk + 1 ) c k +1= 1 3h (9 yk yk 2 ) + 8 (mk +1 + 2 yk yk 1 ) 8 (4.8)
and finally the truncation error of ck+1 can be expressed as 1 5 ( 5) 9 h y (2 ) (ck +1 pk +1 ) 40 121 (4.10)
ck+1 is the finally corrected value of pk+1 called the corrector. Using the same rationale as in (4.6), truncation error in ck+1 can be derived as (1/40)h5y(5)(2). If ck+1 has the specified accuracy, it is used as the approximation yk+1 Calculating the starting values In the above method, the previously-described four points are required. Therefore, to start the calculation, the values y0 , y1, y2 , y3 , y1, y2 , y3 y0 must be calculated using another method. This is performed in this subroutine using the Runge-Kutta-Gill method (subroutine RKG). In calculating m4, the quantity c3-p3 is required, but only in this case c3-p3=0 is assumed. Estimating the error in ck+1 Since the truncation errors in predictor pk+1 and modifier ck+1 are respectively (-1/40)h5y5(22), if the round-off error can be disregarded in comparison with these errors, it can be seen that
Step size control If calculation is made with a constant stepsize, the desired accuracy may not be achieved at certain points. On the other hand, the accuracy of the results can be so much higher than the required accuracy that the effect of round-off errors is greater than that of truncation errors. As a result, the lower digits of yi will oscillate, unless the stepsize is properly controlled. Since truncation error of modifier ck+1 use as the approximation, is given in (4.10), the stepsize is controlled as follows: (a) If (4.11) holds with respect to all elements, ck+1 is used as the approximation. 9 ck + 1 pk + 1 EPS max yk , c k + 1 121
(4.11)
where, EPS is the specified tolerance for the relative error. Its standard value is 64u. (b) If (4.12) holds with respect to all elements, ck+1 is used as the approximation. 9 ck + 1 pk + 1 TOL max y k , ck + 1 121
(4.12)
where TOL=EPS/32 And also, the stepsize is doubled for the next step. At this time, the value of the previous yk-5 is needed again. Thus, the informations prior to yk-5 are kept as long as possible. (c) If (4.13) holds for a particular elements,ck+1 is not used as the approximation. 9 ck + 1 pk + 1 > EPS max y k , ck + 1 121
(4.13)
352
HAMNG
In this case, the current stepsize is halved, and calculations for the step are made again. At this time, yk-1/2 and yk-3/2 are needed. Using yk-1 and yk-2 as the starting values, the Runge-Kutta-Gill method is used to calculated them. If the stepsize is changed due to (b) or (c), the quantity ck-pk is recalculated as c k pk = 242 3h yk yk 3 ( yk 3 + 3 yk 2 27 8
xi
XEND
+ 3 yk 1 + yk )
(4.14)
where h,yi , and h'i on the right side are all quantities after the stepsize has been changed. Calculating the solution at XEND If the previously described method is used, the approximation at XEND may not necessarily be obtained. To make sure that it is obtained at XEND, this subroutine uses the following algorithem. Assume the state just before the independent variable x exceeds XEND and let the value of x at that time be xi and the stepsize be h (Fig. HAMG-1)
When this state is reached, the Hamming method is no longer used. Instead, the Runge-Kutta-Gill method is applied using xi as the starting point. Calculating two approximate solutions with stepsize(XEND-xi )/2 and (XEND)-xi ), solution ye at XEND is obtained as
( 2) + y(2) y(1) 15 ye = ye e e
(4.15)
where ye(2) is approximate solution at XEND with stepsize h=(XEND-xi )/2 ye(1) is approximate solution at XEND with stepsize h=(XEND-xi ). For further information, see Reference[70].
353
HBK1
B21-11-0602
HBK1, DHBK1
CALL HBK1(EV,K,N,IND,M,P,PV,DV,ICON) Function Back transformation is performed on m eigenvectors of an n-order real Hessenberg matrix H to obtain the eigenvectors of a real matrix A. Then the resulting eigenvectors are normalized such that x 2 = 1 . H is obtained from A using the Householder method. 1 m n .
Comments on use Subroutines used SSL II......NRML, and MGSSL FORTRAN basic functions......ABS and SQRT Notes Eigenvectors are stored in EV such that each real eigenvector occupies one column and each complex eigenvector occupies two columns (one for the real part and one for the imaginary part). Refer to Fig. HBK1-1. After subroutine HVEC is executed, parameters EV, IND, and M can be used as input parameters to this routine.
Number of eigenvectors 1 1 2 1 2 3 0 3 4 1 m M1 1 M 0 Real part of a complex eigenvector Imaginary part of a complex eigenvector
Parameters EV...... Input. m eigenvectors of real Hessenberg matrix H(see "Comments on use"). EV is a two-dimensional array, EV(K,M) Output. Eigenvectors of real matrix A. K...... Input. Adjustable dimension of array EV and P. N...... input. Order n of real Hessenberg matrix H. IND...... Input. Specifies, for each eigenvector, whether the eigenvector is real or complex. If the J-th column of EV is a real eigenvector, then IND(J)=1,; if it is the real part of a complex eigenvector, then IND(J)=-1, if it is the imaginary part of a complex eigenvector, then IND(J)=0. IND is a one-dimensional array of size M. M...... Input. Size of array IND. P...... Input. Transformation matrix provided by Householder method (see "Comments on use"). P(K,N) is a two-dimensional array. PV...... Input. Transformation matrix provided by Householder method (see "Comments on use"). DV...... Input. Scaling factor used for balancing of matrix A. DV is a one-dimensional array of size n. If matrix A was not balanced, DV=0.0 can be specified since it need not be a onedimensional array. ICON...... Output. Condition code. See Table HBK1-1.
Table HBK1-1 Condition codes Code 0 10000 30000 Meaning No error N=1 N<M,M<1orK<N Processing EV(1,1)=1.0 Bypassed
IND
EV Real eigenvector Real part of a complex eigenvector Imaginary part of a complex eigenvector Real eigenvector
k2 k a k( +)2 k
( ) ank
k
n22 (n 2 ) ann 2
Parameters A and PV of subroutine HES1 correspond to P and PV of this routine and can be used as input parameters to this routine. The information of the transformation matrix in the Householder method should be entered in P and PV as shown in Fig. HBK1-2. aij(k) are elements of Ak used in
A k +1 = PkT A k Pk ,k = 1,2,..., n 2
(3.1)
k are determined by
(k ) (k ) (k ) k = (ak ak an k ) +1k ) + ( + 2k ) + ... + (
2 2 2
(3.2)
354
HBK1
For further information, refer to the section on HES1. Refer to the section on BLNC for the contents of scaling factor DV. Example Ehgenvalues and eigenvectors of an n-order real matrix are calculated using the following subroutines. Eigenvectors are calculated in the order that the eigenvalues are determined. BLNC... balances an n-order real matrix HES1... reduces a balanced real matrix to a real Hessenberg matrix HSQR... determines eigenvalues of a real Hessenberg matrix. HVEC... determines eigenvectors of a real Hessenberg matrix HBK1... back transforms eigenvectors of a real Hessenberg matrix into eigenvectors of a real matrix, then normalizes the resultant eigenvectors. n100,m10
C **EXAMPLE** DIMENSION A(100,100),DV(100),PV(100),IND(100), * ER(100), EI(100), AW(100,104), EV(100,100) 10 READ(5,500) N IF(N.EQ.0) STOP READ(5,510)((A(I,J),I=1,N),J=1,N) WRITE(6,600) N DO 20 I=1,N 20 WRITE(6,610)(1,J,A(I,J),J=1,N) CALL BLNC(A,100,N,DV,ICON) WRITE(6,620)ICON IF(ICON.NE.0) GO TO 10 CALL HES1(A,100,N,PV,ICON) MP=N DO 35 II=1,N I=1+N-II DO 30 J=1,MP 30 AW(J,I)=A(J,I) 35 MP=I CALL HSQR(AW,100,N,ER,EI,M,ICON) WRITE(6,620)ICON IF(ICON.EQ.20000) GO TO 10 DO 40 I=1,M 40 IND(I)=1 CALL HVEC(A,100,N,ER,EI,IND,M,EV,100,AW, * ICON) WRITE(6,620)ICON IF(ICON.GE.20000) GO TO 10 CALL HBK1(EV,100,N,IND,M,A,PV,DV,ICON) CALL EPRT(ER,EI,EV,IND,100,N,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,10X,18H** ORIGINAL MATRIX * //11X,10H** ORDER=,15) 610 FORMAT(/4(5X,2HA(,I3,1H,,I3,2H)=, E14.7)) 620 FORMAT(/11X,19H** CONDITION CODE =,I5/) END
In this example, subroutine EPRT is used to print the eigenvalues and corresponding eigenvectors of the real matrix. For further information see the example in the EIG1 section. Method Back transformation of the eigenvectors of a real Hessenberg matrix H to the eigenvectors of the balanced ~ real matrix A and back transformation of the ~ eigenvectors of A to the eigenvectors of the real matrix A are performed. The resulting eigenvectors are normalized such that x 2 = 1 . The real matrix A is balanced using the diagonal similarity transformation shown in (4.1). The balanced ~ real matrix A is reduced to a real Hessenberg matrix using the Householder method which performs the (n-2) orthogonal similarity transformations shown in (4.2).
~ A = D 1 AD
(4.1)
P
T 2
~ P1T AP1 P2
P
n2
(4.2)
T h (where Pi = I ui ui i )
Let eigenvalues and eigenvectors of H be and y, then obtain Hy= y From (4.1) and (4.2),(4.3) becomes: PnT 2 (4.3)
P
T 2
P1T D 1 ADP1 P2
P
n2
y = y
(4.4)
P
P
n2
y = DLP1 P2
P
n2
(4.5)
(4.6)
= xi +1 ui ui
hi xi +1 i = n 2, ,21 ,
(4.7) (4.8)
x = Dx1
For further information on the Householder method and balancing, refer to the sections on HES1 and BLNC. NRML is used to normalize the eigenvectors. For details, see Reference [13] pp339-358
355
HEIG2
B21-25-0201
HEIG2, DHEIG2
Table HEIG2-1 Condition codes Code 0 10000 Meaning No error N=1 Processing E(1)=A(1,1) EVR(1,1)=1.0 EVI(1.1)=0.0 The eigenvectors are set to zero vectors. All the eigenvectors are set to zero vectors. Bypassed
Eigenvalues and corresponding eigenvectors of an Hermitian matrix (Householder method, bisection method and inverse iteration method)
CALL HEIG2(A,K,N,M,E,EVR,EVI,VW,ICON)
15000
Function The m largest or m smallest eigenvalues of an n-order Hermitian matrix A are obtained using the bisection method, where 1mn. Then the corresponding eigenvectors are obtained using the inverse iteration method. The eigenvectors are normalized such that x 2 = 1. Parameters A...... Input. Hermitian matrix A in the compressed storage mode. Refer to "2.8 Data Storage". A is a two-dimensional array, A(K,N). The contents of A are altered on output. K...... Input. Adjustable dimension of array A,EVER, and EVI(n). N...... Input. Order n of the Hermitian matrix. M...... Input. M=+m... The number of largest eigenvalues desired. M=-n... The number of smallest eigenvalues desired. E...... Output. Eigenvalues. One dimensional array of size m. EVR,EVI Output. The real part of the eigenvectors are stored into EVR and the imaginary part into EVI both in columnwise direction. The l-th element of the eigenvector corresponding to the j-th eigenvalue E(J) is represented by EVR(L,J)+i.EVI(L,J), where i= 1 . EVR and EVI are two dimensional arrays EVR(K,M), and EVI(K,M). VW...... Work area. One dimensional array of size 9n. ICON...... Output. Condition code. See Table HEIG2-1. Comments on use Subprograms used SSL II...TRIDH, TEIG2, TRBKH, AMACH, MGSSL, and UTEG2 FORTRAN basic functions ... IABS,SQRT,ABS, and AMAX1. Note This subroutine is provided for an Hermitian matrix and not for a general complex matrix. This subroutine should be used to obtain both eigen values and eigenvectors. For determining only eigenvalues, subroutines TRIDH and BSCT1
20000
30000
M=0,N<|M| or K<N
should be used. Example The m largest (or smallest) eigen values of n-order Hermitian matrix A as well as the corresponding eigenvectors are obtained in this example for n100 and m 10.
C **EXAMPLE** DIMENSION A(100,100),E(10),EVR(100,10), * EVI(100,10),VW(900) 10 CONTINUE READ(5,500) N,M IF(N.EQ.0) STOP READ(5,510)((A(I,J),I=1,N),J=1,N) WRITE(6,600) N,M DO 20 I=1,N 20 WRITE(6,610)(I,J,A(I,J),J=1,N) CALL HEIG2(A,100,N,M,E,EVR,EVI,VW,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) GO TO 10 MM=IABS(M) CALL HEPRT(E,EVR,EVI,100,N,MM) GO TO 10 500 FORMAT(2I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1///40X,19H**ORIGINAL MATRIX** *5x,2HN=,I3,5X,2HM=,I3//) 610 FORMAT(/4(4X,2HA(,I3,1H,,I3,2H)=,E15.7)) 620 FORMAT(1H0,20X,5HICON=,I5) END
Subroutine HEPRT used in above example is for printing eigenvalues and eigenvectors of an Hermitian matrix, shown as follows:
SOUBROUTINE HEPRT(E,EVR,EVI,K,N,M) DIMENSION E(M),EVR(K,M),EVI(K,M) WRITE(6,600) DO 10 I=1,M 10 WRITE(6,610) I,E(I) KAI=(M-1)/3+1 LST=0 WRITE(6,620) DO 20 I=1,KAI
356
HEIG2
INT=LST+1 LST=LST+3 IF(LST.GT.M)LST=M WRITE(6,630)(J,J=INT,LST) WRITE(6,640) DO 20 J=1,N 20 WRITE(6,650)J,(EVR(J,L),EVI(J,L), L=INT,LST) RETURN 600 FORMAT(1H1///5X,20H**HERMITIAN MATRIX**, * ///5X,15H**EIGENVALUES**/) 610 FORMAT(5X,2HE(,I3,2H)=,E20.8) 620 FORMAT(1H0,///5X,16H **EIGENVECTORS**//) 630 FORMAT(1H0,3X,3(20X,2HX(,I3,1H), 14X)) 640 FORMAT(//13X,3(9HREAL PART,10X, * 10HIMAG.PART,11X)) 650 FORMAT(1X,I3,6E20.8) END
tridiagonal matrix T by diagonal unitary transformation, T=V*HV where P is a unitary matrix and V is a diagonal unitary matrix. Eigenvalues and eigenvectors of the real symmetric tridiagonal matrix m eigenvalues of T are obtained by the bisection method, then the corresponding eigenvector y is obtained using the inverse iteration method. The inverse iteration method solves (4.2)
Method Eigenvalues and eigenvectors of n order Hermitian matrix A are obtained through the following procedures: Reduction of the Hermitian matrix to a real symmetric tridiagonal matrix. This is done first by reducting the Hermitian matrix A to Hermitian tridiagonal matrix H using the Householder method, H=P*AP then by reducing it further to a real symmetric (4.1)
(T I ) y
= y r 1 r = 1,2,
(4.3)
repeatedly to get eigenvector y, where is the eigenvalue obtained by the bisection method and y0 is an appropriate initial vector. Eigenvectors of the Hermitian matrix Eigenvector x of A can be obtained using eigenvector y obtained in (4.3) as x=PVy (4.4)
Eq. (4.4) is the back transformation of eqs. (4.1) and (4.2). The above three are performed with subroutines TRIDH,TEIG2 and TRBKIH respectively. For details, see references[12], [13] pp. 259-269, and [17].
357
HES1
B21-11-0302 HES1,DHES1
Reduction of a real matrix to a real Hessenberg matrix (Householder method)
CALL HESI(A,K,N,PV,ICON) Function An n-order real matrix A is reduced to a real Hessenverg matrix H using the Householder method (orthogonal similarity method). H=PTAP P is the transformation matrix n1. Parameters A...... Input. Real matrix A. Output. Real Hessenberg matrix H and transformation matrix P. (See Fig. HES1-1) A is a two-dimensional array A (K, N) K...... Input. Adjustable dimension of array A(n) N...... Input. Order n of real matrix A. PV...... Output. Transformation matrix P (See Fig. HES1-2). PV is a one-dimensional array of size n. ICON... Output. Condition code. See Table HES1-1.
A
1 PV 1 a21 12
Comments on use Subprograms used SSL II ... AMACH, and MGSSL FORTRAN basic functions ... ABS, DSQRT, and SIGN Notes Output arrays A and PV are necessary for determining the eigenvalues and corresponding eigenvectors of real matrix A. The precision of eigenvalues is determined in the real Hessenberg matrix transformation process. For that reason, this subroutine has been implemented so that real Hessenberg matrices can be determined at as high a precision as possible; however, in case of matrix containing very large and very small eigenvalues, the precision of the smaller values, some of which are difficult to precisely determine tends to be more affected by the reduction process. Example After an n-order real matrix is reduced to a real Hessenberg matrix, subroutine HSQR is used to determine the eigenvalues. n100.
C **EXAMPLE** DIMENSION A(100,100),PV(100), ER(100),EI(100) 10 READ (5,500)N IF(N.EQ.0)STOP READ(5.510)((A(I,J),I=1,N),J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610)(I,J,A(I,J),J=1,N) CALL HES1(A,100,N,PV,ICON) WRITE(6,620) WRITE(6,630)ICON IF(ICON.EQ.30000) GO TO 10 WRITE(6,610)((I,J,A(I,J),J=1,N),I=1,N) CALL HSQR(A,100,N,ER,EI,M,ICON) WRITE(6,640) WRITE(6,630)ICON IF(ICON.EQ.20000 GO TO 10 WRITE(6,650)(I,ER(I),I,EI(I),I=1,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,10X,18H**ORIGINAL MATRIX * //11X,10H**ORDER=,I5/) 610 FORMAT(/4(5X,2HA(,I3,1H,,I3,2H)=, E14.7)) 620 FORMAT(1H0/11X,20H**HESSENBERG MATRIX) 630 FORMAT(/11X,19H**CONDITION CODE=,I5/) 640 FORMAT(1H0/11X,14H**EIGENVALUES) 650 FORMAT(5X,3HER(,I3,2H)=,E14.7, * 5X,3HEI(,I3,2H)=,E14,7) END
a 1 31 1 a41 a (1) n1
) a k( k+2 k
an( kk)
( n2 ) an n2
1 (k) 2 ak +1k k 1 2 ( n 2) an 1n 2 n 2
Note: The section indicated with * is the Hessenberg matrix; the rest contains some information for the transformation matrix. X indicates work areas. Fig HEW1-1 A and PV after Householder transformation Table HES1-1 Condition code Code 0 10000 30000 Meaning No error N=1 or N=2 K<N or N<1 Processing Transformation is not performed. Bypassed
Method An n-order real matrix A is reduced to a real Hessenberg Matrix through n-2 iterations of the
358
HES1
k = 1,2,
, n 2
and overflow in the computations of (4.2) to (4.4), the elements on the right side of (4.2) are scaled by (4.1)
i = k +1
(k) ai k
where, A1=A.Pk is the transformation (and orthogonal) matrix. When transformation is completed, An-1 is in the real Hessenberg matrix. The k-th transformation is performed according to the following procedure: Let
k) k = ak( +1 k
When determining ukT of (4.3), to insure that cancellation cannot take place in computation of a k( k+)1 k k 1 2 , the sign of k 1 2 is taken to be that of
) a k( k+1 k
Ak = aij
(k ) nk
( )
(k)
2
0, uk T =
, 0, a
) + (a ) ++(a )
2
(k ) k +2 k
(4.2)
(k) nk
Instead of determining Pk for the transformation of (4.1), Ak+1 if determined by (4.7) and (4.8). Bk +1 = Pk T Ak = Ak uk uk T Ak hk Ak +1 = Bk +1 Pk = Bk +1 ( Bk +1 uk hk )uk
T
(k ) k +1 k
1
k 2 , ak( k+)2 k ,
, a
(4.7) (4.8)
) 2 hk = k ak( k+1 k k
Pk = I uk uk T hk
By applying Pk in (4.5) to (4.1), a k( k+)2 k to an( kk) of Ak can be eliminated. The following precatuions are taken during the transformation. To avoid possible underflow
The elements of uk obtained from (4.3) are stored in array A and one-dimensional array PV in the form shown in Fig.HES1-2, because transformation matrix is needed for determining the eigenvectors of real matrix Pk. When n=2 or n=1, transformation is not performed. For further information see Reference[13]pp.339-358.
359
HRWIZ
F20-02-0201 HRWIZ,DHRWIZ
Judgment on Hurwitz polynomials
CALL HRWIZ(A,NA,ISW,IFLG,SA,VW,ICON) Function This subroutine judges whether the following polynomial of degree n with real coefficients is a Hurwitz polynomial (all zeros lies in the lefthalf plane Re(s)<0:
P(s) = a1s n + a2 s n1 +
+a s + a
n
n+1
If P(s) is not a Hurwitz polynomial, the subroutine searches for 0 such that P(s+) becomes a Hurwitz polynomial for > 0(0) Parameters A...... Input. Coefficents of P(s). One-dimensional array of size n+1, assigned in the order of A(1)=a1, A(2)=a2,......,A(n+1)=an+1. NA...... Input. Degree n of P(s). ISW...... Input. Control information. 0: Only judges whether P(s) is a Hurwitz polynomial. 1: Judges whether P(s) is a Hurwitz polynomial, and if it is not a Hurwitz polynomial, searches for 0. Others: 1 is assumed. IFLG... Output Result of judgment. 0: P(s) is Hurwitz polynomial. 1: P(s) is not a Hurwitz polynomial. SA...... Output. The value of 0:0.0 if P(s) is a Hurwitz polynomial. VW...... Work area: One-dimensional array of size n+1. ICON...... Output. Condition code. (See Table HRWIZ1.)
Table HRWIZ-1 Condition codes Code 0 20000 30000 Meaning No error. Value 0 has not been found. NA<1 or A(1)=0. Processing Bypassed. Bypassed.
Notes Since the function of this subroutine relates to obtaining the inverse Laplace transform f(t) of a rational function F(s)=Q(s)/P(s), it can also be used to roughly check the characteristic of f(t). This means that F(s) has singularities in the domain of Re(s)0 if P(s) is not Hurwitz polynomial, and the value of the inverse transform function f(t)increases exponentially as the value of t approaches infinity. To obtain the inverse Laplace transform f(t) of a rational function F(s), use subroutine LAPS1 or LAPS2 depending on whether F(s) is known to be regular in the domain of Re(s)>0. (See Chapter 8 for details about numerical calculation of the inverse Laplace transforms.) Example Given a polynomial P(s)=s4-12s3+54s2-108s+81, the following judges whether it is a Hurwitz polynomial.
C **EXAMPLE** DIMENSION A(5),VW(5) NA=4 NA1=NA+1 A(1)=1.0 A(2)=-12.0 A(3)=54.0 A(4)=-108.0 A(5)=81.0 ISW=1 WRITE(6,600)NA,(I,A(I),I=1,NA1) CALL HRWIZ(A,NA,ISW,IFLG,SA,VW,ICON) WRITE(6,610)ICON IF(ICON.NE.0)STOP WRITE(6,620)ISW,IFLG,SA STOP 600 FORMAT(//24X,3HNA=,I3// * (20X,2HA(,I3,2H)=,E15.8/)) 610 FORMAT(/24X,5HICON=,I6) 620 FORMAT(/24X,4HISW=,I2,5X, * 5HIFLG=,I2,5X,3HSA=,E15.8) END
360
HSQR
B21-11-0402 HSQR,DHSOR
Eigenvalues of a real Hessenberg matrix (two-stage QR method)
CALL HSQR(A,K,N,ER,EI,M,ICON) Function All eigenvalues of an n-order real Hessenberg matrix are determined using the double QR method. n1. Parameters A...... Input. Real Hessenberg matrix. The contents of A are altered on output. A is a two-dimensional array, A(K,N). K...... Input. Adjustable dimensions of array A. N...... Input. Order n of the real Hessenberg matrix. ER,EI...... Output. Eigenvalues. The Jth eigenvalue is ER(J)+iNEI(J) (J=1,2, ...,M); i = 1 ER and EI are one-dimensional arrays of size n. M...... Output. The number of determined eigenvalues. ICON...... Output. Condition code. See Table HSQR-1.
Table HSQR-1 Condition code Code 0 10000 15000 Meaning No error N=1 Some of the eigenvalues could not be determined. Processing ER(1)=A(1,1) and EI(1)=0.0 M is set to the number of eigenvalues that were obtained. 1M<N. M is set to 0. Bypassed
Example After reducing an n-order real matrix to a real Hessenberg matrix using HES1, the eigenvalues are determined. n100.
C **EXAMPLE** DIMENSION A(100,100),PV(100),ER(100),EI(100) 10 READ(5,500)N IF(N.EQ.0)STOP READ(5,510)((A(I,J),I=1,N),J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610)(I,J,A(I,J),J=1,N) CALL HES1(A,100,N,PV,ICON) WRITE(6,620)ICON IF(ICON.EQ.30000)) GO TO 10 CALL HSQR(A,100,N,ER,EI,M,ICON) WRITE(6,630) WRUTE(6,620)ICON IF(ICON.EQ.20000) GO TO 10 WRITE(6,640)(I,ER(I),I,EI(I),I=1,M) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1, 10X, 18H** ORIGINAL MATRIX * //11X,10H** ORDER=,I5/) 610 FORMAT(/4(5X,2HA(,I3,1H,,I3,2H)=,E14.7)) 620 FORMAT(/11X,19H** CONDITION CODE =,I5/) 630 FORMAT(1H0/11X,14H** EIGENVALUES) 640 FORMAT(5X,3HER(,I3,2H)=,E14.7, * 5X,3HEI(,I3,2H)=,E14.7) END
Method In the QR method, the diagonal elements become eigenvalues by making the subdiagonal elements of Hessenberg matrix A converge to zero. To accomplish this the orthogonal similarity transformation shown in (4.1) is applied repeatedly. As+1=QsTAsQs (4.1)
20000 30000
Comments on use Subprograms used SSLII...AMACH and MGSSL FORTRAN basic functions...ABS,SQRT and SIGN Notes Normally, after executing subroutine HES1, this routine is used to determine all eigenvalues. If eigenvectors are also needed, array A should be copied onto another area before calling this routine.
Qs is the orthogonal matrix which is uniquely determined in the QR decomposition shown in (4.2). Rs is an upper triangular matrix whose diagonal elements are positive real numbers. As=QsRs (4.2)
By applying Qs determined in (4.2) to (4.1), the lower subdiagonal elements of A gradually converge to zero. Normally, to improve the rate of convergence, QR decomposition is applied to origin-shifted matrix (As-ksl) instead of As. Then orthogonal similarity transformation is performed. ks is the origin shift. Since both real and/or complex numbers are present in the eigenvalues of a real matrix, it is necessary to select a complex number as ks. As a result, complex arithmetic throughout the process is required. To avoid this problem, the double QR
361
HSQR
method, in which arithmetic is kept real, is adopted in the subroutine. In this case, (4.1) and (4.2) become (4.3) and (4.4) respectively.
( A k I )( A k I ) = (Q Q )( R
s s s s +1 s s +1
(4.3)
s +1
2) The two eigenvalues of the lowest 22 principal submatrix are used for origin shifts. Ks and ks+1 are set to these values. 3) The first column of ( As k s I )( As k s + 1 I ) on the left side of (4.4) is obtained. Since A, is Hessenberg matrix, its first column m1 is m1=(x1,y1,x1,0,......,0)T where
(s) ( s) ( s) (s) x1 = a11 a21 a11 (k s + ks +1 ) + k s k s + 1 + a12 (s) ( s) ( s) y1 = a21 a11 + a22 ks ks +1 (s) ( s) z1 = a32 a21
2
Rs )
(4.4)
The left side of (4.4) is always treated as a real matrix, if ks and ks+1 are a pair of complex conjugate. Since product of orthogonal matrices is also an orthogonal matrix, assuming that Q = QsQs + 1 = P1 P2
(4.8)
P
T 1
n 1
(4.5)
(4.9)
P P
T 2
As P1 P2
P
n 1
(4.6) 4) P1 is determined. If the first column of upper triangular matrix Rs+1Rs is given by (4.10) and (4.11), P1 can be determined as shown in (4.12).
r1 = ( 1 , 0,
Pl is the transformation matrix which determines the element of the first column of upper triangular matrix Rs+1Rs during the QR decomposition in (4.4). Pi (i=2,3,...,n-1) is a series of transformation matrices determined when using the Householder method to transform PlAsPltoAs+2 in (4.6). The process for the double QR method is described below. 1) (4.7) determines whether there any elements which can be regarded as relative zero among lower subdiagonal elements ann-1,......,a21(s) of As
s) s al( sl ) 1 u al( + al( l ) , 1 l 1 l = n, n 1, , 2
, 0)
1 = x12 + y1 2 + z1 2
P1 = I 2 w1 w1 where, w1 = ( m1 r1 ) m1 r1
(4.13)
(4.7)
To avoid cancellation the sign of 1 is taken to be the opposite of the sign of x1. 5) P1TAsP1 is computed. The form of P1TAsP1 is shown in Fig. HSQR-2.
Fig. HSQR-2 Form of P1TAsP1
2 is performed. (a) If l = n, an( sn) is adopted as an eigenvalue, order n of the matrix is reduced to n-1, and the process returns to step 1). If n=0, the process is terminated. (b) If l=n-1, two eigenvalues are obtained from the lowest 22 principal submatrix, order n of the matrix is reduced to n-2, and the process returns to step 1. (c) When 2 l <n-1, the matrix is split as shown in Fig.HSOR-1, the process proceeds to step 2, in this case, submatrix D is used for As. l B C 0 D
Note: Element is regarded as zero. Fig. HSQR-1 A direct sum of submatrices for a Hassenberg matrix
6) P1TAsP1 is reduced to a Hessenberg matrix using the Householder method. The process then returns to step 1. (Refer to the method section HSE1 for more about the Householder method.) By repeating this process, the lowest subdiagonal elements will converge to zero, and eigenvalues should be obtained using (a) and (b) of 1. If eigenvalues can not be obtained. In (a), (b) of 1 after 30 iterations, ICON is set to 15000 or 20000. For further information see References [12],[13] PP.359-371 and [16] PP.177206.
362
HVEC
B21-11-0502 HVEC,DHVEC
Eigenvectors of a real Hessenberg matrix (inverse iteration method)
CALL HVEC(A,K,N,ER,EI,IND,M,EV,ME,AW,ICON) Function Eigenvectors x which correspond to selected eigenvalues of an n-order real Hessenberg matrix A are obtained using the inverse iteration method. Eigenvectors are not normalized. n1. Parameters A...... Input. Real Hessenberg matrix. A is a two-dimensional array, A(K,N) K...... Input. Adjustable dimension of arrays A, EV, and AW. N...... Input. Order n of the real Hessenberg matrix. ER,EI.. Input. Eigenvalues . The real parts of are stored in ER and the imaginary parts are stored in EI. The jth eigenvalue j is represented as:
two consecutive column. See "Comments on use". EV is a two-dimensional array,EV(K,MK). Input. The number of columns of array EV. See "Comments on use". Work area. AW(K,N+4) is a two-dimensional array. Output. Condition code. See Table HVEC-1.
Table HVEC-1 Condition code Code 0 10000 15000 Meaning No error N=1 The engenvector of some eigenvalue could not be determined. Processing EV(1,1)=1.0 The IND information of eigenvectors that could not be determined is cleared to zero. Only as many eigenvectors as can be contained in array EV are computed. The IND information of those eigenvectors which could not be computed is set to zero. All of the IND information is set to zero. Bypassed
16000
There are not enough columns in array EV to store all eigenvectors that were requested.
j=ER(j)+iEI(j)
If the j-th eigenvalue j is complex, j and j+1 should be a pair of complex conjugate eigenvalues. See Fig. HVEC-1. ER and EI are one-dimensional array of size M.
20000
(1 ) (2 ) (3 ) (4 )
Array ER
( M 1 ) ( M )
M 1 M1
M1
30000
2 2
3
2
Array EI
0.0
0.0
M 1
M 1
Comments on use Subprograms used SSL II...AMACH and MGSSL. FORTRAN basic functions...ABS,SQRT,and SIGN Notes Parameter IND and storage of eigenvectors. If arrays ER, EI, and IND are specified as shown in Fig. HVEC-2, the eigenvectors which correspond to 1, 2, 3, 4, 5, 6, and 8 are computed and then stored in array EV as shown in the same figure. Since the eigenvectors which correspond to 3 and 7 are not computed, IND(3) and IND (7) are set to 0 by this routine. Also, since 2 and 6 are complex eigenvalues, IND(2) and IND(6) are set to -1. When IND is specified as shown in Fig. HVEC-3, the eigenvectors are successively stored in array EV from the first column. In this case, note that the eigenvectors are closely stored in order from the first column in EV. Based on the eigenvector storage described above, parameter MK should be set to the number of column required to contain the eigenvectors. If the actual number of columns required for the
IND...
M... EV...
Input. Indicate whether or not eigenvectors are to be determined. When the eigenvector which corresponds to the jth eigenvalue j is to be determined, IND(J)=1. If it is not to be determined, IND(J)=0. See "Comments on use". IND is a one-dimensional array of size M. Input. The number of eigenvalues stored in arrays ER and EI. Output. Eigenvectors x. Eigenvectors are stored in columns of EV. Real eigenvectors of real eigenvalues are stored in one column in EV. Complex eigenvectors of complex eigenvalues are split into the real and imaginary parts and stored in
363
HVEC
eigenvectors is larger than the number specified in MK, as many eigenvectors as can be stored in the number of columns specified in MK are computed, the rest are ignored and ICON is set to 16000. The eigenvalues used by this routine can be determined by subroutine HSQR. The parameters ER, EI and M provided by subroutine HSQR can be input as the parameters for this subroutine. When selected eigenvectors of a real matrix are to be determined: A real matrix is first transformed into a real Hessenberg matrix using subroutine HES1; Eigenvalues are determined using subroutine HSQR; Selected eigenvectors are determined using this routine; and Back transformation is applied to the above eigenvectors using subroutine HBK1 to obtain the eigenvectors of a real matrix. Note that subroutine EIG1 can be applied in order to obtain all the eigenvectors of a real matrix for convenience.
1 2 3 4 5 6 7 8 (1) (2) (3) (4) (5) (6) (7) (8) Array ER
Array IND (on input) (Note) The corresponding eigenvalues appear in Fig. HVEC-2 MK Real part of the complex eigenvector f Imaginary part of the complex eigenvector for 2. K N Real eigenvector for 5. Real eigenvector for 8.
Array EV
2
1
2 0.0 1 ignored 1
0.0 1
6
1
6 1 ignored
0.0 1
Example The eigenvalues of an n-order real matrix are first obtained by subroutines HES1 and HSQR, then eigenvectors are obtained using this subroutine and HBK1. n100.
C **EXAMPLE** DIMENSION A(100,100),AW(100,104),ER(100), * EI(100),IND(100),EV(100,100),PV(100) 10 CONTINUE READ(5,500)N IF(N.EQ.0) STOP READ(5,510)((A(I,J),I=1,N),J=1,N) WRITE(6,600)N DO 20 I=1,N 20 WRITE(6,610)(I,J,A(I,J),J=1,N) CALL HES1(A,100,N,PV,ICON) WRITE(6,620)ICON IF(ICON.EQ.30000) GO TO 10 MP=N DO 35 II=1,N I=1+N-II DO 30 J=1,MP 30 AW(J,I)=A(J,I) 35 MP=I CALL HSQR(AW,100,N,ER,EI,M,ICON) WRITE(6,620)ICON IF(ICON.GE.20000) GO TO 10 DO 40 I=1,M 40 IND(I)=1 CALL HVEC(A,100,N,ER,EI,IND,M,EV,100, * AW,ICON) WRITE(6,620)ICON IF(ICON.GE.20000) GO TO 10 CALL HBK1(EV,100,N,IND,M,A,PV,0.0,ICON) CALL EPRT(ER,EI,EV,IND,100,N,M) GO TO 10 500 FORMAT(I5)
MK Real eigenvector for 1. Real part of the complex eigenvector for 2. Imaginary part of the complex eigenvector for Real eigenvector for 4. Real eigenvector for 5. Real part of the complex eigenvector for 6. Imaginary part of the complex eigenvector for Real eigenvector for 8. 1 1 0 1 1 1 0 1
The resulting eigenvectors by this routine have not been normalized yet. Subroutine NRML should be used, if necessary, to normalize the eigenvectors. When using subroutines HBK1 or NRML, parameters IND, M, and EV of this subroutine can be used as their input parameters.
364
HVEC
510 FORMAT(5E15.7) 600 FORMAT(1H1,5X,15HORIGINAL MATRIX,5X, * 2HN=,I3) 610 FORMAT(/4(5X,2HA(,I3,1H,,I3,2H)=,E14.7)) 620 FORMAT(1H0,20X,5HICON=,I5) END
(4.5) can be solved as follows. Lyr 1 = Pxr 1 (forward substitution) Uxr = yr 1 (backward substitution) (4.6) (4.7)
Subroutine ERPT used in this example is for printing the eigenvalues and eigenvectors of the real matrix. For details, see the example in section EIG1. Method The inverse iteration method is used to determine eigenvectors x which correspond to eigenvalues of an norder real Hessenberg matrix A. In the inverse iteration method, if matrix A and approximation j for eigenvalue of A are given, an appropriate initial vector x0 is used to solve equation (4.1) iteratively. When convergence conditions have been satisfied, xr is determined as the resultant eigenvector.
Since any vector may be used for initial vector x0, x0 may be given such that y0 of (4.8) has a form such as y0=(1,1,1,...,1)T. y0 = L1 Px0 (4.8)
( A I )x
j
= xr 1
r = 1,2,3,
(4.1)
Therefore, for the first iteration, the forward substitution in (4.6) can be omitted. In general, the eigenvectors can be obtained by repeating forward substitution and backward substitution for the second and following iterations. The following apply to this routine: 1) Selection of the initial vector y0 in (4.10) is used for the initial vector. y0 = (EPS1, EPS1, where EPS1 = u A And u is the unit round-off 2) Method for convergence criterion After backward substitution, the condition in (4.12) is tested to determine whether the eigenvectors have been accepted. xr 1 01 . n (4.12)
Where, r is the number of iterations, xr is the vector determined at the r-th iteration. Now let the eigenvalues of an n-order matrix A be i(i=1,2,...,n), and the eigenvectors which correspond to i be ui . Since the appropriate initial vector x0 can be expressed, as shown in (4.2) by linear combination of ur, xr can be written as shown in (4.3) if all eigenvalues i are different. x0 = i ui xr = 1 ( j j ) [ i ui
r n i =1 i j i =1 n
, EPS1)
(4.10) (4.11)
(4.2)
+ i ui ( j j )
j)
]
r
(4.3)
Since 1/(j- j)r is a constant, it can be omitted and (4.3) is rewritten as: xr = i ui + i ui ( j j )
n i =1 i j r
(
j
j)
(4.4)
Since in general
uj
) (
u j << 10 . , (4.4)
If (4.12) is satisfied, xr is accepted as the eigenvectors. If (4.12) is not satisfied, the initial vector is regarded inappropriate. A new initial vector is substituted and backward substitution is continued. 3) When eigenvalues have multiple roots or close roots If eigenvalue j whose eigenvector is to be determined and eigenvalue uj whose eigenvector has already been computed satisfy the condition in (4.13), correct eigenvectors will not be determined no matter how many iterations are performed.
indicates that, if j0 , as r grows greater, xr tends rapidly to jj. The system of linear equations shown in (4.1) are solved using (4.5) after decomposition of (A-jI) to a lower triangular matrix L and an upper triangular matrix U. LUxr = Pxr 1 (4.5)
j i EPS1
(i = 1,2,
, j 1)
) (
k
(4.13)
(4.14)
Therefore, as long as the same initial vector is used, eigenvectors x1(j) and x1(i ) which are computed corresponding to j and i will be approximately 365
HVEC
equal. in such situations, this routine adjusts j in EPS1 units, ~ is used to compute the and when (4.15) is satisfied, u j eigenvectors.
~ > EPS1 j i
(i = 1,2,
, j 1)
(4.15)
366
ICHEB
CALL ICHEB(A,B,C,N,ICON) Function Given an n-terms Chebyshev series defined on interval [a,b]
n 1 2 x (b + a) f ( x ) = ' ck Tk k =1 ba
When a indefinite integral of an arbitrary function is required, this subroutine can be used together with the subroutine FCHEB for Chebyshev series expansion. The ECHEB subroutine used for evaluation of Chebyshev series can be subsequently called to obtain the integral value at point [a,b] in an interval. Determination of arbitrary constant c0 of an integral this subroutine outputs zero as arbitrary constant c0 . If a constant is defined so that an indefinite integral at point [a,b] in an interval is yv, it should be computed by using the subroutine ECHEB use for evaluation of Chebyshev series as follows:
(1.1)
f ( x)dx = ' c k Tk
k =0
2 x (b + a ) ba
(1.2)
and obtains its coefficient { ck }. Where arbitrary constant { c0 } is assumed to be zero. ' denotes to make sum but the first term only is multiplied by factor 1/2. Where ab and n1. Parameters A...... Inputs. Lower limit a of the interval for the Chebyshev series. B...... Input. Upper limit b of the interval for the Chebyshev series. C...... Input. Coefficients{ck}. Stored as C(1)=c0,C(2)=c1,..., C(N)=cn-1. Output. Coefficients { ck } for the indefinite integral. Stored as C(1)=0.0, C(2)= c1 ,..., C(N+1)= c n . One-dimensional array of size N+1. N...... Input. Number of terms n. Output. Number of terms n+1 of the indefinite integral. ICON... Output. Condition code. See Table ICHEB-1.
Table ICHEB-1 Condition code Code 0 30000 Meaning No error Either of the following occurred. 1 N<1 2 A=B Processing Bypassed
where C(1) corresponds to c0, V corresponds to v and YV corresponds to yv respectively. To obtain the definite integral
a f (t )dt,
xi
(3.1)
by changing the upper limit of the integral interval for function f(x), it should determines at first the value of arbitrary constant c0 . So that the value of the indefinite integral at end point a is zero and then should calls the subroutine ECHEB m times repeatedly. (See Example). The error in an indefinite integral can be estimated by the absolute sum of the last two term coefficients. Example The value of function ~ x 1 dt f (x) = + , x [01 ,] 4 0 1 + 100t 2 (3.2)
Comments on use Subprograms used SSL II.....MGSSL FORTRAN basic function...FLOAT Notes
is obtained with increment 0.05 starting from x=0 The subroutine FCHEB expands the integrand in Chebyshev series (required accuracy: absolute error 510-5). Then this subroutine obtains an indefinite integral. Integral constant is determined so that the value of an indefinite integral where x=0 is 1/4 The subroutine ECHEB obtains the function value at each step and computes the error for true value
367
ICHEB
1 1 f ( x ) = + tan 1 10 x 4 10
C
(3.3)
**EXAMPLE** DIMENSION C(258),TAB(255) EXTERNAL FUN EPSA=5.0E-5 EPSR=5.0E-5 NMIN=9 NMAX=257 A=0.0 B=1.0 CALL FCHEB(A,B,FUN,EPSA,EPSR,NMIN, * NMAX,C,N,ERR,TAB,ICON) IE(ICON.NE.0) GO TO 20 WRITE(6,600)N,ERR,ICON WRITE(6,601)(C(K),K=1,N) CALL ICHEB(A,B,C,N,ICON) IF(ICON.NE.0) GO TO 20 WRITE(6,602) WRITE(6,601)(C(K),K=1,N) CALL ECHEB(A,B,C,N,A,F,ICON) IF(ICON.NE.0) GO TO 20 C(1)=(0.25-F)*2.0 WRITE(6,603) H=0.05 X=A 10 CALL ECHEB(A,B,C,N,X,Y,ICON) IF(ICON.NE.0) GO TO 20 ERROR=G(X)-Y WRITE(6,604)X,Y,ERROR X=X+H IF(X.LE.B) GO TO 10 STOP 20 WRITE(6,604)ICON STOP 600 FORMAT(1H0,3X,12HEXPANSION OF, 116H FUNCTION FUN(X),3X,2HN=,I4,3X, 26HERROR=,E13.3,3X,5HICON=,I6) 601 FORMAT(/(5E15.5)) 602 FORMAT(1H0,5X,14HINTEGRATION OF, 117H CHEBYSHEV SERIES) 603 FORMAT(1H0,10X,1HX,7X, 112HINTEGRATION,6X,5HERROR/) 604 FORMAT(1X,3E15.5) 605 FORMAT(1H0,5X,14HCONDITION CODE,I8) END FUNCTION FUN(X) FUN=1.0/(1.0+100.0*X*X) RETURN END FUNCTION G(X) G=0.25+ATAN(10.0*X)/10.0 RETURN END
Method This subroutine performs termwise indefinite integral of an n-terms Chebyshev series defined on interval [a,b] and expresses it in a Chebyshev series. Given
' ck Tk
k =0
n 1
n 2 x (b a ) 2 x (b a ) dx = c k Tk ba ba k =0
b a
(4.2)
where the integral constant is omitted and 2 x (b + a ) y= , the following relation is established ba for coefficients{ck}and { ck }. cn +1 = 0 ba cn = cn 1 4n ba ck = (ck 1 + ck +1 ), 4k k = n 1, n 2,
(4.3)
,1
This subroutine obtains { ck } by using an integral formula for Chebyshev polynomial in (4.3). Zero is used for arbitrary constant c 0 . n times multiplications and divisions are required for obtaining an indefinite integral of n-terms series.
368
IERF
CALL IERF (X,F,ICON) Function This subroutine evaluates the inverse function erf-1(x) of 2 x t 2 the error function erf ( x ) = e dt , using the 0 minimax approximation formulas of the form of the polynomial and rational functions. Limited x <1. Parameters X...... Input. Independent variable x. F...... Output. Function value erf-1(x). ICON... Output. Condition code. See Table IERF-1.
Table IERF-1 Condition codes Code 0 30000 Meaning No error |x|1 Processing F is set to 0.0.
**EXAMPLE** WRITE(6.600) DO 10 K=1,100 X=FLOAT(K-1)/100.0 CALL IERF(X,F,ICON) IF(ICON.EQ.0)WRITE(6,610)X,F IF(ICON.NE.0)WRITE(6,620)X,F,ICON 10 CONTINUE STOP 600 FORMAT(1H1,24HEXAMPLE OF INVERSE ERROR, * 9H FUNCTION///6X,1HX,7X,7HIERF(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,11H**ERROR**,5X,2HX=,E17,7, * 5X,5HIERF=,E17.7,5X,10HCONDITION=,I10) END
Method Some approximation formulas are used for evaluation of the inverse error function erf-1(x), corresponding if x 0.8 or not. x 0.8 The minimax approximation in the sense of relative error based on the Taylor series expansion (See Reference[87]) of erf-1(x) at x=0 is used. Single precision: erf 1 ( x ) = x a k t k / bk t k
3 4
Comments on use Subprograms used SSL II...IERFC,MGSSL FORTRAN basic function...ABS,SQRT,ALOG Notes The range of argument X is limited as X <1. This range is the definition area of this function. When considering the relationship erf-1(x)=erfc-1(1-x) the inverse error function may be evaluated by subroutine IERFC. But, if values of x are within the range x 0.8, higher accuracy and less computation time are accomplished by the IERF subroutine. Example A table of function values computed at x from 0 to 0.99 with step-size 0.01 is made for erf-1(x).
t = 1 ( x / 0.8)
k =0 2
k =0
(4.1)
t = 1 ( x / 0.8)
k =0 2
k =0
(4.2)
Theoretical precision=18.8 digits x >0.8 Considering the relationship erf-1(1-x)= erfc-1(1-x), it is computed by subroutine IERFC. For details refer to the descriptions of IERFC.
369
IERFC
I11-71-0401 IERFC,DIERFC
Inverse complementary error function erfc-1(x)
CALL IERFC(X,F,ICON) Function This subroutine evaluates the inverse function erfc-1(x) of the complementary error function erfc 2 ( x ) = x e t 2 dt using the minimax approximations of the form of the polynomial and rational functions. Limited 0<x<2. Parameters X...... Input. Independent variable x. F...... Input. Function value erfc-1(x). ICON... Output. Condition code. See Table IERFC-1.
Table IERFC-1 Condition codes Code 0 30000 Meaning No error X0 or X2 Processing F is set to 0.0.
* ///6X,1HX,6X,8HIERFC(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,11H**ERROR**,5X,2HX=, E17.7, * 5X,6HIERFC=,E17.7,5X, 10HCONDITION=,I10) END
Method Some approximation formulas are used for evaluation of inverse complementary error function erfc-1(x), corresponding if 0<x<0.2 or if 1.8<x<2, or other. 0<x<0.2 or 1.8<x<2 Placing = log( x(2 x )) and erfc 1 (x) = R( ) , the
auxiliary function R() is evaluated using the minimax approximation in the sense of relative error base on the Strecok theory (See Reference [87]). (a) 0<x<5.10-16 or (2-510-16)<x 2 Letting c / + d Single precision: erfc 1 ( x ) = ak t k
7 k =0
(4.1)
Comments on use Subprograms used SSL II...IERF,MGSSL FORTRAN basic functions...ABS, SQRT, ALOG Notes The range of argument X is limited as 0<X<2. This range is the definition area of this function. When considering the relationship erfc-1(x)=erf-1(1-x) the inverse complementary error function may be evaluated by subroutine IERF. But, if values of x are within the range 0<x<0.2, higher accuracy and less computation time are accomplished by this IERFC. Example A table of function values computed at x from 0.01 to 1.00 with stepsize 0.01 is made for erfc-1(x)
C **EXAMPLE** WRITE(6,600) DO 10 K=1,100 X=FLOAT(K)/100.0 CALL IERFC(X,F,ICON) IF(ICON.EQ.0) WRITE(6,610)X,F IF(ICON.NE.0) WRITE(6,620)X,F,ICON 10 CONTINUE STOP 600 FORMAT(1H1,18HEXAMPLE OF INVERSE, * 29H COMPLEMENTARY ERROR FUNCTION,
(4.2)
Theoretical precision -18.9 digits where c=-4.59999617941507552 d=1.89749541006229975 (b) 5.10-16x<2.5N10-3 or 2-2.510-3<x2-5.10-16 t=c+d Single precision: erfc 1 ( x ) = ak t k / bk t k
4 4 k =0 k =0
(4.3)
(4.4)
370
IERFC
Theoretical precision=18.7 digits where c=0.279728815664916161 d=-0.643957858131678820 (c) 2.5 10-3x<0.2 or 1.8<x1.9975 Letting t=cb+d Single precision: erfc 1 ( x ) = ak t k
7 k =0
(4.6)
Theoretical precision=18.5 digits where c=-0.774406521186630830 d=1.78274506157390808 (4.5) 0.2x1.8 Considering the relationship erfc-1(x)=erf-1(1-x), it is computed by subroutine IERF. For details refer to the descriptions of IERF.
371
IGAM1
CALL IGAM1(V,X,F,ICON) Function This subroutine computes incomplete Gamma function of the first kind,
( , x ) =
0 e t t 1dt
by series expansion, asymptotic expansion, and numerical integration, where v>0,x0. Parameters V...... Input. Independent variable v. X...... Input. Independent variable x. F...... Output. Value of (v,x). ICON... Output. Condition code. See Table IGAM1-1
Code 0 30000 Meaning No error V0 or X<0 Processing F=0.0
**EXAMPLE** WRITE(6.600) DO 20 IV=1,9 V=FLOAT(IV+7*((IV-1)/3))/10.0 DO 10 IX=1,9 X=FLOAT(IX+7*((IX-1)/3))/10.0 CALL IGAM1(V,X,F,ICON) IF(ICON.EQ.0) WRITE(6,610) V,X,F IF(ICON.NE.0) WRITE(6,620) V,X,F,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H1,10HEXAMPLE OF, * 26H INCOMPLETE GAMMA FUNCTION * //5X,1HV,9X,1HX,10X,4HFUNC/) 610 FORMAT(1H ,2F10.5,E17.7) 620 FORMAT(/1H ,11H**ERROR**,5X,2HV=, * F10.5,5X,2HX=,F10.5,5X,6HIGAM1=, * E17.7,5X,10HCONDITION=,I10/) END
Methods Two different approximation formulas are used depending upon the ranges of x divided at x1=3.5(or 5.5 for double precision). For x2(v+1) or x<x1 The computation is based on x x2 ( , x ) = x e x 1 + + + 1 1 2 + + + ( )( ) /
Comments on use Subprograms used SSL II...AFMAX,AMACH,EXPI,IGAM2,MGSSL,and ULMAX FORTRAN basic function...FLOAT,EXP, and GAMMA Notes When X23.0(for single precision) or X46.0(for double precision), the value of (v,x) may be obtained simply by the complete GAMMA(v) function in the FORTRAN basic function, because (v,x) (v) in the above ranges. Example The following example generates a table of (v,x) for v,x=a+b, where a=0,1,2 and b=0.1,0.2,0.3.
(4.1)
The value of (v,x) is computed as a partial sum of the first N terms with N being taken large enough so that the last term no longer affects the value of the partial sum significantly. For x>2(v+1)and xx1 The computation is based on
( , x ) = ( ) ( , x )
(4.2)
where (v) is computed by calling GAMMA, which is one of the FORTRAN basic functions, and F(v,x) is computed by subroutine IGAM2. For further information, see Reference [85] pp.14-16
372
IGAM2
CALL IGAM2(V,X,F,ICON) Function This subroutine computes incomplete Gamma function of the second kind
( , x ) = e t t 1dt = e x e t ( x + t )
x 0
V,X,F,ICON 10 CONTINUE 20 CONTINUE STOP 600 FORMAT(1H1,10HEXAMPLE OF, * 26H INCOMPLETE GAMMA FUNCTION * //5X,1HV,9X,1HX,10X,4HFUNC/) 610 FORMAT(1H ,2F10.5,E17.7) 620 FORMAT(/1H ,11H**ERROR**,5X,2HV=, * F10.5,5X,2HX=,F10.5,5X,6HIGAM2=, * E17.7,5X,10HCONDITION=,I10/) END
dt
by series expansion, asymptotic expansion, and numerical integration, where v0,x0(x0 when v=0). Parameters V...... Input. Independent variable v. X...... Input. Independent variable x. F...... Output. Value of (v.x). ICON... Output. Condition code. See Table IGAM2-1
Table IGAM2-1 Condition codes Code 0 20000 30000 Meaning No error xv-1e-x>flmax V<0,X<0 or V=0 and X=0 Processing F=flmax F=0.0
Methods Since (v,x) is reduced to an exponential integral when v=0 and x>0, subroutine EXPI is used; where as it is the complete Gamma function when v>0 and x=0, so the FORTRAN basic function GAMMA is used. The calculation procedures for v>0 and x>0 are described below. Two different approximation formulas are used depending upon the ranges of x divided at x1=20.0(or 40.0 for double precision). When v=integer or x>x1 The computation is based on the following asymptotic expansion:
1 ( 1)( 2) ( ,x ) = x 1e x 1 + + + x x2 ( 1) ( n) + + xn
Comments on use Subprograms used SSL II...AFMAX,AMACH,MGSSL,EXPI, and ULMAX FORTRAN basic function...FLOAT,EXP,GAMMA, and ATAN Notes For Xlog(flmax), the value or (v,x) becomes smaller enough to underflow. The condition, xv-1e-x>log(flmax) will hold when x>1 and v is very large. Then, the value of (v,x) overflows. Example The following example generates a table of (v,x) for v,x=a+b, where a=0,1,2 and b=0.1,0.2,0.3.
C **EXAMPLE** WRITE(6,600) DO 20 IV=1,9 V=FLOAT(IV+7*((IV-1)/3))/10.0 DO 10 IX=1,9 X=FLOAT(IX+7*((IX-1)/3))/10.0 CALL IGAM2(V,X,F,ICON) IF(ICON.EQ.0) WRITE(6,610) V,X,F IF(ICON.NE.0) WRITE(6,620)
(4.1)
The value of (v,x) is computed as a partial sum of the first n terms, either with n being taken large enough so that the last term no longer affects the value of the partial sum significantly, or with n being take as the largest integer to satisfy nv+x. When vinteger and xx1 The computation is based on the following representation:
1 ( ,x ) = x 1e x 1 + + + x
m1
(4.2)
Where m is the largest integer to satisfy mv. When v<1, the firt term is regarded as 0, and (v-1)(v-2)......(vm)=1. And, because 0<v-m<1, (v-m,x), in the second term can be expressed as:
373
IGAM2
( m, x ) = e t e t ( x + t )
0
m1
dt
(4.3)
singularity, can be calculated efficiently by the double exponential formula for numerical integration. (See Reference [68].) For further information, see Reference [85].
374
INDF
CALL INDF(X,F,ICON) Function This subroutine computes the value of inverse function -1(x) of normal distribution function ( x ) = 1 2
Example The following example generates a table of -1(x) in which x varies from 0.0 to 0.49 with increment 0.01.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,50 X=FLOAT(K-1)/100.0 CALL INDF(X,F,ICON) IF(ICON.EQ.0) WRITE(6,610)X,F IF(ICON.NE.0) WRITE(6,620)X,F,ICON 10 CONTINUE STOP 600 FORMAT(1H1,25HEXAMPLE OF INVERSE NORMAL * ,22H DISTRIBUTION FUNCTION * //6X,1HX,7X,7HINDF(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,11H**ERROR**,5X,2HX=,E17.7 * ,5X,5HINDF=,E17.7,5X,10H CONDITION=,I10) END
x t e 2 0
dt by the relation,
1 ( x ) = 2 erf 1 (2 x )
where x < 1 2 . Parameters X...... Input. Independent variable x F...... Output. Function value -1(x) ICON... Output. Condition code See Table INDF-1
Table INDF-1 Condition code Code 0 30000 Meaning No error |x| 1/2
(1.1)
Method There exists the relation (4.1) between (t) and erf(t), the error function.
(t ) = erf t
Processing F=0.0
2 2 , < t <
(4.1)
(t)=x, or
Therefore
t = 2 erf 1 (x )
from erf t
2 2=x.
Comments on use Subprograms used SSL II...IERF,IERFC,MGSSL FORTRAN basic function...ABS,SQRT,ALOG Notes x <1 2 The value of -1(x) can be obtained by the subroutine INDFC if the following relation is used.
1 ( x ) = 2 erf 1 (2 x )
(4.2)
This subroutine computes -1(x) based on (4.2) by using the subroutine IERF.
1 ( x ) = 1 (1 2 x )
(3.1)
Note that in the range of x 0.4 , however, this leads to less accurate and less efficient computation than calling INDF.
375
INDFC
Note that in the range of 0<x<0.1, however, this leads to less accurate and less efficient computation than calling INDFC. Example The following example generates a table of -1(x) in which x varies from 0.01 to 0.50 with increment 0.01.
C **EXAMPLE** WRITE(6,600) DO 10 K=1,50 X=FLOAT(K)/100.0 CALL INDFC(X,F,ICON) IF(ICON.EQ.0) WRITE(6,610)X,F IF(ICON.NE.0) WRITE(6,620)X,F,ICON 10 CONTINUE STOP 600 FORMAT(1H1,24HEXAMPLE OF INVERSE COMPL, * 37HEMENTARY NORMAL DISTRIBUTION FUNCTION * //6X,1HX,7X,8HINDFC(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,11H**ERROR**,5X,2HX=,E17.7, * 5X,6HINDFC=,E17.7,5X,10HCONDITION=,I10) END
CALL INDFC(X,F,ICON) Function This subroutine computes the value of inverse function -1(x) of complementary normal distribution function ( x ) = 1 2
2 x t e 2 dt 0
by the relation,
1 ( x ) = 2 erfc1 (2 x )
0<x<1 Parameters X...... Input. Independent variable x F...... Output. Function value -1(x) ICON... Output. Condition code See Table INDFC-1
Table INDFC-1 Condition code Code 0 30000 Meaning No error X0 or X1
(1.1)
Method There exists the relation (4.1) between (t) and erf(t), the error function.
Processing F=0.0
(t ) = erfc t
2 2, < t <
(4.1)
Comments on use Subprograms used SSL II...IERFC,IERFC,MGSSL FORTRAN basic function...ABS,SQRT,ALOG Notes 0<x<1. The value of -1(x) can be obtained by the subroutine INDF if the following relation is used.
) 2= x.
Therefore
1 ( x ) = 2 erfc1 (2 x )
(4.2)
This subroutine computes -1(x) based on (4.2) by using the subroutine IERFC subroutine.
1 ( x ) = 1 (1 2 x )
(3.1)
376
INSPL
E12-21-0101
INSPL, DINSPL
CALL INSPL(X,Y,DY,N,C,D,E,ICON) Function Given discrete points x1, x2, ..., xn (x1<x2<...<xn), their corresponding function values yi =f(xi ), i=1,...,n, and the second derivatives at both ends y1'' and ym'', this subroutine obtains the interpolating cubic spline represented as (1.1) below to f(x). When x < x1 2 y1 + c1 ( x x1 ) + d1 ( x x1 ) x x x , i = 1, n 1 When i +1 i 2 S (x ) = yi + ci (x x i ) + d i ( x xi ) 3 + ei ( x x i ) When x > x n y + c ( x x ) + d ( x x )2 n n n n n
Notes There are no restrictions on specifying 2nd order derivatives yi '' and yn'' at both ends. However, when those values are unknown it is possible to specify yi ''=0.0 and yn''=0.0. In that case the integral
x [S ( x )]
xn
1
order derivative of the cubic spline that is to be determined. If the function f(x) to be interpolated can be assumed to have periodic intervals of xn-xl, it is best to specify 2nd derivatives such that yi ''=yn''. Example The number of discrete points n, discrete points xi , and function values yi , i=1,...,n are input. The cubic spline function is determined in order to interpolate a value at x= in the interval [xi ,xi +1]. yi ''=0.0, yn''=0.0, n10.
C **EXAMPLE** DIMENSION X(10),Y(10),DY(2),C(10),D(10), * E(10) READ(5,500) N READ(5,510) (X(I),Y(I),I=1,N) DY(1)=0.0 DY(2)=0.0 CALL INSPL(X,Y,DY,N,C,D,E,ICON) WRITE(6,600) ICON IF(ICON.GT.10000) STOP READ(5,520) I,V XX=V-X(I) YY=Y(I)+(C(I)+(D(I)+E(I)*XX)*XX)*XX WRITE(6,610) YY STOP 500 FORMAT(I2) 510 FORMAT(2E16.8) 520 FORMAT(I2,E16.8) 600 FORMAT(1H1,10X,5HICON=,I5) 610 FORMAT(1H0,10X,19HINTERPOLATED VALUE=,E16.8) END
(1.1)
Parameters X ..... Input. Discrete points xi . One-dimensional array of size n. Y ..... Input. Function values yi . One-dimensional array of size n. DY .... Input. 2nd order derivatives y1'' and yn'' at both ends. One-dimensional array of size 2. DY(1) is set to y1'' and DY(2) is set to yn''. (See Comments) N ..... Input. Number (n) of discrete points. n2. C ..... Output. Coefficients ci of (1.1) One-dimensional array of size n. D ..... Output, Coefficients di of (1.1) One-dimensional array of size n. E ..... Output. Coefficients ei of (1.1) Usually E(N)=0.0 One-dimensional array of size n. ICON .. Output. Condition code. See Table INSPL-1.
Table INSPL-1 Condition codes Code 0 30000 Meaning No error n<2 or XiXi+1 Processing Aborted
Method Consider obtaining the interpolating function shown in (1.1) when given discrete points x1,x2...,xn (x1<x2<...<xn) and their corresponding function values yi =f(xi ), i=1,...,n. In (1.1) for each interval [xn,xi +1], different polynomials of degree three or less (for (-,x1) and (xn, ) polynomials of degree two or less) are shown. Let the interpolating function to be obtained be represented function to be obtained be represented by S(x), which is expressed separately as S0 ( x ), x < x1 S ( x ) = Si ( x ), xi x xi+1 , i = 1, , n 1 Sn ( x ), x > xn
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... none
(4.1)
377
INSPL
Where S0(x) and Sn(x) are polynomials of degree two or less and S1(x),...,Sn-1(x) are polynomials of degree three or less. In this routine S(x) is determined so that the derivatives of S(x) up to 2nd order should be continuous over (-,). For this to be true Si (x) must satisfy S i 1 ( x i ) = S i ( xi ) = yi S i1 ( x i ) = S i( xi ) S i 1 ( x i ) = S i( xi ) i = 1, , n
(4.4)
(4.2)
If yi '', yn'' are given, (4.4) becomes a system of linear equations with respect to y2'', y3'', ..., yn-1. Since the coefficient matrix is a positive definite symmetric matrix, this routine uses the modified Cholesky method. Characteristics of S(x) when yi ''=yn''=0 If yi ''=yn''=0 is given, S(x) becomes linear over (-,x1), (xm, ). At this time it becomes a cubic natural spline with the following characteristics. Let g(x) be any interpolating function which satisfies g( x ) = yi , i = 1,
The coefficients ci , di and ei of (1.1) are determined by the conditions in (4.2). This is shown in (4.3). When i=1,...,n-1 When i = 1, n 1 y i +1 yi hi ( y i+1 + 2 yi) ci = 6 hi y i di = 2 y i+1 y i ei = 6hi When i = n y n y n 1 hn 1 + + 2 cn = y y ( n n 1 ) 6 hn 1 yn dn = 2
, n
(4.5)
(4.3) g(x),g'(x),g''(x) are continuous in [xl, xn]. If S(x) is the interpolating cubic spline corresponding to y''1=yn''=0, then
x {g ( x )}
xn
1
dx
x x1
{S (x )}2 dx
(4.6)
where hi =xi +1-xi , yi "=S''(xi ). From the second condition of (4.2), yi '' satisfies the three term relation.
(The equality occurs only when g(x)=S(x).) In the sense that S(x) minimizes
x {g ( x )}
xn
1
dx
it can be considered the "smoothest" interpolating function. For further information, see References [48], [49] and [50] pp.349 - 356.
378
LAPS1
F20-01-0101
LAPS1, DLAPS1
CALL LAPS1(A,NA,B,NB,T,DELT,L,EPSR,FT, T1,NEPS,ERRV,ICON) Function Given a rational function F(s) expressed by (1.1), this subroutine calculates values of the inverse Laplace transform f(t0), f(t0+t), ..., f(t0+t(L-1)): (1.1) where F(s) must be regular in the domain of Re(s)>0. Parameters A ..... Input. Coefficients of P(s). One-dimensional array of size n+1, assigned in the order of A(1)=a1, A(2)=a2, ..., A(n+1)=an+1. NA .... Input. Degree n of P(s). B ..... Input. Coefficients of Q(s). One-dimensional array of size m+1, assigned in the order of B(1)=b, B(2)=b2, ...., B(m+1)=bm+1. NB .... Input. Degree m of Q(s). T ..... Input. Initial value t0(0) from which the values of f(t) are required. DELT .. Input. Increment t(0) of variable t. If DELT=0.0, only f(t0) is calculated. L ..... Input. The number (L1) of points at which values of f(t) are required. EPSR ... Input. The relative error tolerance for the values of f(t): 10-2 to 10-4 for single precision and 10-2 to 10-7 for double precision will be typical. If EPSR=0.0, the default value 10-4 is used. FT .... Output. A set of values f(t0), f(t0+t),..., f(t0+t(L-1)). One-dimensional array of size L. T1 .... Output. A set of values t0, t0+t, ..., t0+t(L1). One-dimensional array of size L. NEPS ... Output. The number of terms: N in the truncated expansion.
(See "Method"). One-dimensional array of size L. The number of terms N used to calculate FT(I) is stored in NEPS(I). ERRV .. Output. Estimates of the relative error of resultant value FT. One-dimensional array of size L. The relative error of FT(I) is stored in ERRV(I). ICON .. Output. Condition code. (See Table LAPS11.)
Table LAPS1-1 Condition codes Code 0 10000 Meaning No error Some of the results did not meet the required accuracy. Processing Continued. Values representing accuracy for are output to array ERRV. Bypassed.
30000
One of the following conditions: (1) NB<0 or NB>NA (2) T<0 or DELT<0 (3) L<1 (4) EPSR<0 (5) A(1) = 0
Comments on use Subprograms used SSL II ... MGSSL, AFMAX FORTRAN basic functions ... FLOAT, ALOG, ALOG10, CMPLX, AIMAG, EXP, ABS, INT, ATAN Notes Rational function F(s) must be regular in the domain for Re(s)>0. If F(s) is singular or if its regularity is not known, use subroutine LAPS2. If t0=0, the value of f(0) is calculated according to the theorem on initial values as b a (n = m + 1) f (0) = 1 1 (n > m + 1) 0 For NA=NB, (1.1) is written as F ( s) = where, Q( s) = F1 ( s) + F2 (s) P( s ) F1 (s) b1 a1 F1 (s) C2 S n 1 + C3 S n 2 + + Cn+1 + an +1 a1 S n + a2 S n 1 + (3.1)
379
LAPS1
where (t) is the delta function. Since F2(s) satisfies the condition of (8.20) in Chapter 8, inverse transform f2(t) of F2(s) can be calculated from (8.22). Therefore, when NA=NB the subroutine calculates the inverse of F2(s) for t>0. When t=0, the maximum value of the floating point numbers is returned. Example Given a rational function F(s) regular (non-singular) in the area for Re(s)>0: s2 + 4 F ( s) = 4 s + 12 s3 + 54s 2 + 108s + 81 the inverse Laplace transform f(t) is obtained at points, i=1,2,...,9, with EPSR=10-4.
C ** EXAMPLE** DIMENSION A(5),B(3),T1(9),FT(9), * ERRV(9).NEPS(9) NB=2 NB1=NB+1 B(1)=1.0 B(2)=0.0 B(3)=4.0 NA=4 NA1=NA+1 A(1)=1.0 A(2)=12.0 A(3)=54.0 A(4)=108.0 A(5)=81.0 T=0.2 DELT=0.2 L=9 EPSR=1.0E-4 WRITE(6,600) NB,(I,B(I),I=1,NB1) WRITE(6,610) NA,(I,A(I),I=1,NA1) WRITE(6,620) EPSR CALL LAPS1(A,NA,B,NB,T,DELT,L,EPSR, * FT,T1,NEPS,ERRV,ICON) WRITE(6,630) ICON IF(ICON.EQ.30000) STOP WRITE(6,640) (T1(I),FT(I),ERRV(I), *NEPS(I),I=1,L) STOP 600 FORMAT(//24X,3HNB=,I3// * (20X,2HB,(,I3,2H)=,E15.8/)) 610 FORMAT(/24X,3HNA=,I3// * (20X,2HA,(,I3,2H)=,E15.8/)) 620 FORMAT(22X,5HEPSR=,E15.8/) 630 FORMAT(22X,5HICON=,I6//) 640 FORMAT(15X,2HF(,F8.5,2H)=,E15.8,2X, * 6HERROR=,E15.8,2X,2HN=,I3/) END
Method The method for obtaining the inverse Laplace transform is explained in Chapter 8, where f(t) is approximated as: f N (t , 0 ) = e0 N Fn t n=1 e0 k 1 1 p = Fn + p +1 Ap ,r Fk +r = = t n 1 2 r0
(4.1)
0 + i (n 0.5) n where Fn = ( 1) Im F t N =k+p p + 1 Ap , p = 1, Ap ,r 1 = Ap ,r + r In this subroutine, 0, N, and p are determined as follows: Since f(t,0) satisfies f (t , 0 ) = f (t ) e 2 0 f (3t ) + e 4 0 f (5t )
0 is determined as
log( EPSR ) 0 = +2 2
where [O] is the Gaussian notation, so that the user specified relative error tolerance (EPSR) may be expressed as: EPSR f N (t , 0 ) f N 1(t , 0 ) = e 2 0 f N (t , 0 ) (4.2)
Since value N that satisfies the condition of (4.2) depends on the value of t, it is adaptively determined from the following empirical formula N = [5 0 ] + [ 0 t 2.5] and value p is chosen as 5 for 0 4 [0+1] for 4 <09, 9 for 9 <0 Then relative errors of results fN(t,0) are output to array ERRV, which are estimated as follows: f (t , 0 ) f N 1 (t , 0 ) ERRV = N f N (t , 0 ) (4.3)
380
LAPS2
F20-02-0101
LAPS2, DLAPS2
CALL LAPS2(A,NA,B,NB,T,DELT,L,EPSR,FT, T1,NEPS,ERRV,IFLG,VW,ICON) Function Given a rational function F(s) expressed by (1.1), this subroutine calculates values of the inverse Laplace transform f(t0), f(t0+t), ..., f(t0+t(L-1)): P (s ) Q(s) = b1s m + b2 sm1 + +bm s + bm+1 P(s) = a1s n + a2 sn 1 + +an s + an +1 n m, a1 , a2 , , an+1 , b1 , b2 , , bm+1:real value F (s) = Q(s)
(1.1)
One-dimensional array of size L. The number of terms N used to calculate is stored in NEPS(I). ERRV .. Output. Estimates of the relative error of result FT. One-dimensional array of size L. The relative error of FT(I) is stored in ERRV(I). IFLG .. Output. Regularity judgment result. IFLAG=0 if F(s) is regular in the domain of Re(s)>0, IFLAG=1 otherwise. (See "Notes on Use".) VW .... Work area. One-dimensional array of size n+m+2 ICON .. Output. Condition code. (See Table LAPS21.)
Table LAPS2-1 Condition codes Code 0 10000 Meaning No error Some of the results did not meet the required accuracy. Processing Continued. Values representing accuracy for f(t0+tNi): i=0,1,...,L-1 are output to array ERRV. Bypassed
In this case, F(s) need not be regular in the domain for Re(s)>0. Parameters A ..... Input. Coefficients of P(s). One-dimensional array of size n+1, assigned in the order of A(1)=a1, A(2)=a2, ..., A(n+1)=an+1. NA .... Input. Degree n of P(s). B ..... Input. Coefficients of Q(s). One-dimensional array of size m+1, assigned in the order of B(1)=b1, B(2)=b2, ...., B(m+1)=bm+1. NB .... Input. Degree m of Q(s). T ..... Input. Initial value t0(0.0) from which the values of f(t) are required. DELT .. Input. Increment t(>0.0) of variable t. If DELT=0.0, only f(t0) is calculated. L ..... Input. The number (1) of points at which values of f(t) are required. EPSR ... Input. The relative error tolerance for the values of f(t): 10-2 to 10-4 for single precision and 10-2 to 10-7 for double precision will be typical. If EPSR=0.0, the default value 10-4 is used. FT .... Output. A set of values f(t0), f(t0+t),...,f(t0+t(L-1)). One-dimensional array of size L. T1 .... Output. A set of values t0, t0+t, ..., t0+t(L1). One-dimensional array of size L. NEPS ... Output. The number of terms: N in the truncated expansion. (See "Method").
20000
30000
The subroutine failed to obtain the non-negative real value 0 such that the F(s) is regular in the domain of Re(s)>0. One of the following conditions: (1) NB<0 (2) NB>NA (3) T<0 (4) DELT<0 (5) L<1 EPSR<0 A(1) = 0
Bypassed.
Comments on use Subprograms used SSL II ... LAPS1, HRWIZ, MGSSL, AMACH, AFMAX FORTRAN basic functions ... FLOAT, ALOG, ALOG10, CMPLX, AIMAG, EXP, ABS, INT, ATAN Notes Rational function F(s) need not be regular in the domain for Re(s)>0. However, if it is known that F(s) is regular, use subroutine LAPS1 for efficiency. If IFLG=1 is output, F(s) is not regular in the domain of Re(s). This means that f(t) increases exponentially as t approaches infinity. If t0=0, the value of f(0) is calculated according to the theorem on initial values as
381
LAPS2
b1 a1 (n = m + 1) f (0) = (n > m + 1) 0 For NA=NB, (1.1) is written as F ( s) = Q( s) = F1 (s) + F2 ( s) P( s) F2 ( s) C2 S n1 + C3S n2 + + Cn+1 + an+1 a1S n + a2 S n1 + (3.1)
where F1 ( s) b1 a1
where (t) is the delta function. Since F2(s) satisfies the condition of (8.20) in Chapter 8, inverse transform f2(t) of F2(s) can be calculated from (8.22). Therefore, when NA=NB the subroutine calculates the inverse of F2(s) for t>0. When t=0, the maximum value of the floating point numbers is returned. Example Given a rational function F(s): F ( s) = s2 + 4 s 4 + 12 s3 + 54s 2 + 108s + 81
NA=4 NA1=NA+1 A(1)=1.0 A(2)=-12.0 A(3)=54.0 A(4)=-108.0 A(5)=81.0 T=0.2 DELT=0.2 L=9 EPSR=1.0E-4 WRITE(6,600) NB,(I,B(I),I=1,NB1) WRITE(6,610) NA,(I,A(I),I=1,NA1) WRITE(6,620) EPSR CALL LAPS2(A,NA,B,NB,T,DELT,L,EPSR, * FT,T1,NEPS,ERRV,IFLG,VW,ICON) WRITE(6,630) ICON,IFLG IF(ICON.GE.20000) STOP WRITE(6,640) (T1(I),FT(I),ERRV(I), * NEPS(I),I=1,L) STOP 600 FORMAT(//24X,3HNB=,I3// * (20X,2HB(,I3,2H)=,E15.8/)) 610 FORMAT(/24X,3HNA=,I3// * (20X,2HA(,I3,2H)=,E15.8/)) 620 FORMAT(22X,5HEPSR=,E15.8/) 630 FORMAT(22X,5HICON=,I6,20X,5HIFLG=,I2) 640 FORMAT(15X,2HF(,F8.5,2H)=,E15.8,2X, * 6HERROR=,E15.8,2X,2HN=,I3/) END
Method The method for obtaining the inverse Laplace transform is explained in Chapter 8. This subroutine proceeds as follows: Obtain real value 0 for which F(s+0) becomes regular in the domain of Re(s)>0 using subroutine HRWIZ. Calculate inverse Laplace transform g(t) of G(s)F(s+0) by using subroutine LAPS1. Calculate f(t) from f(t)= e r0 t g(t)
the inverse Laplace transform f(t) is obtained at points, ti =0.2+0.2(i-1),where i=1,2,...,9, with EPSR=10-4.
C ** EXAMPLE** DIMENSION A(5),B(3),T1(9),FT(9), * ERRV(9),NEPS(9),VW(8) NB=2 NB1=NB+1 B(1)=1.0 B(2)=0.0 B(3)=4.0
382
LAPS3
F20-03-0101
LAPS3, DLAPS3
CALL LAPS3(FUN,T,DELT,L,EPSR,R0,FT,T1, NEPS,ERRV,ICON) Function Given a function F(s) (including non-rational function), this subroutine calculates values of the inverse Laplace transform f(t0), f(t0+ t), ..., f(t0+ t(L-1)) In this case, F(s) must be regular in the domain of Re(s)>0: Convergence coordinate). Parameters FUN ... Input. The name of the function subprogram which calculates the imaginary part of function F(s) for complex variable s. The form of the subprogram is as follows: FUNCTION FUN(S) where S stands for a complex variable. (See Example.) T ..... Input. Initial value t0(>0.0) from which the values of f(t) are required. DELT .. Input. Increment t(0.0) of variable t. If DELT=0.0, only f(t0) is calculated. L ..... Input. The number (1) of points at which values of f(t) are required. EPSR ... Input. The relative error tolerance for the values of f(t) (0.0): 10-2 to 10-4 for single precision and 10-2 to 10-7 for double precision are typical. If EPSR=0.0 or EPSR1.0 is input, the default value 10-4 is used. R0 .... Input. The value of which satisfies the condition of 0 when function F(s) is regular in the domain of Re(s)>0. If a negative is input as the value of R0, this subroutine assumes R0=0.0. FT .... Output. A set of values f(t0), f(t0+ t),...,f(t0+ t(L-1)). One-dimensional array of size L. T1 .... Output. A set of values t0, t0+ t,..., t0+ t(L1). One-dimensional array of size L. NEPS ... Output. The number of truncation items. Onedimensional array of size L. The number of terms N used to calculate FT(I) is stored in NEPS(I).
ERRV .. Output. Estimates of the relative error of the result. One-dimensional array of size L. The relative error of FT(I) is stored in ERRV(I). ICON .. Output. Condition code. (See Table LAPS31.)
Table LAPS3-1 Condition codes Code 0 10000 Meaning No error Some of the results did not meet the required accuracy. Processing Continued. Values representing accuracy for f(t0+ tNi), i=0,1,..., L1 are output to array ERRV. Bypassed. The result may not be guaranteed. Bypassed.
20000
30000
The value of EXP(R0*T1(I)+0)/T1(I) may overflow for a certain value of I. One of the following conditions: (1) T0 or DELT<0 (2) L<1
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... FLOAT, ALOG, CMPLX, EXP, INT, ATAN, ABS Notes When F(s) is a rational function, use subroutine LAPS2 for efficiency. When F(s) is regular in the domain for Re(s)>0, input 0 as parameter R0. When 00.0, simply set R0=0.0. If a negative value is input as parameter R0, R0=0.0 is assumed in the subroutine. If function f(t) for R0=0.0 and function f(t) for R0>0.0 are significantly different, it is possible because of 0>0.0. To estimate value 0 using this subroutine, perform the following procedure: Calculate f(t) using appropriate values (e.g. R0=0.0, R0=0.5) as R0. Estimate the value of t at which the values of f(t) are not the same with R0=0.0, 0.5, and 1.0. Let this value be ta. If the singular point of F(s) is s0=0+i0(0>0) (if more than one singular point exists, use the largest value of the real part as the value of s0), f(t) varies with the values of R0 in the domain of t > t a 0 ( 0 R 0) , where value 0 is as follows: log( EPSR ) 0 = +2 2 Therefore, 0(=0) can be estimated from:
383
LAPS3
0 RO +
0 ta
(3.1) f(t)
50
The results of f(t) with R0=0.0, R0=0.5, and R0=1.0 on the assumption that EPSR=10-2 are shown by the solid lines in (a), (b), and (c), respectively of Fig. LAPS3-1. The dotted lines show the correct results. These figures show that each f(t) largely varies with the values of R0. . , and f(t) sharply varies at the point of t a 2 , t a 35 t a 5 for R0=0.0, R0=0.5, and R0=1.0. Since 0=5 for EPSR=10-2, the values of 0 are estimated by using (3.1). The estimated values are as follows: For R0=0.0, 0 2.5 . For R0=0.5, 0 193 For R0=1.0, 0 2.0 Since F(s) in (3.2) has the singular point at s0 = 2 i 2 3 , the values of 0 above are proper estimates. The dotted lines in the figure show the results for input of 2.0 as the value of R0. Since the factor e 0 t is included in the expression for calculating f(t) ((4.4) in method), f(0.0) cannot be calculated. Use the value of f(0.01), f(0.0001) or so instead of the value of f(0.0). Note that an overflow may occur for an excessively small value of t. In this subroutine, the value of the imaginary part of function F(s) is evaluated at the following points:
t
6 8 10 12
50
f(t)
200
2 0 4 6 8 10 12 t
200
f(t)
10000
When, for such a point, function F(s) is a multi-valued function, a proper branch for F(s) must be calculated in the function subprogram. For example, suppose the following: F ( s) = 1 s2 + 1
0 2 4 6 t 8 10 12
s 2 + 1 generates the branches for the above sn in Quadrants 1 and 3. In this case, the branch in Quadrant 1 should be employed. Suppose the following functions: F ( s) = exp 4 s2 + 1 s F ( s) = 1 s cosh s 2 + 1
10000
(3.4) (3.5)
1 / s 2 4s + 8
384
LAPS3
In each of the above, the delay factor exp(-as) (a>0) is included in F ( s) for s .In such a case, the function subprogram should be carefully defined. For example, if (3.4) is employed without any modification, the result of f(t) is as shown in 1) in Fig. LAPS3-2. In this case, for t<2, f(t)0.0, and vibration occurs between 2 and 4. This is because the valid condition for the Euler transformation ((8.25) in Section 8.6) may not be satisfied. This is called the Gibbs phenomenon. f(t)
1.00 1) EPSR=104 R0=0.0
F (s) =
{ (
(
(
2
) }
, X = 40
2) 0.80
Suppose that f(t), inversion of Laplace transform is to be calculated at each point of (ti -X)=0.2+0.2(i-1), i=1,2,...,800. Use EPSR=10-4. Instead of F(s), the following expression is employed in the function subprogram: G(s) = exp( Xs) F (s) =
0.60
exp s s 2 + 1 X s +2
2
{(
)}
0.40
0.20
0.00
0, t < X f (t ) = g(t X ), t X Figure LAPS3-3 shows the result of g(t-X) in which t-X is used as the axis of abscissas. (Refer to [101] in References.) f(t)
1.00
4s2 + 1 /s)
For (3.4), if t<2, f(t)=0 is theoretically derived. Thus, the following expression can be sufficiently manipulated: G( s) exp(2 s) F ( s) exp = 2 s 4 s 2 + 1 s
(3.6)
0.80
Note that the above function is the image function of: g(t ) f (t + 2) t > 0
0.60
G(s) gives a more accurate result than F(s). However, since 2 s 4s 2 + 1 may cause numerical cancellation, it should be transformed to the following: 2 s 4s 2 + 1 = 1 2s + 4s2 + 1
0.40
0.20
2) in Fig. LAPS3-2 is the result of G(s) above. F(s) in (3.5) should be expanded into the following, then transformed by terms as in (3.4):
385
LAPS3
L=800 EPSR=1.0E-4 R0=0.0 CALL LAPS3(FUN,T,DELT,L,EPSR,R0,FT, * T1,NEPS,ERRV,ICON) WRITE(6,600) ICON WRITE(6,610) (T1(I),FT(I),NEPS(I), * ERRV(I),I=1,L) 600 FORMAT(1H1,20X,5HICON=,I5//) 610 FORMAT(6X,2HF(,F8.3,2H)=,E16.7,3X,2HN=, * I3,3X,4HERR=,E16.7) STOP END FUNCTION FUN(S) COMPLEX*8 S,SR SR=CSQRT(S*S+1.0) IF(REAL(SR).LT.0.0) SR=-SR SR=CEXP(40.0/(S+SR))*(S*S+2.0) FUN=AIMAG(1.0/SR) RETURN END
Value of p Approximation of f(t), fN(t,0) is calculated by using the following expression, derived from equation (8.28) in Section 8.6. f N (t , 0 ) =
p e0 k 1 1 Fn + p +1 D q Fk = = q 02 t n 1
(4.4)
where (p+1) stands for the number of terms of the Euler transformation. In this subroutine, p is determined from experience as p = 0 + 2 (4.5)
When F(s)=O(s) as s , and if 0, that is, EPSR is given so that the value of p satisfies the condition: p ( + 5) (4.6)
Method Calculation of inverse Laplace transform is described in Section 8.6. Let the value of R0 be , then for >0, G(s)=F(s+) is regular in the domain of Re(s)>0. By calculating inverse transform g(t), function f(t) can be derived as: f ( t ) = et g ( t ) (4.1)
then, (4.4) can also be applied to F(s) for which f(t) may be a distribution. Below is an example in which f(t) may be distribution. Inverse transform of F (s) = s , can be written as f (t ) =
(t ) t
(2
U (t )
t3 2
In the following description, a function which is regular in the domain of Re(s)>0, will be set to F(s) again. Then determination of parameters 0, p, and N described in Section 8.6, will be described. Value of 0 (truncation error) From (8.23) in Section 8.6, 0 approximation f(t,0) of f(t) can be expressed as f (t , 0 ) = f (t ) e 2 0 f (3t ) + e4 0 f (5t )
where (t) stands for the Dirac delta function, and U(t) stands for the following: 1, t 0 U (t ) = 0 , t < 0 Because lim F (s) 0 , the above method cannot be
s
applied to F (s) = s theoretically. However, when p is set to 6(>1/2+5) or more in the range of t>0, this subroutine can be used for this function as usual. Value of N (number of truncation terms) With k and p used in (4.4):
N =k+p
(4.2)
The value of 0 is determined so that the required relative error tolerance EPSR may be as follows: EPSR = f t , 0 f (t ) f (t )
( )
f (t , 0 ) f ( t ) f (3t )
Stands for the number of truncation terms and is equal to the evaluation count for function F(s). The value of k must be determined so that the valid condition for the Euler transformation ((8.25) in Section 8.6) may be satisfied. Such a value of k depends upon t, and can be expressed by: (4.3) k = k1 + k 2 t (where k1 and k2 are constants.) This subroutine calculates f(t) for the range of t 0 t t 0 + t (L 1) with use of the following method, which determines the values of k1 and k2. First, by setting t=t0, define k which allows truncation error ERRV(1) to in the range of ERRV(1)<EPSR. Let this be k'. (4.7)
where [] is the Gaussian notation. 2.0 is added to the second term of the right part in (4.3) to produce 0=3 even for EPSR=10-1. The value of 0 is almost the same as the number of significant digits of fN(t,0).
386
LAPS3
Next, by setting t=t0+ t(L-1), define k which allows ERRV(L)<EPSR. Let this be k''. From these, the following simultaneous equations are obtained: k = k1 + k 2 t 0
Determine the value of k1 and k2 by solving these equations. Then, calculate k by applying these values to equation (4.7) (For the fraction part, round up to the integer part.) The value of N is output to array NEPS.
k = k 1 + k 2 t 0 + t (L 1)
(4.8)
387
LAX
A22-11-0101
LAX, DLAX
Table LAX-1 Condition codes Code 0 20000 Meaning No error Either all of the elements of some row were zero or the pivot became relatively zero. It is highly probable that the coefficient matrix is singular. K<N, N<1, EPSZ<0.0 or ISW1,2 Processing Discontinued
CALL LAX(A,K,N,B,EPSZ,ISW,IS,VW,IP,ICON) Function This subroutine solves a real coefficient linear equations (1.1) using the Crout's method. Ax = b Where A is an nn regular real matrix, b is an ndimensional real constant vector, and x is the ndimensional solution vector. n1. Parameters A ..... Input. Coefficient matrix A. The contents of A are altered on output. A is a two-dimensional array, A(K,N). K ..... Input. Adjustable dimension of array A (N). N ..... Input. Order n of the coefficient matrix A. B ..... Input. Constant vector b. Output. Solution vector x. B is a one-dimensional array of size n. EPSZ .. Input. Tolerance for relative zero test of pivots in decomposition process of A (0.0). If EPSZ is 0.0, a standard value is used. ISW ... Input. Control information. When l (1) systems of linear equations with the identical coefficient matrix are to be solved, ISW can be specified as follows: ISW=1, the first system is solved. ISW=2, the 2nd to lth systems are solved. However, only parameter B is specified for each constant vector b of the systems of equations, with the rest unchanged. (See Notes.) IS .... Output. Information for obtaining the determinant of matrix A. If the n elements of the calculated diagonal of array A are multiplied by IS, the determinant is obtained. VW .... Work area. VW is a one-dimensional array of size n. IP .... Work area. IP is a one-dimensional array of size n. ICON .. Output. Condition code. Refer to Table LAX1. (1.1)
30000
Bypassed
Comments on use Subprogram used SSL II ..... ALU, LUX, AMACH, MGSSL FORTRAN basic functions ..... ABS Notes The solution x obtained by this subroutine may be refined in accuracy by calling subroutine LAXR successively. If EPSZ is set to 10-s, this value has the following meaning; while performing the LU-decomposition by Crount's method, if the loss of over s significant digits occurred for the pivot, the LU-decomposition should be discontinued with ICON=20000 regarding the pivot to be relatively zero. The standard value of EPSZ is 16u, u being the unit round off. If the processing is to proceed at a lower pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. When solving successive systems of linear equations with the identical coefficient matrix, computation can be performed by setting ISW=2 after the first system of equations are processed. By setting ISW=2, LUdecomposition of coefficient matrix A is bypassed so the computation time is reduced. In this case, the value of IS is the same as when ISW=1. Example In this example, l systems of linear equations in n unknown with the identical coefficient matrix are solved. n100.
C **EXAMPLE** DIMENSION A(100,100),B(100),VW(100),IP(100) READ(5,500) N READ(5,510) ((A(I,J),I=1,N),I=1,N) WRITE(6,600) N,((I,J,A(I,J),J=1,N),I=1,N) READ(5,500) L M=1 ISW=1 EPSZ=1.0E-6
388
LAX
10 READ(5,510) (B(I),I=1,N) WRITE(6,610) (I,B(I),I=1,N) CALL LAX(A,100,N,B,EPSZ,ISW,IS,VW,IP, * ICON) WRITE(6,620) ICON IF(ICON.GE.20000) STOP WRITE(6,630) (I,B(I),I=1,N) IF(L.EQ.M) GOTO 20 M=M+1 ISW=2 GOTO 10 20 DET=IS DO 30 I=1,N DET=DET*A(I,I) 30 CONTINUE WRITE(6,640) DET STOP 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1,10X,21H** COEFFICIENT MATRIX * /12X,6HORDER=,I5/(10X,4(1H(,I3,1H,I3, * 1H),E16.8))) 610 FORMAT(///10X,15HCONSTANT VECTOR * /(10X,5(1H(,I3,1H),E16.8))) 620 FORMAT(1H0,10X,15HCONDITION CODE=,I5) 630 FORMAT(1H0,10X,15HSOLUTION VECTOR * /(10X,5(1H(,I3,1H),E16.8))) 640 FORMAT(///10X, * 34HDETERMINANT OF COEFFICIENT MATRIX=, * E16.8) END
is solved using the following procedure. LU-decomposition of coefficient matrix A (Crout's method) The coefficient matrix A is decomposed into the product of a lower triangular matrix L and a unit upper triangular matrix U. To reduce rounding off errors, the partial pivoting is performed in the decomposition process. PA = LU (4.2)
P is the permutation matrix which performs the row exchanges required in partial pivoting. Subroutine ALU is used for this operation. Solving LU=Pb (forward and backward substitutions) Solving equation (4.1) is equivalent to solving the linear equation (4.3). LUx = Pb Equation (4.3) is decomposed into two equations
Ly = Pb
(4.3)
Ux = [
(4.4) (4.5)
then the solution is obtained using forward substitution and backward substitution. Subroutine LUX is used for these operations. For more information, see References [1], [3], and [4].
389
LAXL
A25-11-0101
LAXL, DLAXL
Table LAXL-1 Condition codes Code 0 20000 30000 Meaning No error Rank (A)<n K<M, M<N, N<1 or ISW1,2 Processing Discontinued Bypassed
CALL LAXL(A,K,M,N,B,ISW,VW,IVW,ICON) Function This subroutine solves the overdetermined system of linear equations (1.1) for the least squares solution ~ x using Householder transformation, Ax = b (1.1)
Comments on use Subprogram used SSL II ..... ULALH, ULALB, AMACH, MGSSL FORTRAN basic functions ..... SQRT Notes The least squares solution ~ x is stored in the first n elements of array B. When solving successive systems of linear equations with the identical coefficient matrices, ISW=2 should be specified after the first system. Then reducing the coefficient matrix to an upper triangular matrix is bypassed by setting ISW=2, hence computation time is reduced. Refer to "Method" for reducing to an upper triangular matrix. Example This example shows the method to solve l overdetermined systems of linear equations with the identical coefficient matrix where m, the number of equations, is not less than n, the number of unknowns. m100.
C **EXAMPLE** DIMENSION A(100,100),B(100),VW(200),IVW(100) READ(5,500) M,N,L READ(5,510) ((A(I,J),I=1,M),I=1,N) WRITE(6,600) M,N,((I,J,A(I,J),J=1,N),I=1,M) LL=1 ISW=1 10 READ(5,510) (B(I),I=1,M) WRITE(6,610) (I,B(I),I=1,M) CALL LAXL(A,100,M,N,B,ISW,VW,IVW, ICON) WRITE(6,620) ICON IF(ICON.NE.0) STOP WRITE(6,630) (I,B(I),I=1,N) IF(L.EQ.M) GO TO 20 ISW=2 LL=LL+1 IF(LL.LE.L) GO TO 10 WRITE(6,640) STOP 500 FORMAT(3I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1,5X, * 29HLINEAR LEAST SQUARES SOLUTION/6X, * 11HROW NUMBER=,I4,5X,14HCOLUMN NUMBER= * ,I4/6X,19HCOEFFICIENT MATRIX=/ * (10X,4(1H(,I3,1H,,I3,1H),E17.8,3X))) 610 FORMAT(///10X,16HCONSTANT VECTOR= * /(10X,4(1H(,I3,1H),E17.8,3X))) 620 FORMAT(1H ,10X,15HCONDITION CODE=,I6)
Given mn real matrix A of rank n and m-dimensional constant vector b where m is not less than n. That is, this subroutine determines the solution vector x such that b Ax
2
is minimized. where n1. Parameters A ..... Input. Coefficient matrix A. The contents of A are altered on output. The matrix A is a two-dimensional array, A(K,N). K ..... Input. Adjustable dimension of array A (M). M ..... Input. Number of rows, m, in matrix A. N ..... Input. Number of columns, n, in matrix A. B ..... Input. Constant vector b. ~ . OneOutput. The least squares solution x dimensional array of size m. (Refer to Notes.) ISW ... Input. Control information. When solving l ( 1) systems of linear equations with the identical coefficient matrix, specify as follows: ISW = 1 ... The first system is solved. ISW = 2 ... The 2nd to l th systems are solved. however, the values of B are to be replaced by the new constant vector b with the rest unchanged. (Refer to Notes) VW ... Work area. One-dimensional array of size 2n. IVW ... Work area. One-dimensional array of size n. ICON .. Output. Condition code. Refer to Table LAXL-1.
390
LAXL
630 FORMAT(1H ,10X,16HSOLUTION VECTOR= * /(10X,4(1H(,I3,1H),E17.8,3X))) 640 FORMAT(1H0,5X, * 33HLINEAR LEAST SQUARES SOLUTION END) END
The actual procedure is performed as follows. Transforming a matrix A into a triangular matrixIn transforming a matrix A into an upper triangular matrix, let a(k)ij be the elements of a matrix A(k). Then the transformation is as follows: A( ) = A
1
Method Let A be an m n real matrix with m n and of rank n and b be an m-dimensional constant vector. This subroutine determines the vector ~ x (the least squares solution) so that b Ax
2
A(
k +1 )
= P ( ) A( ) , k = 1 ,
k k
, n
(4.7)
(4.1)
is accomplished by orthogonal matrix P(k) as shown in ( k +1) equation (4.8) such that aik =0, i=k+1,...,m. (Refer to Fig. LAXL-1) P ( k ) I = k u ( k ) u( k )
T
is minimized. Since the Euclidean norm is invariant with the orthogonal transformation. b Ax
2
(4.8)
= Qb QAx
= C Rx
(4.2)
m 2 ( k ) ik Where, k = i= k
u( k ) = u1( ) , u2 ( ) , , um(
T k k
k = k k + a( k ) kk
ui ( k ) = 0, i < k
[ (
)
k)
1 2
)]
(4.3)
uk ( ) = sign a( k ) kk k + a ( k ) kk
k
( (
,i > k
ui
(k )
=a
(k)
ik
~ where R is an n n upper triangular matrix, clearly the equation (4.2) is represented by the equation (4.4) as follows:
k A
k
~ ~ C Rx 2 = C Rx C1
(4.4)
2
~ where C denotes the first n-dimensional vector of C, and C1 is the (m - n)-dimensional vector of C except for ~ C . Therefore, the equation (4.4) is minimum when ~ ~ C Rx = 0 . In other words, if matrix A can be reduced to an upper triangular matrix by an orthogonal transformation as shown in the equation (4.3), the least squares solution ~ x of the equation (4.1) can be obtained by the following the equation (4.5). ~ ~ x = R 1C
The orthogonal matrix P is chosen so that the elements marked by become zeros in the transformation +1 Ak =PkAk. The elements surrounded by are all changed
= P ( )P (
n
n 1 )
P
( 1)
A = QA
(4.5)
In this subroutine, the least squares solution is determined by the following procedures: Reducing a matrix A to an upper triangular matrix ... Transforming a matrix A to an upper triangular matrix with the Householder transformation, matrix R is obtained using the equation (4.3). Obtaining a solution ... The least squares solution ~ x is obtained using the equation (4.5).
This is called the Householder transformation. In this subroutine the following items are taken into consideration: Previous to the k -th transformation, the k -th column is chosen in such a way that k value becomes maximum in equation (4.8) in order to minimize calculation errors. In other words, let the l -th column be chosen out of the equation (4.9) so that S1( k ) =max S (j k ) and then the l-th column is exchanged with k -th column.
k k s j ( ) = aij ( ) , i = k , m i =k
( )
,
(4.9)
391
LAXL
where u is a unit round off. Then rank (A) < n is assumed and the processing is discontinued with ICON = 20000. In order to reduce the calculation for the transformation, P(k) is not computed explicitly, but rather the transformation (4.7) is done by way of the following transformation: A(
k +1)
P
(1 )
(4.10)
P
( 1)
(4.11)
= I k u( ) u (
k k k = A( ) u ( ) y k
k )T
) A
(k)
Solving the system of linear equations (4.12) by using ~ this C , the least squares solution for the equations (4.1) can be obtained as follows:
~ ~=C Rx
where, y k T = k U ( k )T A( k ) taking into consideration the fact that the first (k-1) elements of u(k) are all zeros when the vector y(k) and the
(4.12)
~ Taking into consideration that the matrix R is an upper trangular matrix, the equation (4.12) can be solved using backward substitution.
392
LAXLM
A25-21-0101
LAXLM, DLAXLM
EPS...
Least squares minimal norm solution of a real matrix (singular value decomposition method)
CALL LAXLM(A,KA,M,N,B,ISW,EPS,SIG,V,KV, VW,ICON) Function This subroutine obtains least squares minimal norm solution x+ for a system of linear equations with an m n real matrix A. Ax=b (1.1)
Input. Tolerance for relative zero test of singular values (0.0). When EPS=0.0 is specified, the default value is used. (See Notes.) Output. Singular values. One-dimensional array of size n. (See Notes.) Work area. Two-dimensional array, V(KV,K) where K=min(M+1,N). (See Notes.) Input. Adjustable dimension of array V (N). Work area. One-dimensional array of size n. Output. Condition code. See Table LAXLM-1.
where b is an m-dimensional real constant vector, this subroutine determines the n order solution vector x so that x
2
Meaning No error Any singular values could not be obtained. KA<M, M<1, N<1, KV<N, EPS<0.0 or ISW1,2
is minimized while b Ax
2
is minimized. m1, n1 Parameters A ..... Input. Coefficient matrix A. The contents of A are altered on output. Two-dimensional array, A(KA,N). KA ..... Input. Adjustable dimension of array A (M). M ..... Input. Number of rows in coefficient matrix A, m. N ..... Input. Number of columns in coefficient matrix A and number of rows in matrix V, n. B ..... Input. Constant vector b. Output. Least squares minimal norm solution x+. One-dimensional array of size max(m,n). (See Notes.) ISW ... Input. Control information. Specify depending upon the conditions that one system of linear equations is solved or some systems of linear equations with the identical coefficient matrix is solved as follows: ISW=0: One system is solved. ISW=1: The first system is solved and the information to solve the subsequent systems are left. ISW=2: The second and subsequent systems are solved. However the values of B are to be replaced by the new constant vector b with the rest specifying ISW=1. (See Notes.)
Comments on use Subprograms used SSL II ..... ASVD1, AMACH, MGSSL FORTRAN basic functions ..... MINO, SIGN, SQRT, AMAX1, ABS Notes The least squares minimal norm solution x+ is stored in the first n elements of array B. When only one least squares minimal norm solution is required, if ISW=0 is specified, this subroutine does not compute transformation matrix U by singular value decomposition. Therefore computational time is reduced. Matrix V is returned in the first l columns of array V with l=min(m,n). This matrix V can be obtained on array A. To obtain the least squares minimal norm solutions of a number of systems of linear equations with identical coefficient matrices, specify ISW=1 for the first system. Next specify ISW=2 for the second and subsequent system. Since the singular value decomposition for coefficient matrices is omitted in the second and following systems, the computational time is reduced. Matrices U and V are stored in the first l columns of A and first l columns of V respectively. See Method. All singular values are non-negative and are stored in descending order. When ICON=15000, unobtained singular values are defined -1 and are not arranged in descending order.
393
LAXLM
This subroutine should be used when rank deficient of A is or may be found (rank (A) in (m,n)). When rank (A) = min(m,n), the subroutine LAXL should be used. Input parameter EPS is used for determining the rank of A. It must be carefully specified. See Method. Example This example shows the method to solve the least squares minimal norm solutions for systems of linear equations Ax = b associated with m n coefficient matrix A. Matrix V is obtained on A. 1m100, 1n1100.
C **EXAMPLE** DIMENSION A(100,100),B(100), * SIG(100),VW(100) 10 READ(5,500) M,N IF(M.EQ.0) STOP READ(5,510) ((A(I,J),I=1,M),I=1,N) WRITE(6,600) M,N, * ((I,J,A(I,J),J=1,N),I=1,M) READ(5,510) (B(I),I=1,M) WRITE(6,610) (I,B(I),I=1,M) CALL LAXLM(A,100,M,N,B,0,0.0,SIG, * A,100,VW,ICON) WRITE(6,620) ICON IF(ICON.NE.0) GO TO 10 CALL SVPRT(SIG,A,100,N,N) WRITE (6.630)(I,B(I),I=1,N) GO TO 10 500 FORMAT(2I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,5X, * 25HLEAST SQUARES AND MINIMAL, * 14H NORM SOLUTION/6X, * 11HROW NUMBER=,I4,5X, * 14HCOLUMN NUMBER=,I4/6X, * 19HCOEFFICIENT MATRIX=/ * (10X,4H(1H(,I3,1H,,I3,1H), * E17.7,3X))) 610 FORMAT(///10X, * 16HCONSTANT VECTOR= * /(10X,4(1H(,I3,1H),E17.7,3X))) 620 FORMAT(1H,10X,15HCONDITION CODE=, * I6) 630 FORMAT(1H1,10X, * 16HSOLUTION VECTOR= * /(10X,4(1H(,I3,1H),E17.7,3X))) END
Ax = b
(4.1)
(4.3)
(4.2)
This subroutine can handle matrix A independent of the size of m and n. m n is assumed to make the explanation easy in the following example. Singular value decomposition and least squares minimal norm solution Given a singular value decomposition of A A = U V T where U is an m n matrix as shown in (4.5) U TU = I V is an n n orthogonal matrix V TV = VV T = I is an n n diagonal matrix = diag( 1 , 2 , where (4.6) (4.5) (4.4)
, )
n
1 2 n 0
If m m orthogonal matrix Uc is produced by adding m - n column vectors in the right of U and c is produced by adding m - n n zero matrix below , the singular value decomposition can be represented like following: A = Uc c V T Suppose ~ bc = U c T b , ~ x =VTx (4.9) (4.8)
The subroutine SVPRT in this example prints the singular values and eigenvectors. The subroutine SVPRT is described in the example of the subroutine ASVD1. Method Given m n matrix A and m-dimensional constant vector b, this subroutine solves least squares minimal norm solution x+ for a system of linear equations
Since transformation by orthogonal matrix Uc does not change the value of 2 norm, (4.10) can be obtained based upon (4.8) and (4.9) ~ T ~ b Ax 2 = U c (b Ax) = bc c x
2
(4.10)
2
394
LAXLM
can be obtained from (4.14) and (4.15). From (4.16), (4.19) and (4.12), least squares minimal norm solution x+ is given as x + = V + U T b (4.20)
~ Where b is an n-dimensional vector consisting of the ~ first n elements of b . It can be given by ~ b = UTb
(4.12)
(4.20) can be represented by x+ = A+b by using the generalized inverse A+. See Method of the subroutine GINV. Computational procedures 1) A is reduced to upper bidiagonal matrix J0 by performing the Householder transformation alternatively from left and right. J 0 = Pn Pn1
P AQ Q Q
1 1 2
n 2
(4.21)
(4.13)
For details, see Method of the subroutine ASVD1. 2) J0 is reduced to diagonal matrix by performing orthogonal transformation alternatively from left and right. = Sq
T
S
J 0T1 Tq
(4.22)
,
(4.14)
and the other are arbitrary. That is, the least squares solution is not unique. If the condition that the norm of the least squares solution is minimized is added to the condition, the solution will be obtained uniquely. For this purpose, components excepting those given in (4.14) must be ~ xi = 0 , i = r + 1,
L R
n n
(4.23) (4.24)
For details, see Method of the subroutine ASVD1. 3) Matrices UT and V are given from (4.4), (4.21) and (4.22) as follows:
, n
(4.15)
Taking (4.9) into consideration, since V is orthogonal transformation matrix which makes 2 norm in variable, then x+ obtained by ~ x+ = V x is the least squares minimal norm solution. Next, let x+ represented by using a matrix. + which is the generalized inverse of can be represented by + = diag + , + , where
+ 1 , i > 0 i = i 0 , i = 0 When this + is used, ~ ~ = + b x
S P P V = Q Q T T
T U T = Sq 1 T 1 n n2 1 q
(4.25) (4.26)
(4.16)
, ),
+ n
(4.17)
U and V are obtained on array A and V respectively by multiplying a transformation matrix sequentially from the right. The above discussion is adapted when ISW=1 is specified. When ISW=0 is specified, this subroutine directly computes UT b without producing U. For this purpose, the transformation matrix constructing UT should be sequentially multiplied from the left of b. 4) x + = V +U T b is produced by sequentially multiplying UT, +, and V from the left of b. When ISW=0 is specified, UT is not multiplied.
(4.18)
(4.19)
395
LAXLM
At multiplying +, relative zero test is carried out for i using J 0 EPS as tolerance. If the singular value is less than the tolerance, it is assumed to be zero. When EPS=0.0 is specified, EPS=16u is assumed, where u is the unit round off. When ISW=0, this subroutine directly processes
these procedures. When ISW=1 is specified, this subroutine performs the singular value decomposition by using subroutine ASVD1. For details, see Method of the subroutine ASVD1 and Reference [11].
396
LAXLR
A25-11-0401
LAXLR, DLAXLR
Table LAXLR-1 Condition codes Code 0 20000 25000 Meaning No error Rank(A)<n was found. The convergence condition was not met because of very ill-conditioned coefficient matrix. K<M, M<N or N<1 Processing Discontinued Discontinued (Refer to "Method" for the convergence condition.) Bypassed
CALL LAXLR(X,A,K,M,N,FA,FD,B,IP,VW,ICON) Function ~ to the Given an approximate least squares solution x linear equations with an m n real matrix A (rank (A)=n) such as Ax = b (1.1)
30000
This subroutine refines the solution by the method of iterative modification, where b is an m-dimensional real constant vector, and x is an n-dimensional solution vector. The coefficient matrix A must have been decomposed using the Householder transformation with partial pivoting which exchanges columns of the matrix as shown in Eq. (1.2), R = QA (1.2)
Comments on use Subprograms used SSL II ... ULALB, MAV, AMACH, and MGSSL FORTRAN basic functions ... IABS, ABS and SQRT. Notes This subroutine repeatedly corrects the approximate ~ obtained by the subroutine least squares solution x LAXL, and improves its accuracy. Therefore, prior to calling this subroutine to obtain the refined least squares solution approximate least ~ must have been obtained by squares solution x calling subroutine LAXL and then the results, B, A, VW and IVW, of the subroutine LAXL must be input as the parameters X, FA, FD and IP to be used for this subroutine. In addition, this subroutine needs both the coefficient matrix A and the constant vector b, therefore they must be saved before calling the subroutine LAXL in order not to lose them. Refer to the example shown below for a more practical use. By specifying N=-n, and Euclidean norm ~ of the residual vector b Ax for the 2
where R is an upper triangular matrix, and Q is an orthogonal matrix, also mn1. Parameters X ..... Input. Approximate least squares solution x. Output. Iteratively refined least squares ~. solution x One-dimensional array of size n. A ..... Input. Coefficient matrix A. Two-dimensional array such as A(K,N) K ..... Input. Adjustable dimension of array A (M). M ..... Input. Number of rows m in matrix A. N ..... Input. Number of columns n in matrix A. (See Notes.) FA .... Input. Upper triangular portion of matrix R, and matrix Q. Two-dimensional array such as FA(K,N). (See Notes.) FD .... Input. Diagonal portion of matrix R. One-dimensional array of size n. (See Notes.) B ..... Input. Constant vector b. One-dimensional vector of size m. IP .... Input. Transposition vector which indicates the history of exchanging rows of the matrix A required in partial pivoting. One-dimensional array of size n. (See Notes.) VW .... Work area. One-dimensional array of size m. ICON .. Output. Condition code. See Table LAXLR-1.
approximate least squares solution obtained by the subroutine LAXL. When specified, this subroutine does not perform iterative refinement for the solution, but only computes the Euclidean norm of the residual vector and outputs it to the parameter VW(1). Example ~ to linear equations with m A least squares solution x unknowns and n equations (with m n) is obtained by calling the subroutine LAXL. The least squares ~ is iteratively refined by this subroutine. solution x Here m100.
C **EXAMPLE** DIMENSION A(50,50),FA(50,50),X(50), * B(50),VW(100),IVW(50),FD(100), * NT1(6),NT2(4),NT3(4) DATA NT1/2HCO,2HEF,2HFI,2HCI, * 2HEN,2HT/, * NT2/2HCO,2HNS,2HTA,2HNT/, * NT3/2HSO,2HLU,2HTI,2HON/ READ(5,500) M,N
397
LAXLR
WRITE(6,600) M,N READ(5,510) ((A(I,J),I=1,M),J=1,N) CALL PGM(NT1,6,A,50,M,N) READ(5,510) (B(I),I=1,M) CALL PGM(NT2,4,B,M,M,1) DO 20 I=1,M X(I)=B(I) DO 10 J=1,N FA(I,J)=A(I,J) 10 CONTINUE 20 CONTINUE ISW=1 CALL LAXL(FA,50,M,N,X,ISW,FD,IVW,ICON) WRITE(6,610) ICON IF(ICON.NE.0) STOP CALL LAXLR(X,A,50,M,N,FA,FD,B,IVW, * VW,ICON) WRITE(6,620) ICON IF(ICON.NE.0) STOP CALL PGM(NT3,4,X,N,N,1) STOP 500 FORMAT(2I5) 510 FORMAT(10F8.3) 600 FORMAT(1H1, * /6X29HLINEAR LEAST SQUARES SOLUTION * /6X,11HROW NUMBER=,I4 * /6X,14HCOLUMN NUMBER=,I4) 610 FORMAT(1H,5X,13HICON OF LAXL=,I6) 620 FORMAT(1H,5X,14HICON OF LAXLR=,I6) END
r ( s) = b Ax ( s ) Ad ( s ) = r ( s ) x ( s+1) = x ( s ) + d ( s ) s=1,2,...
where x(s) is the s-th approximate solution to equation (4.1). If Eq. (4.2) is accurately computed, a refined solution of the approximate solution x(1) is numerically obtained. If, however, the condition of the coefficient matrix A is not suitable, an improved solution is not obtained. (Refer to "Iterative refinement of a solution" in Section 3.4.) Procedure performed in this subroutine Suppose that the first approximate solution x(1) has already been obtained by the subroutine LAXL. The residual r(s) is computed by using Eq. (4.2). This is performed by calling the subroutine MAV. The correction d(s) is obtained by using Eq. (4.3). This is performed by calling the subroutine ULALB. Finally, the modified approximate solution x(s+1) is obtained by using Eq. (4.4). The convergence of iteration is tested as follows: Considering u as a unit round off, the iteration refinement is assumed to converge if, at the s-th iteration step, the following relationship is satisfied. d( )
s
The subroutine PGM is used in this example only to print out a real general matrix, it is described in the example for the subroutine MGSM. Method Given the approximate least squares solution (approximate solution, hereafter), ~ x to the linear equations Ax = b (4.1)
x(
s +1)
< 2u
(4.5)
The obtained x(s+1) is then taken as the final solution. However, if the relationship, d( )
s
the approximate solution is iteratively refined as follows: Principle of iterative refinement The iterative refinement is a method to obtain a successive improved approximate solution x(s+1) (s=1,2,...) to the linear equations (4.1) through use of the following equations starting with x(1)=x
x(
s +1)
( ) 1 d > ( s) 2 x
s 1
results, this indicates that the condition of the coefficient matrix A is not suitable. The iteration refinement is assumed not to converge, and consequently the processing is terminated with ICON=25000.
398
LAXR
A22-11-0401
LAXR, DLAXR
Iterative refinement of the solution to a system of linear equations with a real general matrix
CALL LAXR(X,A,K,N,FA,B,IP,VW,ICON) Function ~ is given to linear When an approximate solution x equations with an n n real matrix A such as Ax = b (1.1)
u u
1n
2n
1 un1,n 1
This subroutine refines the approximate solution by the method of iterative modification, where b is an ndimensional real constant vector, and x is an ndimensional solution vector. Prior to calling this subroutine, the coefficient matrix A must be LU-decomposed as shown in Eq. (1.2), PA = LU (1.2)
l l l l
n2
0
lnn
n 1,n 1 n ,n 1
u u l u l l l l
l11 u12 u13 l21 l22 l23
n1,n1 n,n1 n1 n2
1n
2n
N K
n1,n nn
Fig. LAXR-1 Storage of elements of L and U in array FA Table LAXR-1 Condition codes Code 0 20000 25000 Meaning No error The coefficient matrix was singular. The convergence condition was not met because of very illconditioned coefficient matrix. Processing Discontinued Discontinued (Refer to "Method" for the convergence condition.) Bypassed
where L and U are an n n lower triangular matrix and unit upper triangular matrix, respectively, and P is a permutation matrix which exchanges rows of the matrix A required in partial pivoting. n1. Parameters X ..... Input. Approximate solution vector x. Output. Refined solution vector. One-dimensional array of size n. A ..... Input. Coefficient matrix. Two-dimensional array such as A(K,N) K ..... Input. The adjustable dimension of array A (N). N ..... Input. The order n of matrix A (See Notes.) FA .... Input. Matrices L and U. See Fig. LAXR-1. Two-dimensional array, FA(K,N). See Notes. B ..... Input. Constant vector b. One-dimensional vector of size n. IP .... Input. The transposition vector which indicates the history of the rows exchange in partial pivoting. One-dimensional array of size n. Refer to Notes. VW .... Work area. One-dimensional array of size n. ICON .. Output. Condition code. See Table LAXR-1.
30000
K<N or N<1
Comments on use Subprograms used SSL II ... LUX, MAV, AMACH, and MGSSL FORTRAN basic functions ... ABS Notes This subroutine iteratively corrects the approximate ~ obtained by subroutine LAX to get solution solution x x with refined precision. Therefore prior to calling this ~ must be obtained by LAX and the subroutine, x results must be input as the parameters X, FA and IP to be used for this subroutine. In addition, because this subroutine also requires the coefficient matrix A and constant vector b, they must also be prepared separately before calling LAX. Refer to the example for details. If N=n is specified, an estimated accuracy ~ that is (relative error) for the approximate solution x given by the subroutine LAX can be obtained. When specified, this subroutine calculates the relative error and out-
399
LAXR
puts it to work area VW(1) without performing the iterative refinements of accuracy. Refer to "method" for estimation of accuracy. Example ~ for a system of An approximate solution vector x linear equations in n unknowns is obtained by ~ is refined to x. subroutine LAX, then x n100.
C **EXAMPLE** DIMENSION A(100,100),FA(100,100),X(100), * B(100),VW(100),IP(100) 10 READ(5,500) N IF(N.EQ.0) STOP READ(5,510) ((A(I,J),I=1,N),J=1,N) WRITE(6,600) N,((I,J,A(I,J),J=1,N),I=1,N) READ(5,510) (B(I),I=1,N) WRITE(6,610) (I,B(I),I=1,N) DO 20 I=1,N X(I)=B(I) DO 20 J=1,N FA(J,I)=A(J,I) 20 CONTINUE EPSZ=0.0E0 ISW=1 K=100 CALL LAX(FA,K,N,X,EPSZ,ISW,IS,VW,IP, * ICON) WRITE(6,620) ICON IF(ICON.GE.20000) GO TO 10 CALL LAXR(X,A,K,N,FA,B,IP,VW,ICON) WRITE(6,630) ICON IF(ICON.GE.20000) STOP WRITE(6,640) (I,X(I),I=1,N) DET=IS DO 30 I=1,N DET=DET*FA(I,I) 30 CONTINUE WRITE(6,650) DET STOP 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1,10X,20H**COEFFICIENT MATRIX * /12X,6HORDER=,I5/(10X,4(1H(,I3,1H,,I3, * 1H),E17.8))) 610 FORMAT(///10X,15HCONSTANT VECTOR * /(10X,4(1H(,I3,1H),E17.8))) 620 FORMAT(1H0,10X,10HLAX ICON=,I5) 630 FORMAT(1H0,10X,10HLAXR ICON=,I5) 640 FORMAT(1H0,10X,15HSOLUTION VECTOR * /10X,4(1H(,I3,1H),E17.8))) 650 FORMAT(///10X, * 34HDETERMINANT OF COEFFICIENT MATRIX=, * E17.8) END
Method ~ , to the linear Given the approximate solution x equations, Ax = b the solution is iteratively refined as follows: Principle of iterative refinement The iterative refinement is a method to obtain a successively improved approximate solution x(s+1) (s=1,2,...) to the linear equations (4.1) through use of I ~ the following equations starting with x ( ) = x
r ( s) = b Ax ( s ) Ad ( s ) = r ( s ) x ( s+1) = x ( s ) + d ( s ) s=1,2,...
(4.1)
where x(s) is the s-th approximate solution to equation (4.1). If Eq. (4.2) is accurately computed, a refined solution of the approximate solution x(1) is numerically obtained. If, however, the condition of the coefficient matrix A is not suitable, an improved solution is not obtained. (Refer to "Iterative refinement of a solution" in Section 3.4.) Procedure performed in this subroutine Suppose that the first approximate solution x(1) has already been obtained by the subroutine LAX. Then this subroutine repeats the following steps: The residual r(s) is computed by using Eq. (4.2). This is performed by calling the subroutine MAV. The correction d(s) is obtained next by using Eq. (4.3). This is performed by calling the subroutine LUX. Finally the modified approximate solution x(s+1) is obtained by using Eq. (4.4). The convergence of iteration is tested as follows: Considering u as a unit round off, the iterative refinement is assumed to converge if, as the s-th iteration step, the following relationship is satisfied. d( )
s
x(
s+1)
< 2u
(4.5)
The obtained x(s+1) is then taken as the final solution. However, if the relation, d( )
s
( s+1)
( ) 1 d > 2 x ( s)
s 1
400
LAXR
results, this indicates that the condition of coefficient matrix A is not suitable. The iterative refinement is assumed not to converge, and consequently the processing is terminated with ICON = 25000. Accuracy estimation for approximate solution Suppose the error for the approximate solution x(1) is e(1) ( = x(1) x ), its relative error is represented by
(1 )
(1)
is assumed to be almost equal to d(1). The relative error for the approximate solution is therefore
1 estimated by d ( )
x (1)
(Refer to "Accuracy
estimation for approximate solution" in Section 3.4.) For further details, see to References [1], [3], and [5].
401
LBX1
A52-11-0101 LBX1,DLBX1
A system of linear equations with a real general band matrix (Gaussian elimination method)
ICON..
Table LBX1-1. Condition code Code 0 20000 Meaning No error The relatively zero pivot occured. It is highly probable that the coefficient matrix is singular. NNH1,NNH2,NH1<0,NH2<0, EPSZ<0.0 or ISW1,2. Processing Discontinued
30000
Bypassed
This subroutine solves a system of linear equations(1.1) by using the Gaussian elimination method. Where A is an nn real general band matrix with lower band width h1, and upper band width h2, b is an ndimensional real constant vector, and xis an ndimensional solution vector.n>h10, n>h20. Parameters A..... Input. Coefficient matrix A. The contents of A are altered on output. Matrix A is stored in one-dimensional array of size n. min(h1+h2+1,n) in the compressed mode for real general band matrices. N..... Input. Order n of coeffcient matrix A. NH1..... Input. Lower band width h1. NH2..... Input. Upper band width h2. B..... Input. Constant vector. Output. Solution vector. One-dimensional array of size n. ESPZ.. Input. Tolerance for relative zero test of pivots in decomposition process of matrix A(0.0).When this is 0.0, the standard value is used. (See Notes.) ISW... Input. Control informaltion When solving l (1) systems of linear equations with the identical coefficient matrix, ISW can be specifled as follows: ISW=1... The first system is solved. ISW=2... The 2nd to l th systems are solved. However, only parameter B is specified for each constant vector b of the systems with the rest unchanged. (See Motes.) IS.... Output. Information for obtaining the determinant of the matrix A . (Refer to Notes.) FL.... Work area. One-dimensional array of size (n1).h1. VW.... Work area. One-dimensional array of size n. IP.... Work area. One-dimensional array of size n.
Comments on use Subprograms used SSL II..... BLU1,BLUX1,AMACH, MGSSL FORTRAN basic functions..... ABS,MIN0 Notes This subroutine assumes that the relatively zero pivot occurs when the absolute value of the pivot is smaller than the largest absolute value of the elements, in the coefficient matrix, multiplied by EPSZ in the LUdecomposition using the Gaussian elimination method. In such a case, the processing is discontinued with ICON = 20000. The standrd value of EPSZ is 16 u, where u is the unit round off. If the processing is to proceed at a lower pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. When solving successive systems of linear equations with the identical coefficient matrix, ISW=2 should be given for the second time and subsequently. By setting ISW = 2,LU-decomposed coefficient matrix A is bypassed so that the execution time is reduced. In this case, the IS value is the same as when ISW=1. The determinant of the coefficient matrix A can be obtained by multiplying the product of the n array elements A ( i N h+1) , i= 0,1,...,n-1 by the IS value, where h = min (h1+h1+1,n). This subroutine, by making use of band matrix characteristics, saves data storage area. In some cases, however, depending on the size of the band width, a larger data storage area may be required (including work area) than used by subroutine LAX provided for real general matrices. If that is the case, subroutine LAX may be used to save more data storage area. This subroutine is especially useful for the case where the upper and lower band widths of the coefficient matrix of order n are approximately less than n / 3, provided both the band widths are equal.
402
LBX1
Example In this example, l systems of linear equations in n unknown with the identical matrix are solved. n 100, h1 20 and h2 20.
C ** EXAMPLE ** DIMENSION A(4100),B(100),IP(100),FL(1980), * VW(100),NT1(6),NT2(4),NT3(4) DATA NT1/2HCO,2HEF,2HFI,2HCI, * 2HEN,2HT /, * NT2/2HCO,2HNS,2HTA,2HNT/, * NT3/2HSO,2HLU,2HTI,2HON/ READ(5,500)N,NH1,NH2,L WRITE(6,600)N,NH1,NH2 NT=N*MIN0(N,NH1+NH2+1) READ(5,510) (A(I),I=1,NT) M=1 ISW=1 EPSZ=1.0E-6 CALL PBM(NT1,6,A,N,NH1,NH2) READ(5,510) (B(I),I=1,N) CALL PGM(NT2,4,B,N,N,1) CALL LBX1(A,N,NH1,NH2,B,EPSZ,ISW,IS, * FL,VW,IP,ICON) WRITE(6,610) ICON IF(ICON.EQ.0) GOTO 20 WRITE(6,620) STOP 20 CALL PGM(NT3,4,B,N,N,1) M=M+1 ISW=2 IF(L.GT.M) GO TO 10 WRITE(6,630) STOP 500 FORMAT(4I4) 510 FORMAT(4E15.7) 600 FORMAT(1H1 * ///5X,22HLINEAR EQUATIONS AX=B * /5X,6HORDER=,I4 * /5X,19HSUB-DIAGONAL LINES=,I4 * /5X,21HSUPER-DIAGONAL LINES=,I4) 610 FORMAT(1H,4X,5HICON=,I5) 620 FORMAT(1H /5X, * 18H** ABNORMAL END **) 630 FORMAT(1H /5X,16H** NORMAL END **) END C ** MATRIX PRINT (REAL BAND) ** SUBROUTINE PBM(ICOM,L,A,N,NH1,NH2) DIMENSION A(1),ICOM(1) WRITE(6,600) (ICOM(I),I=1,L) M=MIN0(NH1+NH2+1,N) IE=0 IB=1 DO 10 I=1,N
J=MAX0(1,I-NH1) KIB=IB KIE=IE+MIN0(NH1+1,I)+MIN0(NH2,N-I) WRITE(6,610) I,J,(A(K),K=KIB,KIE) IE=IE+M IB=IB+M 10 CONTINUE RETURN 600 FORMAT(/10X,35A2) 610 FORMAT(/3X,1H(,I3,1H,,I3,1H), * 3(2X,E16.7)/(12X,3(2X,E16.7))) END
Subroutines PGM and PBM are used to print out a real matrix and a real band matrix, respectively. The description on subroutine PGM is shown in the example for subroutine MGSM. Method A system of linear equations (4.1) with a real general band matrix A as Ax = b are solved using the following procedure. LU-decomposition of the coefficient matrix A (Gaussian elimination method) The coefficient matrix A is decomposed into the unit lower band matrix L and the upper band matrix U. A = LU Subroutine BLU1 is used for this operation. Solving LUx = b (Forward and backward substitutions) Solving the linear equations (4.1) is equivalent to solving the next linear equations (4.3) . LUx = b (4.3) (4.2) (4.1)
This equation (4.3) is resolved into two equations (4.4) and (4.5) Ly = b Ux = y (4.4) (4.5)
and then solution is obtained using forward and backward substitutions. Subroutine BLUX1 is used for this procedure. For more information, see Reference [1], [3],[4] and [8].
403
LBX1R
ICON..
CALL LBX1R (X, A, N, NH1, NH2, FL, FU, B, IP, VW, ICON) Function Give an approximate solution ~ x to linear equations with n n real band matrix A of lower band width h1 and upper band width h2 such as Ax=b (1.1)
1 m21
1
1
m21
h1
m h1 + 1 1
1 mhl n2 1 mn n2 mn n1 1
1
mh +11
0 this subroutine refines the approximate solution by the method of iterative modification, where b is an ndimensional real constant vector and x is an ndimensional solution vetor. Befor this subroutine is called, the coeffcient matrix A must be LU-decomposed as shown is Eq. (1.2) A=LU (1.2)
h1 (n1)h1
m n n h1
mn nh
m n 1n 2
m nn 2
* * m
Note: The diagonal portion is not stored. The elements represented by ** indicate arbitrary values.
h1
nn 1
* *
h1
where L and Uare an n n unit lower band matrix and upper band matrix, repectively. Also n > h1 0 and n > h2 0. Parameters X..... Input. Approximate solution vector ~ x. Output. Iteratively refined solution vector x One-dimensional array of size n. A..... Input. Coefficient matrix A. Compressed mode for a band matirx. One-dimensional array of size n min (h1+h2+1, n) N..... Input. Order n of the coefficient matrix A. (see "Notes") NH1... Input. Lower band width h1 of the coefficient matrix A. NH2... Input. Upper band width h2 of the coefficient matirx A. FL.... Input. Matrix L Refer to Fig. LBX1R-1 One-dimensional arrary of size (n-1) (h1. (See "Notes".) FU.... Input. Matrix U Refer to Fig. LBX1R-2 One-dimensional array of size n min (h1 + h2 + 1, n)(see"Notes".) B.... Input. Constant vector b. One-dimensional array of size n. IP.... Input. Transposition vector indicating the history of exchangeing rows in partial pivoting. One-dimensional array of size n. (See "Notes".) VW.... Work area. One-dimensional arrary of size n.
Array FU u11
0
u1h unhn u22
unh nh
h u2h+1
un1n1 un-1n Note: The elements represented by ** indicate arbitrary values. h = min(h1 + h2 + 1,n) * * unn * * h h
Comments on use Subprograms used SSL II ...BLUX1, MBV, AMACH, and MGSSL FORTRAN basic functions ..ABS and MIN0
404
LBX1R
Table LBXIR-1 Condition code code 0 20000 25000 Meaning No error Coefficient matrix was singular. The convergence condition was not met because of very illconditioned coefficient matrix. N=0,N NH1,N 2,NH1<0 or NH2<0 Processing Discontinued Discontinued (Refer to "Method" for convergence condition.) Bypassed
30000
Notes This subroutine repeatedly corrects the approximate solution ~ x obtained by subroutine LBX1 and improves its accuracy. Therefore, subroutine LBX1 must have been called to obtain the approximate solution ~ x before calling this subroutine to obtain the iteratively refined solution. In this case, the parameters X, FL, FU and IP must be each assigned values of the parameters B, FL, A and IP ,of subroutine LBX1. (Refer to descriptions of subroutine LBX1.) In addition, this subroutine needs both the coefficient matrix A and the constant vector b. Therefore they must be saved before calling subroutine LBX1 so as not to lose them. For a practical use, refer to the example shown below. By specifying N = n, an estimated accuracy (relative error) for the approximate solution ~ x obtained by subroutine LBX1 can be obtained. This subroutine does not carry out iterative refinement of the solution, but only computes the relative error and outputs it to the parameter VW(1). For the accuracy estimation, refer to (4) Method c. Example An approximate solution ~ x to n-dimensional linear equations is obtained by calling subroutine LBX1, and after that the ~ x is iteratively refined by using this subroutine. Here n 50, h1 10 and h2 10.
C **EXAMPLE** DIMENSION A(1050),FL(490),FU(1050), * X(50),B(50),VW(50),IP(50), * NT1(6),NT2(4),NT3(4) DATA NT1/2HCO,2HEF,2HFI,2HCI, * 2HEN,2HT /, * NT2/2HCO,2HNS,2HTA,2HNT/, * NT3/2HSO,2HLU,2HTI,2HON/ READ(5,500) N,NH1,NH2 WRITE(6,600) N,NH1,NH2 NT0=MIN0(NH1+NH2+1,N)
NT=N*NT0 READ(5,510) (A(I),I=1,NT) CALL PBM(NT1,6,A,N,NH1,NH2) READ(5,510) (B(I),I=1,N) CALL PGM(NT2,4,B,N,N,1) DO 10 I=1,N 10 X(I)=B(I) DO 20 I=1,NT 20 FU(I)=A(I) K=50 CALL LBX1(FU,N,NH1,NH2,X,0.0,1,IS,FL, * VW,IP,ICON) WRITE(6,610) ICON IF(ICON.GE.20000) STOP CALL LBX1R(X,A,N,NH1,NH2,FL,FU,B,IP, * VW,ICON) WRITE(6,620) ICON IF(ICON.GE.20000) STOP CALL PGM(NT3,4,X,N,N,1) DET=IS IC=1 DO 30 I=1,N DET=DET*FU(IC) 30 IC=IC+NT0 WRITE(6,630) DET STOP 500 FORMAT(3I4) 510 FORMAT(4E15.7) 600 FORMAT(1H1 * /6X,21HLINEAR EQUATIONS AX=B * /6X,6HORDER=,I4 * /6X,19HSUB-DIAGONAL LINES=,I4 * /6X,21HSUPER-DIAGONAL LINES=,I4) 610 FORMAT(1H ,5X,13HICON OF LBX1=,I4) 620 FORMAT(1H ,5X,14HICON OF LBX1R=,I6) 630 FORMAT(1H ,5X,12HDETERMINANT=,E15.7) END
Subroutines PBM and PGM are used only to print out a band matrix and a real general matrix, respectively. The descriptions on those programs are shown in the examples of the subroutines LBX1 and MGSM, respectively. Method Given an approximate solution ~ x to the linear equations Ax = b the solution is iteratively refined as follows: Principale of iterative refinement The iterative refinement is a method to obtain a successively improved approximate solution x (s+1) to the linear equations (4.1) through use of the following equations starting with x(1) = x : r ( s) = b Ax ( s ) Ad ( s ) = r ( s ) x ( s+1) = x ( s) + d ( s ) s = 1,2, (4.2) (4.3) (4.4) (4.1)
405
LBX1R
where x(s) is the s-th approximate solution to equation (4.1). If Eq. (4.2) is accurately computed, a refined solution of x(1) is obtained. If, however, the condition of coefficient matrix A is not suitable, no improved solution is obtained. (See "Iterative refinement of a solution" in Section 3.4.) Procedure performed in this subroutine Suppose that the first approximate solution x(1) has already been obtained by subroutine LBX1. This subroutine repeats the following steps: The residual r(s) is computed by using Eq. (4.2). Subroutine MBV is used for this operation. The correction d(s) is obtained next by using Eq. (4.3). Subroutine BLUX1 is used for this operation. Finally, the modified approximate solution x(s+1) is obtained by using Eq. (4.4). The convergence of iteration is tested as follows: Considering u as a unit round off, the iteration refinement is assumed to converge if, at the s-th iteration step, the following relationship is satisfied. d ( s)
The obtained x(s+1) is then taken as the final solution. However, if the relationship. d ( s) d ( s 1)
( s 1) 1 d > ( s) 2 d
results, this indicates that the condition of the coefficient matrix A is not suitable. The iteration refinement is assumed not to converge, and consequently the processing is terminated with ICON = 25000. Accuracy estimation for approximate solution Suppose that the error for the approximate solution x(1) is e(1) (=x(1)-x ), its relative error is represented by e (1) x ( s ) . If this iteration method converges e(1) is assumed to be almost equal to d(1) .Therefore the relative error for the approximate solution is estimated by d (1) x (1) (See "Accuracy estimation for approximate solution" in Section 3.4.) For further details, refer to References [1], [3] and [5].
x ( s +1)
< 2u
(4.5)
406
LCX
A22-15-0101 LCX,DLCX
A system of linear equations with a complex general matrix (Crout's method).
Table LCX-1 Condition codes Code 0 20000 Meaning No error Either all of the elements of some row were zero or the pivot became relatively zero. It is highly probable that the coefficient matrix is singular. K<N, N<1, EPSZ<0.0 or ISW 1,2 Processing Discontinued
CALL LCX (ZA, K, N, ZB, EPSZ, ISW, IS ZVW, IP,ICON) Function This subroutine solves a system of linear equations, as shown in (1.1) using the Crout's method. Ax =b (1.1)
30000
Bypassed
A is an n n non-singular complex general matrix, b is an n-dimensional complex constant vector, and x is an n-dimensional solution vector. n1. Parameter ZA .... Input. Coefficient matrix A. The contents of A are overridden after operation. ZA is a complex two-dimensional array, ZA (KA, N). K .... Input. Adjustable dimension of the array ZA ( N) N .... Input. Order n of the coefficient matrix A. ZB .... Input. Constant vector b. Output. Solution vector X. ZB is a complex one-dimensional array of size n. EPSZ .... Input. Tolerance for relative zero test of pivots in decomposition of A ( 0.0). If EPSZ is 0.0, a standard value is used. (Refer to Notes.) ISW .... Input. Control information When l ( 1) systems of linear equations with the identical coefficient matrix are to be solved, ISW can be specified as follows: ISW = 1 .... The first system is solved. ISW = 2 .... The 2nd to l-th systems are solved. However, only parameter B is specified for each constant vector b of the systems of equations, with the rest unchanged. (Refer to Notes.). IS .... Output. Information for obtaining the determinant of the matrix A. If the n elements of the calculated diagonal of array ZA are multiplied by IS, the deyerminant is obtained. ZVW .... Work area. ZVW is a complex onedimensional array of size n. IP .... Work area. IP is a one-dimensional array of size n. ICON .. Output. Condition code. Refer to Table LCX1.
Comments on use Subprograms used SSL II ..... CLU, CLUX, AMACH, CSUM, MGSSL FORTRAN basic functions ..... REAL, AIMAG, ABS Notes If EPSZ is set to 10-s, this value has following meaning: while performing the LU-decomposition by Crout's method, if the loss of over s significant digits occured for both real and imaginary parts of the pivot, the LU-decomposition should be discontinued with ICON = 20000 regarding the pivot to be relatively zero. Let u be the unit round off, then the standard value of EPSZ is 16u. If the processing is to proceed at a low pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. When solving successive systems of linear equations with the idenficial coefficient matrix, computation can be performed by setting ISW = 2 after the first system of equations. By setting ISW = 2, the LU decomposition of the coefficient matrix A is bypassed so the computation time is reduced. In this case, the value of IS is the same as when ISW = 1. Example l systems of linear equations in n unknow with the identical complex coefficient matrix are solved. n 100.
C **EXAMPLE** DIMENSION ZA(100,100),ZB(100),ZVW(100),IP(100) COMPLEX ZA, ZB, ZVW,ZDET READ(5,500) N,L READ(5,510) ((ZA(I,J), I=1, N), J=1, N) WRITE(6.600)N,((I,J,ZA(I,J),J=1,N),I=1,N) M=1 ISW=1 EPSZ=1.0E-6 10 READ(5,510) (ZB(I),I=1,N) WRITE(6,610) (I,ZB(I),I=1,N) CALL LCX(ZA,100,N,ZB,EPSZ,ISW,IS,ZVW,IP, * ICON) WRITE(6,620) ICON IF(ICON.GE.20000) STOP
407
LCX
WRITE(6,630) (I,ZB(I),I=1,N) IF(L.EQ.M)GOTO 20 M=M+1 ISW=2 GOTO 10 20 ZDET=CMPLX(FLOAT(IS),0.0) DO 30 I=1,N ZDET=ZDET*ZA(I,I) 30 CONTINUE WRITE(6,640) ZDET STOP 500 FORMAT(2I5) 510 FORMAT(5(2F8.3)) 600 FORMAT(1H1,10X,20H** COMPLEX MATRIX ** * /12X,6HORDER=,I5/(3X,2(1H(,I3,1H,,I3, * 1H),2E15.8,2X))) 610 FORMAT(///10X,23HCOMPLEX CONSTANT VECTOR, * /(5X,3(1H(,I3,1H),2E15.8,2X))) 620 FORMAT(1H0,10X,15HCONDITION CODE=, I5) 630 FORMAT(1H0,10X,15HCONDITION VECTOR, * /(5X,3(1H(,I3,1H),2E15.8,2X))) 640 FORMAT(///10X,2HDTERMINANT OF MATRIX, * 2E15.8) END
LU decomposition of the coefficient matrix A (Crout's method) The coefficient matrix A is decomposed into a lower triangular matrix L and a unit upper trangular matrix U. To reduce the rounding error, partial pivoting is performed in the decomposition process. PA = LU (4.2)
P is the permutation matrix which performs the row exchanges required in partial pivoting. Subroutine CLU is used for this operation. Solving LUX = Pb (forward and backward substitution) To solve equation (4.1) is equivalent to solving the next system of linear equations LUX = Pb (4.3)
Method A system of linear equations (4.1). Ax = b is solved using the following procedure. (4.1)
Equation (4.3) is resolved into two equations Ly = Pb Ux = y Then the solution is obtained using forward substitution and backward substitution. Subroutine CLUX is used for these operations. For more information, see References [1], [3], and [4]. (4.4) (4.5)
408
LCXR
A22-15-0401 LCXR,DLCXR
Iterative refinement of the solution to a system of linear equation with a complex general matrix
CALL LCXR(ZX, ZA, K, N, ZFA, ZB, IP, ZVW, ICON) Function When an approximate solution ~ x is given to linear equations with an n n complex matrix, Ax = b (1.1)
u u
1
1n 2n
1 un-1,n
this subroutine refines the approximate solution by the method of iterative modificton, where b is an ndimensional complex constant vector and x is an ndimensional solution vector. Prior to calling this subroutine, the coefficient matrix A must be LU-decomposed as shown in Eq.(1.2), PA = LU (1.2)
ln 1, n 1 ln, n 1 ln n
u u
1n 2n
N K
ln 1 ln 2
Fig. LCXR-1 Storing method for each elements of L and U in array ZFA Table LCXR-1 Condition code
where L and U are n n lower triangular matrix and unit upper triangular matrix respectively, and P is a permutation matrix which exchanges rows of the matrix A required in partial pivoting. Also, n1. Parameters ZX .... Input. Approximate solution vector ~ x. Output. Iteratively refined solution vector x. Complex one-dimensional array of size n. ZA .... Input. Coefficient matrix A. Complex two-dimensional array, ZA (K,N). K .... Input. Adjustable dimension of the array ZA, ZFA ( N) N .... Input. Order n of the coefficient matrix A. (See Comments on use.) ZFA .... Input. Matrices L and U. Refer to Fig. LCXR-1. Complex two-dimensional array, ZFA (K,N). (See Comments on use.) ZB .... Input. Constant vector b. Complex one-dimensional array of size n. IP .... Input. Transposition vector which indicates the history of exchanging rows required in partial pivoting. One dimensional array of size n. (See Comments on use.) ZVW .... Work area. Complex one-dimensional array of size n. ICON .. Output. Condition code. See Table LCXR-1.
Meaning No errors Coefficient matrix was singular. Convergence condition was not met because of very illconditioned coefficient matrix.
Processing Discontinued Discontinued (Refer to the paragraph "Method" for the convergence condition.) Bypassed
30000
Comments on use Subprograms used SSL II ... CLUX,MCV,AMACH,CSUM,MGSSL FORTRAN basic function ... REAL,AIMAG,ABS,IABS Notes This subroutine iteratively corrects the approximate solution ~ x obtained by the subroutine LCX, and refines its precision. Therefore , the subroutine LCX must be called in advance to obtain the approximate solution ~ x prior to calling this subroutine to obtain the refined solution. In this case, the parameters ZX, ZFA and IP must be each assigned the outputs of subroutine LCX that was called prior to this subroutine. In addition, this subroutine requires both the coefficient matrix A and the constant vector b, so that they must be saved before calling subroutine LCX in order not to lose them. Refer to the example below for detail. By specifying N = - n, an estimated accuracy (relative error) for the approximate solution ~ x obtained in the
409
LCXR
subroutine LCX can be obtained. When specified, this subroutine does not perform iterative refinement for the solution, but only computes a relative error and outputs it to the parameter ZVW(1). For details about the accuracy estimation, refer to the following paragraph "Method". Example An approximate solution ~ x to n-dimensional linear equations is obtained first by calling the subroutine LCX and after that it is iteratively refined by using this subroutine. Here n100.
C **EXAMPLE** DIMENSION ZA(100,100),ZFA(100,100), * ZX(100),ZB(100),ZVW(100),IP(100) COMPLEX ZA,ZFA,ZX,ZB,ZVW,ZDET READ(5,500) N IF(N.LE.0) STOP READ(5,510) ((ZA(I,J),I=1,N),J=1,N) WRITE(6,600) N,((I,J,ZA(I,J),J=1,N),I=1,N) READ(5,510) (ZB(I),I=1,N) WRITE(6,610) (I,ZB(I),I=1,N) DO 10 I=1,N ZX(I)=ZB(I) DO 10 J=1,N ZFA(I,J)=ZA(I,J) 10 CONTINUE K=100 CALL LCX(ZFA,K,N,ZX,0.0,1,IS,ZVW,IP, * ICON) WRITE(6,620) ICON IF(ICON.GE.20000) STOP CALL LCXR(ZX,ZA,K,N,ZFA,ZB,IP,ZVW, * ICON) WRITE(6,630) ICON IF(ICON.GE.20000) STOP WRITE(6,640) (I,ZX(I),I=1,N) ZDET=IS DO 20 I=1,N ZDET=ZDET*ZFA(I,I) 20 CONTINUE WRITE(6,650) ZDET STOP 500 FORMAT(I3) 510 FORMAT(4E15.7) 600 FORMAT(1H1,5X,18HCOEFFICIENT MATRIX * /6X,6HORDER=,I5/(6X,2(1H(,I3,1H,,I3, * 1H),2E15.8,1X))) 610 FORMAT(1H ,5X,15HCONSTANT VECTOR * /(6X,3(1H(,I3,1H),2E15.8))) 620 FORMAT(1H ,5X,12HICON OF LCX=,I5) 630 FORMAT(1H ,5X,13HICON OF LCXR=,I5) 640 FORMAT(1H ,5X,17HIMPROVED SOLUTION * /(6X,3(1H),I3,1H),2E15.8,1X))) 650 FORMAT(1H ,5X,12HDETERMINANT=,2E15.8) END
Method Given an approximate solution, ~ x , to the linear equations Ax = b the solution is iteratively refined as follows: Principle of iterative refinement The iteratile refinement is a method to obtain a successively improved approximate solution x(s+1) to the linear equations(4.1) through use of the following equations starting with x(1)= ~ x r(s)=b Ax(s) Ad(s)=r(s) x(s+1)=x(s)+d(s) S=1,2,.... (4.2) (4.3) (4.4) (4.1)
where x(s) is the s-th approximate solution to equation (4.1). If Eq. (4.2) is accurately computed, an refined solution of the approximate solution x(1) is numerically obtained. If the conditions of coeffcient matrix A are not suitable, however, no improved solution is obtained. (See Iterative refinement of a solution in Section 3.4.) Procedure performed in this subroutine Suppose that the first approximate solution x(1) has already been obtained by the subroutine LCX. Then this subroutine repeats the following steps: The residual r(s) is computed by using Eq.(4.2). The residual r(s) is computed by using Eq.(4.2) this is done by calling subroutine MCV. The correction d(s) is obtained next by using Eq.(4.3) and calling subroutine CULX. Finally the modified approximste solution x(s+1) is obtained by using Eq.(4.4). The iteration convergence is tested as follows. Considering u as a unit round off the itereative refinement is assumed to converge if, st the s-th iteration step, the fhe following relationship is satisfied d ( s)
x ( s +1)
< 2u
(4.5)
The obtained x(s+1) is then taken as a final solution. However, if the relation, d (s) x ( s +1)
( s 1) 1 d > (s) 2 x
results, this indicates that the condition of the coefficient matrix A are not suitable. The iterative refinement is assumed not to converge, and consequently the processing is terminated with ICON=25000. Accuracy estimation for approximate solution Suppose the error for the approximate solution 410
LCXR
x(1) is e(1) (=x(1) x), its relative error is represented by e (1) x (1) . If this iteration method converges, e(1) is assumed to be almost equal to d(1). The relative error for the approximate solution is therefore
estimated by d (1)
x (1 )
(See "Accuracy estimation for approximate solution" in Section 3.4.) For further details, see References [1], [3] and [5]
411
LDIV
CALL LDIV (FA, N, ICON) Function The inverse matrix A-1 of an n n positive-definite symmetric matrix A given in decomposed form A=LDLT is computed.
A 1 = ( LT ) D 1 L 1 1
Comments on use Subprograms used SSL IIMGSSL FORTRAN basic functionsnone Notes Prior to calling this subroutine, LDLT-decomposed matrix must be obtained by subroutine SLDL and must be input as the parameter FA to be used. (Refer to the example). In this routine, the diagonal elements of the array D must be given as D-1. D-1 is output by the subroutine SLDL. The subroutine LSX should be used for solving a system of linear equations. Solving a system of linear equations by first obtaining the inverse matrix should be avoided since more steps of calculation are required. This subroutine should be used only when the inverse matrix is inevitable. Example The inverse of an n n positive symmetric matrix is obtained. n 100
c 10 **EXAMPLE** DIMENSION A(5050) READ(5, 500)N IF(N .EQ. 0) STOP NT=N*(N+1)/2 READ(5, 510) (A(I), I=1, NT) WRITE(6, 620) L=0 LS=1 DO 20 I=1, N L=L+1 WRITE(6, 600) I, (A(J), J=LS, L) LS=L+1 CALL SLDL(A, N, 0.0, ICON) IF(ICON .GE. 20000) STOP CALL LDIV(A, N, ICON) WRITE(6, 630) L=0 LS=1 DO 30 I=1, N L=L+1 WRITE(6, 600) I, (A(J), J=LS, L) LS=L+1 WRITE(6, 610) ICON GOTO 10 FORMAT(I5) FORMAT(5E5.0) FORMAT(1H , I5/(10X, 5E16.8)) FORMAT(/10X, 5HICON=, I5) FORMAT(/10X, 12HINPUT MATRIX) FORMAT(/10X, 14HINVERSE MATRIX) END
(1.1)
L and D are, respectively, an n n unit lower triangular and a diagonal matrices. n1. Parameters FA Input. Matrices L and D-1. See Fig. LDIV-1. Output. Inverse A-1. FA is a one-dimensional array of size n(n+1)/2 that contains L and D-1 in the compressed mode for symmetric matrices. N. Input. Order n of the matrices L and D. ICON. Output. Condition code. See Table LDIV-1.
Diagonal matrix D
d11 d22
Matrix D +(L I)
1 1 d11 1 l21 d22
Array FA
d11
1
0
dnn
0
lnn1
1 dnn
l 21
d 22
1
20
ln1
n (n + 1)
ln 1
l21 1
0 0
lnn 1
ln1
30
ln n 1
d nn
1
Note: The diagonal and lower triangular portions of the matrix D-1+(L-I) are stored in the one-dimensional array FA in the compressed mode for symmetric matrices. Fig. LDIV-1 Storage of matrices L and D Table LDIV-1 Condition codes Code 0 10000 30000 Meaning No error Matrix was not a positivedefinite. N<1 Processing Continued Bypassed
412
LDIV
Method Given the LDLT decomposed matrices L and D of an n n positive-definite symmetric matrix A, the inverse A-1 is computed. Since A = LDLT (4.1)
~ Since lii =1,(4.5) can be rewritten with respect to lij as shown in (4.6).
i 1 ~ ~ lij = ij lik lkj k= j
(4.6)
Then, the inverse A-1 can be represented using (4.1) as follows: The inverse of L and D are computed and then the inverse A-1 is computed as (4.2). A1 = ( LT ) D 1 L1 = ( L1 ) D 1 L1
1 T
~ ~ Then considering that lii = 1 and l jj = 1, the elements ~ lij of the ith row (i=2,,n) of L-1 can be obtained successively using ~ lij = lij
i 1
(4.2)
k = j +1
(4.7)
Let L and D-1 be represented as shown in Eq. (4.3) for the following explanation. L = lij , D 1 = diag(d -1 i )
( )
(4.3)
( )
(4.8)
Calculating L-1 Since the inverse L-1 of a unit lower triangular matrix L is also a unit lower triangular matrix, if we represent L-1 by
(4.9)
ij ) L1 = (~
(4.4)
~ ~ of the ith row Considering that lii = 1 , the elements a ij (i = 1,,n) of A-1 are successively obtained using ~ = d 1~ a ij i lij +
then the Eq. (4.5) is obtained based on the relation LL-1=I. 1, i = j ~ lik lkj = ij , ij = k =1 0, i j
n
(4.5)
k = i +1
lki d k1lkj
j = 1,..., i
(4.10)
The precision of the inner product calculation in (4.7) and (4.10) has been raised to minimize the effect of rounding errors. For further information, see Reference [2].
413
LDLX
Comments on use Subprograms used SSL II .... MGSSL FORTRAN basic functions......None Notes Notes that the diagonal elements of D-1 instead of D are required in this subroutine. A system of linear equations can be solved by calling this subroutine after the subroutine SLDL. D-1 is output by subroutine SLDL. However, subroutine LSX can be usually called to solve such equations in one step. For a positive-definite symmetric band matrix, the subroutine BDLX processes faster than this subroutine because the operation for elements out of the band is omitted. Example A system of linear equations is solved after first LDLT decomposition of the nn coefficient matrix using subroutine SLDL. n 100.
C **EXAMPLE** DIMENSION A(5050),B(100) 10 READ(5,500)N IF(N.EQ.0)STOP NTOT=N*(N+1)/2 READ(5,510)(A(I),I=1,NTOT) WRITE(6,640) L=0 LS=1 DO 20 I=1,N L=L+1 WRITE(6,600)I,(A(J),J=LS,L) 20 LS=L+1 CALL SLDL(A,N,1.0E-6,ICON) WRITE(6,610)ICON IF(ICON.GE. 20000)STOP READ(5,510)(B(I),I=1,N) CALL LDLX(B,A,N,ICON) WRITE(6, 610) ICON DET=A(1) L=1 DO 30 I=2, N L=L+I 30 DET=DET*A(L) DET=1.0/DET WRITE(6, 620) (B(I), I=1, N) WRITE(6, 630) DET GOTO 10 500 FORMAT(I5) 510 FORMAT(5E5.0) 600 FORMAT(1H ,I5/(10X,5E16.8)) 610 FORMAT(/10X,5HICON=, I5) 620 FORMAT(/10X,15HSOLUTION VECTOR * //(10X,5E16.8)) 630 FORMAT(/10X, * 34HDETERMINANT OF COEFFICIENT MATRIX=, * E16.8) 640 FORMAT(/10X,12HINPUT MATRIX) END
CALL LDLX (B, FA, N, ICON) Function This subroutine solves a system of linear equations LDLT x = b (1.1)
Where L and D are, respectively, nn unit lower triangular and diagonal matrices, b is an n-dimensional real constant vector, and x is an n-dimensional solution vector. n1. Parameters B.. Input. Constant vector b. Output. Solution vector x. One-dimensional array of size n. FA. Input. Matrices L and D1. See Fig. LDLX-1. One-dimensional array of size n(n+1)/2. N. Input. Order n of the matrices L and D. ICON.. Output. Condition code. See Table LDLX-1.
Diagonal matrix D
d11 d 22
Matrix {D1+(LI)}
d
1 11 1 l 21 d 22
Array FA
d11
1
0
ln 1
l
l 21
d 22
1 nn
1
nn 1
n ( n + 1)
ln1
l l
n1
l 21 1
nn1
ln n 1
1 d nn
Note: The diagonal and lower triangular portions of the matrix D-1+(L-I) are contained in the one-dimensional array A in the compressed mode for symmetric matrices. Fig. LDLX-1 Storage method of matrices L and D-1 Table LDLX-1 Condition codes Code 0 10000 30000 Meaning No error The coefficient matrix was not positive-definite. N<1 Processing Discontinued Bypassed
414
LDLX
Method To solve a system of linear equations (4.1) is equivalent to solve equations (4.2) and (4.3). LDLT x = b Ly = b LT x = D 1 y (4.1) (4.2) (4.3)
where, L=(lij), yT=(y1,,yn), bT=(b1,,bn) Solving LTx =D-1y (backward substitution) LT =D-1y can be consecutively solved using equation (4.5). xi = yi di1
k = i +1
lki xk ,
i = n,...,1
(4.5)
solving Ly=b (forward substitution) Ly=b can be consecutively solved using equation (4.4). yi = bi
where, D-1 = diag(di -1), xT=(x1,,xn). For more information, see Reference [2].
k =1
lik yk ,
i 1
i = 1,..., n
(4.4)
415
LESQ1
CALL LESQ1 (X, Y, N, M, W, C, VW, ICON) Function Given n observed data (x1,y1), (x2,y2),, (xm,yn) and a weight function w(xi ) i=1, 2, .., n, this subroutine obtains polynomial least squares approximations. Let a polynomial of degree m be ym ( x ) as y m ( x ) = c0 + c1 x + + cm x
VW .... ICON ..
c0,c1,, cij Then, m < k,elements C(I+1), I=m+1,, k, are set 0.0. Work area. One dimensional array of size 7n. Output. Condition code. See Table LESQ1-1.
Table LESQ1-1 Condition codes Code 0 30000 Meaning No error n < 2,k > n-1 or there was a negative value in w(xi). Processing Bypassed
(1.1)
this subroutine determines coefficients c0, c1,, cm such that (1.2) is minimized.
2 m = w( xi ) y i y m ( x i ) n i =1
(1.2)
Comments on use Subprograms used SSL II .. MGSSL, AMACH FORTRAN basic functions ..... IABS, DABS, DLOG, FLOAT, and AMAX1 Notes Use of single or double precision subroutines The degree m of the approximation polynomial to be output may be different between single and double precision subroutines for some data. Therefore, it is preferable to use a double precision subroutine when handling a large number of observed data. Specifying weight function values w(xi ) When observed data have nearly the same order, w(xi )=1.0,i= 1,2,,n may be used. But, when they are ordered irregularly, the weight function should be specified as w(xi )=1/yi 2 (when yi =0 specify, w(xj)=1.0). The number of discrete points, n should be as high as possible compared to the upper limit k. Theoretically, n, is recommended to be equal to or greater than 10k. Example The number (n) of discrete points, the discrete points xi , and the observed values yi ,i=1,2,,n are input, then the coefficients of the least squares approximation polynomial are determined. Where 10 n 50,and w(xi ) = 1 (i = 1,2,,n).
C **EXAMPLE** DIMENSION X(50), Y(50), W(50), C(6), VW(350) READ (5,500) N READ (5,510) (X(I), y (I), I=1, N) WRITE (6,600) (I, X(I), Y(I), I=1, N) DO 10 I=1, N 10 W (I)=1.0 M=5
(1.3)
When (1.3) is minimized, m is considered the optimum degree for the least squares approximation. Where, 0 k < n-1. Also, the weight function w(xi ) must satisfy w(x i ) 0 n 2. i = 1,2,
, n
(1.4)
Parameters X .... Input. Discrete points xi , One-dimensional array of size n. Y .... Input. Observed data yi . One-dimensional array of size n. N .... Input. Number (n) of discrete points. M .... Input. Upper limit k of the degree of the approximation polynomial to be determined. If M = -K (K > 0), the approximation polynomial of degree k is unconditionally obtained. Output. The degree k of the approximation polynomial that was determined. Hence, when M = -k, output M is always equal to k. W .... Input. Weight function values w(xi ). One-dimensional array of size n. C .... Output. Coefficient ci of the determined approximation polynomial. C is a onedimensional array of size k+1. Letting the output value of M be m (0 m k), the coefficients are stored in the following order:
416
LESQ1
MI=M CALL LESQ1(X,Y,N,M,W,C,VW,ICON) WRITE(6,610) MI,ICON IF(ICON.EQ.30000)STOP M1=M+1 WRITE(6,620) M,(I,C(I),I=1 M1) STOP 500 FORMAT(I5) 510 FORMAT(2F10.0) 600 FORMAT(1H1//10X,10HINPUT DATA// * 20X,3HNO.,10X,1HX,17X,1HY// * (20X,I3,3X,E15.7,3X,E15.7)) 610 FORMAT(10X, * 29HTHE UPPER LIMIT OF THE DEGREE, * 5X, I5/10X, 5HICON=,I5) 620 FORMAT(//10X, * 20HTHE RESULTANT DEGREE, 14X, I5/ * 10X, 26HTHE RESULTANT COEFFICIENTS/ * (20X,2HC(,I2,2H)=,E15.7)) END
= 0 d jk 0
, jk , j=k
(4.4)
then, elements of the coefficient matrix of the normal equations become zero except the diagonal elements, so b(j m ) = bj = j j where j = d jj = w( x i ) Pj ( x i )
n i =1
(4.5)
Thus, bj(m) can be obtained from (4.5). The {Pj(x)} which satisfies (4.4) can be obtained from the following recurrence formula Pj +1 ( x ) = x j+1 Pj ( x ) j Pj 1 ( x ) P0 ( x ) = 1 , P1 ( x ) = 0
n
Method Least squares approximation polynomial Assume that observed data yi , i=1,2,,n, are given for discrete points xi , i=1,2,,n, and they include some errors. Then, the least squares approximation polynomial for the observed data is the polynomial of degree m, ym ( x ) which minimizes
2 m = w( xi ) yi ym ( xi ) n i =1
j = 0,1,
}
2
j+1 = w( xi ) xi Pj ( xi )
i =1
j = 0,1, 0 , j = 0 j = j j 1 , j = 1,2,
(4.6)
(4.1)
(4.2)
Where Pj(x) is a polynomial of degree j(explained later). To determine bj(m), ym(x) in (4.2) is substituted into (4.1), then we take the partial derivative of m2 in (4.1) with respect to bj(m) and set it equal to zero, thereby obtaining. k = 0,1, , m d jk b(jm) = k j=0 n where d jk = w( xi )Pj ( xi )Pk ( xi ) i =1 n k = w(xi ) yi Pk ( xi ) i =1
m
Selecting the optimum degree In obtaining the least squares approximation polynomial, selecting an optimum degree is of importance. This subroutine selects the optimum degree using a quantity AIC as the means to evaluate the optimum condition of degree m. Letting m2 be
n m 2 m = w( xi ) y i b j Pj ( x i ) j=0 i =1 2
(4.7)
(4.8)
(4.3)
Equation (4.3) is a system of m+1 linear equations for the m+1 unknown bj(m). This system is called the normal equations and bj(m) can be obtained by solving the system. Now, if polynomials {Pj(x)} in (4.3) are chosen as that
In general, the smaller value of AIC shows the more optimum degree. Thus, this subroutine determines the optimum value which will minimize AIC within the range, 0mk, then output a least squares approximation polynomial of that degree. The output polynomial is, using {bj} and {Pj(x)}(j=0,1,,m), expressed as y m ( x ) = bj Pj ( x ) = c0 + c1 x + c2 x 2 + +c m x m
m j =0
(4.9)
in the standard form of polynomials with coefficients c0, c1, c2,, cm. For more details, see Reference [46] pp. 228 to 250.
417
LMINF
CALL LMINF (A, B, FUN, EPSR, MAX, F, ICON) Function Given a real function f(x) with a variable, the local minimum point x* and the function value f(x*) are obtained in interval [a,b], where f(x) is assumed to have up to the second continuous derivative. Parameters A.. Input. End point a of interval [a,b]. Output. Minimum point x*. B.. Input. End point b of interval [a,b]. FUN Input. Name of function subprogram which calculates f(x). The form of subprogram is as follows: FUNCTION FUN (X) Parameters X Input. Variable x. Substitute values of f(x) in function FUN. (See Example.) EPSR.. Input. Convergence criterion (0.0). The default value is assumed if 0.0 is specified. (See Comments on Use.) MAX.. Input. The upper limit (0) of number of evaluations for the function. (See Comments on use.) Output. The number (>0) of actual evaluations. F.. Output. The value of function f(x*). ICON.. Condition code. (See Table LMINF-1.)
Table LMINF-1 Condition codes Code 0 10000 Meaning No error. The convergence condition has not been satisfied within the specified function estimation count. EPSR < 0.0 or MAX=0. Processing The last values obtained are stored in A and F.
Notes An EXTERNAL statement is necessary to declare the subprogram name correspond to parameters FUN in the calling program. EPSR In this subroutine, the convergence condition is checked as follows: During iteration, if x1 x2 max(10 . ,~ x ) EPSR is satisfied at two points x1, and x2, between which x* ~ is assumed to be minimum point x* exists, point x and iteration is stopped, where ~ x = x1 for f(x1)f(x2) ~ and x = x2 for f(x1)>f(x2). Since f(x) is assumed to be approximately a quadratic function in the vicinity of point x*, it is appropriate to specify EPSR as EPSR u , where u is the unit round off to obtain value x* as accurate as the rounding error. The default value of EPSR is 2 u . MAX The number of function evaluation is incremented by one every time f(x) is evaluated. This is the same as the call count of subprogram FUN. The number depends on characteristics of function f(x), interval [a,b], and convergence criterion. Generally, when an appropriate interval [a,b] is specified and the default value is used for the convergence criterion, it is adequate to specify MAX = 400. Even if the convergence condition is not satisfied within the specified evaluation count and the subroutine is returned with ICON = 10000, iteration can be resumed by calling this subroutine again. In this case, the user must specify a negative value as the additional evaluation count in the parameter MAX and retain other parameters unchanged. A and B If there is only one minimum point of f(x) in interval [a,b], this subroutine obtains the value of the point within the specified error tolerance. If there are several minimum points, it is not guaranteed to which point the result converges. This means that it is desirable to set a and b, end points of the interval containing minimum point x*, in the vicinity of minimum point x*. Example Given the following function, f ( x ) = x 4 4 x 3 6 x 2 16 x + 4 a minimum value in interval [-5, 5] is obtained, assuming that the default value is used for the convergence criterion.
30000
Bypassed.
Comments on use Subprograms used SSL II AMACH, MGSSL FORTRAN basic functions ABS, SQRT, AMAX1
418
LMINF
**EXAMPLE** EXTERNAL FUN A=-5.0 B=5.0 EPSR=0.0 MAX=400 CALL LMINF (A,B,FUN,EPSR, * MAX, F, ICON) WRITE(6,600)ICON,MAX,A,F 600 FORMAT(1H1//1X,5HICON=,I6,2X, * 4HMAX=,I5,2X,2HA=,E15.7,2X, * 2HF=,E15.7) STOP END C OBJECTIVE FUNCTION FUNCTION FUN (X) FUN= (((X-4.0)*X-6.0)*X-16.0)*X+4.0 RETURN END
is satisfied, assumes x1 to be x*, f1 to be f(x*), and sets ICON=0, then stops processing. 5) If f1fhf2,, assumes x1= xh, and returns to 2). However, if the convergence condition xh x2 max 10 . , x2
is satisfied, assumes x2 to be x* and f2 to be f(x*), and sets ICON=0, then stops processing. 6) If f1<fh>f2, assumes x2= xh (for f1 f2)or x1= xh (for f1>f2), and returns to 2). However, if the convergence condition x1 x h max(10 . , x1 ) (for f1 f2 ) or x2 xh max(10 . , x2 )
Method Given a single variable real function f(x) and interval [a,b] in which the minimum value is to be obtained, minimum point x* and the value of function f(x*) are obtained using the quadratic interpolation. It is assumed that -f(x) is unimodal in interval [a,b]. If -f(x) is not unimodal, this subroutine obtains one of the minimum points. The processing comprises two steps: Obtains two points x1 and x2 between which point x* exists. Based on function values f(x1), f(x2) and f(xh) at points x1 and x2, and middle point xh, determines the minimum point using a quadratic interpolation formula which passes through the points (x1,f(x1)), (xh,f(xh)), and (x2,f(x2)). There steps are repeated until the convegence condition is satisfied in the interval containing the minimum point. Calculation procedures For simplicity, let f(x1), f(x2)be denoted as f1, f2, Procedure step 1 (determination of points x1 and x2) 1) Assumes the smaller of a and b to be x1, the larger to be x2, and =max (EPSR, 2 u .) 2) Determines middle point xh in interval [x1,x2] from xh=( x1+ x2)/2 3) If f1>fh<f2, computes h=x2-xh and proceeds to step2. 4) If f1fhf2, assumes x2=xh, and returns to
(for
*
f1 > f 2 )
is satisfied, assumes x1 or x2 to be x , f1 or f2 to be f(x*), and sets ICON=0, then stops processing. Procedure step2 7) Obtains minimum point xm using the quadratic interpolation by means of following calculation: h h = ( f 2 f 1 ) ( f 1 2 f h + f 2 ) 2 x m = x h h 8) If the convergence condition h max 10 . , xh 2
is satisfied, proceeds to 9); otherwise, assumes x1 = x m (for f m f h ) or x1=xh and x h = x m (for f m f h ) , and obtains two points between which point x* exists, then returns to 7). 9) For the following two points in the vicinity of point ~ x = x h ( for f m f h ) which x = xm ( for f m < f h ) or ~ minimizes the function value, ~ x1 = ~ x + max(10 . ,~ x ) 2 ~ x =~ x max 10 . ,~ x 2
2
if f ( ~ x1 ) < min( f m , f h ) and f (~ x2 ) < min( f m , f h ) ~ ) to be f(x*), ~ to be x* and f( x are satisfied, assumes x and sets ICON=0, then stops processing. If these conditions are not satisfied, obtains two points between which point x* exists, then return to 7).
419
LIMING
Table LMING-1 Condition codes Code 0 10000 Meaning No error. The convergence condition has not been satisfied within the specified function evaluation count. The value of EPSR is too small. Processing The last values obtained are stored in A and F. Bypassed. (The last values obtained are stored in A and F.) Bypassed.
Function Given a single variable real function f(x) and its derivative g(x), the local minimum point x* and the function value f(x*) are obtained in interval [a, b], where f(x) is assumed to have up to the third continuous derivative. Parameters A ........ Input. End point a of interval [a, b]. Output. Minimum point x*. B ........ Input End point b of interval [a, b]. FUN ... Input. Name of function subprogram which calculates f(x). The form of subprogram is as follows: FUNCTION FUN (X) Parameters X ... Input. Variable x. Substitute values of f(x) in function FUN. (See Example.) GRAD .. Input. Name of function subprogram which calculates g(x). The form of subprogram is as follows: FUNCTION GRAD (X) Parameters X ... Input. Variable x. Substitute the value of g(x) in function GRAD. (See Example.) EPSR .. Input. Convergence criterion (0.0). The default value is assumed if 0.0 is specified. (See Comments on use.) MAX .. Input. The upper limit (0) of number of evaluations for f(x) and g(x). (See Comments on use.) Output. The number (>0) of actual evaluations. F ........ Output. The value of function f(x*). ICON .. Condition code. (See Table LMING-1.)
30000
EPSR<0.0 or MAX=0.
Comments on use Subprograms used SSL II ... AMACH, MGSSL FORTRAN basic functions ... ABS, SQRT, AMAX1 Notes An EXTERNAL statement is necessary to declare the subprogram names correspond to parameters FUN and GRAD in the calling program. EPSR In this subroutine, the convergence condition is checked as follows: During iteration, if ~ EPSR x1 x 2 max(10 . ,x ) is satisfied for two points x1 and x2 between which x* exists, point ~ x is assumed to be minimum point x* and iteration is stopped, where ~ x = x1 for f(x1) f(x2) ~ and x = x2 for f(x1)>f(x2). Since f(x) is assumed to be approximately a cubic function in the vicinity of point x*, it is appropriate to specify EPSR as EPSR u , where u is the unit round off to obtain value x* as accurate as the rounding error. The default value of EPSR is 2 u . MAX The number of function evaluation count is incremented by one every time f(x) or g(x) is evaluated. This is the same as the call count of subprogram FUN and GRAD. The number depends on characteristics of function f(x) and g(x), interval [a, b], and convergence criterion. Generally, when an appropriate interval [a,b] is specified and the default value is used for the convergence criterion, it is adquate to specify MAX=400. Even if the convergence condition is not satisfied within the specified evaluation count and the subroutine is returned with ICON=10000, iteration can
420
LIMING
be resumed by calling this subroutine again. In this case, the user must specify a negative value as the additional evaluation count in the parameter MAX and retain other parameters unchanged. A and B If there is only one minimum point for f ( x ) in interval [a , b] , this subroutine obtains the value of the point within the specified error tolerance. If there are several minimum points, it is not guaranteed to which point the result converges. This means that it is descrable to set a and b , end points of the interval containing minimum point x * , in the vicinity of minimum point x * . Example Given the following function, f ( x ) = x 4 4 x 3 6 x 2 16 x + 4
The processing comprises two steps: Obtains two points x 1 and x 2 between which point x * exists. Based on function values f ( x1 ) and f ( x 2 ) at points x 1 and x 2 and their derivatives g( x1 ) and g( x 2 ) , determines the minimum point using a cubic interpolation formula which passes through points x1 , f ( x1 ) and x 2 , f ( x2 )
These steps are repeated until the convergence condition is satisfied in the interval containing the minimum point. Calculation procedures For simplicity, let f ( x1 ) , f ( x 2 ) ,...be expressed as f 1 , f 2 , ... Procedure step 1 (determination of two points x 1 and x 2 ) 1) Assumes the smaller of a and b to be x1, the larger to be x 2 , and =max(EPSR, 2 u ) If g1 <0 and g2 >0, proceeds to step 2. 2) Determines middle point xh in interval [ x1 , x 2 ] from x h = ( x1 + x 2 ) / 2 3) If f 1 f h f 2 , assumes x 2 = x h and returns to 2). However, if the convergence condition x1 x h max(10 . , x2 ) is satisfied, assumes x1 to be x * and f1 to be f ( x *) ,and sets ICON = 0, then stops processing. 4) If f 1 f h f 2 , assumes x1 = x h , and returns to 2). However, if the convergence condition x h x2 max(10 . , x2 ) is satisfied, assumes x 2 to be x * and f 2 to be f ( x *) , and sets ICON =0, then stops processing. 5) If f 1 < f h > f 2 , assumes x 2 = x h (for f 1 f 2 ) or x1 = x h (for f 1 > f 2 ), and returns to 2). However, if the convergence condition x1 xh max 10 . , x1 (for f 1 f 2 ) or x2 xh max 10 . , x2 (for f 1 > f 2 )
Method Given a single variable real function f (x ) , its derivative to be obtained, minimum point x * and the value of function f ( x * ) are obtained using cubic interpolation.
be f ( x * ) , and sets ICON=0, then stops processing. 6) If f 1 > f h < f 2 and If gh < 0 and g2 > 0 , assumes x1 = x h , then proceeds to step 2); If g1 < 0 and gh > 0 , assumes x 2 = x h , then proceeds to step 2); If g1 0 and gh 0 , assumes x 2 = x h , then returns to 2); If gh 0 and g2 0 , assumes x1 = x h , then returns to 2);
421
LIMING
h = h( w + z g1 ) / ( g2 g1 + 2w) xm = x1 + h
is satisfied, or if gm = 0 , assumes xm to be x * and f m , to be f ( x * ) , and sets ICON=0, then stops processing. If the convergence condition is not satisfied, assumes x1 = x m ( g m < 0) or x 2 = x m ( g m > 0) , then returns to 2).
422
LOWP
CALL LOWP (A, N, Z, ICON) Function This subroutine finds zeros of a fifth or less degree polynomial with real coefficients; a0a n + a1 x n1 + ...+ an = 0(n 5,a0 0) by the successive substitution method, Newton method, Ferrari method, Bairstom method, and the root formula for quadratic equations. Parameters A. Input. Coefficients of the equations. A is a one-dimensional array of size n + 1 . Where A(1) = a0 , A(2) = a1 , ...... and ..., A( N + 1) = a n N. Z. Input. Degree of the equation. Output. n roots Z is a complex one-dimensional array of size n. ICON.. Output. Condition code. See Table LOWP-1.
Table LOWP-1 Condition codes Code 0 10000 Meaning No error When determining a real root of a fifth degree equation, after 50 successive substitutions fkfk+1<0 was not satisfied. a0=0.0, n0 or n>5 Processing Xk+1 is used as the initial value in Newton's method and processing continues. Refer to equation (4.16) in the method. Bypassed
Method In the explanations below the coefficient of the highest power of the polynomial is assumed to be 1 (there is no loss of generality) When n = 2 (quadratic equations) The root formula is used. This is done by calling subroutine RQDR. For n = 3 (third degree equations) 3 2 If one real root x1 of f ( x ) = x + c1 x + c2 x + c3 = 0 is obtained, the equation becomes. f ( x ) = ( x x1 )( x 2 + pi x + p2 ) p1 = c1 + x1 where, p2 = c2 + x1 p1 and the problem is reduced to solving a quadratic equation. The single real root x1 is obtained using Newton's method. The initial value xa is determined after examining the characteristics of f ( x ) . Namely, let f ' ( x ) = 3x 2 + 2c1 x + c2 = 0 the following three cases are considered when determining xa . (4.2) (4.1)
(a) When f ' ( x ) = 0 has two different real roots xm1 and xm2(xm1) and a minimum value f(xm2). If f ( xm1 ) f ( x m2 ) < 0 , the point of inflection of f ( x ) is
30000
used for xa. If f ( x m1 ) f ( x m2 ) > 0 , the following cases are considered for determining xa . When f ( x m1 ) > 0 A quadratic equation in h, which is obtained by setting the Taylor series expansion of f ( x m1 + h) up to h 2 equal to zero, is considered. Let its positive real root be h again, then x a = x m1 h When f ( x m ) < 0 A quadratic equation in h, which is obtained by setting the Taylor series expansion of f ( xm 2 + h) up to h 2 equal to zero, is considered. Let its positive real root be h again, and then (4.3)
Comments on use Subprograms used SSL II ... RQER, U3DEG, AMACH, UREDR, and MGSSL FORTRAN basic functions ... SQRT, ABS, and CMPLX Example Order n and coefficient ai ( i = 0 , 1, ..., n) are entered and n roots are determined.
C **EXAMPLE** DIMENSION A(6), Z(5) COMPLEX Z READ(5,500) N N1=N+1 READ(5,510)(A(I),I=1,N1) CALL LOWP(A,N,Z,ICON) WRITE(6,600) N,ICON WRITE(6,610)(A(I),I=1,N1) IF(ICON.EQ.30000) STOP WRITE(6,620)(Z(I),I=1,N) STOP
423
LOWP
x a = x m2 + h
(4.4)
(b) When f ' ( x ) = 0 has multiple roots This occurs when the maximum value and then minimum value match the inflection point. Let the inflection point be xi and perform the successive substitution method once, then xa = xi f ( xi ) (4.5)
p1 + p1 , and p2 + p2 are used as the new values for p1 and p2 , and the corresponding q1 and q2 are obtained using (4.11). When n = 5(fifth degree equation) Let one of the real roots of the following fifth degree equation. f ( x ) = x 5 + c1 x 4 + c2 x 3 + c3 x 2 + c4 x + c5 = 0 (4.14) be x1 , then f ( x ) can be rewritten as
' f ( x ) = ( x x1 )( x 4 + c1 x 3 + c'2 + c'3 + c'4 ) = 0
(b) When f ' ( x ) = 0 does not have any real roots The inflection point of f ( x ) s used for xa. When n = 4 (fourth degree equation) Generally, a fourth degree equation f ( x ) = x 4 + c1 x 3 + c2 x 2 + c3 x + c4 = 0 can be factored into two quadratic factors using Ferrari's method. f ( x ) = ( x 2 + p1 x + p2 )( x 2 + q1 x + q 2 ) If one real root of the following third degree equation is determined (4.6)
(4.15)
Therefore once x1 has been obtained, the problem is reduced to solving a fourth degree equation. x1 is determined as follows: First, using the successive substitution method x0 = 0 f 0 = c5 xk +1 = x k f k
3 c2 2 + (c1 c3 4c4 )
2 + (4c2 c4 c2 3 c1 c4 ) = 0
(4.8)
(4.16)
f k = f ( x k ) k = 0, 1, ..., 50
2 + c4 = 0
(4.9)
xk and xk +1 are determined such that f k f k +1 < 0 Next, using the method of regular falsi xa = xk +1 ( x k +1 x k ) f k +1 / ( f k +1 f k ) xa is determined. Newton's method is then applied using xa as the initial value. The upper limit of iteration by (4.16) is set to 50. If f k f k +1 < is not satisfied when that limit is reached the last xk +1 is used as the initial value in Newton's method. Convergence criterion For third and fifth degree equations, Newton's method is used to obtaine one real root. The method used to examine convergence is discussed below. Let third and fifth degree equations be represented in the following general form. c0 x n + c1 x n1 +......+cn = 0 (4.17)
2 c1 + (c2 ) = 0
(4.10)
It p2 and q2 are complex roots, the remaining real roots of (4.8) are examined and real roots within a certain allowable quantity range are used for p2 and q2 . Later, p1 , q1 , p2 and q2 are modified using Bairstow's method. Of the following quantities q1 q2 q3 q4 = c1 p 1 = c 2 p1 q 1 p 2 = c1 p 1 q 2 p 2 q 1 = c 0 p1 q 3 p 2 q 2
(4.11)
d1 = q1 p1 d 2 = q2 p1d1 p2 d 3 = p1d 2 p2 d1
(4.12)
q1 to q4 are calculated first, then d1 to d 3 are calculated. Then the systems of linear equation in (4.13) are solved for p1 p1 and p2 . d 2 p1 + d1 p2 = q3 d 3 p1 + d 2 p2 = q4 424 (4.13)
(where c0 =1, n =3 or 5) and let the k -th approximate value obtained when Newton's method is applied to (4.17) be xk , xk is accepted as a root of (4.17) if it satisfies c j xk =
j 0 n n j
u c j xkn j
j=0
(4.18)
Where u is the round-off unit. For futher details, see Reference [25].
LPRS1
n+ 1 n
CALL LPRS1 (A, K, M, N, EPSZ, IMAX, ISW, NBV, B, VW, IVW, ICON)
m A
Function This subroutine solves linear programming problem shown below by using the revised simplex method; Minimize (or maximize) the objective function of linear z = c j x j + c0 =
j 1 n
m+1 K -cT C0
K .
aij x j di , i = ml + 1 , ml + 2 ,, ml + mg j =1
n j 1
aij x j = d i , i = ml + mg + 1, ml + mg + 2 , , = ml + mg + me , x j 0 , j = 1, 2 n This subroutine solves this problem in the following two phase: Phase 1 obtaining basic feasible solution. Phase 2 obtaining the optimal solution. This subroutine allows entry of the initial feasible basis. There is no constraint on sign of di . Assume m = m1 + mg + me . m h matrix consisting of elements {aij } : called coefficient matrix A . d = ( d1 , d 2 ,, dm )T : called a constant vector. c = ( c1 , c2 ,, cm )T : called a coefficient vector. c0 : called a constant term. n 1 , ml 0 , mg 0 , me 0 m 1 Parameters A. Input. Coefficient matrix A , Constant vector d , coefficient vector c and constant term c0 . See Table LPRS1-1. Two-dimensional array of size A(K, N+1).
Input. Adjustable dimension of arrays A and B ( m + 1 ). M . Input. Number of constraints. One-dimensional array of size 3. M(1), M(2), and M(3) contain m1 , mg and me , respectively. N . Input. Number of variables n EPSZ .. The relative zero criterion for elements (coefficient and constant term) to be used during iteration and the pivot to be used when basic inverse matrix B 1 is obtained. EPSZ 0.0. A default value is used when EPSZ=0.0. See Notes. IMAX .. Input. Maximum number of iterations ( 0 ). See Notes. Output. Number of iterations actually executed ( > 0 ). ISW .. Input. Control information. ISW specifies whether the objective function is to be minimized or maximized and whether the initial feasible basis is given. ISW is expressed as 10 d1 + d0 . Where 0 d0 1 and 0 d1 1 . When d 0 = 0 , the objective function is to be minimized. When d 0 = 1 , the objective function is to be maximized. When d1 = 0 , a basis is not given. When d1 = 1 , a basis is given.
425
LPRS1
NBV ..
B .
Output. When an optimal solution or basic feasible solution is obtained, ISW contains a value of d1 = 1 . Otherwise the input value remains. Input. (When ISW = 10 or 11 is specified.) Initial feasible basis. Output. Optimal or feasible basis. One-dimensional array of size m . See Notes. Output. Basic inverse matrix B 1 for an optimal solution or basic feasible solution, optimal solution or basic feasible solution g , simplex multiplier and objective function value q . Two-dimensional array B(K, m+1). See Fig. LPRS1-2.
m+1 m
Table LPRS1-1 Condition codes Code 0 10000 Meaning An optimal solution was obtained. A basic feasible solution was obtained but the problem has no optimal solution. The number of iterations reached to the specified upper limit during phase 2. The basic feasible solution was obtained. The problem is infeasible. The value EPSZ might not be appropriate. When ISW=10 or ISW=11, the set of the given variables is not a basis. When ISW=10 or ISW=11, the set of the given variables is infeasible. The basic variable could not be interchanged during phase 1. The value EPSZ might not be appropriate. The number of iterations reached to the upper limit during phase 1. One of the following conditions occurred: 1 Negative value was contained in M(1), M(2) or M(3). 2 N<1 3 IMAX=0 4 EPSZ<0.0 5 M(1)+M(2)+M(3)<1 6 M(1)+M(2)+M(3)K 7 Zero or negative number was contained in the elements of NBV. 8 The number exceeding N+M(1)+M(2) was contained in the elements of NBV. 9 The same basic variable number appeared in the elements of NBV. 10 ISW was incorrectly given. Processing
11000
20000
The basic feasible solution and corresponding basic inverse matrix, simplex multiplier and objective function value are stored in B Bypassed
21000
Bypassed
22000
Bypassed
23000
Bypassed
24000 m m+1 K B
1
Bypassed
g 30000
Bypassed
VW .. IVW .. ICON ..
Work area. One-dimensional array of size 2n + m + m1 + mg + 1 . Work area. One-dimensional array of size n + m1 + mg . Output. Condition code. See Table LPRS1-1.
Comments on use Subprograms used SSL II ... ALU, LUIV, AMACH, MGSSL FORTRAN basic functions ... ABS, IABS Notes Contents of NBV When the number of basic variable is specified by NBV (when ISW=10 or ISW=11), the number of the slack variable corresponding the i-th i ml + mg unequality constraint must be n + i . When the computed basic solution contains the i-th slack variable, the slack variable number is assumed to be n +i . An artificial variable cannot be specified as a basic variable at entry time. When an
artificial variable is combined with the computed basic solution,NBV contains value of zero. If the i-th basic variable is an artificial variable, NBV(i) contains a value of zero. When the basic feasible solution has been obtained (when ICON=0, 10000 or 11000), NBV(i)=0 indicates that the i-th constraint is redundant
426
LPRS1
(which is derived form other constraints with NBV ( i ) 0). Moreover, the content of NBV is ginven corresponding in storage order of the optimal solution or basic feasible solution g (See Fig LPRS 1-2). It is X3=0 against number j which is not stored in NBV. Givein IMAX The number of iterations is that of criterions of the optimality standards (See Method 4.7) assciated with a basic fesible solution (at phase 1, the basic feasible solution contains artificial variables). The standard value for IMAX is 10m If the optinal solution could not be obtained within the specified number of iterations and ICON contains a condition code of 11000, this subroutine can be called again to continue iteration. In this case, a negative value for the number of additional iterations must be specified in the parameter IMAX, While other parameters remaim unchanged. Giveing EPSZ Suppose the maximum abolute value of the input date (contents of array A) elements to be amax. Zero is assumed for the element in which the absolute value for the elements during iteration is less than amax EPSZ. When a basic inverse matrix B-1 is obtained by using ALU or LUIV sobroutinc, EPSZ is used as the relative zero criterrion value (Refer to Comments on use of the subroutine ALU) . The standard value for EPSZ is 16 u (u:unit round off). It is desirable that the absolute value must be adjusted as far as possible by multiplying each column or row by constants. When ICON=20000 or 23000, the value of EPSZ may not be appropriate. In this case, use the standard value for EPSZ or change the value for retry. When varibale xj is negative This subroutine principally used the condition xj 0, j=1,2,...,n Therefore if xj is negative, the subroutine can be used after transformation of the problem as listed below: x Replce xj by x + j j 0, x 0 Add the constraints of x + j j Example This example solves a linear programming problem when the maximum number of variables is 10 and the maximum number of constraints is 20:
C **EXAMPLE** DIMENSION A(21,11), B(21,21), M(3), * NBV(20), VW(61), IVW(30) READ(5,500)N, M, ISW N1=N+1 MM=M(1)+M(2)+M(3) M1=MM+1
D0 10 I=1, M1 READ(5,510) (A(I,J), J=1, N1) 10 CONTINUE WRITE (6,600) (J,J=1, N) IF(M(1).EQ. 0) GOTO 30 WRITE (6,610) DO 20 I=1, M(1) WRITE (6,620) I, (A(I, J), J=1, N1) 20 CONTINUE 30 IF (M(2). EQ. 0) GOTO 50 WRITE (6,630) IS=M (1)+1 IE=M(1)+M(2) DO 40 I=IS, IE WRITE (6,620) I, (A(I,J), J=1, N1) 40 CONTINUE 50 IF(M(3), EQ. 0) GOTO 70 WRITE(6,640) IS=M(1)+M(2)+1 DO 60 I=IS, MM WRITE (6,620)I, (A(I, J), J=1, N1) 60 CONTINUE 70 IF (MOD(ISW, 10).EQ.0) GOTO 80 WRITE (6,650) (A(M1,J), J=1, N1) GOTO 90 80 WRITE (6,660) (A(M1,J), J=1, N1) 90 READ (5,520) EPSZ, IMAX WRITE (6,670) EPSZ, IMAX IF (ISW. LT.10) GOTO 100 READ (5,500) (NBV(1), I=1, MM) WRITE (6,680) (NBV(I), I=1, MM) 100 CALL LPRS1 (A, 21, M, N, EPSZ, IMAX, * ISW, NBV, B, VW, IVW, ICON) WRITE (6.720)B(M1,M1) WRITE (6,690) ICON, IMAX IF(ICON, GE.20000) STOP IF(ICON, EQ.0) WRITE (6,700) IF(ICON. GE. 10000) WRITE (6,710) WRITE (6,720)B(M1,M1) WRITE (6,730) (NBV(I), B(I, M1), I=1, MM) STOP 500 FORMAT (10I4) 510 FORMAT (11F6.0) 520 FORMAT (E10.2, I5) 600 FORMAT (1H1, 15HINITIAL TABLEAU * /1H0, 10X, 11 (I6,4X)) 610 FORMAT (1H , 10HLHS. LE. RHS) 620 FORMAT (1H , I6, 4X, 11F10.3) 630 FORMAT (1H , 10HLHS. GE. RHS) 640 FORMAT (1H , 10HLHS. EQ. RHS) 650 FORMAT (1H , 14HOBJ. FUNC. (MAX) * /1H, 10X,11F10.3) 660 FORMAT (1H , 14HOBJ. FUNC. (MIN) * /1H, 10X,11F10.3) 670 FORMAT (1H0, 5HEPSZ=, E12.4, 5X, * 5HIMAX=,I4) 680 FORMAT (1H0, 13HINITIAL BASIS * /1H, 20I 4) 690 FORMAT (1H0, 5HICON=, 12X, 5HIMAX=, I4) 700 FORMAT (1H0, 16HOPTIMAL SOLUTION) 710 FORMAT (IH0, 17HFEASIBLE SOLUTION 720 FORMAT (1H , 9HOBJ, FUNC., F15.4) 730 FORMAT (1H , I6,3X, F15.4) END
427
LPRS1
Method First, the following standard linear programming problem is explained. Minimize the objective function z = c T x + c0 subject to Ax = d xo Assume an m n matrix A where rank A = m n and assume d = (d1 , d2 ,...,d m ) and c = (c1 ,c2 ,...,cn ) .
T
ps > 0 , s L (4.8) it may be possible to get a better basic feasible solution which minimizes the value of z further by replacing any basis, by xs . Let a null set be , and (4.3) I + = i f is > 0
(4.1) (4.2)
x = ( x1 , x2 ,..., x n ) ,
T
holds, the basis in which xkr is replaced by xs is a feasible basis. And the basic solution for a new basis is as follows: x k 'r = gr f rs , gr , ir f rs , j L' , gr f rs (4.10)
The j -th column of A is expressed by a j when m column of A : ak 1 , a k 2 ,..., a km are linearly independent, the corresponding xk 1 , x k 2 ,...,xkm are called bases and xki is colled the i -th basic variable. Suppose a set of non-basic variable numbers to be L, a system of linear equations which is equivalent to (4.1) and (4.3) can be expressed below: xki + f ij x j = gi
jL
x'ki = gi f is xj = 0 z = q ps
, i = 1, 2, , m (4.4)
When k 'i is of a new basic variable number and L' is a set of new non-basic variable numbers. Therefore the following relationships can be established: k 'r = s , ' k i = ki , i r , L' = L {s} + {kr } The value z in this new basic feasible solution is smaller than the old value if g r > 0. When I + = , the problem has no optimal solution. If B = [ak 1 , a k 2 , , akm ]
z + pj x j = q
j L
This is called a basic form and one of its solutions x ki = g i , i = 1, 2, , m xj = 0 , j L z=q is colled a basic solution. When
(4.5)
C B = [c k 1 , c k 2 , , c km ]
(4.11)
= C B B 1
are give, the values of coefficients of a basic form shown in (4.4) and the right side are expressed as follows: (4.6) f j = b 1 a j , j L g = B 1 d p j = a j c j , q = d c0 Where f j = ( f1 j , f 2 j ,..., f mj ) and g = ( g1 , g2 ,..., gm )
T
T
gi 0, i = 1, 2, , m
holds, the basic solution shown in (4.5) satisfies (4.2). The solution shown in (4.5) is a basic feasible solution In the basic feasible form, if a certain s which satisfies (4.8) exisits, p j 0, j L (4.7)
(4.12)
j L
holds, (4.5) is the optimal solution. (4.7) is the optimality criterion for the basic feasible solution. In the basic feasible form, if a certain s whic satisfies (4.8) exists, 428
hold. B , B 1 and are called a basic matrix, basic inverse matrix and simplex multiplier (vector) respectively. The following summarizes the computational
LPRS1
procedures for a standard linear progromming problem: Basic inveerse matrix B for a fesible basis and simplex multiplier are computed. p j is computed by using the formula shown in (4.12).
1
subfect to:
A* x * + A( a ) x ( a ) = d , a x* 0 , x( ) 0
(4.15)
where x * is an (n + m l + m g ) -dimensional vector contains slack variables and A* is the corrsponding coefficient matrix. x ( a ) is an m-dimensional vector,
T
The optimality criterion shown in (4.7) is tested. If the standards are satisfied, the g is assumed as an optimal solution. If they are not satisfied, f s is computed based on (4.12). The variable to be replaced by x s is selected based on (4.9) and a new fesible base is produced. The revised simplex method obtains the optiml solution by repeating these procedures. Soulution for non-standard linear programming problem When unequality constraints are contained, they must be adjusted to the following equality constraints to transform them to a stndard linear programming problem. Given
a ij x j d i , i = 1,2, , m l
n j =1
order m, A( a ) = (a(ija ))
(4.16)
are called artificial variables. When the optimal solution is obtained of this problem, if, z 1 = 0 , that is x ( a ) = o holds, the basic feasible solution for the given problem has been obtained. When z1 > 0 , the original problem is infeasible. If z 1 = 0 , an artificial variable may remain in the basis. In this case, it must be handled so that the articial variable value is always zero when the subsequent problem is to be solved. Computational procedures When the initial fesible basis can be given (ISW=10 or ISW=11), this subroutine immediately executes procedure 2). 1) Initialization of phase 1 a Assuming x ( ) as a basis in (4.15) this subroutine defines the basic inverse matrix B 1 , which is equal to (4.16). This subroutine determines the corresponding basic solution g , simplex multiplier and objective function value q form (4.11) and (4.12):
gi = d i
where
aij x j + xn + i = di , i = 1,2,..., mi
j =1
xn + i
(4.13)
where
n aij x j x n+ i = di j =1 (4.14) , i = ml + 1 , ml + 2 , x n+i 0 , m l + m g
(4.17)
q = di
i =1
is assumed to be held. The varibles added in (4.13) and (4.14) are called slack variables. The maximization problem is transformed to the minization problem by multiplying objective functions by -1. Obtaining the initial basic solution When the initial feasible basic solution has not been obtained, the following problem must be solved before the given problem is solved: Minimize the objective function z1 = x(i a )
i =1 m
This subroutine immediately executes procedure 4) 2) The basic inverse matrix corresponding to the initial feasible basis is computed by using the subroutines ALU and LUIV. If the inverse matrix cannot be obtained, this subroutine terminates abnormally after it sets a condition code of 20000 to ICON. 3) Initalizain of phase 2 Simplex multiplier is computed by using (4.11). Objective function value q is computed based on relationship shown in (4.12): q = c B g + c0 Where the element of CB is assumed to be 0
429
LPRS1
corresponding to a slack variable and artificial variable. 4) Testing the optimality criterion This suborutine obtains the p j corresponding to the non-basic variables containing slack variables by using (4.12) and tests the optimality criterion shown in (4.7). If (4.8) is satisfied, this subroutine executes procedure 5) immediately. If the optimality criterion is safisfied: when ISW 10, the optimal solution has been obtained. This subroutine terminates normally after it set a condition code of 0 to ICON. when ISW<10 and q > 0 , the problem has no basic feasible solution. This suborutine terminates after it sets condition code of 20000 to ICON. when ISW<10 and q = 0 , an initial basic feasible solution has been obtained. This subroutine completes phase 1 at this stage. This subroutine increments the contents of ISW by 10 and executes procedure 3) again. 5) Testing the number of iterations If the number of terations has not reached the upper limit, this subroutine executes procedure 6) and continue iterations. When it has reahed the upper limit during phase 1, this subroutine terminates abnormally after it sets a condition code of 24000 to ICON. When it has reached the upper limit during phase 2, this subroutine terminates after it sets a condition code of 11000 to ICON. 6) Replacing bases This subroutine computes fs corresponding to x s by using (4.12). If f is 0 (i = 1, 2,
is expressed by i , the matrix for new bases can be obtained as shown below: 1 r r f rs i f is r i , i r (4.17)
This is called pivot operation in which f rs is assumed to be a pivot. This subroutine executes procedure 4) again after this procedure. Convergence criterion When a variable to be stored into a base is x s and a variable to be fetched form the base during replacement of the base, the value of the objective function decreases by ps gr f rs
(> 0)
, m) is satisfied, no
optimal solution exists. When such a condition occurs during phase 1, this subroutine sets a condition code of 10000 to ICON and terminates. When it occurs during phase 2, this subroutine sets a condition code of 23000 to ICON and terminates. If f is > 0 , this subroutine determines base xkr to be changed by using (4.9). 7) Computing basic inverse matrices for new bases When the i-th row (i = 1, 2, , m + 1) of a matrix
is satisfied. The same basic feasible solution does not appear as far as (4.18) is satisfied during iteration. Since the number of basic feasible solutions is limited this subroutine can obtain the optimal soution while replacing base by the other - or it can find out that no optimal solution exists. If gr =0 is satisfied, the value of the objective function does not vary. If this condition occurs repeatedly, a basic feasible solution which has appeared once may appear again - some feasible solution appear periodically. As a result no optimal solution cannot be obtained normally. To avoid such a condition this subroutine imposed certain restriction on r and s : The minimum-valued j is regarded as s if p j > 0 in (4.8) The r0 which makes the minimum value of (4.9) zero, minimizes kr0 and satisfies gr0 gi = min f r0 s i I + f is is regarded as r . For further information, see Reference [41].
B p
g q
430
LSBIX
VW ....
Work area, One-dimensional array of size n(hm + 1) hm (hm + 1) / 2 . (See"Comments on Use.") Work area. One-dimensional array of size 2n . Output. Condition code. (See Table LSBIX-1.)
CALL LSBIX (A, N, NH, MH, B, EPSZ, ISW, VW, IVW, ICON) Function This subroutine solve a system of linear equations Ax = b (1.1)
Table LSBIX-1 Condition codes Code 0 20000 Meaning No error. A relative zero pivot has been found. It is highly probale that the coefficient matrix is singular. The bandwidth was exceeded the tolerable range during operation. NH>0, NH>MH, MHN, EPSZ>0.0 or ISW 1 or 2. Processing Bypassed.
using the block diagonal pivoting method, where A is an n n indefinite symmetric band matrix with band width h , b is an n -dimensional real constant vector, and x is an n -dimensional solution vector (n > h 0) .(there are two similar methods, the one is analogous to Gaussian elimination method and the other is analogous to Crout method ;this subroutine uses the former.) Paramters A ....... Input. Coefficinet matrix A . Compressed storage mode for symmetric band matrix. One-dimensional array of size n(h + 1) h(h + 1) / 2 . N ....... NH .... Input. The order n of coefficient matrix A , constant vector b , and solution vector x . Input. Band width h of A . The content is altered on output. (SeeComments on Use.) Input Maximum tolerable band width hm (N>MHNH) (See Comments on Use.) Input. Constant vector b . Output. Solution vector x . One-dimensional array of size n. Input. Tolerance (0.0) for relative zero test of pivots. The default value is used if 0.0 is specified. (See "Comments on Use.") Input. Control information. When l ( 1) systems of linear equations with the identical coefficient matirx are to be solved, ISW can be specified as follows: ISW=1 ... The first system is solved. ISW=2 ... The 2nd to -th systems are solved. However, only parameter 2: B is specified for each consstant vector b of the systems, with the rest unchanged. (See "Notes".)
25000
Bypassed.
30000
Bypassed.
Comments on use Subprograms used SSL II...SBMDM, BMDMX, AMACH, MGSSL FORTRAN basic functions...AMAX1, ABS, IDIM Notes If 10 s is specified as EPSZ, this is interperted as follows: If the loss of significant digits exceeds s decimal digits for the pivot value (a determinat of (11 or 22 matrix of the pivot) during the MDMT decomposition by the block diagonal pivoting method, the pivot value is assumed to be relative zero, and ICON=20000 is set, then the processing is stopped. Let u be the unit round off, then the standard value of EPSZ is 16u . It is posible to continue the decomposition, even if the pivot takes small value by specifying extreme small value, for the parameter EPSZ. In such case, however the result is not guarnteed. In case to solve several system of linear equations with identical coefficient matrix, the second and subsequent system can be solved efficiently by specifying as ISW = 2. Because this subroutine bypasses the procedure for MDMT decomposition. When ISW=2.
MH .
B .......
EPSZ ..
ISW....
431
LSBIX
For the method to obtain the determinant of matrix A , see "Example" and explanations of subroutine SBMDM which is called in this subroutine. If rows and columns are exchanged by pivoting, generally the band width of the matrix is increased. It is desirable to specify the maximum tolerable band width hm so that the increment of band width can be allowed. If the band width exceeds hm during MDMT decompositon, processing is stopped assuming that ICON=25000. This subroutine permit to allocate the array A and VW to the same area. Example Given l systems of linear equations with the identical coeffcient matrix, the solutions and the determinant are obtained as follows, where n 100 and h hm 50 .
C **EXAMPLE** DIMENSION A (3825), B (100), IVW (200) READ (5,500) N, NH, MH WRITE (6,600) N, NH, MH NHP1=NH+1 NT=(N+N-NH) *NHP1/2 READ(5,510) (A(J), J=1, NT) READ(5,510) L EPSZ=1, 0E-6 ISW=1 DO 10 K=1, L IF (K.GE.2) ISW=2 READ(5,510) (B(I), I=1, N) CALL LSBIX (A, N, NH, MH, B, EPSZ, ISW, A, * IVW, ICON) WRITE (6,610) ICON IF (ICON. GE. 20000) STOP WRITE (6,620) (B(I), I=1, N) 10 CONTINUE DET=1.0 J=1 I=1 20 M=IVW(I) IF (M. NE. I) GO TO 30 DET=A(J)*DET J=MIN0(I,MH)+1+J I=I+1 GO TO 40 30 JJ=MIN0 (I, MH)+1+J DET=(A(J)*A(JJ)-A(JJ-1)*A(JJ-1))*DET J=MIN0(I+1, MH)+1+JJ I=I+2 40 IF (I. LE. N) GO TO 20 WRITE (6,630) DET STOP 500 FORMAT(3I4) 510 FORMAT (4E15.7) 600 FORMAT (1H1/10X, 2HN=,I3,5X, 3HNH=,I3,5X, * 3HMH=, I3) 610 FORMAT(1H0, 10X, 5HICON=, I5)
620 FORMAT (11X, 15HSOLUTION VECTOR * /(15X, 5E15.6)) 630 FORMAT (1H0, 10X, * 34HDETERMINANT OF COEFFICIENT MATRIX=, * E15.6) END
Method This subroutine solves a system of linear equation Ax = b as follows: MDMT decompositon of the coefficient matrix A (the block diagonal pivoting method) The MDMT decomposition of coefficient matrix A is obtained by the block diagonal pivoting method as PAP T = MDM T (4.2) (4.1)
where P denotes the permutation matrix to exchange rows in the pivoting operation, M is a unit lowerband matrix, and D is a symmetric block diagonal matrix comprising blocks at most of order 2. Subroutine SBMDM is used for this calculation. Solution A system of linear equations (4.1) is equivalent to P 1 MDM T P T x = b (4.3)
This can be solved by forward and backward substitutions and other minor computations as follows:
Mx (1) = Pb 2 1 Dx ( ) = x ( ) 2 T ( 3) M x = x( ) P T x = x ( 3)
Subroutine BMDMX is used for these calculations. (See references [9] and [10] for details.)
432
LSBX
Table LSBX-1 Condition codes Code 0 10000 Meaning No error The negative pivot occurred. The coefficient matrix is not positive-definite. The relatively zero pivot occurred. It is highly probable that the coefficient matrix is singular. NH<0, NHN, EPSZ<0.0 or ISW 1,2. Processing Continued
CALL LSBX (A, N, NH, B, EPSZ, ISW, ICON) Function This subroutine solves a system of linear equations (1.1) by using the modified Cholesky's method, Ax = b Where A is an n n real positive-definite symmetric band matrix with lower and upper band widths h , b is an n -dimensional real constant vector, x is an n dimensional solution vector, and n > h 0 . Parameters A ...... Input. Coefficient matrix A . The contents of A are altered on output. A is stored in onedimensional array of size n(h + 1) h(h + 1) / 2 in the compressed mode for symmetric band matrices. Input. Order n of coefficient matrix A . Input. Lower and upper band width h . Input. Constant vector b . Output. Solution vector x . One dimensional array of size n . Input. Tolerance for relative zero test of pivots in decomposition process of matrix A( 0.0) . When this is 0.0, the standard value is used. (Refer to "Notes") Input. Control information. When solving l ( 1) systems of linear equations with an identical coefficient matrix, ISW can be specified as follows: ISW=1...The first system is solved. ISW=2...The 2nd to lth system are solved. However, only parameter B is specified for each constant vector b of the systems with the rest unchanged. (Refer to "Notes".) Output. Condition code. Refer to Table LSBX-1.
20000
Discontinued
30000
Bypassed
Comments on use Subprograms used SSL II ....SBDL, BDLX, AMACH, MGSSL FORTRAN basic functions....ABS Notes The solution obtained by this subroutine can be refined in accuracy by successively calling subroutine LSBXR. Since this subroutine omits the operations concerning the elements out of the band, the processing speed is faster than subroutine LSX provided for positivedefinite symmetric matrices. If EPSZ is set to 10 s , this value has the following meaning; while performing the LU-decomposition by Crount's method, if the loss of over s significant digits occurred for the pivot, the LU-decomposition should be discontinued with ICON = 20000 regarding the pivot to be relatively zero. The standard value of EPSZ is 16u , where u being the unit round off. If the processing is to proceed at a lower pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. When successively solving systems of linear equations with an identical coefficient matrix, computation can be performed by setting ISW = 2, the LDLT decomposition process for the coefficient matrix is bypassed so that the computation time can be reduced. If the negative pivot occured in the decomposition, the coefficient matrix is not positive-definite. In this case, this subroutine is continued with ICON=10000. However, it should be noted large calculation errors may occur since the pivoting is not performed. The determinant of the coefficient matrix can be obtained by multiplying all the n diagonal elements in array A after the subroutine has been executed and then by inverting the multiplied value. Note that array A is in the compressed mode for symmetric band matrices. The contents of the resultant A are identical to those on output of subroutine SBDL.
EPSZ..
ISW...
ICON ..
433
LSBX
Example l systems of linear equations in n unknown with an identical coefficient matrix are solved. n 100 and h 50 .
C **EXAMPLE** DIMENSION A(3825), B(100) READ(5,500) N, NH WRITE(6,600) N, NH NH1=NH+1 NT=N*NH1-NH*NH1/2 READ(5,510) (A(I), I=1, NT) READ(5,500)L K=1 ISW=1 EPSZ=1.0E-6 READ(5,510) (B(I), I=1,N) CALL LSBX (A, N, NH, B, EPSZ, ISW, ICON) WRITE (6,610)ICON IF (ICON. GE. 20000) STOP WRITE(6,620)(B(I), I=1, N) IF (K. EQ.L)GO TO 20 K=K+1 ISW=2 GO TO 10 DET=A(1) K=1 DO 30 I=2,N K=K+MIN0(I, NH1.) DET=DET*A(K) CONTINUE DET=1.0/DET WRITE(6,630)DET STOP FORMAT (2I5) FORMAT (4E15.7) FORMAT (1H1/10X, 2HN=,I3, 3HNH=, I3) FORMAT (1H0,10X, 5HICON=, I5)
620 FORMAT (11X, 15HSOLUTION VECTOR * /(15X, 5E17.8) 630 FORMAT (1H0, 10X, * 34HDETERMINANT OF COEFFICIENT MATRIX= * , E17.8) END
Method A system of linear equations (4.1) with a real positivedefinite symmetric band matrix A are solved in the following procedure. Ax = b (4.1)
10
LDTT decomposition of the coefficient matrix A (Modified Cholesky's method) LDTT decomposion is performed on coefficient matrix A by modified Cholesky's method. A = LDL (4.2)
20
where L is a unit lower band matrix and D is a diagonal matrix. Subroutine SBDL is used for this operation. Solving LDLT x = b (Forward and backward substitutions) A system of linear equations LDLT x = b (4.3)
30
434
LSBXR
Matrix D -1+( L - I )
1 l21d 22
Array FA
1 d11 l21 1 d22
0
dnn
1 d11
0
1 dh +1 h +1
CALL LSBXR (X, A, N, NH, FA, B, VW, ICON) Function Given an approximate solution to linear equations with an nxn positive definite symmetric band matrix of upper and lower band width h, Ax = b (1.1)
lh +11
lnn h
1 d nn
lh +11
1 dh +1 h+1
n (h + 1 )
h (h + 1) 2
0
Only lower band portion lnn h
1 d nn
this subroutine refines the approximate solution by the method of iterative modification, where b is an ndimensional real constant vector, and x is an ndimensional solution vector. Prior to calling this subroutine, the coefficient matrix A must be LDTT-decomposed as shown in Eq. (1.2), A = LDLT (1.2)
Note: The diagonal and the lower band portions in the matrix D-1+(L-I) are contained in array FA in the compressed mode for a symmetric band matrix. Fig .LSBXR-1 Storage of matrices L and D-1 Table LSBXR-1 Condition Codes Code 0 10000 25000 Meaning No error Coefficient matrix was not positive-definite The convergence condition was not met because of an illconditioned coefficient matrix. N=0,NH<0 or NH|H| Processing Discontinued (Refer to Method (4) d for the convergence condition.) Bypassed
where L and D are an n n unit lower band matrix with lower band width h and an n n diagonal matrix respectively. Also n > h 0 . Parameters X..... Input. Approximate solution vector x. Output. Refind solution vector x. One dimensional array of size n. A.... Input. Coefficient matrix A. Matrix A is stored in one-dimensional array of the size n(h+1)-h(h+1)/2 in the compressed mode for a symmetric band matrix. N.... Input. Order n of the matrix A. (Refer to notes.) NH.... Input. Lower band width h. FA.... Input. Matrices L and D-1. Refer to Fig. LSBXR-1. Matrices are stored in one -dimensional array of size n(h+1)-h(h=1)/2 in the compressed mode for a symmetric band matrix. B.... Input. Constant vector b. One-dimensional array of size n. VW.... Work area. One-dimensional array of size n. ICON.. Output. Condition code. Refer to Table LSBXR-1.
30000
Comments on use subprograms used SSL II ... BDLX, MSBV, AMACH, MGSSL FORTRAN basic functions ... ABS Notes This subroutines iteratively improves the approximate ~ obtained by subroutine LSBX to get solution x solution x with refined accuracy. ~ must be Therefore, prior to calling this subroutine, x obtained by subroutine LSBX and the results must be input as the parameters X and FA for this subroutine. In addition, the coefficient matrix A and constant vector b whitch are required for this subroutine must also be prepared and stored separately before valling subroutine LSBX. Refer to the example for details By specifying N = -n, an estimated accuracy (relative ~ given by the error) for the approximate solution x subroutine LSBX can be obtained. When specified, this subroutine calculates the relative error and outputs it to work area VW(1) without performing the iterative refinement of accuracy.Refer to method for estimation of the accuracy. Example ~ for a system of linear An approximate solution x equations in n unkowns is obtained by subroutine 435
LSBXR
Principle of iterative refinement The iterative refinement is a method to obtain a s +1 successively, improved approximate solution x ( ) to the linear equations (4.1) through use of the 1 ~. following euqtions starting with x ( ) = x
r ( ) = b Ax ( ) s s Ad ( ) = r ( ) s+ s x ( 1) = x ( s ) + d ( ) s=1,2,...
s s
where xs is the s-th approximate solution to equation(4.1). If Eq.(4.2)is accurately computed ,a refined solu1 tion of the approximate solution x ( ) is numerically obtained. If, however the condition of coefficient matrix A is not suitable, an improved solution is not obtained. (Refer to 3.4(2)e.Iterative refinement of a solution.) Procedure performed in this subroutine Suppose that the first approximate solution x (1) has already been obtained by subroutine LSBX. Then -this subroutine repeats the following steps: s The residual r ( ) is computed by using Eq. (4.2). Subroutine MSBV is used for this operation. s The correction d ( ) is obtained next by using Eq.(4.3). Subroutine BDLX is used for this operation. + Finally the modified approximate solution x ( s 1) is obtained by using Eq.(4.4). The convergence of the iteration is tested as follows: Considering u as a unit round off, the iteration refinement is assumed to converge if, at the s-th iteration step, the following relationship is satisfied
Method Given an approximate solution, ~ xir to the linear equations, Ax = b the solution is iteratively refined as follows: (4.1)
d(
s)
/ x(
s+1)
< 2u
(4.5)
The obtained x ( ) is then taken as the final solution. However, if the relationship,
s +1
d ( s) d ( s 1)
+
>
( s 1) 1 d ( s) 2 x
results, this indicates that the condition of the coefficient matrix A is not suitable. The iteration refinement is assumed not to converge, and consequently the processing is terminated with ICON = 25000. 436
LSBXR
Accuracy estimation for approximate solution Suppose that the error for the approximate solution x (1) is e (1) = x (1) x ,its relative error is represented by e ( )
1 1
almost equal to d(1) , therefore the relative error for the approximate solution is estimated by d (1)
/ x (1)
/ x( )
1
. If this iteration
for approximate solution in Section 3.4.) For further details, see References[1],[3]and[5].
437
LSIX
A22-21-0101 LSIX,DLSIX
A system of linear equations with a real indefinite symmetric matrix (Block diagnoal pivoting method)
Table LSIX-1 Condition codes Code 0 20000 Meaning No error The relatively zero pivot occurred. It is highly probable that the coefficient matrix is singular. N<1, EPSZ<0.0 or ISW1, 2 Processing Aborted
CALL LSIX (A,N,B,EPSZ,ISW,VW,IP,IVW,ICON) Function This subroutine solves a system of linear equations AX = b using the block diagonal pivoting method(there are two similar methods which are called Croutlike method and Gaussianlike method respectively. This subroutine uses the former method.),where A is an n n real indefinite symmetric matrix, b is an n-dimensional real constant vector, X is an ndimensional solution vector, and n 1 . Parameters A ..... Input. Coefficient matrix A. The contents of A may be overridden after operation. Compressed mode for symmetric matrix. One-dimensional array of size n (n+n)/2. N ..... Input. Order n of the coefficient matrix A, constant vector b and solution vector x. B ..... Input. Constant vector b. Output. Solution vector x. One-dimensional array of size n. EPSZ .. Input. Tolerance for relative zero test of pivots in decomposition process of A (0.0). If EPSZ = 0.0, a standard value is used. (See Notes.) ISW ... Input. Control information When l (1) systems of linear equations with the identical coefficient matrix are to be solved, ISW can be specified as follows: ISW=1 ... The first system is solved. ISW=2 ... The 2-nd to n-th systems are solved. However, only parameter B is specified for each constant vector b of the systems, with the rest unchanged. (See Notes.) VW .... Work area. One-dimensional array of size 2n. IP .... Work area. One-dimensional array of size n. IVW ... Work area. One-dimensional array of size n. ICON ..... Output. Condition code. Refer to Table LSIX-1.
30000
Aborted
Comments on use Subprograms used SSL II ... SMDM, MDMX, AMACH, MGSSL USCHA FORTRAN basic functions ... ABS,SQRT, IABS,ISIGN Notes If EPSZ is set to 10-S, this value has the following meaning: while performing the MDMT -decomposition by the block diagonal pivoting method, if the loss of over s significant digits occurred for the pivot value(i.e., determinant of a 1 1 or 2 2 matrix of the pivot), the MDMT -decomposition should be discontinued with ICON = 20000 regarding the pivot value as relatively zero. Let u be the unit round off, then the standard value of EPSZ is 16 u. If the processing is to proceed at a low pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. When successively solving systems of linear equations with the identical coefficient matrix, after solving the first system, ISW should be set to 2. With ISW=2, calculation time is reduced since the process in which the coefficient matrix A is MDMT decomposed is bypassed. For how to obtain the determinant of matrix A, refer to the example shown below or the corresponding description on the subroutine SMDM which is used in this subroutine. This subroutine makes use of symmetric matrix characteristics also while decomposing in order to save the data storage area. Example L systems of linear equations with the identical coefficient matrix are solved as well as the determinant of the coefficient matrix, where n100.
C **EXAMPLE** DIMENSION A(5050), B(100),VW(200),IP(100), * IVW(100) DATA IA, IB, IX/1HA, 1HB, 1HX/ READ(5,500) N,L NT=(N*(N+1))/2 READ(5,510)(A(I),I=1, NT) WRITE(6,600) N CALL PSM(IA, 1, A, N)
438
LSIX
M = 1 ISW = 1 EPSZ = 1.0E-6 10 READ(5,510) (B(I), I=1, N) CALL PGM(IB, 1, B, N, N, 1) CALL LSIX(A, N, B, EPSZ, ISW, VW, IP, IVW, ICON) WRITE(6,610) ICON IF(ICON. GE. 20000) STOP CALL PGM(IX, 1, B, N, N, 1) IF (M. GE. L) GO TO 20 M=M+1 ISW=2 GO TO 10 20 DET = 1.0 I = 1 J = 1 30 IF(IP(J+1). GT. 0) GO TO 40 DET = DET*(A(I)*A(I+J+1)-A(I+J)*A(I+J)) J = J+2 I = I+J-1+J GO TO 50 40 DET = DET*A(I) J = J+1 I = I+J 50 IF (J. LT. N) GO TO 30 IF (J. EQ. N) DET = DET*A(I) WRITE(6,620) DET STOP 500 FORMAT(2I3) 510 FORMAT(4E15.7) 600 FORMAT(1H1, * /6X, 21HLINEAR EQUATIONS AX = B * /6X, 6HORDER=, I4) 610 FORMAT (1H , 5X, 13HICON OF LSIX=, I6) 620 FORMAT(1H , 5X, 17HDETERMINANT OF A = ,E14.7) END
Method The linear equations Ax = b is solved using the following procedure: MDMT - decomposition of the coefficient matrix A (block diagonal pivoting method). The coefficient matrix A is decomposed by the block diagonal pivoting method as follows. PAP T = MDM T (4.2) (4.1)
where P is a permutation matrix that exchanges rows of the matrix A required in its pivoting, M is a unit lower triangular matrix, and D is a symmetric block diagonal matrix which consists only of the blocks, each at most of order 2. The subroutine SMDM is used for this operation. Solving P 1 MDM T (P T ) x = b
1
(4.3)
The subroutines PSM and PGM that are both called in this example are used for printing a real symmetric matrix and a read general matrix, respectively. The descriptions on those subroutines can be found in the example for the subroutine MGSM.
(P )
x = x(
3)
Consequently, the solution is obtained using forward substitution and backward substitution, in addition to minor computation. The subroutine MDMX is used for this operation. For more details, see References [9] and [10].
439
LSIXR
Array FA
d11
d 21
d 21
d11
0
d 22
0
d 22
CALL LSIXR (X, A, N, FA, B, IP, VW, ICON) Function ~ is given to linear When an approximate solution x equations with an n n symmetric matrix. Ax = b (1.1)
d33
d 21
m31
m32
0
1
This subroutine refines the approximate solution by the method of iterative modification, where b is an ndimensional real constant vector, and x is an n-dimensional solution vector. Prior to calling this subroutine, the coefficient matrix A must be MDMT decomposed as shown in(1.2), PAP T = MDM T (1.2)
m31 Note:
m32
The diagonal and the lower triangular portions of the matrix D+(M-I) are stored in one-dimensional array FA in the compressed mode for a symmetric matrix. In this case D consists of block of order 2 and 1.
where, P is a permutation matrix which exchanges rows of the matrix A required in pivoting, M is a unit lower triangular matrix and D is a symmetric block diagonal matrix consist of a symmetric blocks of maximum order 2, furthermore, if d k +1,k 0, mk +1,k = 0 .Where M = mij , D = d ij and n 1. Parameters ~. X ..... Input .Approximate solution vector x Output. Refined solution vector x. One-dimensional array of size n. A ..... Input. Coefficient matrix A. Matrix A is stored in a one-dimensional array of size n(n+1)/2 in the compressed mode for a symmetric matrix. N ..... Input. Order n of matrix A. See Notes. FA ..... Input. Matrices M and D. See Fig. LSIXR-1.Matrices are stored in a one-dimensional array of size n(n+1)/2. B ..... Input. Constant vector b. One-dimensional array of size n. IP ..... Input. Transposition vector indicating the history of exchanging rows of the matrix A required in pivoting. One-dimensional array of size n. (See Notes.) VW ..... Work area. One-dimensional array of size n ICON .. Output. Condition code. See Table LSIXR-1.
Table LSIXR-1 Condition codes Code 0 20000 25000 Meaning No error Coefficient matrix was singular The convergence condition was not satisfied because of an ill-conditioned coefficient matrix. N=0 Processing Discontinued Discontinued.( See Method for the convergence condition. Bypassed
( )
( )
30000
Comments on use Subprograms used SSL II ... MDMX,MSV,AMACH, MGSSL FORTRAN basic functions ... IABS, ABS Notes This subroutine iteratively improves to get solution ~ obtained by subroutine the approximate solution x ~ with refined precision. LSIX x ~ must Therefore, prior to calling this subroutine, x be obtained by subroutine LSIX and the results must be input as the parameters X, FA and IP for this subroutine. In addition, the coefficient matrix A and constant vector b which are required for this subroutine must also be prepared and stored separately before calling subroutine LSIX. See the Example for details. By specifying N = n, an estimated accuracy ~ given (relative error) for the approximate solution x by subroutine LSIX can be obtained. When specified, this subroutine calculates the relative error and outputs it to work area VW(1) without performing the iterative refinement of accuracy. See the Method for estimation of the accuracy.
440
LSIXR
Example ~ for a system of linear An approximate solution x equations of order n is obtained by subroutine LSIX, then it is iteratively refined by this subroutine. n 100 .
C **EXAMPLE** DIMENSION A(5050), FA(5050), X(100), * B(100), VW(200), IP(100), IVW(100) 10 READ(5,500) N IF (N.EQ.0) STOP NT=N*(N+1)/2 READ(5,510) (A(I), I=1, NT) READ(5,510) (B(I), I=1, N) DO 20 I=1, N X(I)=B(I) 20 CONTINUE DO 30 I=1, NT 30 FA(I)=A(I) EPSZ=0.0E0 ISW=1 CALL LSIX(FA, N, X, EPSZ, ISW, IP, IVW, ICON) WRITE(6,620)ICON IF(ICON. GE. 20000)GO TO 10 CALL LSIXR(X, A, N, FA, B, IP, VW, ICON) WRITE(6,630)ICON IF(ICON. GE. 20000)STOP WRITE(6,640) (I, X(I), I=1, N) GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 620 FORMAT(1H0, 10X, 11HLSIX ICON=, I5) 630 FORMAT(1H0, 10X, 11HLSIXR ICON=, I5) 640 FORMAT(1H0, 10X, 15HSOLUTION VECTOR * /(10X, 4(1H(,I3, 1H), E17.8))) END
where x ( ) is the s-th approximate solution to (4.1). If (4.2) is accurately computed, a refined solution of 1 the approximate solution x ( ) is numerically obtained. If, however, the condition of coefficient matrix A is not suitable, an improved solution is not obtained. (See Section 3.4 Iterative refinement of a solution.)
s
Procedure performed in this subroutine Suppose that the first approximate solution x (1) has already been obtained by subroutine LSIX. Then this subroutine repeats the following steps: s The residual r ( ) is computed by using (4.2). Subroutine MSV is used for this operation. The correction d ( s ) is obtained next by using (4.3). Subroutine MDMX is used for this operation. + Finally the modified approximate solution x ( s 1) is obtained by using (4.4). The convergence of the iteration is tested as follows: Considering u as a unit round-off, the iteration refinement is assumed to converge if, at the s-th iteration step, the following relationship is satisfied. d ( s)
/ x (s
+1)
< 2u
(4.5)
s+ The obtained X ( 1 ) is then taken as the final solution. However, if the relationship,
d( )
s
x(
s+1)
( ) 1 d > (s) 2 x
s 1
the solution is iteratively refined as follows: Principle of iterative refinement The iterative refinement method is to obtain a s succesively improved approximate solution x ( ) to the linear equations (4.1) through use of the following 1 ~ equations starting with x ( ) = x
r ( ) = b Ax ( s) s Ad ( s ) = r ( ) + x ( s 1) = x ( s ) + d ( s ) s = 1,2,
s
results, this indicates that the condition of the coefficient matrix A is not suitable. The iteration refinements is assumed not to converge, and consequently the processing is terminated with ICON=25000. Accuracy estimation for approximate solution Suppose that the error for the approximate solution
x (1) is e (1)
(= x
1
(1 )
by e ( )
1
/ x( )
If this iteration method converges, e ( ) is assumed to 1 be almost equal to d ( ) , therefore the relative error for the approximate solution is estimated by d( )
1
/ x( ) .
1
(See Section 3.4 for details.) For further details, see References [1], [3], and [5].
441
LSTX
a32
CALL LSTX (D, SD, N, B, EPSZ, ISW, ICON) Function A system of linear equations Ax = b (1.1)
Array SD a21 a32 a n,n1
an1,n
an ,n1
ann
is solved by using the modified Choleskys method, where A is an n n positive definite symmetric tridiagonal matrix, b is an n -dimentional real constant vector and x is an n -dimentional solution vector. Also n1. Parameters D ..... Input. Diagonal portion of the coefficient matrix A . After computation, the contents are destroyed. Refer to Fig. LSTX-1. One-dimensional array of size n . SD ..... Input. Subdiagonal portion of the coefficient matrix A . After computation, the contents are destroyed. Refer to Fig. LSTX-1. One-dimensional array of size n -1. N ..... Input. Order n of the coefficient matrix A , the constant vector b and the solution vector x. B ..... Input. Constant vector b . Output. Solution vector x . One-dimensional array of size n. EPSZ ..... Input. Tolerance for relative zero test of pivots ( 0.0) . If EPSZ=0.0, a standard value is used. See Notes. ISW ..... Input. Control information When l ( 1) systems of linear equations with the identical coefficient matrix are to be solved, ISW can be specified as follows: ISW = 1 ... The first system is solved ISW = 2 ... The 2nd to l -th systems are solved. However, only parameter B is specified for the new constant vector b of the systems, with the rest unchanged. See Notes. ICON ..... Output. Condition code. See Table LSTX-1. Comments on use Subprograms used SSL II ... AMACH, MGSSL FORTRAN basic function ... ABS Notes If EPSZ is set to 10-S, this value has the following
Array D a11
a22
a33
ann
Fig. LSTX-1 Storing method for each element of matrix A into arrays SD and D Table LSTX-1 Condition codes Code 0 10000 Meaning No error A negative pivot occurred. The coefficient matrix is not positivedefinite. The zero pivot occurred. It is highly probable that the coefficient matrix is singular. N<1, EPSZ<0.0 or ISW 1, 2 Processing Continued
20000
Discontinued
30000
Bypassed
meaning; while performing the LDLT-decomposition using the modified Cholesky method, if the loss of over s significant digits occurs for the pivot value, the LDLT-decomposition is discontinued with ICON=20000 and the pivot is regarded as zero. Let u be the unit round off, then the standard value of EPSZ is 16 u . If the processing is to proceed even at a low pivot value, EPSX has to be given the minimum value but the result is not always guaranteed. When successively solving systems of linear equations with the identical coefficient matrix, ISW should be set to 2 after solving the first system. With ISW=2, calculation time is reduced since the LUdecomposition of the matrix A is bypassed. The determinant of matrix A can be obtained by multiplying n array elements, D(i ), i = 1, , n .
When the negative pivot occurs in the decomposition, the calculation error may possibly be large since no pivoting is performed in this subroutine.
442
LSTX
This subroutine make use of the characteristics of a matrix when repetitive computations are carried out. As a result this subroutine has a faster processing speed compared to the normal modified Cholesky method although the number of computations are the same. Example This example solves l systems of linear equations in n unknown with an identical coefficient matrix, n 100 .
C **EXAMPLE** DIMENSION D(100), SD(99), B(100) DATA IA, IB, IX/1HA, 1HB, 1HX/ READ(5,500) N,L NM1=N-1 READ(5,510) (D(I), I=1, N), (SD(I), I=1, NM1) WRITE(6,600) N CALL PTM(IA, 1, SD, D, SD, N) ISW=1 M=1 10 READ(5,510) (B(I), I=1, N) CALL PGM(IB, 1, B, N, N, 1) CALL LSTX(D, SD, N, B, 0.0, ISW, ICON) IF(ICON.EQ.0) GO TO 20 WRITE(6,610) ICON STOP 20 CALL PGM (IX, 1, B, N, N, 1) IF (M.EQ.L) GO TO 30 M=M+1 ISW=2 GO TO 10 30 WRITE(6,620) STOP 500 FORMAT(2I3) 510 FORMAT(4E15.7) 600 FORMAT(1H1, 5X, * 34HLINEAR EQUATIONS AX=B(TRIDIAGONAL) * /6X, 20H(POSITIVE, SYMMETRIC) * /6X, 6HORDER=,I5) 610 FORMAT (1H , 5X,13HICON OF LSTX=,I6) 620 FORMAT(1H , 5X,13H* NORMA END *) END
Cholesky method as shown in Eq. (4.2). A = LDLT where L is a unit lower band matrix with band width 1 and D is a positive definite diagonal matrix. Therefore, solving Eq. (4.1) results is solving Eqs. (4.3) and (4.4),
Ly = b
(4.3)
1
L x=D y
T
(4.4)
Eqs. (4.3) and (4.4) can be readily solved by using forward and backward substitutions. Modified Cholesky method If matrix A is positive-definite, the LDLTdecomposition as shown in (4.2) is always possible. The decomposition using the modified Cholesky method is given by lij d j = aij lik d k l jk , j = 1,
k =1 j 1
di = aii
i 1
k =1
lik d k lik
, i 1 , i = 1,, n
(4.5) (4.6)
where A = (aij ) , L = (lij ) and D = diag (di ) . Furthermore, since matrix A is a tridiagonal matrix, Eqs. (4.5) and (4.6) can be rewritten into li ,i1di 1 = ai ,i1 di = aii1di1lii1 (4.7) (4.8)
Subroutines PTM and PGM used in this example print out a real tridiagonal matrix and a real general matrix, respectively. The descriptions of those programs are given in the examples for subroutines LTX and MGSM. Method A linear equations with a positive-definite symmetric tridiagonal matrix, Ax = b (4.1)
Procedure performed in this subroutine This subroutine obtains the solution by considering the characteristics of the matrix. LDLT-decomposition Normally, when matrix A is LDLT-decomposed using the modified Cholesky method, elements li ,i1 and di (i = 1,
is solved by using the modified Choleskys method. Since matrix A is a positive-definite symmetric tridiagonal matrix, the matrix can always be decomposed into the LDLT form by using the modified
Eqs. (4.7) and (4.8). However, this subroutine considers the characteristic of a symmetric tridiagonal matrix, and obtains the elements of matrices L and D recursively, starting with the upper left hand elements together with the lower right hand elements, ending with the middle elements. This fact reduces the number of iterations. Elements l i,i 1 , d i , l n i+1, n i+ 2 and d n i +1 i = 1,
,[(n + 1) / 2])
443
LSTX
Solving LT x = D 1 y (forward and backward substitutions) Normally, the solution is obtained successively by x i = yi d 1 lki x k , i = n,
k = i+1 n
Solving Ly = b (forward and backward substitutions) Normally, the solution is obtained successively by yi = bi lik y k , i = 1,
k =1 i 1
,1
(4.16)
, n
(4.13)
where, x T = ( x1 , , xn ) , and D 1 = diag ( d i1 ). This subroutine successively obtains the solution by Eqs. (4.17), (4.18) and (4.19).
1 x [( n + 1 ) / 2 = y [( n + 1) / 2 ] d [( n +1 )/ 2 ]
where y T = ( y1 , , yn ) , and b T = (b1 , , bn ) . This subroutine successively obtains the solution by Eqs. (4.14) and (4.15). yi = bi li ,i1 yi1 yn i+1 = bn i+1 i = 1,
xi = y i di1
i +1, i
x i+1
x n i+1 = y ni+1 d
(4.14)
n i +1, n i+ 2
n i+1, ni x n i i = [( n + 1) / 2 ] 1,...,1
1 ni +1
,[(n + 1) / 2]
y n i+ 2
(4.15)
444
LSX
CALL LSX (A, N, B, EPSZ, ISW, ICON) Function This subroutine solves a system of linear equations (1.1) using the modified (square root free) Choleskys method. Ax = b (1.1)
A is an n n positive-definite symmetric matrix, b is an n -dimentional real constant vector, and x is the n -dimentional solution vector. n 1. Parameters A ..... Input. Coefficient matrix A . The contents of A are overridden after operation. A is stored in a one-dimensional array of size n(n + 1) / 2 in the compressed mode for symmetric matrices. N ..... Input. Order n of the coefficient matrix A . B ..... Input. Constant vector b . Output. Solution vector x . B is a one-dimensional array of size n. EPSZ ..... Input. Tolerance for relative zero test of pivots in decomposition process of A( 0.0) . When EPSZ is 0.0, a standard value is used. (See Notes.) ISW ..... Input. Control information When l ( 1) systems of linear equations with the identical coefficient matrix are to be solved, ISW can be specified as follows: ISW=1 ... The first system is solved. ISW=2 ... The 2nd to l -th systems are solved. However, only parameter B is specified for each constant vector b of the systems, with the unchanged (See Note.) ICON ..... Output. Condition code. See Table LSX-1.
Table LSX-1 Condition codes Code 0 10000 Meaning No error The negative pivot occured. The coefficient matrix is not positive-definite. The relatively zero pivot occurred. It is highly probable that the coefficient matrix is singular. N<1, EPSX<0.0 or ISW 1, 2 Processing Continued
Comments on use Subprograms used SSL II ... SLDL, LDLX, AMACH, and MGSSL FORTRAN basic functions ... ABS Notes The solution obtained with this subroutine can be refined in accuracy by successively calling subroutine LSXR. If EPSZ is set to 10-S, this value has the following meaning: while performing the LDL T decomposition by modified Choleskys method, if the loss of over s significant digits occurred for the pivot, the LDLT decomposition should be discontinued with ICON=20000 regarding the pivot to be relatively zero. Let u be the unit round off, then the standard value of EPSZ is 16u . If the processing is to proceed even at a low pivot value, EPSZ has to be given the minimum value but the result is not always guaranteed. When successively solving systems of linear equations with the identical coefficient matrix, after solving the first system, ISW. should be set to 2. With ISW=2, calculation time is reduced since the process in which the coefficient matrix A is LDLT decomposed is bypassed. If the negative pivot occurs in the decomposition, the coefficient matrix is not a positive-definite. In this subroutine the condition code is set accordingly (ICON=10000) and processing is continued. However, it should be noted that large calculation error may occur since the pivoting is not performed. The determinant of the coefficient matrix can be obtained by multiplying the n diagonal elements (the diagonal elements of D 1 ) of the array A after the subroutine has been executed and then by determining the inverse number. Note that array A is in the compressed mode for symmetric matrices. When for a positive definite symmetric band matrix, subroutine LSBX processes faster than this subroutine because the operation for the element out of the band is omitted. Example l systems of linear equations in n unknown with the identical coefficient matrix are solved. n 100 .
C **EXAMPLE** DIMENSION A(5050),B(100) READ(5,500)N NT=N*(N+1)/2 READ(5,510)(A(I),I=1,NT) WRITE(6,600)N READ(5,500)L M=1 ISW=1
20000
Discontinued
30000
Bypassed
445
LSX
EPSZ=1.0E-6 10 READ(5,510)(B(I),I=1,N) CALL LSX(A,N,B,EPSZ,ISW,ICON) WRITE(6,610)ICON IF(ICON.GE.20000)STOP WRITE(6,620)(B(I),I=1,N) IF(L.EQ.M) GOTO 20 M=M+1 ISW=2 GOTO 10 20 DET=A(1) L=1 DO 30 I=2,N L=L+I DET=DET*A(L) 30 CONTINUE DET=1.0/DET WRITE(6,630) DET STOP 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1/10X,6HORDER=,I5) 610 FORMAT(1H0,10X,5HICON=,I5) 620 FORMAT(11X,15HSOLUTION VECTOR * /(15X, 5E16.8) 630 FORMAT (1H0,10X, * 34HDETERMINANT OF COEFFICIENT MATRIX= * ,E16.8) END
Method A system of linear equations (4.1) which has a real positive-definite symmetric coefficient matrix is solved using the following procedure. Ax = b (4.1)
LDLT decomposition of coefficient matrix A (Modified Choleskys method) The coefficient matrix A is LDLT decomposed into the form (4.2). A = LDLT (4.2)
where L is a unit lower triangular matric and D is a diagonal matrix. Subroutine SLDL is used for this operation. Solving LDLT x = b (Forward and backward substitution) A system of linear equations LDLT x = b is solved using subroutine LDLX. For more information, see Reference [2]. (4.3)
446
LSXR
D
Diagonal elements are inverted
Matrix { D 1 + ( L I } Array FA
1 d11 1 l2 1 d 22
0
d nn
1 d11
l21
1 d 22
CALL LSXR (X, A, N, FA, B, VW, ICON) Function ~ is given to linear When an approximate solution x equations with an n n positive-definite symmetric matrix A such as Ax = b (1.1)
ln 1
1 ln n1 d nn
n(n + 1) L
Lower triangular portion only
2 ln 1
1 l21 1
ln 1
0
ln n1 1
ln n1
1 d nn
this subroutne refines the approximate solution by the method of iterative modification, where b is an n dimensional real constant vector and x is an ndimensional solution vector. Prior to calling this subroutine, the coefficient matrix A must be LDLT decomposed as shown in Eq. (1.2), A = LDLT (1.2)
Note:
The diagonal and lower triangular sections of the matrix D 1 (L I ) are contained in the one-dimensional array FA in the compressed mode for symmetric matrices.
Fig. LSXR-1 Storage of matrices L and D Table LSXR-1 Condition code Code 0 10000 25000 Meaning No error The coefficient matrix was not positive-definite. The convergence condition was not met because of a very illconditioned coefficient matrix. N=0 Processing continued Discontinued (Refer to method for convergence condition.) By passed
where L and D are an n n unit lower triangular matrix and a diagonal matrix respectively, also n 1. Parameters X ..... Input. Approximate solution vector x Output. Refined solution vector x One-dimensional array of size n . A ..... Input. Coefficient matrix A . Matrix A is stored in one-dimensional array of size n(n + 1) / 2 in the compressed mode for N ..... FA ..... a symmetric matrix. Input. Order n of matrix A. (See Notes.) Input. Matrices L and D 1 . Refer to Fig. LSXR-1. One-dimensional array of size n(n + 1) / 2 to
30000
contain symmetric band matrices in the compressed mode. B ..... Input. Constant vector b . One-dimensional array of size n . VW ..... Work area. One-dimensional array of size n . ICON ..... Output. Condition code. See table LSXR-1. Comments on use Subprograms used SSL II ..... LDLX, MSV, AMACH, MGSSL FORTRAN basic functions ..... ABS Notes This subroutine iteratively improves the approximate solution x obtained by subroutine LSX to get solution x with refined precision. Therefore, prior to calling this subroutine, x must be obtained by subroutine
LSX and the results must be input as the parameters X and FA to be used for this subroutine. In addition, the coefficient matrix A and constant vector b which are required for this subroutine must also be prepared and stored separately before calling subroutine LSX. Refer to the example for details. If N= n is specified, an estimated accuracy (relative error) for the approximate solution x given by the subroutine LSX can be obtained. When specified, this subroutine calculates the relative error and outputs it to work area VW(1) without performing the iterative refinement of precision. See Method for estimation of accuracy. Example An approximate solution x for a system of linear equations in n unknowns is obtained by subroutine LSX, then it is iteratively refined by this subroutine. n 100 .
C **EXAMPLE** DIMENSION A(5050),FA(5050),X(100), * B(100),VW(100) 10 READ(5,500)N IF(N.EQ.0)STOP
447
LSXR
NT=N*(N+1)/2 READ(5,510)(A(I),I=1,NT) READ(5,510)(B(I),I=1,N) DO 20 I=1, N X(I)=B(I) 20 CONTINUE DO 30 I=1,NT 30 FA(I)=A(I) EPSZ=0.0E0 ISW=1 CALL LSX(FA,N,X,EPSZ,ISW,ICON) WRITE(6,620)ICON IF(ICON.GE.20000)GO TO 10 CALL LSXR(X,A,N,FA,B,VW,ICON) WRITE(6,630)ICON IF(ICON.GE.20000)STOP WRITE(6,640)(I,X(I),I=1,N) DET=FA(1) L=1 DO 40 I=2,N L=L+1 40 DET=DET*FA(L) DET=1.0/DET WRITE(6,650)DET GO TO 10 500 FORMAT(I5) 510 FORMAT(4E15.7) 620 FORMAT(1H0,10X,10HLSX ICON=,I5) 630 FORMAT(1H0,10X,10HLSXR ICON=,I5) 640 FORMAT(1H0,10X,15HSOLUTION VECTOR * /(10X,4(1H(,I3,1H),E17.8))) 650 FORMAT(///10X, * 34HDETERMINANT OF COEFFICIENT MATRIX=, * E17.8) END
s where x ( ) is the s-th approximate solution to equation (4.1). If Eq. (4.2) is accurately computed, a refined 1 solution of the approximate solution x ( ) is numerically obtained. If, however, the condition of the coefficient matrix A is not suitable, no improved solution is obtained. (See Section 3.4 Iterative refinement of a solution.)
Procedure performed in this subroutine Suppose that the first approximate solution x (1) has already been obtained by the subroutine repeats the following steps: s The residual r ( ) is computed by using Eq. (4.2) This is done by calling the subroutine MSV. The correction d ( s ) is obtained next by using Eq. (4.3). by calling subroutine LDLX. s+ Finally, the modified approximate solution x ( 1) is obtained by using Eq. (4.4). The convergence of the iteration is tested as follows: Considering u as a unit round off, the iteration refinement is assumed to converge if, at the s-th iteration step, the following relationship is satisfied. d (s)
/ x ( s +1)
< 2u
(4.5)
1 The obtained x ( ) is then taken as the final solution. However, if the relationship, s+
d ( s) x
( s+1)
>
the solution is iteratively refined as follows: Principle of iterative refinement The iterative refinement is a method to obtain a successively improved approximate solution x ( s+1) to the linear equations (4.1) through use of the following ~ equations starting with x (1) = x
r ( ) = b Ax ( ) s s Ad ( ) = r ( ) + s s s x ( 1) = x ( ) + d ( ) s = 1, 2,
s s
( s1) 1 d ( s) 2 x
results, this indicates that the condition of the coefficient matrix A is not suitable. The iteration refinement is assumed not to converge, and consequently the processing is terminated with ICON = 25000. Accuracy estimation for approximate solution 1 Suppose the error for the approximate solution x ( ) is e (1) = x (1) x , its relative error is represented by e (1 )
/ x ( 1)
1 is assumed to be almost equal to d ( ) . The relative error for the approximate solution is therefore 1 estimated by d ( )
/ x ( 1)
Accuracy estimation for approximate solution.) For further details, see References [1], [3], and [5].
448
LTX
CALL LTX (SBD, D, SPD, N, B, EPSZ, ISW, IS IP, VW, ICON) Function A system of linear equations Ax = b (1.1)
Array SBD a21 a32 an ,n1
0
an ,n1
an1,n ann
is solved by using the Gaussian elimination method, where A is an n n real tridiagonal matrix, b is an n-dimensional real constant vector, and x is an n dimensional solution vector. Here n 1. Parameters SBD ..... Input. Lower sub-diagonal portion of the coefficient matrix A . The contents are destroyed after computation. Refer to Fig. LTX-1. One-dimensional array of size n -1. D ..... Input. Diagonal portion of the coefficient matrix A. The contents are destroyed after computation. See Fig. LTX-1. One-dimensional array of size n . SPD ..... Input. Upper sub-diagonal portion of the coefficient matrix A . The contents are destroyed after computation. See Fig. LTX-1. One-dimensional array of size n -1. N ..... Input. Order n of the coefficient matrix A B ..... Input. Constant vector b . Output. Solution vector x . One-dimensional array of size n . EPSZ ..... Input. Tolerance for relative zero test of pivots ( 0.0) If EPSZ = 0.0, a standard value is used. (See Notes.) ISW ..... Input. Control information. When l ( 1) systems of linear equations with the identical coefficient matrix are to be solved, ISW can be specified as follows: ISW=1 ... The first system is solved ISW=2 ... The 2nd to l -th systems are solved. However, only parameter B is specified for the new constant vector b of the system, with the rest unchanged. (See Notes.) Output. Information used to obtain a determinant of matrix A . (See Notes.) Work area. One-dimensional array of size n .
ann Fig. LTX-1 Storing method for each element of matrix A into arrays SBD, D and SPD
VW ..... Work area. One-dimensional array of size n. ICON ..... Output. Condition code. Refer to Table LTX-1.
Table LTX-1 Condition codes Code 0 20000 Meaning No error The negative pivot occurred. It is highly probable that the coefficient matrix is singular. N<1, or EPSZ<0.0 Processing Discontinued
30000
By passed
Comments on use Subprograms used SSL II ... AMACH, MGSSL FORTRAN basic functions ... AMAX1, ABS Notes This subroutine makes decisions on the relative zero of pivots by using a relational equation containing the value of EPSZ. For details, see Method. Let u be the unit round off. The standard value of EPSZ is then 16 u . If the processing is to proceed even at a low pivot value, EPSZ has to be given the minimum value but the result is not always guaranteed. When successively solving systems of linear equations with the identical coefficient matrix, after solving the first system, ISW should be set to 2.
IS .....
IP .....
449
LTX
With ISW=2, the calculation time is reduced since the process in which the coefficient matrix A is LUdecomposed is bypassed. The value of IS the same as when ISW=1. The determinant of the matrix A is obtained by multiplying the n elements, D(i), i=1, ..., n by the value of IS. Example L systems of linear equations with an identical coefficient matrix of order n are solved. n100.
C **EXAMPLE** DIMENSION SBD(99),D(100),SPD(99), * B(100),IP(100),VW(100),NT1(6), * NT2(4),NT3(4) DATA NT1/2HCO,2HEF,2HFI,2HCI, * 2HEN,2HT /, * NT2/2HCO,2HNS,2HTA,2HNT/, * NT3/2HSO,2HLU,2HTI,2HON/ READ(5,500)N,L NM1=N-1 READ(5,510)(SBD(I),I=1,NM1), * (D(I),I=1,N),(SPD(I),I=1,NM1) WRITE(6,600)N CALL PTM(NT1,6,SBD,D,SPD,N) ISW=1 M=1 10 READ(5,510)(B(I),I=1,N) CALL PGM(NT2,4,B,N,N,1) CALL LTX(SBD,D,SPD,N,B,0.0,ISW, * IS,IP,VW,ICON) WRITE(6,610)ICON IF(ICON.NE.0)STOP CALL PGM (NT3, 4, B, N, N, 1) IF (M. EQ. L) GO TO 20 M=M+1 ISW=2 GO TO 10 20 WRITE(6,620) STOP 500 FORMAT(3I2) 510 FORMAT(4E15.7) 600 FORMAT(1H1,5X, * 29HLINEAR EQUATIONS (TRIDIAGONAL) * /6X,6HOLDER=,I5) 610 FORMAT(1H ,5X,12HICON OF LTX=,I5) 620 FORMAT(1H ,5X,13H** NORMAL END) END SUBROUTINE PTM(ICOM,L,SBD,D,SPD,N) DIMENSION ICOM(L),SBD(1),D(N),SPD(1) WRITE(6,600)(ICOM(I),I=1,L) DO 30 I=1,N IF (I.NE.1)GO TO 10 IC=1 WRITE(6,610)I,IC,D(I),SPD(I) GO TO 30 10 IC=I-1 IF(I.NE.N)GO TO 20
The subroutines PTM and PGM are used only to print out a real tridiagonal matrix and a real general matrix. The subroutine PGM is described in the example for the subroutine MGSM. Method A system of linear equations with a real tridiagonal matrix A Ax = b (4.1)
is solved by using the Gaussian elimination method based on partial pivoting. A matrix can be normally decomposed into the product of a unit lower triangular matrix L and an upper triangular matrix U with partial pivoting. A = LU Consequently, solving Eq. (4.1) is equal to solving
Ly = b Ux = y
(4.2)
(4.3) (4.4)
Since both L and U are triangular matrices, Eqs. (4.3) and (4.4) can be readily solved by using back-ward and forward substitutions. Guassian elimination method k Let A( ) represent the matrix at the k-th step (k = 1, , n 1) of the Gaussian elimination method, where A( ) = A . The k-th step of elimination process is represented by
1
A( k
+1)
= M k Pk A( k )
(4.5)
where Pk is a permutation matrix to select a pivot row of the k-th column of the matrix A( ) . The Mk is a matrix to eliminate the element below the diagonal in the k-th column of the permuted matrix, and is given by
k
1 0 1 Mk = m 1 + k 1 ,k 0 1
(4.6)
450
LTX
( )
( 1)
1 1
(4.11)
k +1)
= M n1 Pn1
1
L = ( M n1 Pn1
M P )
1
M P A
1
(4.7) (4.8)
are given by Eq. (4.12). The other elements of matrix k+ A( 1) to which the k + 1st elimination step is applied are equal to the corresponding element of matrix A( ) .
k
matrix A is rewritten as A = LU where L and U are a unit lower triangular matrix and an upper triangular matrix, respectively. Procedure performed in this subroutine [Forward substitution] Eq. (4.9) results from Eq. (4.3) based on Eq. (4.8) y = M n1 Pn1
a k + 1, j = ak + 1 a k , j m k + 1, k
, j = k + 1, k + 2
k
( k + 1)
(k )
(k ) (k )
(4.12)
( ) is Eq. (4.10) is selected as The pivot element a kk follows to minimize the computational errors before this (k ) that reflects scaling factor Vl elimination process. a lk (k ) (k) = max Vl alk as Vl a lk
M P b
1 1
(4.9)
element, where Vl is an inverse of the maximum absolute value element in the l -th row of coefficient matrix A . (k ) satisfies If the selected pivot element a lk
(k) < max aij u alk
where A = (aij ), u unit round off then matrix A is assumed to be numerically singular and the processing is terminated with ICON=20000. [Backward substitution] Eq. (4.4) is obtained iteratively by
( )
y = y(
n)
,n 1)
elimination step, obtains each element of the k -th column of matrix L and k-th row of matrix U by using Eqs. (4.10) and (4.11).
k (k) mk +1,k = a k( +)1,k / a kk
k +2 yk ukj x j / ukk ,k = n, xk = = j k +1
,1 , x )
n T
(4.13)
(4.10)
451
LUIV
Table LUIV-1 Condition codes Code 0 20000 30000 Meaning No error A real matrix was singular. K<N or N<1 or there was an error in IP. Processing Discontinued Bypassed
CALL LUIV (FA, K, N, IP, ICON) Function This subroutine computes the inverse A1 of an n n real general matrix A given in decomposed form PA = LU A1 = U 1 L1 P L and U are respectively the n n lower triangular and unit upper triangular matrices, and P is the permutation matrix which performs the row exchanges in partial pivoting for LU decomposition. n 1 . Parameters FA ..... Input. Matrix L and matrix U . Output. Inverse A1 . FA is a two-dimensional array, FA (K, N). Refer to Fig. LUIV-1. K ..... Input. Adjustable dimension of array FA (N). N ..... Input. Order n of the matrices L and U . IP ..... Input. Transposition vector which indicates the history of row exchanges in partial pivoting. One-dimensional array of size n. ICON ..... Output. Condition code. See Table LUIV-1.
Unit upper triangular matrix
Comments on use Subprograms used SSL II ..... MGSSL FORTRAN basic functions ..... None Notes Prior to calling this subroutine, LU-decomposed matrix must be obtained by subroutine ALU and must be input as the parameters FA and IP to be used for this subroutine. The subroutine LAX should be used for solving linear equations. Obtaining the solution by first computing the inverse matrix requires more steps of calculation, so subroutine LUIV should be used only when the inverse matrix is inevitable. The transposition vector corresponds to the permutation matrix P of PA = LU When performing LU decomposition with partial pivoting. Refer to Nones of the subroutine ALU. Example The inverse of an n n real general matrix is obtained. n 100 .
C **EXAMPLE** DIMENSION A(100, 100), VW(100), IP(100) READ(5,500)N IF(N. EQ. 0)STOP READ(5,510) ((A(I, J), I=1, N), J=1, N) WRITE(6,600)N, ((I, J, A(I, J), J=1, N), I=1, N) CALL ALU(A, 100, N, 0.0, IP, IS, VW, ICON) WRITE(6,610)ICON IF(ICON .GE. 20000)STOP CALL LUIV(A, 100, N, IP, ICON) WRITE(6,620)ICON IF(ICON .GE. 20000)STOP WRITE(6,630) ((I, J, A(I, J), I=1, N), J=1, N) STOP 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(//11X, 16H**INPUT MATRIX**/12X, * 6HORDER=, I5/(2X, 4(1H(,I3, 1H,, I3, 1H), E16.8))) 610 FORMAT(1H0, 10X, 20HCONDITION CODE(ALU)=, I5) 620 FORMAT(1H0, 10X, 21HCONDITION CODE(LUIV)= I5) 630 FORMAT(1H0, 10X, 18H**INVERSE MATRIX**, * /(2X,4(1H(, I3, 1H,, I3, 1H), E16.8))) END
Array FA
l11 l 21 l 22 l 31 l 32 l n1 l n2
0 0 ln1n1 l nn1
lnn
u u
l nn 1
1n
2n
N K
l n 1 n 1 u n 1n l nn
ln1 l n2
452
LUIV
Method This subroutine computes the inverse of an n n real general matrix, giving the LU-decomposed matrices L , U and the permutation matrix P which indicates row exchanges in partial pivoting. PA = LU (4.1)
(4.7)
then, the inverse of A can be represented using (4.1) as follows: The inverse of L and U are computed and then the inverse of A is obtained as (4.2). A1 = (P 1 LU ) = U 1 L1P
1
k =1
(4.8)
(4.2)
L and U are as shown in Eq. (4.3) for the following explanation. L = (lij ) , U = (uij ) (4.3)
column ( j = n,
,2)
Calculating L1 Since the inverse L1 of a lower triangular matrix L is also a lower triangular matrix, if we represent L1 by ~ L1 = lij
j 1 ~ = u ~ , i = j 1, u uik u ij ij kj k =i +1
,1
(4.9)
()
Calculating U 1 L1 P Let the product of matrices U 1 and L1 be B , then its elements bij are obtained by
n ~~ bij = u l , i = 1, ik kj k= j n
(4.4)
, j 1 ~~ b = u l , i = j, ,n
ij k =i ik kj
k =1
1, i = j ij = 0, i j (4.5) is rewritten as
i 1
( j = 1, ,n) of
n ~~ bij = u l , ik kj k= j
B are obtained by i = 1,
, j 1
(4.10)
k=j
~ n ~~ bij = lij + u l , i = j, ik kj
k =i +1
,n
~ and the elements lij of the j -th column ( j = 1, ,n) of the matrix L1 are obtained as follows:
i 1 ~ ~ lij = lik lkj /lii , i = j + 1, ,n k= j ~ l jj = l / l jj
,n)
(4.6)
Next, matrix B is multiplied by the permutation matrix to obtain the inverse A1 . Actually however, based on the values of the transposition vector IP , the elements of A1 are obtained simply by exchanging the column in the matrix B . The precision of the inner products in (4.6), (4.9)m and (4.10) has been raised to minimize the effect of rounding errors. For more information, see Reference [1].
Calculation U 1 Since the inverse U 1 of a unit upper triangular matrix U is also a unit upper triangular matrix, if we represent U 1 by 453
LUX
CALL LUX (B, FA, K, N, ISW, IP, ICON) Function This subroutine solves a system of linear equations LUx = Pb (1.1)
Array FA
L and U are, respectively, the lower triangular and unit upper triangular matrices, P is a permutation matrix which performs row exchange with partial pivoting for LU decomposition of the coefficient matrix, b is an n-dimentional real constant vector, and x is an n-dimentional solution vector. Instead of equation (1.1), one of the following can be solved.
Ly = Pb Uz = b
0
ln1n1 lnn 1
l nn
u l l u u
l11 u12 u13
21 22 23
1n
2n
l n1 l n 2
l n 1n 1 un 1n l nn1 l nn
N K
(1.2) (1.3)
Parameters B ..... Input. constant vector b Output. One of solution vector x , y or z B is a one-dimensional array of size n . FA ..... Input. Matrix L and matrix U . See Fig. LUX-1. FA is a two-dimensional array, FA (K, N). K ..... Input. Adjustable dimension of array FA (N) N ..... Input. The order n of matrices L and U . ISW ..... Input. Control information. ISW=1 ... x is obtained. ISW=2 ... y is obtained. IsW=3 ... z is obtained. IP ..... Input. The transposition vector which indicates the history of the row exchange in partial pivoting. IP is a one-dimensional array of size n (See Notes of subroutine ALU). ICON ..... Output. Condition code. See Table LUX-1.
Table LUX-1 Condition codes Code 0 20000 30000 Meaning No error The coefficient matrix was singular. K<N, N<, ISW1,2,3, or there was an error in IP. Processing Discontinued Bypassed
Comments on use Subprograms used] SSL II ..... MGSSL FORTRAN basic functions ..... none Notes A system of linear equations can be solved by first calling the subroutine ALU to decompose the coefficient matrix into L and U and by then calling this subroutine. However, instead of both these subroutines, the subroutine LAX can be called to solve such equations in one step. Example A system of linear equations is solved by first using subroutine ALU to decompose the n n coefficient matrix into L and U, n100.
C 10 **EXAMPLE** DIMENSION A(100,100),B(100),VW(100),IP(100) READ(5,500)N IF(N .EQ. 0) STOP READ(5,510) ((A(I, J), I=1, N), J=1, N) READ(5,510) (B(I), I=1, N) WRITE(6,600) N, ((I, J, A(I, J), J=1, N), I=1, N) WRITE(6,610) (I, B(I), I=1, N) CALL ALU(A, 100, N, 1.0E-6, IP, IS, VW, ICON) WRITE(6,620) ICON IF(ICON .GE. 20000) GO TO 10 CALL LUX(B, A, 100, N, 1, IP, ICON) WRITE(6,630)ICON IF(ICON .GE. 20000) GO TO 10 WRITE(6,640) (I, B(I), I=1,N) GO TO 10 FORMAT(I5) FORMAT(4E15.7) FORMAT(///10X, 22H**COEFFICIENT MATRIX**
454
LUX
* /12X, 6HORDER=, I5, ?(10X, 4(1H(, I3, 1H,, I3, 1H) * , E16.8))) 610 FORMAT(1H0, 10X, 15HCONSTANT VECTOR */(10X, 5(1H(, I3, 1H), E16.8))) 620 FORMAT(1H0, 10X, 14HCONDITION(ALU) * ,I5) 630 FORMAT(1H0, 10X, 14HCONDITION(LUX) * , I5) 640 FORMAT(1H0, 10X, 15HSOLUTION VECTOR * /(10X, 5(1H(, I3,1H), E16.8))) END
where L = lij . y T = ( y1 ,
()
, y ),( Pb)
n
,n
(4.4)
T
= (b1 ,
, b' )
n
Method A system of linear equations LUx = Pb can be solved by solving following equations
Ly = Pb Ux = y
Solving Ux = y (backward substitution) Ux = y can be serially solved using equations (4.5). xi = yi uik x k ,i = n, where, U = (uij ),x T
k =i +1 n
(4.1)
,1 = ( x , ,x )
1 n
(4.5)
(4.2) (4.3)
Precision of the inner products in (4.4) and (4.5) has been raised to minimize the effect of rounding error. For more information, see References [1], [2], [3], and [4].
455
MAV
CALL MAV (A, K, M, N, X Y, ICON) Function This subroutine performs multiplication of an m n real matrix A and a vector x .
y = Ax
See the example in Comments on use below. Example This example shows the program that solves a linear equations (3.4) with subroutine LAX and that obtains a residual vector b Ax through the solution, when n 100 . Ax = b
C
(3.4)
where, x is an n -dimensional vector and y is an mdimensional vector, m and n 1. Parameters A ..... Input. Matrix A , two-dimensional array, A (K, N). K ..... Input. The adjustable dimension of array A , (M). M ..... Input. The number of rows of matrix A . N ..... Input. The number of columns of matrix A . X ..... Input. Vector x , one dimensional array of size n . Y ..... Output. Multiplication y of matrix A and vector x , one-dimensional array of size m . ICON ..... Output. Condition codes. See Table MAV-1.
Table MAV-1 Condition code Code 0 30000 Meaning No error M<1, N=0 or K<M Processing Bypassed
Comments on use Subprograms used SSL II ..... MGSSL FORTRAN basic function ... IABS Notes This subroutine mainly consists of the computation.
y = Ax
(3.1)
**EXAMPLE** DIMENSION A(100,100),X(100),Y(100),VW(100), * IP(100), W(100, 100) READ(5,500)N READ(5,510) ((A(I, J), I=1, N), J=1, N) READ(5,510) (X(I), I=1, N) WRITE(6,600) N WRITE(6,610) ((I, J, A(I, J), J=1, N), I=1, N) WRITE(6,620) (I, X(I), I=1, N) EPSZ=1.0E-6 ISW=1 DO 10 I=1, N Y(I)=X(I) DO 10 J=1, N W(J, I)=A(J, I) 10 CONTINUE CALL LAX(A,100,N,X,EPSZ,ISW,IS,VW,IP, * ICON) WRITE(6,630) (I, X(I), I=1, N) CALL MAV(W, 100, N, -N, X, Y, ICON) IF(ICON .NE. 0) GOTO 30 WRITE(6,640) (I, Y(I), I=1, N) DN=0.0 DO 20 I=1, N DN=DN+Y(I) *Y(I) 20 CONTINUE DN=SQRT(DN) WRITE(6,650) DN 30 WRITE(6,660) ICON STOP 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1, 18HCOEFFICIENT MATRIX * /1H, 6HORDER=, I5) 610 FORMAT(/4(1H ,1H(,I3, 1H,,I3, 1H), E17.8)) 620 FORMAT(/1H ,15HCONSTANT VECTOR * /(10X, 4(1H(,I3, 1H), E17.8))) 630 FORMAT(/1H, 15HSOLUTION VECTOR * /(10X, 4(1H(, I3, 1H), E17.8))) 640 FORMAT(/1H, 15HRESIDUAL VECTOR * /(10X, 4(1H(,I3, 1H), E17.8))) 650 FORMAT(/1H ,5HNORM=, E17.8) 660 FORMAT(/1H ,5HICON=, I5) END
(3.2)
Method This subroutine performs multiplication y = ( yi ) of an vector x = ( x j ) through using the equation (4.1). m n real matrix A = (aij ) and an n -dimensional
by specifying N= n and giving an arbitrary vectory y' to the parameter Y. This method can be used to compute a residual vector of linear equations such as r = b Ax (3.3)
456
MAV
yi = aij x j ,i = 1, ,m
j =1
(4.1)
In this subroutine, precision of the sum of products in (4.1) has been raised to minimize the effect of rounding errors.
457
MBV
y = y' Ax
CALL MBV (A, N, NH1, NH2, X, Y, ICON) Function This subroutine performs multiplication of an n n band matrix A with lower band width h1 and upper band width h2 by a vector x
y = Ax
by specifying N= n and giving an arbitary vector y' to the parameter Y. In practice, this method can be used to compute a residual vector of linear equations (Refer to the example shown below). Example The linear equations with an m n matrix of lower band with h1 and upper band width h2 . Ax = b is solved by calling the subroutine LBX1, and then the residual vector b Ax is computed with the resultant. Here n 100 , h1 20 and h2 20 .
C **EXAMPLE** DIMENSION A(4100), X(100), IP(100), * FL(1980), VW(100), Y(100), W(4100), * NT1(6), NT2(4), NT3(4), NT4(4) DATA NT1/2HCO, 2HEF, 2HFI, 2HCI, * 2HEN, 2HT /, * NT2/2HCO, 2HNS, 2HTA, 2HNT/, * NT3/2HSO, 2HLU, 2HTI, 2HON/, * NT4/2HRE, 2HSI, 2HDU, 2HAL/ READ(5,500) N, NH1, NH2 WRITE(6,600) N, NH1, NH2 IF(N.LE.0.OR.NH1.GE.N.OR.NH2.GE.N) STOP NT=MIN0(N,NH1+NH2+1) READ(5,510) (A(I), I=1, NT) CALL PBM (NT1, 6, A, N, NH1, NH2) READ(5,510) (X(I), I=1, N) CALL PGM (NT2, 4, B, N, N, 1) DO 10 I=1, NT 10 W(I)=A(I) DO 20 I=1, N 20 Y(I)=X(I) CALL LBX1(A, N, NH1, NH2, X, 0.0, 1, IS, * FL, VW, IP, ICON) IF (ICON.GE.20000) GO TO 30 CALL PGM (NT3, 4, X, N, N, 1) CALL MBV (A, -N, NH1, NH2, X, Y, ICON) IF(ICON.NE.0) GO TO 30 CALL PGM (NT4, 4, Y, N, N, 1) RN=0.0 DO 25 I=1, N 25 RN=RN+Y(I)*Y(I) RN=SQRT(RN) WRITE(6,610) RN STOP 30 WRITE(6,620) ICON STOP 500 FORMAT(3I5) 510 FORMAT(10F8.3) 600 FORMAT(1H1, 14HBAND EQUATIONS * /5X, 6HORDER=, I5 * /5X, 19HSUB-DIAGONAL,LINES=, I4 * /5X, 21HSUPER-DIAGONAL, LINES=, I4) 610 FORMAT(1H ,4X, 14HRESIDUAL NORM=, E17.8) 620 FORMAT (1H ,4X, 5HICON=, I5) END
(1.1)
where x and y are both an n-dimensional vectors. Also, n > h1 0 and n > h2 0 . Parameters A ..... Input. Matrix A . Compressed mode for a band matrix. One-dimensional array of size n min(h1 + h2 + 1, n) Input. Order n of the matrix A . (See Notes.) NH1 ..... Input Lower band width h1 . NH2 ..... Input Upper band width h2 . X ..... Input. Vector x . One-dimensional array of size n . Y ..... Output. Vector y One-dimensional array of size n . ICON ..... Output. Condition code. See the Table MBV-1.
Table MBV-1 Condition code Code 0 30000 Meaning No error N=0, n NH1, n NH2 , Processing Bypassed
N .....
Comments on use Subprograms used SSLII ... MGSSL FORTRAN basic functions ... IABS, MIN0 Notes This subroutine mainly consists of the computation
y = Ax
(3.1)
458
MBV
The subroutines PBM and PGM are used in this example only to print out a band matrix and a real general matrix respectively. The description of the two programs are shown in the example for the subroutines LBX1 and MGSM, respectively. Method This subroutine performs multipuliation y = ( y i ) ,of an n n band matrix A = (aij ) with lower band width h1 x = ( x j ) through using the Eq. (4.1). and upper band width h2 by an n -dimentional vector
yi = aij x j ,i = 1,
j =1
,n ,n
(4.1)
However, this subroutine recognizes that the matrix is a band matrix and the actual computation is done by yi =
man ( i + h2 ,n ) j =man ( 1,i h1 )
aij x j ,i = 1,
(4.2)
This subroutine performs the product sum calculation in Eq. (4.2) with higher precision in order to minimize the effect of rounding errors.
459
MCV
CALL MCV (ZA, K, M, N, ZX, ZV, ICON) Function This subroutine performs multiplication of an m n complex matrix A by a complex vector x
y = Ax
Refer to the example in Comments on use below. Example In this example, the n -dimensional linear equations with complex coefficients. Ax = b are solved by calling the subroutine LCX, and then the residual vector b Ax is obtained through the solution. Here n 50 .
C **EXAMPLE** DIMENSION ZA (50,50),ZX (50),ZY (50), * ZVW (50), IP(50), ZW(50, 50), * NT1(6), NT2(4), NT3(4), NT4(4) COMPLEX ZA, ZX, ZY, ZVW, ZW DATA NT1/2HCO, 2HEF, 2HFI, 2HCI, * 2HEN, 2HT /, * NT2/2HCO, 2HNS, 2HTA, 2HNT/, * NT3/2HSO, 2HLU, 2HTI, 2HON/, * NT4/2HRE, 2HSI, 2HDU, 2HAL/ READ(5,500) N IF (N.LE.0) STOP READ(5,510)((ZA(I, J), I=1, N), J=1, N) WRITE(6,600) N CALL PCM (NT1, 6, ZA, 50, N, N) ISW=1 EPSZ=1.0E-6 READ(5,510) (ZX(I), I=1, N) CALL PCM (NT2, 4, ZX, N, N, 1) DO 10 I=1, N ZY(I)=ZX(I) DO 10 J=1, N ZW(J, I)=ZA(J, I) 10 CONTINUE CALL LCX(ZA, 50, N, ZX, EPSZ, ISW, IS, * ZVW, IP, ICON) IF(ICON.GE.20000) GO TO 30 CALL PCM (NT3, 4, ZX, N, N, 1) CALL MCV (ZW, 50, N, -N, ZX, ZY, ICON) IF (ICON .NE. 0) GO TO 30 CALL PCM (NT4, 4, ZY, N, N, 1) RN=0.0 DO 20 I=1, N CR=REAL (ZY(I)) CI=IMAG (ZY(I)) RN=RN+CR*CR+CI*CI 20 CONTINUE RN=SQRT (RN) WRITE (6,610) RN STOP 30 WRITE(6,620) ICON STOP 500 FORMAT(I5) 510 FORMAT(5(2F8.3)) 600 FORMAT(1H1,24HCOMPLEX LINEAR EQUATIONS * /5X, 6HORDER=, I5) 610 FORMAT(1H , 4X, 14HRESIDUAL NORM=, E17.8) 620 FORMAT(1H , 4X, 5HICON=, I5) END
(1.1)
where, x is an n -dimensional complex vector, y is an m -dimensional complex vector and m , n 1 . Parameters ZA ..... Input. Matrix A Two-dimensional array, ZA (K, N) K ..... Input. Adjustable dimension of array ZA (M) M ..... Input. Row number m of matrix A N ..... Input. Column number n of matrix A . (Refer to Comments on use.) ZX ..... Input. Complex vector x One-dimensional array of size n . ZY ..... Output. Multiplication y of matrix A complex vector x One-dimensional array of size m ICON ..... Output. Condition code. Refer to Table MCV-1.
Table MCV-1 Condition code Code 0 30000 Meaning No error M<1, n=0 or K<M Processing Bypassed
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... IABS Notes This subroutine mainly consists of the computations,
y = Ax
(3.1)
(3.2)
by specifying N= n and giving an arbitrary vector y' to the parameter ZY. This method can be used to compute a residual vector of linear equations.
460
MCV
SUBROUTINE PCM (ICOM, L, ZA, K, M, N) DIMENSION ZA (K, N), ICOM(L) COMPLEX ZA WRITE(6,600) (ICOM(I), I=1, L) DO 10 I=1, M WRITE(6,610) I, (J, ZA(I, J), J=1, N) 10 CONTINUE RETURN 600 FORMAT(1H , 35A2) 610 FORMAT(1H , 1X, I3, 2(I3, 2E17.7) */(5X, 2(I3, 2E17.7))) END
,m
(4.1)
The subroutine PCM is used in this example only to print out a complex matrix.
This subroutine reduces rounding errors as much as possible by performing the inner product computation, Eq. (4.1), with higher precision.
461
MDMX
Table MDMX-1 Condition codes Code 0 20000 30000 Meaning No error Coefficient matrix was singular. N<1, or an error was found in IP. Processing Discontinued Bypassed
CALL MDMX (B, FA, N, IP, ICON) Function This subroutine solves a system of linear equations with an MDMT-decomposed real indefinite symmetric matrix, where M is a unit lower triangular matrix, D is a symmetric block diagonal matrix consisting of symmetric blocks at most of order 2, P is a permutation matrix (which exchanges rows of the coefficient matrix based on pivoting for MDMT-decomposition), b is an n -dimensional real constant vector, and x is an n dimensional solution vector. If d k +1,k 0 , then, m k +1,k = 0 , and n 1 . Parameters B ..... Input. Constant vector b. Output. Solution vector x . One-dimensional array of size n . FA ..... Input. Matrices M and D See Fig. MDMX-1 One-dimensional array of size n(n + 1) / 2 . N ..... Input. Order n of the matrices M and D , constant vector b and solution vector x . IP ..... Input. Transposition vector that indicates the history exchanging rows based on pivoting. One-dimensional array of size n . ICON ..... Output. Condition code. See Table MdMX-1.
Block diagonal matrix D Array FA
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... IABS Notes A system of linear equations can be solved by calling the subroutine SMDM first to MDMT-decompose the coefficient matrix prior to calling this subroutine. However, such equations can be solved by calling the subroutine LSIX in one step. The input parameters FA and IP to this subroutine are the same as the output parameters A and IP of the subroutine SMDM. Example A system of linear equations is solved after MDMTdecomposing an n n real symmetric matrix by calling the subroutines SMDM. Where n 100 .
C **EXAMLE** DIMENSION A(5050), B(100), VW(200), IP(100), * IVW(100) DATA IA, IB, IX/1HA, 1HB, 1HX/ READ(5,500) N NT=(N*(N+1))/2 READ(5,510) (A(I), I=1, NT) WRITE(6,600) N CALL PSM(IA, 1, A, N) EPSZ=0.0 CALL SMDM (A, N, EPSZ, IP, VW, IVW, ICON) WRITE(6,610) ICON IF(ICON .GE. 20000) STOP READ(5,510) (B(I), I=1, N) CALL PGM (IB, 1, B, N, N, 1) CALL MDMX (B, A, N, IP, ICON) WRITE(6,620) ICON IF(ICON .GE. 20000) STOP CALL PGM (IX, 1, B, N, N, 1) STOP 500 FORMAT(I3) 510 FORMAT(4E15.7) 600 FORMAT(1H1 * /6X, 21HLINEAR EQUATIONS AX=B * /6X, 6HORDER=, I4) 610 FORMAT(1H , 5X, 13HICON OF SMDM=, I6) 620 FORMAT(1H , 5X, 13HICON OF MDMX=, I6) END
0 0 d33
d11 d 21 m 31
d12 d 22 m32
00 d33
0 1 0 0 1 m 31 m32 1 Note: The diagonal portion and the lower triangular portion of the matrix D+(M-1) are stored in the one-dimensional array FA in compressed mode for a symmetrical matrix. In this case D consists of blocks of order 2 and 1.
d33
462
MDMX
The subroutines PSM and PGM in this example are used only to print out a real symmetric matrix and a real general matrix, respectively. These programs are described in the example for subroutine MGSM. Method Solving a system of linear equations with an MDMTdecomposed real symmetric matrix. P 1 MDM T (P T ) x = b
1
where
( ,x ),( Pb)
( 1)
n
= (b'1 ,
,b' )
n
Solving DX ( 2 ) = X (1) For a 1 1 pivot, it can be serially solved using eq. (4.8).
2 1 x i( ) = x i( ) / ii ,i = 1,
(4.1)
,n
(4.8)
(P )
If, however, the i-th iteration uses a 2 2 pivot, 2 x i and x i(+1) are both obtained using Eq. (4.9) and after
(2)
x=x
( 3)
( = (x
i +1
( 1)
(4.9)
where M is a unit lower triangular matrix, D is a symmetric block diagonal matrix consisting of symmetric blocks at most of order 2, b is a constant vector, and x is a solution vector. This subroutine assumes that M and D are both decomposed by the block diagonal pivoting method, and P is a permutation matrix. (For details, see Method for the subroutine SMDM.) Solving Mx (1) = Pb (back substitution) For a 1 1 pivot (i.e., if the order of the block of D is 1), it can be serially solved using Eq. (4.6). x i = bi mik x k ,i = 1,
k =1
,xn2
( )
Solving M T x ( 3) = x ( 2 ) (forward substitution) For a 1 1 pivot, it is serially solved using eq. (4.10) xi( 3) = xi( 2 ) mki x k( 3)
n k =i +1
,i = n, ,1
(4.10)
3
(1 )
i 1
( 1)
,n
(4.6)
If, however, the i -th ineration uses a 2 2 pivot (i.e., 1) is obtained using the order of matrix D block is 2), x i(+1 Eq. (4.7), preceded by x i( ) , and after that (i + 2) -th step
1
(4.11)
is computed.
1) = b' i + 1 mik x k(1 ) x i(+ 1 k =1 i 1
( 3) T ( 3) where x = x1 ,
1
( ,x )
( 3)
n
(4.7)
Solving (P T ) x = x ( 3)
3 The vector x ( ) is multipled by the permutation matrix to obtain the element x1 of the solution vector x. 3 In practice, however, the elements of the vector x ( ) have only to be exchanged by referencing the value of the transposition vector IP . Precision of the inner products in this subroutine has been raised to minimize the effect of rounding errors.
463
MGGM
CALL MGGM (A, KA, B, KB, C, KC, M, N, L, VW, ICON) Function This subroutine performs multiplication of an m n real general matrix A by an n l real general matrix B . C = AB where, C is an m l real matrix. m,n,l 1 . Parameters A ..... Input. Matrix A, two-dimensional array, A (KA, N). KA ..... Input. The adjustable dimension of array A , (M). B ..... Input. Matrix B, two-dimensional array, B (KB, L). KB ..... Input. The adjustable dimension of array B , (N). C ..... Output. Matrix C, two-dimensional array, C(KC, L). (Refer to Comments on use.) KC ..... Input. The adjustable dimension of array C , (M). M ..... Input. The number of rows m in matrix A and C . N ..... Input. The number of columns n in matrix A and the number of rows n in matrix B . L ..... Input. The number of columns l in matrices B and C . VW ..... Work area. A one-dimensional array of size n. ICON ..... Output. Condition codes. Refer to Table MGGM-1.
Table MGGM-1 Condition code Code 0 30000 Meaning No error M<1, N<1, L<1, KA<M, KB<N, or KC<M Processing Bypassed
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... None Notes Saving the storage area. The contents of array A are not required to be reserved, the subroutines can be called to save the storage area as follows: CALL MGGM (A, KA, B, KB, A, KA, M, N, L, VW, ICON) In this case, matrix C is stored in array A. However, user must declare the array A as A (KA, L) instead of A (KA, N). Example The following shows an example of obtaining the multiplication of matrices A and B . Here, m 50 , n 60 , and l 30 .
C **EXAMPLE** DIMENSION A (50, 60), B(60, 30), C(50, 30), * VW(60) DATA IA/1HA/,IB/1HB/,IC/1HC/ DATA KA/50/,KB/60/,KC/50/ 10 READ(5,100) M, N, L IF (M.EQ.0) STOP WRITE(6,150) READ(5,200) ((A(I, J), I=1,M),J=1, N) READ(5,200) ((B(I, J),I=1,N),J=1,L) CALL MGGM (A, KA, B, KB, C, KC, M, N, L, VW, * ICON) IF(ICON.NE.0) GOTO 10 CALL PGM (IA, 1, A, KA, M, N) CALL PGM (IB, 1, B, KB, N, L) CALL PGM (IC, 1, C, KC, M, L) GOTO 10 100 FORMAT (3I5) 200 FORMAT (4E15.7) 150 FORMAT(1H1///10X, * 27H** MATRIX MULTIPLICATION **) END
Subroutine PGM in the example is for printing a real matrix. This program is shown in the example for subroutine MGSM.
464
MGSM
CALL MGSM (A, KA, B, C, KC, N, VW, ICON) Function This subroutine performs multiplication of an n n real general matrix A by an n n real symmetric matrix B . C = AB where, C is an n n real matrix, n 1 . Parameters A ..... Input. Matrix A, two-dimensional array, A (KA, N). KA ..... Input. The adjustable dimension of array A , (N). B ..... Input. Matrix B stored in the compressed mode, one dimensional array of size n(n + 1) / 2 . Output. Matrix C two-dimensional array, C(KC, N). (See Comments on use.) KC ..... Input. The adjustable dimension of array C , (N). N ..... Input. The number of columns n of matrices A , B and C . VW ..... Input. The order n of matrices A , B and C . ICON ..... Output. Condition codes. See Table MGSM1.
Table MGSM-1 Condition code Code 0 30000 Meaning No error N<1,KA<N or KC<N Processing Bypassed
Example The following shows an example of obtaining the multiplication C of a real matrix A by a real symmetric matrix B . Now, the matrix C is overwritten in the same area for A . n<100.
C **EXAMPLE** DIMENSION A(100, 100), B(5050), VW(100) DATA IA/1HA/,IB/1HB/,IC/1HC/ 10 READ(5,100)N IF(N.EQ.0) STOP WRITE(6,150) NT=N*(N+1)/2 READ(5,200) ((A(I,J),J=1,N),I=1,N) READ(5,200) ((B(I),I=1, NT) CALL PGM(IA, 1, A, 100, N, N) CALL PSM (IB, 1, B, N) CALL MGSM (A, 100, B, A, 100, N, VW, ICON) WRITE(6,250) ICON IF(ICON.NE.0) GOTO 10 CALL PGM(IC, 1, A, 100, N, N) GOTO 10 100 FORMAT(I5) 200 FORMAT(4E15.7) 150 FORMAT(1H1///10X, * 33H** C=A*B GENERAL BY SYMMETRIC **) 250 FORMAT(//10X, 13H** MGSM ICON=, I5) END C ** MATRIX PRINT (REAL NON-SYMMETRIC)** SUBROUTINE PGM (ICOM, L, A, K, M, N) DIMENSION A(K, 1), ICON(1) WRITE(6,600) (ICOM(I), I=1, L) DO 10 I=1, M WRITE(6,610) I, (J, A(I, J), J=1, N) 10 CONTINUE RETURN 600 FORMAT(/10X, 35A2) 610 FORMAT(/5X, I3, 3(4X, I3, E17.7), * (/8X, 3(4X, I3, E17.7))) END C ** MATRIX PRINT (REAL SYMMETRIC) ** SUBROUTINE PSM (ICOM, L, A, N) DIMENTION A(1), ICON(1) WRITE(6,600) (ICON(I), I=1, L) LS=1 LE=0 DO 10 I=1, N LE=LE+I WRITE(6,610) I, (A(J), J=LS, LE) 10 LS=LE+1 RETURN 600 FORMAT (/10X, 35A2) 610 FORMAT(/5X, I3, 3(4X, E17.7), * (/8X, 3(4X, E17.7))) END
C .....
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic function ... none Notes Saving the storage area: When the contents of array A is not required to be reserved, the subroutines can be called to save the storage area as follows: CALL MGSM(A, KA, B, A, KA, N, VW, ICON) In this case, matrix C is stored in the general mode in array A .
Subroutines PGM and PSM in the example are for printing the real and real symmetric matrices.
465
MINF1
Diagonal matrix D
Matrix D + (L - I)
Array H
1 d11
CALL MINF1 (X, N, FUN, EPSR, MAX, F, G, H, VW, ICON) Function Given a real function f ( x ) of n variables and an initial vector x0 , the vector x* which gives a local minimum x* of f ( x ) and its function value f (
d11 d22 00
00
d nn
1 d11
1 00 l21 d22 1 l l d n1 nn 1 nn
l 22
1 d22
) are obtained by
using the revised quasi-Newton method. The f ( x ) is assumed to have up to the second continuous partial derivative, and n1. Parameters X ..... Input. Initial vector x0 . Output. Vector x * . One-dimensional array of size n. N ..... Input. Number of variables n. FUN ... Input. Name of function subprogram which calculates f ( x ) . The form of subprogram is as follows: FUNCTION FUN(X) where X .....Input. Arbitrary variable vector x . One-dimensional array of size n. The function FUN should be assigned with the value of f ( x ) . (See the example below.) EPSR ... Input. Convergence criterion (0.0) When EPSR=0.0, a standard value is used. See Note. MAX ... Input. Upper limit or number of evaluations for the function ( 0) . See Note. Output. Number of times actually evaluated (>0). Output. Value of the function f ( x* ) . Output. Gradient vector at x* . One-dimensional array of size n. Output. Hessian matrix at x* . This is decomposed as LDLT and stored in compressed storage mode for a symmetric matrix. See Fig. MINF1-1. One-dimensional array of size n(n+ 1) / 2 .
1 l 1 21 l n1
lnn 1 1
0 0
Note: The approximate Hessian matrix is decomposed as LDLT, and after computation, the diagonal and lower triangular -1 portions of the matrix, D +(L-I), are stored into the onedimensional array H in compressed storage mode for a symmetric matrix. Fig. MINF1-1 Storage Hessian matrix Table MINF1-1 Condition code Code 0 10000 Meaning No error Convergence condition was not satisfied within the specified number of evaluations of the function. During computation, 9kTPk0 occurred, so the local decrement of the function was not attained. See Eq. (4.5) in Method. EPSR was too small or the error of difference approximation for a gradient vector exceeded the limit. N<1, EPSR<0.0 or M=0 Processing Parameters X, F, G and H each contains the last value obtained. Discontinued (Parameters X and F each contains the last value obtained.)
20000
30000
Bypassed
Comments on use Subprograms used SSL II ... LDLX, UMLDL, AMACH and MGSSL FORTRAN basic functions ... ABS, SQRT, AMAX1 and AMIN1 Notes The program which calls this subroutine must have an EXTERNAL statement for the function program name that corresponds to the argument FUN. Giving EPSR The subroutine tests convergence by xk +1 x k
VW .....
Work area. One-dimensional array of size 3 n+ 1. ICON ..... Output. Condition code. See Table MINF1-1.
. , xk max 10
) EPSR
466
MINF1
for the iteration vector xk and if the above condition is satisfied, xk +1 is taken as the local minimum point x* and the iteration is terminated. The subroutine assumes that function f ( x ) is approximately quadratic in the region of the local minimum point x* . If the function value f ( x * ) is to be obtained as accurate as the unit round off, EPSR u , u is the unit round off is satisfactory. The standard value of EPSR is 2N u Giving MAX The number of evaluations of a function is calculated by the number of f ( x ) for variable vector x. It corresponds to the number of calling subprogram FUN. The number of evaluations of a function depends on characteristics of the function in addition to the initial vector and a convergence criterion. Generally, for good initial vector, if a standard value is used as the convergence criterion, MAX=400 n is appropriate. If the convergence condition is not satisfied within the specified number of evaluations and the subroutine is returned with ICON=10000, the iteration can be continued by calling the subroutine again. In this case parameter MAX is specified with a negative value for an additional evaluation number, and the contents of other parameters must be kept intact. Example The global minimum point x* for f ( x ) = (1 x1 ) + 100 x2 x1
2
OBJECTIVE FUNCTION FUNCTION ROSEN(X) DIMENSION X(2) ROSEN=(1.0-X(1))**2+100.0* * (X(2)-X(1)*X(1))**2 RETURN END
Method Given a real function f ( x ) of n variables and an initial vector x0, the vector x* which gives a local minimum of f ( x ) and its function value f ( x * ) are obtained by using the revised quasi-Newton method. The subroutine obtains the gradient vector g of f ( x ) by using difference formula. Revised quasi-Newton method When the function f ( x ) is quadratic, its Taylor series expansion in the region of the local minimum point x* is given by f ( x ) = f ( x* ) +
T 1 x x* ) B( x x * ) ( 2
(4.1)
where B is a Hessian matrix of f ( x ) at the point x* . If the matrix B is positive definite, Eq. (4.1) has a global minimum. Let xk be an arbitrary point in the region of x* and let gk be the gradient vector of f(x) at the point xk then x* can be obtained by using Eq. (4.1) as follows: x* = x k B 1 gk (4.2) Even when function f ( x ) is not quadratic, it can be assumed to approximate a quadratic function in the region of x* and a iterative formula can be derived based on Eq. (4.2). However, since obtaining an inverse of matrix B directly is not practical because of the great amount of computation, an approximate matrix to B is generally set and is modified while the iteration process is being carried out. The revised quasi-Newton method obtains a local minimum point x* by letting Bk be an approximation of the matrix B and using the following iterative formulae: Bk pk = gk xk +1 = xk + k pk Bk +1 = Bk + Ek k = 0,1,
2 2
**EXAMPLE** DIMENSION X(2), G(2), H(3), VW(7) EXTERNAL ROSEN X(1)=-1.2 X(2)=1.0 N=2 EPSR=1.0E-3 MAX=400*2 CALL MINF1 (X, N, ROSEN, EPSR, MAX, * F, G, H, VW, ICON) WRITE(6,600) ICON IF(ICON.GE.20000) STOP WRITE(6,610) F, MAX WRITE(6,620) (I, X(I), I, G(I), I=1, N) STOP 600 FORMAT(1H1, 6H*ICON=, I5) 610 FORMAT(1H, 3H*F=,E15.7, 5H MAX=, I5/) 620 FORMAT(/3H X(,I2, 2H)=,E15.7, 2X, * 3H G(,I2, 2H)=,E15.7) END
(4.3)
where, g0 = f ( x0 ) and B0 are an arbitrary positive definite matrix, pk is a vector denoting the search direction from xk toward the local minimum point, and k is a (linear search) constant which is set so f ( xk + k Pk ) is the smallest locally. Ek is a matrix of rank two which is used to improve the approximate Hessian matrix Bk + Ek is defined 467
MINF1
assuming that function f ( x ) is quadratic in the region of the local minimum point x* , and the secant condition is satisfied.
xi = ( xk1 ,x k2 ,
x )
n T k
(g
k +1
gk ) = Bk +1 ( x k +1 xk )
(4.4)
at point xk ) during the iteration process shown in (4.3), the following relation gk pk = pk Bk pk < 0
T T
ei is the i-th coordinate vector h = u, u: unit round off At the beginning of the iteration, gk is approximated by using Eq. (4.7), but when the iteration is close to the convergence area, the approximation method is changed to (4.8). (b) Linear search (selection of k ) The linear search obtains the minimum point of function f ( x ) along the search direction pk i.e. it obtains k which minimizes the function
(4.5)
must be satisfied based on the sufficient condition of the second order that the function f ( x ) has a minimum value at the point x* . In other words, the iterative calculation requires that the approximate Hessian matrix Bk is positive definite. In the revised quasi-Newton method, the approximate Hessian matrix Bk is expressed as being decomposed as LDLT and the refinement by the Ek is accomplished as follows.
T L k +1 Dk 1 LT k +1 = L k Dk L k + E k
( ) = f ( xk + pk ), 0
(4.9)
The subroutine approximates ( ) by the quadratic interpolation and assumes k as follows: ak min{1, 2(f ( xk ) f ( xk 1 )) / g T k Pk } (4.10)
(4.6)
The above equation makes use of the quadratic convergency of the Newton method, setting k =1 in the final step of the iteration. In addition, the second term of Eq. (4.10) guarantees that f ( x k +1 ) < f ( xk ) to prevent it being divergent during the initial iteration process. The second term of Eq. (4.10) assumes. f ( xk +1 ) f ( xk ) f ( xk ) f ( xk 1 ) (4.11)
The characteristic of the revised quasi-Newton method is to guarantee that Dk +1 is positive definite by keeping all the diagonal elements of Dk +1 positive. Computational procedure in the subroutine (a) Initializing the Hessian matrix ( B0 = I n ) (b) Computation of the gradient vector gk (c) Determining the search vector T pk Lk Dk Lk pk = gk This equation is solved by
calling the subroutine LDLX. (d) Linear search ( x k +1 = x k + k p k ) (e) Improvement of the approximate Hessian matrix
in the initial iteration step, and it is not an exact approximation made by the quadratic interpolation. Therefore the subroutine searches for the minimum point by using extrapolation and interpolation described as follows (linear search): let f0, f1 and f2 be the function values for the points x k +1( 0 ) = x k , x k +1(1) = x k + k pk and xk +2 = x k + 2 k pk ,2, respectively, then (a) If f 0 > f1 and f 1 < f 2 , the search is terminated
( 2) (1) setting xk +1 as the minimum point.
Lk + 1 Dk + 1 LT k + 1 = Lk Dk Lk T + Ek
The above steps, (b) to (e), are repeated for k=0, 1, ... Notes on each algorithm (a) Computation of the gradient vector gk The subroutine approximates gk by using the forward difference (4.7) and the central difference (4.8), g f ( x k + hei ) f ( xk ) / h
i k i k
F ( ) f0 f1 f2
( ( f (x
+ hei ) f ( x k hei ) / 2h
n T k
(4.7)
2k
(4.8)
Where,
gk = ( gk1 ,gk2 ,
g )
(b) If f 0 > f1 > f 2 , min which gives the minimum point is extrapolated by using the quadratic interpolation based on those three points as follows:
468
MINF1
( 2) xk +1
terminated, but if the function f ( x ) keeps decreasing further at the point xk +1 , i.e.,
T T gk +1 pk < gk pk
(4.12)
2k
min 4k
) ( ) ( ) (
f0
If 4 k < min the search goes back to the beginning after setting k = 2 k
f1 f2 f3
then the new search direction pk +1 sa well as k +1 are determined to repeat the linear search. If Eq. (4.12) is not satisfied, the process moves to the next step to improve the approximate Hessian matrix. (c) Convergence criterion The subroutine terminates the iteration when Eq. (4.13) is satisfied in the iteration process (linear search) performed after the calculation of gk is changed to the approximation by the central difference (4.8). The obtained xk +1 is assumed to be
2k
4k
min
(4.14)
( ) f0
f1/2
f1
(d) Improving approximate Hessian matrix The BFGS (Broyden - Fletcher - Goldfarb - Shanno) furmula (4.14) is used for the improvement. Bk +1 = Bk +
T rk rk T k rk
T Bk k k Bk T k Bk k
(4.14)
k/2
Where,
If f 0 < f1/ 2 < f1 , the search goes back to the beginning after interpolating min which gives a minimum point by using the quadratic interpolation based on those three points and then setting k = max( k / 10, min )
( )
f1
rk = gk +1 gk k = x k +1 x k
The subroutine starts the iteration by setting a unit matrix to the initial approximate Hessian matrix B0 . The i-th step improvement for the Hessian matrix Bk is carried out in the form of being decomposed as LDLT. rk rkT ~ ~ ~ T = + Lk Dk LT L D L k k k k k pk rk ~ ~ ~T gk g Lk +1 Dk +1 LT k +1 = Lk Dk Lk + pk gk
T k
f1/2 f0
(4.15) (4.16)
min
Where the second terms of both (4.15) and (4.16) are rank one matrices. For further details, refer to Reference [34].
469
MING1
H .....
CALL MING1 (X, N, FUN, GRAD, EPSR, MAX, F, G, H, VW, ICON) Function Given a real function f ( x ) of n variables, its derivative a local minimum of f ( x ) and its function value f ( x * ) are obtained by using the quasi-Newton method. f ( x ) is assumed to have up to the second continuous partial derivative, where x = ( x1 ,x2 ,
Output. Inverse matrix of a Hessian matrix at x*. This is stored in the compressed mode for symmetric matrix. One-dimensional array of size n(n + 1) / 2 .
VW .....
Work area. One-dimensional array of size 3n + 1 . ICON .... Output. Condition code. See Table MING1-1.
Table MING1-1 Condition code Code 0 10000 Meaning No error Convergence condition was not satisfied within the specified number of evaluations. During computation, T gk p k 0 occurred, so the local decrement of the function was not attained (See (4.5) in Method). EPSR was too small. The function is monotonically decreasing along searching direction. N<1, EPSR<0.0 or MAX=0 Processing The last value is stored in parameters X, F, G, and H. Discontinued (The last value is stored in parameters X, and F). Discontinued
, x )
n
and n 1.
20000
Parameters X ..... Input. Initial vector x0 . Output. Vector x* One-dimensional array of size n. N ..... Input. Number of variables n. FUN ..... Input. Name of function subprogram which calculates f ( x ) . The form of subprogram is as follows: FUNCTION FUN(X) where, X ..... Input. Variable vector x . One-dimensional array of size n. The function FUN should be assigned with the value of f ( x ) . (See Example.) GRAD .. Input. Name of subroutine subprogram which computes g( x ) . The form of subprogram is as follows: SUBROUTINE GRAD(X, G) where, X ..... Input. Variable vector x. One-dimensional array of size n. G ..... Output. One-dimensional array of size n which has a correspondence G(1) = f / x1 , , G( N ) = f / x n
250000
30000
Bypassed.
Comments on use Subprograms used SSL II ... AMACH, MGSSL MSV, AFMAX FORTRAN basic functions ... ABS, SQRT Notes The program which calls this subroutine must have an EXTERNAL statement for the subprogram name that corresponds to the arguments FUN and GRAD. Giving EPSR: The subroutine tests convergence of the iteration vector xk by x k +1 x k max 10 . , x k EPSR and if the above condition is satisfied, xk +1 is taken as the local minimum point x* and the iteration is terminated. The subroutine assumes that function f ( x ) is approximately quadratic in the region of the local minimum point x*. If the function value f ( x * ) is to be obtained as
(See Example.) EPSR ..... Input. Convergence criterion (0.0) When EPSR=0.0, a default value is used. (See Notes.) MAX ..... Input. The upper limit (0) of the number of evaluations of functions f ( x ) and g( x ) . (See Notes.) Output. The number of evaluations in which f ( x ) and g( x ) are actually evaluated (>0).
F ..... G .....
accurate as the unit round off, EPSR u , where u is the unit round off is satisfactory. The default value is u / 8.0
470
MING1
Giving MAX: For a variable vector x, the total number of evaluations is calculated by adding the number of computation for f ( x ) , (ie., 1), and the number of computations for g( x ), (ie., n). The number of evaluations of functions depends on characteristics of the functions in addition to the initial vector and the convergence criterion. Generally, if the default value is used as the convergence criterion and a good initial vector are used, MAX=400Nn is appropriate. If the convergence condition is not satisfied within the specified number of evaluations and the subroutine returned with ICON=10000, the iteration can be continued by calling the subroutine again. In this case, parameter MAX is specified with a negative value for an additional evaluation number, and the contents of other parameters must be kept intact. Example The global minimum point x* for f ( x ) = (1 x1 ) + 100(x 2 x
2 2 2 1 T
Method Given a real function f ( x ) of n variables, its derivative local minimum of f ( x ) and its function value f ( x * ) are obtained by using the quasi-Newton method. Quasi-Newton method When the function f ( x ) is quadratic, its Taylor series expansion in the region of the local minimum point x* is given by f ( x ) = f (x * ) +
T 1 x x * ) B( x x * ) ( 2
(4.1)
where B is a Hessian matrix of f ( x ) at the point x*. If the matrix B is positive definite, (4.1) has a global minimum. Let xk be an arbitrary point in the region of x* and let gk be the gradient vector of f ( x ) at the point xk then x* can be obtained using (4.1) as follows: x* = x k Hgk (4.2)
where, H is an inverse matrix of Hessian matrix B . Even when function f ( x ) is not quadratic, it can be assumed to approximate a quadratic function in the region of x* and a iterative formula can be derived based on (4.2). However, since obtaining an inverse of matrix B directly is not practical because of the great amount of computation, an approximate matrix to B is generally set and is modified while the iteration process is being carried out. The quasi-Newton method obtains a local minimum point x* by letting Hk be an approximation of the matrix H and using the following iterative formula (4.3) and (4.4)
T H k +1 = H k + (1 + rkT H k r k / kT r k )( k k / kT rk )
x k + 1 = x k + k pk
(4.3)
(H k rk kT + k rkT H k ) / kT rk where,
(4.4)
pk = H k gk , rk = gk +1 gk , k = x k +1 x k , k = 0 ,1 , 2 , where, H0 is an arbitary positive definite matrix, in (4.3) pk is a vector denoting the search direction from xk , toward the local minimum point and k is a (linear
locally smallest. For the search direction pk to be downwards (the function f ( x ) decreasing locally along the pk direction) during the iteration process shown in (4.3) and (4.4), the following relation T (4.5) gk pk < 0
471
MING1
4) Linear search ( xk +1 = xk + k pk )
must be satisfied. Computational procedure in the subroutine 1) Initializing the approximate inverse matrix of the Hessian matrix (H0 =In). 2) Computation of gradient vector gk 3) Computation of search vector pk ( pk = H k gk ) 5) Improvement of the approximate inverse matrix Hk (Hk+1 is obtained from (4.4)) The above steps 2 through 5 are repeated for k=0, 1, ... Note on each algorithm Initializing the approximate inverse matrix This subroutine uses unit matrix I n as initial approximate inverse matrix H0 corresponding to a Hessian matrix. Inverse matrix H k is improved by (4.4) each time it is iterated. H1, however, is obtained by (4.4) after resetting H0 = s I n
(b) The function values corresponding to points (0) xk +1 = xk , x ( 1 ) k +1 = xk + k pk , x ( 2 ) k +1 = x k + 2 k pk are obtained and they are assumed to be f 0 , f1 and f 2 respectively. (c) If f 0 > f1 and f 1 < f 2 , point min is interpolated by using a quadratic interpolation based on these three points by
min = k
f2 f0 k 2 f 0 2 f1 + f 2
(4.9)
The search is terminated by setting min as the final k and the function value is assumed to be a minimum value.
()
f0
f1
f2 fmin
where s = T r0 / r0T r0 Linear search (selection of k ) The linear search obtains the minimum point of function f ( x ) along the search direction pk that is
k
min
2k
(4.6)
If f 2 < f 4 , min is extrapolated by using quadratic interpolation (4.9) based on these three points f0, f1 and f2. If 4 k < min , the search goes back to (b) after setting k = 2 k . If 2 k < min < 4 k , this subroutine terminates the search assuming this min to be final k and function value f min to be the minimum value.
k min 1, 2( f ( xk ) f ( xk 1 )) / gT k pk
(4.7)
( )
f0
The above equation makes use of the quadratic convergency of the Newton method, setting k = 1 in the final step of the iteration. In addition, the second term of (4.7) guarantees that f ( xk +1 ) < f ( xk ) to prevent it from diverging during the initial iteration process. The second term of (4.7) assumes variable ratio of the function as f ( xk +1 ) f ( x) f ( xk ) f ( xk 1 ) (4.8)
f1 f2 fmin
f4
2k
min
4k
in the initial iteration step, and it is not an exact approximation made by the quadratic interpolation. Therefore the subroutine searches for the minimum point by using extrapolation and interpolation described as follows (linear search): (a) k is obtained from (4.7). 472
MING1
()
f0 f1 f2 f4
2 k
4 k
If f 0 < f1/ 2 , this subroutine goes back to the beginning of (e) after setting f 1 = f1/ 2 and k = 1 / 2 k . Thus, this subroutine terminates the linear search based on k . If function f ( x ) continues to decrement at xk+1, that is, if
T T gk +1 pk < gk pk
(e) If f 0 f1 , the function value corresponding to point 1 x = x k + k pk is obtained and sets it as f 1/2 . 2 If f 0 > f1/ 2 and f 1/2 < f1 , min is interpolated by using the quadratic interpolation based on these three points. f1 f 0 min = k k (4.10) 2 4 f 0 2 f 1/ 2 + f1 The search is terminated setting min as k and function value f min is assumed to be the minimum value.
()
1 2 k +1
(4.11)
a new search direction pk+1 and k +1 are determined and the linear search is iterated. If(4.11) is not satisfied, this subroutine goes the next step in which approximate inverse matrix of a Hessian matrix is improved. Convergence criterion This subroutine terminates the iteration when the iterative vector xk and xk +1 satisfy x k +1 x k = max 1.0 , x k
) EPSR
f0 f1/2 fmin
f1
The obtained xk +1 is assumed to be the minimum point x*. For further details, see Reference [35].
1 2
k min
473
MSBV
example shown below.) r = b Ax Example The linear equations with an n n real positivedefinite symmetric band matrix Ax = b (3.4) (3.3)
CALL MSBV (A, N, NH, X, Y, ICON) Function This subroutine performs multiplication of an n n real symmetric band matrix A with upper and lower band widths h by a vector x
y = Ax
(1.1)
is solved using subroutine LSBX and then the residual vector b Ax is compute with the resultant. n 100.
C **EXAMPLE** DIMENSION A(5050), X(100), Y(100), W(5050) READ(5,500) N, NH IF (N .EQ. 0) STOP NH1 = NH + 1 NT = N*NH1 NH*NH1/2 READ(5,510)(A(I), I = 1, NT) READ(5,510) (X(I), I = 1, N) WRITE(6,600) N, NH L = 1 LE = 0 DO 10 I = 1, N LE = LE + MIN0(I, NH1) JS = MAX0 (1, I-NH1) WRITE(6,610)I, JS, (A(J), J = L, LE) L = LE + 1 10 CONTINUE WRITE(6,620)(I, X(I), I = 1, N) EPSZ = 1.0E6 ISW = 1 DO 20 I = 1, N Y(I) = X(I) 20 CONTINUE DO 30 I=1,NT W(I)=A(I) 30 CONTINUE CALL LSBX(A, N, NH, X, EPSZ, ISW, ICON) IF(ICON .GE. 20000) GOTO 50 WRITE(6,630)(I, X(I), I = 1, N) CALL MSBV(W, N, NH, X, Y, ICON) IF(ICON .NE. 0) GOTO 50 WRITE(6,640)(I, Y(I), I = 1, N) DN = 0.0 DO 40 I = 1, N DN = DN + Y(I)*Y(I) 40 CONTINUE DN = SQRT(DN) WRITE(6,650)DN STOP 50 WRITE(6,660) ICON STOP 500 FORMAT(2I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1, 18HCOEFFICIENT MATRIX * /1H , 2HN=, I5, 3X, 3HNH=, I5) 610 FORMAT (/5X, 1H(,I3, 1H, ,I3, 1H), 4E17.8 * /(10X, 4E17.8))
where x and y are both n-dimensional vectors, and n > h 0. Parameters A .... Input. Matrix A. Matrix A is stored in one-dimensional array of size n (h + 1) h (h + 1)/2 in the compressed mode for symmetric band matrices. N .... Input. Order n of the matrix A. (See Notes.) NH .... Input. Upper and lower band widths h. X .... Input. Vector x. One-dimensional array of size n. Y .... Output. Vector y. One-dimensional array of size n. ICON .... Output. Condition code. See Table MSBV-1.
Table MSBV-1 Condition codes Code 0 30000 Meaning No error N = 0, NH < 0 or NH |N| Processing Bypassed
Comments on use Subprograms used SSL II ..... MGSSL FORTRAN basic function .... IABS Notes This subroutine mainly consists of the computation
y = Ax
(3.1)
by specifying N = -n and giving an arbitrary vector y to the parameter Y. In practice, this method can be used to compute a residual vector of linear equations. (Refer to the
474
MSBV
620 FORMAT(/1H , 15HCONSTANT VECTOR * /(5X, 4(1H(, I3, 1H), E17.8,5X))) 630 FORMAT(/1H , 15HSOLUTION VECTOR * /(5X, 4(1H(,I3, 1H), E17.8,5X))) 640 FORMAT(/1H , 15HRESIDUAL VECTOR * /(5X, 4(1H(,I3, 1H), E17.8,5X))) 650 FORMAT(/1H , 5HNORM=, E17.8) 660 FORMAT(/1H , 5HICON= ,I5) END
where A is n n real symmetric band matrix with lower and upper band widths h and x is an n dimensional vector. While, this subroutine computes the multiplication using equation (4.2) instead of equation (4.1) by making use of symmetric band matrix characteristics. yi =
min ( i + h , n ) j = max (1, i h )
( )
aij x i , i = 1,
, n
(4.2)
is computed: y i = a ij x j , i = 1,
j =1 n
,n
(4.1)
This subroutine increases the precision of the inner products in equation (4.2) so that the effects of running error are minimized.
475
MSGM
CALL MSGM (A, B, KB, C, KC, N, VW, ICON) Function This subroutine performs multiplication of an n n real symmetric matrix A and an n n real matrix B. C = AB where, C is an n n real matrix n, 1. Parameters A .... Input. Matrix A, in the compressed mode, one-dimensional array of size n ( n + 1) / 2 . B .... Input. Matrix B, two-dimensional array, B (KB, N) KB .... Input. The adjustable dimension of array B, ( N). C .... Output. Matrix C, two-dimensional array, C (KC, N). (See Comment on use.) KC .... Input. The adjustable dimension of array C, ( N). N .... Input. The order n of matrices A, B and C. VW .... Work area. One-dimensional array of size n ICON .... Output. Condition codes. See Table MSGM-1.
Table MSGM-1 Condition code Code 0 30000 Meaning No error N<1, KB<N or KC<N Processing Bypassed
Notes Saving the storage area: If there is no need to keep the contents on the array A, more storage area can be saved by using the EQUIVALENCE statement as follows: EQUIVALENCE (A(1), C(1.1)) Refer to the example shown in Comments on use below. Example The following shows an example of obtaining the multiplication of a real symmetric matrix A by a real matrix B, Here, n 100.
C **EXAMPLE** DIMENSION A(5050), B(100.100), * C(100, 100), VW(100) EQUIVALENCE (A(1), C(1,1)) DATA 1A/1HA/,IB/1HB/,IC/1HC/ 10 READ(5,100) N IF(N.EQ.0) STOP WRITE(6,150) NT = N*(N + 1)/2 READ(5,200)(A(I), I = 1, NT) READ(5,200) ((B(I, J), J = 1, N), I = 1, N) CALL PSM (IA, 1, A, N) CALL PGM (IB, 1, B, 100, N, N) CALL MSGM (A, B, 100, C, 100, N, VW, ICON) WRITE(6,250) ICON IF (ICON.NE.0) GOTO 10 CALL PGM (IC, I, C, 100, N, N) GOTO 10 100 FORMAT (I5) 200 FORMAT (4E15.7) 150 FORMAT (1H1///10X, * 27H** MATRIX MULTIPLICATION **) 250 FORMAT (//10X, 13H**MSGM ICON= ,I5) END
Comments on use Subprograms used SSL II ... CSGM, MGGM, MGSSL FORTRAN basic functions ... None
Subroutines PSM and PGM in the example are for printing the real symmetric and real matrices. These programs are shown in the example for subroutine MGSM.
476
MSSM
CALL MSSM (A, B, C, KC, N, VW, ICON) Function The subroutine performs multiplication of two n n real symmetric matrices A and B. C = AB where, C is an n n real matrix, n 1. Parameters A .... Input. Matrix A, in the compressed mode, one-dimensional array of size n ( n + 1) / 2 . B .... Input. Matrix B, in the compressed mode, one-dimensional array of size n ( n + 1) / 2 . C .... Output. Matrix C, two-dimensional array, C (KC, N). (See Notes.) KC .... Input. The adjustable dimension of array C, ( N). N .... Input. The order n of matrices A, B and C. VW .... Work area. One-dimensional array of size n. ICON .... Output. Condition codes. See Table MSSM-1.
Table MSSM-1 Condition code Code 0 30000 Meaning No error N<1 or KC<N Processing Bypassed
Notes Saving the storage area: If there is no need to keep the contents on the array A, more storage area can be saved by using the EQUIVALENCE statement as follows: EQUIVALENCE (A(1), C(1,1)) Refer to the example shown in Comments on use below. Example The following shows an example of obtaining the multiplication real symmetric matrices A and B. Here, n 100.
C **EXAMPLE** DIMENSION A(5050), B(5050), C(100, 100), * VW(100) EQUIVALENCE (A(1), C(1, 1)) DATA 1A/1HA/,IB/1HB/,IC/1HC/ 10 READ(5,100) N IF (N .EQ. 0) STOP WRITE(6,150) NT = N*(N + 1) /2 READ(5,200)(A(I), I = 1, NT) READ(5,200)(B(I), I = 1, NT) CALL MSSM (A, B, C, 100, N, VW, ICON) IF (ICON .NE. 0) GOTO 10 CALL PSM (IA, 1, A N) CALL PSM (IB, 1, B, N) CALL PGM (IC, 1, C, 100, N, N) GOTO 10 100 FORMAT (I5) 200 FORMAT (4E15.7) 150 FORMAT (1H1///10X, * 27H** MATRIX MULTIPLICATION **) END
Comments on use Subprograms used SSL II ... CSGM, MGSM, and MGSSL. FORTRAN basic functions ... None
The subroutines PSM and PGM in the example are for printing the real symmetric and real matrices. These programs are shown in the example for subroutine MGSM.
477
MSV
CALL MSV (A, N, X, Y, ICON) Function This subroutine performs multiplication of an n n real symmetric matrix A and a vector x.
y = Ax
Refer to the example in Comments on use below. Example This example shows the program to solve a system of linear equations (3.4) by subroutine LSX and to obtain a residual vector b Ax based on the solution. Where n 100. Ax = b
C
(3.4)
(1.1)
where, x and y are n-dimensional vectors, n 1. Parameters A .... Input. Matrix A, in the compressed mode, one-dimensional array of size n ( n + 1) / 2 . N .... Input. The order n of matrix A. X .... Input. Vector x, one-dimensional array of size n. Y .... Output. Multiplication y of matrix A and vector x, one-dimensional array of size n. ICON .... Output. Condition codes. See Table MSV-1.
Table MSV-1 Condition code Code 0 30000 Meaning No error N=0 Processing Bypassed
Comments on use Subprograms used SSL II .... MGSSL FORTRAN basic function ....IABS. Notes This subroutine mainly consists of the computation,
y = Ax
(3.1)
by specifying N = n and giving an arbitrary vector y to the parameter Y. This method can be used to compute a residual vector of linear equations such as r = b Ax (3.3)
**EXAMPLE** DIMENSION A(5050), X(100), Y(100), W(5050) READ(5,500) N IF (N .EQ. 0) STOP NT = N*(n + 1) /2 READ(5,510) (A(I), I = 1, NT) READ(5,510) (X(I), I = 1, N) WRITE(6,600) N L = 1 LE = 0 DO 10 I = 1, N LE = LE + I WRITE(6,610) I, (A(J), J = L, LE) L = LE + 1 10 CONTINUE WRITE(6,620) (I, X(I), I = 1, N) EPSZ = 1.0E 6 ISW = 1 DO 20 I = 1, N Y(I) = X(I) 20 CONTINUE DO 30 I = 1, NT W(I) = A(I) 30 CONTINUE CALL LSX (A, N, X, EPSZ, ISW, ICON) WRITE(6,630)(I, X(I), I = 1, N) CALL MSV(W, N, X, Y, ICON) IF (ICON .NE. 0) GO TO 50 WRITE(6,640)(I, Y(I), I = 1, N) DN = 0.0 DO 40 I = 1, N DN = DN + Y(I)*Y(I) 40 CONTINUE DN = SQRT(DON) WRITE(6,650) DN 50 WRITE(6,660) ICON STOP 500 FORMAT(I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1, 18HCOEFFICIENT MATRIX * /1H , 6HORDER =, I5) 610 FORMAT(/5X, 1H(,I3, 1H), 4E17.8/(10X, 4E17.8)) 620 FORMAT(/1H, 15HCONSTANT VECTOR * /(5X, 4(1H(, I3, 1H), E17.8, 5X))) 630 FORMAT(/1H , 15HSOLUTION VECTOR * /(5X, 4(1H(, I3, 1H), E17.8, 5X))) 650 FORMAT(/1H , 5HNORM =, E17.8) 660 FORMAT(/1H , 5HICON =, I5) END
478
MSV
Method This subroutine performs multiplication y = (yi ) of an n n real matrix A = (aij) and an n dimensional vector x = (xj) through using the equation (4.1). y i = aij x j , i = 1,
j =1 n
In this subroutine, precision of the inner products in (4.1) has been raised to minimize the effect of rounding errors.
,n
(4.1)
479
NDF
Example The following example generates a table of (x ) in which x varies from 0.0 to 10.0 with increment 0.1.
C **EXAMPLE** WRITE(6,600) DO 10 K = 1, 101 X = FLOAT(K1) /10.0 CALL NDF(X, F, ICON) WRITE(6,610) X, F 10 CONTINUE STOP 600 FORMAT(1H1, 24HEXAMPLE OF NORMAL DISTRI, * 15HBUTION FUNCTION//6X, 1HX, 7X, 6HNDF(X)/) 610 FORMAT(1H , F8.2, E17.7) END
CALL NDF (X, F, ICON) Function This subroutine computes the value of normal 1 x t2 distribution function ( x ) = e 2 dt by the 2 0 relation.
( x ) = erf x / 2 / 2
Parameters X ..... Input. Independent variable x. F ..... Output. Function value (x ) ICON .. Output. Condition code See Table NDF-1.
Meaning No error
(1.1)
(x) =
0 e u
du
(4.1)
t/ 2 =u
Comments on use Subprograms used SSL II ...MGSSL FORTRAN basic function ...ERF Notes There is no restriction with respect to the range of argument X. Using the relationship between normal distribution function (x ) and complementary normal distribution function ( x )
can be written with variable transformation as x 1 2 u2 (x) = e 2 du 2 0 x 1 2 2 u2 e du = 2 0 2 x 2 Therefore from erf ( x ) = e u du 0 the following holds.
( x) =
1 erf x / 2 2
(4.2)
( x) = 1 / 2 ( x)
the value of (x ) can be computed by using
This subroutine computes (x ) from (4.2) by using (3.1) FORTRAN function ERF.
subroutine NDFC. Note that in the range of x > 2 , however, this leads to less accurate and less efficient computation than calling NDF.
480
NDFC
Example The following example generates a table of ( x ) in which x varies from 0.0 to 10.0 with increment 0.1.
C *EXAMPLE** WRITE(6,600) DO 10 K = 1, 101 X = FLOAT (K-1)/ 10.0 CALL NDFC(X, F, ICON) WRITE(6,610) X, F 10 CONTINUE STOP 600 FORMAT(1H, 24HEXAMPLE OF COMPLEMENTARY, * 29H NORMAL DISTRIBUTION FUNCTION * //6X, 1HX, 7X,7HNDFC(X)/) 610 FORMAT(1H , F8.2. E17.7) END
CALL NDFC (X, F, ICON) Function This subroutine computes the value of complementary normal distribution function.
(x) =
1 2
t e 2
dt
( x ) = erfc x / 2 / 2
Parameters X .... Input. Independent variable x. F ..... Output. Function value ( x ) ICON .. Output. Condition code. See Table NDFC-1.
(1.1)
(x ) =
1 2
x e
t 2
dt
(4.1)
t / 2 =u,
as
(x) =
1 2 2
1 2
x
2
e u 2 2 dt
Comments on use Subprogram used SSL II ... MGSSL FORTRAN basic function ... ERFC Notes There is no restrictions in the range of argument X. Using the relationship between normal distribution function ( x ) and complementary normal distribution function ( x ) .
x
2
e u 2 du 2
e u 2 du
(x) =
1 erfc x / 2 2
(4.2)
(x) =
1 (x) 2
(3.1)
the value of ( x ) can be computed by using subroutine NDF. Note that in the range of x > 2 , however, this leads to less accurate and less efficient computation that calling NDFC.
481
NLPG1
D31-20-0101-NLPG1, NDLPG1
Nonlinear programming (Powells method using function values and its derivatives)
CALL NLPG1 (X, N, FUN, GRAD, FUNC, JAC, M, EPSR, MAX, F, VW, K, IVW, ICON) Function Given an n-variable real function f ( x) , its derivative
g( x ) , f ( x)
JAC ....
X ... Input. Variable vector x. One-dimensional array of size n. C ... Output. One-dimensional array of size m, where C(1) = c1(x), ..., C(M(1)) = cm1(x), ..., C(M(1) + M(2)) = cm(x). (See Example.) Input. Name of subroutine subprogram which calculates J (x ) . The form of subprogram is as follows: SUBROUTINE JAC (X, CJ, K) Parameters X Input. Variable vector x. One-dimensional array of size n. CJ ... Output. Jacobian matrix. Two-dimensional array, CJ (K, N), where CJ(I,J ) = ci x j K ... Input. Adjustable dimension of array CJ. (See Example.) Input. The number of constraints. One-dimensional array of size 2, where M (1) = m1 and M(2) = m2 . Input. Convergence criterion ( 0.0). The default value is used if 0.0 is specified. (See Comments on Use.) Input. The upper limit ( 0) of number of evaluations for functions f ( x ), g( x ), c( x ), and J ( x ) . (See Comments on Use.) Output. The number (>0) of actual evaluations Output. The value of function f ( x * ) Work area. VW is two-dimensional array, VW(K, M(1) + M(2) + 2 N + 12) . Input. Adjustable dimension ( M(1) + M(2) + N + 4) of array VW.
and initial vector x0, vector x* which minimizes and the value of function
f x*
( ) are obtained
(1.1) (1.2)
The Jacobian J (x ) of
f ( x)
{c (x)}
i
derivative. Further, x = (x1 ,x 2 , x n )T and m1 and m2 are the number of the equality and inequality constraints, where n 1 , m1 0 , m2 0 , and m 1, (m = m1 + m2 ) . Parameters X ..... Input. Initial vector x0. Output. Vector x*. One-dimensional array of size n. N ..... Input. Number n of variables. FUN ..... Input. Name of function subprogram which calculates f ( x) The form of subprogram is as follows: FUNCTION FUN (X) Parameters X ... Input. Variable vector x. One-dimensional array of size n. Substitute the value of f ( x) in function FUN. GRAD. (See Example.) Input. Name of subroutine subprogram which calculates g(x ) . The form of subprogram is as follows: SUBROUTINE GRAD (X, G) Parameters X ... Input. Variable vector x. One-dimensional array of size n. G ... Output. One-dimensional array of size n, where G(1) = f x1 ,, G( N ) = f x n FUNC. (See Example.) Input. Name of subroutine subprogram which calculates ci(x). The form of subprogram is as follows: SUBROUTINE FUNC (X, C) Parameters
EPSR ..
MAX ..
IVW ..... Work area. One-dimensional array of size 2 (M(1) + M(2) + N + 4) . ICON ..... Output. Condition code. (See Table NLPG11)
482
NLPG1
Table NLPG1-1 Condition codes Code 0 10000 Meaning No error. The convergence condition has not been satisfied within the specified function evaluation count. Local decrement of the function was not satisfied during the calculation. (See Method.) The value of EPSR is too small. There may not be a solution that satisfies the constraints, or the initial value x0, is not appropriate. Retry with a different initial value x0. N < 1, EPSR < 0.0, M(1) < 0, M(2) <0, K < M (1) + M(2) + N + 4, MAX = 0. Processing The last values obtained are stored in X and F. Bypassed. (The last values obtained are stored in X and F.) Bypassed.
20000
21000
Generally, when an appropriate initial vector is specified and the default value is used for the convergence criterion, it is adequate to specify MAX = 800mn. Even if the convergence condition is not satisfied within the specified evaluation count and the subroutine is returned with ICON = 10000, iteration can be resumed by calling this subroutine again. In this case, the user must specify a negative value as the additional evaluation count in the parameter MAX and retain other parameters unchanged. Example Given the following 2-variable real function
2 f ( x1 , x2 ) = x1 2x1 x 2 + 2 x 2 2 10 x1 + x2
30000
Bypassed.
Comments on use Subprograms used SSL II ... AMACH, UQP, UNLPG, MGSSL FORTRAN basic functions ... ABS, AMAX1, Notes An EXTERNAL statement is necessary to declare the subprogram names correspond to parameters FUN, GRAD, FUNC and JAC in the calling program. EPSR In this subroutine, the convergence condition is checked as follows: During iteration, if x k +1 x k max 10 . , x k EPSR
the vector which minimizes function and the value of f ( x * ) are obtained subject to the following constraints: c1 ( x1 , x 2 ) = 0.5 x12 + 15 . x2 22 = 0 where the initial vector is x 0 = ( 2,2)
C
c1 ( x1 , x 2 ) = x1 + x 2 0
is satisfied, point xk+1 is assumed to be minimum point x* and iteration is stopped. Since f ( x ) is assumed to be approximately a quadratic function in the vicinity of point x*, it is appropriate to specify EPSR as EPSR u , where u is the unit round off to obtain the value of function f ( x * ) as accurate as the rounding error. The default value of EPSR is 2 u MAX The number of function evaluation is incremented by one every time f ( x ) is evaluated, by n every time and by mn every time J ( x ) is evaluated.
The number depends on characteristics of the functions, initial vector, and convergence criterion.
**EXAMPLE** DIMENSION X(2), M(2), VW(8, 18), * IVW(16) EXTERNAL TEST, GRAD, TESTC, JAC X(1) = 2.0 X(2) = 2.0 N = 2 M(1) = 1 M(2) = 1 EPSR = 1.0E 3 MAX = 800*2*2 K = 8 CALL NLPG1(X, N, TEST, GRAD, TESTC, * JAC, M, EPSR, MAX, F, VW, K, IVW, ICON) WRITE(6,600) ICON IF(ICON. GE. 20000) STOP WRITE(6,610) F, MAX WRITE(6,620) (I, X(I), I = 1, N) STOP 600 FORMAT(1H1, 6H*ICON=, I5) 610 FORMAT(1H, 3H*F= , E15.7, 1X, 4HMAX =, I5) 620 FORMAT(1H, (/2X, 2HX(, I2, 2H)=, E15.7)) END C OBJECTIVE FUNCTION FUNCTION TEST(X) DIMENSION X(2) TEST = (X(1) 2.0*X(2) 10.0)*X(1) + * (2.0*X(2) + 1.0)*X(2) RETURN END C DERIVATIVE SUBROUTINE GRAD(X, G) DIMENSION X(2), G(2) G(1) = 2.0*X(1) 2.0*X(2) 10.0 G(2) = 2.0*X(1)+.0*X(2) + 1.0 RETURN END
483
NLPG1
CONSTRANTS SUBROUTINE TESTC(X, C) DIMENSION X(2), C(2) C(1) = 0.5*X(1)*X(1) + 1.5*X(2)*X(2) 2.0 C(2) = X(1) + X(2) RETURN END JACOBIAN SUBROUTINE JAC(X, CJ, K) DIMENSION X(2), CJ(K,2) CJ(1,1)=X(1) CJ(2,1)=-1.0 CJ(1,2)=3.0*X(2) CJ(2,2)=1.0 RETURN END
B is the Hessian matrix of f ( x ) for xk. The value of y that minimizes function (4.4) is computed and the solution is defined as yk. Then, the linear search is a applied to obtain the value of a that satisfies min f ( x k + y k ) (4.6)
Method This subroutine solves a nonlinear programming problem given as f ( x) minimize subject to the constraints ci ( x ) = 0, i = 1,2,, mi (equality constraints) ci ( x ) 0, i = m1 + 1,, m1 + m2 (inequality constraints) using Powells variable metric method. Let us introduce the following symbols for simplicity: M1 ..... Set (1,2,, m1 ) of subscripts of the equality M2 ..... constraints. (This may be an empty set.) Set ( m1 + 1,, m1 + m2 ) of subscripts of the inequality constraints. (This may be and empty set.) Set ( m1 + 1,, m1 + m2 ) of subscripts of constraints. (This must not be an empty set.) Gradient vector of f Gradient vector of ci. (4.2) (4.3) (4.1)
the better approximation x k +1 is obtained. On such process, Hessian matrix B is not calculated directly but is approximated using vectors g ( x k + 1 ) g ( x k ) and k y k during iteration. On the other hand, for the minimization with constraints such as (4.2) and (4.3), the value of y is obtained under the constraints. For (4.2), the condition of the linear approximation. ci ( x ) = ci ( x k ) + y Tci ( x k ) = 0, i M1 is imposed, whereas for (4.3), the condition ci ( x ) = ci ( x k ) + y Tci ( x k ) 0, i M2 (4.9) (4.8)
is imposed. It is therefore necessary to obtain the value y that minimizes (4.4) satisfying the conditions of (4.8) and (4.9) in order to solve the nonlinear programming problem given by (4.1), (4.2), and (4.3). This is a quadratic programming problem with respect to y. Concerning the linear search, the penalty function W ( x ) = f ( x ) + P c( x )
M ..... g ..... ci ..
(4.10)
should be applied instead of (4.6), namely the value of that minimizes W ( x ) is obtained. Where the function P c( x ) takes zero if all constraints are satisfied; otherwise, it takes a positive value. This will be explained precisely later. Further, information about not only f ( x ) but also c( x ) are incorporated to update approximation matrix Bk of the Hessian matrix. If only the equality constraint is imposed, the following must be satisfied at the minimum point: g( x )
i M1
Let us explain outline of the algorithm for the problem by comparing with that for unconstrained minimization problem. The revised quasi-Newton method, that is, the variable metric method to minimize the objective function f ( x ) without constraints such as (4.2) and (4.3), is described as follows. Function f ( x ) can be approximated by quadratic function at an arbitrary point xk, in the region of the minimum point as follows: f ( x) f ( xk ) + y T g( xk ) where y = x xk (4.5) 1 T y By 2
[ ]
ici (x ) = 0
(4.11)
(4.4)
where i , is the Lagrange multiplier. To solve (4.11) which is a simultaneous nonlinear equations of order n+m1, the second partial derivatives of
( x, ) = f ( x )
i M1
i ci ( x )
(4.12)
484
NLPG1
are necessary. This means that (4.11) cannot be solved with only the partial derivatives of f ( x ) . Updating of Bk is therefore performed based on the matrix of rank 2 obtained from vectors kyk and
(4.17)
k = x ( xk +1 , ) x ( xk , )
(4.13)
Where x is the gradient vector of with respect to x. If the problem has nonlinear equality constraints, the exact linear search for W(x) causes extreme slow step size of xk, as a result, it does not converge to the actual minimum point in some cases; therefore, a watchdog should be introduced to watch behavior of solution xk. Explanations about calculation procedures of this subroutine are given in the next subsection, where the functions are used which are defined as follows: Penalty function W( x ) = f (x ) +
(4.18)
is satisfied, where xk, is a feasible point, assumes xk to be x* and f ( x k ) to be f ( x ) , and sets ICON = 0, then stops processing; otherwise, the linear search for W(x) is performed to obtain xk+1 = xk + yk in the yk direction. If * yk is small enough to be considered as convergence and if xk is a feasible point, ICON = 20000 is set and processing is stopped. This is because the convergence criterion is too small, but the point can be considered to be the minimum point. If xk is not a feasible point, ICON = 21000 is set and processing is stopped. If * yk is large, proceeds to step 3. 4) When there is no feasible solution for QPk: The problem is modified to the following quadratic programming problem: QPk: 1 T y Bk y + y Tg( xk ) z Minimize 2 Subject to constraints y Tci ( x k ) + ci ( xk )z = 0 , i M1 T y ci ( x k ) + ci ( xk )z i 0 , i M2 where, 0 z 1, 1, ci ( x k ) > 0 , zi = < z c x , , 0 ( ) i k (4.20) (4.19)
i ci ( x) + i min(0, ci ( x ))
i M1 i M 2
(4.14)
The function increases effect of the penalty term as the point x takes out of the constraints. Coefficient i is determined according to the method explained later. Linear approximation of the penalty function this is defined as linear approximation at an arbitrary point xk, in the region of the minimum point
T Wk ( x ) = f ( x k ) + ( x x k ) g( x k ) + i ci ( x k ) + ( x x k )T ci ( x k )
iM 1
iM 2
T i min 0, c i ( x k ) + ( x x k ) ci ( x k )
(4.15)
Lagrangian function Lk ( x ) = f ( x )
i M1
i ci ( x )
(4.16)
where i is the Lagrange multiplier determined from xk, as explained later. Calculation procedures Step 1 (initial value setting) 1) Sets the following values: k = 0 (iteration count) H0 = In l = 0 (watchdog location) lt = 5 (interval to check watchdog location) = 0.25 EPSR, EPSR 0 (conversion judg - = ment criterion) 2 u , EPSR = 0 Step 2 (quadratic programming problem) 2) Solves the quadratic programming problem QPk with respect to y as follows:
is a sufficiently large positive value Denotes the optimal solution as yk and z . If z < and if xk is a feasible point assumes xk to be x* and f ( x k ) to be f ( x * ) and sets ICON =0,
then stops processing. If z < and if xk is not a feasible point, there is no feasible solution for the nolinear programming problem given as (4.1), (4.2), and (4.3) (constraints conflict with each other), or the initial value x0 is not appropriate, thus ICON = 21000 is set and processing is stopped. If z and if
485
NLPG1
yk
< max 10 . , xk
(4.21)
= + ( 1 )Bk1
(4.25)
is satisfied, and if xk is a feasible point; assumes xk to be x* and f ( x k ) to be f ( x* ) , and sets ICON = 0, then stops processing. If (4.21) is not satisfied, proceeds to step 3. Step 3 (watchdog processing) 5) Assume k = k + 1 Checks behavior of solution xk to judge whether the step size of xk is appropriate. If W ( xk ) W ( xl ) W ( xl ) Wl ( xl +1 ) is satisfied, proceeds to step 5. Step 4(watchdog and Bk updating) 6) If W ( xk ) W ( xl ) is satisfied, assumes l = k and xi = xk. 7) If the value of k is a multiple of lt, assumes xk = xl and l =k. 8) Updates Bk as follows. Using = x k x k 1 (= * y k 1 ) = gk gk 1 i (ci ( x k ) ci ( xk 1 )) iM determines , T 0.2 T Bk 1 1 = T Bk 1 T T 0 . 8 T B T , < 0.2 Bk 1 k 1
(4.22)
Then, returns to step 2. Step 5 (modification of step size) 9) Checks the value of * obtained at 3) as follows: Obtains x that satisfies the following in the yk direction: W( x ) W( xk 1 ) L( x ) L( xk 1 )
or
(4.27)
If there is no x that satisfies (4.27), returns to step 4. If there is an x that satisfies (4.27), ~ y is assumed. xk+1 = xk k ~ = * , returns to step 4; otherwise returns to step If 3. Notes on algorithm 1) Determination of i Determines i , from solutions of QPk using the Lagrange multiplier for the constraints. 2) Determination of i 3) The initial value is specified as i = 2| i | , then . | i | (the i = 2| i | is set for i , that satisfies i < 15 current value is used for i ) thereafter. (See references [94] and [95] for details.)
(4.23)
(4.24)
486
NOLBR
Output. The number of iterations executed. FNOR Output. The value of f ( xi ) for the solution vector obtained. Work area. One dimensional array of size n (n + 3) ICON ..... Output. Condition codes. See table NOLBR-1. VW .....
Table NOLBR-1 Condition codes Code 1 Meaning Convergence criterion Processing Normal
CALL NOBR (X, N, FUN, EPSZ, EPST, FC, M, FNOR, VW, ICON) Function This subroutine solves a system of nonlinear equations (1.1) by Brents method. f 1 ( x1 , x 2 ,, x n ) = 0 f 2 ( x1 , x 2 ,, x n ) = 0 f n ( x1 , x 2 ,, x n ) = 0
(1.1)
10000
Normal
That is, let f ( x) = ( f 1 ( x), f 2 ( x), , f n ( x )) 7 ) and x = (x1, x2, ..., xn)T, then eq. (1.2) is solved from the initial value x0 . f ( x) = 0 (1.2)
20000
25000 30000
was satisfied. The specified convergence conditions were not satisfied during the given number of iterations. A solution vector was not found within the search range (See parameter FC.). The Jacobian of f(x) reduced to 0 during iterations. N0, EPSZ<0, EPST<0, FC0, or M0
where 0 is an n-order zero vector. Parameters X ..... Input. An initial vector x0 to solve equation (1.2). Output. Solution vector. One dimensional array of size n. N ..... Input. Dimension n of the system. FUN ..... Input. The name of the function subprogram which evaluates the function f k ( x ) . FUN must be declared as EXTERNAL in the program from which this subroutine is called. Its specification is: FUNCTION FUN (X, K) Parameters X ..... Input. Vector variable, x One dimensional array of size n. K ..... Input. An integer such that f k ( x ) is evaluated (1 K n). (See example) EPSZ ..... Input. The tolerance ( 0.0). The search for a solution vector is terminated when f ( xi ) EPSZ (Refer to notes) EPST ..... Input. The tolerance ( 0.0). The iteration is considered to have converged when x i x k 1 EPSZ x i (Refer to notes) FC ..... Input. A value to indicate the range of search for the solution vector ( 0.0). The search for a solution vector is terminated . (Refer to when x i > FC max x0 ,10
Comments on use Subprogram used SSL II ... AMACH and MGSSSL FORTRAN basic functions ... ABS, AMAX1, SIGN, SQRT Notes ZFUN must be declared as EXTERNAL in the program from which this subroutine is called. Setting of EPSZ and EPST Two convergence criteria are used in this subroutine. When either of two is met, the iteration terminates. If the user wishes to cancel one of the criteria, he has only to set the corresponding tolerance equal to 0.0. That is, when: a) EPSZ = A (> 0) and EPST = 0. Unless x i xi 1 repeated until f ( x i ) A is satisfied, or until M times iterations have been completed. b) EPSZ = 0 and EPST = B (> 0) repeated until xi xi 1 B xi
is satisfied
until M times iteration have been completed. c) EPSZ = 0 and EPST = 0 Unless f ( xi ) = 0 or xi xi 1 = 0 , the iteration is repeated M times. This setting c) is useful for executing M times-iterations.
M .....
notes) Input. The upper limit of iterations (> 0) (See notes) 487
NOLBR
[The meaning of FC] Sometimes a solution vector cannot be found in the neighbourhood of the initial vector x0. When this happens, xi diverges from x0, as a result, numerical difficulties such as overflows may occur in evaluating f ( x ) . Parameter FC is set to make sure that these anomalies may not occur by limiting the range of search for solution. Standard value of FC is around 100.0. [Setting of M] The number of iterations needed for convergence to the solution vector depends on the nature of the equations and the magnitude of tolerances. When an initial vector is improperly set or the tolerances are too narrowly set, parameter M should be set to a large number. As a rule of thumb, M is set to around 50 for n = 10. Single precision/double precision setting Usually, double precision subroutine can often solve those nonlinear equation. While single precision subroutine may fail. Example Non-linear simultaneous equations with two unknowns
2 x1 (1 x 2 ) = 2.25 3 x1 (1 x 2 ) = 2.625
is solved by Brents method in this subroutine. At a typical step, starting from y1 = xi-1, a set of intermediate approximations y2, y3, ...yn, yn+1 are calculated and yn+1 is taken as xi which can be considered as better approximation than xi-1. Each of yk+1 (1 k n) is selected in the way that the Taylor expansion of f i ( y ) up to the first order term at yi should be zero. f j ( y) f j ( y j ) + g T j ( y y j ), j = 1,2,, k , where f j f j gT , , j = x1 xn x = y
1
(4.2)
Procedure of Brents method The procedure to obtain xi from xi1 is discussed here. Assume that an orthogonal matrix Q1 is given (Q1 = I when x1 is to be obtained from x0) (a) First step Let y1 = xi1 and expand f 1 (x ) at y1 in Taylors series and approximate it by taking up to the first order term.
T f 1 ( y ) f 1 ( y1 ) + g1 ( y y1 )
(4.3)
are solved with initial vector x0 = (5.0, 0.8)T The solutions are x = (3.0, 0.5)T and x = (81/32, - 1/3)T
C **EXAMPLE** DIMENSION X(2), VW(10) EXTERNAL FUN X(1) = 5.0 X(2) = 0.8 N = 2 EPSZ = 1.0E-5 EPST = 0.0 FC = 100.0 M = 20 CALL NOLBR (X, N, FUN, EPSZ, EPST, FC, * M, FNOR, VW, ICON) WRITE(6,600)ICON,M,FNOR,(I,X(I),I=1,N) STOP 600 FORMAT (1H , 5HICON = , I5/1H , 2HM =, I5/ * 1H , 5HFNOR = , E15.7/ * (1H , 2HX(,I2, 2H)= ,E15.7)) END FUNCTION FUN(X,K) DIMENSION X(2) GO TO (10, 20), K 10 FUN = X(1)*(1.0 X(2)**2) 2.25 RETURN 20 FUN = X(1)*(1.0 X(2)**3) 2.625 RETURN END
and to let it be y2. This is performed according to the following procedure. T Let g1 Q1 = w1T then an orthogonal matrix. P1, is obtained by Householder method to satisfy the following condition
T P = eT , = w , eT = (1,0,,0) w1 1 11 1 1 2 1
where one of the double sign is selected to be equal to T that of the first element of w1 . The, y2 is calculated as follows; y2 = y1 f1( y1 ) Q2e1 , Q2 = Q1P 1 1 (4.4)
(b) Second step . . . (c) k-th step Again using Taylors series of f k ( y ) at yk:
488
NOLBR
y yk ) f k ( y ) f k ( yk ) + gT k (
T
(4.5)
From the row vector gk Qk , we obtain vector w T by k replacing the first(k-1) elements in gk Qk with zeros
T = ( 0, ,0, , , , ) wk k 1
T
Considerations on Algorithm (a) Approximation of partial derivatives In calculating wk, the j-th element (kjn) of wk is T Qk e j . This is equal to the derivative of fk at yk gk along the direction indicated by Qkej (the j-th column of Qk). This subroutine approximates this derivative by the divided difference as follows: 0 0 f k ( yk + hiQk e k ) f k ( yk ) f k ( yk + hiQk e k ) f k ( yk ) (4.9)
k 1
Next, we obtain an orthogonal matrix Pk by Householder method to satisfy the following condition. wk Pk = k e k , k = wk 2 ,
T T T
wk
1 hi
(4.8)
e k = ( 0 , ,0 ,1,0 , ,0 ) Here, the double sign is selected to be the same sign as the k-th element in w T . The matrix Pk has the form: k k 1 1 0 0 0 1 0 P k
k 1
where hi = X i1 u and u is the round-off unit. (b) When k = 0 In the k-th step above, if
k = 0
(4.10)
Pk =
it is impossible to calculate yk+1. In this case, the subroutine automatically sets yk+1 = yk. This means that yk will not be modified at all. If, further
k = 0, k = 1,2,, n
(4.11)
then, y1 (= xi1) will never be modified during the steps. This can happen when the Jacobian of f ( x ) . f i J = x j
It can be shown that yk+1, according to (4.6), satisfies the conditions (4.7) f1 ( y1 ) + g1T ( y k +1 y1 ) = 0 T f 2 ( y 2 ) + g2 ( yk +1 y2 ) = 0 T f k ( y k ) + gk ( yk +1 yk ) = 0
(4.12)
(4.7)
is nearly singular. In this case, processing fails with ICON = 25000. The condition in (4.10) is determined by testing if the following condition is satisfied. f k y k + hQ i k e j f k ( yk )
u f k ( yk )
Letting yn+1, which is obtained at n-th step (k= n), be xi, if xi satisfies the convergence criterion, the iteration terminates and xi is taken as the solution vector. If not, the above steps are repeated from the first step with the next starting value of iteration vector y1 = xi and Q1 = Qn+1.
, j = k , k + 1,, n
(4.13)
489
NOLF1
VW .....
CALL NOLF1 (X, N, FUN, M, EPSR, MAX, F, SUMS, VW, K, ICON) Function Given m real functions f 1 ( x ), f 2 ( x ), , f m ( x ) of n variables and initial vector x0, this subroutine obtains vector x* which gives a local minimum of F ( x) =
m i =1
Work are. Two-dimensional array, VW (K, N + 2). K ..... Input Adjustable dimension ( m + n) of array VW. ICON ..... Output. Condition code. See Table NOLF1-1.
Code 0 10000 Meaning No error The convergence condition was not satisfied within the specified number of evaluations. During computation, Marquardt number vk exceeded the upper limit (See (4.14) in Method). EPSR was too small or the error of difference approximation of a Jacobian matrix exceeded the limit of computation. N < 1, M < N, EPSR < 0.0, MAX = 0 or K< m+n Processing The last value is stored in parameters X, F and SUMS. Discontinued (The last value is stored parameters X, F and SUMS.)
{ f ( x)}
i
(1.1)
20000
and its function value F(x*) by using the revised Marquardt method (Levenberg-Marquardt-Morrison method (LMM method)). This subroutine does not require derivative of F(x). However, the f i ( x ) is assumed to have up to the first continuous partial derivative, and m n 1. Parameters X .... Input. Initial vector x0. Output. Vector x*. One-dimensional array of size n. N ..... Input. Number of variables n. FUN ..... Input. Name of subroutine subprogram which calculates f i ( x ) . The form of subprogram is as follows: SUBROUTINE FUN (X, Y) where, X ..... Input. Variable vector x. One-dimensional array of size n. Y .... Output. Function value f i ( x ) corresponding to variable vector x. One-dimensional array of size m, with correspondence, F(1) = f 1 ( x ), , F( M ) = f m ( x ) Input. Number of functions m. Input. Convergence criterion ( 0.0). When EPSR = 0.0 is specified, a default value is used. (See Notes.) MAX ... Input. The upper limit ( 0) of the number of evaluations of function (See Notes.) Output. Number of evaluation actually performed (> 0). F ..... Output. Function value f i ( x * ) One-dimensional array of size m, with correspondence, F(1) = f 1 ( x* ), , F(M ) = f m ( x * ) SUMS .. Output. Value of the sum of squares F ( x * ) M ..... EPSR ..
30000
Bypassed
Comments on use Subprograms used SSL II ... AMACH, MGSSL FORTRAN basic functions ... ABS, SQRT, FLOAT Notes The program which calls this subroutine must have an EXTERNAL statement for the subprogram name that correspondents to the argument FUN. [Giving EPSR] This subroutine assumes that F(x) is approximately quadratic in the region of the local minimum point x*. To obtain F(x*) as accurate as the unit round off, EPSR should be given as EPSR u when u is the unit round-off. The default value is 2 u [Giving MAX] The number of evaluations of a function is counted by the number of computation of f i ( x ) for a variable vector x, i = 1, ..., m. This corresponds to the number of callings of subprogram FUN. The number of evaluations of a function depends on characteristics of equation { f i ( x ) } in addition to the initial vector and a convergence criterion. Generally, if the default values is used as the convergence criterion, and a good initial vector is used, MAX = 100NnNm is appropriate. If the convergence condition is not satisfied within the specified number of evaluations and the subroutine is returned with ICON = 10000, the iteration can be continued by calling the subroutine again. In this case, parameter MAX is specified with a negative
490
NOLF1
value for an additional evaluation number and the contents of other parameters must be kept intact. Example The minimum point x* for F ( x1 ,x 2 ) = f where f 1 ( x1 ,x2 ) = 1 x1 f 2 ( x1 ,x2 ) = 10( x2 x12 ) is obtained with the initial vector x0 = ( 1.2, 1.0)T.
C **EXAMPLE** DIMENSION X(2), F(2), VW(4,4) EXTERNAL ROSEN X(1) = 1.2 X(2) = 1.0 N= 2 M= 2 EPSR = 1.0 E3 MAX = 100*2*2 CALL NOLF1 (X, N, ROSEN, M, EPSR, MAX, * F, SUMS, VW, 4, ICON) WRITE(6,600) ICON IF(ICON. GE. 20000) STOP WRITE(6,610) SUMS, MAX WRITE(6,620) (I, X(I), I=1, N) WRITE(6,630) (I, F(I), I=1, M) STOP 600 FORMAT(1H1, 6H*ICON= I5) 610 FORMAT(1H , 17H SUM OF SQUARES= * E15.7,6H MAX = ,I5/) 620 FORMAT (1X, 3H X(, I2, 2H)=, E15.7) 630 FORMAT (1X, 3H F(, I2, 2H)=, E15.7) END C OJECTIVE FUNCTION SUBROUTINE ROSEN (X, Y) DIMENSION X(2), Y(2) Y(1) =1.0 X(1) Y(2) =(X(2) X(1)*X(1))*10.0 RETURN END
2 1
This subroutine solves this problem by using the LMM method. The Levenberg-Marquardt method, the Newton-Gauss method and the steepest descent method are explained below. Suppose that the approximate vector xk of vector x* which gives a local minimum is obtained and following relation is satisfied. x * = x k + x k (4.3)
( x , x ) + f (x , x )
1 2 2 2 1 2
f ( x ) is expanded up to the first order in the region of xk by using the Taylor series which results in (4.4). f ( x k + x k ) = f ( x k ) + J ( x k )x k (4.4)
f 1 f 1 x x n 1 x = x J ( x k ) k f m f m x n x1
From (4.4), the value of F ( x k + x k ) can be J ( x k ) is subsequently expressed as Jk.
(4.5)
( xk + xk ) f ( xk + xk ) ( xk ) f ( xk ) + 2 f T ( xk )J k xk
T T
+ xk J k J k xk
(4.6)
Method This subroutine obtains vector x* which gives a local minimum of F(x) = f (x) = f T (x) f (x)
2
The value of x k which minimizes this value is given as the solution of the system of linear equations (4.7) obtained when the right side of (4.6) is differentiated for x k .
T T Jk J k x k = J k f (x k )
(4.7)
= fi (x)
m i =1
(4.1)
and function value F(x*) corresponding to m real functions f 1 ( x ), f 2 ( x ), , f m ( x ) of n variables. Where, f ( x ) = f 1 ( x ), f 2 ( x ), , f m ( x) x = ( x1 , x2 , ,xn )
T
(4.7) is called a normal equations. In the Newton-Gauss method, x k is used for iterations as x k + 1 = x k + x k In this method, x k denotes the descent direction of F ( x ) , but x k may diverge itself.
(4.2)
(4.8)
491
NOLF1
F ( xk ) is the direction of the steepest descent of F(x) at xk. In the steepest descent method, x k is used as x k = F ( x k ) (4.9)
Computational procedures in this subroutine 1) Initialization Set Marquardt number v0. Obtains f ( x 0 ) and F ( x 0 ) . Set k = 0 2) Obtain Jk by difference approximation. 3) Solve (4.11) by the least squares method to obtain x k Let x k + 1 = x k + x k and obtain f ( x k +1 ), F ( x k + 1 ) 4) Test whether or not F(xk+1) < F(xk) is satisfied. When satisfied, go to step 8). 5) Convergence criterion When the convergence condition is satisfied, the subroutine terminates processing with ICON = 0 assuming xk to be minimum point x*. 6) Increase the Marquardt value, that is, let vk = 1.5 vk 7) Test the upper limit of the Marquardt number by vk 1/u, where u is the unit round off. (4.14)
Although x k in (4.9) surely guarantees a decrement of F(x), it is noted that if iteration is repeated, F(x) starts to zigzag, as many computational practices have been reported. Therefore, to decrease these demerits, Levenberg, Marquardt and Morrison proposed to determine x k by the following equations:
{J
T k
J k + v I x k = J f ( x k )
2 k T k
(4.10)
where, vk is a positive value (called the Marquardt number). x k which is determined by (4.10) depends on the value of vk. As vk 0 , the direction of x k is that of the Newton-Gauss method. On the other hand, the x k decreases monotonically in proportion as vk steepest descent direction J f ( x k ) decreases
T k
monotonically along with the increment of vk. As vk , the direction of x k is that of the steepest descent method. The characteristics of the Levenberg-Marquardt method is to determine the value of vk adaptively during iteration and to minimize F(x) efficiently. LMM method In the method by (4.10), normal equations are explicitly constructed, so it is not numerically stable. Equation (4.10) is equivalent to the least squares problem corresponding to the following: f ( xk ) Jk xk = v I k O
When (4.14) is satisfied, go to step 3) and continue iteration. When not satisfied, this subroutine terminates processing with ICON = 20000. 8) Convergence criterion When the convergence condition is satisfied, this subroutine terminates processing with ICON = 0 assuming xk+1 to be minimum point x*. 9) If this subroutine does not execute step 6), the Marquardt number is decreased, that is, let, vk = 0.5 vk
(4.11)
That is, the minimization of sum of squares of residual in (4.11) can be expressed by (4.10). In the LMM method, the normal equations are not explicitly constructed. The LMM method obtains x k by the least squares method applying the orthogonal transformation which is numerically stable, to (4.11). This subroutine obtains x by (4.11), and then x k + 1 = x k + x k and iterates to satisfy F(xk+1) < F(xk) to obtain minimum point x*. 492
Then setting k as k = k + 1 and proceed to step 2) to continuation. Notes on each algorithm 1) Setting Marquardt number v0 The norm of the Jacobian matrix at x0 is used as the initial value of the Marquardt number, v 0 = (f i / x j ) / (m n)
m n 2 i =1 j =1
(4.15)
NOLF1
f n f1 J k = x1 xn f m f m x = x k x1 x n
the forward difference (4.17) are used.
Where, g1 is the n-dimensional vector and g2 is the m-dimensional vector. Since the norm is unitarily invariant for orthogonal transformation, least squares solution x k in (4.11) is obtained by (4.20). Rx k = g1 (4.20)
(4.16)
f i f i ( xk + he j ) f i ( x k ) / h x j
(4.17)
Since R is an upper triangular matrix, (4.20) can be computed by backwards substitution. 4) Convergence criterion This subroutine test the convergence during iteration as follows: When F(xk+1) < F(xk) and x k +1 xk max 10 . , xk EPSR
( (
) )
where, ej is the j-th coordinate vector h = u , where u is the unit round off. 3) Computing x k by the least squares method This subroutine uses the Householder method to obtain x k solving (4.11) by the least squares method. That is, the left side of (4.11) is multiplied from the left by the orthogonal matrix Q of the Householder transformation to obtain upper triangular matrix. Jk R Q = v I O k
as satisfied, xk+1 is assumed to be minimum point x*. When F(xk+1) F(xk) and x k +1 xk max 10 . , xk EPSR are satisfied, xk is assumed to be minimum point x*. For further details, refer to References [36] and [37].
(4.18)
Where, R is the upper triangular matrix of n n. The orthogonal transformation is performed for the right side of (4.11). f ( xk ) g1 Q = g O 2
(4.19)
493
NOLG1
CALL NOLG1 (X, N, FUN, JAC, M, EPSR, MAX, F, SUMS, VW, K, ICON) Function Given m real functions f 1 ( x ), f 2 ( x ), , f m ( x ) with n variables, its Jacobian J(x), and initial vector x0, this subroutine obtains vector which gives a local minimum of F(x) =
m
The default value is used if 0.0 is specified. (See Comments on Use.) MAX ..... Input. The upper limit (0) of the count of function evaluation. Output. The count (> 0) of actual evaluation F ..... Output. The value of function f i ( x * ) . One-dimensional array of size m, where F(1) = f 1 ( x), , F( M ) = f m ( x ) Output. The value of the sum of squares F(x*). VW ..... Work area. Two-dimensional array of VW (K, N + 2) K ..... Input. The adjustable dimension ( m + n) of array VW. ICON ..... Condition code. (See Table NOLG1-1.)
Table NOLG1-1 Condition codes Code 0 10000 Meaning No error. The convergence condition was not satisfied within the specified number of interation. Marquardt number (vk) exceeded the upper limit during calculation. (See (4.14) in Method.) EPSR was too small or the error of the difference approximation of the Jacobian matrix exceeded the limit of calculation. N < 1, M < N, EPSR < 0.0, MAX = 0, or K < m+n Processing The last values obtained are stored in X, F and SUMS. Bypassed. (The last values obtained are stored in X, F and SUMS.)
SUMS .
i =1
{ f (x)}
i
(1.1)
and its function value F(x*) using the revised Marquardt method, that is, Levenberg-Marquardt-Morrison (LMM) method: In this subroutine, fi(x), i = 1 ,..., m is assumed to have up to the first continuous partial derivative, and m n 1. Parameters X ..... Input. Initial vector x0. Output. Vector x*. One-dimensional array of size n. N ..... Input. Number of variables n. FUN..... Input. Name of subroutine subprogram that calculates f i ( x ) The form of subprogram is as follows: SUBROUTINE FUN (X, Y) Parameters X ..... Input. Variable vector x. One-dimensional array of size n. Y ..... Output. Function values f i ( x ) for variable vector x. One-dimensional array of size m where F(1) = f 1 ( x), , F( M ) = f m ( x ) JAC ... Input. Name of subroutine subprogram that calculates J(x) The form of subprogram is as follows: SUBROUTINE JAC (X, G, K) Parameters X ..... Input. Variable vector x. One-dimensional array of size n. G ..... Output. Jacobian matrix for variable vector x. Two-dimensional array G (K, N) where G( I, J ) = f i / x j K ..... Input. Adjustable dimension of array G. Input. Number m of the functions. Input. Convergence criterion ( 0.0).
20000
30000
Bypassed.
Comments on use Subprograms used SSL II .. AMACH, MGSSL FORTRAN basic functions ... ABS, SORT, FLOAT Notes An EXTERNAL statement is necessary to declare the subprogram names correspond to parameters FUN and JAC in the calling program. EPSR Since F(x) is assumed to be approximately a quadratic function in the vicinity of point x*, it is appropriate to specify EPSR as EPSR u , where u is the unit round off to obtain the value of function F(x*) as accurate as the rounding error. The default value of EPSR is 2 u
M ..... EPSR ..
494
NOLG1
MAX The function evaluation count is incremented by one every time f i ( x ),i = 1, ,m is calculated and by n every time J(x) is calculated for variable vector x. The function evaluation count depends on characteristics of function f i ( x ) , initial vector, and
JACOBIAN SUBROUTINE ROSENJ (X, G, K) DIMENSION X(2), G(K, 2) G(1,1) = 1.0 G(2,2) = 20.0*X(1) G(1,2) = 0.0 G(2,2) = 10.0 RETURN END
convergence criterion. Generally, when an appropriate initial value is specified and the default value is used for the convergence criterion, it is adequate to specify MAX = 100n m. Even if the convergence condition is not satisfied within the specified evaluation count and the subroutine is returned with ICON = 10000, iteration can be resumed by calling this subroutine again. In this case, the user must specify a negative value as the additional evaluation count in the parameter MAX and retain other parameters unchanged. Example Given the following function: F ( x1 , x2 ) = f 12 ( x1 , x2 ) + f 22 ( x1 , x2 ) where f 1 ( x1 , x 2 ) = 1 x 1 f 2 ( x1 , x2 ) = 10( x2 x12 )
Method Given m real functions f 1 ( x ), f 2 ( x ), , f m ( x ) with n variable: F(x) = f (x) = f T (x) f (x)
2
= f i (x)
m i =1
(4.1)
vector x* which gives a local minimum of function F(x) and its function value F(x*) are obtained. Where, f ( x ) = f 1 ( x ), f2 ( x ), , f m ( x ) x = ( x1 , x2 , , xn )
T
(4.2)
minimum point x* is obtained using value x0 = ( 1,2, 1.0)T as the initial value
C **EXAMPLE** DIMENSION X(2), F(2), VW(4, 4) EXTERNAL ROSEN, ROSENJ X(1) = 1.2 X(2) = 1.0 N = 2 M = 2 EPSR = 1.0E 3 MAX = 100*2*2 CALL NOLG1 (X, N, ROSEN, ROSENJ, M, EPSR, * MAX, F, SUMS, VW, 4, ICON) WRITE(6,600) ICON IF(ICON. GE. 20000) STOP WRITE(6,610) SUMS, MAX WRITE(6,620) (I, X(I), I = 1, N) WRITE(6,630) (I, F(I), I = 1, M) STOP 600 FORMAT (1H1, 6H*ICON = ,I5) 610 FORMAT (1H , 17H SUM OF SQUARES= , * E15.7,6H MAX = ,I5/) 620 FORMAT (1X, 3H X(, I2, 2H)= , E15.7) 630 FORMAT (1X, 3H F(, I2, 2H)= , E15.7) END C OBJECTIVE FUNCTION SUBROUTINE ROSEN (X, Y) DIMENSION X(2), Y(2) Y(1) = 1.0 X(1) Y(2) = (X(2) X(1) *X(1))*10.0 RETURN END
This subroutine uses the revised Marquardt method, that is, the Levenberg-Marquardt-Morrison (LMM) method. To explain this method, let us review the Levenberg-Marquardt, Newton-Gauss, and steepest descent methods. Suppose that the approximate vector xk of vector x* that gives a local minimum is given and expressed as x * = x k + x k (4.3)
Expanding f ( x ) to a Taylor series of the first order in the vicinity of xk, we obtain f ( x k + x k ) = f ( x k ) + J ( x k )x k where J(xk) is the Jacobian matrix (4.4)
f1 f1 x x n 1 J ( xk ) = f m f m x = x k x1 x n
(4.5)
f T ( xk ) f ( x k ) + 2 f T ( xk )J k xk
(4.6)
495
NOLG1
The value of xk which minimizes F ( xk + xk ) is the solution of the system of linear equations (4.7) obtained by differentiating the right side of (4.6) with respect to xk :
T T Jk J k x k = J k f (xk )
(4.7)
This is called as the normal equation. In the Newton-Gauss method, xk is used for iterations as x k + 1 = x k + x k The xk direction indicates the descent direction, but xk may diverge in some case.
T F ( xk ) = 2 J k f (xk )
This means that the minimization of sum of squares of residual in (4.11) can be expressed by (4.10). The LMM method obtains xk without generating a normal equation system, but it includes the least squares method in which the orthogonal transformation having a high numerical stability is applied to (4.11). In this subroutine, x is obtained from (4.11); then using x k + 1 = x k + x k minimum point x* is obtained through iterations in which F(xk+1) < F(xk)
(4.8)
and F ( xk ) is the steepest descent direction of F(x) for xk. In the steepest descent method, xk = F ( xk ) (4.9)
is used. Although decrement of F(x) is guaranteed by xk of (4.9), many computational practices have shown that the value of F(x) starts oscillation during iterations. To eliminate these disadvantages, that is, divergence of xk and oscillation of F(x), Levenberg, Marquardt, and Morrison have proposed to obtain xk using
{J
T k
T 2 J k + vk I x k = J k f (xk )
(4.10)
where vk is a positive number called a Marquardt number. The value of xk obtained from (4.10) apparently depends on the value of vk : The direction of xk for v k 0 is that used in the Newton-Gauss method, where xk monotonically decreases as the value of vk increases beginning from 0 and the angle between T xk and the steepest descent direction J k f (xk ) monotonically decreases as vk further increases. If vk approaches infinity, the direction of xk becomes equal to that used in the steepest descent method. Advantageous features of the Levenberg-Marquardt method are to determine the most suitable value of vk dynamically during iterations to minimize the value of F(x) efficiently. LMM method The method in which expression (4.10) is used does not have sufficient numerical stability because the normal equation system is explicitly constructed. Equation (4.10) is equivalent to the least squares problem for f ( xk ) Jk xk = (4.11) v I O k
is satisfied. Computational procedures 1) Initialization Sets Marquardt number v0. Obtains f(x0) and F(x0). Sets k = 0. 2) Obtains Jk. 3) Solves (4.11) using the least squares method to obtain xk Sets xk + 1 = xk + xk Obtains f(xk+1) and F(xk+1). 4) Checks whether F(xk+1) < F(xk) is satisfied; if so, proceeds to 8) 5) Checks convergence; if the convergence condition is satisfied, assumes xk as to be minimum point x*, sets ICON = 0, then stops processing. 6) Increases Marquardt number as vk = 1.5 vk 7) Checks upper limit of Marquardt number. If vk 1/u, where u is the unit round off (4.14)
is satisfied, returns to 3) to continue iterations; otherwise, sets ICON = 20000, then stops processing. 8) Checks convergence; if the convergence condition is satisfied, assumes xk+1 as to be minimal point x*, sets ICON = 0, then stops processing. 9) If 6) has been bypassed, decreases Marquardt number: vk = 0.5vk. Sets k = k + 1, then returns to 2). Notes on algorithms 1) Marquardt number v0 setting The norm of the Jacobian matrix for x0 is used as the initial value of Marquardt number.
496
NOLG1
v0 = ( f i / x j ) / (m n)
m n 2 i =1 j =1
(4.15)
where g1 is an n-dimensional vector and g2 is an mdimensional vector. Since the norm is invariant for the orthogonal transformation, the least squares solution of xk for (4.10) is obtained from Rxk = g1 (4.18)
2) Calculation of xk by the least squares method The Householder method is used to solve (4.11) and obtain xk by the least squares method. The orthogonal matrix Q of the Householder transformation is multiplied by the left side of (4.11) to obtain the upper triangular matrix. Jk R Q = v k I O
(4.16)
Since R is an upper triangular matrix, (4.18) is solved using backward substitution. 3) Convergence check The convergence condition is checked as follows: If F(xk+1) < F(xk) and xk +1 xk max 10 . , xk EPSR
where R is the n n upper triangular matrix. The orthogonal transformation is also multiplied on the right side of (4.11) to obtain f ( xk ) g1 Q = g O 2
are satisfied, assumes xk+1 to be minimum point x*. If F(xk+1) F(xk) . , xk EPSR and xk +1 xk max 10
are satisfied, assumes xk to be minimum point x*. (See reference [36] and [37] for details.)
(4.17)
497
NRML
CALL NRML (EV, K, N, IND, M, MODE, ICON) Function Eigenvectors yi are formed by normalizing m eigenvectors xi (i = 1, , m) of an n-order real matrix. Either (1.1) or (1.2) is used. yi = xi / xi
Notes Eigenvectors are stored in EV such that each real eigenvector occupies one column and each complex eigenvector occupies two consecutive columns (one for the real part and one for the imaginary part). Refer to Fig. NRML-1. If subroutine HVEC or HBK1 are called before this subroutine, parameters EV, IND, and M can be used as input parameters to this routine.
Number of eigenvectors
1 1 2 1
2 3 0
3 4 1
(\
m M 1 M 1 0
(1.1)
IND 1
yi = xi / xi
(1.2)
EV
Real eigenvector Real part of a complex eigenvector Imaginary part of a complex eigenvector Real eigenvector
n 1. Parameters EV..... Input. m eigenvectors xi ( i = 1, , m ). (See Comments on use) EV (K,M) is a two-dimensional array. Output Normalized eigenvectors yi . K..... Input. Adjustable dimenson of array EV. ( n) N..... Input. Order n of the real matrix. IND..... Input. For each eigenvector in EV, indicates whether eigenvector is real or complex. If the Jth column of EV contains a real eigenvector, IND(J) = 1; if it contains the real part of a complex eigenvector, IND(J) = -1, and if it contains the imaginary part of a complex eigenvector, IND(J) = 0. IND is a one-dimensional array of size M. M..... Input. Size of the array IND. MODE.....Input. Indicate the method of normalization MODE = 1... (1.1) is used. MODE = 2... (1.2) is used. ICON..... Output. Condition code See Table NRML-1. Comments on use Subprograms used SSL II.....MGSSL FORTRAN basic functions..... ABS and SQRT
Table NRML-1 Condition codes Code 0 10000 30000 Meaning No error N=1 N<M, M<1, K<N, MODE was not 1 and 2 or an error was found in IND Processing EV (1,1) =1.0 Bypassed
Example Subroutine EIG1 is called to obtain the eigenvectors of an n-order real matrix, and then this routine is used to normalize the resultant eigenvalues such that x = 1. n 100.
C **EXAMPLE** DIMENSION A(100,100), ER(100), EI(100), * EV(100,100), VW(100), IND(100) 10 READ(5,500) N IF(N .EQ. 0) STOP READ(5,510) ((A(I,J),I=1,N),J=1,N) WRITE(6,600) N DO 20 I=1,N WRITE(6,610) (I,J,A(I,J),J=1,N) 20 CONTINUE CALL EIG1(A,100,N,ER,EI,EV,VW,ICPM) WRITE(6,620) ICON IF(ICON .GT. 10000) GO TO 10 DO 30 I=1,N 30 IND(I)=1 DO 40 I=1,N IF(EI(I) .EQ. 0.0) GO TO 40 IF(IND(I) .EQ. 0) TO TO 40 IND(I)=1 IND(I+1)=0 40 CONTINUE CALL NRML(E,V,100,N,IND,N, 1, ICON) CALL EPRT(ER,EI,EV,IND,100,N,N) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7)
When the eigenvectors of a real symmetric matrix are to be normalized, all of IND informations are 1.
498
NOLG1
600 FORMAT (1H1, 5, 15HORIGINAL MATRIX, 5X, * 2HN =, I3/) 610 FORMAT (/4(5X, 2HA(,I3,1H,,I3,2H)=,E14.7)) 620 FORMAT (1H0, 20X, 5HICON =, I5) END
In this example, subroutine EPRT is used to print the eigenvalues and corresponding eigenvectors of the real matrix. For details refer to the Example in section EIG1.
Method Given m eigenvectors x1(i = 1, ..., m) of an n-order real matrix, normalized eigenvectors yi are computed. Where xi =(x1i, ..., xni)T. When MODE = 1 is specified, each vector xi is normalized such that the maximum absolute value among its elements becomes 1. yi = xi / xi
, xi
= max x ki k
(4.1)
When MODE = 2 is specified, each vector xi is normalized such that the sum of the square of absolute values corresponding to its elements is 1. y i = x i / xi 2 , xi = xki
n 2
k =1
(4.2)
499
ODAM
CALL ODAM (X, Y, FUN, N, XEND, ISW, EPSA, EPSR, VW, IVW, ICON) Function This subroutine solves a system of first order ordinary differential equations of the form:
Output. Solution vector at final value xe. When the step output is specified, the solution vector at x = xm. FUN ..... Input. The name of the subprogram which evaluates f i (i = 1,2, , N ) in (1.1).
y = f ( x , y , y , , y ), y ( x ) = y y = f ( x , y , y ,, y ), y ( x ) = y
y1 = f1 ( x , y1 , y 2 , , y N ), y1 ( x0 ) = y10
2 2 1 2 N 2 0 N N 1 2 N N 0
20 N0
(1.1)
The form of the subroutine is as follows: SUBROUTINE FUN (X, Y, YP) Where X: Input. Independent variable x. Y: Input, One-dimensional array of size N, with corresponding Y(1) = y1, Y(2) = y2, ..., Y(N) = yN. YP: Output. One-dimensional array of size N, with corresponding YP(1) = f , ( x , y , y , , y ),YP (2) = f ( x , y , y , , y ), YP( N ) = f N ( x , y1 , y2 , , y N )
1 1 2 N
, f
and initial values x0, y10, y20, ..., yn0, , and the final value of x, (xe), are given. That is, it obtains the solutions
N ..... Input. Number of equations in the system. XEND ... Input. Final point xe to which the system should be solved. ISW ..... Input. Integer variable to specify conditions in integration. ISW is non-negative integer having three decimal digits, which can be expressed as ISW = 100d3 + 10d2 + d1
(y
1m
, y2 m ,
, y
Nm
)
m j =1
at points xm = x0 + hj ; m = 1,2 ,
,e
(See Fig. ODAM-1). The step size hj is controlled so that solutions satisfy the desired accuracy. This subroutine provides two types of output mode as shown below. The user can select the appropriate mode according to his purpose. Final value output: Returns to the user program when the solution at final value xe is obtained. Step output: Returns to the user program each time the solution at x1, x2, ...is obtained.
h1 x0 x1 h2 x2 h3 x3 he xe
Parameters X ..... Input. Starting point x0. Output. Final value xe. When the step output is specified, an interim point xm to which the solutions are advanced a single step. Y ..... Input. Initial values y10, y20, ...,yN0. They must be given in order of Y(1) = y10, Y(2) = y20, ..., Y(N) = yN0. One-dimensional array of size N.
Each d1 should be specified as follows d1: Specifies whether or not this is the first call. 0 ....First call 1 ....Successive call The first call means that this subroutine is called for the first time for the given differential equations. d2: Specifies the output mode. 0 ...Final value output 1 ...Step output d3: Indicates whether or not functions f 1 , f 2 , , f N can be evaluated beyond the final value xe. 0 ....Permissible 1 ....Not permissible The situation in which the user sets d3 = 1 is when derivatives are not defined beyond xe, or there is a discontinuity there. However, the user should be careful that if this is not the case specifying d3 = 1 leads to unexpectedly inefficient computation. Output. When this subroutine returns to the user program after obtaining the solutions at xe or the solutions at each step, d1 and d3 are altered as follows: d1: Set to 1. On subsequent calls, d1 should not be altered by the user. Resetting d1 = 0 is needed only when the user starts to solve another equations. d3: When d3 = 1 on input, change it to d3 = 0 when the solution at xe is obtained.
500
ODAM
EPSA ..... Input. Absolute error tolerance. ( 0.0) Output. If a value smaller than the allowable value EPSA is specified at entry time, this value is appropriately changed. (See Notes.) EPSR ..... Input. Relative error tolerance. Output. If EPSR is too small, the value is changed to an appropriate value. (See Notes.) VW ..... Work area. One-dimensional array of size 21N + 110. When calling this subroutine repeatedly, the contents should not be changed. IVW ..... Work area. One-dimensional array of size 11. When calling this subroutine repeatedly, the contents should not be changed. ICON ..... Output. Condition code. See Table ODAM-1.
Table ODAM-1 Condition Code Code 0 10 Meaning (In step output) A single step has been taken. Solution at XEND was obtained. Processing Subsequent calling is possible. Subsequent calling is possible after changing XEND. To continue, just call again. The function counter will be reset to 0. Although subsequent calling is possible, it is better to use a subroutine for stiff equations. EPSR and EPSA were set to larger, acceptable vaiues. Subsequent calling is possible. (The increased values of EPSR and EPSA should be checked by the user) Processing terminates.
Comments on use Subprograms used SSL II ... MGSSL, AMACH, UDE, USTE1, UNIT1 FORTRAN basic functions ... MOD, AMAX1, AMIX1, AMINI, ABS, SQRT, SIGN Notes This subroutine is a standard program to solve nonstiff and mildly stiff differential equations along with Runge-Kutta subroutine ODRK1. If in the following situation, this subroutine can be used more effectively. It takes much time for computing function f1 , f 2 , , f N Highly accurate solution is required. The solutions at many points are required, for example to make a table of the solutions. Derivatives, f 1 , f 2 , , f N have discontinuities. If it is known beforehand, that the equations are stiff subroutine ODGE should be used. The name of the subroutine associated with parameter FUN must be declared as EXTERNAL in the calling program. [Judgment by ICON] When the user specifies the final value output by setting the second digit of ISW to 0, he can obtain the solution at xe only when ICON is 10. However, this subroutine may return the control to the user program when ICON is 100, 200 or 10000 before reaching xe. When the step output is specified by setting the second digit of ISW to 1, the user can receive the solution at each step not only when ICON is 0, but also when ICON is 100 or 200. ICON = 10 indicates that the solution at xe has been obtained. [EPSA and EPSR] Suppose the elements of the solution of differential equations are Y(L) and the error (local error) is le(L), this subroutine controls the error to satisfy the following for L = 1, 2, ...., N.
100
200
A single step has been taken. It is detected that more than 500 steps are required to reach XEND. A single step has been taken. However it is detected the equations being processed have strong stiffness. EPSR and EPSA were too small for the arithmetic precision.
10000
30000
One of the following occurred: 1 N 0 2 X = XEND 3 An erroneous ISW was specified. 4 EPSA < 0 or EPSR < 0 5 The contents of IVW was changed (in subsequent calling).
(3.1)
When EPSA = 0.0 is specified in (3.1), the relative error is tested. When EPSR = 0.0 is specified in (3.1), the absolute error is tested. The user should read the following notes in using these criterions: It is desirable to use the relative error criterion for the problem in which the magnitude of the solution varies substantially. The absolute error criterion may be used for the problem in which the magnitude of the solution does not vary so much or the small solution is not required. Specifying EPSA0 and EPSA0 result in stable and useful criterion. In this case, relative errors are tested for the larger solution and absolute errors are tested for the smaller solution.
501
ODAM
If the maximum accuracy attainable by this subroutine is desired, specify EPSA and EPSR smaller than required. Then their values are appropriately increased in the subroutine. ICON = 10000 notifies the user of this behavior. The user should call the subroutine successively after receiving ICON = 10000. When EPSA = EPSR = 0.0 is specified, it should be changed to EPSR = 16u. u is a unit of round-off errors. [Parameter XEND] If the solutions at a sequence of output points are required, this subroutine should be successively called changing XEND sequentially. It is assumed that this subroutine is called repeatedly and thus it sets the value of parameters required for subsequent calls when returning to the user program. Therefore, the user can call the subroutine only by changing XEND. Only EPSA and EPSR can be changed on an as-required basis. Discontinuous points of derivatives and non-defined domain. If the solution or its derivatives has discontinuous points the points have to be detected to obtain satisfactory accuracy. Example: The equation, y, 0 x 1 y = y , 1 < x 2 , y (0) = 1 has the solution y = ex for 0 x 1, and y = e2-x for 1 x 2. Therefore, first-order derivative has a jump at x = 1. This subroutine automatically detects discontinuous points and performs appropriate computation. The user needs not recognize the discontinuous points. However, if the user specifies the location of the discontinuous points in a way below, the time required for detection is shortened and computation may be accurate. Call this subroutine with XEND set to a discontinuous point and with setting the third digit of ISW to 1. Setting the third digit of ISW to 1 without changing the lower two digits of ISW can be performed by: ISW = MOD (ISW, 100) + 100 When the solution at the discontinuous point has been obtained, the subroutine returns the control to the user program after setting the third digit to 0. Set the first digit of ISW to 0 on the next call, after advancing XEND appropriately. This can be performed by: ISW = (ISW / 10)*10
By setting ISW in this way, the subroutine is told as if the solution at discontinous points were a new initial value and other differential equations were to be solved. Example Simultaneous second-order ordinary differential equations y1 y 1= r 3 , y1 (0) = 1 , y1(0) = 0 y2 y 2= 3 , y 2 (0) = 0 , y 2(0) = 1 r are solved, where r = ( y12 + y 22 ) . These second-order
1/ 2
equations can be rewritten into first-order equations by replacing y1by y3 and y2 by y4 as follows: y 1 = y 3 , y1 (0) = 1 y 2 : y 4 , y 2 (0) = 0 y1 y 3 = 3 , y 3 (0) = 0 r y 4 = y 2 , y 4 (0) = 1 r3
(3.2)
The following example shows the solution on interval [0,2] with EPSA =10-8 and EPSR = 10-5 in (3.2). The solutions are to be output at each point of the following: xj = 2 j , j = 1,2, 64
,64
Therefore, this subroutine is called repeatedly increasing the value of parameter XEND by 2/64.
C ** EXAMPLE** DIMENSION Y(4), VW(200), IVW(11) EXTERNAL FUN X = 0.0 Y(1) = 1.0 Y(2) = 0.0 Y(3) = 0.0 Y(4) = 1.0 N = 4 EPSA = 1.0E8 EPSR = 1.0E5 ISW = 0 PAI = 4.0*ATAN (1.0) DX = PAI/32.0 WRITE(6,600) C DO 30 I = 1,64 XEND = DX*FLOAT(I)
502
ODAM
10 CALL ODAM (X, Y, FUN, N, XEND, ISW, EPSA, * EPSR, VW, IVW, ICON) IF(ICON. EQ. 10) GO TO 20 IF (ICON. EQ. 100) WRITE(6,620) IF (ICON. EQ. 200) WRITE(6,630) IF(ICON. EQ. 10000) WRITE (6,640) EPSA, * EPSR IF (ICON, EQ. 30000) STOP GO TO 10 20 WRITE(6,610) X, (Y(L), L = 1,4) 30 CONTINUE STOP 600 FORMAT(1H1, 12X, 1HX, 22X, 4HY(1), * 16X, 4HY(2), 16X, 4HY(3), 16X, 4HY(4)/) 610 FORMAT(6X, E15.8, 10X, 4(E15.8,5X)) 620 FORMAT(10X, 14HTOO MANY STEPS) 630 FORMAT(10X, 13HTHE EQUATIONS, * 1X, 18HAPPEAR TO BE STIFF) 640 FORMAT(10X, 15HTOLERANCE RESET, * 5X, 5HEPSA=, E12.5,5X, 5HEPSR=, E12.5) 650 FORMAT (10X, 13HINVALID INPUT) END SUBROUTINE FUN (X, Y, YP) DIMENSION Y(4), YP(4) R3 = (Y(1)*Y(1) + Y(2)*Y(2))**1.5 YP(1) = Y(3) YP(2) = Y(4) YP(3) = Y(1) / R3 YP(4) = Y(2) / R3 RETURN END
some derivatives already computed we can get a formula. Now, we consider a interpolation polynomial pm,k(x) based on k derivatives, which satisfies: Pk ,m ( x m+1 j ) = f m+1 j , j = 1,2, , k
(4.3)
If this Pk,m(x) is used for approximation to f(x,y) in (4.2) and ym is used instead of y(xm), we get a solution Pm+1:
m+1 Pk ,m ( x )dx Pm+1 = y m + xm x
(4.4)
Method This subroutine uses the Adams method with step-size control and order control. It is a standard subroutine to solve non-stiff or mildly-stiff initial value problems. This subroutine is most suitable for problems in which derivatives f 1 , f 2 , , f N in(1.1)are complicated and it takes much time to evaluate them. For convenience, we consider a single equation for some time, and we write it as
This is called k th-order Adams-Bashforth formula. Among various forms to represent Pk,m(x), the Newton form is used here. Interpolation points, generally, xm+1j (j = 1,2, ..., k) are unequally spaced because of step-size control. But, for simplicity, we suppose they are equally spaced with the interval of h. Newton backward difference representation for Pk,m(x) is expressed by: x xm ( x x m ) ( x x m+2 k ) k 1f Pk , m ( x ) = f m + f m + + m h h k 1 (k 1) Substituting this into (4.4), we get
dx
(4.5)
y = f ( x , y ), y ( x0 ) = y0
(4.1)
When k is 1, P1,m ( x ) = f m and the following is obtained: Pm + 1 = ym + hf m This is Eulers method. When f ( xm + 1 , Pm + 1 ) is computed using Pm+1 in (4.4), the approximation to derivative at xm+1 can be obtained. Using this, if we integrate again the approximation after correcting Pk,m(x) in (4.4), a more accurate solution can be obtained. Based upon this idea, Pm+1 in (4.4) is called a predictor and the corrected solution is called a corrector which is expressed by cm+1. Suppose P*k,m(x) to be a k-1 order polynomial interpolation satisfying the following:
The solution at xm is expressed by ym and the exact solution is expressed by y(xm). The value of f ( xm , y m ) is
1) Principle of the Adams method Suppose solution y0, y1, ..., ym have already been obtained, and we are going to obtain the solution ym+1 at xm+1 = xm+hm+1 From (4.1), the following equation holds:
m+1 f ( x , y )dx y ( x m+1 ) = y (x m ) + xm x
(4.2)
If the integrand f(x,y) in the right side is approximated by the polynomial interpolation using
503
ODAM
Pk*,m ( x m+1 j ) = f m+1 j , j = 1,2, , k 1 Pk*,m ( x m+1 ) = f ( xm+1 , Pm+1 ) In this interpolation, f ( xm+1 , Pm+1 ) is used and the oldest f m+1 k is removed. The corrector cm+1 is computed by: cm+1 = y m + xm +1 Pk*,m ( x )dx
xm
(4.6)
This is called the k th order Adams-Moulton formula. If P*k,m(x) is expressed in the form of Newton backward difference interpolation, (4.6) can be expressed as follows: f cm+1 = y m + h i =1 where, 0f mp+1 = f mp+1 f ( x m+1 , pm+1 ) if mp+1 =i 1f mp+1 i 1f m ,i 1 * 0 =1 1 1 i* = 0 (s 1)(s)(s + i 2)ds , i 1 i!
k * i 1 i 1 p m+1
Prediction ... Pm+1 Evaluation ... f(xm+1,pm+1) Correction ... ym+1 Evaluation... f(xm+1,ym+1) This is often called the PECE method. 2) Adams method based upon modified divided differences Since points{xm+1-j} are unequally spaced, the computation for a predictor (4.4) and corrector (4.6) in that situation are described concretely. Pk,m(x) can be expressed using divided differences as follows: Pk ,m ( x ) = f [ xm ] + ( x x m ) f [ xm , xm1 ]+ + ( x xm )( x xm1 )
(x x
m+ 2 k
) f [x
, x m1 ,
,x
(4.10)
m+1 k
(4.7)
where, f [ xm ] = f m f x m , x m1 ,
m 1
, x ] f [ x , , x ] f [ x , , x ] =
[
m j m j m m +1 j
x m xm j
, j = 1,2 , (4.8)
,k 1
This is called the Backward Eulers method. These are the principles of the Adams method. Since, in actual computation, points {xm+1-j} are spaced unequally due to step-size control Pk,m(x) and P*k,m(x) are expressed in the form of a modified divided difference instead of using (4.5) an (4.7). The error of the corrector cm+1 is estimated as indicated below. Note that fm+1-k was not used in constructing Pk,m(x). If, however, we use fm+1-k and integrate the resulting interpolation polynomial of degree higher by one, which we donote by P*k+1,m(x), we can obtain another corrector, say cm+1(k+1), of order higher by one. According to the error analysis, E m + 1 cm + 1 (k + 1) cm + 1 (4.9)
In the integration formula based upon the expression in (4.10), points {xm+1-j} and divided differences are used in the program. However, this subroutine uses a sequence of step sizes{hm+1-j} instead of {xm+1-j}, and modified devided differences instead of divided differences. The formula to be described below is reduced to (4.5) if the step size is constant. We introduce notations to be used later. hi = xi xi 1 s = ( x x m ) / hm+1 i (m + 1) = hm+1 + hm + + hm+2i , i = 1,2, i (m + 1) = hm+1 / i (m + 1), i = 1,2, 1 (m + 1) = 1 1 (m + 1) 2 (m + 1) i1 (m + 1) i (m + 1) = , i = 2,3, 1 (m) 2 (m) i1 (m) 1 (m) = f [ xm ] = f m i (m) = 1 (m) 2 (m) i1 (m) f [ xm , x m1 , , xm+1i ] i = 2,3, (4.11)
can be used as an estimate of the local error of cm+1. Consequently, if the magnitude of Em+1 is within a tolerance, this subroutine consider cm+1 to meet the required accuracy, and take cm+1 (k + 1), instead of cm+1, as a solution to be output. In what follows, ym+1(k) stands for cm+1, and ym+1 for cm+1 (k + 1). The procedures to obtain the solution at xm+1 are summarized as follows:
Here, i (m) is called a modified divided difference. When the step size is constant, i (m + 1) = ih , i (m + 1) = 1 / i and i (m + 1) = 1 therefore i (m) =i1f m Using above notations, the general term in (4.10) can be expressed by:
504
ODAM
( x x )( x x )( x x
m 1
shm+1 shm+1 = 1 (m + 1) 2
) f [x , x + (m) (m + 1)
m + 2i m 1
m 1
, x
i
m +1i
]
q
1 2 3 4
(4.12)
To simplify the right hand side of this equation we introduce i * (m) = i (m + 1)i (m) and 1 shm+1 ci ,m ( s) = m + 1 = s ( ) 1 sh + shm+1 + 1 (m) m 1 m ( 1 + 1) 2 (m + 1) ,i = 1 ,i = 2
The values placed on the first row in this table correspond to {gi,1}. Therefore (4.14) is reduced to pm+1 = ym + hm+1 gi ,1i * (m)
k i =1
3 5/12 1/8
4 .3/8
(4.16)
Next, the computation of corrector is described. For corrector ym+1, the formula of order k + 1 which is one order higher than the predictor is used. The corrector ym+1 is based upon:
m+1 * Pk +1,m ( x )dx ym+1 = ym + xm x
(4.17)
Then (4.12) can be expressed by ci ,m (s)i* (m) . Therefore we get Pk ,m ( x ) = ci ,m ( s)i * (m)
k i =1
shm +1 + i 2 (m ) , i = 3 ,4 , i 1 m +1 ) (
Where, P*h+1,m(x) is the interpolation polynomial satisfying not only the interpolation conditions for Pk,m(x) but also Pk*+ 1,m ( xm + 1 ) = f mp+ 1 = f ( xm + 1 , pm + 1 ) (4.13) Using a divided difference we can write. Pk*+1 ,m ( x ) = Pk ,m ( x ) + ( x x m )( x x m1 ) ( x xm+1 k ) f
p
where ci,m(s) is a polynomial with respect to s of degree i -1, which is determined depending upon only the distribution of points {xm+1-j}. Substituting (4.13) into (4.4), and changing the integration variable x to s, the following can be obtained.
1 k 0 ci ,m (s)ds i* (m) pm+1 = ym + hm+1 i =1
[x
m +1
,x
m+1 k
(4.18)
The index p indicates that in the divided difference f mp+1 should be used instead of f m + 1 = f ( xm + 1 , ym + 1 ) . Substituting (4.18) into (4.17), we get, ym+1 = pm+1 + hm+1 gk +1,1k p +1 (m + 1) (4.19)
(4.14)
This corresponds to (4.5) in which the step size is constant. The integral for ci,m(x) can be obtained by repeated integration by parts. The results are mentioned below, where sequence {gi,q} is produced by (4.15) for i 1 and q 1. g1 ,q = 1 / q , g2 ,q = 1 / (q(q + 1)) gi ,q = gi 1 ,q i 1 ( m + 1) gi 1 ,q +1 , i 3 gi ,1 = 0 ci ,m (s)ds
1
So the corrector can be expressed by adding the correction term to predictor pm+1. Here, the index p also indicates that in the divided difference of k +1 (m + 1), f mp+1 should be used instead of f m + 1 = f ( xm + 1 , ym + 1 ) . The k th order corrector ym+1(k) can be computed in the same way as follows: ym+1 ( k ) = pm+1 + hm+1 gk ,1k p +1 ( m + 1) (4.20)
(4.15)
3) Solution at any point Since the step size is taken as long as the error is within a tolerance generally the output point xe satisfies xm < xe xm+1 (4.21)
The following shows the triangular table for gi,q in (4.15) when the step size is constant.
505
ODAM
In obtaining the solution at xe, although we could restrict the step size so as to h it xe, this subroutine integrates beyond xe with a step size optimally determined to get the solution at xm+1, unless a particular situation is posed on the problem, e.g. when f (x,y) is not defined beyond xe. Then the solution at xe is obtained as follows. Let Pk+1,m+1(x) be an interpolation polynomial of degree k satisfying: Pk + 1, m + 1 ( x m + 2 j ) = f m + 2 j , j = 1,2,
(4.25)
Defining the right side of the equation as ERR, if for a given tolerance . ERR (4.26)
,k + 1
()
(4.22)
If the solution at xm+1 satisfies the required accuracy, ye also satisfies the required accuracy. To compute (4.22), Pk+1,m+1(x) should be expressed using modified divided differences. First letting, hI = xe xm+1 , s = ( x xm+1 ) / hI Pk+1,m+1(x) can be expressed as: Pk +1,m+1 ( x ) = f [ xm+1 ] + ( x x m+1 ) f [ xm+1 , x m ]+ + ( x xm+1 )
( x x
m+ 3i 1
m +2 k
) f [x
m+1
, , x
m +1 k
is satisfied, the subroutine accepts ym+1 as the solution at xm+1, then evaluates f(xm+1,ym+1). This completes the current step. 5) Order control Control of the order is done at each step by selecting the order of the formula of the Adams method. This means to select the degree of the interpolation polynomial which approximates f(x,y). This selection is performed before the selection of the step size. Suppose the solution ym+1 at xm+1 has been accepted by the k th order Adams method and the order for the next step is going to be selected. The local error at xm+2 can be determined according to the step size hm+2 to be selected later and the derivative at xm+2. Since these are not known when the order is selected, the error cannot be known correctively. Therefore using only those values which are available so far, the subroutine estimates the local errors at xm+2 of order k 1, k, and k + 1 as ERKM1, ERK, and ERKP1 below.
p ERKM1 = h * k 1 k ( m + 1)k ( m + 1) * = h k k +1 ( m + 1)k +p1 (m + 1) ERK ERKP1 = h k*+1k +2 ( m + 1)
( x x )( x x )( x x ) f [x , x sh + (m + 1) sh = (m + 1) (m + 1) sh + (m + 1) (m + 1) (m + 1)
m+1 m m +1 l l 1 2 l i 2 i i 1
, m
, x
m+ 2 i
(4.27)
After expressing Pk+1,m+1(x) using modified divided differences and substituting it into (4.22), the following is obtained: ye = ym+1 + hI giI,1i (m + 1)
i =1 k +1
i1
(4.23)
where giI,1 are generated by the following recurrence equation: g1I,q = 1 / q giI,q = i 1 giI1 ,q i 1 giI1,q+1 , i 2 where hI / 1 (m + 1) , i = 1 i = hI + i1 (m + 1) ,i 2 i (m + 1) i = hI / i (m + 1) , i 1 (4.24)
i* is the coefficient defined in (4.7). ERKP1 is estimated only when the preceding k + 1 steps have been taken with a constant step size h. This is because if the step size is not constant, the value of ERKP1 may not be reliable. In addition to (4.27), the local error of order k -2 is also estimated as ERKM2 below.
ERKM2 = h k*2 k 1 (m + 1)k p 1 1 (m + ) The order is controlled based on the above introduced values. a) When one of the following is satisfied, reduce the order to k-1.
4) Acceptance of solutions Suppose local error of k th order corrector ym+1(k) to be lem+1(k) It can be estimated by the difference between(k + 1)th order corrector ym+1 and ym+1(k). From (4.19) and (4.20), we can see the following: 506
ODAM
k > 2 and max (ERKM1, ERKM2) ERK k = 2 and ERKM1 0.5ERK The preceding k + 1 steps have been taken with a constant step size and ERKM1 min (ERK, ERKP1) b) When the preceding k + 1 steps have been taken with a constant step size and one of the following is satisfied, increase the order to k + 1. 1 < k < 12 and ERKP1 < ERK< max (ERKM1, ERKM2) k = 1 and ERKP1 < 0.5ERK c) The order is not changed at all if neither a) or b) above are satisfied. At each step, the above mentioned a), b) and c) are tested sequentially. 6) Step size Control The step size is controlled at each step after the order has been selected. Suppose order k for the next step has been selected and the most recently used step size is h. If the next step is processed by step size rNh, the local error can be estimated by: rk+1 ERK (4.28)
is not satisfied, the step is retried. The order is selected by testing a) in item 5, that is, the order will either be decreased or not be changed at all. On the other hand, the step size is halved unconditionally. If the step is tried three times and (4.26) has still not been satisfied, the first order Adams method, that is, Eulers method, is used and the step size is halved until (4.26) is satisfied. 8) Stating procedure At the first step in solving the given initial value problem, the first order Adams method is used. Here, the method of determining the initial step size and the method of increasing the order and step size are described. When we assume the initial step size is h1, the local error in Eulers method at points x1 ( = x0 + h1) is estimated by h12 f ( x 0 , y0 ) h1 can be selected so as not to exceed 0.5 . However, taking into consideration the possibility of f(x0,y0) = 0, and also for safety, the following is used: 0.5 h1 = min 0.25 f ( x , y ) 0 0 where, H = max 4u x0 , xe x0
1 2
Therefore, the ratio r may be taken a value as large as possible while the value in (4.28) does not exceed the error tolerance . However, for safety, 0.5 is used instead of , and r is determined with the following conditions; rk+1 ERK0.5 (4.29)
, H
(4.30)
u: unit of round-off error At starting step, the order and step-size is controlled as follows: The order is increased by one for subsequent steps and the step size is increased twice each time a step is processed. This is because the order should be increased rapidly for effectiveness, and also because h1 of (4.30) tends to be conservative when is small. This control is terminated when the solution at a certain step does not meet the criterion, or when the order comes to 12, or a) in item 5) is satisfied. The subsequent orders and step sizes are controlled according to the previously mentioned general rules. 9) Extension to a system of differential equations For a system of differential equations, the above mentioned procedures can be applied to each component of the solution vector. However, each error estimate of ERR, ERK, ERKM1, ERKM2 and ERKP1 is defined as follows instead of defining to each component: From the user specified EPSA and EPSR, we introduce W(I) = Y(I) EPSR + EPSA / EPS EPS = max( EPSA, EPSR )
If the step size varies, it will after the coefficients of predictor and corrector formulas. If the step size varies much, it will possibly cause undesirable error propagation property of the formula. Taking this into consideration, when increasing the step size, it should be increased by a factor of two at most, and when decreasing the step size, it should be halved at most. The step size is controlled as follows: a) When increasing the step size, if 2k+1 ERK0.5 b) the step size is increased by a factor of 2. When decreasing the step size, if ERK>0.5 the actual rate is determined with r = (0.5 / ERK)1/(k+1) according to r = min (0.9, max(1/2, r)) c) If neither a) nor b) are satisfied, the step size is not changed at all. 7) When the solution could not be accepted When the criterion (4.26) for accepting the solution
(4.31)
507
ODAM
Note that when this is satisfied, from (4.31) and (4.32), we can see (4.32) le( I ) Y ( I ) EPSR + EPSA , I = 1,2,
,N
where, Y(I) and le(I) are the Ith component of the solution vector and its local error respectively. ERK and ERKM1 are defined similarly. The criterion used for accepting the solution is ERR EPS
This subroutine is based on the code (Reference [71]) by L.F. Shampine and M.K. Gordon.
508
ODGE
CALL ODGE (X, Y, FUN, N, XEND, ISW, EPSV, EPSR, MF, H, JAC, VW, IVW, ICON) Function This subroutine solves a system of first order ordinary differential equations of the form:
, y ), y ( x ) = y y = f ( x , y , y , , y ), y ( x ) = y y = f ( x , y , y , , y ) , y ( x ) = y
y1 = f 1 ( x , y1 , y2 ,
2 2 1 2 N 1 0 10 N 2 0 N N 1 2 N N 0
20 N0
(1.1)
vector at x = xm. FUN ..... Input. The name of subroutine subprogram which evaluates f i , i = 1,2, , N in (1.1). The form of the subroutine is as follows: SUBROUTINE FUN (X, Y,YP) where X ..... Input. Independent variable x. Y ..... Input. One-dimensional array of size N, with the correspondence Y(1) = y1, Y(2) = y2, ..., Y(N) = yN YP ..... Output. One-dimensional array of size N, with the correspondence YP(1) = f 1 ( x , y1 , y2 , , y N ),
by Gears method or Adams method, when functions f 1 , f 2 , , f N and initial values x0, y10, y20, ..., yN0 and the final value of x, xe are given. That is, it obtains the solutions (y1m, y2m, ..., yNm) at points
N ..... XEND.
xm = x0 + h j ; m = 1,2 ,,
j=1
step size is controlled so that solutions satisfy the desired accuracy. Gears method is suitable for stiff equations, whereas Adams method is suitable for nonstiff equations. The user may select either of these methods depending on stiffness of the equations. This subroutines provides two types of output mode as shown below. The user can select the appropriate mode according to his purpose: Final value output ... Returns to the user program when the solution at final value xe is obtained. Step output ... Returns to the user program each time the solution at x1, x2, ... is obtained.
h1 x0 h2 x2 h3 x3 he xe
Fig. ODGE-1 Solution output point xm (in the case x0 < xe)
Parameters X ..... Input. Starting point x0. Output. Final value xe. When the step output is specified, an interim point to which the solution is advanced a single step. Y ..... Input. Initial values y10,y20, ..., yN0. They must be given in the order of Y(1) = y10, Y(2) = y20, ..., Y(N) = yN0 One-dimensional array of size N Output: Solution vector at final value xe. When the step output is specified, the solution
Input. Number of equations in the system. Input. Final point xe to which the system should be solved. ISW ..... Input. Integer variable to specify conditions in integration. ISW is a nonnegative integer having four decimal digits, which can be expressed as ISW= 1000d4 + 100d3 + 10d2 + d1 Each di should be specified as follows. d1 ..... Specifies whether or not this is the first call 0 ..... First call. 1 ..... Successive call The first call means that this subroutine is called for the first time for the given differential equations. d2 ..... Specifies the output mode. 0 ..... Final value output. 1 ..... Step output. d3 ..... Indicates whether or not functions f 1 , f 2 , , f N can be evaluated beyond the final value xe. 0 ..... Permissible. 1 ..... Not permissible. The situation in which the user sets d3 = 1 is when derivatives are not defined beyond xe, or there is a discontinuity there. However, the user should be careful that if this is not the case specifying d3 = 1 leads to unexpectedly inefficient computation. d4 ..... Indicates whether or not the user has altered some of the values of MF, EPSV, EPSR and N: 0 .... Not altered. 1 ..... Altered. See 6 and 7 in
509
ODGE
Comments on Use for specification. H ..... Output. When the solutions at xe or at an interim point are reterned to the user program, the values of d1, d3, and d4 are altered as follows. d1 ..... Set to 1: On subsequent calls, d1 should not be altered by the user. Resetting d1 = 0 is needed only when the user starts solving another system of equations. d3 ..... When d3 = 1 on input, change it to d3 = 0 when the solution at xe is obtained. d4 ..... When d4 = 1 on input, change it to d4 = 0. EPSV ..... Input. Absolute error tolerances for components of the solution. One-dimensional array of size N, where EPSV(L) 0.0, L = 1,2, ..., N Output. If EPSV(L) is too small, the value is changed to an appropriate value. (See 4 in Comments on Use.) EPSR ..... Input Relative error tolerance. Output. If EPSR is too small, the value is changed to an appropriate value. (See 4 in Comments on Use.) MF ..... Input. Method indicator. MF is an integer with two decimal digits represented as MF = 10*METH + ITER. METH and ITER are the basic method indicator and the corrector iteration method respectively, with the following values and meanings. METH... 1 for Gears method. This is suitable for stiff equations 2 for Adams method. This is suitable for nonstiff equations. ITER ... 0 for Newton method in which the analytical Jacobian matrix J = f i / y j is
For nonstiff equations, specify ITER = 3 Input. Initial step size (H0) to be attempted for the first step on the first call The sign of H must be the same as that of xe x0. A typical value of |H| is H = min 105 , max 104 x0 , xe x0
))
The value of H is controlled to satisfy the required accuracy. Output. The step size last used. JAC ... Input. The name of subroutine subprogram which evaluates the analytical Jacobian matrix: f 1 f 1 f 1 y y yN 1 2 f 2 f 2 f 2 y N J = y1 y 2 f N f N f N y1 y2 y N The form of the subroutine is as follows. SUBROUTINE JAC (X, Y, PD, K) where, X ..... Input. Independent variable x. Y ..... Input. One-dimensional array of size N, with the correspondance Y(1) = y1, Y(2) =y2, , Y(N) = yN PD ... Output. Jacobian matrix stored in a two-dimensional array PD (K, K), where f PD(i , j ) = i y j
used. The user must prepare a subroutine to calculate the Jacobian matrix. (See explanations about parameter JAC.) 1 for Newton method in which the Jacobian matrix is internally approximated by finite difference. 2 for Same as ITER = 1 except the Jacobian matrix is approximated by a diagonal matrix. 3 for Function iteration in which the Jacobian matrix is not used. For stiff equations, specify ITER = 0, 1 or 2.0 is the most suitable value, but if the analytical Jacobian matrix cannot be prepared, specify 1. Specify ITER = 2 if it is known that the Jacobian matrix is a diagonally dominant matrix.
1iN,1jN K ..... Input. Adjustable dimension of array PD. (See Example.) Even if the user specifies ITER 0, he must prepare a dummy subroutine for the JAC parameter as follows: SUBROUTINE JAC (X, Y, PD, K) RETURN END VW ..... Work area. One-dimensional array of size N(N +17) + 70. The contents of VW must not be altered on subsequent calls. IVW ..... Work area. One-dimensional array of size N + 25. The contents of IVW must not be altered on subsequent calls. ICON .... Output. Condition code. (See Table ODGE-1.)
510
ODGE
Table ODGE-1 Condition codes Code 0 10 Meaning A single steg has been taken (in step output). Solution at XEND was obtained. EPSR and EPSV(L): L = 1, 2, .., N are too small for the arithmetic precision. The requested accuracy could not be achieved even with a step size 10-10 times the initial step size. The corrector iteration did not converge even with a step size 10-10 times the initial step size. Processing Subsequent calls are possible. Subsequent calls are possible after changing XEND. EPSR and EPSV(L): L = 1, 2, ..., N were increased to proper values. (Check the in EPSR and EPSV.)
Parameters EPSV and EPSR Let Y(L) be the L-th component of the solution vector and le(L) be its local error, then this subroutines controls the error so that le ( L) EPSR Y( L) + EPSV(L) (3.1)
10000
15000
16000
30000
One of the following occurred, 1) N 0 2) X = XEND. 3) ISW specification error. 4) EPSR < 0 or there exists I such that EPSV(I) < 0. 5) (XEND X) H0. 6) The IVW was changed (on the second or subsequent calls).
The methods specified through parameter MF may not be appropriate for the given equations. Change the MF parameter, then retry. Bypassed
is satisfied for L = 1, 2, ..., N. When EPSV(L) = 0 is specified, the relative error is tested. If EPSR = 0, the absolute error is tested with different tolerances between components. Note the following in specifying EPSV(l) and EPSR: Relative error test is suitable for the components which range over different orders in the integration interval. Absolute error test may be used for the components which vary with constant orders or so small as to be of no interest. However, it would be most stable and economical to specify: EPSV(L)0, L=1, 2, ,N EPSR0 In this case, relative errors are tested for the large components and absolute errors are tested for the small components. In the case of stiff equations the orders of magnitude of the components might be greatly different, it is recomendable to specify different EPSV(L) between the components. If EPSR = 0 and some of the elements of EPSV are zero on input, the subroutine after EPSR to 16u, where u is the round off unit. Parameter XEND If the solutions at a sequence of values of the independent variable are required, this subroutine should be successively called changing XEND. For this purpose, the subroutine sets the values of parameters required for the next call when returning to the user program. Therefore the user can call the subroutine only by changing XEND. Changing MF during the solution If the given equations are non-stiff initially and stiff later in the integration interval, it is desirable to change the value of MF from 23 to 10 (or 11 or 12) as follows when the equations become stiff: Set d4 of ISW to 1. This can be done with the statement ISW = ISW + 1000. Change the value of MF. Set XEND to the value of the next output point, then call this subroutine. This subroutine clears the d4 of ISW by ISE= MOD (ISE, 1000)
Comments on use Subprograms used SSL ... MGSSL, AMACH, USDE, UNIT2, USTE2, USETC, USETP, USOL, UADJU, UDEC FORTRAN basic functions ... MOD, FLOAT, AMAX1, AMIN1, ABS, SORT Notes This subroutine can be effectively used for stiff equations or those which is initially nonstiff but change to be stiff in the integration interval. For nonstiff equations, use subroutine ODAM or ODRK1 for efficiency. The names of the subroutines associated with parameter FUN and JAC must be declared as EXTERNAL in the calling program. Judgement by ICON When the user specifies the final value output, he can obtain the solution at xe only when ICON = 10. When the step output is specified, the user can obtain the solution at each step when ICON = 0. ICON = 10 indicates that the solution at xe has been obtained.
511
ODGE
indicating that the users request has been completely accomplished on return to the user program. However, if the solution at XEND can be readily obtained without changing MF, MF is not changed on return. This means that the value of MF is changed only when the value of XEND reaches a value where the method should be changed. Changing parameters N, EPSV, and EPSR during the solution The user can change the values of parameters N, EPSV, and EPSR during the solution. However, considerable knowledge about the behavior of the solution would be required for changing the value of N as follow: In the solution of stiff equations, some components of the solution do not change so much as compared with the other components or some components become small enough to be neglected. If these components are of no interest to the user it will be practical to regard these components as constants thereafter then to integrate only the remainder. This reduces the amount of computations. To change the value of parameter N means to reduce the number of components to be intergrated. In this subroutine, some of the last components of the system (1.1) are removed. Therefore, the user must arrange the components prior to the solution. Based on the above, reduction of parameter N can be done in the manner described below: Suppose that initial value of N is N0 and changed to Nc (<N0) during the solution, (N0 Nc) equations of the last potion of the system are removed, so the reduced system of equations are solved. In this case, the components Y(L): L = Nc + 1, Nc + 2, ..., N0, are kept constant in the system reduced. In the user-prepared subroutines, FUN and JAC, derivatives and Jacobian matrices only for Nc equations need be calculated. To identify the change of N in these routines, specify parameter N in COMMON statements. Values of EPSV and EPSR can also be changed if necessary in the same way as parameter MF explained above. Example The following example solves the system: y1 = y 2 , y1 (0) = 1 = 11y 2 10 y1 , y2 (0) = 1 y2 in the interval [0, 100]. The system is stiff because the eigenvalues of the Jacobian matrix are 1 and 10. In
the following example, MF = 10, EPSR = 10-4 and EPSV(1) = EPSV(2) = 0 are used. The solution at the following points are to be obtained. xj =10-3+j, j = 1, 2, ...., 5 For this purpose, this subroutine is called repeatedly by setting XEND to xj.
C **EXAMPLE** DIMENSION Y(2), EPSV(2), VW(110), IVW(30) EXTERNAL FUN, JAC X = 0.0 Y(1) = 1.0 Y(2) = 1.0 N = 2 EPSR = 1.0E4 EPSV(1) = 0.0 EPSV(2) = 0.0 MF = 10 ISW = 0 H = 1.0E 5 WRITE(6,600) C XEND = 1.0E3 DO 40 I = 1, 5 XEND = XEND *10.0 10 CALL ODGE (X, Y, FUN, N, XEND, ISW, EPSV, * EPSR, MF, H, JAC, VW, IVW, ICON) IF(ICON. EQ. 10) GO TO 30 IF (ICON . EQ. 10000. OR. ICON. EQ. 15000) * GO TO 20 IF (ICON. EQ. 16000) WRITE(6,630) STOP 20 WRITE(6,620) EPSR, EPSV(1), EPSV(2) GO TO 10 30 WRITE(6,610) X, Y(1), Y(2) 40 CONTINUE STOP 600 FORMAT(1H1, 12X, 1HX, 22X, 4HY(1), * 16X, 4HY(2)/) 610 FORMAT(6X, E15.8, 10X, 2(E15. 8,5X)) 620 FORMAT(10X, 15HTOLERANCE RESET, 5X, * 5HEPSR=, E12.5, 5X, 8HEPSV(1)= ,E12.5, * 5X, 8HEPSV(2) =, E12.5) 630 FORMAT(10X, 17HNO CONVERGENCE IN, * 20H CORRECTOR ITERATION) 640 FORMAT(10X, 13HINVALID INPUT) END SUBROUTINE FUN(X, Y, YP) DIMENSION Y(2),YP(2) YP(1) = Y(2) YP(2) = 11.0*Y(2)10.0*Y(1) RETURN END SUBROUTINE JAC(X, Y, PD, K) DIMENSION Y(2),PD(K, K) PD(1, 1) = 0.0 PD(1, 2) = 1.0 PD(2, 1) = 10.0
512
ODGE
Method Both Gears and Adams methods with step size and order controls are used in this subroutine. Gears method is suitable for stiff equations, whereas Adams method is suitable for non-stiff equations. Both methods are multistep methods. The subroutine employs the identical strategies for storing the solutions at the past points and for controling the step size and order between the two methods. Gears method will be described below first, then the step size control and order control will follow. The modifications necessary to be made when Adams method is used are also presented. For simplicity, consider a single equation y=f(x,y) , y(x0)=y0 for which the computed solution at xm (referred to as the solution hereafter) is denoted by ym and the true solution is referred to as y(xm). The value of f(xm, ym) is represented shortly as fm, which must be distinguished from f(xm, y(xm)). 1) Principle of Gears method Assume that y0, y1, ..., ym are known and the solution ym+1 at xm+1 = xm + hm+1 is being obtained. The fundamental ideas of Gears method are best stated as follows: Now, we consider the interpolation polynomial m+1 (x) of degree k satisfying k + 1 conditions
becomes nonlinear with respect to ym+1; therefore, ym+1 is calculated using an iteration method with an appropriate initial value. An initial value can be determined as follows: Suppose the polynomial m(x)to be an interpolation polynomial of degree k satisfying.
(4.4)
(4.5)
is regarded as an approximation at xm+1 and is used as the initial value for the iteration. In Gears method explained above, pm+1 is referred to as the predictor and ym+1 obtained in the iteration method is referred to as the corrector. Especially, in the Gears method when k = 1, that is, of order one pm+1 = y m + hm+1 f ( x m , y m ) is used as the predictor, and the solution ym+1 is obtained from hm+1 f ( xm+1 , ym+1 ) = ym+1 y m (4.7) (4.6)
, j = 0,1,2 ,
,k
(4.1)
Equation (4.1) contains solution ym+1 as an unknown parameter. The value of ym+1 is determined so that the derivative of the polynomial m+1 (x) at xm+1 is equal to f(xm+1, ym+1), that is, to satisfy
(4.6) and (4.7) are called the Euler method and the backward Euler method, respectively. Since Gears method is based on the backward differentiation formula as expressed in (4.3), it is referred to as the backward differentiation formula (BDF) method. 2) Nordsieck form for Gears method The predictor is calculated from m(x), whereas the corrector is calculated from m+1 (x) as explained above. Since the corrector obtained determines the m+1 (x), the calculation of the corrector means to generate m+1 (x). The determined m+1 (x) is used to calculate the predictor in the next step. This means that one integration step consists of generating m+1 (x) from m(x); m(x) can be expanded into a Taylor series as
(4.2)
m ( x ) = ym + ( x xm ) y m + ( x xm )
If we represent m+1 (x) as a Lagrangian form, and differentiate it at x = xm+1, (4.2) gives
+(x x )
m
ym + 2! (4.8)
(k) ym k!
(4.3)
where
(q) = ym
dq m ( xm ) dx q
where m+1,j are constants determined by the distribution of {xm+1-j}. Generally, since f(xm+1, ym+1)is nonlinear with respect to ym+1, (4.3)
In this subroutine, coefficients of (4.8) and step size h = hm+1 = xm+1 xm are used to express the row vector , zm = ( y m , hy m
, h y
k
(k) m
k !)
(4.9) 513
ODGE
This is referred to as the Nordsieck expression for the history of solution and is used to express m(x); therefore, the problem to generate m+1 (x) from m(x) is reduced to obtain the following from zm: zm+1 = ( y m+1 , hy m +1 ,
Since the polynomial m+1 (x) m+1(x) - m (x) has degree k and satisfies conditions , j = 1,2, 0 m+1 ( x m+1 j ) = y y , j=0 m+1( 0 ) m+1
, k
, h y
k k i =0
(k) m+1
k !)
(4.10)
m+1 (x) is determined uniquely and can be expanded at xm+1 in to a Taylor series m+1 ( x ) = ym+1 ym+1( 0) lq ( x xm+1 ) h q
k q q=0
(4.11)
(4.14)
The right-hand side is the sum of elements of zm. To simplify conversion from zm to zm+1 in the prediction, the following is calculated for (4.11) zm+1(0) = z m A (4.12)
where lq is determined depending on the distribution of {xm+1-j}and more precisely, it is the coefficient of tq in the expression 1 + t t 1 + s1 s2
1 + st
k
(4.15)
where A is the (k + 1) (k + 1) unit lower triangular matrix defined as , i< j 0 aij = i i! , i j = j i !(i j )! where A = (aij). For example, A is expressed as follows when k = 5: 1 1 1 A= 1 1 1 0 1 4 1 10 5 1
where sj = (xm+1 xm+1-j)/h. Although lq also depends on values k and m, they are omitted in this expression. From (4.14), we can reduce the right-hand side of (4.13) to (ym+1ym+1(0))li, therefore, by introducing l = (l0 , l1 ,
, l )
k
(4.16)
the relation between zm+1 and zm+1(0) is expressed as zm+1 = zm+1( 0 ) + y m+1 y m+1( 0 ) l
(4.17)
1 2 3 4 5
1 3 6 10
This gives how zm+1 is generated after the corrector ym+1 is determined. The ym+1 can be calculated based on the relation between the second elements of both sides of (4.19), that is, hy m +1 = hy m +1( 0 ) + y m+1 ym+1( 0 ) l1 ym +1 = f ( x m+1 , y m+1 ) where This can be written as
(4.18)
Since the lower triangular portion of A is the Pascals triangle, this is referred to as the Pascals triangle matrix. Let the first element of zm+1(0) obtained from (4.12) be ym+1(0), then pm+1
(k) ym+1( 0 ) = y m + hy m k! + + h k ym
(y
m+1
y m+1( 0 )
) lh ( f (x
1
m+1
which is equal to pm+1. So ym+1(0) is used hereafter for pm+1. The (i + 1)-th element of zm+1(0)is equal to (i) hi m ( xm+1 ) / i ! , so calculation of (4.12) means to predict the solution and higher order derivatives at xm+1. On the other hand, the corrector is calculated from a relation between zm+1(0) and zm+1, which is derived below: The (i + 1) -th element of zm+1 zm+1(0) is obtained from
(i) hi m x +1 ( m+1 )
) lh ( f (x
1
m+1
+1(0 ) , u) y m
(4.20)
, so it is obtained using the Newtons method (See later). 3) Solutions at an arbitrary value of the independent variable Since the step size is taken as large as possible within the tolerable error, the following situation is typical about the point xe at which the solution is to be obtained xm < xe xm+1 (4.21)
i! i! i i h d m+1 ( x ) m ( x ) = i ! dx i
(i) hi m ( xm+1 )
514
ODGE
Using the lem+1(q), q = k 1, k, k + 1, the order is selected as follows. First from the tolerance , we calculate
= ( x e x m+1 ) h , h = hm+1
} (h y
i i
(i ) m+1
i !)
(4.22)
q = lem+1 ( q )
1 ( q +1)
, q = k 1, k , k + 1
(4.27)
4) Acceptance of solutions Let lem+1(k) denote the local error of the corrector ym+1, then the subroutine estimate it as follows using the difference between the corrector and the predictor: k x + x + 1 m 1 m 1 j lem+1 (k ) = 1 + = j 2 l1 x m x m+1 j If, for some tolerance lem+1 (k ) (4.24)
1
where q means the tolerable scaling factor of the step size when order q is to be used for the next step. Suppose
q = max (q )
q
(4.28)
(y
m+1
y m+1( 0 )
(4.23)
then q is adopted as the order for the next step. This means that the step that results in the largest step size is adopted. So, the next step size is determined as q h If the solution is not accepted because the condition(4.24) is not satisfied, the step is retaken by reducing the step size to kNh without changing the order. 6) Adams method Although Adams method is explained under Method of subroutine ODAM, this subroutine employs other computational procedures than those of ODAM. That is, while Adams method is represented in terms of the modified divided differences in subroutine ODAM, the Nordsieck form is used in this subroutine. Much of computational procedures are shared between Gears and Adams methods in this subroutine. In Adams method, however, values introduced above in Gears method are modified as follows: Nordsieck form in Adams method In Adams method, the true solution y(x) is approximated by the interpolation polynomial Pm+1(x) of degree k given by the conditions Pm+1 ( x m+1 j ) = f ( x m+1 , y m+1 j ) j = 0,1, , k 1 Pm+1 ( x m ) = ym
is satisfied ym+1 is accepted as the solution at xm+1, then zm+1 is generated from (4.17), to proceed to the next step. 5) Order and step size controls This subroutine uses Gears method of order1), 2), 3), 4), or 5) depending on the behavior of the solution. Suppose the order of Gears method used at the previous step to be k, then the order at the current stop is either k 1, k or k + 1. Suppose that solution ym+1 at xm+1 has been accepted by the method of order k, and the order for the next step is to be determined. For that purpose, the subroutine estimates the local errors lem+1(k), lem+1(k 1) as well as lem+1(k), where lem+1(k 1) lem+1(k + 1) means the local errors at xm+1 if the methods of order k 1, k + 1 respectively would have been used. This subroutine estimates lem+1(k 1) and lem+1(k + 1) from lem+1 (k 1) = (s1 s2 lem+1 (k + 1) =
sk +1 (em+1 Qm+1 em )
k +1,1
s
k 1
(4.29)
(k + 2)l
k x x m+1 j m +1 1 + 2 x x m m +1 j (4.26)
where lk-1,1 and lk+1,1 are coefficients of t1 with k replaced by k 1 and k + 1 in (4.15), and em+1 = ym+1 y m+1( 0 ) Qm+1 = (cm+1 cm )(h hm ) cm+1 = s1 s2
k k k +1
(4.30)
x s 1 + x
2
m+1 m
Since(4.30) contains f(xm+1, ym+1) on the righthand side, it generally becomes a nonlinear equation with respect to ym+1. To solve this equation, an initial value is calculated from the polynomial Pm(x) of degree k given by the conditions
515
ODGE
j = 1,2,
,k
(4.31)
(4.32)
0 k 2 (k) lem+1 (k 1) = k 1 (4.38) u + s du(h k y m +1 k !) j 0 0 k 1 e u + s lem+1 (k ) = (4.39) m +1 klk 1 j du sk 0 0 k lem+1 (k + 1) = klk 1 u + s du Lsk (em+1 Qm+1em ) j 0 (4.40) where em+1 = y m+1 ym+1( 0 ) , L = k + 1, Qm+1 = sk l k (m) sk (m) lq
From the above, it follows that Adams method consists of generating Pm+1(x) from Pm(x). Pm(x) can be expanded to a Taylor series at xm Pm ( x ) = ym + ( x x m ) y m + +( x xm ) y
k
(k ) m
k! (4.33)
(h h )
m
k +1
(4.41)
(q) q=0,1,, k means Pm( q ) (xm). Using where ym coefficients of (4.33) and step size h = hm+1 = xm+1 xm, we introduce a row vector
zm = ( y m , hy m ,
, h
(k) ym k !)
(4.34)
This is the Nordsieck form of polynomial Pm(x) in Adams method. Calculation of zm+1(0) The zm+1(0) can be calculated in the same way by (4.12) using zm obtained from (4.34). Relation between zm+1(0) and zm+1 The (i + 1)-th element of zm+1 zm+1(0) is hi d i Pm+1 ( x ) Pm ( x ) i ! dx i
In (4.41), sk(m) and lk(m) are obtained by substituting m for m+1 in their definitions. Equations (4.38) to (4.40) are used to check the solution and to control the order and step size in the same way as Gears method. 7) Extension to a system of differential equations The above discussion can be applied to each component of the solution in the case of systems of differential equations; however, the error estimates, such as lem+1(k), must be defined as the norms of vector as follows. From the user-specified EPSV(I), I = 1, 2, ..., N and EPSR we introduce EPS = max (EPSR, max (EPSV(I))) W(I)=(|Y(I)| N EPSR+EPSV(I))/EPS and define ERK as N le(I) 2 ERK = I =1 W(I)
12
x = xm +1
(4.35)
(4.42)
where Y(I) and le(I) are the I-th component of the solution and its local error respectively. Under these conditions, the subroutine tests ERK EPS If this is satisfied, le(I ) Y(I) EPSR + EPSV(I) I = 1,2, , N is automatically satisfied. Moreover, norms ERKM1 and ERKP1 which correspond to lem+1(k1) and lem+1(k + 1) respectively in the case of single equations are defined in the same way as (4.42). The order and step size are controlled based on (4.27) but with the following substitutions:
m+1
(x ) = ( y
m+1
ym+1( 0 ) ) lq ( x x m+1 ) h q
k q k=0
(4.36)
and by substituting this into (4.35), we can express (4.35) as (ym+1ym+1(0))li , where lq is the coefficient of tq of the polynomial of degree k given by
1 (u + s )du 1 (u + s )du
t
k 1 1
k 1 1
(4.37)
where sj = (xm+1 x m+1-j)/hm+1. Using lq, we obtain the relation between zm+1(0) and zm+1 which has the same from as (4.17). Local error Also, in Adams method, local errors at order k 1, k, and k + 1 are estimated for the acceptance of the solution, step size and order control. Let these errors be lem+1 (k 1), lem+1(k), lem+1 (k + 1), then these values are estimated as follows:
516
ODGE
8) Corrector iteration This subroutine calculates the corrector as a zero of a nonlinear algebraic equation as mentioned above. This section summanzes how to obtain the zero in the case of systems of differential equations. In this case (4.20) is expressed as G (u) u y m+1( 0 )
1. to approximate Pm+1,0 by finite differences. 2: to approximate Pm+1,0 with a diagonal matrix by finite differences Dm+1 = diag (d1, d2, ..., dN) (4.46)
) (
h f ( xm+1 , u) y m +1( 0 ) l1
(4.43)
This subroutine solves (4.43) by the Newtons method expressed as , r = 01 , ,2, , where u0 = ym+1( 0 ) h f G =I Pm+1,r = l1 u ur u ur ur+1 = ur Pm+11,r G (ur )
where di =[fi (xm+1, ym+1(0)+v) (fi (xm+1, ym+1(0)]/vi v = 0.1 G(ym+1(0)) = (v1, v2, , vN)T The approximation is effective only when Jm+1 is diagonally dominant matrix. 3: to approximate Pm+1,0 with the identity matrix I. In this case (4.44) becomes a simple recurrence formula ur+1 = ur G(ur) (4.47)
(4.44)
This is sufficient to solve nonstiff equations. Convergence of (4.44) is tested by N urI+1 urI I =1 W(I)
2
In the subroutine, Pm+1.r is not evaluated at each iteration, but Pm+1,0 = I h f J where J m+1 = l1 m+1 u (4.45)
ym+1( 0 )
c * EPS
12
(4.48)
is used instead. This subroutine contains several methods for evaluating Pm+1,0, For Pm+1,0 calculation, there are several methods, one of which the user can select through the parameter MF. Let MF = 10*METH + ITER, then ITER is the indicator on how to evaluate Pm+1,0, with the following values and meanings: 0: to evaluate Pm+1,0 by the analytical Jacobian matrix Jm+1. In this case, the user must prepare subroutine JAC to evaluate Jm+1.
where uI is the I-th element of vector u and c* is a constant specific to the problem. This subroutine is based on the code written by A.C. Hindmarsh and G.D.Byrne (References [76] and [77]).
517
ODRK1
CALL ODRK1 (X, Y, FUN, N, XEND, ISW, EPSA, EPSR, VW, IVW, ICON) Function This subroutine solves a system of first order ordinary differential equations of the form: y1 = f1 ( x , y1 , y 2 , , y N ), y1 (x 0 ) = y10 y 2 = f 2 ( x , y1 , y2 , , y N ), y2 ( x0 ) = y 20 = f N ( x , y1 , y2 , , y N ), y N (x 0 ) = y N 0 yN
(1.1)
where X: Input. Independent variable x. Y: Input. One-dimensional array of size N, with corresponding Y(1) = y1, Y(2) = y2, ... , Y(N) = yN. YP: Output. One-dimensional array of size N, with corrosponding YP(1)=f1(x, y1, y2, , yN), YP(2)=f2(x, y1, y2, , yN), YP(N)=fN(x, y1, y2, , yN). N ..... Input. Number of equations in the system. XEND .. Input. Final point xe to which the system should be solved. ISW ... Input. Integer variable to specify conditions in integration. ISW is a non-negative integer having two decimal digits, which can be expressed as ISW = 10d2 + d1 Each di should be specified as follows: d1: Specifies whether or not this is the first call. 0: First call 1: Successive call The first call means that this subroutine is called for the first time for the given differential equations. d2: Indicator for the output mode 0: Final value output 1: Step output Output. When this subroutine returns to the user program after obtaining the solutions at xe or the solutions at each step, d1 is set as d1 = 1. When this subroutine is called repeatedly, d1 should not be altered. The user has to set d1 = 0 again only when he starts to solve other equations. EPSA ..... Input. Absolute error tolerance See Method. EPSR ..... Input. Relative error tolerance. Output. If EPSR is too small, the value is changed to an appropriate value. (See Notes.) VW ..... Work area. One-dimensional array of size 9 N + 40. When calling this subroutine repeatedly, the contents should not be changed. IVW .... Work area. One-dimensional array of size 5. When calling this subroutine repeatedly, the contents should not be changed. ICON .. Output. Condition code. See Table ODRK1-1.
by Rung-Kutta-Verner method, when functions f1, f2 , ,fN and initial values x0, y10,y20, ..., yN0 and the final value xe are given, i.e. obtains the solution (y1m, y2m, ..., yNm) at xm= x0+ h (m=1,2,, e)
j =1 m
(See Fig. ODRK 1-1). The step size hj is controlled so that solutions satisfy the desired accuracy. This subroutine provides two types of output mode as shown below. The user can select the appropriate mode according to this purposes. Final value output ... Returns to the user program when the solution at final value xe is obtained. Step output ... Returns to the user program each time the solutions at x1, x2, ... are obtained.
h1 x0 x1 h2 x2 h3 x3 he xe
Fig. ODRK1-1 Solution output point xm (in the case x0 < xe)
Parameters X ..... Input. Starting point x0. Output. Final value xe. When the step output is specified, an interim point xm to which the solutions are advanced a single step. Y ..... Input. Initial values y10, y20, ... yN0. They must be given in order of Y(1) = y10, Y(2) = y20, ..., Y(N) = yN0. One-dimensional array of size N. Output. Solution vector at final value xe. When the step output is specified, the solution vector at x = xm. FUN ..... Input. The name of the subprogram which evaluates fi (i = 1, 2, ..., N) in (1.1). The form of the subroutine is as follows: SUBROUTINE FUN (X, Y, YP)
518
ODRK1
Table ODRK1-1 Condition codes Code 0 Meaning (In step output) A single step has been taken. Solution at XEND was obtained. Processing Normal, Successive calling is possible. Normal, Successive calling is possible after changing XEND Return to user program before continuing the integration. Successive calling is possible. Return to user program before continuing the integration. The function counter will be reset to 0 on successive call. Return to user program before continuing the integration. The user must increase EPSA or EPSR before calling again. Return to user program before continuing the integration. The user must increase EPSA before calling again. Bypassed
10
10000
11000
Integration was not completed because EPSR was too small in comparison with the arithmetic precision of the computer used (See Comments on use.) Integration was not completed because more than 4000 derivative evaluations were needed to reach XEND.
returns control to the user program before continuing the integration. The user can call this subroutine successively after identifying occurrences. When ICON = 15000 to 16000, the subroutine returns control to the user program before continuing the integration. In these cases, however, the user must increase EPSA or EPSR then he can call this subroutine successively (See the example). Relative error tolerance EPSR is required to satisfy EPSR r min = 1012 + 2u where u is the round-off unit. When EPSR does not satisfy the above condition, the subroutine increases EPSR as EPSR = r min and returns control to the user program with ICON = 10000. To continue the integration, the user may call the subroutine successively. In this subroutine, the smallest stepsize hmin is defined to satisfy hmin = 26u.max( x , d ) , where x is independent variable, and d = (xe x0)/100. When the desired accuracy is not achieved using the smallest stepsize, the subroutine returns control to the user program with ICON = 15000. To continue the integration, the user may call the subroutine again after increasing EPSA or EPSR to an appropriate value. Example A system of first order ordinary differential equations
2 . y1 = y1 y 2 , y1 (0) = 10 = 1 y1 , y2 (0) = 10 . y2
15000
Integration was not completed because requested accuracy could not be achieved using smallest alloable stepsize.
16000
(When EPSA = 0) Integration was not completed because solution vanished, making a pure relative error test impossible.
30000
Some of the following occurred: 1. N 0 2 X = XEND 3 ISW was set to an improper value. 4 EPSA < 0 or EPSR < 0 5 After ICON = 15000 or 16000 is put out, successive calling is done without changing EPSA or EPSR.
Comments on use Subprograms used SSL II ... AMACH, MGSSL, URKV, UVER FORTRAN basic function ... ABS, SIGN, AMAX1, AMIN1 Notes This subroutine may be used to solve non-stiff and mildly stiff differential equations when derivative evaluations are inexpensive but cannot be used if high accuracy is desired. The name of the subroutine associated with parameter FUN must be declared as EXTERNAL in the calling program. Solutions may be acceptable only when ICON is 0 or 10. When ICON = 10000 to 11000, the subroutine
is integrated from x0 = 0.0 to xe = 4.0, under EPSA = 0.0, EPSR = 10-5. Solutions are put out at each step.
C **EXAMPLE** DIMENSION Y(2), VW(58), IVW(5) EXTERNAL FUN X = 0.0 Y(1) = 1.0 Y(2) = 1.0 N = 2 XEND = 4.0 EPSA = 0.0 EPSR = 1.0E5 ISW = 10
519
ODRK1
10 CALL ODRK1 (X, Y, FUN, N, XEND, ISW, EPSA, * EPSR, VW, IVW, ICON) IF(ICON.EQ.0. OR.ICON.EQ.10) GO TO 20 IF(ICON.EQ.10000) GO TO 30 IF(ICON.EQ.11000) GO TO 40 IF(ICON.EQ.15000) GO TO 50 IF(ICON.EQ.16000) GO TO 60 IF(ICON.EQ.30000) GO TO 70 20 WRITE(6,600) X,Y(1), Y(2) IF(ICON.NE.10) GO TO 10 STOP 30 WRITE(6,610) GO TO 10 40 WRITE(6,620) GO TO 10 50 WRITE(6,630) EPSR = 10.0*EPSR GO TO 10 60 WRITE(6.630) EPSA = 1.0E5 GO TO 10 70 WRITE(6,640) STOP 600 FORMAT(1H0,10X,2HX= ,E15.7,10X, * 5HY(1)= ,E15.7,10X,5HY(2)= ,E15.7) 610 FORMAT(1H0,10X,14HRELATIVE ERROR, * 20H TOLERANCE TOO SMALL) 620 FORMAT(1H0,10X,14HTOO MANY STEPS) 630 FORMAT(1H0,10X,15HTOLERANCE RESET) 640 FORMAT(1H0,10X,13HINVALID INPUT) END SUBROUTINE FUN (X, Y, YP) DIMENSION Y(2), YP(2) YP(1) = Y(1)**2*Y(2) YP(2) = 1.0/Y(1) RETURN END
k = h f ( x , y ) 1 1 h ,y + k k = h f x + 18 18 k = h f x + 1 h , y 1 k + 1 k 6 12 4 2 2 4 8 k = h f x + h , y k + k + k 9 81 27 81 2 40 4 56 54 x + h ,y + k k + k + k k = h f 3 33 11 11 11 369 72 5380 k = h f k + k + k x + h ,y 73 73 219 12285 2695 k + k 584 1752 8 8716 656 39520 k = h f , y k + k + k x h + 9 891 297 891 416 52 k + k 11 27 3015 9 4219 k = h f k k k x + h ,y + 256 4 78 5985 539 693 k k + k + 128 384 3328 y = y + 3 k + 4 k + 243 k + 77 k + 73 k 80 25 1120 160 700 57 16 1377 121 891 y y k k k k k = + + + + 640 65 2240 320 8320 2 k + T y 35 y = = 33 k 122 k + 891 k 33 k 73 k 640 325 2240 320 700 891 2 k + k + 8320 35
1 m +1 m m 2 m+ 1 m m+ 1 m 1 3 m+ 1 m m+ 1 m 1 2 4 m+ 1 m m+ 1 m 1 2 3 5 m +1 m m +1 m 1 2 3 4 6 m+ 1 m m+ 1 m 1 2 3 4 5 7 m+ 1 m m+ 1 m 1 2 3 4 5 8 m +1 m m +1 m 1 2 3 4 5 7 m+ 1 m 1 3 4 5 6 m 1 m 1 3 4 5 7 8 m 1 m 1 1 3 4 5 6 7 8
(4.3) In the above formula, y m+1 and ym+1 are approximations with 5th and 6th order truncation error respectively, and T is an estimate of the local truncation error in y*m+1. In this subroutine, the approximation ym+1 with higher accuracy is accepted as the solution when y*m+1 satisfies the desired accuracy. Stepsize control Initial stepsize determination: Since y*m+1 given by (4.3) is a 5th order approximation, the local truncation error at x1 = x0 + h is estimated by h5 times hf(x0,y0) which is the term of degree one in h in the Taylor expansion of the solution y(x0 + h) at x0. So the initial stepsize h1 is determined by h1 = max h1,26u max x0 , d where h = min hi hi6 f i ( x0 , y0 ) = EPSA
1 i N
Method Defining solution vector y(x), function vector f(x,y), initial vector y0 as y ( x ) = ( y1 , y2 , , y N ) , T f ( x , y ) = ( f1 ( x , y ), f 2 ( x , y ), , f N ( x , y )) , T y 0 = ( y10 , y 20 , , y N 0 )
T
(4.1)
the initial value problem of a system of first order ordinary differential equations (1.1) can be rewritten as: y(x) = f(x,y),y(x0) = y0 (4.2)
Runge-Kutta-Verner method This subroutine uses the Runge-Kutta-Verner method with estimates of the truncation error as shown below (The excellence of this method are described in Reference [73]). Solutions at point xm+1 = xm + hm+1 are obtained by using the formulas below
)}
(4.4)
+ EPSR yi ( x0 )
(4.5) (4.6)
520
ODRK1
(u is the round-off error unit) Solution acceptance and rejection: When an estimate T of local truncation error given by (4.3) satisfies the following condition, the solution ym+1 is accepted. Ti EPSA + EPSR , i = 1,2, , N y i ( x m ) + y i ( x m 1 ) 2
holds for some integer i0, the stepsize for the next trial is determined as follows. In order that i-th component of the solution may be accepted, the magnifying rate si for stepsize must satisfy the condition si6 Ti = EPSA + EPSR yi ( x m ) + yi ( xm+1 ) 2
(4.10)
(4.7)
This test becomes a relative error test when EPSA = 0. Such pure relative error test is recommendable if the user wants to be sure of accuracy. If EPSR = 0.0, it is corrected to EPSR = 10-12+2u automatically in the subroutine. At this time, unless the absolute value of the solution is so large, EPSA becomes the upper bound of the absolute error. If the absolute value of the solution is large, the second term of the right hand side in (4.7) becomes the upper bound of the absolute error, so (4.7) is essentially relative error test. Stepsize control: The dominant term of the truncation error term in i-th component of y*m+1 can be expressed as h6Ci with h being a stepsize, Ci being a constant. If h is sufficiently small, h 6 Ci Ti (4.8)
Taking the minimum of si for i = 1, ..., N and then multiplying it by a safety constant 0.9, the rate can be obtained as yi ( xm ) + yi ( x m+1 ) 2 Ti (4.11)
s = 0.9 min
6 1 i N
EPSA + EPSR
If s determined by (4.11) is equal to or less than 0.1, s = 0.1 is assumed. If s < 0.1, that is, Ti EPSA + EPSR > 96 (4.12)
max
1 i N
yi ( xm ) + yi ( x m+1 ) 2
holds. If the stepsize h is changed to sh, the estimated truncation error changes from Ti to s6 Ti. If the previous stepsize is unsuccessful i.e., if Ti 0 > EPSA + EPSR yi 0 ( x m ) + yi 0 ( x m+1 ) 2
(4.9)
s is calculated from (4.11). If the previous stepsize is successful i.e. if s determined by (4.11) is equal to or greater than 5, s = 5.0 is assumed. If s < 5.0, that is, 6 Ti 9 > max 1i N yi ( x m ) + yi ( xm+1 ) 50 EPSA + EPSR 2 s is calculated from (4.11). For a detailed description of the Runge-Kutta-Verner method, see Reference [72].
521
PNR
CALL PNR (A, B, NT, N, NS, INS, ICON) Function When complex data { k } of dimension n is given, this ~ using reverse binary subroutine determines { k} ~ is given, determines transformation. Also if
{ } .
k
{ }
k
positive integer). The reverse binary transformation means that the ~ located element of { k } or { k} k = k0 + k1 N 2 + .... + kl-1 N 2l1 is moved to location ~ k = kl1 + kl 2 N 2+ + k0 N 2l 1 (1.1)
Comments on use Subprograms used SSL II ..... MGSSL FORTRAN basic functions ..... ALOG and IABS Notes Use I: This subroutine is usually used with subroutine CFTN or subroutine CFTR. Discrete complex Fourier transform and inverse Fourier transform are defined generally
(1.2)
This routine performs the data permutation required in Fast Fourier Transform method. Parameters ~ . A ..... Input. Real parts of { k } or { k} ~ Output. Real parts of or
{ }
k
{ }.
k
B .....
One-dimensional array of size NT. ~ . Input. Imaginary parts of { k } or { k} ~ or . Output. Imaginary parts of { { k} k} One-dimensional array of size NT. Input. Total number of data (N) including ~ to be permuted. the { k } or { k} Normally, NT = N is specified. (See Notes.) Input. Dimension n. Input. The interval of the consecutive data ~ to be permuted of dimension n { k } or { k}
=
k
1 n1 x j jk n j= 0
, k = 01 , , ,n 1
(3.1)
and x j = k jk
k =0 n 1
NT .....
, j = 0,1,
, n 1
(3.2)
In CFTN, the transform in (3.3) or (3.4), corresponding to (3.1) or (3.2), is performed. ~ = x jk , k = 0,1, n j k
j =0 n 1 ~ x j = k jk k =0 n1
N ..... NS .....
in the NT data ( 1 and NT). Normally, NS = 1 is specified. (See Notes.) ISN ..... Input. Interval (0) of the NT data. Normally, ISN = 1 is specified. (See Notes.) ICON ..... Output. Condition code. See Table PNR-1.
Table PNR-1 Condition codes Code 0 30000 Meaning No error INS = 0, NS < 1, NT < N, NT l < NS, or N2 ( l : 0 or a positive integer) Processing Bypassed
, n 1 , j = 0,1, , n 1 , n 1 , j = 0,1, , n 1
(3.3) (3.4)
In CFTR, the transform in (3.5) or (3.6), corresponding to (3.1) or (3.2) is performed. n k = ~ x j jk , k = 0,1,
j =0 n1
(3.5) (3.6)
~ jk xj = k
k =0
n 1
522
PNR
Thus, this subroutine is used with CFTN, after the ~ or transformation of (3.3) or (3.4), to permute { k} ~ x into { } or x .
{ }
j
{ }
j
When used with CFTR, just before the transformation of (3.5) or (3.6) is performed, this routine permutes {x j } ~ . Since the parameters of this x or or into ~
{ }
k
{ } { }
j k
subroutine are essentially the same as with CFTN and CFTR, their specifications are the same. Refer to Examples (a) and (b). Use II: This subroutine can be also used when performing a multi-variate Fourier transform or inverse Fourier transform with CFTN or CFTR. A multi-variate discrete complex Fourier transform is defined generally for two variate
K 1,K 2 =
(3.7)
**EXAMPLE** DIMENSION A(1024), B(1024) READ(5,500) N, (A(I), B(I), I = 1, N) WRITE(6,600) N, (I, A(I), B(I), I = 1, N) CALL PNR (A, B, N, N, 1, 1, ICON) WRITE(6,610) ICON IF(ICON .NE. 0) STOP CALL CFTR(A, B, N, N, 1, 1, ICON) WRITE(6,610) ICON IF(ICON .NE. 0) STOP DO 10 I = 1, N A(I) = A(I)/FLOAT(N) B(I) = B(I)/FLOAT(N) 10 CONTINUE WRITE(6,620)(I, A(I), B(I), I = 1, N) STOP 500 FORMAT (I5/(2E20.7)) 600 FORMAT(1H0, 10X, 13HINPUT DATA N =,I5/ * /(15X, I5, 2E20.7)) 610 FORMAT(1H0, 10X, 12HRESULT ICON =, I5) 620 FORMAT(15X, I5, 2E20.7)) END
(b) Permutation before a one-variable transform Given complex time series data x j of dimension
{ }
, K1 = 0,1,
, N 1 1,
J 1=0 J 2= 0
K 2 = 0,1,
, N 2 1
(3.8)
n, before performing a Fourier transform, the data is permuted using this subroutine, and a transform x j } using subroutine is performed on the results {~ CFTR, and then scaling is performed to obtain { k } . In case of n 1024 ( = 210).
C **EXAMPLE** DIMENSION A(1024), B(1024) READ(5,500) N, (A(I), B(I), I = 1,N) WRITE(6,600) N, (I, A(I), B(I), I = 1, N) CALL CFTN(A, B, N, N, 1, 1, ICON) WRITE(6,610) ICON IF(ICON .NE. 0) STOP CALL PNR (A, B, N, N, 1, 1, ICON) WRITE(6,610) ICON IF(ICON. NE. 0) STOP DO 10 I = 1, N A(I) = A(I) / FLOAT(N) B(I) = B(I) / FLOAT(N) 10 CONTINUE WRITE(6,620)(I, A(I), B(I), I = I, N) STOP 500 FORMAT(I5/(2E20.7)) 600 FORMAT(IH0, 10X, 13HINPUT DATA N =,I5/ * /(15X, I5, 2E20.7)) 610 FORMAT (1H0, 10X, 12HRESULT ICON =, I5) 620 FORMAT(15X, I5, 2E20.7) END
, K1 = 0,1,
, N1 1,
J 1=0 J 2=0
K 2 = 0,1,
, N 2 1
(3.9)
For an inverse transform, a transform similar to a onevariable transform can be performed. When this subroutine is used with CFTN, after the transformation ~ } is permuted. If of (3.8) is performed, {N1.N2 k 1.k 2 used with CFTR, just before the transformation of (3.9),{xj1.j2} is permuted. Refer to Example (c). Specifying ISN: ~ If NT real parts and imaginary parts of { k } or { k} are each stored in areas of size NTI in intervals of I, the following specification is made. ISN = I The permuted results are also stored in intervals of I. Examples (a) Permutation after a one-variable transform Given complex time series data {x j } of dimension n, after a Fourier transform is performed using
523
PNR
(c) Permutation after a two-variate transform Given complex time series data {xj1j2} of dimension N1 and N2, a Fourier transform is performed with the subroutine CFTN, then the ~ } are permuted by this results {N1.N2 k 1.k 2 subroutine and scaled to obtain { k 1.k 2 }. In case of N1N2 1024 ( = 210). The data {xj1j2} can be stored as shown in Fig. PNR-1.
C **EXAMPLE** DIMENSION A(1024), B(1024), N(2) READ(5,500)(N(I), I = 1,2) NT = N(1)*N(2) READ(5,510)(A(I), B(I), I = 1, NT) WRITE(6,600) N, (I, A(I), B(I), I = 1, NT) NS = 1 DO 10 I = 1,2 CALL CFTN (A, B, NT, N(I), NS, 1, ICON) IF(ICON .NE. 0) STOP CALL PNR (A, B, NT, N(I), NS, 1, ICON) NS = NS*N(I) 10 CONTINUE DO 20 I = 1, NT A(I) = A(I) / FLOAT(NT) B(I) = B(I) / FLOAT(NT) 20 CONTINUE WRITE(6,610)(I, A(I), B(I), I = 1, NT) STOP 500 FORMAT(2I5) 510 FORMAT(2E20.7) 600 FORMAT(1H0, 10X, 13HINPUT DATA N=,2I5/ * /(15X, I5, 2E20.7)) 610 FORMAT(1H0, 10X, 11HOUTPUT DATA/ * /(15X, I5, 2E20.7)) END
{ } specified,
data must be permuted immediately before or after transformation. In other words, when k and j of (4.1) are expressed as k = k 0 + k 1 2+ + k l1 2 l1 , k 0 ,
0 1 l 1
j = j + j 2 ++ j
l 1
, k , j , , j
0
l 1
= 0,1 = 0,1
(4.2)
l 1
~ (k + k N2+ the Fast Fourier Transform results become 0 l ll l1 ~ + kl1N2 ) against (kl1+ kl2N2+...k0N2 ) In this case (k0 + klN2+ ...+ kl1N2ll)k0+k12+k-12-1
expressed in reverse binary order. ~ against is in Therefore, the data order of { { k} k} reverse binary order, and final data permutation becomes ~ and j are necessary. On the other hand, if { k} expressed as k = k l 1 + k l 2 2 + + k 0 2 l1 , k 0 , j = jl 1 + jl 2
l 1 0 0
2++ j 2
, k = 0, 1 , j , , j = 0, 1
l 1 l 1
(4.3)
the results of the Fast Fourier Transform are in normal order without permutation as
(k 0 + k 1 2+ + k l1 2 l1 )
If the order of the data {xj} is permuted in a reverse binary order as shown in j of (4.3) before transformation, final data permutation is not needed. As previously mentioned, with the Fast Fourier Transform for certain data { } , transposition of data in location shown in (4.4) and (4.5) is required. k = k 0 + k1 2 + + k l 1 2 l 1 ~ k = k l 1 + k l 2 2+ + k 0 2 l 1
Method As is necessary with the radix 2 Fast Fourier Transform, this subroutine performs permutation such that the result is in reverse binary order against input order. First, let a discrete complex Fourier transform be defined as jk k = x j exp 2i , k = 0,1, j=0 n
n 1
, n 1
(4.1)
(4.4) (4.5)
In (4.1) the scaling factor 1/n is omitted. The use of Fast Fourier Transform method is considered for n = 2I. (Refer to the section on subroutine CFT for the principles of the Fast Fourier Transform method).
~ , this subroutine permutes the data Given { k } or { k} ~ by reverse binary order of transformation to obtain or { k } .
{ }
k
Basic conditions for permutation are: ~ For k= k , transposition is unnecessary ~ ~ ~ ~ ~ (k ) )are For k k , (k) and ( k ) (or, ( k ) and permuted. For further information, refer to References [55], [56], [57].
524
RANB2
J12-20-0101 RANB2
Generation of binomial random integers
changed as long as the same value has been specified in parameter M and P. Example Generating 10000 pseudo random numbers from a binomial distribution with m = 20 and p = 0.75, the frequency distribution histogram is plotted.
C **EXAMPLE** DIMENSION IA(10000), VW(21),IVW(21), * HSUM(21) INTEGER*4 IX DATA X1, X2/0.5,20.5/ DATA NINT, XINT/21,1.0/ DATA M, P, IX, N/20, 0.75, 0, 10000/ DO 10 I=1, 21 10 HSUM(I)=0.0 CALL RANB2(M,P,IX,IA,N,VW,IVW, ICON) C SUM NOS. IN HISTGRAM FORM ISW= 1 DO 20 I= 1, N X=IA(I) 20 CALL HIST (X,X1,X2,NINT,XINT,HSUM, * ISW) C PLOT DISTRIBUTION WRITE(6,600) ISW = 2 CALL HIST(X,X1,X2,HINT,HINT,HSUM, * ISW) STOP 600 FORMAT(1H1,10X,15HBINOMIAL RANDOM, * 20H NUMBER DISTRIBUTION//) END
CALL RANB2 (M, P, IX, IA, N, VW, IVW, ICON) Function This subroutine generates a sequence of n pseudo random integers from the probability density function (1.1) of binomial distribution with moduli m and p.
m k m p k 1 p) Pk = k (
, m, m = 1,2,
(1.1)
Parameters M ..... Input. Modulus m. P ..... Input. Modulus p. IX ..... Input. Starting value of non-negative integer (must be INTEGER*4) Output. Starting value for next call of RANB2. See Notes. IA ..... Output. n binomial pseudo random integers. N ..... Input. Number of n of binomial pseudo random integers to be generated. VW ..... Work area. One-dimensional array of size m + 1. IVW ..... Work area. One-dimensional array of size m + 1. ICON ..... Output. Condition code. See Table RANB2-1.
Table RANB2-1 Condition code Code 0 30000 Meaning No error M < 1, P 0, P 1, IX < 0 or N <1 Processing Bypassed
For detailed information on subroutine HIST, see the Example in subroutine RANU2. Method Binomial random integers are generated as indicated below. When integer l is determined so that a pseudo random number u generated from uniform distribution in the interval (0, 1) satisfies equation (4. 1) l is a binomial random integer. Fl 1 u < Fl (4.1)
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions .... ALOG, EXP, DMOD, FLOAT Note Starting value IX This subroutine transforms uniform pseudo random numbers into binomial random integers. Parameter IX is given as the starting value to generate uniform pseudo random numbers. It is handled in the same way as RANU2. See comments on use for RANU2. The contents of VW and IVW should not be
, m
(4.2)
Figure RANB2-1 represents(4.1) where m = 6 and p = 0.5. For example when u = 0.74321, l = 4.
525
RANB2
Fl 1.0
0.7 0.5
Since this cumulative distribution is unique when m and p are determined, it is time consuming to compute (4.2) each time for a binomial random integer. Therefore if the cumulative distribution table is generated once, it can be used for reference for the subsequent computation. Parameter VW is used for these reference. If u is a value close to 1, checking l = 1, 2, ... in (4.1) is also time consuming. Parameter IVW is used as an index table to start l at an appropriate value depending upon value u. For further information, see Reference [93].
l
526
RANE2
J11-30-0101 RANE2
Generation of exponential pseudo random numbers
CALL RANE2 (AM, IX, A, N, ICON) Function This subroutine generates a sequence of n pseudo random numbers form the probability density function (1.1) of exponential distribution with mean value m.
x 1 m e m Where, x 0, m > 0, and n 1
g( x ) =
(1.1)
Parameters AM..... Input. Mean value of exponential distribution, m. IX..... Input. Starting value of non-negative integer (must be INTEGER *4). Output. Starting value for next call of RANE2. See Comments on use below. A..... Output. n random numbers. One-dimensional array of size, n. N..... Input. Number of pseudo-random numbers to be generated. ICON.. Output. Condition codes. See Table RANE2-1.
Table RANE2-1 Condition codes Code 0 30000 Meaning No error AM 0, IX < 0 or N < 1 Processing Bypassed
**EXAMPLE** DIMENSION A(10000),HSUM(12) INTEGER*4 IX DATA X1,X2,NINT,XINT/0.0,6.0,12,0.5/ DATA AM,IX,N/1.0,0,10000/ DO 10 I=1,12 10 HSUM(I)=0.0 CALL RANE2(AM, IX, A, N, ICON) C SUM NOS. IN HISTGRAM FROM ISW=1 DO 20 I=1,N X=A(I) 20 CALL HIST(X, X1, X2, NINT, XINT,HSUM * ,ISW) C PLOT DISTRIBUTION WRITE (6,6000) ISW=2 CALL HIST(X,X1,X2,NINT,XINT,HSUM, * ISW) STOP 600 FORMAT (1H1,10X,11HEXPONENTIAL, * 27H RANDOM NUMBER DISTRIBUTION//) END
See the example in RANU2 for subroutine HIST. Method Exponential pseudo random numbers {y} are generated by
y = m log u
(4.1)
where, {u} is a sequence of uniform (0, 1) pseudo random numbers generated and m is the mean value. The function, (4.1), can be derived as follow: The cumulative exponential distribution function F(y) will be obtained from (1.1) F ( y ) = 0 g( x )dx = 0
y y
1 1 1 m y x e dx = 1 e m m
Comments on use Subprograms used SSL II ... RANU2 and MGSSL FORTRAN basic functions ... ALOG and DMOD Note Starting value IX This subroutine transforms uniform pseudo random numbers generated by RANU2 into exponential pseudo random numbers. Parameter IX is given as the starting value to generate uniform pseudo random numbers. See comments on use for RANU2. Example 10,000 exponential pseudo random numbers from exponential distribution with mean value 1.0 are generated and the frequency distribution histogram is plotted.
(4.2)
Let u1 be one of the uniform pseudo random numbers, (4.3) is obtained from (4.2) based on the relation u = F(y). y1 = m log(1 u1 ) (4.3)
Thus, exponential pseudo random numbers y1, y2, y3, ..... can be transformed one to one from uniform pseudo random numbers, u1, u2, u3, ..... .
527
RANN1
J11-20-0301 RANN1
Fast normal pseudo random numbers
This subroutine generates normal pseudo random numbers faster than subroutine RANU2. Example Given a normal distribution having mean value 0 and standard deviation 1.0, this subroutine generates 10,000 pseudo random numbers and a frequency distribution histogram is plotted.
C **EXAMPLE** DIMENSION A(10000), HSUM(12) INTEGER*4 IX DATA X1, X2/-3.0, 3.0/ DATA NINT, XINT/12,0.5/ DATA AM, SD, IX, N/0.0, 1.0, 0, 10000/ DO 10 I=1, 12 10 HSUM(I)=0.0 CALL RANN1 (AM, SD, IX, A, N, ICON) C SUM NOS. IN HISTGRAM FORM ISW=1 DO 20 I=1, N X=A(I) 20 CALL HIST (X,X1,X2,NINT,XINT,HSUM, * ISW) C PLOT DISTRIBUTION WRITE(6,600) ISW=2 CALL HIST(X,X1,X2,HINT,XINT,HSUM, * ISW) STOP 600 FORMAT (1H1, 10X, 13HNORMAL RANDOM, * 20H NUMBER DISTRIBUTION//) END
CALL RANN1 (AM, SD, IX, A, N, ICON) Function This subroutine generates n pseudo random numbers from a given probability density function (1.1) of normal distribution with mean value m and standard deviation : g( x ) = 1 2 e
( x m )2 2 2
(1.1)
where n 1 Parameters AM..... Input. Mean value m of the normal distribution. SD..... Input. Standard deviation of the normal distribution. IX..... Input. Initial value of nonnegative integer (must be INTEGER*4). Output. Initial value for the next call of this subroutine. (See Comments on Use.) A..... Output. n pseudo random numbers. Onedimensional array of size n. N..... Input. Number of pseudo random numbers n to be generated. ICON.. Output. Condition code. (See Table RANN1).
Table RANN-1 Condition codes Code 0 30000 Meaning No error IX < 0 or N < 1. Processing Bypassed.
See Example for subroutine RANU2 for subroutine HIST in this example. Method The inverse function method is used to generate normal pseudo random numbers. For uniform pseudo random numbers ui (i = 1, 2, ..., n) in interval (0, 1) transformation. zi = G 1 (ui ) + m (4.1)
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... SQRT, ALOG, ABS, SIGN, DFLOAT, DINT Notes Initial value IX This subroutine generates uniform pseudo random numbers and then transforms them to normal pseudo random numbers. Parameter IX is specified as the initial value to generate uniform pseudo random numbers and is processed in the same way as for RANU2. (See Comments on Use for RANU2.)
is applied to generate normal pseudo random numbers zi (i = 1, 2, ..., n), where G-1(u) is an inverse function of cumulative normal distribution function G ( z ) = g (x )dx
x
This subroutine uses Ninomiyas best approximation to realize high-speed G-1 (u) calculation. 1) For u 0.5 0.46875 G 1 (u) = cx e x 2 + d + x 2 + b
( (
528
RANN1
2) For u 0.5 > 0.46875 G-1(u) = sign(u-0.5)Np(v+q+r/v) where v = log 0.5 u 0.5
Since the formula of 1) is used in most cases (probability is 15/16), high-speed calculation is realized.
529
RANN2
J11-20-0101 RANN2
Generation of normal pseudo random numbers
CALL RANN2 (AM, SD, IX, A, N, ICON) Function This subroutine generates a sequence of n pseudo random numbers from the probability density function (1.1) of normal distribution with mean value m and standard deviation . g( x ) = 1 e
( x m )2 2 2
Example 10,000 normal pseudo random numbers are generated from normal distribution with mean value 0 and standard deviation 1.0 and the frequency distribution histogram is plotted.
C **EXAMPLE** DIMENSION A(10000), HSUM(12) INTEGER*4 IX DATA X1, X2/-3.0, 3.0/ DATA NINT, XINT/12, 0.5/ DATA AM, SD, IX, N/0.0, 1.0, 0, 10000/ DO 10 I=1, 12 10 HSUM(I)=0.0 CALL RANN2 (AM, SD, IX, A, N, ICON) C SUM NOS. IN HISTGRAM FORM ISW=1 DO 20 I=1, N X=A(I) 20 CALL HIST (X,X1,X2,NINT,XINT,HSUM, * ISW) C PLOT DISTRIBUTION WRITE (6,600) ISW=2 CALL HIST (X,X1,X2,HINT,XINT,HSUM, * ISW) STOP 600 FORMAT (1H1, 10X, 13HNORMAL RANDOM, * 20H NUMBER DISTRIBUTION//) END
2 where n 1
(1.1)
Parameters AM..... Input. Mean value of the normal distribution, m. SD..... Input. Standard deviation of the normal distribution, . IX..... Input. Starting value of non-negative integer (must be INTEGER*4) Output. Starting value for the next call of RANN2. See comments on use below. A..... Output. n pseudo random numbers. Onedimensional array of size n. N..... Input. Number of pseudo-random numbers to be generated. ICON.. Output. Condition codes. See Table RANN2-1.
Table RANN2-1 Condition codes Code 0 30000 Meaning No error IX < 0 or N < 1 Processing Bypassed
Refer to the example in RANU2 for subroutine HIST. Method Normal pseudo random numbers are generated using the Box and Mller method, according to (4.1) and (4.2): zi = ( 2 log ui ) 2 cos 2ui +1 + m
1
(4.1) (4.2)
Comments on use Subprograms used SSL II ... RANN2 and MGSSL FORTRAN basic functions ... SQRT, ALOG, SIN, COS and DMOD Notes Starting value IX This subroutine transforms uniform pseudo random numbers generated by RANU2 into normal pseudo random numbers. Parameter, IX is given as the starting value to generate uniform pseudo random numbers. See Comments on use for RANU2.
Where m and are the mean value and standard deviation of normal distribution respectively. Thus, normal pseudo random number (z1, z2, z3, ...) are calculated from as many uniform pseudo random number (u1, u2, u3, ...). Here, when the odd number of normal pseudo random number is to be generated, a pair of uniform random numbers is required for the last one.
530
RANP2
J12-10-0101 RANP2
Generation of Poisson pseudo random integers
Table RANP2-1 Condition codes Code 0 30000 Meaning No error AM 0, AM > log(flmax) IX < 0 or N<1 Processing Aborted
CALL RANP2 (AM, IX, IA, N, VW, IVW, ICON) Function This subroutine generates a sequence of n pseudo random integers from the probability density function (1.1) of Poisson distribution with mean value m. p k = e m mk k! (1.1)
m=8
Notes AM log(flmax) Because, for AM > log(flmax), the value e-m underflows in computation of Fn in (4.2). For a large AM ( 20), the Poisson pseudo random integers may be approximated by the normal pseudo random numbers with the mean value m and standard deviation m. See Methods. Starting value IX This subroutine transforms uniform pseudo random numbers generated by RANU2 into Poisson Pseudo random integers. Parameter, IX is given as the starting value to generate the uniform pseudo random numbers. See Comment on use for RANU2. Both VW and IVW must not be altered while parameter AM remains the same. Example 10,000 Poisson pseudo random integers from Poisson distribution with mean value 1.0 are generated and the frequency distribution histogram is plotted.
**EXAMPLE** DIMENSION A(10000), VW(12), * IVW(12), HISUM(6) INTEGER*4 IX DATA X1, X2/-0.5, 5.5/ DATA NINT, XINT/6, 1.0/ DATA AM, IX, N/1.0, 0, 10000/ DO 10 I=1, 6 10 HSUM(I)=0.0 CALL RANP2 (AM, IX, IA, N, VW, IVW, ICON) C SUM NOS. IN HISTGRAM FORM ISW=1 DO 20 I=1, N X=IA(I) 20 CALL HIST (X,X1,X2,NINT,XINT,HSUM, * ISW) C PLOT DISTRIBUTION WRITE(6,600) ISW=2 CALL HIST (X,X1,X2,NINT,XINT,HSUM, * ISW) STOP 600 FORMAT (1H1, 10X, 14HPOISSON RANDOM, * 20H NUMBER DISTRIBUTION//) END C
Parameters AM..... Input. Mean value of Poisson distribution, m. See Comments on use below. IX..... Input. Starting value of non-negative integer (must be INTEGER*4). Output. Starting value of next call of RANP2. See Comments on use below. IA..... Output. Poisson pseudo random integers. One-dimensional array of size n. N..... Input. Number n of Position pseudo random integers to be generated. VW.... Work area. One-dimensional array of size [2m + 10]. IVW... Work area. One-dimensional array of size [2m + 10]. ICON.. Output. Condition codes. See Table RANP21. Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... EXP and DMOD
531
RANP2
Refer to the example in RANU2 for subroutine HIST. Methods Poisson pseudo random integer is determined as l when pseudo random number l generated from uniform distribution on the range (0, 1) satisfies the relationship. Fl 1 u < Fl (4.1)
[The effect of truncation in computation of Fl] Since Poisson distribution (4.2) continues infinitively, computation of Fl must be stopped at an appropriate value of n. This value depends upon the precision of computation in (4.2). Once Fl-1 for l = 1, 2, 3, ..., further computation in (4.2) is meaningless. When m 20, because of the above affection, Poisson pseudo-random integers may be better approximated by the normal pseudo-random integers with (mean value m and standard deviation m).
Fl m=1 1.0 0.9 u 0.8 0.7 0.6 0.5 0.4 0.3 0.2 0.1 1 0 1 2 3 4 5 6 l
mk , l = 0,1,2 k!
Fig. RANP2-2 demonstrates the generation of Poisson random integers according to the transformation in (4.1) where, u = 0.84321 and l = 2. Since m determines the form of cumulative distribution function Fl if a table of cumulative distribution function for given value of m is once determined, repetitive computations of (4.2) will be eliminated. Parameter VW is used to support this table. Further, u gets closer to 1, it would be of no use to search this table step by step starting from 0 in ascending order. Here again, parameter IVW is used to give a proper index to search this table depending upon the value of u.
532
RANU2
J11-10-0101 RANU2
Generation of uniform (0, 1) pseudo random numbers
CALL RANU2 (IX, A, N, ICON) Function This subroutine generates, by the congruence method, a sequence of n pseudo random numbers based on a stating value from a uniform distribution on the range (0, 1). n 1. Parameters IX.... Input. Starting value. A non-negative integer. (must be INTEGER*4) Output. Starting value for the next call of RANU2. See comments on use. A..... Output. n pseudo random numbers. Onedimensional array of size n. N..... Input. Number of pseudo random numbers to be generated. ICON.. Output. Condition codes. See Table RANU21.
Table RANU2-1 Condition codes Code 0 30000 Meaning No error IX < 0 or N 0 Processing Bypassed
Test for uniform random numbers Uniform random numbers have two main properties: probability unity and randomness. It is important to understand these properties when using this subroutine. Table RANU2-2 shows the results of testing of statistical hypothesis on pseudo random numbers generated by this subroutine with IX = 0. Generally speaking, we cannot generate pseudo random numbers suitable for all cases and expect them to pass all the tests. However, as Table RANU2-2 shows, this subroutine has been implemented with the values of a and c (refer to method), properly selected such that the resultant pseudo random numbers have passable properties to stand the tests of frequency and randomness. Example 10,000 uniform pseudo random integers are generated and a histogram of their frequency distribution is plotted.
C **EXAMPLE** DIMENSION A(10000), HSUM(10), INTEGER*4 IX DATA X1, X2 NINT, XINT/0.0, 1.0, 10, 0.1/ DATA IX, N/0, 10000/ DO 10 I=1, 10 10 HSUM(I)=0.0 CALL RANU2 (IX, A, N, ICON) C SUM NOS. IN HISTGRAM FORM ISW=1 DO 20 I=1, N X=IA(I) 20 CALL HIST (X,X1,X2,NINT,XINT,HSUM, * ISW) C PLOT DISTRIBUTION WRITE (6,600) ISW=2 CALL HIST (X,X1,X2,HINT,XINT,HSUM, * ISW) STOP 600 FORMAT (1H1, 10X, 14HUNIFORM RANDOM, * 20H NUMBER DISTRIBUTION//) END
Comments on use Subprograms used SSL II ... MGSSL FORTRAN basic functions ... DMOD Notes Starting value IX When a sequence of pseudo random integers, {IXj} is to be obtained by the congruence method (3.1), the user must give an starting value IX0 (usually zero is given). IXi+1 a IXi + c (mod m),i =0,1,,n1 (3.1)
Subroutine HIST in this example computes the frequency distribution and plots the histogram. The contents are shown below.
SUBROUTINE HIST (X,X1,X2,NINT,XINT, HSUM, ISW) DIMENSION IMAGE(31), HSUM(1) DATA II, IBLK, IAST/1HI, 1H, 1H*/ IF (ISW. NE. 1) GO TO 30 C TO SET UP HISTGRAM FOR RANDOM NOS. J=0 IF (X. GT. (X1 + X2) / 2.0) J = NINT/2 BK = X1 + J*XINT 10 J = J + 1 BK = BK + XINT *
where IXi , a, c and m are all non-negative integers. This sequence {IXi } is normalized into (0, 1) and a sequence of pseudo random numbers is generated in parameter A. After generation of n pseudo random numbers IXn is given to parameter IX. Thus, when next n pseudo random numbers are to be generated successively, they will be generated with the current starting value IXn in parameter IX, unless it is changed. When this subroutine is repeatedly called n times with parameter N set to 1, n uniform pseudo random integers {IXn} are obtained.
533
RANU2
IF (X. LT. X1) RETURN IF (X. LT. BK) GO TO 20 IF (X. LT. X2) GO TO 10 RETURN 20 HSUM(J)=HSUM(J) + 1.0 RETURN C TO GET MAX X FOR PLOTTING 30 Y=HSUM(1) DO 40 I=2, NINT 40 Y=AMAX1 (HSUM(I), Y) IMAGE(1)=II DO 50 I=2, 31 50 IMAGE(I)=IBLK BK=X1-XINT WRITE (6,600) DO 60 I=1, NINT BK=BK + XINT WRITE (6,610) BK J=30.0*HSUM(I)/Y + 1.5 IMAGE(J)=IBLK IMAGE(1)=II 60 CONTINUE BK=BK + XINT WRITE (6,610) BK RETURN 600 FORMAT (2X, 8HBREAK PT, 3X, 6HPT SUM, * 11, 21HGRAPH OF DISTRIBUTION)
610 FORMAT (2X, F5.1, 1X, 48(1H-)) 620 FORMAT (12X, F7.1, 5X, 31A1) END
Method Nowadays, almost all the pseudo uniform random numbers are generated according to Lehmers congruence method. IX i +1 a IX i + c (mod m) (4.1)
where IXi, a, c and m are non-negative integers. Since the congruence method relates two numbers in a certain definite association, it is foreign to the idea of probability, but if a sequence of pseudo random numbers, properly generated from the method, stands satistical tests, we can rely the congruence method as the pseudo0 random number generator. If values are given to IX0, a and c in (4.1), {IXi } forms a sequence or residues with modules m and all the elements of {IXi } satisfy IXi < m. Letting ri = IXi / m for {IXi }, we can obtain a pseudo random number sequence {ri } which distributes on the interval (0, 1). Here, for h such that IXh = IX0, h is called the period of the sequence {IXi }. This follows from the fact that IXh+1 = IX1, IXh+2 = IX2, ...
Table RANU2-2 2-tests of RANU2 Number of samples not rejected at the level of significance a%. 10% 5% 94 99 45 48 10 10 18 19 19 19 100 100 10 10 68 84 6 91 10 92 10 6 94 10 94 10
Test items
Size of samples* 1000 2000 10000 10000x2 5000x3 1000 10000 1000 10000
Remarks 1% 99 50 10 29 20 100 10 91 10 97 10 100 10 10 equal subintervals 10 equal subintervals 10 equal subintervals 10x10 equal subintervals 5x5x5 equal subintervals lag k = 60 lag k = 600 The gaps of width longer than 7 were grouped into one class. The gaps of width longer than 8 were grouped into one class. The runs of length longer than 3 were grouped into one class. The runs of length longer than 4 were grouped into one class. The runs of length longer than 6 were grouped into one class. The runs of length longer than 9 were grouped into one class.
1000 10000
1000 10000
* **
Number of random numbers contained in one sample. Test was done on the first successive sequences of samples.
534
RANU2
There is a theory that such a period h always exists in any sequence of pseudo random numbers and its largest value relates to m. This simply means that a pseudo random number sequence without period cannot be obtained with the congruence method. In practice, if we assign a sufficiently large number to m we can make h long enough to make the sequence {IXi } like random numbers. In this subroutine, m was assigned to m = 2 31 (4.2)
(4.3)
formula, which shows that a value close to m 2 minimizes the 1st order serial correlation among
The value of c is selected so that c and m are prime each other. Thus, c = 1234567891 To tell the truth, a and c were not simply determined, they are selected as a best pair among several other combinations of a and c through repetitive testing. This shows that the selection depends largely on empirical data. Further details should be referred to Reference [89] pp.43-57.
535
RANU3
J11-10-0201 RANU3
Generation of shuffled uniform (0, 1) pseudo random numbers
CALL RANU3 (IX, A, N, ISW, IVW, ICON) Function This subroutine generates, by the congruence method with shuffling, a sequence of n pseudo random numbers based on a starting value from a uniform distribution on the range (0, 1). Where n 1. Parameters IX..... Input. Starting value. A non-negative integer (must be INTEGER*4) Output. Starting value for the next call of RANU3. See Comments on use. A..... Output. n uniform random numbers. Onedimensional array of size n. N..... Input. The number of uniform random numbers to be generated. ISW... Input. Specify 0 for the first call. Specify 1 for the subsequent calls. IVW... Work area. One-dimensional array of size 128 (must be INTEGER*4) ICON.. Output. Condition code. See Table RANU3-1.
Table RANU3-1 Condition codes Code 0 30000 Meaning No error IX < 0, N0, ISW < 0 or ISW > 1. Processing Bypassed
After generating random numbers, final IXi is given to parameter IX. If generating random numbers in succession, IXi can be used as a starting value. [Successive generation of random numbers] Random numbers can be generated in succession by calling this subroutine repeatedly. To perform this, ISW = 1 is entered for the subsequent calls. In this case, the contents of parameter IX and IVW should not be altered. If ISW = 0 is entered for the subsequent calls, another series of random numbers may be generated using the value of parameter IX at that time value. Example 10000 pseudo random numbers are generated from uniform distribution in the range (0, 1) and a histogram of their frequency distribution is plotted.
**EXAMPLE** DIMENSION A(10000), HSUM(10), IVW(128) INTEGER*4 IX, IVW DATA X1, X2 NINT, XINT/0.0, 1.0, 10, 0.1/ DATA IX, N/0, 10000 /, ISW / 0 / DO 10 I = 1, 10 10 HSUM(I) = 0.0 CALL RANU3 (IX, A, N, ISW, IVW, ICON) C SUM NOS. IN HISTGRAM FORM ISW = 1 DO 20 I = 1, N X = A(I) 20 CALL HIST (X,X1,X2,NINT,XINT,HSUM, * ISW) C PLOT DISTRIBUTION WRITE (6, 600) ISW = 2 CALL HIST (X,X1,X2,HINT,XINT,HSUM, * ISW) STOP 600 FORMAT (1H1, 10X, 14HUNIFORM RANDOM, * 20H NUMBER DISTRIBUTION//) END C
Comments on use Subprograms used SSL II ... MGSSL, RANU2 FORTRAN basic functions ... DMOD Notes This subroutine enhances randomness which is one of two properties, probability unity and randomness, of random numbers. Therefore, the property of random numbers in this subroutine is superior to that in subroutine RANU2 (particularly for multiple dimensional distribution), but the processing speed is rather slow. If the random number should be generated quickly, it is advisable to use subroutine RANU2. [Starting value IX] Using the congruence method in (3.1), the starting value IX0 when requiring uniform random integer sequence {IXi } is specified in parameter IX. IX i + 1 = a IX i + c(mod m), i = 0, 1,
For detailed information on subroutine HIST, see the Example in subroutine RANU2. Method Uniform random number have two main properties: probability unity and randomness. The pseudo random number sequence generated using the Lehmer method IX i+1 a IX i + c(mod m), i = 0, 1, 2,
(4.1)
increases in regularity as its order becomes higher in multiple-dimensional distribution and thus the randomness of pseudo random numbers is decreased. For example, if we construct points so that each point
(3.1)
536
RANU3
is coupled such as Pi (IXi , IXi +1) and plot Pi on the x-y coordinate, these points will be located on several parallel lines. This subroutine uses the method with shuffling to decrease the demerit of the Lehmer method. The way of generating random numbers is the same as that of the Lehmer method. However it enhances the randomness by determining the order of a random number sequence by using random numbers. Random number sequence is generated as follows: 1) Generation of basic random number table Using the Lehmer method, ordered uniform random integers of length 128 are generated. Let express as: IX iB , i=1, 2, ,80 (4.2)
2) Generation of random number sequence Using the Lehmer method, one subsequent random number is generated which we call IX0. The following procedure is repeated using l = 1, 2, ..., n to generate n pseudo random numbers. Using l-1-th random number, one random number is chosen from a basic random number table. This number is called IXl. , j = IX l 1 (mod 80) + 1 IX l = IX B j (4.3)
IXl is normalized in the interval (0, 1) and stored in A(l) as the l-th pseudo uniform random number. Subsequently, the l + 1-th random number, IXl+1 is generated and stored in the j-th position in the basic random number table. = IX l +1 IX B j (4.4)
537
RATF1
J21-10-0101 RATF1
Frequency test of uniform pseudo random numbers (0, 1)
Table RATF1-1 Condition code Code 0 10000 Meaning No error Some expected frequency Fi is small and the approximation of chi-square distribution is poor. Increase n or decrease l. N < L, L < 2, ALP 100, ALP 0, ISW < 0 or ISW > 1. Processing Continued. Resultant of test is not so reliable. Bypassed
CALL RATF1 (A, N, L, ALP, ISW, IFLG, VW, IVW, ICON) Function This subroutine performs the one-dimensional frequency test for n pseudo uniform (0, 1) random number sequence {xi } based upon the test of statistical hypothesis. On the null hypothesis that pseudo uniform random numbers are uniform random numbers, this subroutine divides the range (0, 1) into l intervals and performs chisquare test using the actual frequency and the expected frequency of the random numbers failing in each interval. Then it judges whether or not to accept this hypothesis on significance level %. When the number of random numbers is great, they can be tested in succession by calling this subroutine repeatedly by dividing the random number sequence into parts. Where, n l 2 and 100 > > 0. Parameters A..... Input. Pseudo uniform random number sequence {xi }. One-dimensional array of size n. N..... Input. The number of uniform random numbers. See Notes. L..... Input. The number of intervals. See Notes. ALP.. Input. Significance level . See Notes. ISW... Input. Control information. Specifies whether or not the test is performed independently for several random number sequences by calling this subroutine repeatedly. When ISW = 0 is specified, the test is performed independently for each random number sequence. When ISW = 1 is specified, the test is performed continuously. However ISW = 0 is specified for the first call. See Notes. IFLG... Output. Test results. When IFLG = 0 is specified, the hypothesis is accepted. When IFLG = 1 is specified, the hypothesis is rejected. VW..... Work area. One-dimensional array of size 2. IVW.... Work area. One-dimensional array of size L + 1 (must be INTEGER*4). ICON... Output. Condition code. See Table RATF1-1.
30000
Comments on use Subprograms used SSL II ... UX2UP, MGSSL FORTRAN basic functions ... SQRT, EXP, ALOG, FLOAT, ABS, ERFC, ATAN Notes [Standard for setting the number of random numbers (n) and the number of subrange (l)] To enhance the reliability of testing, it is desirable to make the number of random numbers (n) large enough. Generally, the expected frequency Fi should satisfy Fi (= n l ) > 10 (3.1)
This subroutine sets ICON = 10000 when (3.1) is not satisfied. When m is large enough, the value of l is generally by: l = [1 + 3.322 log 10 n] (3.2)
For example, when n = 10000, l = 10 is adequate and when n = 1000, l = 14 is adequate.(3.2) is empirical formula based on the sense of sight appropriateness for the frequency distribution of random numbers falling in each interval. [Standards for setting significance level ] Significance level can be optionally specified according to the theory of statistical hypothesis test. The significance level, however, indicates the probability of error of the first kind which means to reject the hypothesis although it is true, the value specified should lie between 1% and 10% Generally either 5% or 1% is used. [Testing in successing] Suppose uniform random number sequence {yi } of size m is divided into s sets of random number sequences. Letting
{y } = {y } + {y }++{y }
i i1 i2 is
and letting numbers in each random number sequence be m1, m2, ..., ms that is,
538
RATF1
m = m1 + m2 + ... + ms One call of this subroutine enables the testing of random number sequence {yi }. By calling repeatedly for each random number sequence it is possible to obtain the final test results for {yi }, also. Table RATF1-2 shows the relationship between the contents of parameters and the object of the test for repeated calling of random number sequences.
Table RATF1-2 Testing in succession Calling sequence 1 2 A {yi1} {yi2} {yis} N m1 m2 ISW 0 1 Object of test {yi1} {yi1} + {yi2}
{yi1} + {yi2} + ... + {yis} Notes: The value of parameter L and ALP should be constant. S 1
ms
If ISW = 0 is specified each time this subroutine is called, the random number sequence is tested individually. When calling this subroutine repeatedly, the contents of work areas VW and IVW should not be altered. [Contents of work area] After executing this subroutine, the following values are stored in the work area: VW(1): Upper probability of 2 distribution of freedom degree l - 1 at l 1 at 2 0 . 2 VW(2): Value of 0 for the frequency distribution of random sequence {xi }. IVW(I): The actual frequency of random numbers falling in the I-th interval. I = 1, 2, ..., l. Example Pseudo uniform random number sequence {xi } of size 10000 is generated by subroutine RANU2 and divided into 10 sets of random number sequence of size 10000 and the frequency tests for each set are performed. Where, l = 10 and = 5%.
C **EXAMPLE** DIMENSION A(10000), VW(2), IVW(11) INTEGER*4 IX, IVW DATA IX, N/0, 1000 /, IOK / 10 / DATA L, ALP/10, 5.0 /, ISW / 0 / NS = 10 LL = L-1 WRITE (6, 600) IX, N, NS, LL, ALP IS = 1
IE = N DO 20 I = 1, NS CALL RANU2 (IX, A, N, ICON) CALL RATF1 (A,N,L,ALP,ISW,IFLG,VW, * IVW, ICON) IF (ICON. EQ. 0) GOTO 10 WRITE (6, 610) I, IS, IE. IOK = IOK-1 GOTO I5 10 IOK = IOK-IFLG IF (IFLG. EQ. 0) WRITE (6, 620) I, IS, IE IF (IFLG. EQ. 1) WRITE (6, 630) I, IS, IE 15 IS = IE + 1 20 IE = IE + N RATE = IOK*100.0/NS WRITE (6, 640) IOK, RATE STOP 600 FORMAT (1H1, 60(1H*)/6X, * 26HFREQUENCY TEST FOR UNIFORM, * 16H RANDOM NUMBERS./1X, 60(1H*)// * 6X, 20HINITIAL VALUE IX =, I5/ * 6X, 20HSAMPLING LENGTH N =, I5/ * 6X, 20HSAMPLE NUMBER =, I5/ * 6X, 20HFREE DEGREE L-1 =, I5/ * 6X, 20HSIGINIFICANCE LEVEL =,F5.1,1H%/ *6X, 12HRESULTANTS : // *9X, 25HNO. SAMPLE JUDGEMENT) 610 FORMAT (9X,I2,I7,1H-,I5,4X,5HERROR) 620 FORMAT (9X,I2,I7,1H-,I5,4X,5HSAFE) 630 FORMAT (9X,I2,I7,1H-,I5,4X,5HFAIL) 640 FORMAT (//6X, 17HTOTAL CONCLUSION:// * 9X, I2, 2H (, F5.1 * 21H %) SAMPLES ARE SAFE.) END
Method Divide the interval (0, 1) into / equal intervals and let the number of pseudo random numbers falling if n i-th interval to be fi . Also suppose the expected frequency corresponding to fi to be Fi . The value
=
2 0 i =1
(f
Fi ) Fi
(4.1)
forms chi-square distribution of freedom degree l - 1 for many samples of {xi }. This subroutine obtains value 02 from (4.1) and tests the null hypothesis that n pseudo random numbers are uniform random numbers on significance level %. In (4.1), the expected frequency Fi can be obtained by Fi = n / l For details, refer to Reference [93]. (4.2)
539
RATR1
J21-10-0201 RATR1
Runs test of up-and-down of uniform (0.1) pseudo random numbers
Table RATR1-1 Condition code Code 0 10000 Meaning No error Some expected frequency Fi is small and the approximation of chi-square distribution is poor. N < L + 2, L < 2, ALP 100, ALP 0, ISW < 0 or ISW > 1. Processing Continued. Resultant of test is not so reliable. Bypassed
CALL RATR1 (A, N, L, ALP, ISW, IFLG, VW, IVW, ICON) Function This subroutine performs the runs test of up-and-down for n pseudo uniform (0, 1) random number sequences {xi } based upon the test of statistical hypothesis. On the null hypothesis that pseudo uniform random numbers are uniform random numbers, this subroutine performs chi-square test using the actual frequency and expected frequency of run of length r (1 r l, run of length greater than l is assumed to be length l) and tests whether or not the hypothesis is rejected on significance level %. Run of length r means a sub-sequence in which continued r elements are incremented ( or decreased) monotonically in a random number sequence. When the number of random number sequences is great, they can be tested in succession by calling this subroutine repeatedly. Where, n l + 2, l 2, 100 > > 0. Parameters A..... Input. Pseudo uniform random number sequence {xi }. One-dimensional array of size n. N..... Input. The number of uniform random numbers. L..... Input. The length l of the maximum run. See Notes. ALP... Input. Significance level . See Notes. ISW... Input. Control information. Specifies whether or not the test is performed independently for several random number sequences by calling this subroutine repeatedly. When ISW = 0 is specified, the test is performed independently for each random number sequence. When ISW = 1 is specified, the test is performed continuously. However ISW = 0 is specified for the first call. See Notes. IFLG... Output. Test results. When IFLG = 0 is specified, the hypothesis is accepted. When IFLG = 1 is specified, the hypothesis is rejected. VW....... Work area. One-dimensional array of size 3. IVW..... Work area. One-dimensional array of size L + 8 (must be INTEGER*4). ICON.. Output. Condition code. See Table RATR1-1.
30000
Comments on use Subprograms used SSL II ... UX2UP, MGSSL FORTRAN basic functions ... SQRT, EXP, ALOG, FLOAT, ATAN, ERFC, MAX0, MIN0 Notes [Standard for setting the length l of maximum run] The expected frequency Fr to make the length of run r is expressed by: Fr = 2n r 2 + 3r + 1 r 3 + 3r 2 r 4 2 (r + 3)! (r + 3)! ,r = 1, 2,, n 2
(3.1)
That is the expected frequency Fr decreases as Fr +1 Fr (r + 1) For example, when n = 10000, F1 = 4160, F2 = 1834, ..., F5 = 20, F6 = 3. Therefor, in this case, should be taken as l=5 This subroutine sets ICON = 10000 when the expected frequency Fi does not satisfy Fi > 10 [Standard for setting significance level] The significance level can be optionally specified according to the theory of statistical hypothesis test. The significance level, however, indicates the probability of error of the first kind which means to reject the hypothesis although it is true, the value specified should lie between 1% and 10%. Generally either 5% or 1% is used. [Testing in succession] Suppose uniform random number sequence {yi } of size m is divided into s sets of random number sequences. Letting {yi } = {yi1} + {yi2} + ... + {yis} and letting numbers in each random number sequence be m1, m2, ..., ms, that is , m = m1 + m2 + ... + ms
540
RATR1
One call of this subroutine enables the testing of random number sequence {yi }. By calling repeatedly for each random numbers sequence it is possible to obtain the final test results for {yi }, also. Table RATR1-2 shows the relationship between the contents of parameters and the object of the test for repeated calling of random number sequences.
Table RATR1-2 Successive testing Calling sequence 1 2 A {yi1} {yi2} N ISW Object of test {yi1} {yi1} + {yi2}
ms S {yis} 1 {yi1} + {yi2} + ... + {yis} Notes: The value of parameter L and ALP should be constant.
m1 m2
0 1
If ISW = 0 is specified each time this subroutine is called, the random number sequence is tested individually. When calling this subroutine repeatedly, the contents of work areas VW and IVW should not be altered. [Contents of work area] After executing this subroutine, the following values are stored in the work area: VW(1): Upper probability of 2 distribution of freedom degree l - 1 at 02 . VW(2): Value of 02 for the frequency distribution of random sequence {xi }. IVW(I): The actual frequency of runs of length l. I = 1, 2, ..., l. Example Pseudo uniform random number sequence {xi } of size 10000 is generated by subroutine RANU2 and divided into 10 sets of random number sequence of size 1000 and the runs tests of up-and-down for each set are performed. Where, l = 4 and = 5%.
C **EXAMPLE** DIMENSION A(1000), VW(3, IVW(12) DATA IX, N/0, 1000 /, IOK / 10 / DATA L, ALP/4, 5.0 /, ISW / 0 / NS = 10 LL = L-1 WRITE (6, 600) IX, N, NS, LL, ALP IS = 1 IE = N DO 20 I = 1, NS CALL RANU2 (IX, A, N, ICON) CALL RATR1 (A, N,L,ALP,ISW,IFLG,VW, * IVW, ICON) IF (ICON. EQ. 0) GOTO 10
WRITE (6, 610) I, IS, IE. IOK = IOK-1 GOTO I5 10 IOK = IOK-IFLG IF (IFLG. EQ. 0) WRITE (6, 620) I, IS, IE IF (IFLG. EQ. 1) WRITE (6, 630) I, IS, IE 15 IS = IE + 1 20 IE = IE + N RATE = IOK*100.0 / NS WRITE (6, 640) IOK, RATE STOP 600 FORMAT (1H1, 60(1H*)/6X, * 21HRUNS TEST FOR UNIFORM, * 16H RANDOM NUMBERS./1X, 60(1H*)// * 6X, 20HINITIAL VALUE IX =, I5/ * 6X, 20HSAMPLING LENGTH N =, I5/ * 6X, 20HSAMPLE NUMBER =, I5/ * 6X, 20HFREE DEGREE L-1 =, I5/ * 6X, 20HSIGNIFICANCE LEVEL=,F5.1,1H%/ *6X, 12HRESULTANTS : // *9X, 25HNO. SAMPLE JUDGEMENT) 610 FORMAT (9X, I2, I7, 1H-, I5, 4X, 5HERROR) 620 FORMAT (9X, I2, I7, 1H-, I5, 4X, 5HSAFE) 630 FORMAT (9X, I2, I7, 1H-, I5, 4X, 5HFAIL) 640 FORMAT (//6X, 17HTOTAL CONCLUSION:// * 9X, I2, 2H (, F5.1 * 21H %) SAMPLES ARE SAFE.) END
Method The up run of length r means a sub-sequence which consists of r element satisfies following xk 1 > x k < x k +1 < < x k + r > xk +r +1 where the first element of the sub-sequence is xk (1 k < n). However, when k = 1 or k + r = n, the inequality signs should not be used at the ends. For down run, the similar definition is used. Now the number of runs of length r (maximum l, 1 r l) in {xi } is expressed as fr. fl is the total number of runs in which the length is more than l. Letting the expected frequency of length r be Fr, the value forms chi-square distribution freedom degree l - 1 for many samples of {xi }.
2 0
(f =
l i =1
Fi ) Fi
(4.1)
This subroutine tests the null hypothesis that n pseudo random numbers are uniform random numbers on significance level % after obtaining value 02 from (4.1). If (4.1), the expected frequency Fr is Fr = 2n r 2 + 3r + 1 r 3 + 3r 2 r 4 2 (r + 3) ! (r + 3) ! , r = 1,2 , (4.2)
,n 2
541
RATR1
Fr Fr
r
(4.5)
(4.4)
in which expected frequency Fr is modified by the actual frequency fr. This enhances the accuracy of the testing. For details, refer to Reference [93].
542
RFT
CALL RFT (A, N, ISN, ICON) Function When one-variable real time series data {xj} of dimension n is given, this subroutine performs a discrete real Fourier transform or its inverse Fourier transform using the Fast Fourier Transform (FFT) Method. n must be a number expressed as n = 2l (n: positive integer). Fourier transform When {xj} is input, this subroutine performs the transform defined in(1.1), and determines Fourier coefficients {nak} and {nbk}. nak = 2 x j cos
j =0 n1
{ak},{bk}
a0
an/2
a1
b1
a2
b2
an/21 bn/21
n , 2 n 1 , 2
(1.1)
Inverse Fourier transform When {ak}, {bk} are input, this subroutine performs the transform defined in (1.2), and determines the values {2xj} of the Fourier series. 2kj 2kj + bk sin 2 x j = a0 + 2 ak cos k =1 n n
n / 2 1
(1.2)
+ an / 2 cosj j=0,,n-1 Parameters A..... Input. {xj} or {ak}, {bk} Output. {nak}, {nbk} or {2xj} One-dimensional array of size N. See Fig. RFT-1 for the data storage format. N..... Input. Dimension n. ISN... Input. Specifies normal or inverse transform ( 0). For transform: ISN = + 1 For inverse transform: ISN = - 1 (See Notes). ICON.. Output. Condition code See Table RFT-1
Table RFT-1 Condition codes Code 0 30000 Meaning No error l ISN = 1 or N 2 (l: positive integer) Processing Bypassed
Comments on use Subprograms used SSL II ... CFTN, PNR, URFT, and MGSSL FORTRAN basic functions ... ATAN, ALOG, SQRT, SIN, and IABS Notes General definition of discrete real Fourier transform: Discrete real Fourier transforms and inverse Fourier transforms are generally defined as: 2 n 1 2kj n ak = x j cos , k = 0, , = 2 nj0 n (3.1) 2n1 2kj n , k = 1, , 1 bk = x j sin 2 n j =0 n n / 21 1 2kj 2kj x j = a0 + ak cos + bk sin k =1 n n (3.2) 2 1 + an / 2 cosj , j = 0, , n 1 2 This routine determines {nak}, {nbk}, or {2xj} in place of {ak}, {bk} of (3.1) or {xj} of (3.2). Scaling of the resultant values is left to the user. Notice that a normal transform followed by an inverse transform returns the original data multiplied by the value 2n. Specifying ISN: ISN is used to specify normal or inverse transform. It is also used as follows; If {xj} or {ak}, {bk} are stored in an area of size NI in intervals of I, the following specification is made. For transform: ISN = + I For inverse transform: ISN = -1 In this case, the results of the transform are also stored in intervals of I. Example Real time series data {xj} of dimension n is put, transform is performed using this routine, and the results are scaled to obtain {ak}, {bk}. In case of n 1024 (= 210).
543
RFT
**EXAMPLE** DIMENSION A(1024) READ (5, 500) N, (A(I), I = 1, N) WRITE (6, 600) N, (I, A(I), I = 1, N) ISN = 1 CALL RFT (A, N, ISN, ICON) WRITE (6, 610) ICON IF (ICON. NE. 0) STOP WRITE (6, 620) A(1) N1 = N/2 - 1 IF (N1. NE. 0) WRITE (6, 630) (I, A(2*I + 1), * A(2*I + 2), I = 1, N1) N1 = N1 + 1 WRITE (6, 630) N1, A(2) STOP 500 FORMAT (I5 / (2E20.7)) 600 FORMAT (1H0,10X,13HINPUT DATA N=,I5/ * /(15X, I5, E20.7)) 610 FORMAT (1H0, 10X, 12HRESULT ICON=,I5/) 620 FORMAT (1H0, 17X, 1HK, 10X, 4HA(K), 16X, 4HB(K) * //19X, 1H0, E20.7) 630 FORMAT (/15X, I5, 2E20.7) END
considering (4.2) and (4.3). This means that complex transform on real data has redundancy in calculating conjugate elements. In this routine this redundancy is avoided by use of inherent complex transform as described below: Real transform by the complex Fourier transform First, expansion of the complex transform (4.1) applying the principles of the Fast Fourier Transform (FFT) method is be considered. Since n = 2m, k and j can be expressed as k = k 0 + k1 m, 0 k 0 m 1,0 k1 1 j = j0 + j1 2 , 0 j0 1,0 j1 m 1 If (4.4) is substituted in (4.1) and common terms rearranged, (4.5) results.
1 jk jk k0 + k1m = exp 2i 0 1 exp 2i 0 0 j 0=0 2 n m 1 jk exp 2i 0 0 x j + j 2 j1 =0 m 0 1
(4.4)
Method This subroutine performs a discrete real Fourier transform (hereafter referred to as real transform) of dimension n (=2m) using the radix 8 and 2 Fast Fourier Transform (FFT) method. By considering real data {xj} to be transformed as complex data with the imaginary part zero, a real transform can be done by a discrete complex Fourier transform (hereafter referred to as complex transform). However in such case, the complex transform can be done efficiently using the characteristics as described below. Let the complex transform be defined as kj k = x j exp 2i , k = 0,..., n 1 j =0 n
n 1
(4.5)
(4.5) means that a complex transform of dimension 2m can be performed by two sets of elementary complex transforms of dimension m by and m sets of
j1
(Refer to the section on CFT for principle of the Fast Fourier Transform method.) In this routine (4.5) is successively calculated for complex data with the imaginary parts zero. Transform by
j1
(4.1)
Two sets of elementary complex transforms of dimension m are performed by respect to j0. By
j1
Then, when {xj} is real data, the complex conjugate relationship results as shown in (4.2)
n k = k* , k = 1,... n 1
(4.2)
where * represents complex conjugates Now, the relationship between the results of a real transform {ak}, {bk}, and the results of a complex transform {ak} are a0 = 2 0 , n / 2 = 2 n / 2 ak = ( k + n k ) , k = 1,..., n / 2 1 bk = i ( k n k ) , k = 1,... n / 2 1
performing complex transforms on the even-number data {x1j} and the odd-number data {x2j}, { kx 1 } and { kx 2 } can be determined. Since the imaginary Parts of the complex data {x1j} and {x2j} are zero, just as in (4.2), the conjugate relationships shown in (4.6) exist.
x1 x1 * m k = ( k ) , k = 1,..., m 1 x2 x2 * m k = ( k )
(4.6)
(4.3)
Therefore, when a complex transform is used for real data from (4.2) and (4.3) it can be seen that {ak}, {bk} can be determined by determined only ak, k = 0, ..., n/2
The above two sets of elementary complex transforms can be performed as a single transform plus a few additional operations; that is, the real parts of {x1j} and {x2j} are paired as shown in (4.7) to form the real and imaginary parts of new complex data {zj}. z j = x1 j + i x 2 j , j = 0,..., m 1 (4.7)
and complex transform of dimension m is done with respect to {zj} and { kz } is determined. Then, using (4.8), { kx 1 } and { kx 2 } are obtained
544
RFT
from
kx1 = kx 2
* 1 z z k + ( m k ) 2 * 1 z z = k ( m k ) 2i
) m , k = 1, , 2 )
(4.8)
Processing in this routine The processing for a real Fourier transform in this routine is discussed. Refer to Fig. RFT-2 for specific example of dimension 16. (a) Let the even number real data of dimension n be {x1j} and odd number data be {x2j}, then complex transform of dimension m is performed with respect to {zj} in (4.7) to determine { kz }. (b) Using (4.8), the transformed results { kx1 } and { kx 2 } correspond to {x1j} and {x2j} are determined from { kz }. (c) { kx 2 } is multiplied by the rotation factor. (d) Complex transforms of dimension 2 are performed. In this routine, the complex transform in (a) is performed by subroutines CFTN and PNR. For further information, refer to References [55], [56], and [57].
Procedure (c)
0x1
The result {k} is the complex transform of complex data whose imaginary parts are zero. To obtain {ak} and {bk}, {k} needs to be determined only for k = 0, ..., n/2. In complex transforms by , calculation conjugate
j0
terms is omitted.
Procedure (a) Procedure (b) Procedure (d) *2
0x 2
02
*1
a0
j0
j1 = 0 ,
*2
a0 a1
12
*1
1x1
1x 2
j0 = 0,
j1
j 1 = 1,
*2
j0
b1 a2
and
22
2x1
j 0 = 1,
j1
*1
2x 2
j1 = 2 ,
j0
b2 a3 b3 a4 b4 a5 b5 a6 b6 a7 b7
32
*1
3x1
3x 2
*2 j1 = 3,
j0
42
*1
4x1
4x 2
*2 j1 = 4 ,
j0
52
5x1
5x 2
*2 j1 = 5,
j0
62
6x1
6x 2
*2 j1 = 6 ,
j0
72
7x1
7x 2
*2 j1 = 7 ,
j0
Note: Symbol indicates complex data, symbols and indicate real data. Symbols be omitted. is the rotation factor; = expo (-2i/16) *1 Separation into two sets of 8 term complex Fourier transforms of dimension 8 *2 Complex Fourier transform of dimension 2 Fig. RTF-2 Flowchart of a real Fourier transform of dimension 16
545
RJETR
CALL RJETR (A, N, Z, VW, ICON) Function This subroutine finds zeros of a polynomial with real coefficients; a 0 x n + a 1 x n 1 +
0
An n degree polynomial equation has n roots. All of the roots can not always be obtained. Users should be aware of this and make sure of the values of parameters ICON and N after calculation. Example Degree n and real coefficients aj are input and roots are calculated for 1 n 50.
C **EXAMPLE** DIMENSION A(51), Z(50), VW(306) COMPLEX Z READ (5, 500) N N1 = N + 1 READ (5, 510) (A(I), I = 1, N1) DO 10 I = 1, N1 K = I - 1 WRITE (6, 600) K, A(I) CALL RJETR (A, N, Z, VW, ICON) WRITE (6, 610) N, ICON IF (ICON. EQ. 30000) STOP WRITE (6, 620) (I, Z(I), I = 1, N) STOP FORMAT(I2) FORMAT(5F10.0) FORMAT(10X, 2HA (, I2, 2H) =, E20.8) FORMAT (10X, 2HN=,I2,5X,5HICON=,I5) FORMAT (10X, 2HZ (, I2, 2H) =, 2E20.8) END
(a: real ,a
0, n 1)
+a
=0
by Jenkins-Traubs three-stage algorithm. Parameters A..... Input. Coefficients of the polynomial equation. One-dimensional array of size (n + 1) A(1) = a0, A(2) = a1, ..., A(N + 1) = an in order. The contents of A are altered on output. N..... Input: Degree of the equation. Output: The number of roots obtained. (See Comments on use.) Z..... Output. n roots. Complex one-dimensional array of size n. Obtained roots are returned in Z(1), Z(2) ... So, if the number of obtained roots is N, those roots are returned in Z(1), ... Z(N). VW... Work area. One-dimensional array of size 6 (n + 1) ICON.. Output. Condition code. See Table RJETR-1.
Table RJETR-1 Condition codes Code 0 10000 Meaning No error All of n roots were not obtained. Processing The number of obtained roots is put into parameter N. These roots themselves are put into Z(1)Z(N). Bypassed
10
Method This subroutine employs the Jenkins-Traubs three-stage algorithm. The three-stage algorithm consists of: Using K polynomial (described later) defined differently at each of the three stages, the roots are pursued so that the smallest root is first found. (state 1) To make sure if the calculation can converge. (stage 2) Finally to speed up the convergence and to obtain the roots. (stage 3) Especially, if a real coefficient polynomial equation is given, since the roots are pursued as linear or quadratic factors, the discrimination if a linear or a quadratic factor is converging is made in the stage 2. Then accordingly the calculation is speeded up in two ways in the stage 3. If the second order factors are determined, the roots are obtained with the quadratic equation formula. Features a. Only real arithmetic is used. Complex conjugate roots are found as quadratic factors. b. Roots are calculated in roughly increasing order of modulus; this avoids the instability which occurs when the polynomial is deflated with a large root. c. The rate of convergence of the third stage is
30000
n < 1 of a0 = 0
Comments on use Subprograms used SSL II ... MGSSL, AMACH, RQDR, IRADIX, AFMAX, AFMIN, and UJET FORTRAN basic functions ... ABS, ALOG, EXP, SQRT, CMPLX, SIN, ATAN, REAL, AIMAG, and AMAX1 Notes A COMPLEX declaration for array Z must be done in the program which calls this subroutine.
546
RJETR
faster than second order. K polynomials Before describing the algorithm two important sequences of polynomials are introduced and their characteristics are described below. In equation f ( x ) a0 x n + a1 x n1 +
j mi i =1
B( ) =
(4.7)
= ( x i ) = 0, i k (i k )
+a
respectively. The every K()(x) of (4.6) is of degree n 1 at most. Employing (4.3) for K(0)(x) as before, the polynomial defined by (4.6) is given as follows: K ( ) ( x ) = ci i f i (x ), i = (i )
j i =1
(4.1)
(4.8)
Lets assume a0 = 1 and an 0, but there is no loss of generality. Starting from (n 1)-th degree arbitrary polynomial K(0)(x), for = 0, 1, ... K()(x) is defined as K(
+1)
The polynomial defined by (4.6) is called fixed-shift polynomial. It has the following two important properties. If there exists 1 such that
( x) =
K ( ) (0) 1 ( ) f ( x ) K ( x) x f (0)
(4.2)
1 < i ,i 2
then, 1 is real and f ( x ) / K ( ) ( x ) = x 1 lim
(4.9)
(4.10)
f i ( x) =
f ( x) x i
(4.3)
holds, where K())(x) is defined to be K()(x) divided by its leading coefficient. If there exist 1 and 2 such that
(x) = c
j i =1 i
fi (x)
(4.4)
1 = 2 < i ,i 3
then, by letting K 0( ) (x ) = K ( ) (x ), K v( ) (0) 1 ( ) ) = K v(+ x K x f ( x ), ( ) ( ) v 1 x f (0) v = 0,1 and K 0( ) (s1 ) K 0( ) (s2 ) x 2 ( x ) = K1( ) (s1 ) K1( ) (s2 ) x K 2( ) (s1 ) K 2( ) (s2 ) 1
( )
(4.11)
From (4.4), if 1 exists such that |1 | < |i | (i 2) and c 0, f ( x ) / K ( ) ( x ) = x 1 lim holds, where K (
)
(4.12)
(4.5) K(
)
( x) is defined to be
( x)
divide
by its leading coefficient. The rate of convergence of (4.5) depends on the ratio of 1 and 2 (i 2). The polynomial defined by (4.2) is called a no-sift polynomial. The second polynomials are defined as follow. Starting from (n - 1)-th degree polynomial K ( 0 ) ( x ) ,for = 0, 1, ... , it is defined as K(
+1)
holds. Three-stage algorithm The three-stage algorithm consists of three stages. (n 1)-th degree polynomials K()(x) which play a basic role at each step, are generated as different sequences for each of the steps. Polynomial K(M)(x) K(H)(x) at the end of stage 1 is used as the beginning polynomial for stage 2, and K(L)(x) at the end of stage 2 is used as the beginning polynomial for stage 3. Stage 1 (no-sift process) The algorithm starts with K(0)(x) = f(x) and
( x ) = 1 [ K ( ) ( x) + ( A( ) x + B ( ) ) f ( x)] ( x)
(4.6)
Here (x) is a real quadratic x2 + ux + v with roots s1 and s2 such that s1 s2, |s1| = |s2| =, min || and f(s1) f(s2)0. A() and B() are chosen so that the expression in the bracket [ ] of (4.6) can be divided by (x) and are A( ) = f (s1 ) f (s2 ) K ( ) (s1 ) K ( ) (s2 ) s1 f (s1 ) s2 f (s2 ) f (s1 ) f (s2 )
547
RJETR
the process (4.2) is iterated M, times. As for M, it is described later. The purpose of this stage is to make the term which include pi of small absolute value dominant in K(M)(x). Stage 2 (fixed-shift process) Applying (4.6) for = M, M - 1, ..., L - 1, a sequence of fixed-shift polynomials are produced. As for L, see Stopping Criterion. The purpose of producing fixedshift polynomials is to see if (4.9) of (4.11) holds. However, since k, k = 1, ..., j cannot be calculated f ( x ) / K ( ) ( x ) and ()(x) must be calculated as well as finxed-polynomials, then by using both of them, whether roots converge on linear or quadratic factors is determined. Which of (4.10) of (4.13) holds depends on the choice of s1 and s2. If any convergence is not met, it can be considered to be due to improper choice of s1 and s2, and then they would be chosen again. (See Notes on algorithm.) When f ( x ) / K ( ) ( x ) starts to converge in stage 2, the rate of convergence is accelerated by shifting it with current approximate. And when ()(x) starts to converge, the speed is accelerated by replacing (x) of (4.6) with ()(x). This motivates going to the next variable-shift process. Stage 3 (variable-shift process) This step is divided into the following two procedures depending on the state of convergence (upon linear or quadratic factors) in stage 2. (a) Iteration for a linear factor Letting s( L ) = Re s1 f (s1 )/K ( L ) (s1 ) K ( l ) s( l ) 1 (l ) K x K ( l+1) (x ) = f ( x ) ( ) (l ) (l ) xs f s s( l 1) = s( l ) f s( l ) /K ( l ) s( l )
+
K0( K1(
( +1)
( x) =
K2(
K1(
+1)
+1)
K2(
(s ) K (s ) K (s ) K (s ) K (s ) K
( ) ( ) ( )
1 0 1 1 1 2
() ()
( +1) ( +1)
(s )x (s )x (s )1 (s ) (s )
() () ()
2 2 2
( ) ( )
( ) Where s1( ) and s2 are two roots of ()(x). ( ) Then the sequence (x) converges to (x-1)(x-2). As for stopping rule see Stopping Criterion.
Notes on algorithm Initial values s1, s2 Solving the following equation by Newtons method. x n + a1 x n 1 +
+ a
n 1
x an = 0
let only one positive root be , then s1, and s2 are set as: s1 = (cos + i sin ),s2 = (cos + i sin ) where theta k k = 0 , 1, 2 , (4.18)
= L , L + 1,
( )
( )
( ) ( )
(4.14)
(4.15)
Normalization of K()(x) To avoid overflows in operations, it is taken into account that K(0)(x) = f(x)/n, and K()(x) are normalized by diving (4.6) with A() in (4.7). (4.6) with A() in (4.7). Calculation of K()(x) and ()(x) Let f (x ) = Q( x ) ( x ) + b( x + u) + a, K ( ) ( x ) = Qk( ) ( x ) (x ) + d ( x + u) + c. Then, using these a, b, c, d, u, v, Q1(x) and Qk()(x), ( +1) K (x) is calculated as follows. a 2 + uab + vb 2 ( ) + K ( 1) ( x ) = Qk ( x ) bc ad ac + uad + vbd + x Qf ( x ) + b bc ad In addition, ()(x) is also calculated using a, b, c, d, u,, and v, in the same way. Stopping criterion Stage 1 The purpose of this stage is to accentuate the smaller roots. In the implementain, M is set to 5, a number arrived at by numerical experience. Stage 2 Letting t = f (0) / K ( ) (0) , if 1 1 t and t + 2 t + 1 t + 1 2 2 then Stage 2 is terminated and iteration for a linear factor in Stage 3 is performed. t + 1 t
then the sequences s(+1) converges to 1 (b) For = L + 1, ..., (+1)(x) are calculated based on the following variable-shift polynomial K(+1)(x).
K
( +1)
(x) = ( 1 ) (x)
( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ( )
+1 +1
(4.16) K 0(
+1)
K v(+1 1
+
(4.17)
548
RJETR
Letting (
( x) = x
+ ux + , the sequence (
( x)
c0 = a 0
is monitored by applying the same test to v. If the condition is satisfied, Stage 2 is terminated and iteration for a quadratic factor in Stage 3 is performed. But if both t and v do not converge even after 20 l times iteration, s1 and s2 are reselected by rotationg through appropriate degree in (4.18). Where I is the number of times s1 and s2 are reselected and its maximum limit is 20. When I exceeds 20, processing is terminated with ICON = 10000. Stage 3 (a) Iteration for a linear factor Letting s = s(), if a i s n i u ai s n i
i =0 i= 0 n n
c1 = max a1 , u c0
bk = ak u bk 1 v bk 2 , ck = max a k , u ck 1 , v ck 2 then
B = bn1 = an 1 u bn2 v bn2 v bn3 , A = bn = a n u bn1 v bn2 and D = cn1 = max an1 , u cn 2 , v cn3 , C = cn = max an , u cn1 , v cn 2 are calculated. If B D u and A C u (u is the round-off unit) is satisfied, x2+ ux + v is adopted as a quadrate factor of f(x). Limit number of iteration is 20 in both (a) and (b). If convergence is not met within the limit, the stopping condition met within the limit, the stopping condition in Stage 2 is made severe and the rest of Stage 2 is repeated. For details, see References [30] and [31].
is satisfied, s is adopted as the root. Where u is the round-off unit. (b) Iteration for a quadratic factor Letting the quotient produced by dividing polynomial f(x) by a quadratic factor x2 + ux + v be Q(x), and its remainder be B( x + u ) +A
2
f(x)=( x + ux + v) Q(x)+ B( x + u ) +A where B and A are calculated by synthetic division. When both B and A lose their significant digits, quadratic factor are judged to have converged. That it, letting
549
RKG
CALL RKG (Y, F, K, N1, H, M, SUB, VW, ICON) Function This subroutine solves a system of first order differential equations: y1 = f1 (x , y1 , y 2 , , y n ), y10 = y1 (x 0 ) = f 2 ( x , y1 , y2 , , y n ), y 20 = y 2 (x 0 ) y2 = f n ( x , y1 , y2 , , y n ), y n 0 = y n (x 0 ) yn n 1
(1.1)
The subroutine is provided by the user as follows: SUBROUTINE SUB (YY,FF) Parameters YY: Input. One-dimensional array of size n + 1, where YY(1) = x, YY(2) = y1, YY(3)=y2, ..., YY(n +1) = yn FF: Output. One-dimensional array of size n +1, where FF(2) = f1, FF(3) = f2, FF(4) = f3, ...., 'FF(n +l) = fn (See the example). Nothing must be substituted in FF(1). VW....Work area. One-dimensional array of size n+ 1. ICON..Output. Condition code. See Table RKG-1.
Table RKG-1 Condition codes Code 0 30000 Meaning No error N1 < 2, K < N1, M <2, or H = 0.0 Processing Bypassed
on a mesh x0 + h, x0 + 2h, ..., x0 + (m-1)h with initial values y1 (x0) y2 (x0) ... yn (x0), by the Runge-Kutta-Gill method. Parameters Y..... Input. Initial values x0, y10, y20, ..., yn0 are specified as follows: Y(1,1) = x0, Y(2,l) = y10, Y(3,1) = y20, ..., Y(N1, 1) = yn0 Y is two-dimensional array, Y(K,M). Output. Values y1, y2, ..., yn for xj = x0 + jh (j=1, ..., m-1). They are output as follows: For J = 1, 2, ..., n-1 Y(1, J + 1): xj Y(2, J + 1): y1j = y1(xj) Y(N1, J + 1): ynj = ynj(xj) Output. Values of y1, y2, ..., yn for xj = x0 + jh (j = 0, l, ..., m-1), i.e., the values of f1, f2, ..., fn F is a two-dimensional array, F(K,M). They are output as follows: Let F(1, J + 1) :1.0 F(2, J + 1) : y1j = y1(xj) F(N1, J + 1) : ynj=yn(xj) Input. Adjustable dimension of arrays Y and F. Input. n + 1 where n is the number of equations in the system. Input. Stepsize h. Input. The number of discrete points of independent variable x at which approximations yi (i=1, ..., n) are to be obtained. Starting point x0 is also included in this number. m 2. Input. The name of subroutine which evaluates fi (i = 1, 2, ..., n) in (1.1).
F ....
Comments on use Subprograms used SSL II... MGSSL FORTRAN basic functions... None Notes SUB must be declared as EXTERNAL in the program from which this subroutine is called. This subroutine generates approximations at fixed intervals using a constant stepsize. As the computation proceeds, the errors tend to become larger in general; it is usually not advisable to obtain approximations at points very far from x0 though it depends on the size of h. However, this subroutine has the advantage that it is a one step method, i.e., in determining the solution at x0 +jh only the solution at x0 + (j - 1) h is necessary. This is suitable for calculating a few starting values in the multistep method, and should be exclusively used for that purpose. Example The initial value problem (3.1) of a system of differential equations is solved. , y10 = y1 (1) = 5 y1 = y2 4 2 = 2 y1 + y2 , y 20 = y2 (1) = 3 y2 x x h=0.1,m=10
(3.1)
SUB..
550
RKG
** EXAMPLE ** DIMENSION Y(3,l0),F(3,10),VW(3) EXTERNAL SUB Y(1,1)=l.0 Y(2,1)=5.0 Y(3,1)=3.0 H=0.1 CALL RKG(Y,F,3,3,H,10,SUB,VW,ICON) IF (ICON. NE. 0) STOP WRITE(6, 600) WRITE(6, 610) ((Y(I,J),I=1,3), (F(I,J),I=2,3) * ,J=1,10) STOP 600 FORMAT(1Hl/1H ,20X,IHX,19X,2HY1,18X, 2HY2, * 18X,2HFl,18X,2HF21//) 610 FORMAT(1H ,10X,5E20.8) END SUBROUTINE SUB(YY,FF) DIMENSION YY(3), FF(3) FF(2) =YY(3) FF(3)=4.0*YY(2)/(YY(l)*YY(1)) +2.0*YY(3)/ * YY(1) RETURN END
Let the vector which has elements yi (i = 0, 1, ..., n) be represented as y . Then (4.2) can be simplified to y = f ( y ), y 0 = y ( x 0 ) (4.4)
With respect to (4.4), the procedure of the RungeKutta-Gill method to approximate y(x0+ h) is shown in (4.5) below. In the following expressions, qi and ki denote (n+ 1) dimensional vectors just as yi and fi Initially assumes a zero vector. k1 = hf ( y 0 ) y 1 = y0 + 1 (k1 2q0 ) 2 1 k1 2
q 1 = q0 + 3 ( y 1 y 0 ) k2 = hf ( y1 )
Method Considering the independent variable x itself as a function; y0(x) =x,y00=y0(x0)=x0 (4.1)
1 ( k q1 ) y2 = y1 + 1 2 2 1 q2 = q1 + 3( y 2 y1 ) 1 2 k2 k 3 = hf ( y 2 ) 1 y 3 = y2 + 1 + 2 (k3 q 2 ) 1 q3 = q2 + 3( y 3 y 2 ) 1 + 2 k3 k4 = hf ( y3 ) y4 = y3 + 1 (k 4 2 q 3 ) 6 (4.5)
initial value problem (1.1) of a system of first order differential equations, can be written as
y = f ( y , y ,, y ), y = y ( x )
= f 0 ( y0 , y1 , , yn ), y00 = x0 y0 y1 = f1 ( y0 , y1 , , y n ), y10 = y1 ( x0 ) = f 2 ( y0 , y1 , , yn ), y20 = y2 ( x0 ) y2
n n 0 1 n n0 n 0
1 k4 2 Then y4 is taken as the approximation to y(x0+ h). When determining the solution at x + 2h, setting q0 = q4 y0 = y4 ,(4.5), is repeated. In this way, the approximations at x0 + 3h,......,x0 + (m-1) h, are determined. For more information, see Reference [69].
q4 = q 3 + 3( y 4 y3 )
551
RQDR
CALL RQDR (A0, A1, A2, Z, ICON) Function This subroutine finds zeros of a quadratic with real coefficients; a0 a 2 + a1 x + a2 = 0(a0 0,n 1) Parameters A0, Al, A2...Input. Coefficients of the quadratic equation. Z..... Output. Roots of the quadratic equation. Z is a complex one-dimensional array of size 2. ICON.. Output. Condition code. See Table RQDR-1.
Table RQDR-l Condition codes Code 0 10000 Meaning No error a0 = 0.0 Processing -a2/a1 is stored in the real part of Z (1), and 0.0 is stored in the imaginary part. Z (2) may be incorrect. Bypassed
**EXAMPLE** DIMENSION Z(2) COMPLEX Z READ(5,500) A0, Al, A2 CALL RQDR( A0, Al, A2, Z, ICON) WRITE(6,600) ICON, A0, Al, A2 IF(ICON. EQ. 30000) STOP WRITE(6,6l0) (Z(I),I= 1, 2) STOP 500 FORMAT(3F10.0) 600 FORMAT(l0X, 5HICON=,I5/l0X, 2HA=,3El5.6) 6l0 FORMAT(l0X,2HZ =, 2E15.6) END
Method The roots of a quadratic equation (a0x2 + a1x + a2 = 0) can be obtained from 2 where, P1 = a1/a0 and P2 = a2/a0 When P1 2 >> 4P2 a great loss of precision will result in one of the calculations P1 + P12 4 P2 or
2 P P 4 P2 . To avoid this problem, root formulas 1 1
x=
P P12 4 P2
with rationalized numerators are used in calculations. These are shown below. Let D= P12 4 P2 For D0, (conjugate complex numbers, multiple roots) x1 = P1 / 2 + i D / 2 x2 = P1 / 2 + i D / 2 For D > 0 (two real roots) If P1 > 0 + D x1 = 2 P2 / P 1 x2 = P D /2 1 + If P1 0 x 1 = (- P1 D )/ 2 x 2 = 2 P 2 /( P1 + D ) (4.1)
30000
Comments on use Subprograms used SSL II... AMACII and MGSSL FORTRAN basic functions ... CMPLX, SQRT, and ABS Example The coefficients of a quadratic equation are entered and roots Z, are determined.
)
(4.2)
very large, P12 may cause an overflow. In order to avoid this situation, the condition |P1|>1035 is checked. If the condition is satisfied, the above-described procedure is used. If the condition is satisfied, the roots are discriminated using D0 = 1- 4P2/P1/P1 and calculated as P1 D0 . D is
552
SBDL
Table SBDL-l Condition codes Code 0 10000 Meaning No error The negative pivot occurred. The matrix is not positivedefinite. The relatively zero pivot occurred. The matrix is possibly singular. NH<0, NH N or EPSZ < 0.0 Processing Continued
CALL SBDL (A, N, NH, EPSZ, ICON) Function This subroutine computes LDLT decomposition (1.1). A = LDLT (1.1)
20000
Discontinued
30000
Bypassed
of the n n real positive-definite symmetric band matrix A with upper and lower band widths h by using the modified Cholesky's method, where L is a unit lower band matrix with band widths h, D is a diagonal matrix , and n > h 0. Parameters A..... Input. Matrix A. Output. Matrices L and D-1. Refer to Fig.SBDL-1. Matrix A is stored in a one dimensional array of size n(h + 1)- h(h + 1)/2 in the compressed mode for symmetric band matrices. N..... Input. Order n of matrix A. NH.... Input. Lower band width h . EPSZ.. Input. Tolerance for relative zero test of pivots in decomposition process of matrix A ( 0.0). If EPSZ is 0.0, a standard value is used. ICON.. Output. Condition code Refer to Table SBDL-1
Diagonal matrix d11 d22
Comments on use Subprograms used SSL II... AMACH, MGSSL FORTRAN basic functions... ABS Notes Since this subroutine omits the operations concerning the elements out of the band, the processing speed is faster than subroutine SLDL provided for positivedefinite symmetric matrices. If EPSZ is set to 10s, this value has the following meaning: While performing the LDLT -decomposition by modified Cholesky's method, if the loss of over s significant digits occurred for the pivot, the LDLTdecomposition should be discontinued with ICON = 20000 regarding the pivot to be relatively zero. The standard value of EPSZ is 16Nu, where u is a unit round off, but the result is not always guaranteed. If the negative pivot occurred in the decomposition, the matrix is not a positive-definite. In this case, this subroutine is continued, with ICON = 10000. However, it should be noted that large calculation errors may occur since the pivoting is not performed. This subroutine performs LDLT decomposition, but it should be noted that D-1 is output to the array instead of D. The determinant of the matrix can be obtained by multiplying all the n diagonal elements of array A (the diagonal elements of D-1) after the subroutine has been executed and then by determining the inverse number. Notice that the array A is in the compressed mode for symmetric band matrices. Example The n n matrix with the lower and upper band width h is input and LDLT decomposition is computed. n 100 and h 50.
D
Inverting the diagonal elements
Matrix D1 + (LI)
1 l21 d 22 1 d11
Array A
d
1 1 1
0
1 dh +1 h +1
l 21
d
1 2 2
l h+11
dnn
lnnh
1 dn
n( h + 1) l h +11
d h + 1h + 1
1
1
l21 1 lh+11
h( h + 1)
0
1
lnn-h
l nn h
1
d
1 nn
Note: On output, diagonal and lower band portions of matrix D-1+(LI) are stored in one-dimensional array A in the compressed mode for symmetric band matrices.
553
SBDL
**EXAMPLE** DIMENSION A(3825) 10 READ(5,500)N, NH IF(N.EQ. 0)STOP NH1=NH+1 NT=N*NH1-NH*NH1/2 READ(5,510)(A(I), I=1, NT) WRITE(6,630) L = 0 LS = 1 DO 20 I = 1,N L = L+MIN0(I, NH1) JS = MAX0(1, I-NH1) WRITE(6,600)I,JS, (A(J),J=LS, L) 20 LS = L+1 CALL SBDL(A, N, NH, 1.0E-6, ICON) WRITE(6,610)ICON IF(ICON .GE. 20000)GO TO 10 WRITE(6,640) L = 0 LS = 1 DET = 1.0 DO 30 I = 1, N L = L+MIN0 (1,NHI) JS = MAX0(1, I-NH1) WRITE(6,600)I, JS, (A(J), J = LS, L) DET = DET*A(L) 30 LS = L+1 DET = 1.0/DET WRITE(6,620)DET GO TO 10 500 FORMAT(2I5) 510 FORMAT(4E15.7) 600 FORMAT(1H,1H(,I3,1H, ,I3,1H)/(10X,5E17.8)) 610 FORMAT(/10X, 5HICON=, I5) 620 FORMAT(//10X, * 22HDETERMINANT OF MATRIX=, E17.8) 630 FORMAT(/10X, 12HINPUT MATRIX) 640 FORMAT(/l0X, l7HDECOMPOSED MATRIX) END
~~ A = LLT
(4.1)
~ Where L is a lower triangular matrix. Further, if L is ~ defined by L = L diag( Tii equations (4.1) can be rewritten to
A = LDLT
(4.2)
Where L is a unit lower triangular matrix, and D is a positive-definite diagonal matrix. The modified Cholesky's method gives the following equations to decompose as shown in equations (4.2). lij d j = aij lik d k l jk , j = 1,
k =1 j 1
, i 1
(4.3) (4.4)
d i = aii lik d k l jk
k =1
i 1
Where i = 1, ..., n. (For further details, see the Method for subroutine SLDL). If matrix A is a positive-definite symmetric band matrix, in equations (4.2), matrix A becomes a lower band matrix, with the identical band width as A. Therefore, in this subroutine, the calculation concerning the elements out of the band are omitted, and the decomposition is actually computed using the following equations (4.5) and (4.6). lij d j = aij
j 1
k =max ( 1,i h )
j = i h,
Method Modified Cholesky's method A real positive-definite symmetric matrix A can always be decomposed in the following form.
di = aij
k =max ( 1,i h )
j 1
, n
lik d k l jk ,
554
SBMDM
N..... NH....
CALL SBMDM (A, N, NH, MH, EPSZ, IP, IVW, ICON) Function An n n nonsingular real symmetric band matrix A ~ having band width h is MDMT-decomposed using the block diagonal pivoting method. (There are similar two methods, Crout-like and Gaussian-like methods, of which the Gaussian-like method is used in this subroutine.) PAP T = MDM T (1.1)
Input. Order n of matrix A. Input. Band width h of matrix A. ~ Output. Band width h of matrix M. (See Comments on Use.) MH..... Input. Maximum tolerable band width ,hm(N > MH NH).(See Comments on Use.) EPSZ .. Input. Relative zero criterion ( 0.0) for pivoting operation. The default value is used if 0.0 is specified. (See, Comments on Use.) IP..... Output. Transposition vector indicating the history of row exchanges by pivoting operation. One-dimensional array of size n. (See Comments on Use.) IVW..... Work area. One-dimensional array of size n. ICON.. Output. Condition code. (See Table SBMDM-l.)
where P is a permutation matrix to be used to exchange rows of matrix A in the pivoting operation, M is a unit lower band matrix, and D is a symmetric block diagonal matrix comprising symmetric blocks each at most of order 2; further dk+1, k 0 if mk+1,k=0 ,where M = (mij) and D = (dij) for n h 0. Parameters A..... Input. Matrix A given in compressed mode for the symmetric band matrix assuming A to have band width hm. (See Comments on Use.) Output. Matrices M and D, (See Figure SBMDM-l.) One-dimensional array of size n( hm+1)- hm( hm+1)/2
Block diagonal matrix D Array FA
Table SBMDM-l Condition codes Code 0 20000 Meaning No error. The relatively zero pivot occurred. The coefficient matrix may be nonsingular. The band width exceeded the maximum tolerable band width during processing. NH < 0, NH > MH, MH N or EPSZ <0.0. Processing Bypassed.
25000
Bypassed.
30000
Bypassed.
d11 d 21 d 21 d 22
0
d 33 d 44
d11
Diagonal portion and band portion of the mximum tolerable band width
0
m43 d 44
0
1 m43 1
0
Only the lower triangular portion
Comments on use Subprograms used SSL II... AMACH, MGSSL FORTRAN basic functions... MAX0, MIN0, ABS, AMAX1 Notes When 10-s is set as relative zero criterion EPSZ for pivoting operation: If loss of significant digits exceeds decimals in the pivot (determinant of 1 1 or 2 2 pivot matrix) during the MDMT decomposition in the block diagonal pivoting method, the pivot value is regarded as a relative zero and ICON = 20000 is set, then processing is stopped. The default value of EPSZ is 16Nu, where u is the unit round off. If the calculation must not be stopped even if the pivot value becomes small, specify a very small value in the EPSZ parameter. In this case, however, the result is not guaranteed. result is not guaranteed.
Note: In this example, order of blocks in D2. And 1 band widthis2. M Fig.SBMDM-1 Decomposed element storing method
555
SBMDM
The transposition vector is considered to be analogues to permutation matrix P in PAPT = MDMT used in the MDMT decomposition in the block diagonal pivoting method. In this subroutine, contents of array A are actually exchanged and the related historical data is stored in IP. Note that data storing methods are different between 1 1 and 2 2 pivot matrices. At step k of the decomposition, data is stored as follows: For 1 1 pivot matrix, no row is exchanged and k is stored in IP(k). For 2 2 pivot matrix, k is stored in IP(k)and the negative value of the row (and column) number that is exchanged by row (k + 1) (and column (k + l)) is stored in IP(k+1). The determinant of matrix A is equal to that of calculated D. The elements of matrices M and D are stored in array A (Figure SBMDM-l). (See Example for subroutine LSBIX.) Generally, the matrix band width increases when rows and columns are exchanged in the pivoting operation. This means that the user must specify band width hm greater than actual band width h . If the band width exceeds hm , processing is stopped assuming ICON = 25000. The output value for NH indicates the necessary and sufficient condition for hm Simultaneous linear equations are solved by calling subroutine BMDMX after this subroutine. In an ordinary case, the solution is obtained by the calling subroutine LSBIX. The numbers of positive and negative eigenvalues of matrix A can be obtained. (See Example.) Example Given an n n real symmetric band matrix having width h, the numbers of positive and negative eigenvalues are obtained under conditions n 100 and h hm 50.
C **EXAMPLE** DIMENSION A(3825), IP(100), IVW(100) READ(5,500) N, NH, MH WRITE(6,600) N, NH, MH MHP1 = MH+1 NT = (N+N-MH) * MHIP1/2 READ(5,510) (A(J), J=1, NT) EPSZ = 0.0 CALL SBMDM(A.N,NH,MH,EPSZ,IP,IVW, * ICON) WRITE(6,610) ICON IF(ICON. GE 20000) STOP INEIG=0 IPEIG=0 I = 1
J = 1 10 M=IP(J) IF(M. EQ. J) GO TO 20 IPEIG = IPEIG + 1 INEIG = INEIG + 1 I = MIN0 (MH,J) +MIN0 (MH,I+1) +2+I J = J+2 GO TO 30 20 IF(A(I). GT. 0.0) IPEIG=IPEIG+1 IF(A(I). LT. 0.0) INEIG=INEIG+1 I = MIN0 (MH, J) +1+I J = J+1 30 IF(J. LE. N) GO TO 10 WRITE(6,620) IPEIG, INEIG STOP 500 FORMAT(3I4) 510 FORMAT(4E15.7) 600 FORMAT(1H1/1OX,2HN=,I3,5X,3HNH,I3.5X, * 3HMH=, I3) 610 FORMAT(/10X,5HICON=,I5) 620 FORMAT(1H0,5X,20HPOSITIVE EIGENVALUE=,I4 * /6X, 20HNEGATIVE EIGENVALUE=,I4 ) END
Method Block diagonal pivoting method A positive-definite symmetric matrix A can be decomposed as (4.1) using the modified Cholesky method: A = M1 D1 M1
T
(4.1)
where M1 is a unit lower triangular matrix and D1 is a diagonal matrix. If A is not a positive-definite matrix, this decomposition is generally impossible or numerically unstable even if it is possible; however, this difficulty is resolved by rearranging (4.1) to (4.2): PAP T = MDM T (4.2)
where P is the permutation matrix to be used for exchanging rows in the pivoting operation, M is a unit lower triangular matrix, and D is a symmetric matrix comprising symmetric blocks each at most of order 2. Decomposition to the form of (4.2) is referred to as the block diagonal pivoting method. Procedures in this subroutine This subroutine uses Algorithm D (references [9] and [10]) to minimize increase of the band width caused by exchanging rows (and columns) in the pivoting operation. In Algorithm D, elements of the coefficient matrix are updated at each decomposition step. The coefficient matrix obtained at step k completion is (k) expressed as A(k) = ( aij ) where A(0)=A. In this case, processing at step k (k=l,2,..., n) consists of
556
SBMDM
1) Determines
( k 1) (k = a mk = max aik k <i n
1)
(4.3)
2) If
(k a kk
1)
, ( = 0.525)
(4.4)
r = ak , k
( k 1) / a( k 1)
k +1, k
a (k 1) a (k 1) a (k 1) / a (k 1) s= i, k k +1, k +1 k +1, k / d i, k +1
(k t = aik
(4.5)
1)
) rai(,kk +1 /d 1
1)
a (ji
k +1)
= s a (jkk
4) If
( k 1 ) 2 | a kk |
, j = i, (4.6) aik
( k +1) = s,
i = k + 2,
, n
(4.16) (4.17)
(k +1) ai, k +1 = t
, n
(4.18)
(4.7)
is satisfied, the matrix is considered to be singular, ( k 1) is used then processing is stopped; otherwise, a kk as 1 1 pivot matrix to calculate
( s = aik
k 1)
( ) / a kk ,
k 1
, n
(4.8) (4.9)
, n
When decomposition is completed, the diagonal block portion of A(n) is D and the other portions are M. The band structure of the coefficient matrix has been ignored for simplifying explanations above, however, the band structure is used to efficiently process calculations in the actual program. Generally, the band width increases when a 2 2 pivot matrix is used. This subroutine reduces unnecessary calculations by exactly tracing the band width change. (See references [9] and [10] for details.)
Increments k by one, then procees to step 1). 6) Exchange row (and column) k + 1 and m. If
k 1 a k( +1,k) <
557
SEIG1
CALL SEIGI (A, N, E, EV, K, M, VW, ICON) Function All eigenvalues and corresponding eigenvectors of an norder real symmetric matrix A are determined using the QL method. The eigenvectors are normalized such that x 2 = 1 . n 1. Parameters A..... Input. Real symmetric matrix A. Compressed storage mode for symmetric matrix. A is a one-dimensional array of size n (n+1)/2. The contents of A are altered on output. N..... Input. Order n of matrix A. E.. Output. Eigenvalues. E is a one-dimensional array of size n. EV...... Output. Eigenvectors. Eigenvectors are stored in columns of EV. EV(K,N) is a two-dimensional array. K..... Input. Adjustable dimension of array EV. ( n) M..... Output. Number of eigenvalues/eigenvectors obtained. VM.... Work area VW is a one-dimensional array of size 2n. ICON.. Output. Condition code See Table SEIG1-1.
Table SEIG1-1 Condition codes Code 0 10000 15000 Meaning No error N=1 Some of eigenvalues and eigenvectors could not be determined. Processing E(1) = A(1), EV (1, 1) = 1.0 M is set to the number of eigenvalues and eigenvectors that were determined. M=0
Notes All eigenvalues and corresponding eigenvectors are stored in the order that eigenvalues are determined. Parameter M is set to n when ICON = 0, when ICON = 15000, parameter M is set to the number of eigenvalues and corresponding eigenvectors that were obtained. This subroutine is used for a real symmetric matrix. When determining all eigenvalues and corresponding eigenvectors of a real symmetric tridiagonal matrix, subroutine TEIG1 should be used. If only the eigenvalues of a real symmetric matrix are to be determined, subroutines TRID1 and TRQL should be used. Example All eigenvalues and corresponding eigenvectors of an n-order real symmetric matrix A are determined. n 100.
C **EXAMPLE** DIMENSION A(5050),E(100),EV(100,100), * VW(200) 10 CONTINUE READ(5, 500) N IF(N.EQ. 0) STOP NN=N* (N+1)/2 READ(5, 510) (A(I), I=1, NN) WRITE(6, 600) N NE=0 DO 20 I=1, N NI = NE + 1 NE = NE + 1 20 WRITE(6, 610) I, (A(J), J=NI, NE) CALL SEIG1 (A, N, E, EV, 100, M, VW, ICON) WRITE(6, 620) ICON IF(ICON .GE. 20000) GO TO 10 CALL SEPRT(E, EV, 100, N, M) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,20X,15HORIGINALMATRIX,15X. * 6HORDER =, I3/1H0) 610 FORMAT(1H0,7X,I3,5E20.7/(l1X,5E20.7)) 620 FORMAT(1H0, 20X, 5HICON =, I5) END
This example, subroutine SEPRT is used to print the eigenvalues and corresponding eigenvectors of a real symmetric matrix. The contents of SEPRT are:
SUBROUTINE SEPRT(E, EV, K, N, M) DIMENSION E(M), EV(K,M) WRITE(6, 600) KAI = (M-1)/5+1 LST = 0 DO 10 KK=1, KAI INT = LST + l
20000
30000
Bypassed
Comments on use Subprograms used SSL II... TRID1, TEIG1, TRBK, AMACH, and MGSSL. FORTRAN basic functions... SQRT, SIGN, ABS, and DSQRT
558
SEIG1
LST = LST+ 5 IF(LST.GT. M) LST = M WRITE(6, 610) (J, J=INT, LST) WRITE(6, 620) (E(J), JINT, L,, ST) DO 10 I=1,N WRITE(6,630) I,(EV(I,J) J = INT,LST) 10 CONTINUE RETURN 600 FORMAT(1H1, 20X, * 26HEIGENVALUE AND EIGENVECTOR) 610 FORMAT(1H0, 5120) 620 FORMAT(1H0, 5X, 2HER, 3X, 5E20.8/) 630 FORMAT (5X, I3, 3X, 5E20.8) END
where QH is an orthogonal matrix obtained as the product of transformation matrices in the Householder method. QH = P1 P2
P
n2
(4.3)
T is obtained using subroutine TRID 1. QH is computed from (4.3). Using the QL method, tridiagonal matrix T is reduced to diagonal matrix D to determine the eigenvalues. For information on the QL method, see the section on TRQL. This transformation is D = QT L AQL (4.4)
Method All eigenvalues and corresponding eigenvectors of an norder real symmetric matrix A are, determined. Using the orthogonal similarity transformation in (4.1), real symmetric matrix A can be reduced to diagonal matrix D. D = Q T AQ (4.1)
Where Q is an orthogonal matrix. Diagonal elements of diagonal matrix D obtained in (4.1) become all eigenvalues of real symmetric matrix A; and the i-th column of Q is the eigenvector which corresponds to i-th diagonal element of D. In this routine, eigenvalues and eigenvectors (Q) are determined as follows. Using the Householder method, real symmetric matrix A is reduced to tridiagonal matrix T.
T T = QH AQH
Qs
(4.5)
(4.6)
(4.2)
By performing the transformation of (4.4) and the computation of (4.6) at the same time, all eigenvalues and corresponding eigenvectors can be obtained together. This is done by subroutine TEIG1. The eigenvectors are normalized such that ||x||2 = 1. For further information see References [12], [13] pp 191-195, [13] pp.212-248, and [16] pp.177-206.
559
SEIG2
CALL SEIU2 (A, N, M, E, EV, K, VW, ICON) Function The m largest or m smallest eigenvalues of an n-order real symmetric matrix A are determined using the bisection method. Then the corresponding eigenvectors are determined using the inverse iteration method. The eigenvectors are normalized such that ||x||2 = 1. 1 m n. Parameters A..... Input. Real symmetric matrix A Compressed storage mode for symmetric matrix. A is a one-dimensional array of size n(n + 1)/2. The contents of A are altered on output. N..... Input. Order n of real symmetric matrix A. M..... Input. M = + m ... The m largest eignvalues desired M = m ... The m smallest eigenvalues desired E..... Output. Eigenvalues. E is a one-dimensional array of size m EV .... Output. Eigenvectors. Eigenvectors are stored in columns of EV. EV(K,M) is a two-dimensionable array K..... Input. Adjustable dimension of array EV. ( n) VW..... Work area. One-dimensional array of size 7 n. ICON .. Output. Condition code. See Table SEIG2-1.
Table SEIG2-l Condition code Code 0 10000 15000 Meaning No error N=1 Some of eigenvectors could not be determined although m eigenvalues were determined. The eigenvector could not be determined. M = 0, N < |M| or K < N Processing E(1) = A(1), EV(1, 1) = 1.0 The eigenvector is treated as vector 0. The eigenvector is treated as vector 0. Processing is bypassed.
Comments on use Subprograms used SSL II... TRID1, TEIG2, TRBK, AMACH, UTEG2 and MGSSL. FORTRAN basic functions ... IABS, SQRT, SIGN ABS, AMAX1 and DSQRT. Notes This subroutine is used for real symmetric matrices. When m eigenvalues/eigenvectors of a real symmetric tridiagonal matrix are to be determined, subroutine TEIG2 should be used. When determining m eigenvalues of a real symmetric matrix without the corresponding eigenvectors, subroutines TRID1 and BSCT1 should be used. Example The m largest or m smallest eigenvalues and corresponding eigenvectors of an n-order real symmetric matrix A are determined. n100, m 10.
C **EXAMPLE** DIMENSION A(5050), E(l0), EV(l00, 10), VW(700) 10 CONTINUE READ(5, 500) N, M IF(N. EQ. 0) STOP NN=N *(N+1)/2 READ(5, 510) (A(I), I=1, NN) WRITE(6, 600) N, M NE=0 DO 20 I=1, N NI = NE+1 NE = NE+I WRITE(6, 610) I,(A(J), J=NI, NE) 20 CONTINUE CALL SEIG2 (A, N, M, E, EV, 100, VW, ICON) WRITE(6, 620) ICON IF (ICON .GE. 20000) GO TO 10 MM = IABS(M) CALL SEPRT(E, EV, 100, N, MM) GO TO 10 500 FORMAT(2I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,20X,15HORIGINAL MATRIX,5X,2HN=, * I3, 5X, 2HM =, I3/1H0) 610 FORMAT(1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT(1H0, 20X, 5HICON=, I5) END
20000
30000
In this example, subroutine SEPRT is used to print eigenvalues and corresponding eigenvectors of the real symmetric matrix. For detail on this subroutine, refer to the example in section SEIG1. Method The m largest or m smallest eigenvalues of an n order real symmetric matrix A are determined using the bisection method. Then, the corresponding
560
SEIG2
eigenvectors are determined using the inverse iteration method. First, real symmetric matrix A is reduced to tridiagonal matrix T using the Householder method:
T T = QH AQH
Where is an eigenvalue determined using the bisection method, and x0 is an appropriate initial vector. The subroutine TEIG2 performs this operation. Let eigenvectors of T be y, then eigenvectors x of A are obtained using QH in (4.1) as x = QH y (4.3)
(4.1)
where QH is an orthogonal matrix. This is done by subroutine TRID1. Next, m eigenvalues are determined using the bisection method. Then, corresponding eigenvectors of T are determined using the inverse iteration method, which determines eigenvectors by solving equation (4.2) iteratively. which is back transformation corresponding the Householder's reduction. This is done by subroutine TRBK. The eigenvectors are normalized such x 2 = 1 . For further information, see References [12] and [13] pp 418-439.
(T I ) xr = xr 1, r = 1,2
(4.2)
561
SFRI
CALL SFRI (X, SF, ICON) Function This subroutine computes Sine Fresnel integral S (x) = 1 2
* ///6X,1HX,9X,4HS(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H,11H ** ERROR **,5X,2HX=,E17.7, * 5X,2HS=,E17.7, 5X,10HCONDITION =, I10) END
Methods Two different approximation formulas are used depending on the ranges of x divided at x = 4. For 0 x < 4 The power series expansion of S(x) S (x) =
sin(t ) t
dt =
2 x
sin t 2 dt 2
by series and asymptotic expansions, where x 0. Parameters X..... Input. Independent variable x. SF.. Output. Value of S(x). ICON.. Output. Condition codes. See Table SFRI-1.
Table SFR1-1 Condition codes Code 0 20000 30000 Meaning No error X tmax x<0 Processing SF = 0.5 SF = 0.0
( 1) 2 x x 2 n +1 = n 0 (2n + 1)!(4n + 3)
n
(4.1)
k =0
ak z 2 k , z = x 4
(4.2)
Double precision: S ( x ) = x a k x 2 k +1
11 k =0
Comments on use Subprograms used SSL II... MGSSL, UTLIM FORTRAN basic functions ... SIN, COS, and SQRT Notes The valid ranges of parameter X are: 0 X < tmax This is provided because sin(x) and cos(x) lose their accuracy if X exceeds the above ranges. Example The following example generates a table of S (x) from 0.0 to 100.0 with increment 1.0.
C **EXAMPLE** WRITE (6,600) DO 10 K = 1,101 X = K-1 CALL SFRI(X, SF, ICON) IF(ICON.EQ.0) WRITE(6,610)X,SF IF(ICON.NE.0) WRITE(6,620)X,SF,ICON 10 CONTINUE STOP 600 FORMAT(1H1,27HEXAMPLE OF FRESNEL INTEGRAL,
(4.3)
is calculated through use of the following approximate expressions of P (x) and Q (x ): Single precision: P( x ) = 2
+ ak z k 1 , z = 4 x 10
x k =0 2 11 Q( x ) = ak z k , z = 4 x k x =0 Double precision:
11 1 10 + a k z k 1 bk z k , z = 4 x k =0 x k =0 10 10 1 Q( x ) = ck z k d k z k , z = 4 x k k =0 x =0
(4.5) (4.6)
P( x ) =
(4.7) (4.8)
562
SGGM
CALL SGGM (A, KA, B, KB, C, KC, M, N, ICON) Function This subroutine performs subtraction of an m n real general matrix B from a real general matrix A. C=AB where C is an m n real general matrix. m, n 1. Parameters A.. Input. Matrix A , two-dimensional array, A(KA, N). KA.. Input. The adjustable dimension of array A, ( M). B.. Input. Matrix B , two-dimensional array, B(KB, N). KB.. Input. The adjustable dimension of array B, ( N). C.. Output. Matrix C, two-dimensional array C(KC, N). (See Notes.) KC.. Input. The adjustable dimension of array C, ( M). M.. Input. The number of rows m of matrices A, B, and C. N.. Input. The number of columns n of matrices A, B, and C. ICON ... Output. Condition codes. See Table SGGM-1.
Table SGGM-1 Condition code Code 0 30000 Meaning No error M<1, N<1, KA < M, KB < M or KC < M Processing Bypassed
Notes Saving the storage area: If there is no need to keep the contents on array A or B, more storage area can be saved by the following CALL statement. When the contents of array A are not needed: CALL SGGM (A, KA, B, KB, A, KA, M, N, ICON) When the contents of array B are not needed: CALL SGGM (A, KA, B, KB, B, KB, M, N, ICON) In the above two cases, matrix C is stored in array A or B. Example The following shows an example of obtaining the subtraction of a real general matrix B from A. Here, m, n 50.
C **EXAMPLE** DIMENSION A(50,50), B(60,60), C(100,l00) DATA IA/1HA/, IB/1HB/ ,IC/1HC/ DATA KA/50/ ,KB /60/ ,KC/100/ 10 READ(5,100) M,N IF(M.EQ.0) STOP WRITE(6, 150) READ(5,200) ((A(I, J),I=1, M) ,J=1, N) READ(5,200) ((B(I, J),I=1 ,M), J=1, N) CALL SGGM(A, KA, B, KB, C, KC, M, N, ICON) IF(ICON.NE.0) GOTO 10 CALL PGM(IA, 1, A, KA, M, N) CALL PGM(IB, 1, B, KB, M, N) CALL PGM(IC, 1, C, KC, M, N) GOTO 10 100 FORMAT (2I5) 200 FORMAT(4E15.7) 150 FORMAT(1H1///l0X, * 21H** MATRIX ADDITION **) END
The subroutine PGM in the example is for printing a real matrix. This program is shown in the example for subroutine MGSM.
Comments on use Subprograms used SSL II... MGSSL FORTRAN basic function ... None
563
SIMP1
CALL SIMPI (Y, N, H S, ICON) Function Given function values yi = f(xi ) at equally spaced points xi = x1 + (i-1) h, i=1,..., n this subroutine obtains the integral: S=
xn
**EXAMPLE** DIMENSION Y(100) READ(5,500) N, H READ(5,510) (Y(I), I=1, N) CALL SIMP1 (V, N, H, S, ICON) WRITE(6, 600) ICON, S STOP 500 FORMAT(I3, F10. 0) 510 FORMAT(6F10. 0) 600 FORMAT(10X, 15HILL CONDITION =,I5 * /10X, 16HINTEGRAL VALUE =,E15.7) END
x1
f ( x )dx
n 3, h > 0.0
by Simpson's rule, where h is the increment. Parameters Y.. Input. Function values yi . One-dimensional array of size n. N.. Input. Number of discrete points n. H.. Input. Increment h of the abscissas. S.. Output. Integral S. ICON.. Output. Condition code. See Table SIMP1-1.
Table SIMPI-1 Condition codes Code 0 10000 Meaning No error n=2 n < 2 or h 0.0 Processing Calculation is based on the trapezoidal rule. S is set to 0.0.
Method Using function values yi at discrete points in the interval [xi , xn], integration is performed using Simpson's rule. The first three points are approximated using a second degree interpolating polynominal and integration is performed over the interval
x f ( x )dx 3 ( y1 + 4 y2 + 2 y3 )
x3
1
(4.1)
Next, the same calculation is continued for the succesive three points;
(4.2)
30000
If the number of discrete points is odd this calculation is done completely. However, if it is even the above method is used over the interval [x1, xn-3], and the Newton-Cotes 3/8 rule is used over the remaining interval [xn-3, xn]
Comments on use Subprograms used SSL II......MGSSL FORTRAN basic functions..none Example Function values yi and the increment h are input and the integral S is determined.
xn
n 3
f ( x )dx
3 h( y1 + 3 y2 + 3 y3 + y4 ) 8
(4.3)
For n = 2, since the Simpsons rule cannot be used, the trapezoidal rule is used
x f ( x )dx 2 ( y1 + y2 )
x2
1
(4.4)
564
SIMP2
CALL SIMP2 (A, B, FUN, EPS, S, ICON) Function Given a function f(x) and constants a, b, and , this subroutine obtains an approximation S such that S f ( x )dx
b a
(1.1)
by adaptive Simpson's rule. f(x) must have finite values over the integration interval. Parameter A Input. Lower limit a of the interval. B.. Input. Upper limit b of the interval. FUN ... Input. The name of the function subprogram which evaluates the integrand f(x). See the example. EPS ... Input. The absolute error tolerance ( 0.0) for the integral. If EPS = 0.0 is specified, the integral will be calculated as accurately as this subroutine can. Output. The estimated error bound of the approximation obtained (See Notes.) S... Output. Approximation to the integral. ICON.. Output. Condition code. See Table SIMP2-1.
Table SLMP-2-l Condition codes Code 0 10000 Meaning No error For > 0.0, an S such that (1.1) is satisfied could not be obtained Processing The approximate value that was determined and its max. absolute error are output to parameters S and EPS. Bypassed
Even if f(x) has the form g(x)|xx0|, this subroutine will work efficiently. However, g (x) must satisfy a) and b), must be nonnegative, and x0 must be a, b, or (a + b)/2. If it is know that f(x) or any of its first five derivatives are not continuous at any point(s) other than a, b, or (a + b)/2, the interval of the integration should be divided into smaller intervals at that (those) point(s). This subroutine can then be used on each of the resulting intervals. Accuracy of S that is output This subroutine determines S such that (1.1) is satisfied. However, sometimes S can not be determined due to the difficult form of the integrand f(x) or a too small. In such cases, this subroutine calculates an approximation with as high an accuracy as possible, and estimates the error bound and then these values are returned in parameters S and EPS with ICON set to 10000. The parameter EPS can also be specified as EPS = 0.0. This condition corresponds to the above case, however ICON is set to 0 especially in this case.
0 x 2 + 10 6 dx
is determined. EPS=0.0
C ** EXAMPLE ** EXTERNAL FUN A=0.0 B=1.0 EPS=0.0 WRITE(6.600) A,B,EPS CALL SIMP2(A,B,FUN,EPS,S,ICON) WRITE(6.610) ICON,S,EPS STOP 600 FORMAT(1H1/1H,30X,2HA=,E16.8,5X,2HB=,E16.8, * 5X,10HINPUT EPS=,E16.8//) 610 FORMAT(1H , 30X, 12H***RESULT***/1H,30X, * 5HICON=,I5,5X,2HS=,E16.8,5X,4HEPS =,E16.8) END FUNCTION FUN(X) FUN=1.0/(X*X+1.OE-6) RETURN END
30000
< 0.0
Comments on use Subprograms used SSL II... MGSSL, AMACH FORTRAN basic functions... ABS Notes FUN must be declared as EXTERNAL in the program from which this subroutine is called. This subroutine is designed to treat efficiently integrands f(x) having the following properties: a) f(x) and its first five derivatives are continuous in the integration interval, and b) f(x) does not have high frequency oscillations.
Method This subroutine is based on adaptive Simpson's rule. In the adaptive algorithm, the choice of points at which the integrand is evaluated is based on the behaviour of the integrand, and as a result the integrand is evaluated at many points where the integrand changes rapidly or irregularly, but not so
565
SIMP2
many points where the integrand changes smoothly or regularly. To simplify the explanation, a < b will be assumed. Using the strategy described below, the integration intervel [ a, b, ] is subdivided, and Simpson's rule is apolied to each of the subintervals. Some of the subintervals are further subdivided. Finally, by summing the integral over the subintervals, the integral over the entire interval [a, b] is obtained. This subroutine is designed to obtain an approximation to a specified absolute accuracy. Hopefully, the approximation is within the absolute error tolerance . Simpson's rule and error estimation Let the interval [,] be a subinterval in [a, b ], and h= . The quadrature rule and error estimation method used for the integral:
is also true. From (4.4) and (4.5), if the term O(h6) can be ignored, R( 2 )[ , ] f ( x ) f ( x )dx 1 R[ , ] f ( x ) R( 2 )[ , ] f ( x ) 15
(4.6)
Since the righthand side of (4.6) can be evaluated during calculations, it is used for the error estimation of R(2)[,] f(x). In (4.6) it is assumed that the round-off error is small. The quantity ( )/(b a) is assigned to the subinterval [,] as the limit such that the error of R(2)[,]f( x) in (4.6) should not be exceeded; i.e., if
1 R[ , ] f ( x ) R ( 2 ) [ , ] f ( x ) ba 15
(4.7)
f ( x )dx
are discussed below R[, ] f(x) is defined as R[ , ] f ( x ) h + + f ( ) f ( ) + 4 f 6 2
(4.1)
R(2) [ ,] f(x) is used as an approximation to (4.1). If (4.7) is not satisfied, [,] is further subdivided. In actual calculations, instead of (4.7), the equivalent expression (4.8) is used. D[ , ] f ( x ) E where (4.8)
(4.2)
This is Simpson's rule based on three points. And R(2)[ , ]f(x) is also defined as R ( 2 ) [ , ] f ( x ) R , ( + ) 2 f ( x ) + R ( + ) 2 , f ( x )
D[ , ] f ( x ) = R and E= 180 b- a
(2)
(4.3)
{ [ , ] f ( x )}
12 R[ , ] f ( x )
(4.9)
This is derived from splitting [, ] I into two subintervals and then applying Simpson's rule based on three points to each sub-interval. In this subroutine, (4.1) is approximated by (4.3). The error of R(2)[, ]f(x)can be estimated using the Euler-MacLaurin expansion formula. If f (x) and its first five derivatives are continuous in [, ], then R( 2 )[ , ] f ( x ) f ( x )dx C4 h4 4 = f ( ) ( x )dx + O( h 6 ) 24
(4.10)
(4.4)
Strategy for subdividing the integration interval[a, b] How to subdivide the interval and how to select the subinterval to which the quadrature rule (4.3) is applied, are described here. For the sake of explanation, every subinterval is assigned its number and level as follows. The integration interval [ a, b] is defined as number 1, level 0 interval. The interval [a, (a + b) / 2] is defined as number 2, level 1 interval, and the interval [(a + b) / 2, b], is defined as number 3, level l interval. In general, if the interval [,( + )/2] is number 2 N, level (L+ 1) interval, then the interval [ ( + )/2, ] is number (2N+l), level (L+ 1) interval (See Fig. SIMP2-1).
( x )dx + O(h 6 )
(4.5)
566
SIMP2
a ( 2, 1 ) ( 4, 2 ) ( 5, 2 )
( 1, 0 ) ( 3, 1 ) ( 6, 2 ) ( 7, 2 )
( 8, 3 ) ( 9, 3 ) (10, 3) (11, 3)
Note:
The left member in parentheses ii the number and the right member is the level.
point on, it is probable that D[,]f(x) of (4.8) will have no significant digits. This is because the significant digits of the function value of f(x) are lost in the calculation of D [,] f(x). If this condition occurs in a particular sub-interval, the subdividing must not be continued, so the following considerations are made. Theoretically, if in [,], f(x) and its first four derivatives are continuous, and f(4)(x) is of constant sign, then D , ( + ) 2 f ( x ) D[ , ] f ( x )
(4.13)
Subdivision is done as follows. First, (4.3) is applied to number 2, level 1 interval. If (4.8) is satisfied, R(2)[a,(a + b) / 2] f(x) is used as an approximation over the interval [a,( a + b )/2]. If (4.8) is not satisfied, (4.3) is then applied to the number 4, level 2 interval. In general, (4.3) is used on an interval of number N, level L and then the test (4.8) is applied. If (4.8) is not satisfied, the same procedure follows with the interval of number 2N, level (L+ 1). However, if (4.8) is satisfied, the R(2)[ ,]f(x) at that time is used as an approximation value over the interval [,]. That value is then added to a running sum. Then the same procedure is applied to number M(K)+ 1, Level L K interval, where M(K)is the first even integer of the sequence. M (0) 1 , M (0) = N , M (1) = 2 M(J) 1 , M ( J + 1) = 2
Therefore, if (4.13) is not satisfied during the calculations, the cause is either that zeros of f(4)(x) exist in [,], or the round-off error has completely dominated the calculation of D[,] f(x) or D [, ( + )/2] f(x) (however, it is difficult to determine which is the actual cause). For most cases, if the subinterval is small, the cause comes from irregularities caused by the round-off error rather than the existence of zeros in f(4)(x) When this type of situation occurs, it is advisable to discontinue the subdivision process and substitute a different value for in (4.7), i.e., substitute a different value E' for the E of (4.8). In this subroutine, the following is used for the control of E. If for a subinterval [,] in level 5 or higher, D[ , ] f ( x ) > E ', D , ( + ) 2 f ( x ) > E ' and D , ( + ) 2 f ( x ) D[ , ] f ( x ) occur, E' is changed to E = D , ( + ) 2 f ( x ) Then R(2)[ , (, )/2] f(x) is accepted as the approximation over [, ( + )/2]. If in subinterval [,] D[ , ] f ( x ) E (4.18) (4.14) (4.15)
,
When L K = 0, the integration over the interval [a, b] is complete. Thus, (4.11) is output as the approximation over the interval [a, b].
( ) R [ai1 , ai ] f ( x )
n 2 i =1
(4.16)
(4.17)
(a 0 = a , a n = b )
(4.11)
Each R(2)[ai -1, ai ]f(x) satisfies (4.8) and, consequently, (4.7). (4.12) results from (4.6) and (4.7).
i =1
R(2)[ai 1, ai ] f ( x ) a f ( x )dx
b
(4.12)
occurs, R(2)[ , ]f(x) is accepted as the approximation over [, ], and if |D[, ]f(x)| 0, E' is changed as E = max E , D[ , ] f ( x )
Round-off error It has been explained that whether or not R(2)[ ,] f(x) for a subinterval [,] is accepted, is determined by whether or not (4.8) is satisfied. If (4.8) is not satisfied, [,] is subdivided and integration for [,( + )/2 ] is considered. During these processes of subdivision, from a certain
(4.19)
Even when E' is controlled as explained above, there are still other problems. Even if a zero of f(4)(x) exists in [, ], it is judged as a round-off error, and E' in (4.18) may become a little bit larger
567
SIMP2
than necessary. Some devices for the problems are taken to a degree (the details are omitted). For level 30 intervals, R(2) [, ] f(x) is accepted unconditionally, and E' is not changed. Due to the control of E', the final approximation (4.11) no longer satisfies (4.12), and the error will become
In this subroutine eff of (4.20) is output to parameter EPS. For further information, see Reference [61].
eff
1 n = (ai ai 1) b a i =1
(4.20)
568
SINI
CALL SINI (X, SI, ICON) Function This subroutine computes Sine integral Si (x ) =
x sin
600 FORMAT(1H1,24HEXAMPLE OF SINE INTEGRAL, * 8HFUNCTION/// 6X,1HX,9X,5HSI(X)/) 610 FORMAT(1H ,F8.2,E17.7) 620 FORMAT(1H ,1lH** ERROR **,5X,2HX=,E17.7, * 5X,3HSI=,E17.7,5X,1OHCONDITION=,I10) END
(t ) dt
Methods Two different approximation formulas are used depending on the ranges of x divided at x = 4 For 0 |x| < 4 The power series expansion of Si (x),
by the series and asymptotic expansions. Parameters X..... Input. Independent variable x. SI. Output. Function value of Si (x) ICON .. Output. Condition codes. See Table SINI-1.
Table SINI-1 Condition codes Code 0 20000 Meaning No error |x| tmax Processing SI = sign (x) / 2
( 1) x S ( x) = (2n + 1)!(2n + 1)
n 2 n+1 i n=0
(4.1)
(4.2)
Double precision: Si ( x ) = a k x 2 k +1
11 k =0
Comments on use Subprogram used SSL II... MGSSL, UTLIM FORTRAN basic functions ... ABS, SIN, and COS Notes The valid ranges of parameter X are: |X| < tmax This is provided because sin (x)and cos (x) lose their accuracy if |X| exceeds the above range. Example The following example generates a table of Si (x) from 0.0 to 10.0 with increment 0.1.
C **EXAMPLE** WRITE (6,600) DO 10 K=1,101 A=K-1 X=A/10.0 CALL SINI(X,SI,ICON) IF(ICON.EQ.0) WRITE(6,610) X,SI IF(ICON.NE.0) WRITE(6,620)X,SI,ICON 10 CONTINUE STOP
(4.3)
} ]
(4.4)
is calculated through use of the following approximate expressions of P (x) and Q (x): Single precision: P( x ) = a k z k , z = 4 x
11 k =0 11
(4.5) (4.6)
Q( x ) = bk z k , z = 4 x
k =0
Double precision: P( x ) = a k z k bk z k , z = 4 x
11 11 k =0 k =0
(4.7) (4.8)
Q( x ) = ck z k d k z k , z = 4 x
10 11 k =0 k =0
569
SLDL
Table SLDL-1 Condition code Code 0 10000 Meaning No error The negative pivot occurred. Matrix A is not a positivedefinite. The relatively zero pivot occurred. It is highly probable that matrix A is singular. N <1 or EPSZ < 0.0 Processing Continued
CALL SLDL (A, N, EPSZ, ICON) Function An n n positive symmetric matrix A is LDLT decomposed using the modified Cholesky's method. A = LDLT Where L is a unit lower triangular matrix, D is a diagonal matrix, and n 1. Parameters A..... Input. Matrix A. Output. Matrices Land D-1. See Fig. SLDL-1. A is stored in a one-dimensional array of size n ( n + 1)/2 in the compressed mode for symmetric matrices. N..... Input. Order n of the matrix A. EPSZ.. Input. Tolerance for relative zero test of pivots in decomposition process of A ( 0.0). When EPSZ = 0.0, a standard value is used. (See notes.) ICON.. Output. Condition code. See Table SLDL-1.
Diagonal matrix D
20000
Discontinued
30000
Bypassed
(1.1)
Comments on use Subprograms used SSL II... AMACH, MGSSL FORTRAN basic functions ... ABS Notes If EPSZ is set to 10-s, this value has the following meaning: while performing the LDL T decomposition by modified Cholesky's method,if cancellation of over s significant digits occured for the pivot, the LDLT decomposition should be discontinued with ICON = 20000 regarding the pivot to be relatively zero. Let u be the unit round off, then the standard value of EPSZ is 16 u. If the processing is to proceed at a low pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. If the negative pivot occurs in the decomposition, the coefficient matrix is not positive. In this subroutine, the condition code is set accordingly (ICON = 10000) and processing is continued. However, it should be noted that large errors may occur in such cases because pivoting was not performed. In this subroutine, LDLT decomposition is performed, but is should be noted that D-1 is output to the array instead of D. The determinant of the matrix can be obtained by multiplying all the n diagonal elements of the array A (the diagonal elements of D-1 ) after the subroutine has been executed and then by determining the inverse number. Note that the array A is in the compressed mode for symmetric matrices. For a positive-definite symmetric band matrix, the subroutine SBDL processes faster than this subroutine because the operation for the elements out of the band is omitted. Example A n n matrix is input and LDLT decomposition is computed. n 100.
Matrix {D
+ ( L I )}
Array A
d 11 d 22
0
dnn
d 1 l 21 d 22
1 11
l n1
l
0
d
1 nn
d11 l 21
d 22
nn 1
ln1
1 l 21 1
n(n + 1) 2
ln1 Note:
l
0
1
nn 1
lnn 1 d nn
1
On output, the diagonal and lower triangular portions of the matrix D-1 +(LI) are stored in the one-dimensional array A in the compressed mode for symmetric matrices. Fig. SLDL-I Storage of the decomposed elements
570
SLDL
**EXAMPLE** DIMENSION A(5050) 10 READ(5,500) N IF(N .EQ.0) STOP NT=N*(N+1)/2 READ (5,510) (A(I),I=1,NT) WRITE(6,630) L=0 LS=1 DO 20 I=1,N L=L+I WRITE(6,600)I, (A(J), J=LS, L) 20 LS=L+1 CALL SLDL(A, N, 1.0E-6, ICON) WRITE(6,610)ICON IF(ICON.GE. 20000) GOTO 10 WRITE(6,640) L=0 LS=1 DET=1.0 DO 30 I=1, N L=L+I WRITE(6,600) I, (A(J),J=LS,L) DET=DET* A(L) 30 LS=L+1 DET=1.0/DET WRITE(6,620) DET GOTO 10 500 FORMAT(I5) 510 FORMAT(5E 15.0) 600 FORMAT(1H , I5/(10X, 5E16.8)) 610 FORMAT(/10X, 5HICON=, I5) 620 FORMAT(/I10X, * 22HDETERMINANT OF MATRIX=. E16.8) 630 FORMAT(/10x, 12HINPUT MATRIX) 640 FORMAT(/10X, 17HDECOMPOSED MATRIX) END
~~ A = L LT
(4.1)
~ where, L is a lower triangular matrix. Decomposition is uniquely defined if all the positive diagonal elements ~ of L are required. In the Cholesky's method, decomposition is performed as follows:
j 1 ~ Tij , j = 1, lij = a ij Tik T jk k =1 12 i 1 ~ 2 lii = a T ii ik k =1 ~ where, A = a ij , L = Tij
, i 1
(4.2) (4.3)
( )
( )
~ If L is determined such that L = Ldiag (Tii ) , then ~ ~ ~~ A = LLT = Ldiag lii diag lii LT ~2 = Ldiag lii LT = LDLT
( ) ( ) ( )
(4.4)
where, L is a unit lower triangular matrix, and D is a positive-definite diagonal matrix. While in the modified Cholesky's method, the decomposition is performed through using the following equations. lij d j = aij
i 1
k =1
k =1
lik dk l jk ,
j 1
j = 1, , i 1
(4.5) (4.6)
Method Modified Cholesky's method A real positive-symmetric matrix A can always be decomposed as
, n
Although the Cholesky's method needs a square root calculation in equation (4:3), the modified Cholesky's method does not need it. For more information, see Reference [2].
571
SMDM
Array A
d 11 d 21
d 12
d 11
d11
0
d 22
0
d 22 m32 d 33
CALL SMOM (A, N, EPSZ, IP, VW, IVW, ICON) Function An n n real indefinite symmetric matrix A is MDMTdecomposed PAP T = MDM T (1.1)
d 33
d 21 m31
d33
1 0 1
0 0
by the block diagonal pivoting method (there are two similar methods which are called Croutlike method and Gaussianlike method, respectively. This subroutine uses the format method), where P is a permutation matrix that exchanges rows of the matrix A required in its pivoting, M is a unit lower triangular matrix, and D is a symmetric block diagonal matrix that consists of only symmetric blocks, each at most of order 2. In addition, if dk+1,k 0 then mk+ 1,k = 0, where M= ( mij) and D = ( dij), and n 1. Parameters A .... Input. Matrix A Compressed mode for a symmetric matrix Output. Matrices M and D. See Fig. SMDM-1. One-dimensional array of size n (n + 1)/2. N..... Input. Order n of the matrix A EPSZ .. Input. Tolerance for relative zero test of pivots in decomposition process of A ( 0.0). If EPSZ = 0.0, a standard value is used. (See Notes.) IP...... Output. Transposition vector that indicates the history of exchanging rows of the matrix A required in pivoting. One-dimensional array of size n. (See Notes.) VW .... Work area. One-dimensional array of size 2 n. IVW ... Work area. One-dimensional array of size n. ICON .. Output. Condition code. See Table SMDM-1.
Table SMDM-1 Condition code Code 0 20000 Meaning No error The relatively zero pivot occurred. It is highly probable that the matrix is singular. N < 1 or EPSZ < 0.0 Processing Discontinued
After computation, the diagonal portion and lower triangular portion of the matrix D+(M I) are stored in the one-dimensional array A in compressed mode for a symmetric matrix. In this case, D consists of blocks of order 2 and 1.
Comments on use Subprograms used SSL II... AMACH, MGSSL, USCHA FORTRAN basic functions ... ABS, SQRT, IABS, ISIGN Notes If EPSZ is set to l0-s this value has the following meaning: while performing the MDMT -decomposition by the block diagonal pivoting method, if the loss of over s significant digits occurred for the pivot value (i.e., determinant of a 1 1 or 2 2 matrix of the pivot), the MDMT- decomposition should be discontinued with ICON = 20000 regarding the pivot value as relatively zero. Let u be the unit round off, then the standard value of EPSZ is 16Nu If the processing is to proceed at a low pivot value, EPSZ will be given the minimum value but the result is not always guaranteed. The transposition vector corresponds to the permutation matrix P in the MDMT-decomposition with pivoting, PAP T = MDM T which is done by the block diagonal pivoting method.' This subroutine exchanges the elements of array A in its pivoting, and records its history in the parameter IP. Note that, for a 1 1 or 2 2 pivot the way of storing in the IP is a little different. The storing method at the k-th step of the decomposition is as follows: for 1 1 pivot, the row (and column) number r( k) that is exchanged by the k-th row (and column) is stored in IP( k), and for 2 2 pivot, the negative value of the row (and column) number s( k+ 1) that is exchanged by the ( k+ l)st row (and column) is also stored in IP ( k + 1),
30000
Bypassed
572
SMDM
i.e., -s is stored in IP ( k+1 ). The determinant of matrix A is equal to the determinant of matrix D created by the computation, and elements of matrix D are stored in the array A as shown in Fig. SMDM-1. Refer to the example for the subroutine LSIX. This subroutine makes use of symmetric matrix characteristics also while decomposing in order to save the data storage area. One way to solve a system of linear equations is to. call this subroutine followed by the subroutine MDMX. However, instead of these subroutines, subroutine LSIX can be normally called to solve such equations in one step. The number of positive and negative eigenvalues for the matrix A can be obtained. Refer to the example below. Example Using the subroutine SMDM, this example obtains the numbers of both positive and negative eigenvalues, by which the characteristics of a matrix can be investigated. Here, an n n real symmetric matrix is used, n 100.
C **EXAMPLE** DIMENSION A(5050),VW(200),JP(100),IVW(l00) DATA IA/1HA/ READ(5,500) N NT=(N*(N+1))/2 READ(5,510) (A(I),I=1,NT) WRITE(6,600) N CALL PSM(IA,1,A,N) EPSZ=0.0 CALL SMDM(A,N,EPSZ,IP,VW,IVW,ICON) WRITE(6,610) ICON IF(ICON.GE.20000) STOP INEIG=0 IPEIG=0 I=I J=1 10 IF(IP(J+1).GT.0) GO TO 20 IPEIG=IPEIG+1 INEIG=INEIG+1 J=J+2 I=I+J-1+J GO TO 30 20 IF(A(I).GT.0.0) IPEIG=IPEIG+1 IF(A(I).LT.0.0) INEIG=INEIG+1 J=J+1 I=I+J 30 IF(J.LT.N) GO TO 10 IF(J.NE.N) GO TO 40 IF(A(I).GT.0.0) IPEIG=IPEIG+1 IF(A(I).LT.0.0) INEIG=INEIG+1 40 WRITE(6,620) IPEIG,INEIG STOP 500 FORMAT(I3) 510 FORMAT(4E15.7) 600 FORMAT(1H1 * /6X,28HCLASSIFICATION OF EIGENVALUE * /6X,I6HORDER OF MATRIX =,I4)
610 FORMAT(1H ,5X,13HICON OF SMDM=,16) 620 FORMAT(1H ,5X,20HPOSITIVE EIGENVALUE=,I4 * /6X,2OHNEGATIVE EIGENVALUE=,I4) END
The subroutine PSM that is used in this example is used only to print a real symmetric matrix. Its program is described in the example for the subroutine MGSM. Method Block diagonal pivoting method A positive-definite symmetric matrix A can be decomposed as shown in Eq. (4.1) using the modified Cholesky method, A = M1 D1 M1T (4.1)
where M1 is a unit lower triangular matrix and D1 is a diagonal matrix. A real symmetric matrix A is not always decomposed as above. It may be unstable in the sense that there is no bound on the element growth in decomposition process. Rewrite Eq. (4.1) into the form of Eq. (4.2) to overcome this complexity. PAPT = MDMT (4.2)
The method to decompose the matrix into Eq. (4.2) is called the block diagonal pivoting method, where P is a permutation matrix that exchanges row of the matrix based on the pivoting, M is a unit lower triangular matrix, and D is a symmetric block diagonal matrix consisting of symmetric blocks at most of order 2. This subroutine, when the real symmetric matrix A is given, obtains the matrices P, D and M, all of which satisfy Eqs. (4.3) and (4.4) by using the block diagonal pivoting method. PAP T = MS S = DM T (4.3) (4.4)
Procedure performed in this subroutine At the k-th step ( k = 1, ..., n) of the decomposition in this subroutine, the k-th column of the matrices M, S and D are each obtained in the following computations (in which the elements not defined explicitly are all zeros). If a 2 2 pivot is chosen, the ( k + 1 )-th column is also obtained. For better understanding of the following explanation, n-dimensional vectors Q and R are introduced. The elements of the matrices and vectors are A = (aij), M = (mij), D= (dij), S=(sij), Q= (qi ), R =( ri ).
573
SMDM (a)
k 1 l =1
Go to step (g). Where a good value of is (1+ 17 )/8. (See the reference items.) (c) The (k + 1)st rows (and columns) of matrices M and A are exchanged with the j -th rows (and columns) and also qk+1 is exchanged with qj. si, k +1 = di,i 1mk +1,i 1 + dii mk +1,i + di,i +1mk +1,i +1 i = 1, , k 1 ri = ai, k +1
k 1 l =1
, n
If |rk+1| 2>, rk+1 is chosen as a 1 1 pivot. The k-th row (and columns) of matrices M and A are exchanged with the (k + 1)-th row (and columns), respectively. d kk = rk +1 mk +1, k = q k +1 rk +1 mik = ri rk +1 , i = k + 2, , n Go to step (g).
q q (f) det k k +1 ( = q k rk +1 q k +1 qk +1 ) is chosen as a 2 qk +1 rk +1 2 pivot. As a 2 2 pivot d kk = q k d k ,k +1 = d k +1,k = qk +1 d k +1, k +1 = rk +1 mik = (qi Ak +1 ri qk +1 ) (qk rk +1 qk +1q k +1 ) m = rq q q A r q k +1 qk +1 ) i ,k +1 ( i k i k +1 ) ( k k +1 i = k + 2, , n (g) The next computational step is defined as the (k + l)-th step if the k-th step pivot is 1 1 and as the (k +2)-th step if 2 2. Go to step (a). This algorithm takes into consideration whether or not the elements of the matrix D are zeros when calculating sik and/or si,k+1. If the k-th step execution has terminated at either step (d) or (e), the values of si,k+1, (i =1, ..., k) and qi (i = k + l, ..., n) at the (k + 1)-th step have already been calculated except for one more multiplication and addition yet to be performed.
, n
Precision of the inner products in this subroutine has been raised to minimize the effect of rounding errors. For further information, see References [9] and [10].
574
SMLE1
CALL SMLE1 (Y, N, M, L, F, ICON) Function Given a set of observed data at equally spaced points this subroutine produces the smoothed values based on polynomial local least squares fit. Each of the data is smoothed by fitting least squares polynomial of specified degree, not over all the data, but over a subrange of specified data points centered at the point to be smoothed. This process is applied to all the observed values. A limitation exists concerning m and l.
Table SMLE1-1 Limitation of m and l Degree (m) 1 3 Number of observed values (l) 3 5 5 7
Comments on use Called subprograms SSL II ..... MGSSL FORTRAN basic functions ..... none Notes This subroutine presupposes that the original function cannot be approximated by single polynomial, but can be approximated locally by a certain degree of polynomial. The choice of m and l should be done carefully after considering the scientific information of the observed data and the experience of the user. Note that the extent of smoothing increases as l increases, but decreases as m increases. It is possible to repeat calling this subroutine, that is, to apply them m th degree least squares polynomial relevant to l points to smoothed values. But if it is repeated too many time, its result tends to approach to the one which is produced by applying the m-th degree least squares polynomial to overall observed data. So, when it is repeated, the user decides when to stop it. If the user wants to apply smoothing formulas with m and l other than those prepared here, subroutine SMLE2 is recommended to use. Example At equally spaced data points, the number (n) of observed data, observed data yi , the degree (m) of local least squares approximation and the number (l) of observed data which is used in the polynomial are input and each observed data is smoothed. (n 20)
C **EXAMPLE** DIMENSION Y(20),F(20) READ(5,500) N,M,L READ(5,510) (Y(I),I=1,N) CALL SMLE1(Y,N,M,L,F,ICON) WRITE(6,600) WRITE(6,610) ICON IF (ICON.NE.0) STOP WRITE(6,620) M,L WRITE(6,630) (I,Y(I),F(I),I=1.N) STOP 500 FORMAT(3I5) 510 FORMAT(5F10.0) 600 FORMAT(lHl////26X. * 28H**** SMOOTHING BY SMLE1 ****) 610 FORMAT(1H0,37X,5HICON=,I5) 620 FORMAT(lH0,20X,22HDEGREE OF POLYNOMIAL = * ,I2/1H,23X,19HPOINT OF SUBRANGE=,I2/ * 1H0,17X,3HNO,10X,15HOBSERVED VALUES, * 10X,15HSMOOTHED VALUES) 630 FORMAT(lH,16X,I4,10X,F15.7,10X,F15.7) END
Parameters Y..... Input. Observed data yi One-dimensional array of size n. N.... Input. Number (n) of observed data. M.... Input. Degree (m) of local least squares polynomials. L..... Input. Number (l) of observed data to which a least squares polynomials is fit. F.... Output. Smoothed values. One-dimensional array of size n. ICON. Output. Condition code. See Table SMLE12.
Table SMLE 1-2 Condition code Code 0 30000 Meaning No error (1) m 1 and m 3 (2) When m = 1, l 3 and l 5 When m = 3, l 5 and l 7 (3) n < l processing Aborted
575
SMLE1
Method This subroutine smoothes n given observed data by fitting mth degree local least squares polynomials relevant to l data points instead of fitting a single least squares polynomial over all the data. Namely, an observed data yk is smoothed by fitting mth degree least squares polynomial relevant to l (= 2r +1) observed data yk-r, ..., yk-l, yk, yk+l, ..., yk+r and evaluating it at k. Suppose
And in (4.1) the coefficient of m in l is the same as that of m= l in l = 3:(r = 1). Smoothing formulas with m and l used in this subroutine are show below. The smoothing formula concerning m = 1 and l = 3: (r= 1) y 1 ( 1) = 1 (51 + 20 1 ) 6
i = yi , s = i k , k r i k + r
(See Fig. SMLE1-1) yk r , r ,
, y
k 1
, y k , y k +1 ,
,1 ,0 ,1 ,
, y
k +r
,r
1 y 1 ( 2) = (3 2 + 21 + 0 2 ) 5 1 y 1 ( 1) = (4 2 + 3 1 + 20 + 1 ) 10 1 y 1 ( 0 ) = ( 2 + 1 + 0 + 1 + 2 ) 5 The smoothing formula concerning m = 3 and l = 5; (r= 2) 1 (69 2 + 41 60 + 41 2 ) 70 1 y 3 ( 1) = (2 2 + 271 + 120 81 + 22 ) 35 1 y 3 ( 0 ) = ( 3 2 + 12 1 + 170 + 121 32 ) 35 .. y 3 ( 2) = The smoothing formula concerning m = 3 and l = 7; (r= 3) (4.2)
1 (39 3 + 8 2 4 1 40 + 1 + 42 23 ) 42 1 y 3 ( 2 ) = (8 3 + 19 2 + 16 1 + 60 41 72 + 43 ) 42 1 y 3 ( 1) = ( 4 3 + 16 2 + 19 1 + 120 + 21 42 + 3 ) 42 1 y3( 0 ) = ( 2 3 + 3 2 + 61 + 70 + 61 + 32 23 ) 21 y 3 ( 3) =
The m-th degree least squares polynomial relevant to these s is expressed as follows:
2 (2 j + 1) (2r )! Pj (t ,2r ) Pj ( s,2r )t y m ( s) = t = r j = 0 (2r + j + 1)( ! 2 ! r j ) (4.1) r m
where Pj ( ,2r ) =
k =0
( 1)
j+ k
( )(k ) = ( 1)( 2)
( k + 1)
(4.1) is called a m-th degree smoothing formula relevant to l points. This formula can be derived from the least squares polynomial which was described at the "Method" of subroutine LESQ1 in case w(xi ) an abscissas are equally spaced. yk is smoothed by (4.3). (2 j + 1) (2r )! 2 Pj (t ,2r )Pj (0,2r )t y m (0) = = = t r j 0 ( 2r + j + 1)( ! 2r j )! (4.3)
r m
. For details, see Reference [46] pp.228 to 254, [51] pp.314 to 363.
When yk is either among y1, ..., yr or among yn-r+1, ..., yn, yk does not have r observed data equally on both sides and can not be smoothed by ym (0). In case of y1, ..., yr, the smoothing is done by ym (r), ..., ym (1) and in case of yn-r+1, ..., yn, by ym (1), ..., ym (r).
576
SMLE2
CALL SMLE2 (X, Y, N, M, L, W, F, VW, ICON) Function Given a set of observed data at x1, x2, ..., xn (x1 < x2 < ... < xn) and corresponding weights w(xi ), i = 1, 2, ..., n, this subroutine produces the smoothed values based on polynomial local least squares fit. Each of the data is smoothed by fitting least squares polynomial of specified degree m, not over all the data, but over a subrange of specified l data points centered at the point to be smoothed. Where n l, w(xi ) 0 (i= 1, ..., n), l m+ 2, m 1 and l must be an odd integer. Parameters X.... Input. Discrete points xi . One-dimensional array of size n. Y.... Input. Observed values yi . One-dimensional array of size n. N.... Input. Number (n) of observed values. M.... Input. Degree (m) of local least squares a polynomials. L..... Input. Number (l) of observed data to which least squares polynomial is fit. W..... Input. Weight functions w(xi ). Normally w(xi ) = l. One-dimensional array of size n. F .. .. Output. Smoothed values. One-dimensional array of size n. VW... Working area. One-dimensional array of size 2l. ICON.. Output. Condition code. See Table SMLE21.
Table SMLE2-2 Condition codes Code 0 30000 Meaning No error One of the following happened: (1) x1 < x2 < . . . < xn-1 < xn is not satisfied. (2) n < 1 (3) m < 1 or m+2 > 1 (4) Some of m (xi) are negative. (5) 1 is even. processing Bypassed
Notes This subroutine presupposes that the original function cannot be approximated by single polynomial. but can be approximated locally by a certain degree of polynomial. The choice of m and l should be done carefully after considering the scientific information of the observed data and the experience of the user. Note that the extent of smoothing increases as l increases, but decreases as m increases. It is possible to repeat calling this subroutine, that is, to apply the mth degree least squares polynomial relevant to l points to smoothed values. But if it is repeated too many times, its result tends to approach to the one which is produced by applying the mth degree least squares polynomial to overall observed data. So, when it is repeated, the user decides when to stop it. This subroutine can be used in the case data points are not equally spaced. But it takes more processing time than the subroutine SMLE1. Example Number (n) of discrete points, discrete points xi , observed values yi , degree m of local least squares polynomial and number of observed values l are given to smooth the observed values. n 20, m 17, w( xi ) = 1,(i = 1,
C
, n)
**EXAMPLE** DIMENSION X(20),Y(20),w(20),F(20), VW(40) READ(5,500) N,M,L READ(5,510) (X(1),I=l,N) READ(5,510) (X(1),I=l,N) DO 10 I=1,N 10 W(I)=1.0 CALL SMLE2 (X,Y,N,M,L,W,F,VW,ICON) WRITE(6,600) WRITE(6.610) ICON IF(ICON.NE.0) STOP WRITE (6,620) M,L WRITE(6,630) (X(I),Y(I),F(I),I=1,N) STOP 500 FORMAT(3I5) 510 FORMAT(5F10.0) 600 FORMAT(1H1////26X, * 28H**** SMOOTHING BY SMLE2 **** 610 FORMAT(1H0, 37X,5HICON=,I5) 620 FORMAT(1H0,20X,22HDEGREE OF POLYNOMIAL = * ,I2/1H ,23X,19HPOINT OF SUBRANGE =,I2/ * 1H0, 11X,8ABSCISSA,11X,15HOBSERVED VALUES. * 10X,15HSMOOTHED VALUES) 630 FORMAT(1H ,10X,F10.0,10X,F15.7,10X, F15.7) END
Comments on use subprograms used SSL II... MGSSL FORTRAN basic functions ... None
Method This subroutine smoothes n given observed data at unequally spaced points x1, x2, ..., xn by fitting m-th degree local least squares polynomials relevant to l
577
SMLE2
points, instead of fitting a single least squares polynomial over all the data. Namely and observed data yk is smoothed by fitting mth degree least squares polynomial relevant to l(=2r+1) observed data yk-r, ..., yk-1, yk, yk+1, ..., yk+r and by evaluating it at x = xk. Suppose
j +1 =
t = r r
w(t )t [ Pj (t )]
2 r
t = r
w(t )[Pj (t )]
2
j = 0 ,1,2 ,
(4.2)
j =
t = r
s = yi , s = xi , s = i k k r i k +r
(See Fig. SMLE2-l) The mth degree least squares polynomial relevant to these s is expressed as follows: r W p m ( t ) t j( t ) t = r ym (s ) = r Pj (s ) 2 j =0 W p ( t) j( t ) t = r
j = 1,2 ,
As for (4.1) refer to Method of the subroutine LESQ1. Then yk is smoothed by (4.3). r w P ( ) ( ) t t j t m r ym (0 ) = t = P j ( 0 ) r 2 j=0 w P ( t ) j( t ) t = r
(4.1)
(4.3)
yk + 1
When yk is either among y1, ..., yr among yn-r+1, ..., yn, yk does not have r observed data equally on both sides and can not be smoothed by ym (0). In case of y1, ..., yr the smoothing is done by ym (1), ..., ym (r) respectively and in case of yn-r+1, ..., yn at ym (_r), ..., ym (_1) respectively. For details, see reference [46] pp.228 to 254 and [51] pp.314 to 363.
y
0
1
k +r
yk r
y
yk
k 1
0 xk r
x
k 1 k
xk + 1
x
x
k +r
578
SPLV
CALL SPLV (X, Y, N, ISW, DY, V, M, DV, K, VW, ICON) Function Given discrete points x1, x2, ..., xn ( x1 < x2 < ... < xn) and function values yi = f( xi ), i = 1, 2, ..., n this subroutine obtains interpolated values, and 1st and 2nd order derivatives at x = vi , i = 1, 2, ..., m using a cubic spline interpolating function. n 3, x1 v1 ,v 2 , ,vm xn ,m 1 The boundary conditions for derivatives at both ends of discrete points (x = x1, x = xn) may be specified. Parameters X..... Input. Discrete points xi . X is a one-dimensional array of size n. Y..... Input. Function values yi . Y is a one-dimensional array of size n. N..... Input. Number of discrete points n. ISW... Input Control information. ISW is a one-dimensional array of size 2, and denotes the type of boundary conditions. Both ISW {1) and ISW (2) must be any one of 1, 2, 3, or 4. Accordingly, derivatives must be input to DY (1) and DY (2). Details are given below. How to specify boundary conditions: When ISW(1)=1, DY(1)=f" (x1) =2, DY(1) = f" (x1) =3, DY(1)=f" (x1) / f"(x2) =4, DY(1) need not be input. When ISW(2)=1, DY(2)=f' (xn) =2, DY(2) = f'(xn) =3, DY(2) =f(xn) /f"(xn) =4, DY(2) need not be input. When ISW(1) = 4 (or ISW(2)=4), f(x1) (or f"(xn)) is approximated using a cubic (or quadratic, when n=3) interpolating polynomial and the resultant value taken as a boundary condition. DY.... Input. Derivatives at both end points. DY is a one-dimensional array of size 2. (See parameter ISW.) V..... Input. Points at which interpolated values are to be obtained, vi i = 1,..., m V is a one-dimensional array of size m M..... Input. Number of points m at which interpolated values are to be obtained. DV.... Output. Interpolated value, and derivatives of
order 1 and 2 at vi . Two-dimensional array of DV (K,3) For I = 1,2, ..., M, interpolated value, and derivatives of order 1 and 2 at V(I) are returned respectively in DV (I,1), DV (I,2) and DV (I,3). K..... Input. Adjustable dimension of array DV ( M). VW...... Work area. VW is a one-dimensional array of size 2n. ICON.. Output. Condition code. See Table SPLV-1.
Table SPLV-1 Condition codes Code 0 30000 Meaning No error 1 N<3 2 xi xi+1 3 ISW (1) or ISW (2) is not equal to 1.2, 3 or 4 4M<1 5 vi < x1 or x1 < vi 6K<M Processing Aborted
Comments on use Subprograms used SSL II ... MGSSL, USPL FORTRAN basic function... None Notes When the derivatives at both ends are unknown, "4" may be specified for both ISW(1) and ISW(2). Example Discrete point xi, function value yi , i = 1, 2, ..., n, and boundary conditions ISW(1), DY(1), ISW(2), and DY(2) are input, and the interpolated values, firstorder derivatives and second-order derivatives at points: v2 i 1 = xi ,i = 1, v2 i = ( xi + xi +1 ) / 2 ,i = 1, are determined n 10.
C **EXAMPLE** DIMENSION X(l0),Y(l0),ISW(2), DY(2), * V(50), DV(50,3), VW(20) READ(5,500) N READ(5,510) (X(I), Y(I), I=1, N) WRITE(6,600) (I, X(I), Y(I), I=1, N) READ(5,520) (ISW(I), DY(I), I = 1, 2) WRITE(6,610) (ISW(I), DY(I),I=1, 2) N1 = N-1 DO 10 I=1, N1 V(2*I-1)=X(I) 10 V(2*I)=0.5* (X(I)+X(I+l))
,n
,n 1
579
SPLV
M=2*N-1 V(M)=X(N) CALL SPLV(X,YN,ISW,DY,V,M,DV,50, * VW, ICON) WRITE(6,620) ICON IF(ICON EQ. 30000) STOP WRITE(6,630) (I,V(I), (DV(I,J),J=l,3), * I=1,M) STOP 500 FORMAT(I5) 510 FORMAT(2F10.0) 520 FORMAT(15, F10.0) 600 FORMAT( 1H1//10X, 10HINPUT DATA// * 20X, 3HNO, 10X, 1HX, 17X, 1HY// * (20X, I3, 3X, E15.7, 3X, E15.7)) 610 FORMAT(/10X, l4HBOUNDARY COND. / * 20X, 7HISW(1)=, I3,7H,DY(1) =, E15.7/ * 20X, 7HISW(2)=, I3,7H,DY(2) =, E15.7/) 620 FORMAT(10X,7HRESULTS/20X,5HICON=,I5/) 630 FORMAT(20X,3HNO.,10X,1HV,17X,4HY(V), * 5HY'(V), 13X, 6HY''(V)// * (20X, I3, 4(3X, E15.7))) END
When
For i = 1,
,n 1
(4.3)
yi satisfies the three-term relation of (4.4) according to the third condition in (4.2). hi 1 yi 1 + 2(hi 1 + hi ) yi+ hi yi +1 y yi yi yi 1 = 6 i +1 hi 1 hi ,i = 2 , (4.4)
Method Given discrete points x1, x2, ..., xn ( x1 < x2 < ... < xn) and function values yi = f( xi ), i = 1, 2, ..., n , the interpolated values and the 1st and 2nd order derivatives at any point v in [x1, xn] are determined using a cubic interpolating spline. Here, a cubic interpolating spline is an interpolating function S ( x) defined in interval [x1, xn] and it satisfies the following conditions: S(x) is an polynomial of degree three at most in each interval [xi , xi +1] i= 1,..., n - 1 S(x) and its derivatives of up to order 2 are continuous on the interval [x1, xn] That is, S( x) C2 [x1, xn] S( xi ) = yi , i = 1, 2, ..., n Here, S(x) is determined. For the convenience of explanation, S (x) is sectionally expressed by (4.1). S(x) = Si (x) 2 3 = y i + c i ( x x i ) + d i ( x x i ) + ei ( x x i ) (4.1) x i x x i+1 , i = 1, , n 1
,n 1
Therefore, ci , di and ei in (4.3) may be determined by solving yi from (4.4). In (4.4), only (n - 2) equations are available for n unknows yi , so that two more equations for yi are required to solve (4.4) uniquely. This subroutine allows the user to assign such equations as boundary conditions. How to specify boundary conditions Assumption is made that equations in the following forms (4.5) and (4.6) are given as boundary conditions for solving (4.4).
1 y1+ 1 y2 = d1 n yn = d n 1 + n yn
(4.5) (4.6)
(4.2)
These constants 1, 1, d1, n, n and dn can be specified arbitrarily. In this subroutine, however, the following assumptions are made: (a) (ISW(1) = 1, DY(1) =f"(x1) specifying f''(x1)). Then, (4.5) is reduced to y1" = f'' (x1). (b) (ISW(2) =2, DY(1) = f''(x1) specifying f''(x1)). The equation corresponding to (4.5) is generated in the following manner: Since the derivative S1 (x1) as determined by (4.1) and (4.3) is expressed by: S1( x1 ) = y2 y1 2 y + y2 h1 1 6 h1
Accordingly, coefficients ci , di and ei in (4.1) are determined by the conditions of (4.2). These coefficients are given in (4.3).
(c) (ISW(1) =3,DY (1)=, f"( x1)/f"( x2)) specifying f"( x1)/f"( x2)
580
SPLV
= f ( x1 ) / f ( x2 ) (4.5) can be By letting y1/ y2 written as y1 f ( x1 ) / f ( x2 ) y2 = 0 (d) f'(x1) is approximated using an interpolating polynomial (ISW(1) =4, there is no need to input DY(1)). f'(xn) is approximated by an interpolating polynomial using four points of x1, x2, x3, and x4 then the case (b) is applied. (However, when only three discrete points are available, f(x1) is approximated using the three points.) The abovedescribed four steps describe the procedure for assigning an equation corresponding to (4.5) The procedure for assigning an equation corresponding to (4.6) is based on a similar idea. (e) (ISW(2) = 1, DY(2) =f'(xn)) specifying f'(xn) (f) (ISW(2) = 2, DY(2) = f'(xn)) specifying f'(xn) In this situation, (4.6) can be written as
= yn 1 + 2 yn
6 y yn 1 f ( xn ) n hn 1 hn 1
(g) (ISW(2) = 3, DY (2) = f'(xn)/f'(xn-1) specifying f'(xn) (h) (f) is fitted by approximating f' (xn) (There is no need to input ISW(2) = 4, DY(2).) (a)through (d) and through (h) can be specified combined with each other. For example, (a) and (e), (a) and (g) or (b) and (h) might be specified. Interpolated value calculation The interpolated value, the derivative of order 1 and 2 at any point v in interval [x1, xn] are determined by evaluating Si (x) and Si (x), Si (x) which are defined on interval [xi , xi +1] satisfying the condition xi v < xi +1 For further information, see Reference [48].
581
SSSM
CALL SSSM (A, B, C, N, ICON) Function These subroutines perform subtraction of n n real symmetric matrices A and B C=A-B where C is an n n real symmetric matrix. n 1. Parameters A..... Input. Matrix A, in the compressed mode, one-dimensional array of size n (n+1)/2. B..... Input. Matrix B, in the compressed mode, one-dimensional array of size n (n +1)/2. (See Notes.) C..... Output. Matrix C, in the compressed mode, one-dimensional array of size n (n +1)/2. (See Notes.) N..... Input. The order n of matrices A, B and C. ICON .. Output. Condition codes. See Table SSSM-1.
Table SSSM-1 Condition code Code 0 30000 Meaning No error n<1 processing Bypassed.
Notes Saving the storage area: When the contents of array A or B are not required. Save the area as follows: When the contents of array A are not needed. CALL SSSM (A, B, A, N, ICON) When the contents of array B is not needed. CALL SSSM (A, B, B, N, ICON) In the above two cases, matrix C is stored in array A or B. Example The following shows an example of obtaining the subtraction f matrix B from matrix A. Here, n 100.
C **EXAMPLE** DIMENSION A(5050),B(5050).C(5050) DATA IA/1HA/, IB/1HB/, IC/1HC/ 10 READ(5,100) N IF(N.EQ.0) STOP WRITE(6,150) NT=N* (N+1)/2 READ(5,200) (A(I), I=1,NT) READ(5,200) (B(I), I=1,NT) CALL SSSM(A,B,C,N,ICON) IF(ICON.NE.0) GOTO 10 CALL PSM(IA,1,A,N) CALL PSM(IB,1,B,N) CALL PSM(IC,1,C,N) GOTO 10 100 FORMAT(I5) 200 FORMAT(4E15.7) 150 FORMAT(1H1///10X, * 21H** MATRIX ADDITION **) END
Comments on use Subprograms used SSL II... MGSSL FORTRAN basic function... None
Subroutine PSM in the example is for printing the real symmetric matrix. This program is shown in the example for subroutine MGSM.
582
TEIG1
TElG1 (D, SD, N, E, EV, K, M, ICON) Function All eigenvalues and corresponding eigenvectors of norder real symmetric tridiagonal matrix T are determined using the QL method. The eigenvectors are normalized such that ||x||2=1.n1. Parameters D..... Input. Diagonal elements of real symmetric tridiagonal matrix T. D is a one-dimensional array of size n. The contents of D are altered on output. SD.... Input. Subdiagonal elements of tridiagonal matrix .T The subdiagonal elements are stored in SD (2) to SD (N). The contents of SD are altered on output. N..... Input. Order n of tridiagonal matrix T. E..... Output. Eigenvalues. E is a one-dimensional array of size n. EV.... Output. Eigenvectors. Eigenvectors are stored in columns of EV. EV(K,N) is a two-dimensional array. K..... Input. Adjustable dimension of array EV. M..... Output. Number of eigenvalues/eigenvectors that were determined. ICON .. Output. Condition code. See Table TEIG1-1. Comments on use Subprogram used SSL II ..... AMACH and MGSSL FORTRAN basic functions .. ABS, SIGN, and SQRT Notes Eigenvalues and corresponding eigenvectors are stored in the order that eigenvalues are determined.
Table TEIG1-1 Condition code Code 10000 15000 Meaning N=1 Some eigenvalues/eingenvectors could not be determined. processing E(1) = D(1), EV(1,1)=1.0 M is set to the number of eigenvalues/eigenv ector that were determined. M=0
Parameter M is set to n when lCON=0: parameter M is set to the number of eigenvalues/eigenvectors that were determined when ICON = 15000. This routine is used for real symmetric tridiagonal matrices. For determining all eigenvalues and corresponding eigenvectors of a real symmetric matrix, subroutine SEIG 1 should be used. For determining all eigenvalues of a real symmetric tridiagonal matrix, subroutine TRQL should be used: Example All eigenvalues and corresponding eigenvectors of norder real symmetric tridiagonal matrix T are determined. n 100.
C *EXAMPLE** DIMENSION D(100),SD(100),EV(100,100),E(100) 10 READ(5, 500) N IF(N.EQ. 0) STOP READ(5, 510) (D(I), SD(I), I=1, N) WRITE(6, 600) N,(I,D(I), SD(1), I=1, N) CALL TEIG1 (D, SD, N, E, EV, 100, M, ICON) WRITE(6, 610) ICON IF(ICON. GE. 20000) GO TO 10 CALL SEPRT(E, EV, 100, N, M) GO TO 10 500 FORMAT(I5) 510 FORMAT(2El5.7) 600 FORMAT(1H1, 5X, I5HORIGINAL MATRIX, 5X, * 6HORDER =, I3/IH0, 20X, 14H***DIAGONAL***. * 5X, I4H**SUBDIAGONAL*//(l3X, I3, 5X, * 2(E14.7, 5X))) 610 FORMAT (1H0, 20X, SHICON=, I5) END
In this example, subroutine SEPRT is used to print eigenvalues and corresponding eigenvectors of real symmetric matrices. For details see the example in section SEIG1. Method All eigenvalues and corresponding eigenvectors of norder real symmetric tridiagonal matrix T are determined using the QL method. The QL method used to determine eigenvalues is explained in the SEIG1 section, the QL method of determining eigenvectors will be explained. In the orthogonal similarity transformation of (4.1), orthogonal matrix Q reduces T to diagonal matrix D. The column vectors of Q are the eigenvectors of T. D=QTTQ (4.1)
20000
30000
Bypassed
By repeatedly executing the orthogonal similarity transformation in (4.2), the QL method reduces T to D, and obtains all eigenvalues as the diagonal elements of D.
583
TEIG1
Ts+1 = Qs TsQs
T
s = 1,2,3,
(4.2)
1 Q ( ) = Q ( )Qs s s
(4.7)
(T
k s I ) = Qs Ls
(4.3)
P
s
(s )
P1( )
s
(4.8)
If (4.7) is substituted in (4.8). Where ks is the origin shift and Ls is, a lower triangular matrix. If T converges to a diagonal matrix on the m-th iteration from (4.2).
T T D = Qm Qm 1
Q( ) = Q(
s
s 1)
Pn(1) Pn(2)
s
P
( s)
P1(
s)
(4.9)
Q Q T Q Q Q
T 2 T 1 1 1 2
m 1
Qm
(4.4)
Where Tl = T From (4.1) and (4.4), eigenvectors are obtained as the column vectors of Q = Q1Q2 If Q ( Q(
s 1)
Q
m 1
Qm
(4.5)
is defined as
s 1)
= Q1Q2
Q
s
After all Q can be determined by repeating (4.9) for s = 1, 2, ..., m. In the QL method, if an eigenvalue does not converge after 30 iterations, processing is terminated. However, the M eigenvalues and eigenvectors that were determined till then can still be used. Since matrix Q is orthogonal, the eigenvectors obtained in the above method are normalized such that ||x||2=1. For further information see References [12], [13] pp. 227-248 and [16] pp. 177-206.
s 1
(4.6)
584
TEIG2
CALL TEIG2 (D, SD, N, M, E, EV, K, VW, ICON) Function The m largest or m smallest eigenvalues and corresponding eigenvectors are determined from n-order real symmetric tridiagonal matrix T. The eigenvalues are determined using the bisection method, and the corresponding eigenvectors are determined using the inverse iteration method. The eigenvectors are normalized such that ||x||2=1.1mn. Parameters D..... Input. Diagonal elements of real symmetric tridiagonal matrix T. D is a one-dimensional array of size n. SD.... Input. Subdiagonal elements of real symmetric tridiagonal matrix T. SD is a one-dimensional array of size n. The subdiagonal elements are stored in SD(2) to SD(N). N.... Input. Order n of tridiagonal matrix T. M.... Input. M = + m ... The m largest eigenvalues desired. M = - m .... The m smallest eigenvalues desired. E..... Output. Eigenvalues. E is a one- dimensional array of size m. EV..... Output. Eigenvectors. Eigenvectors are stored in columns of EV. EV (K,M) is a two-dimensional array. K..... Input. Adjustable dimension of array EV. VW...... Work area. VW is a one-dimensional array of size 5n. ICON .. Output. Condition code. See Table TEIG2-1.
Table TEIG2-1 Condition codes Code 0 10000 15000 Meaning No error N=1 After determining m eigenvalues, all of their corresponding eigenvectors could not be determined. None of the eigenvectors could be determined. Processing E(1)=D(1), EV (1, 1) = 1.0 The eigenvectors that could not be obtained become zero vectors. All of the eigenvectors become zero vectors. Bypassed
Comments Subprograms used SSL II slave subroutines....AMACH and MGSSL, and UTEG2 FORTRAN basic functions.....ABS, AMAX1 and IABS Notes This subroutine is used for real symmetric tridiagonal matrices. When determining m eigenvalues/eigenvectors of a real symmetric matrix, subroutine SEIG2 should be used instead. When determining m eigenvalues of a tridiagonal matrix without their corresponding eigenvectors subroutine BSCT1 should be used. Example The m largest or m smallest eigenvalues of an n-order real symmetric tridiagonal matrix are determined, then the corresponding eigenvectors are determined. n 100, m 10.
C **EXAMPLE** DIMENSION D(100),SD(100),E(10),EV(100,10), * VW(500) 10 CONTINUE READ(5, 500) N, M IF(N. EQ. 0) STOP READ(5, 510) (D(I), SD(I), I = 1, N) WRITE(6, 600) N,M,(I,D(I), SD(I), I = 1, N) CALL TEIG2 (D, SD, N, M, E, EV, 100, VW, ICON) WRITE(6, 610) ICON IF(ICON.NE. 0) GO TO 10 MM=IABS(M) CALL SEPRT(E,EV,100,N,MM) GO TO 10 500 FORMAT(2I5) 510 FORMAT(2E15.7) 600 FORMAT(1H1,5X,15HORIGINAL MATRIX,5X,2HN= * I3,2HM=,I3/1H0,20X,14H***DIAGONAL***. * 5X,14H**SUBDIAGONAL*//(13X,I3,5X, * 2(E14.7, 5X))) 610 FORMAT(1H0, 20X, SHICON=, I5) END
In this example, subroutine SEPRT is used to print eigenvalues and corresponding eigenvectors of real symmetric matrices. For details, see the example in section SEIGI. Method The m largest or m smallest eigenvalues and corresponding eigenvectors of an n-order real symmetric tridiagonal matrix are determined. The m eigenvalues are determined using the bisection method and corresponding eigenvectors are determined using the inverse iteration method. Refer to the section BSCTI for a description of the bisection method. The inverse iteration method is discussed below. Let the eigenvalues of tridiagonal
20000
30000
585
TEIG2
matrix T are
1 > 2 > 3
>
y0 =
(
n
n u T , n u T ,
n u T
)T
(4.9)
(4.1)
When j is obtained as an approximation for j using the bisection method, consider the determination of corresponding eigenvectors using the inverse iteration method. In the inverse iteration method (4.2) is iteratively solved. When convergence condition has been satisfied, xr is considered to be an eigenvector.
( t ii + t i 1 i ) i =1 = (t ij ), t 01 = 0
= y0
(4.10)
(T I )x
j
= x r 1
r = 1,2,
(4.2)
(x0 is an appropriate initial vector) Let the eigenvectors which correspond to the eigenvalues 1 , 2 , , n be u1 , u2 , , un and the appropriate initial vector x0 can be represented as a linear combination:
xr is accepted as an eigenvector. (4.11) can be discussed as follows. From (4.2), by normalization of xr (4.12) is obtained
(T
j I )x r / x r
x 0 = i ui
i =1
= x r 1 / x r
(4.12)
1
(4.3)
corresponds
to the residual vector. When the norm of this residual vector satisfies. x r 1 1 / x r 1 y0
2
xr =
(4.13)
( j j )r
. , if aj 0 Since in general ( j j ) / (i j ) << 10 in (4.4), as r grows greater, xr tends rapidly to juj. The system of linear equations of (4.2) are solved using (4.5) after decomposition of (T - ujI) lower triangular matrix L and upper triangular matrix U LUxr = Px r1 (4.5)
In other words, when this residual vector is considered zero vector, xr can be considered to have converged to an eigenvector. From (4.10), (4.13) becomes (4.11). In this routine, when five iterations are performed and x5 does not satisfy (4.11) ICON is set to 15000 to indicate that the eigenvector was not determined, and the elements of the corresponding column in EV is set to zero. Orthogonalization of eigenvectors The eigenvectors of a real symmetric tridiagonal matrix should be orthogonal. However, a disadvantage of the inverse iteration method is that eigenvectors corresponding to close eigenvalues may not be satisfactorily orthogonal. Therefore to insure orthogonal eigenvectors,this routine performs the following processing. When the eigenvalue ui is being determined, ui and the previously computed eigenvalue ui -l are tested to see whether they satisfy.
(P is a permutation matrix used for pivoting.) (4.5) can be solved as follows Ly r 1 = Px r1 Ux r = y r 1 (forward substitution) (backward substitution) (4.6) (4.7)
Since any vector can be used for initial vector x0. x0 may be given such that y0 of (4.8) has a form such as y0 = (1, 1, ... 1)T. y0 = L1Px 0 (4.8)
i i 1 103 T
(4.15)
Therefore, in the first iteration the forward substitution of (4.6) can be omitted, and by repeating forward substitution and backward substitution for the second and following iterations, eigenvectors can be determined. The initial vector and convergence criterion used in the inverse iteration method. In this routine, the following is used for the initial vector; 586
If (4.15) is satisfied, the approximate eigenvector xi obtained from i is made orthogonal to the eigenvector xi-l obtained from i -l so as to satisfy
(x
, x i 1 ) = 0
(4.16)
Similarly, if several consecutive eigenvalues satisfy (4.15), they are handled as a group, and their corresponding eigenvectors orthogoalized.
TEIG2
Direct sum of submatrices If T splits a sum of m submatrices T1, T2, .... Tm, the eigenvalues and corresponding eigenvectors of T are respectively, the diagonal elements of D and the column vectors of Q shown in (4.17).' D1 D2 D= 0 Q1 Q2 Q= 0 0 Dm 0 Qm
From (4.17) and (4.18) the following are obtained; D1 = Q1T T1Q1 D2 = Q2TT2Q2 . . . T Dm = Qm TmQm (4.19)
(4.17)
Thus, the eigenvalues and corresponding eigenvectors of T can be obtained by determining the eigenvalues and corresponding eigenvectors of each submatrix. For more information, see references [12] and [13] pp. 4l8-439.
587
TRAP
CALL TRAP (X, Y, N, S, ICON) Function Given unequally spaced at points x1, x2, ..., xn (x1 < x2< ...< xn) and corresponding function values yi=f(xi ), i=1, 2, ..., n, this subroutine obtains S=
xn
Notes Even when discrete points xi are equally spaced, this subroutine can be used, however, it is preferable to use Simpson's rule (subroutine SIMP1). Example Discrete points xi and function values yi are input, and the integral S is determined.
C ** EXAMPLE ** DIMENSION X (20), Y (20) READ(5,500) N READ(5,510) (X(I) ,Y(I), I=1, N) CALL TRAP (X, Y, N, S, ICON) WRITE(6,600) ICON,S STOP 500 FORMAT(I2) 510 FORMAT(2F10.0) 600 FORMAT(l0X,l5HILL CONDITION =,I5 * /10X, l6HINTEGRAL VALUE =,E15.7) END
x1
f ( x )dx
n2
using the trapezoidal rule. Parameters X ..... Input. Discrete points xi One-dimensional array of size n. Y..... Input. Function values yi One-dimensional array of size n. Input. Number of discrete points n. S..... Output. Integral S. ICON... Output. Condition code. See Table TRAP-1.
Table TRAP-1 Condition codes Code 0 30000 Meaning No error n < 2 or xi xi+1 Processing S is set to 0.0.
x f ( x )dx 2 { ( x x )( f ( x ) + f (x )) + ( x x )( f (x ) + f ( x ))++(x x )
xn
1
n1
Comments on use Subprograms used SSL II ..... MGSSL FORTRAN basic functions ... none
+( x
1 f (x n ) + f ( xn1 ) } = { ( x2 x1 ) f (x1 ) 2 + ( x 3 x1 ) f ( x 2 ) +
n
x n 2 ) f ( xn 1 ) + ( xn xn 1 ) f ( xn ) }
(4.1)
588
TRBK
CALL TRBK (EV, K, N, M, P, ICON) Function Back transformation is applied to m eigenvectors of norder real symmetric tridiagonal matrix T to form eigenvectors of real symmetric matrix A. T must have been obtained by the Householder reduction of A.1 m n. Parameters EV..... Input. m eigenvectors of real symmetric tridiagonal matrix T. EV(K,M) is a two dimensional array. Output. Eigenvectors of real symmetric matrix A. K..... Input. Adjustable dimension of array EV ( n) N.... Input. Order n of the real symmetric tridiagonal matrix. M..... Input. Number m of eigenvectors. P..... Input. Transformation matrix obtained by the Householder's reduction (See Comments on use".) P is a one-dimensional array of size n( n +1)/2. ICON... Output. Condition code. See Table TRBK-1.
Table TRBK-l Condition codes Code 0 10000 30000 Meaning No error N=1 N < |M|, K < N, or M = 0 Processing EV (1, 1) = 1.0 Bypassed
is used to obtain the eigenvalues and corresponding eigenvectors from the tridiagonal matrix, and finally this subroutine is used to back transform the resultant eigenvectors to form the eigenvectors of the real symmetric matrix. n l00.
C **EXAMPLE** DIMENSION A(5050),D(l00),SD(l00),E(100), * EV(100, 100),VW(500) 10 READ(5,500) N, M IF(N EQ. 0)STOP NN=N *(N+1)/2 READ(5,510) (A(I), 1=1, NN) WRITE(6,600) N.M NE = 0 DO 20 I=1, N NI = NE+1 NE = NE+I 20 WRITE(6,610) I, (A(J). J=NI, NE) CALL TRID1 (A, N, D, SD, ICON) IF(ICON .EQ. 30000)GOTO 10 CALL TEIG2 (D, SD, N, M, E, EV, 100, VW, ICON) WRITE(6.620) ICON IF(ICON.GE. 20000)GOTO 10 CALL TRBK (EV, 100, N, M, A, ICON) WRITE(6,620) ICON IF (ICON.NE. 0) GOTO 10 MM=IABS(M) CALL SEPRT(E, EV, 100, N, MM) GOTO 10 500 FORMAT(2I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1, 10X, 18H** ORIGINAL MATRIX * //11X,10H** ORDER =I5,10X, 6H** M =I3/) 610 FORMAT(1H0, 7X, 13, 5E20.7/(11X, 5E20.7)) 620 FORMAT(/11X, 19H** CONDITION CODE =,I5/) END
In this example, subroutine SEPRT is used to print the eigenvalues and corresponding eigenvectors of real symmetric matrices. For details see the example in section SEIG1. Method m eigenvectors of n-order real symmetric tridiagonal matrix T are back transformed to obtain the eigenvectors of real symmetrical matrix A. The reduction of A to T is performed using the Householder method which performs n-2 orthogonal similarity transformations shown in (4.1). T = PnT2
Comments on use Subprograms used SSL II... MGSSL FORTRAN basic functions... IABS Notes This subroutine is called usually after subroutine TDIDI. Parameter A provided by TRID1 can be used as input parameter P of this subroutine. For detailed information about array P refer to subroutine TRID1. The eigenvectors are normalized when ||x||2 =1, and if parameter M is negative, the absolute value is used. Example TRID1 is first used to reduce an n-order real symmetric matrix to a tridiagonal matrix, then TEIG2
P P
T 2
T 1
AP1 P2
P
n 2
(4.1)
For more details, refer to "Method" for subroutine TRID1. Let the eigenvalues and corresponding eigenvectors of T be and y respectively, then Ty = y If (4.1) is substituted in (4,2), then (4.2)
589
TRBK
PnT 2
P P
T 2
T 1
AP1 P2
P
n 2
y = y
(4.3)
1(where
P
n 2
y = P1 P2
P
n 2
(4.4)
,2,1
(4.6)
P
n 2
(4.5)
Since the eigenvectors x are obtained from (4.5), ||x||2=1. For further information reference [13] pp. 212-226.
590
TRBKH
CALL TRBKH (EVR, EVI, K, N, M, P, PV, ICON) Functions m number of eigenvectors y of n order real symmetric tridiagonal matrix T is back transformed to the eigenvectors x of Hermitian matrix A. x = PV * y where P and V are transformati0n matrices when transformed from A to T by the Householder's reduction and diagonal unitary transformation, respectively, and l m n. Parameters EVR... Input. m eigenvectors y of n order real symmetric tridiagonal matrix T. Output. Real part of eigenvector x of n order Hermitian matrix A. Two dimensional array, EVR (K, M) (See "Comments on use"). EVI..... Output. Imaginary part of eigenvector x of n order Hermitian matrix A. Two dimensional array, EVI (K,M) (See "Comments on use"). K..... Input. Adjustable dimension of arrays EVR and EVI. ( n) N..... Input. Order n of the real symmetric tridiagonal matrix. M.... Input. The number P of eigenvectors. (See "Comments on use"). P..... Input. Transformation vector T obtained by the Householder's reduction from A to T. In the compressed storage mode for an Hermitian matrix. Two dimensional array, P (K, N). (See "Comments on use"). PV... Input. Transformation matrix V obtained by diagonal unitary transformation from A to T. One dimensional array of size 2 n. (See "Comments on use"). ICON.... Output. Condition code. See Table TRBKH-1.
Table TRBKH-l Condition code Code 0 10000 30000 Meaning No error N=1 N < |M|, K < N or M = 0 Processing EV(1, 1) = 1.0 Bypassed
Comments on use subprograms used SSL II ... MGSSL FORTRAN basic functions.... IABS Notes This subroutine is for an Hermitian matrix and not to be applied to a general complex matrix. Note that array P does not directly represent transformation matrix P for reduction of A to T. This subroutine, TRBKH, is normally used together with subroutine TRIDH. Consequently the contents of A and PV output by subroutine TRIDH can be used as the contents of parameters P and PV in this subroutine. The contents of array P and PV are explained on "Method" for subroutine TRIDH. If input eigenvector y is normalized such as ||y||2 = 1, then output eigenvector x is normalized as ||x||2 = 1. The l-th element of the eigenvector that corresponds to the j-th eigenvalue is represented by EVR (L, J) + iNEVI (L, J), where i= 1 When parameter M is negative, its absolute value is taken and used. Example An n order Hermitian matrix is reduced to a real symmetric tridiagonal matrix using subroutine TRIDH, and m number of eigenvalues and eigenvectors are obtained using TEIG2. Lastly by this subroutine, TRBKH, the eigenvectors of the real symmetric tridiagonal matrix are back transformed to the eigenvectors of the Hermitian matrix. n 100.
C **EXAMPLE** DIMENSION A(100,100),D(100),SD(100),V(200), * EVR(100,100),EVI(100,l00),VW(500),E(100) 10 CONTINUE READ(5,500) N,M IF(N. EQ. 0) STOP READ(5,510)((A(I,J) I=1, N),J=1,N) WRITE(6,600) N, M DO 20 I=1,N 20 WRITE(6,610) (I,J, A(I,J),J=1,N) CALL TRIDH (A,100,N,D,SD,V,ICON) WRITE(6,620) ICON IF(ICON. EQ. 30000) GO TO 10 CALL TEIG2(D,SD,N,M,E,EVR,100,VW,ICON) WRITE(6,620) ICON IF(ICON GE. 20000) GO TO 10 CALL TRBKH(EVR,EVI,100,N,M,A,V,ICON) WRITE(6,620) ICON IF(ICON. NE. 0) GO TO 10 MM=IABS(M) CALL HEPRT(E,EVR,EVI,100,N,MM) GO TO 10 500 FORMAT(2I5) 510 FORMAT(4E15.7) 600 FORMAT(1H1///40X,19H** ORIGINAL MATRIX **,
591
TRBKH
* 5X, 2HN=, I3, 5X, 2HM=, 13//) 610 FORMAT(/4(5X 2HA(,I3,1H,,I3,2H)=,E14.7)) 620 FORMAT(1H0, 20X, 5HICON=, I5) END
P P AP P P
* 2 * 1 1 2 n 2
n 2
Vy = y
(4.3)
Subroutine HEPRT in this example is used to print eigenvalue and eigenvectors of an Hermitian matrix. For its details, refer to the example for subroutine HEIG2. Method The m number of eigenvectors of n order real symmetric tridiagonal matrix T are back transformed to the eigenvectors of Hermitian matrix A. Reduction of A to T is done by the Householder method and diagonal unitary transformation as shown in the eq. (4.1). T = V * (Pn*2
P
Vy = P1 P2
P
n 2
Vy
(4.4)
P
n 2
Vy
(4.5)
P P AP P P
* 2 * 1 1 2
n 2
)V
The calculation of eq. (4.5) is carried out in the sequence shown in eqs. (4.6) and (4.7)
z = Vy
(4.1)
(4.6)
* k k +1
where P = I - uk uk /hk is a diagonal unitary matrix. For detailed information, refer to subroutine TRIDH. Letting and y be eigenvalue and eigenvector respectively of T, then eq. (4.2) is established. Ty = y (4.2)
z k = zk +1 uk u z /hk k = n 2 , ,2 ,1
(4.7)
where z= zn-1 and x=z1. Thus obtained eigenvector x (= z1) is normalized as ||x||2 = 1 if ||y||2 = 1 in eq. (4.5). Refer to subroutine TRIDH for the Householder method and diagonal unitary transformation. For details, see Reference [17].
592
TRIDH
( 3) ) Re(a 32
Im( a 31 ) Im( a 32 ) (1 + 3 / 3 )
1 2 (2)
( 3)
Im( a 41 )
(2)
Im( a51 )
(1)
(2)
Im( a52 )
(1)
CALL TRIDH (A, K, N, D, SD, PV, ICON) Function An n-order Hermitian matrix A is reduced first to an Hermitian tridiagonal matrix H, H = P * AP (1.1)
(1 + 3 / 3 )
(2)
h3
Re(a41 )
(2)
Re( a 42 )
(2)
Im( a54 ) (1 + 1 / 1 )
1
(1)
Re(a51 )
( 1)
Re( a52 )
(1)
h1 2
by the Householder method, then it is further reduced to a real symmetric tridiagonal matrix T by diagonal unitary transformation. T = V * HV (1.2)
Note:
The symbol X indicates a work area. This is for n=5 Refer to eq. (4.11) or (4.13) to hk.
where P and V are transformation matrices, and n1. Parameters A..... Input. Hermitian matrix A. Output. Transformation matrix P. (Refer to Fig. TRIDH-1). In the compressed storage mode for Hermitian matrices. (See "Comments on use"). Two dimensional arrays of size A (K, N). K..... Input. Adjustable dimension of the array A ( n) N..... Input. Order n of the Hermitian matrix. D..... Output. Main diagonal elements of real symmetric tridiagonal matrix T. (See Fig. TRIDH-2). One dimensional array of size n. SD.... Output. Subdiagonal elements of real symmetric tridiagonal matrix T. (Refer to Fig. TRIDH-2). One dimensional array of size n. The outputs are stored into SD (2) to SD (N) and SD (1) is set to zero. PV..... Output. Transformation vector V (Refer to Fig. TRIDH-3). One dimensional array of size 2 n. ICON.. Output. Condition code. See Table TRIDH1.
0 | h23 | h33
0 | hn1n |
0 3 h33
| hnn1 |
Array SD
| h21 |
| h32 |
| hn1n2 | | hnn1 |
Fig. TRIDH-2 Correspondence between real symmetric tridiagonal matrix T and arrays D and SD
v1 0
0 v2
0 0 1 2 3 4 0
0 vn 2n1 2n
Re(vn) Im(vn)
593
TRIDH
Comments on use Subprograms used SSL 11 ... AMACH, BSUM, and MGSSL FORTRAN basic functions... ABS and SQRT Notes This subroutine is used for an Hermitian matrix, and not for a general complex matrix. Output arrays A and PV will be needed to obtain eigenvectors of the Hermitian matrix A. These A and PV correspond respectively to P and PV in subroutine TRBKH which is used to obtain eigenvectors of the Hermitian matrix. The accuracy of the eigenvalues is determined when tridiagonalization is made. Consequently the tridiagonal matrix must be obtained as accurately as possible, and this subroutine takes this into account. However, when there are both very large and small eigenvalues, the smaller eigenvalues tend to be more affected by the transformation compared to the larger ones. Therefore, in this situation, it may be difficult to obtain the small eigenvalues with good accuracy. Example An n-order Hermitian matrix is reduced to a real symmetric tridiagonal matrix, then by subroutine TRQL, its eigenvalues are computed for n 100.
C **EXAMPLE** DIMENSION A(100,100), D(100), SD(100), * V(200) E(100) 10 CONTINUE READ(5,500) N, M IF (N. EQ. 0) STOP READ(5,510) ((A(I,J),I=1,N),J=1.N) WRITE(6,600) N, M DO 20 I=1, N 20 WRITE(6,610) (I,J,A(I,J),J=1,N) CALL TRIDH(A,100,N,D,SD,V,ICON) WRITE(6, 620) WRITE(6,630) ICON IF(ICON. EQ. 30000) GO TO 10 WRITE(6,640) WRITE(6,650) (I, D(I), SD(1), I=1, N) CALL TRQL(D, SD, N, E, M, ICON) WRITE(6,630) ICON IF(ICON. GE. 20000) GO TO 10 WRITE(6,660) WRITE(6,670) (I, E(I), I=1, M) GO TO 10 500 FORMAT(2I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1///, 40X, 19H**ORIGINAL MATRIX** * 5X, 2HN=,I3,5X,2HM=,I3//) 610 FORMAT(4(5X,2HA(,I3,1H,,I3,2H)=,E14.7)) 620 FORMAT(1H0//,11x,22H **TRIDIAGONAL MATRIX * 630 FORMAT(1H0, 20X, 5HICON=,I5) 640 FORMAT(1H0, //1X, 3(3HNO., 5X, 8HDIAGONAL, 7X, * 11HSUBDIAGONAL, 2X), //) 650 FORMAT(1X, 3(I3, 2E17.7))
660 FORMAT(1H1///, 5X, 15H**EIGENVALUES**/) 670 FORMAT(1X, 4(2HE(, I3, 2H)=, E17.7)) END
Method The reduction of an n-order Hermitian matrix A to a real symmetric tridiagonal matrix T is done in two steps shown in eqs. (4.1) and (4.2). The n-order Hermitian matrix A is reduced to an norder Hermitian tridiagonal matrix H by the Householder method. This is performed through n-2 iteration of the unitary similarity transformation. Ak +1 = Pk* Ak Pk where A1 = A k = 1,2 ,
,n 2
(4.1)
This is the same equation as that of the orthogonal similarity transformation for a real symmetric matrix except that PRT is replaced by Pk (Refer to TRID1 for the Householder method of real symmetric matrix). The resultant matrix An-1 in those transformations becomes an Hermitian tridiagonal matrix H. The Hermitian tridiagonal matrix H obtained in eq. (4.1) is further reduced to an n-order real symmetric tridiagonal matrix T by the diagonal unitary similarity transformation (4.2). T = V * HV V =diag(vj) Let H = (hij) and v1 = 1 where H = An1 (4.2) (4.3)
v j = hjj 1v j 1 / hjj 1 , j = 2 ,
,n
(4.4)
Then from transformation (4.2), each element tij of T is given as a real number as follows: t jj = v *j hjj v j = h t jj1 = v h jj1 v j1 = h *jj1 v *j1 / h jj1 h jj1 v j1 = h jj1 (4.5)
* j
(4.6)
That is, if the absolute value of hjj-1 is taken in the course of obtaining subdiagonal elements of H, it will directly become subdiagonal element of T. After above two transformations, takes the form shown in Fig. TRDH-2. Now, the transformation process for the eqs. (4.1) and (4.2) is explained. The k-th step transformation, for Ak = ( ai( k ) ), is represented by
k = a l1
(k ) 2 + a(k ) 2 + + a(k ) 2 l2 ll 1
(4.7)
594
TRIDH
where, l = n k + 1
2 t ll 1 = k 1
(4.8)
To avoid possible underflows and/or overflows in the computations shown in eqs. (4.7) to (4.14), each element on the right hand side of eq. (4.7) is scaled by
l 1
Here, if a ll 1 0
(k)
a Re lj
j =1
(k ) + Im a( k ) lj
(4.17)
k = a (llk)1 k
2
u = al1 ,
* k
( k )*
hk = k + k
, a
1 2
(4.9) , a ll 1 (1 + k / k ),0,
( k )*
( k )*
ll 2
,0)
(4.10) (4.11)
Instead of using the transformation (4.15) after obtaining Pk Ak+1 is obtained as follows: pk = Ak uk / hk , K k = u* pk / 2hk k qk = pk K k uk
* = Ak uk q k q k u* k
(k)
(4.18) (4.19)
* * Ak +1 = ( I uk uk / hk ) Ak ( I uk uk / hk )
(4.20)
,a
ll 2
( k )*
k2 ,0,
,0
(4.12) (4.13)
Transformation matrices Pk and V are needed when obtaining eigenvectors of the Hermitian matrix. For that reason, uk in eq. (4.10) or (4.12) and square root of hk in eq. (4.11) or (4.13) are stored in the form in Fig. TRIDH-1. Diagonal elements vj of diagonal unitary matrix V are stored into one-dimensional array PV as shown in Fig. TRIDH-3. When input parameter N is 1, the diagonal elements of A are directly put into array D. For details, see References [13] pp.212-226 and [17].
(k t ll = a ll
1)
(k ) (k ) ,a ll 2 of the Hermitian By eq.(4.15), elements a l1 , matrix A are eliminated. In the actual transformation, the following considerations are taken.
595
TRID1
smaller eigenvalues tend to be affected more by the reduction process. In some case, it is very difficult to obtain small eigenvalues precisely. Example After an n-order real symmetric matrix is reduced to a tridiagonal matrix, subroutine TRQL is used to compute the eigenvalues. n 100.
C **EXAMPLE** DIMENSION A(5050), D(100), SD(100), E(100) 10 READ( 5, 500) N IF (N. EQ. 0) STOP NN=N*(N+1) /2 READ(5, 510) (A)(I), I=1, NN) WRITE(6, 600) N NE=0 DO 20 I=1, N NI=NE+1 NE=NE+I 20 WRITE(6, 610) I, (A(J), J=NI. NE) CALL TRID1 (A, N, D, SD, ICON) WRITE(6, 620) WRITE(6, 630) ICON IF (ICON. EQ. 30000) GO TO 10 WRITE(6, 640) (I, D(I), SD(I), I=1, N) CALL TRQL(D, SD, N, E, M, ICON) WRITE(6, 650) WRITE(6, 630) ICON IF (ICON. EQ 20000) GO TO 10 WRITE (6, 660) (I, E(I), I=1, M) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT (1H1,10X,18H** ORIGINAL MATRIX/ * 11X, 10H** ORDER =, I5) 610 FORMAT (1H0, 7X, I3, 5E20.7/(11X, 5E20.7)) 620 FORMAT (1H0/11X, 21H** TRIDIAGONAL MATRIX) 630 FORMAT (11X,19H** CONDITION CODE =, I5/) 640 FORMAT (5X, I5, 2E16.7) 650 FORMAT (1H0/11X, 14H** EIGENVALUES) 660 FORMAT(5X, 2HE(, I3,2H)=, E15.7) END
CALL TRID1 (A, N, D, SD, ICON) Function An n-order real symmetric matrix A is reduced to a real symmetric tridiagonal matrix T using the Householder method (orthogonal similarity transformation). T = P T AP where P is the transformation matrix. n 1. Parameters A..... Input. Real symmetric matrix A. Output. Transformation matrix P. Compressed storage mode for symmetric matrix. A is a one-dimensional array of size n(n+1)/2. N..... Input. Order n of real symmetric matrix A. D..... Output. Diagonal elements of tridiagonal matrix T. D is a one-dimensional array of size n. SD..... Output. Subdiagonal elements of tridiagonal matrix T. SD is a one-dimensional array of size n. SD(2) - SD(N) is used; SD (1) is set to 0. ICON .. Output. Condition code. See Table TRID1-1.
Table TRID1-1 Condition codes Code 0 10000 30000 Meaning No error N=1 or N=2 N<1 Processing Reduction is not performed. Bypassed
(1.1)
Comments on use Subprograms used SSL II ... AMACH, and MGSSL FORTRAN basic functions ... ABS, DSQRT, and SIGN Notes Array A that is output is needed for determining the eigenvectors of real symmetric matrix A. The precision of eigenvalues is determined in the tridiagonal matrix reduction process. For that reason this subroutine has been implemented to calculate tridiagonal matrices with as high a degree of precision as possible. However, when very large and very small eigenvalues exist, the
Method Reduction of an n-order real symmetric matrix A to a tridiagonal matrix is performed through n 2 iterations of the orthogonal similarity transformation Ak +1 = PkT Ak Pk , k = 1,2,
, n 2
(4.1)
where A1 = A, Pk is an orthogonal transformation matrix. The resultant matrix An-1 in above transformations becomes a real symmetric tridiagonal matrix. The k th transformation is performed according to the
( following procedure. Let Ak = aij
( )
k)
596
TRID1
k k = al(1 )
( ) + (a ) ++(a )
2
(k) l2
(k ) ll 1
(4.2)
Ak + 1 = ( I u k u kT / hk ) Ak ( I u k u kT / hk ) = Ak u k q kT q k u kT (4.9)
Where l = n k + 1
k) (k ) ,a (k ) 1 T = 2 a( uk , ,a k ,0, ,0 l ll 2 ll 1 1
T k
) 2 h k = k a( ll 1 k
k
1
Pk = I uk u / hk
Transformation matrix Pk is required to determine the eigenvectors of the real symmetric matrix A, so the elements of uk of (4.3) and hk of (4.4) are stored as shown in Fig. TRID1-l.
( 3) a31
( ) of Ak By applying in Pk in (4.5) to (4.l), al(1k ) to a ll 2 can be eliminated. The following considerations are applied during the actual .transformation. To avoid possible underflow and overflow in the computations of (4.2) to (4.4), the elements on the (k) . right side are scaled by a ij
j =1 l 1
( 3) a32 32 1
h3
( 2) a43 22 ( 1) a53 1
(2) a41
(2) a42
h2
(1 ) a54 12 1
(1 ) a51
(1) a52
h1
(Note): X represents work area, n=5 Fig. TRID1-1 Array A after Householder's reduction (A is in the compressed storage mode)
the sign of
1 2 k
is
taken to that of a a k 1
(k )
. 1k
(4.7) (4.8)
When n= 2 or n=1 the diagonal elements and the subdiagonal elements are entered as is in arrays D and SD. For further information see Reference [13] pp.212226.
597
TRQL
CALL TRQL (D, SD, N, E, M, ICON) Function All eigenvalues of an n-order real symmetric tridiagonal matrix T are determined using the QL method. n 1 Parameters D..... Input. Diagonal elements of tridiagonal matrix T. D is a one-dimensional array of size n. The contents of D are altered on output. SD.... Input. Subdiagonal elements of tridiagonal matrix T. The elements must be be stored in SD(2) to SD (N). The contents of SD are altered on output. N.. Input. Order n of tridiagonal matrix. E..... Output. Eigenvalues E is a one-dimensional array of size n. M..... Output. Number of eigenvalues that were obtained. ICON.. Output. Condition code. See Table TRQL-1.
Table TRQL-1 Condition codes Code 0 10000 15000 Meaning No error N=1 Some of the eigenvalues could not be determined. Processing E(1)=D(1) M is set to the number of eigenvalues that were determined. 1 M < n. M=0 Bypassed
eigenvalues of a tridiagonal matrix, it is faster to use subroutine BSCT1. When eigenvectors of a tridiagonal matrix are also to be determined, TEIG 1 should be used. Example An n-order real symmetric matrix is reduced to a tridiagonal matrix using subroutine TRID1, then this routine is used to obtain the eigenvalues. n100.
C **EXAMPLE** DIMENSION A(5050), D(l00), SD(100), E(100) 10 CONTINUE READ(5, 500) N IF(N. EQ. 0) STOP NN=N* (N+1)/2 READ(5, 510) (A(I), I=1, NN) WRITE(6, 600) N LST=0 DO 20 I=1, N INT=LST+1 LST=LST+I WRITE(6, 610) I,(A(J), J=INT, LST) 20 CONTINUE CALL TRID1 (A, N, D, SD, ICON) WRITE(6, 620) ICON IF(ICON. NE. 0) GO TO 10 CALL TRQL(D, SD, N, E, M, ICON) WRITE(6, 620) ICON IF(ICON GE. 20000) GO TO 10 WRITE(6, 630) (I, E(I), I=1. M) GO TO 10 500 FORMAT(I5) 510 FORMAT(5E15.7) 600 FORMAT(1H1,5X,15HORIGINAL MATRIX,10X, * 2HN=,I3) 610 FORMAT(1H0,7X,I3,5E20.7/(11X,5E20.7)) 620 FORMAT(1H0, 20X, 5HICON=, I5) 630 FORMAT(1H0,5X,10HEIGENVALUE//(8X,4(2HE(, * I3, 2H)=, E15.7, 3X))) END
20000 30000
Comments on use Subprograms used SSL II ... AMACH and MGSSL FORTRAN basic functions ... ABS, SQRT, and SIGN Notes Parameter M is set to n when ICON =0 or to the number of eigenvalues that were obtained when ICON = 15000. This routine uses the QL method which is best suited for tridiagonal matrices in which the magnitude of the element is graded increasingly. This routine is used for tridiagonal matrices. When determining eigenvalues of a real symmetric matrix, first reduce that matrix to a tridiagonal matrix using subroutine TRID1, and then call this routine. When determining approximately n/4 or less
Method All eigenvalues of n-order real symmetric tridiagonal matrix T are determined using the QL method. Before explaining the QL method, the representation of the tridiagonal matrix and its eigenvalues will be defined. The tridiagonal matrix is represented as T and its eigenvalues as (1, 2, ..., n). All eigenvalues are assumed to be different. The diagonal elements of tridiagonal matrix T are represented as d1, d2,..., dn and the subdiagonal elements as e1, e2, ..., en.That is.
598
TRQL
d1 e1
e1 d 2 e2 e2
0
(4.1)
T=
en1 en1 dn
By successively calculating (4.8) from the inside to outside (4.4) and (4.5) can be executed in parallel. Normally, in order to improve the rate of convergence in the QL method. (Ts kI) origin-shifted by an appropriate constant k is used instead of Ts. Thus (4.4) becomes
(T (T
kI ) = Q s L s
(4.9)
To determine eigenvalues, the QL method uses the following three theorems. If a tridiagonal matrix T is a real symmetric matrix, such an orthogonal matrix X that satisfies (4.2) exists. D = X T TX (4.2)
kI ) = QsT (Ts kI )Q s
(4.10)
Since (4.10) can also be written as Ts +1 = QsT (Ts kI )Qs + kI then, Ts +1 = QsT Ts Qs (4.12) (4.11)
where D is a diagonal matrix and diagonal elements of D are all eigenvalues of T. If T is non-singular, it can be, uniquely decomposed into an orthogonal matrix Q and a lower triangular matrix L whose diagonal elements are all positive, T = QL (4.3)
Note that this Qs differs from the Qs of (4.5). That is, based on (4.9) if Qs is calculated as QsT (Ts kI ) = Ls (4.13)
Let real symmetric tridiagonal matrix T be T1, and the matrix obtained after the s-th iteration be Ts +1 The following iterative calculation can be done: Ts = Q s L s
T s
s = 1,2,3,
Ts +1 = Q Ts Qs
(4.4) (4.5)
Ts+1 can be obtained from (4.12). The origin shift k is determined as follows: Let an eigenvalue obtained on di in (4.1) be i and rate of the convergence of i , depends on the ratio:
i k / i +1 k
(4.14)
From the orthogonal similarity transformation of (4.5), Ts+1 becomes a real symmetric tridiagonal matrix. Furthermore, the Ts+1 is determined only the n-th column of Qs and when S , Ts+1 converges to a diagonal matrix. By using the above three theorems, the QL method determines all eigenvalues. However, in the actual calculations of the QL method, (4.4) and (4.5) are calculated in parallel instead of first obtaining Qs in (4.4) and then determining Ts+1 of (4.5). Since from (4.4) QsTTs = Ls (4.6)
k is determined by obtaining the eigenvalues of 2 2 submatrix Bs showing (4.15) using the Jacobian method, s and using the one obtained on d i( ) . (s) e (s) i i Bs = d( s) (s) d e i i +1
s
(4.15)
Ts is transformed into a lower triangular matrix Ls s T when premultiplied by QsT. Therefore, if Pi ( ) T is the transformation matrix which eliminates the i th element of the (i+l)th column of Ts, QsT can be represented as QsT = P1( ) P2( )
s T s T
P P
n1
n 1
( s )T
(4.7)
By this way, ei( ) converges to 0 rapidly. If k is recalculated for each iteration of (4.12), the rate of convergence is further improved. Therefore, if (4.12) is calculated after recalculating k at every times, the accelerating of convergence can be performed. The ks is k calculated for the s-th iteration. (4.12) is actually calculated in the form shown in (4.8), so the calculation s T s T of Pi ( ) (i = n-1, ..., 2, 1) is described next. Since Pi ( ) makes elements (n- 1, n) of (Ts - ksI) zero when postmultiplied by (Ts - ksI), Pn-1 can be thought of as the following matrix:
( s )T
Ts Pn(1)
s
P
(s)
P1(
s)
(4.8)
599
TRQL
Pn(1)
s T
1 = 0
s s s f = d i(+1) d i( ) / 2ei( )
k s = d i( s ) ei( s ) / f
f 2 +1
(4.24)
where,
2 Cn 1 = (d n k s )/ (d n k s ) + en 1 2
Sn 1 = en 1 / (dn k s ) + en21
2 s T
1 2
1 2
If above Pn(1) is used in the calculation of ~ s T k Ts = Pn(1) Ts Pn(1) ~ Ts will have the following form: (4.16)
(Signs of Lf2 +1 and f are made equal) ~ ~ 2) Cn-1 and Sn-1 are determined Ts is obtained. Then Ts is calculated from (4.16). ~ Ts is reduced to a tridiagonal matrix by Givens 3) method. 4) Steps 1) to 3) are repeated as s = s + 1 until one of the following conditions is satisfied. (a) e j u d j + d j+1 (b)
) ( j = i ,i + 1, , n 1)
(4.20)
~ Ts =
** *** *** 0
In this form, element (n 2, n) and element n ,n 2) are appended to a tridiagonal matrix. Since above Ts is a symmetric matrix, it can be reduced to a tridiagonal matrix using the Givens method. Let the transformation matrices used in the Givens method for reduction of Ts to a tridiagonal matrix be ~ ~ s) Qs = Pn( 2 ~ P
( s)
2
where u is the unit round-off. s 30 where S is number of iterations. 5) When condition (a) is satisfied with j = i, this means that eigenvalue i is determined. When n-1 is determined, then n is determined automatically. 6) When condition (b) is satisfied, i is considered to be undertermined and ICON is set to 15000. The process is terminated. The following considerations have been made in order to diminish the execution time of this subroutine. 1) If matrix T is a direct sum of submatrixes. steps 1) to 6) above are applied to each submatrix in order to reduce operations. When condition (4.20) is satisfied with j i, matrix T is split into submatrices. 2) The above steps 2) to 3) are put together as (4.18) and are calculated as shown in (4.21). g j = C j +1d j +1 S j +1e j +1 1 (s)2 2 + wj = g2 e j j C j = g j /w j , S j = e (j s) 2 /w j , x j = 2C j S j e (j s ) s +1) s) = C2 + S2 d (j + d j(+ d j( s ) + x j j j 1 1 ( s+1) (s) 2 ( s) e j = C j S jd j S j e j ( j = n 1, n 2 , , i + 1, i ) ( s+1) ( s +1) di = d i+1 2 xi
( s) (s) ( s) = 0.0, Cn = 10 en . , Sn = 10 .
~s P1( )
(4.17)
and with respect to the Ts to Ts+1 reduction, we obtain ~ ~~ Ts + 1 = QsT TsQs (4.18)
Therefore, from (4.19), (4.21) and (4.22), Ts+1 can be calculated as ~sT ~sT Ts + 1 = P1( ) P2( ) ~ P (P ~ ~ P P
n 2
(4.21)
( s )T
n1
( s )T
~ s) s) Ts Pn( 1 Pn( 2
)
(4.19)
(s )
(s)
The computation process for this routine is shown next. Steps 1) to 6) are performed for i=1, 2, ..., n1. 1) Shift Ks of origin is calculated according to:
For further information see references [12], [13] pp. 227-248 and [16] pp.177-206.
600
TSDM
Table TSDM-1 Condition code Code 1 Meaning Processing The obtained approximate root Normal end satisfied the convergence criteria I. (See parameter ISW.) The obtained approximate root Normal end satisfied the convergence criteria II. (See parameter ISW.) Normal end Iterations were tried unconditionally m times. (M= m) Normal end Although m iterations were specified (M=m), before finishing all iterations, f(xj) = 0.0 was satisfied, thereby the iteration was stopped and xj was set as the root. Although m iterations were Normal end specified (M=m), before finishing all iterations, |xi-xi-1| uN|xi| was satisfied, thereby the iteration was stopped and xj was set as the root. The specified convergence The last iteration is criterion was not satisfied within value Xi stored in the limit of iterations given. X. Terminated A difficulty occurred during computation. so Muller's method could not be continued. See. (4) Method. Bypassed The input parameter had error(s). when M>0, either of the followings was found: 1 ISW=1 and EPS < 0, or 2 ISW=2 and ETA<0, or 3 ISW=3, EPS<0 and ETA<0, or in other case, M=0 or ISW 1, 2, 3 was found.
CALL TSDM(X, FUN, ISW, EPS, ETA, M, ICON) Function This subroutine finds a zero of a real function f(x) =0 An initial approximation to the zero must be given. Parameters X..... Input. Initial value of the root to be obtained. Output. Approximate root. FUN ... Input. Function subprogram name which computes the function f(x). ISW... Input. Control information. One of the convergence criteria for the root obtained is specified. ISW must be either one of 1, 2, or 3. When ISW = 1, x1 becomes the root if it satisfies the condition f ( x i ) EPS: Convergence criteria I When ISW = 2, xj becomes the root if it satisfies the condition x i x i1 ETA x i : Convergence criteria II When ISW = 3, xi becomes the root if either of the criteria described above are satisfied. See "Comments on use". EPS ... Input. The tolerance ( 0.0) used in the convergence criteria II. (See the parameter ISW.) ETA.. Input. The tolerance ( 0.0) used in the convergence criteria II. (See the parameter ISW.) M ..... Input. Upper limit of number of iterations to obtain the solution. See "Comments on use". Output. Number of iterations actually tried. ICON.. Output. Condition code. See Table TSDM-1. Comments on use Subprograms used (a) SSL II..... MGSSL, AMACH, AFMAX and AFMIN (b) FORTRAN basic functions .. ABS, EXP, SQRT and ALOG Notes The function subprogram specified by the parameter FUN mut be defined as having only one argument for the variable x, and the program which calls this TSDM subroutine must have
10
11
12
10000
20000
30000
EXTERNAL statement for that function subprogram. (See the example below.) This subroutine, even if ISW = 1 is given, stops the iteration with ICON = 2 whenever
x i x i 1 u. x i
is satisfied., and also stops the iteration with ICON = 1 whenever f(xi ) = 0.0 is satisfied even if ISW = 2 is given. Iterations are repeated m times unconditionally, when M is set as M = m (m > 0). However, if f(xi )= 0.0 or xi xi 1 u. xi is satisfied before finishing m iterations, the iteration is stopped and the result is put out with ICON = 11 or ICON = 12.
601
TSDM
= f [ xi , xi 1 ] + ( x i xi 1 ) f [ x i , x i 1 , xi 2 ]
4 f i f [ xi , xi 1 , xi 2 ]
2
2 fi
12
(4.3)
Of these two roots for P (x) = 0, the root corresponding to the larger absolute value of the denominator in the second term of Eq. (4.3) is chosen as the next iteration value xi +1. This means that xi +1 is a root closer to xi . In Eq. (4.1), if the term of x2 is null, i.e., if f [ x i , xi 1 , xi 2 ] = 0, the following equation is used in place of using Eq. (4.3): x = xi = xi fi f [ xi , xi 1 ] xi xi 1 fi f i f i 1 (4.4)
Method The subroutine uses Muller's method. This uses an interpolating polynomial P (x) of degree two, by using three approximate values for a root and approximates f(x) near the root to be obtained. One of the roots for P(x) = 0 is taken as the next approximate root of f(x). In this way iteration is continued. This algorithm has the following features: a. Derivatives of f(x) are not required b. The function is evaluated only once at each iteration c. The order of convergence is 1.84 (for a single root). Muller's method Let be a root of f(x) and let three values xi -2,xi -1 and xi be approximations to the root (See later explanation for initial values x1 , x2 and x3). According to Newtons interpolation formula of degree two, f(x) is approximated by using the three values described above as follows:
P( x) = f i + f [xi , xi 1 ]( x xi ) + f [xi , xi 1 , xi 2 ](x xi )(x xi 1 )
This is the secant method. In Eq. (4.1) also, if both terms x and x2 are null, P(x) reduces to a constant and the algorithm fails. (See later explanation.) Considerations of Algorithm Initial values x1, x2 and x3 The three initial values are set as follows: Let x be an initial value set by the user in the input parameter X. When x 0 x1= 0.9x x2 = l.lx x3 = x When x= 0, x1 = -1.0 x2 = 1.0 x3 = 0.0 When f(xi -2) = f(xi -1) = f(x) This corresponds to the case in which both terms x and x2 in Eq. (4.1) are null, so Muller's method cannot be continued. The subroutine changes xi -2, xi -1, and xi and tries to get out of this situation by setting xi-2= (1+pn)xi -2 xi-1= (1+pn)xi -1 xi= (1+pn)xi where p=u-1/10, u is the unit round off and n is the count of changes. Muller's method is continued by using x'i -2, x'i -1, and x'i When more than five changes are performed the subroutine terminate unsuccessfully with ICON = 20000.
(4.1)
where fi = f(xi ), and f [xi , xi1 ] and f [xi , xi1 , xi2 ] are the first and the second order divided differences of f(x), respectively, and are defined as follows:
f [x i , x i 1 ] = f i f i 1 x i x i 1
f [x i , x i 1 , x i 2 ] =
f [x i , x i 1 ] f [ x i 1 , x i 2 ] x i x i 2
(4.2)
602
TSDM
Convergence criteria The following two criteria are used. Criteria I. When the approximate root xi satisfies f(xi ) EPS, the xi is taken as the root. Criteria II. When the approximate root xi satisfies |xi xi -1| ETAN|xi |
the xi is taken as the root. When the root is a multiple root or very close to another root, ETA must be set sufficiently large. If 0 ETA < u, the subroutine resets ETA = u. For further details, see Reference [32].
603
TSD1
y f(x)
a x b
Function Given two points a, b such that f(a) f(b) 0, a zero in [a, b] of the real transcendental equation f(x)=0 is obtained. The derivatives of f( x) are not required when determining the zero. The bisection method, linear interpolation method, and inverse quadratic interpolation method are used depending on the behavior of f( x) during the calculations. Parameters AI... Input. Lower limit a of the interval. BI..... Input. Upper limit b of the interval. FUN.... Input. The name of the function subprogram which calculates f( x) . In the program which calls this subroutine, the user must declare EXTERNAL and prepare the function subprogram. EPST... Input. The tolerance of absolute error ( 0.0) of the approximated root to be determined (See the notes) X..... Output. The approximated zero ICON... Output. Condition code. See Table TSDI-1.
Table TSD1-l Condition codes Code 0 30000 Meaning No error f(a) f(b) > 0 or EPST < 0.0 Processing Bypassed
Fig. TSD1-1
The required accuracy of the root being determined is defined by parameter EPST. If the interval [a, b] does not include the origin, EPST=0.0 can be specified, and the subroutine will calculate as precise root as possible. Example One root of f(x) = sin2(x) 0.5 = 0 is calculated in the interval [0.0,1.5]. Notice that f(x) has different signs at both ends of the interval, and only one root exists in this interval.
C **EXAMPLE** EXTERNAL FSIN AI=0.0 BI=1.5 EPST=1.0E-6 CALL TSD1 (AI,BI,FSIN,EPST,X,ICON) WRITE(6,600) X,ICON STOP 600 FORMAT(10X,E15.7.5X,I10) END FUNCTION FSIN(X) FSIN=SIN(X) **2-0.5 RETURN END
Comments on use Subprograms used SSL II ... AMACH and MGSSL FORTRAN basic functions... ABS Notes FUN must be declared as EXTERNAL in the program from which this subroutine is called. If there are several zeros in the interval [a, b] as shown in Fig. TSD-l, it is uncertain which zero will be obtained.
Method With some modifications, this subroutine uses what is widely known as the Dekker algorithm. The iteration formula to be used at each iteration (bisection method, linear interpolation method, inverse quadrantic interpolation method) are determined by examining the behavior of f(x) . f(x) is a real function that is continuous in the interval [a, b], and f (a )f (b ) < 0 . At the beginning of the algorithm, c is taken as a ; the general procedures used thereafter are as follows. Procedure 1 If f(b) f(c) > 0, c is assumed to be the same as a. If f(b)f(c)<0 and |f(b)| > |f(c)|, b and c are interchanged and then a is assumed equal to c. In this manner, band c are determined such that f(b)f(c)<0 and |f(b)| |f(c)|
604
TSD1
Variables a, b, and c have the following meanings: a... Current approximation to a root b... Previous b c... The opposing variable of b; a root lies between b and c. Procedure 2 Let m = (c b)/2 , as long as |m| < is not satisfied, one of the following (a), (b), or (c) is used to calculate the next approximation i and that value is assigned to b (as explained in detail later, is a function of b). (a) When |f(a)||f(b)| The bisection method, i = (b + c) /2 is applied (b) When a = c The linear interpolation (4.1) is applied i =b (a b ) f (b ) / f (a ) 1 f (b ) / f ( a ) =b+ p/ q
is satisfied, the division p/q is not performed, instead the bisection method (described in (a)) is used. When |p/q|<, i is calculated as i = b + sign(c b) to keep convergence from slowing down. Convergence criterion When either (a) or (b) below is satisfied, convergence is judged to have occurred. Calculation is terminated, and current b is taken as the root. (a) f(b) = 0(This will happen when complete underflow occurs) (b) |m|<=2u|b|+/2 >0 (4.3) Where u is the round-off unit and is the tolerance to the root (that corresponds to the parameter EPST of this routine). The righthand side of (4.3) has been derived experimentally. For more details see reference [3]. Let the exact root be x, the upper limit of the absolute error |bx| somewhat larger than the righthand side of (4.3) because of the rounding error. The result can be expressed as
(4.1)
(c) When |f(b)| < |f(a)||f(c)| The inverse quadratic interpolation method is applied Let fa = f(a), fb = f(b), fc = f(c), also r1=fa/fc, r2=fb/fc, r3=fb/fa, then (c b) f a ( f a f b ) (b a) f c ( f b f c ) i = b fb ( f a f c )( f b f c )( f b f a ) (c b)r1 (r1 r2 ) (b a )(r2 1) = b r3 (r1 1)(r2 1)(r3 1) =b+ p/q Procedure 1 and procedure 2 are then repeated. Preventing overflow When using (4.1) and (4.2), the following is necessary to prevent overflow. That is, when 3 3 3 | p / q| > | c b| = |2m| = | m| 4 4 2 (4.2)
|bx|6u|x|+ Care should be taken when specifying the value of parameter EPST. If the interval [a, b] includes the origin, it is unwise to set EPST=0.0 since there is a possibility that the exact root is the origin. Otherwise, EPST can be set to 0.0 without problems. For further information, see Reference [28].
605
APPENDICES
606
A.1 OUTLINE
Auxiliary subroutines internally supplement the functions of SSLII subroutines and slave subroutines. In Section 2.9, for example, SSL II subroutines frequently call for the unit round off "u". Then, the auxiliary subroutine for "u" facilitates the use of "u" for various subroutines that require "u" in execution. Thus, auxiliary subroutines are usually called from general or slave subroutines in SSL II. and have features as follows:
Features of auxiliary subroutines Some auxiliary subroutines are computer-dependent, (while SSLII subroutines and slave subroutines are computer-independent). Some auxiliary subroutines have single and double precision parameters at the same time, (whereas these two are not combined in the SSLII general subroutines and slave subroutines). There is no naming rule to apply to auxiliary subroutines, as with SSL II general subroutines and slave subroutines.(See Section 2.3).
Table A.1 Auxiliary subroutines Item Unit round off Printing of condition message Control of message printing Product sum (Real vector) Product sum (Complex vector) Radix of the floating-point number system Positive max. value of the floating -point number system Positive min. value of the AFMIN DFMIN M,F floating -point number system * M: Computer dependent subprograms. F: Function subprograms. S: Subroutine subprograms. ** MGSET is the sub-entry of MGSSL. AFMAX DFMAX M,F See A.8. AMACH MGSSL MGSET** ASUM,BSUM CSUM IRADIX DSUM,DBSUM DCSUM Subroutine name Single precision Double precision DMACH M,F S S S S M,F See A.2. See A.3. See A.4. See A.5. See A.6. See A.7. Feature* Reference section
607
AMACH
Function The function value defines the unit round off u in normalized floating-point arithmetic. u = M1-L/2(for (correctly) rounded arithmetic) u = M1-L(for chopped arithmetic) where M is the radix of the number system, and L the number of digits contained in the mantissa. Table AMACH-1 lists the values for single and double precision arithmetic.
Parameter EPS.. Input. EPS is specified as follows depending on the working precision. Single precision:Single precision real variable or constant. Double precision:Double precision real variable or constant. Example The unit round off for single and double precision arithmetic are obtained.
C **EXAMPLE** REAL*4 AEPS REAL*8 DEPS,DMACH AEPS=AMACH(AEPS) DEPS=DMACH(DEPS) WRITE(6,600) AEPS,DEPS STOP 600 FORMAT(10X,5HAEPS=,E16.7, * 5X,5HDEPS=,D25.17) END
Table AMACH-1 Unit round off AMACH Single precision L=26 u=1/22-25 L=6 u=16-5 L=23 u=1/22-22 DMACH Double precision L=61 u=1/22-60 L=14 u=16-13 L=52 u=1/22-51 Application
Binary:M=2
Rounded arithmetic
FACOM M series FACOM S series SX/G 200 series FM series SX/G series
608
MGSSL
A.3 MGSSL
Printing of condition messages CALL MGSSL(ICON,MCODE)
This subroutine does not usually print messages by itself. The printing message is controlled by subroutine MGSET, see MGSET. Example The following example, taken on subroutine LAX, shows how this subroutine is called internally by SSL II general subroutines.
C **EXAMPLE** SUBROUTINE LAX(A,K,N,B,EPSZ,ISW,IS, * VW,IP,ICON) DIMENSION A(K,N),B(N),VW(N),IP(N), * MCODE(6) DATA MCODE/2HA2,2H2-,2H11,2H-0, * 2H10,2H1 / IF(ISW.EQ.1) GOTO 1000 IF(ISW.EQ.2) GOTO 1100 ICON=30000 GOTO 8000 1000 CALL ALU(A,K,N,EPSZ,IP,IS,VW,ICON) IF(ICON.NE.0) GOTO 8000 1100 CALL LUX(B,A,K,N,1,IP,ICON) 8000 CALL MGSSL(ICON,MCODE) RETURN END
Function This subroutine prints the condition messages for SSL II subroutines Parameters ICOM.. Input. Condition code. MCODE.. Input. Subroutine classification code. One dimensional array of size 6. All 11-digit classification code is specified in MCODE. Example:For classification code, A52-22-0101: DATA MCODE/2HA5,2H2-,2H22,2H-0,2H10,2H1/ Comments on use Notes This subroutine is called by all SSL II general subroutines upon completion of the execution except by special function subroutines when normally ending with ICON=0.
609
MGSET
A.4 MGSET
Control of message printing CALL MGSET(ISET,IFLE)
Example The example shows how MGSET is used in subroutine LSX to solve a system of linear equations with a positive symmetric matrix.
DIMENSION A(5050),B(100) CALL MGSET(0,6) 10 READ(5,500)N IF(N.EQ.0) STOP NT=N*(N+1)/2 READ(5,510) (A(I),I=1,NT) READ(5,510) (B(I),I=1,N) WRITE(6,600) N CALL LSX(A,N,B,0.0,1,ICON) IF(ICON.GE.20000) GOTO 20 WRITE(6,610) (B(I),I=1,N) 20 CALL MGSET(-1,6) GOTO 10 500 FORMAT(I5) 510 FORMAT(5E16.8) 600 FORMAT(1H0,4X,6HORDER=,I5) 610 FORMAT(1H,4X,15HSOLUTION VECTOR * /(5X,E15.7)) END
Function This subroutine controls message printing for SSL II general subroutines. Parameters ISET.. Input. Output level.(See Table MGSET-1.) IFLE.. Input. File reference No. for output.(Data set identification No.)
Table MGSET-1 Output level ISET 0 1 2 3 -1 Control function Output when the condition code is among 030000. Output when the condition code is among 1000030000. Output when the condition code is among 2000030000. Output when the condition code is 30000. No condition message is output.
Comments on use Notes Printing of the condition messages: SSL II general subroutines call the auxiliary subroutine MGSSL to print condition message upon completion of the processing. Usually, auxiliary subroutine does not print messages, but messages can be printed by calling this subroutine in advance in the user's program. Extent of output control: Output control by this subroutine is retained until it is called again from the user's program. Note that, when an SSL II subroutine called by user's program calls other SSL II subroutines, they are also under the output control. Termination of printing: The message printing previously called for can be terminated by calling this subroutine again with ISET=-1. File reference number: IFLE=6 is usually specified as the standard. This subroutine is the sub-entry of the auxiliary subroutine MGSSL.
Several sets of systems are solved successively in this example. Subroutine MGSET is called two times in the program:first it is called after the array statement to produce the message when the first system is solved then it is called at statement number"20"to terminate the message printing in the successive operations.Since subroutine LSX internally uses component routines (SLDL, LDLX), they are also under the output control.
ORDER=3 ****SSL2(A22-51-0202) CONDITION 0**** ****SSL2(A22-51-0302) CONDITION 0**** ****SSL2(A22-51-0101) CONDITION 0**** SOLUTION VECTOR 0.1352613E+01 0.1111623E+00 0.4999998E+01 ORDER=4 SOLUTION VECTOR 0.5000001E+01 0.3333330E-01 0.1111110E+00 0.2499998E+00
610
ASUM(BSUM)
Function Given n-dimensional real vectors a and b, this subroutine computes the product sum .
= ai bi
i =1 n
Note: DBSUM cannot be used if the FORTRAN system does not support the quadruple-precision operation function.
where, aT=(a1, a2, ..., an), bT=(b1, b2, ..., bn) Parameters A.... Input. Vector a. One-dimensional array of size IA N. B.... N.... IA... Input. Vector b. One-dimensional array of size IB N. Input. Dimension n of vectors. Input. An interval between consecutive elements of vector a (=0). Generally, it is set to 1. Refer to Notes. Input. An interval between consecutive elements of vector b (=0). Generally, it is est to 1. See Notes. Output. Inner product . Refer to Notes. Example When n-dimensional real matrix A (=(aij)) is defined as a two-dimensional array A (K, N), the product sum in the m-th column and l-th row is calculated as shown below:
= aim al n +1 i
i 1
m Array A
IB...
KN l
SUM..
Comments on use Notes The purpose of this subroutine: From the theory of error analysis on floatingpoint arithmetic, the calculation of product sumfrequently used in numerical analyses requires high accuracy to maintain the needed number of significant digits. To do that, this subroutine enjoys an optimum method, which depends on the computer to be used. Data spacing in arrays A and B: Set IA=p when elements of vector a are to be stored in array A with spacing p Likewise, set IB=q when elements of vector b are to be stored in array B with spacing q If p, q<0 are must be taken in assigning arrays A and B(see Example). About BSUM: The functions of BSUM are equivalent to those of ASUM but BSUM computes the product sum in double precision. The comparison among ASUM, BSUM, DSUM and DBSM is tabulated as follows:
Where, n100
C **EXAMPLE** DIMENSION A(100,100) K=100 READ(5,100) N,((A(I,J),I=1,N),J=1,N) READ(5,200) M,L CALL ASUM(A(1,M),A(L,N),N,1,-K,SUM) WRITE(6,150) M,L,SUM STOP 100 FORMAT(I5/(4E15.7)) 200 FORMAT(2I5) 150 FORMAT(1H1//10X,2HM=,I5,5X,2HL=, I5, * 5X,4HSUM=,E16.7) END
611
CSUM
A.6 CSUM, DCSUM Product sum (Complex vector) CALL CSUM (ZA, ZB, N, IA, IB, ZSUM) Function Given n-dimensional complex vectors a and b this subroutine computes the product sum .
Data interval of array ZA, ZB: Specify IA=pwhen elements of vector are to be stored in array ZA with the interval p. Similarly, specify IB=q when elements of vector b are to be stored in array ZB with the interval q. If p, q<0, assigning of arrays ZA and ZB should be done with sufficient care. (See the example.) Example When n-dimensional complex matrix A(=(aij)) is given as a two-dimensional array ZA (K, N), the following example computes the product sum u in the m-th column and the l-th row.
= ai bi
i 1
Where
Parameters ZA... Input. Vector a. One-dimensional complex type array of size IA N. ZB... N.... IA... Input. Vector b. One-dimensional complex type array of size IB N.. Input. Dimension n of vectors. Input. An interval between consecutive elements of vector a(0). Generally, it is set to 1. (See Notes.) Input. An interval between consecutive elements of vector b (0). Generally, it is set to 1. (See Notes.) Output. Inner product .
C
= aim a ln +1 i
i 1
KN l
Array ZA
IB...
ZSUM.
Comments on use Notes The purpose of this subroutine: From the theory of error analysis on floating-point arithmetic, the calculation of the product sum frequently used in numerical analysis requires high precision. This subroutine uses the most appropriate method depending on the computer used.
**EXAMPLE** DIMENSION ZA(100,100) COMPLEX ZA K=100 READ(5,100)N,((ZA(I,J),I=1,N),J=1,N) READ(5,200) M,L CALL CSUM(ZA(1,M),ZA(L,N),N,1,-K,ZSUM) WRITE(6,150) M,L,ZSUM STOP 100 FORMAT(I5/(4E15.7)) 200 FORMAT(2I5) 150 FORMAT(1H1//10X,2HM=,I5,5X,2HL=, I5, * 5X,5HCSUM=,2E16.7) END
612
IRADIX
A.7 IRADIX Radix of the floating-point number system (Function subprogram) IRADIX(RDX) Function The radix of the floating-point number system is set as an integer-type function value. See Table IRADIX-1.
Table IRADIX-1 Radix for floating-point Arithmetic Binary Hexadecimal IRADIX IRADIX=2 IRADIX=16 Application FM series SX/G 100 series FACOM M series FACOM S series SX/G 200 series
Parameter RDX... Input. Real variable, or a constant. Any real number can be specified as RDX. Example The radix of the number system can be obtained as follows.
C **EXAMPLE** REAL*4 RDX RDX=IRADIX(RDX) WRITE(6,600)RDX 600 FORMAT(//10X,4HRDX=,E15.7) STOP END
613
AFMAX, AFMIN
Example The maximum and minimum values for single and double precisions are obtained as follows:
C **EXAMPLE** REAL*4 X0,X1,X2 REAL*8 Y0,Y1,Y2,DFMAX,DFMIN X1=AFMAX(X0) X2=AFMIN(X0) Y1=DFMAX(Y0) Y2=DFMIN(Y0) WRITE(6,600) X1,X2,Y1,Y2 STOP 600 FORMAT(10X,6HAFMAX=,E16.7/ * 10X,6HAFMIN=,E16.7/ * 10X,6HDFMAX=,D25.17/ * 10X,6HDFMIN=,D25.17) END
Maximum value AFMAX(X) Minimum value AFMIN(X) Function The positive maximum value flmax or minimum value flmin of the floating-point number system is set. See Table AFMAX-1. Parameter X.. Input. This specified according to the precision as: Single precision:Single precision real variable or constant. Double precison:Double precision real variable or constant.
Table AFMAX-1 Max, and min. values for floating-point unmber system Maximum values Single precision Double precision AFMAX DFMAX (1-2-26)2255 (1-2-61)2255 (1-16-6)1663 (1-16-14)1663 (1-2-53)21024 (1-2-56)2252 Minimum values Single precision Double precision AFMIN DFMIN 2-12-256 2-12-256 16-116-64 16-116-64 2-12-1021 2-12-259
Application
Binary
(1-2-24)2128
2-12-125
FACOM M series FACOM S series SX/G 200 series FM series SX/G 100 series
614
In this appendix, subroutine name of SSLII are listed in alphabetical order. The subroutines are divided into three lists based on their uses. Only single precision subroutine names are included.
615
Table B.1 General subroutines Subroutine name AGGM AKHER AKLAG AKMID AKMIN ALU AQC8 AQE AQEH AQEI AQMC8 AQME Classification code A21-11-0101 E11-11-0201 E11-11-0101 E11-42-0101 E12-21-0201 A22-11-0202 G23-11-0301 G23-11-0401 G23-21-0101 G23-31-0101 G24-13-0101 G24-13-0201 Subprogram used AFMAX AFMAX
Table B.1 -continued Subroutine name BSFD1 BSF1 BSVEC BTRID BYN BYR BY0 BY1 CBIN CBJN CBJR CBKN CBLNC CBYN CEIG2 CELI1 CELI2 CFRI CFT CFTM CFTN CFTR CGSBM CGSM CHBK2 CHES2 CHSQR CHVEC CJART CLU CLUIV CLUX CNRML COSI CQDR CSBGM CSBSM CSGM CSSBM CTSDM ECHEB ECOSP EIGI ESINP EXPI FCHEB FCOSF FCOSM FCOST FSINF FSINM FSINT GBSEG Classification Code E31-32-0101 E31-31-0101 B51-21-0402 B51-21-0302 I11-81-1101 I11-83-0202 I11-81-0401 I11-81-0501 I11-82-1101 I11-82-1301 I11-84-0101 I11-82-1201 B21-15-0202 I11-82-1401 B21-15-0101 I11-11-0101 I11-11-0201 I11-51-0201 F12-15-0101 F12-11-0101 F12-15-0202 F12-15-0302 A11-40-0101 A11-10-0101 B21-15-0602 B21-15-0302 B21-15-0402 B21-15-0502 C22-15-0101 A22-15-0202 A22-15-0602 A22-15-0302 B21-15-0702 I11-41-0201 C21-15-0101 A11-40-0201 A11-50-0201 A11-10-0201 A11-50-0101 C23-15-0101 E51-30-0201 E51-10-0201 B21-11-0101 E51-20-0201 I11-31-0101 E51-30-0101 E51-10-0101 F11-11-0201 F11-11-0101 E51-20-0101 F11-21-0201 F11-21-0101 B52-11-0101 Subprogram used TRID1, UCHLS, UESRT UBAS1, UCAR2 UBAS1, UCAR1 AMACH AMACH BY0, BY1, UBJ0, UBJ1, UTLIM AMACH, AFMAX, UTLIM, ULMAX UBJ0, UTLIM UBJ1, UTLIM AMACH, ULMAX AMACH, ULMAX AMACH, ULMAX CBIN, AMACH, ULMAX, UTLIM IRADIX CBIN, CBKN, AMACH, ULMAX, UTLIM CBLNC, CHES2, CNRML, AMACH, CSUM, IRADIX
AQN9 ASSM ASVD1 BDLX BICD1 BICD3 BIC1 BIC2 BIC3 BIC4 BIFD1 BIFD3 BIF1 BIF2 BIF3 BIF4 BIN BIR BI0 BI1 BJN BJR BJ0 BJ1 BKN BKR BK0 BK1 BLNC BLUX1 BLU1 BMDMX BSCD2 BSCT1 BSC1 BSC2 BSEG BSEGJ
G23-11-0201 A21-12-0101 A25-31-0201 A52-31-0302 E12-32-1102 E12-32-3302 E12-31-0102 E12-31-0202 E12-31-0302 E12-31-0402 E11-32-1101 E11-32-3301 E11-31-0101 E11-31-0201 E11-31-0301 E11-31-0401 I11-81-1201 I11-83-0301 I11-81-0601 I11-81-0701 I11-81-1001 I11-83-0101 I11-81-0201 I11-81-0301 I11-81-1301 I11-83-0401 I11-81-0801 I11-81-0901 B21-11-0202 A52-11-0302 A52-11-0202 A52-21-0302 E32-32-0202 B21-21-0502 E32-31-0102 E32-31-0202 B51-21-0201 B51-21-1001
AMACH AMACH AMACH, AFMIN AMACH, AFMAX AMACH, AFMAX AMACH AFMAX, AFMIN, UAQE1, UAQE2, UAQE3, UFNIO, UFN2O, UFN3O, UFN4O, AMACH AMACH AMACH UBAS1, UCIO1,ULUI1, UMIO1 UBAS1, UCIO3, ULUI3, UMIO3 UBAS1, UCIO1,ULUI1, UMIO1 UBAS1, UCIO2, ULUI1, UMIO2 UBAS1, UCIO3, ULUI3 UMIO3 UBAS4, UCIO4, ULUI4, UMIO4, UPEP4 UBAS1, UCAD1 UBAS1, UCAD1 UBAS1, UCAR1 UBAS1, UCAR1 UBAS1, UCAR1 UBAS4, UCAR4, UPEP4 AMACH,BI0, BI1, AFMIN, AFMAX, ULMAX AFMIN, AMACH, ULMAX AFMAX, ULMAX AFMAX, ULMAX AMACH, BJ0, BJ1, AFMIN, UTLIM AMACH, AFMIN, UTLIM UTLIM UTLIM BK0, BK1, ULMAX AMACH, AFMAX, ULMAX ULMAX ULMAX IRADIX ASUM AMACH UBAS0, UCDB2, UPOB2, UPCA2 UREO1 AMACH UBAR1, UCAO1, UCDB1, UNCA1, UREO1 UBRS0, UCDB2, UPOB1, UPCA1, UREO1, AFMAX AMACH,BSCT1, BSVEC, BTRID AMACH, BDLX, MSBV, SBDL, TEIG1, TRBK,
AMACH, CSUM AMACH AMACH, CSUM AMACH, CQDR, UCJAR AMACH, CSUM CSUM CSUM UTLIM
AMACH, BLNC, HES1, IRADIX ULMAX, AFMAX AMACH, UTABT, UCOSM AMACH, UTABT, UCOSM, UNIFC UCOSM, UPNR2, UTABT UCOSM, UPNR2, UTABT AMACH, UTABT, USINM, UNIFC USINM, UPNR2, UTABT USINM, UPNR2, UTABT AMACH, MSBV, TRID1, TEIG1, TRBK, UCHLS, UBCHL, UBCLX, UESRT ADVD1, AMACH
GCHEB GINV
E51-30-0301 A25-31-0101
616
TableB.1-conteimued Subroutine name GSBK GSCHL GSEG2 Classification code B22-10-0402 B22-10-0302 B22-10-0201 Subprogram used
TableB.1-continued Subroutine name MING1 MSBV MSGM MSSM MSV NDF NDFC NLPG1 NOLBR NOLF1 NOLG1 NRML ODAM ODGE Classification Code D11-20-0101 A51-14-0101 A21-12-0401 A21-12-0301 A21-14-0101 I11-91-0101 I11-91-0201 D31-20-0101 C24-11-0101 D15-10-0101 D15-20-0101 B21-11-0702 H11-20-0141 H11-20-0151 Subprogram used AMACH, AFMAX, MSV CSGM, MGGM CSGM, MGSM
HAMNG HBK1 HEIG2 HES1 HRWIZ HSQR HVEC ICHEB IERF IERFC IGAM1 IGAM2 INDF INDFC INSPL LAPS1 LAPS2 LAPS3 LAX LAXL LAXLM LAXLR LAXR LBX1 LBX1R LCX LCXR LDIV LDLX LESQ1 LMINF LMING LOWP LPRS1 LSBIX LSBX LSBXR LSIX LSIXR LSTX LSX LSXR LTX LUIV LUX MAV MBV MCV MDMX MGGM MGSM MINF1
H11-20-0121 B21-11-0602 B21-25-0201 B21-11-0302 F20-02-0201 B21-11-0402 B21-11-0502 E51-30-0401 I11-71-0301 I11-71-0401 I11-61-0101 I11-61-0201 I11-91-0301 I11-91-0401 E12-21-0101 F20-01-0101 F20-02-0101 F20-03-0101 A22-11-0101 A25-11-0101 A25-21-0101 A25-11-0401 A22-11-0401 A52-11-0101 A52-11-0401 A22-15-0101 A22-15-0401 A22-51-0702 A22-51-0302 E21-20-0101 D11-30-0101 D11-40-0101 C21-41-0101 D21-10-0101 A52-21-0101 A52-31-0101 A52-31-0401 A22-21-0101 A22-21-0401 A52-31-0501 A22-51-0101 A22-51-0401 A52-11-0501 A22-11-0602 A22-11-0302 A21-13-0101 A51-11-0101 A21-15-0101 A22-21-0302 A21-11-0301 A21-11-0401 D11-10-0101
AMACH, UCHLS AMACH, GSBK, GSCHL, TRBK, TRID1, UCHLS, UTEG2 AMACH, RKG NRML AMACH, TEIG2, TRBKH, TRIDH, UTEG2 AMACH AMACH AMACH AMACH IERFC IERF AMACH, IGAM2, AFMAX, EXPI, ULMAX AMACH, EXPI, ULMAX, AFMAX IERF, IERFC IERF, IERFC AFMAX LAPS1, HRWIZ, AFMAX, AMACH ALU, AMACH, LUX AMACH, ULALB, ULACH ADVD1, AMACH AMACH, MAV, ULALB AMACH, LUX, MAV AMACH, BLUX1, BLU1 AMACH, BLUX1, MVB AMACH, CLUX, CLUX, CSUM AMACH, CLUX, CSUM, MCV
AMACH, UQP, UNLPG AMACH AMACH AMACH AMACH, UDE, USTE1, UINT1 AMACH, USDE,UINT2, USTE2, USETC, USETP, USOL, UADJU, UDEC AMACH, URKV, UVER
ODRK1 PNR RANB2 RANE2 RANN1 RANN2 RANP2 RANU2 RANU3 RATF1 RATR1 RFT RJETR RKG RQDR SBDL SBMDM SEIG1 SEIG2
H11-20-0131 F12-15-0402 J12-20-0101 J11-30-0101 J11-20-0301 J11-20-0101 J12-10-0101 J11-10-0101 J11-10-0201 J21-10-0101 J21-10-0201 F11-31-0101 C22-11-0101 H11-20-0111 C21-11-0101 A52-31-0202 A52-21-0202 B21-21-0101 B21-21-0201
RANU2 RANU2 ULMAX RANU2 UX2UP UX2UP CFTN, PNR, URFT AFMAX, AFMIN, AMACH, IRADIX, RQDR, UJET AMACH AMACH AMACH AMACH,TEIG1, TRID1, TRBK AMACH, TEIG2, TRBK, TRID1, UTEG2 UTLIM
AMACH AMACH AMACH MAMCH, RQDR, UREDE, U3DEG ALU, LUIV, AMACH SBMDM, BMDMX, AMACH AMACH, BDLX, SBDL AMACH, BDLX, MSBV AMACH, MDMX, SMDM, USCHA MDMX, MSV, AMACH AMACH AMACH, LDLX, SLDL AMACH, LDLX, MSV AMACH
SFRI I11-51-0101 SGGM A21-11-0201 SIMP1 G21-11-0101 SIMP2 G23-11-0101 AMACH SINI I11-41-0101 UTLIM SLDL A22-51-0202 AMACH SMDM A22-21-0202 AMACH, USCHA SMLE1 E31-11-0101 SMLE2 E31-21-0101 SPLV E11-21-0101 USPL SSSM A21-12-0201 TEIG1 B21-21-0602 AMACH TEIG2 B21-21-0702 AMACH, UTEG2 TRAP G21-21-0101 TRBK B21-21-0802 TRBKH B21-25-0402 TRIDH B21-25-0302 AMACH TRID1 B21-21-0302 AMACH TRQL B21-21-0402 AMACH TSDM C23-11-0111 AFMAX, AFMIN, AMACH TSD1 C23-11-0101 AMACH Note: In the "Subprograms used"column, any subroutine names (except MGSSL) which are called in each subroutine are listed.
617
ODGE AQME AQME AQME BSC1 BSCD2, BSC2 BICD1, BICD3, BIC1, BIC2, BIC3, BIFD1, BIFD3, BIF1, BIF2, BIF3, BSF1,BSFD1 BIC4, BIF4 GBSEG GBSEG BY0 BY1 BIFD1, BIFD3 BSC1 BIF1, BIF2, BIF3, BSF1 BSFD1 BIF4 BSC1 BSCD2, BSC2 CFTM BSEGJ, GBSEG, GSCHL, GSEG2 BICD1, BIC1 BIC2 BICD3, BIC3 BIC4 CJART FCOSM, FCOST ODAM ODGE BSEGJ, GBSEG UVER AQME UX2UP AQME U3DEG AQME AQME ODAM ODGE RJETR LAXL, LAXLR LAXL BICD1, BIC1, BIC2 BIR, BI0, BI1, BKR, BK0, BK1, BYR, CBIN, CBJN, CBJR, CBKN, EXPI, IGAM2, RANP2 BICD3, BIC3
Note: Each slave subroutine listed is called directly by the subroutine listed in its"Calling subroutines" colmn.
618
Calling subroutines (Called by many general and slave subroutines.) (Called by the user of SSL II.) (Called by all general subroutines.) BLNC, CBLNC, RJETR
AFMIN
GEIG2, CHES2, CHVEC, CLU, CLUX, CLUIV AKHER, AKLAG, AQME, BI0, BI1, BKR, BYR, CTSDM, EXPI, IGAM2, MING1, RJETR, TSDU, UPOB1 AQE, AQME, BIN, BIR, BJN, BJR, CTSDM, RJETR, TSDM
Note: Refer to Appendix A. MGSET is the sub-entry of MGSSL. Each auxiliary subroutine listed is called directly by the subroutine listed in its"Calling subroutines"column.
619
Liner algebra Code A11-10-0101 A11-10-0201 A11-40-0101 A11-40-0201 A11-50-0101 A11-50-0201 A21-11-0101 A21-11-0201 A21-11-0301 A21-11-0401 A21-12-0101 A21-12-0201 A21-12-0301 A21-12-0401 A21-13-0101 A21-14-0101 A21-15-0101 A22-11-0101 A22-11-0202 A22-11-0302 A22-11-0401 A22-11-0602 A22-15-0101 A22-15-0202 A22-15-0302 A22-15-0401 A22-15-0602 A22-21-0101 A22-21-0202 A22-21-0302 A22-21-0401 A22-51-0101 A22-51-0202 A22-51-0302 A22-51-0401 A22-51-0702 A25-11-0101 A25-11-0401 A25-21-0101 A25-31-0110 A25-31-0201 A51-11-0101 A51-14-0101 A52-11-0101 A52-11-0202 A52-11-0302 A52-11-0401 A52-11-0501 A52-21-0101 Subroutine CGSM CSGM CGSBM CSBGM CSSBM CSBSM AGGM SGGM MGGM MGSM ASSM SSSM MSSM MSGM MAV MSV MCV LAX ALU LUX LAXR LUIV LCX CLU CLUX LCXR CLUIV LSIX SMDM MDMX LSIXR LSX SLDL LDLX LSXR LDIV LAXL LAXLR LAXLM GINV ASVD1 MBV MSBV LBX1 BLU1 BLUX1 LBX1R LTX LSBIX
Linear algebra-continued Code A52-21-0202 A52-21-0302 A52-31-0101 A52-31-0202 A52-31-0302 A52-31-0401 A52-31-0501 Subroutine SBMDM BMDMX LSBX SBDL BDLX LSBXR LSTX
Non-linear equations Code C21-11-0101 C21-15-0101 C21-11-0101 C22-11-0111 C22-15-0101 C23-11-0101 C23-11-0111 C23-15-0101 C24-11-0101 Subroutine RQDR CQDR LOWP RJETR CJART TSD1 TSDM CTSDM NOLBR
Eigenvalues and eigenvectors Code B21-11-0101 B21-11-0202 B21-11-0302 B21-11-0402 B21-11-0502 B21-11-0602 B21-11-0702 B21-15-0101 B21-15-0202 B21-15-0302 B21-15-0402 B21-15-0502 B21-15-0602 B21-15-0702 B21-21-0101 B21-21-0201 B21-21-0302 B21-21-0402 B21-21-0502 B21-21-0602 B21-21-0702 B21-21-0802 B21-25-0201 B21-25-0302 B21-25-0402 B22-21-0201 B22-21-0302 B22-21-0402 B51-21-0201 B51-21-0302 B51-21-0402 B51-21-0001 B52-11-0101 Subroutine EIGI BLNC HES1 HSQR HVEC HBK1 NRML CEIG2 CBLNC CHES2 CHSQR CHVEC CHBK2 CNRML SEIG1 SEIG2 TRID1 TRQL BSCT1 TEIG1 TEIG2 TRBK HEIG2 TRIDH TRBKH GSEG2 GSCHL GSBK BSEG BTRID BSVEC BSEGJ GBSEG
Extrema Code D11-10-0101 D11-20-0101 D11-30-0101 D11-40-0101 D15-10-0101 D15-20-0101 D21-10-0101 D31-20-0101 Subroutine MINF1 MING1 LMINF LMING NOLF1 NOLG1 LPRS1 NLPG1
620
Interpolation and approximation Code E11-11-0101 E11-11-0201 E11-21-0101 E11-31-0101 E11-31-0201 E11-31-0301 E11-31-0401 E11-32-1101 E11-32-3301 E11-42-0101 E12-21-0101 E12-21-0201 E12-31-0102 E12-31-0202 E12-31-0302 E12-31-0402 E12-32-1102 E12-32-3302 E21-20-0101 E31-11-0101 E31-21-0101 E31-31-0101 E32-31-0102 E32-31-0202 E31-32-0101 E32-32-0202 E51-10-0101 E51-10-0201 E51-20-0101 E51-20-0201 E51-30-0101 E51-30-0201 E51-30-0301 E51-30-0401 Transforms Code F11-11-0101 F11-11-0201 F11-21-0101 F11-21-0201 F11-31-0101 F12-11-0101 F12-15-0101 F12-15-0202 F12-15-0302 F12-15-0402 F20-01-0101 F20-02-0101 F20-02-0201 F20-03-0101 Subroutine FCOST FCOSM FSINT FSINM RFT CFTM CFT CFTN CFTR PNR LAPS1 LAPS2 HRWIZ LAPS3 Subroutine AKLAG AKHER SPLV BIF1 BIF2 BIF3 BIF4 BIFD1 BIFD3 AKMID INSPL AKMIN BIC1 BIC2 BIC3 BIC4 BICD1 BICD3 LESQ1 SMLE1 SMLE2 BSF1 BSC1 BSC2 BSFD1 BSCD2 FCOSF ECOSP FSINF ESINP FCHEB ECHEB GCHEB ICHEB
Numerical differentiation and quadrature Code G21-11-0101 G21-21-0101 G23-11-0101 G23-11-0201 G23-11-0301 G23-11-0401 G23-21-0101 G23-31-0101 G24-13-0101 G24-13-0201 Subroutine SIMP1 TRAP SIMP2 AQN9 AQC8 AQE AQEH AQEI AQMC8 AQME
Pseudo random numbers Code J11-10-0101 J11-10-0201 J11-20-0101 J11-20-0301 J11-30-0101 J12-10-0101 J12-20-0101 J21-10-0101 J21-10-0201 Subroutine RANU2 BANU3 RANN2 RANN1 RANE2 RANP2 RANB2 RATF1 RATR1
Differential equations Code H11-20-0111 H11-20-0121 H11-20-0131 H11-20-0141 H11-20-0151 Special functions Code I11-11-0101 I11-11-0201 I11-31-0101 I11-41-0101 I11-41-0201 I11-51-0101 I11-51-0201 I11-61-0101 I11-61-0201 I11-71-0301 I11-71-0401 I11-81-0201 I11-81-0301 I11-81-0401 I11-81-0501 I11-81-0601 I11-81-0701 I11-81-0801 I11-81-0901 I11-81-1001 I11-81-1101 I11-81-1201 I11-81-1301 I11-82-1101 I11-82-1201 I11-82-1301 I11-82-1401 I11-83-0101 I11-83-0201 I11-83-0301 I11-83-0401 I11-84-0101 I11-91-0101 I11-91-0201 I11-91-0301 I11-91-0401 Subroutine CELI1 CELI2 EXPI SINI COSI SFRI CFRI IGAM1 IGAN2 IFRF IERFC BJ0 BJ1 BY0 BY1 BI0 BI1 BK0 BK1 BJN BYN BIN BKN CBIN CBKN CBJN CBYN BJR BYR BJR BKR CBJR NDF NDFC INDF INDFC Subroutine RKG HAMNG ODRK1 ODAM ODGE
621
APPENDIX D REFERENCES
[1] [2]
Forsythe. G.E and Moler, C.B.Computer Solution of Linear Algebraic Systems,Prentice-Hall, Inc., 1967 Martin R.S.,Peters, G. and Wilkinson, J.H. Symmetric Decomposition of A Positive Definite Matrix. Linear Algebra, Handbook for Automatic Computation, Vol.2, pp.9-30, Springer-Verlag, Berlin-Heidelberg-New York,1971
[9]
Bunch,J.R and Kaufman,L. Some Stable Methods for Calculation Inertia and Solving Symmetric.Linear Systems, Mathematics of Computation, Vol.13,No.137,January 1977,pp.163-179
[10] Bunch,J.R. and Kaufman, L. Some Stable Methods for Calculation Inertia and Solving Symmertric Linear Systems,Univ. of Colorado Tech. Report 63, CU:CS:06375 [11] Golub,G.H. and Reinsch,C. Singular Value Decomposition and Least Squares Solutions, Linear Algebre,Handbook for Automatic Computation,Vol.2,pp.134-151,Springer-Verlag,Berlin Heidelberg-New York, 1971 [12] Wilkinson,J.H. The Algebraic Eigenvalue Problem, Clarendon Press, Oxford, 1965 [13] Wilkinson,J.H.and Reinsch, C.Linear Algebra, Handbook for Automatic Computation,Vol.2,Springer-Verlag, Berlin-Heidelberg-New York,1971 [14] Smith,B.T., Boyle, J.M.,Garbow,B.S.,Ikebe,Y.,Kleme,V.C and Moler,C.B. Matrix Eigensystem Routine-EISPACK Guide 2nd edit. Lecture Note in Computer Science 6, SpringerVerlag,Berlin-Heidelberg-New York,1976. [15] Ortega,J. The Givens-Householder Method for Symmetric Matrix, Mathematical Methods for Digital Computors,Vol.2, John wiley&Sons, New York-LondonSydney,pp.94-115,1967 [16] Togawa,H. Numerical calculations of matrices, chap.3, pp.146-210, Ohmsha Ltd., Tokyo, 1971 (Japanese only) [17] Mueller,D.J Householders Method for Complex Matrices and Eigensystems of Hermitian Matrices, Numer.Math.8,pp.72-92,1996 [18] Jennings,A. Matrix Computation for Engineers and Scientists,J.Wiley, pp.301-310,1977 [19] Togawa,H. Vibration analysis by using FEM, chap.4, pp.156-162, Saiensu-sha Co., 1970. (Japanese only)
[3]
Bowdler,H.J., Martin, R.S. and Wilkinson, J.H. Solution of Real and Complex Systems of Linear Equations, Linear Algebra, Handbook for Automatic Computation, Vol.2,pp.93-110,Springer-Verlag, Berlin-HeidelbergNew York,1971
[4]
Parlett,B.N. and Wang,Y.The Influence of The Compiler on The Cost of Mathematical Software-in Particular on The Cost of Triangular Factorization, ACM Transactions on Mathematical Software,Vol.1,No.1,pp.35-46, March, 1975
[5] [6]
Wilkinson, J.H. Rounding Errors in Algebraic Process, Her Britannic Majestys Stationary Office,London, 1963 Peter Businger and Gene H. Golub. Linear Least Squares Solutions by Householder Transformatinos,Linear Algebra,Handbook for Automatic Computation,Vol.2,pp.111-118 Springer-Verlag, BerlinHeidelberg-New York,1971
[7]
Martin,R.S and Wilkinson,J.H. Symmetric Decomposition of Posive Definite. Band Matrices,Linear Algebra,Handbook for Automatic Computation,Vol.2,pp.50-56 Springer-Verlag, BerlinHeidelberg-New York ,1971
[8]
Martin,R.S. and Wilkinson,J.H. Solution of Symmetric and Unsymmetric Band Equations and the Calculations of Eigenvectors of Band Matrices,Linear Algebra,Handbook for Automatic Computation,Vol.2,pp.70-92, SpringerVerlag, Berlin Heidelberg New York,1971
622
[20] Brezinski, C. Acceleration de la Convergence en Analyse Numerique, Lecture Notes in Mathematics 584, Springer, pp. 136-159, 1977. [21] Wynn, P. Acceleration Techniques for Iterated Vectol and Matrix Problems, Mathematics of Computation, Vel. 16, pp. 301-322, 1962. [22] Yamashita,S. On the Error Estimation in Floating-point Arithmetic, Journal of Information Processing Society of Japan, Vol.15, No.12, pp.935-939, 1974 (Japanese only) [23] Yamashita,S. and Satake,S. On the calculation limit of roots of the algebraic equation, Journal of Information Processing Society of Japan, Vol.7, No.4, pp.197-201, 1966 (Japanese only) [24] Hirano,S. Error of the algebraic equation - from "Error in the Numerical Calculation", bit, extra number 12, pp.1364-1378, 1975 (Japanese only) [25] Kiyono,T. and Matsui,T. Solution of a low polynomial, "Information", Data Processing Center, Kyoto University, Vol.4, No.9, pp.9-32, 1971 (Japanese only) [26] Garside, G.R.,Jarratt,P. and Mack, C. A New Method for Solving Polynomial Equations,Computer Journal, Vol. 11,pp.87-90,1968 [27] Ninomiya,I. GJM solution of a polynomial, IPSJ National Conference, p.33, 1969 (Japanese only) [28] Brent, Richard P. Algorithms for Minimization without Derivatives, Prentice-Hall, London-Sydney-ToKyo, pp. 47-60, 1973 [29] Peters, G. and Wilkinson, J.H. Eigenvalues of Ax=Bx with Band Symmetric A and B, Comp. J. 12,pp.398404,1969 [30] Jenkins, M. A. and Traub, J.F. A three-stage algorithm for real polynomials using quadratic iteration, SIAM J. Number. Anal., Vol.17,pp.545-566, 1970 [31] Jenkins, M. A.Algorithm 493 Zeros of a real polynomial, ACM Transaction on Mathematical Software,Vol.1,No.2,pp.178-187,1975 [32] Traub, J. F. The Solution of Transcendental Equations, Mathematical Methods for Digital Computers, Vol. 2, 1967, pp. 171-184 [33] Cosnard, M. Y. A Comparison of Four Methods for Solving Systems of Nonlinear Equations, Cornell University Computer Science Technical Report TR75248, 1975 [34] Fletcher, R. Fortran subroutines for minimization by quasi-Newton methods, Report R7125 AERE, Harwell, England, 1972
[35] Shanno, D. F. and Phua, K. H. Numerical comparison of several varible metric algorithms J. of Optimization Theory and Applications, Vol. 25, No. 4, 1978 [36] Marquardt, D. W. An algorithm for least squares estimatron of nonlinear parameters, Siam J. Appl. Math., 11, pp. 431-441, 1963 [37] Osborne, M. R. Nonlinear least squares-The Levenberg algorithm revisited, J. of the Australian Mathematical Vociety, 19, pp. 343-357, 1976 [38] Moriguchi,S. Primer of Linear Programming. JUSE Press Ltd., 1957, remodeled,1973. (Japanese only) [39] Ono,K. Linear Programming on the calculation basis. JUSE Press Ltd., 1967, remodeled,1976. (Japanese only) [40] Tone,K. Mathematical Programming. Asakura Publishing, 1978. (Japanese only) [41] Kobayashi,T. Primer of Linear Programming. Sangyo Tosho, 1980. (Japanese only) [42] Kobayashi,T. Theory of Network. JUSE Press Ltd., 1976. (Japanese only) [43] Dantzig, G. Linear Programming and Extensions, Princeton University Press, 1963. [44] Simonnard, M. (translated by W. S. Jewell) Linear Programming, Prentice-Hall,1966. [45] Vande Panne, C. Linear Programming and Related Techniqes, North-Holland, 1971, [46] Ralston, A. A First Conrse In Numerical Analysis, Mc Graw-Hill, New York-Tronto-London, 1965. [47] Gershinsky, M. and Levine, D. A. Aitken-Hermite Interpolation, Journal of the ACM, Vol. 11, No. 3, 1964, pp. 352-356. [48] Greville, T. N. E. Spline Functon, Interpolation and Numerical Quadrature, Mathematical Methods for Digital Computers, Vol. 2, Johe Wiley & Sons, New York-London-Sydney, 1967, pp. 156-168. [49] Ahlberg, J. H., Nilson, E:N. and Walsh, J. L. The Theory of Splines and Their Applications. Academic Press, New York and London, 1967. [50] Hamming R. W. Numerical Methods for Scientists and Engineers, McGraw-Hill, New York-Tronto-London, 1973 [51] Hildebrand, F. B. Introduction to Numerical Analysis, sec, ed. McGraw-Hill, 1974. [52] Akima, H. A New Method of Interpolation and Smooth Curve Fitting Based on Local Procedure Journal of the ACM, Vol. 17, No. 4, 1970. pp. 589-602.
623
[53] Carl de Boor. On Calculating with B-splines, J.Approx. Theory, Vol.6, 1972, pp.50-62. [54] Akima, H. Bivariate Interpolation and Smooth Surface Fitting Based on Local Procedures, Comm. Of the ACM., Vol.17, No.1, 1974, pp.26-31 [55] Singlton, R.C. On Computing the Fast Fourier Transform, Communications of The ACM, Vol.10, No.10, pp. 647-654, October, 1967 [56] Singlton, R.C. An ALGOL Convolution Procedure Based On The Fast Fouier Tronsform, Communications of The ACM, Vol.12, No.3, pp.179-184, March, 1969 [57] Singlton, R.C. An Algorithm for Computing The Mixed Radix Fast Fourier Transform, IEEE Transactions on Audio and Electroacoustics, Vol.AU-17, No.2, pp.99-103, June, 1969 [58] Torii,T. Fast sine/cosine transforms and the application to the numerical quadrature. Journal of Information Processing Society of Japan, Vol.15, No.9, pp.670-679,1974 (Japanese only) [59] Torii,T. The subroutine package of Fourier transforms (Part 1,2). Nagoya University Computation Center News, Vol.10, No.2, 1979 (Japanese only) [60] Fox, L. and Parker, I.B. Chebyshev Polynomials in Numerical Analysis, Oxford University Press, 1972 [61] Lyness, J.N. Notes on the Adaptive Simpson Quadrature Routine, Journal of the ACM, Vol.16, No.3, 1969, PP.483-495 [62] Davis, P.J. and Rabinowitz,P. Methods of Numerical Intergration, Academic Press, 1975 [63] Kahaner, D.K. Comparison of numerical quadrature formulas. In Mathematical Software (Ed. J.R. Rice), Academic Press, 1971, pp.229-259 [64] De Boor, C. CADRE:An algorithm for numerical quadrature. In Mathematical Software (Ed. J.R. Rice), Academic Press, 1971, pp.417-449 [65] Clenshaw, C.W. and Curtis, A.R. A method for numerical integration on an automatic computer. Numer.Math.2, 1960, pp.197-205 [66] Torii,T., Hasegawa,T., Ninomiya,I. The automatic integral method with the interpolation increasing sample points in arithmetic progression. Journal of Information Processing Society of Japan, Vol.19, No.3, 1978, pp.248-255 (Japanese only) [67] Takahashi, H. and Mori, M. Double Exponential Formulas for Numerical Integration. Publications of R.I.M.S, Kyoto Univ. 9, 1974, pp.721741
[68] Mori,M. Curves and curved surfaces. Kyoiku Shuppan, 1974 (Japanese only) [69] Romanelli, M.J. Runge-Kutta Methods for Solution of Ordinary Differential Equations, Mathematical Methods for Digital Computer, Vol.2, John Wiley & Sons, New York-London-Sydney, 1967, PP.110-120 [70] Hamming, R.W. Stable Predictor Corrector Methods for Ordinary Differential Equations, Jouranl of the ACM, Vol.6, 1956, PP.37-47 [71] Shampine, L.F. and Gordon, M.K. Computer Solution of Ordinary Differential Equations, Freeman, 1975 [71] Verner, J.H. Explicit Runge-Kutta methods with estimate of the local truncation error, SIAM J. Numer. Anal Vol.15, No.4, 1978 pp.772-790 [72] Jackson, K.R., Enright, W.H. and Hull, T.E. A theoretical criterion for comparing Runge-Kutta formulas,SIAM J.Numer, Anal., Vol.15, No.3, 1978, pp.618-641 [74] Gear, C.W. Numerical Initial Value Problems in Ordinary Differential Equations, Prentice-Hall, 1971 [75] Lambert, J.D. Computational Methods in Ordinary Differential Equations, Wiley, 1973 [76] Hindmarsh, A.C. and Byrne, G.D. EPISODE:An Effective Package for the Integration of Systems of Ordinary Differential Equations, UCID30112, Rev.1, Lawrence Livermore Laboratory, April 1977 [77] Byrne, G.D. and Hindmarsh, A.C. A Polyalgorithm for the Numerical Solution of Ordinary Differential Equations, ACM Transaction of Math. Soft., Vol.1, No.1, pp.71-96, March 1975. [78] Hart, J.F. Complete Elliptic Integrals, John Wiley & Sons, Computer Approximations, 1968. [79] Cody, W.J. and Thacher Jr, C.H. Rational Chebyshev Approximations for the Exponential Integral Ei, (x), Mathematics of Computation, Vol.22, pp.641-649, July 1968. [80] Cody, W.J. and Thacher Jr, C.H. Chebyshev Approximations for the Expontial Integral Ei (x), Mathematics of Computation, Vol.23, pp.289-303, Apr. 1969. [81] Yamauchi,J., Moriguchi,S. and Hitotsumatsu,S. The calculation of Bessel Function by using the recurrence formula. Baifukan Co., Numerical calculation for the computer II, pp.103-120, 1967. (Japanese only)
624
[82] Uno,T. Bessel Function. Baifukan Co., Numerical calculation for the computer III, pp.166-186, 1972. (Japanese only) [83] Yoshida,T., Asano,M., Umeno,M. and Miki,S. Recurrence Techniques for the Calculation of Bessel Function In(z) with Complex Argument. Journal of Information Processing Society of Japan, Vol.14, No.1, pp.23-29, Jan.1973. (Japanese only) [84] Yoshida,T., Ninomiya,I. Computation of Bessel Function Kn(n) with Complex Argument by Using the -method. Journal of Information Processing Society of Japan, Vol.14, No.8, pp.569-575, Aug.1973. (Japanese only) [85] Moriguchi, Utagawa and Hitotsumatsu Iwanami Formulae of Mathematics III. Iwanami Shoten, Publishers, 1967. (Japanese only) [86] Forsythe,G.E. (Mori,M.'s translation) Numerical Calculation for Computers - the computer science researches book series No.41. Kagaku Gijutsu Shuppan, 1978. (Japanese only) [87] Streck, A.J. On the Calculation of the Inverse of Error Function, Mathematics of Computation, Vol.22, 1968. [88] Yoshida,T. and Ninomiya,I. Computation of Modified Bessel Function Kv(x) with Small Argument x. Transactions of Information Processing Society of Japan, Vol.21, No.3, pp.238-245, May.1980 (Japanese only) [89] Nayler, T.H. Computer Simulation Techiques, John Wiley & Sons, Inc., 1966, pp.43-67. [90] Algorithm 334, Normal Random Deviates, Comm. ACM, 11 (July 1968) , p.498. [91] Pike, M.C. Algorithm 267, Random Normal Deviate, Comm. ACM, 8 (Oct. 1965), p.606.
[92] Wakimoto,K. Knowledge of random numbers. Morikita Shuppan, 1970. (Japanese only) [93] Miyatake,O. and Wakimoto,K. Random numbers and Monte Carlo method. Morikita Shuppan, 1978. (Japanese only) [94] Powell, M.J.D. A Fast Algorithm for Nonlinearly constranied Optimization Calculations. Proceedings of the 1977 Dundee Conference on Numerical Analysis, Lecture Notes in Mathematics, Springer-Verlag, 1978 [95] Powell, M.J.D., et al. The Watchdog Technique for forcing Convergence in Algorithms for Constrained Optimization, Presented at the Tenth International Symposium on Mathematical Programming, Montreal, 1979 [96] Ninomiya,I. Improvement of Adaptive Newton-Cotes Quadrature Methods. Journal of Information Processing Society of Japan, Vol.21, No.5, 1980, pp.504-512. (Japanese only) [97] Ninomiya, I. Improvements of Adaptive Newton-Cotes Quadrature Methods, Joumal of Information Processing, Vol.3, No.3, 1980, pp.162-170. [98] Hosono,T. Numerical Laplace transform. Transactions A of IEEJ, Vol.99-A, No.10, Oct.,1979 (Japanese only) [99] Hosono,T. Basis of the linear black box. CORONA Publishing Co., 1980. (Japanese only) [100] Bromwich, T.J.IA. Introduction to the Theory of Infinite Series. Macmillan.1926 [101] Hosono, T. Numerical inversion of Laplace transform and some applications to wave optics. International U.R.S.I-Symposium 1980 on Electromagnetic Waves, Munich, 1980.
625
Subroutine ODRK1 CGSBM CSBGM CSSBM CSBSM LSBIX SBMDM BMDMX LAXLM ASVD1 GINV CEIG2 CBLNC CHES2 CHSQR CHVEC CHBK2 CNRML BSEG BTRID BSVEC BSEGJ GBSEG AQN9 IERF IERFC NDF INDF NDFC INDFC RANNI FCOSF ECOSP FSINF ESINP FCHEB
T. Torii
Item A system of first order ordinary differential equations (Runge-Kutta-Verner method) Storage mode conversion of matrices (real general to real symmetric band) Storage mode conversion of matrices (real symmetric band to real general) Storage mode conversion of matrices (real symmetric to real symmetric band) Storage mode conversion of matrics (real symmetric band to real symmetric) A system of linear equations with a real indefinite symmetric band matrix (Block diagonal pivoting method) MDMT decomposition of a real indefinite symmetric band matrix (Block diagonal pivoting method) A system of linear equations with real indefinite symmetirc band matrix decomposed into the factors M, D and MT Least squares minimal norm solution with a real matrix (Singular value decomposition method) Singular value decomposition of a real matrix (Householder method, QR method) Moore-Penrose generalized inverse of a real matrix (Singular value decomposition method) Eigenvalues and corresponding eigenvectors of a complex matrix (QR method) Balancing of a complex matrix Reduction of a complex matrix to a complex Hessenberg matrix (Stabilized elementary similarity transformation method) Eigenvaluse of a complex Hessenberg matrix (QR method) Eigenvectors of a complex Hessenberg matrix (Inverse iteration method) Back transformation of the eigenvectors of a complex Hessenberg matrix to those of a complex matrix Normalization of eigenvectors of a complex matrix Eigenvalues and corresponding eigenvectors of a real symmetric band matrix (Lutishauser-Shwarz method, bisection method and inverse iteration method) Reduction of a rael symmetric band matrix to a tridiagonal matrix (Lutishauser-Schwarz method) Eigenvectors of a rael symmetric band matrix (Inverse iteration method) Eigenvalues and corresponding eigenvectors of a real symmetric band matrix (Jennings method) Eigenvalues and corresponding eigenvectors of a real symmetric band generalized eigenproblem Ax=BX (Jennings method) Integration of a function by adaptive Newton-Cotes 9-point rule Inverse error function erf-1 (x) Inverse complementary error function erfc-1 (x) Normal distribution function (x) Inverse normal distribution function -1 (x) Complementary normal distribution function (x) Inverse complementary normal distribution function -1 (x) Fast normal pseudo random numbers Fourier cosine series expansion of an even function (Function input, fast cosine transformation) Evaluation of a cosine series Fourier sine series expansion of an odd functon (Function input, fast sine transformation) Evaluation of a sine series Chebyshev series expansion of a real function
626
Author T. Torii
Subroutine ECHEB GCHEB ICHEB FCOST FCOSM FSINT FSINM T. Hasegawa AQC8 AQMC8 K.Hatano BICD1 BICD3 BIC1 BIC2 BIC3 BIC4 BIFD1 BIFD3 BIF1 BIF2 BIF3 BIF4 BSCD2 BSC1 BSC2 BSFD1 BSF1 Y.Hatano AKMID AQE AQEH AQEI AQME T.Yoshida CBIN CBKN CBJN CBYN BJR BYR BIR BKR CBJR
Item Evaluation of a Chebyshev series Differentiation of a Chebyshev series Indefinite integral for Chebyshev series Discrete consine transform (Trapezoidal rule, radix 2 FFT) Discrete cosine transform (midpoint rule, radix 2 FFT) Discrete sine transform (Trapezoidal rule, radix 2 FFT) Discrete sine transform (midpoint rule, radix 2 FFT) Integration of a function by a modified Clenshaw-Curtis rule Multiple integration of a function by a modified Clenshaw-Curtis rule B-spline two-dimensional interpolation coefficient calculation (I -I) B-spline two-dimensional interpolation coefficient calculation (III-III) B-spline Interpolation coefficient calculation (I) B-spline interpolation coefficient calculation (II) B-spline interpolation coefficient calculation (III) B-spline interpolation coefficient calculation (IV) B-spline two-dimensional interpolation, differentiation, and integration (I-I) B-spline two-dimensional interpolation, differentiation, and integration (III-III) B-spline interpolation differentiation, and integration (I) B-spline interpolation differentiation, and integration (II) B-spline interpolation differentiation, and integration (III) B-spline interpolation differentiation, and integration (IV) B-spline two-dimensional smoothing coefficient calculation variable knots B-spline smoothing coefficient calculation with fixed knots B-spline smoothing coefficient calculation variable knots B-spline two-dimensional smoothing B-spline smoothing differentiation, and integration Two-dimensional quasi-Hermite interpolation Integration of a function by double exponential formula Integration of a function over the semi-infinite interval by double exponential formula Integration of a function over the infinite interval by double exponential formula Multiple integration of a function by double exponential formula Integer order modified Bessel function of the first kind with a complex variable, In (z) Integer order modified Bessel function of the second kind with a complex variable,Kn (z) Integer order Bessel function of the first kind with a complex variable, Jn (z) Integer order Bessel function of the second kind with a complex variable, Yn (z) Real order Bessel function of the first kind, Jv (x) Real-order Bessel function of the second kind, Yv (x) Real order modified Bessel function of the first kind, Iv (x) Real order modified Bessel function of the second kind, Kv (x) Real order Bessel function of the first kind with a complex variable, Jv (z)
627
K.Tone
Minimization of function with a variable (Quadratic interpolation using function values only) Minimization of function with a variable (Qubic interpolation using function values and its derivatives) Minimization of a function with several variables (quasi-Newton method, using function values and its derivatives) Minimization of the sum of squares of functions with several variables (Revised Marquardt method, using function values only) Minimization of the sum of squares of functions (Revised Marquardt method using function values and its derivatives) Nonlinear programming problem (Powells method using function values only) Solution of linear programming problem (Revised simplex menthod) Inversion of laplace transform of a rational function (analytic in the right half plane) Inversion of laplace transform of a rational function Inversion of laplace transform of a general function Judgement on Hurwiz polynomials A system of first order ordinary differntial equations (Adams method) A stiff system of first order ordinary differential equations (Gears method)
T. Kobayashi T. Hosono
L.F. Shampine
ODAM*
* This program is based on that registered in ANL-NESC in U.S.A. The original code is available direcly form the Center. NESC: National Energy Software Center Argonne National Laboratory 9700 South Cass Avenue Argonne, IIIinois 60439 U.S.A.
628
Reply requested:
Yes
No
Please evaluate overall quality of this manual by marking () in the appropriate boxes. Good Fair Poor Good Fair Poor Good Fair Poor Organization: Use of examples: Legibility: Accuracy: Index coverage: Handiness/Binding: Clarity: Cross referencing: (Others): Figures & tables: General appearance: Technical level: Too high Appropriate Too low Overall rating of this publication: Good Fair Poor
Person in charge:
Note) Local representative should pass this form to the section in charge of distribution in FUJITSU.
By
FUJITSU LIMITED
_____________________________________________________________________________________________________
99SP4020E-1
_____________________________________________________________________________________________________