ITSOLVER Call
solves a sparse linear system by using iterative methods
- CALL ITSOLVER( x, error, iter, method, A, b, <precon>, <tol>, <maxiter>, <start>, <history>);
The ITSOLVER call returns the following values:
- x
- is the solution to
.
- error
- is the final relative error of the solution.
- iter
- is the number of iterations executed.
The inputs to the ITSOLVER call are as follows:
- method
- is the type of iterative method to use.
- A
- is the sparse coefficient matrix in the equation
.
- b
- is a column vector, the right side of the equation
.
- precon
- is the name of a preconditioning technique to use.
- tol
- is the relative error tolerance.
- maxiter
- is the iteration limit.
- start
- is a starting point column vector.
- history
- is a matrix to store the relative error at each iteration.
The ITSOLVER call solves a sparse linear system by iterative methods, which
involve updating a trial solution over successive iterations to minimize the error.
The ITSOLVER call uses the technique specified in the
data:image/s3,"s3://crabby-images/29a42/29a422416b2225c5ffb00b739158f2b9a1ada7c4" alt="method"
parameter to update the solution. The accepted
data:image/s3,"s3://crabby-images/29a42/29a422416b2225c5ffb00b739158f2b9a1ada7c4" alt="method"
options are as follows:
- method = 'CG':
- conjugate gradient algorithm, when A is symmetric and positive definite.
- method = 'CGS':
- conjugate gradient squared algorithm, for general A.
- method = 'MINRES':
- minimum residual algorithm, when A is symmetric indefinite.
- method = 'BICG':
- biconjugate gradient algorithm, for general A.
The input matrix
data:image/s3,"s3://crabby-images/9a2f7/9a2f733f64e5de2351c9413b5e01a1128bde5056" alt="a"
represents
the coefficient matrix in sparse format; it is an
data:image/s3,"s3://crabby-images/21119/2111915c6a8bb78918e103e82da0d53051c09971" alt="x"
3 matrix, where
data:image/s3,"s3://crabby-images/a5ae5/a5ae5bd45e56315109d7592bd087485e20f89f3a" alt="n"
is the number of nonzero elements. The first column
contains the nonzero values, while the second and third columns contain the
row and column locations for the nonzero elements, respectively. For the algorithms assuming symmetric
data:image/s3,"s3://crabby-images/9a2f7/9a2f733f64e5de2351c9413b5e01a1128bde5056" alt="a"
, conjugate gradient, and minimum residual, only the lower triangular elements should be specified. The algorithm
continues iterating to improve the solution until either the relative error tolerance
specified in
data:image/s3,"s3://crabby-images/a5ed4/a5ed400406283c7927f05a34678f2273fb4d652e" alt="tol"
is satisfied or the maximum number of iterations specified
in
data:image/s3,"s3://crabby-images/27139/27139e36a9ce16d9166ed94f7930cd8d5b123929" alt="maxiter"
is reached. The relative error is defined as
data:image/s3,"s3://crabby-images/5eaa3/5eaa3e5300a987c31ae35e4f6ab3baf20127dd65" alt="error = \vert ax - b\vert _2 / (\vert b \vert _2 + \epsilon )"
where the
data:image/s3,"s3://crabby-images/0f0bf/0f0bfbfe6d1ff0458dff8153d9d5b2eae726337a" alt="\vert \cdot \vert _2"
operator is the Euclidean norm, and
data:image/s3,"s3://crabby-images/0f90e/0f90e21c567ebaa6b8dae87f174fcbdecbcdceb4" alt="\epsilon"
is a
machine-dependent epsilon value
to prevent any division by zero. If
data:image/s3,"s3://crabby-images/a5ed4/a5ed400406283c7927f05a34678f2273fb4d652e" alt="tol"
or
data:image/s3,"s3://crabby-images/27139/27139e36a9ce16d9166ed94f7930cd8d5b123929" alt="maxiter"
is not specified in the call, then a
default value of
data:image/s3,"s3://crabby-images/db6df/db6dffb0c09bf53a6a40db7e45ccc4ca5ba25ef6" alt="10^{-7}"
is used for
data:image/s3,"s3://crabby-images/a5ed4/a5ed400406283c7927f05a34678f2273fb4d652e" alt="tol"
and 100000 for
data:image/s3,"s3://crabby-images/27139/27139e36a9ce16d9166ed94f7930cd8d5b123929" alt="maxiter"
.
The convergence of an iterative algorithm can often be enhanced by
preconditioning the input coefficient matrix. The preconditioning option
is specified with the
data:image/s3,"s3://crabby-images/6e824/6e82418bf5567a508cc7856f3cdd66838df3c08b" alt="precon"
parameter, which can take one of the following
values:
- precon = 'NONE':
- no preconditioning
- precon = 'IC':
- incomplete Cholesky factorization, for
= 'CG' or 'MINRES' only
- precon = 'DIAG':
- diagonal Jacobi preconditioner, for
= 'CG' or 'MINRES' only
- precon = 'MILU':
- modified incomplete LU factorization, for
= 'BICG' only
If
data:image/s3,"s3://crabby-images/6e824/6e82418bf5567a508cc7856f3cdd66838df3c08b" alt="precon"
is not specified, no preconditioning is applied.
A starting trial solution can be specified with the
data:image/s3,"s3://crabby-images/7ea91/7ea913d5d8d48b3ccdd56c3f6000b50fcd0c2b74" alt="start"
parameter; otherwise
the ITSOLVER call generates a zero starting point. You can supply a matrix to
store the relative error at each iteration with the
data:image/s3,"s3://crabby-images/1bcb7/1bcb7801ba0fd11da563dd2798fb3195db1abd23" alt="history"
parameter. The
data:image/s3,"s3://crabby-images/1bcb7/1bcb7801ba0fd11da563dd2798fb3195db1abd23" alt="history"
matrix should be dimensioned with enough elements to store the maximum number
of iterations you expect.
Your IML program should always check the returned
data:image/s3,"s3://crabby-images/d8e70/d8e7068b943da59256754b42446c32cafdf3f288" alt="error"
and
data:image/s3,"s3://crabby-images/c97be/c97be020d79d4c2e4f48f85fb9f25b10724e14e2" alt="iter"
parameters to verify that the desired relative error tolerance was
reached. If not, your program might continue the solution process with another
ITSOLVER call, with
data:image/s3,"s3://crabby-images/7ea91/7ea913d5d8d48b3ccdd56c3f6000b50fcd0c2b74" alt="start"
set to the latest result. You might also try a
different
data:image/s3,"s3://crabby-images/6e824/6e82418bf5567a508cc7856f3cdd66838df3c08b" alt="precon"
option to enhance convergence.
For example, use the biconjugate gradient algorithm to solve the system
![[ 3 & 2 & 0 & 0 \ 1.1 & 4 & 1 & 3.2 \ 0 & 1 & -10 & 0 \ 0 & 3.2 & 0 & 3 ] x = [ 1 \ 1 \ 1 \ 1 ]](images/langref_langrefeq475.gif)
Here is the code:
/* value row column */
A = { 3 1 1,
2 1 2,
1.1 2 1,
4 2 2,
1 3 2,
3.2 4 2,
-10 3 3,
3 4 4};
/* right hand side */
b = {1, 1, 1, 1};
maxiter = 10;
hist = j(maxiter,1,.);
start = {1,1,1,1};
tol = 1e-10;
call itsolver(x, error, iter, 'bicg', A, b, 'milu', tol,
maxiter, start, hist);
print x;
print iter error;
print hist;
The results are as follows:
X
0.2040816
0.1938776
-0.080612
0.1265306
ITER ERROR
3 3.494E-16
HIST
0.0254375
0.0080432
3.494E-16
.
.
.
.
.
.
.
Use the conjugate gradient algorithm solve the symmetric positive definite system
![[ 3 & 1.1 & 0 & 0 \ 1.1 & 4 & 1 & 3.2 \ 0 & 1 & 10 & 0 \ 0 & 3.2 & 0 & 3 ] x = [ 1 \ 1 \ 1 \ 1 ]](images/langref_langrefeq476.gif)
Here is the code:
/* value row column */
A = { 3 1 1,
1.1 2 1,
4 2 2,
1 3 2,
3.2 4 2,
10 3 3,
3 4 4};
/* right hand side */
b = {1, 1, 1, 1};
call itsolver(x, error, iter, 'CG', A, b);
print x, iter, error;
The results are as follows:
X
2.68
-6.4
0.74
7.16
ITER
4
ERROR
5.77E-15