PDF version (NAG web site
, 64-bit version, 64-bit version)
NAG Toolbox: nag_eigen_withdraw_real_band_geneig (f02sd)
Purpose
nag_eigen_real_band_geneig (f02sd) finds the eigenvector corresponding to a given real eigenvalue for the generalized problem , or for the standard problem , where and are real band matrices.
Note: this function is scheduled to be withdrawn, please see
f02sd in
Advice on Replacement Calls for Withdrawn/Superseded Routines..
Syntax
[
a,
b,
vec,
d,
ifail] = f02sd(
ma1,
mb1,
a,
b,
sym,
relep,
rmu,
d, 'n',
n)
[
a,
b,
vec,
d,
ifail] = nag_eigen_withdraw_real_band_geneig(
ma1,
mb1,
a,
b,
sym,
relep,
rmu,
d, 'n',
n)
Description
Given an approximation to a real eigenvalue of the generalized eigenproblem , nag_eigen_real_band_geneig (f02sd) attempts to compute the corresponding eigenvector by inverse iteration.
nag_eigen_real_band_geneig (f02sd) first computes lower and upper triangular factors, and , of , using Gaussian elimination with interchanges, and then solves the equation , where – this is the first half iteration.
There are then three possible courses of action depending on the input value of
.
1. |
.
This setting should be used if is an ill-conditioned eigenvalue (provided the matrix elements do not vary widely in order of magnitude). In this case it is essential to accept only a vector found after one half iteration, and must be a very good approximation to . If acceptable growth is achieved in the solution of , then the normalized is accepted as the eigenvector. If not, columns of an orthogonal matrix are tried in turn in place of . If none of these give acceptable growth, the function fails, indicating that was not a sufficiently good approximation to . |
2. |
.
This setting should be used if is moderately close to an eigenvalue which is not ill-conditioned (provided the matrix elements do not differ widely in order of magnitude). If acceptable growth is achieved in the solution of , the normalized is accepted as the eigenvector. If not, inverse iteration is performed. Up to iterations are allowed to achieve a vector and a correction to which together give acceptably small residuals. |
3. |
.
This setting should be used if the elements of and vary widely in order of magnitude. Inverse iteration is performed, but a different convergence criterion is used. |
See
Algorithmic Details for further details.
Note that the bandwidth of the matrix must not be less than the bandwidth of . If this is not so, either must be filled out with zeros, or matrices and may be reversed and supplied as an approximation to the eigenvalue . Also it is assumed that and each have the same number of subdiagonals as superdiagonals. If this is not so, they must be filled out with zeros. If and are both symmetric, only the upper triangles need be supplied.
References
Peters G and Wilkinson J H (1979) Inverse iteration, ill-conditioned equations and Newton's method SIAM Rev. 21 339–360
Wilkinson J H (1965) The Algebraic Eigenvalue Problem Oxford University Press, Oxford
Wilkinson J H (1972) Inverse iteration in theory and practice Symposia Mathematica Volume X 361–379 Istituto Nazionale di Alta Matematica, Monograf, Bologna
Wilkinson J H (1974) Notes on inverse iteration and ill-conditioned eigensystems Acta Univ. Carolin. Math. Phys. 1–2 173–177
Wilkinson J H (1979) Kronecker's canonical form and the algorithm Linear Algebra Appl. 28 285–303
Parameters
Compulsory Input Parameters
- 1:
– int64int32nag_int scalar
-
The value , where is the number of nonzero lines on each side of the diagonal of . Thus the total bandwidth of is .
Constraint:
.
- 2:
– int64int32nag_int scalar
-
If
,
is assumed to be the unit matrix. Otherwise
mb1 must specify the value
, where
is the number of nonzero lines on each side of the diagonal of
. Thus the total bandwidth of
is
.
Constraint:
.
- 3:
– double array
-
lda, the first dimension of the array, must satisfy the constraint
.
The
by
band matrix
. The
subdiagonals must be stored in the first
rows of the array; the diagonal in the (
)th row; and the
superdiagonals in rows
to
. Each row of the matrix must be stored in the corresponding column of the array. For example, if
and
the storage scheme is:
Elements of the array marked
need not be set. The following code assigns the matrix elements within the band to the correct elements of the array:
for j=1:n
for i=max(1,j-ma1+1):min(n,j+ma1-1)
a(i-j+ma1,j) = matrix(i,j);
end
end
If
(i.e., both
and
are symmetric), only the lower triangle of
need be stored in the first
ma1 rows of the array.
- 4:
– double array
-
ldb, the first dimension of the array, must satisfy the constraint
- if , ;
- if , .
If
,
b must contain the
by
band matrix
, stored in the same way as
. If
, only the lower triangle of
need be stored in the first
mb1 rows of the array.
If , the array is not used.
- 5:
– logical scalar
-
If
, both
and
are assumed to be symmetric and only their upper triangles need be stored. Otherwise
sym must be set to
false.
- 6:
– double scalar
-
The relative error of the coefficients of the given matrices
and
. If the value of
relep is less than the
machine precision, the
machine precision is used instead.
- 7:
– double scalar
-
, an approximation to the eigenvalue for which the corresponding eigenvector is required.
- 8:
– double array
-
must be set to indicate the type of problem (see
Description):
- Indicates a well-conditioned eigenvalue.
- Indicates an ill-conditioned eigenvalue.
- Indicates that the matrices have elements varying widely in order of magnitude.
Optional Input Parameters
- 1:
– int64int32nag_int scalar
-
Default:
the second dimension of the arrays
a,
b. (An error is raised if these dimensions are not equal.)
, the order of the matrices and .
Constraint:
.
Output Parameters
- 1:
– double array
-
Details of the factorization of , where is an estimate of the eigenvalue.
- 2:
– double array
-
Elements in the top-left corner, and in the bottom right corner if , are set to zero; otherwise the array is unchanged.
- 3:
– double array
-
The eigenvector, normalized so that the largest element is unity, corresponding to the improved eigenvalue .
- 4:
– double array
-
If
on entry, the successive corrections to
are given in
, for
, where
is the total number of iterations performed. The final correction is also given in the last position,
, of the array. The remaining elements of
d are set to zero.
If on entry, no corrections to are computed and
is set to , for . Thus in all three cases the best available approximation to the eigenvalue is .
- 5:
– int64int32nag_int scalar
unless the function detects an error (see
Error Indicators and Warnings).
Error Indicators and Warnings
Errors or warnings detected by the function:
-
-
On entry, | , |
or | , |
or | , |
or | , |
or | when , |
or | when (ldb is not checked if ). |
-
-
On entry, | . Either fill out a with zeros, or reverse the roles of a and b, and replace rmu by its reciprocal, i.e., solve |
-
-
On entry, | when , |
or | when . |
-
-
is null. If
is nonsingular, all the eigenvalues are zero and any set of
n orthogonal vectors forms the eigensolution.
-
-
is null. If is nonsingular, all the eigenvalues are infinite, and the columns of the unit matrix are eigenvectors.
-
-
On entry, | and are both null. The eigensolution is arbitrary. |
-
-
on entry and convergence is not achieved in
iterations. Either the eigenvalue is ill-conditioned or
rmu is a poor approximation to the eigenvalue. See
Algorithmic Details.
-
-
on entry and no eigenvector has been found after
back-substitutions.
rmu is not a sufficiently good approximation to the eigenvalue.
-
-
on entry and
rmu is too inaccurate for the solution to converge.
-
An unexpected error has been triggered by this routine. Please
contact
NAG.
-
Your licence key may have expired or may not have been installed correctly.
-
Dynamic memory allocation failed.
Accuracy
The eigensolution is exact for some problem
where
are of the order of
, where
is the value used for
relep.
Further Comments
Timing
The time taken by nag_eigen_real_band_geneig (f02sd) is approximately proportional to for factorization, and to for each iteration.
Storage
The storage of the matrices and is designed for efficiency on a paged machine.
nag_eigen_real_band_geneig (f02sd) will work with full matrices but it will do so inefficiently, particularly in respect of storage requirements.
Algorithmic Details
Inverse iteration is performed according to the rule
where
is the element of
of largest magnitude.
Thus:
Hence the residual corresponding to
is very small if
is very large (see
Peters and Wilkinson (1979)). The first half iteration,
, corresponds to taking
.
If
is a very accurate eigenvalue, then there should always be an initial vector
such that one half iteration gives a small residual and thus a good eigenvector. If the eigenvalue is ill-conditioned, then second and subsequent iterated vectors may not be even remotely close to an eigenvector of a neighbouring problem (see pages 374–376 of
Wilkinson (1972) and
Wilkinson (1974)). In this case it is essential to accept only a vector obtained after one half iteration.
However, for well-conditioned eigenvalues, there is no loss in performing more than one iteration (see page 376 of
Wilkinson (1972)), and indeed it will be necessary to iterate if
is not such a good approximation to the eigenvalue. When the iteration has converged,
will be some multiple of
,
, say.
Therefore
giving
Thus
is a better approximation to the eigenvalue.
is obtained as the element of
which corresponds to the element of largest magnitude,
, in
. The function terminates when
is of the order of the
machine precision relative to
.
If the elements of and vary widely in order of magnitude, then and are excessively large and a different convergence test is required. The function terminates when the difference between successive corrections to is small relative to .
In practice one does not necessarily know if the given problem is well-conditioned or ill-conditioned. In order to provide some information on the condition of the eigenvalue or the accuracy of
in the event of failure, successive values of
are stored in the vector
d when
is nonzero on input. If these values appear to be converging steadily, then it is likely that
was a poor approximation to the eigenvalue and it is worth trying again with
as the initial approximation. If the values in
d vary considerably in magnitude, then the eigenvalue is ill-conditioned.
A discussion of the significance of the singularity of
and/or
is given in relation to the
algorithm in
Wilkinson (1979).
Example
Given the generalized eigenproblem
where
find the eigenvector corresponding to the approximate eigenvalue
.
Although
is symmetric,
is not, so
sym must be set to
false and all the elements of
in the band must be supplied to the function.
(as written above) has
subdiagonal and
superdiagonals, so
ma1 must be set to
and
filled out with an additional subdiagonal of zeros. Each row of the matrices is read in as data in turn.
Open in the MATLAB editor:
f02sd_example
function f02sd_example
fprintf('f02sd example results\n\n');
a = [0, 0, 0, 0, 0;
0,-1,-1,-1,-1;
1, 2, 3, 4, 5;
1, 1, 1, 1, 0;
2, 2, 2, 0, 0];
b = [0, 1, 2, 2, 1;
5, 4, 3, 2, 1;
1, 2, 2, 1, 0];
ma1 = int64(2+1);
mb1 = int64(1+1);
sym = false;
rmu = -12.33;
relep = 0;
d = zeros(30, 1);
d(1) = 1;
[a, b, vec, d, ifail] = f02sd( ...
ma1, mb1, a, b, sym, relep, rmu, d);
eval = rmu + d(30);
disp('Corrected eigenvalue');
disp(eval);
disp('Eigenvector')
disp(vec/norm(vec));
f02sd example results
Corrected eigenvalue
-12.3394
Eigenvector
-0.0377
0.2606
-0.5560
0.6598
-0.4315
PDF version (NAG web site
, 64-bit version, 64-bit version)
© The Numerical Algorithms Group Ltd, Oxford, UK. 2009–2015