1DGBRFS(1) LAPACK routine (version 3.1) DGBRFS(1)
2
3
4
6 DGBRFS - the computed solution to a system of linear equations when the
7 coefficient matrix is banded, and provides error bounds and backward
8 error estimates for the solution
9
11 SUBROUTINE DGBRFS( TRANS, N, KL, KU, NRHS, AB, LDAB, AFB, LDAFB, IPIV,
12 B, LDB, X, LDX, FERR, BERR, WORK, IWORK, INFO )
13
14 CHARACTER TRANS
15
16 INTEGER INFO, KL, KU, LDAB, LDAFB, LDB, LDX, N, NRHS
17
18 INTEGER IPIV( * ), IWORK( * )
19
20 DOUBLE PRECISION AB( LDAB, * ), AFB( LDAFB, * ), B( LDB, *
21 ), BERR( * ), FERR( * ), WORK( * ), X( LDX, * )
22
24 DGBRFS improves the computed solution to a system of linear equations
25 when the coefficient matrix is banded, and provides error bounds and
26 backward error estimates for the solution.
27
28
30 TRANS (input) CHARACTER*1
31 Specifies the form of the system of equations:
32 = 'N': A * X = B (No transpose)
33 = 'T': A**T * X = B (Transpose)
34 = 'C': A**H * X = B (Conjugate transpose = Transpose)
35
36 N (input) INTEGER
37 The order of the matrix A. N >= 0.
38
39 KL (input) INTEGER
40 The number of subdiagonals within the band of A. KL >= 0.
41
42 KU (input) INTEGER
43 The number of superdiagonals within the band of A. KU >= 0.
44
45 NRHS (input) INTEGER
46 The number of right hand sides, i.e., the number of columns of
47 the matrices B and X. NRHS >= 0.
48
49 AB (input) DOUBLE PRECISION array, dimension (LDAB,N)
50 The original band matrix A, stored in rows 1 to KL+KU+1. The
51 j-th column of A is stored in the j-th column of the array AB
52 as follows: AB(ku+1+i-j,j) = A(i,j) for max(1,j-
53 ku)<=i<=min(n,j+kl).
54
55 LDAB (input) INTEGER
56 The leading dimension of the array AB. LDAB >= KL+KU+1.
57
58 AFB (input) DOUBLE PRECISION array, dimension (LDAFB,N)
59 Details of the LU factorization of the band matrix A, as com‐
60 puted by DGBTRF. U is stored as an upper triangular band
61 matrix with KL+KU superdiagonals in rows 1 to KL+KU+1, and the
62 multipliers used during the factorization are stored in rows
63 KL+KU+2 to 2*KL+KU+1.
64
65 LDAFB (input) INTEGER
66 The leading dimension of the array AFB. LDAFB >= 2*KL*KU+1.
67
68 IPIV (input) INTEGER array, dimension (N)
69 The pivot indices from DGBTRF; for 1<=i<=N, row i of the matrix
70 was interchanged with row IPIV(i).
71
72 B (input) DOUBLE PRECISION array, dimension (LDB,NRHS)
73 The right hand side matrix B.
74
75 LDB (input) INTEGER
76 The leading dimension of the array B. LDB >= max(1,N).
77
78 X (input/output) DOUBLE PRECISION array, dimension (LDX,NRHS)
79 On entry, the solution matrix X, as computed by DGBTRS. On
80 exit, the improved solution matrix X.
81
82 LDX (input) INTEGER
83 The leading dimension of the array X. LDX >= max(1,N).
84
85 FERR (output) DOUBLE PRECISION array, dimension (NRHS)
86 The estimated forward error bound for each solution vector X(j)
87 (the j-th column of the solution matrix X). If XTRUE is the
88 true solution corresponding to X(j), FERR(j) is an estimated
89 upper bound for the magnitude of the largest element in (X(j) -
90 XTRUE) divided by the magnitude of the largest element in X(j).
91 The estimate is as reliable as the estimate for RCOND, and is
92 almost always a slight overestimate of the true error.
93
94 BERR (output) DOUBLE PRECISION array, dimension (NRHS)
95 The componentwise relative backward error of each solution vec‐
96 tor X(j) (i.e., the smallest relative change in any element of
97 A or B that makes X(j) an exact solution).
98
99 WORK (workspace) DOUBLE PRECISION array, dimension (3*N)
100
101 IWORK (workspace) INTEGER array, dimension (N)
102
103 INFO (output) INTEGER
104 = 0: successful exit
105 < 0: if INFO = -i, the i-th argument had an illegal value
106
108 ITMAX is the maximum number of steps of iterative refinement.
109
110
111
112 LAPACK routine (version 3.1) November 2006 DGBRFS(1)