naginterfaces.library.linsys.real_sparse_fac_solve¶
- naginterfaces.library.linsys.real_sparse_fac_solve(a, comm, rhs, mtype)[source]¶
real_sparse_fac_solve
calculates the approximate solution of a set of real sparse linear equations with a single right-hand side, or , where has been factorized bymatop.real_gen_sparse_lu
ormatop.real_gen_sparse_lu_reuse
.For full information please refer to the NAG Library document for f04ax
https://support.nag.com/numeric/nl/nagdoc_30.1/flhtml/f04/f04axf.html
- Parameters
- afloat, array-like, shape
The nonzero elements in the factorization of the matrix , as returned by
matop.real_gen_sparse_lu
ormatop.real_gen_sparse_lu_reuse
.- commdict, communication object
Communication structure.
This argument must have been initialized by a prior call to
matop.real_gen_sparse_lu
.- rhsfloat, array-like, shape
The right-hand side vector .
- mtypeint
specifies the task to be performed.
Solve .
Solve .
- Returns
- rhsfloat, ndarray, shape
is overwritten by the solution vector .
- residfloat
The value of the maximum residual, , over all the unsatisfied equations, in case
matop.real_gen_sparse_lu
ormatop.real_gen_sparse_lu_reuse
has been used to factorize a singular or rectangular matrix.
- Raises
- NagValueError
- (errno )
On entry, .
Constraint: .
- Notes
No equivalent traditional C interface for this routine exists in the NAG Library.
To solve a system of real linear equations or , where is a general sparse matrix, must first be factorized by
matop.real_gen_sparse_lu
ormatop.real_gen_sparse_lu_reuse
.real_sparse_fac_solve
then computes by block forward or backward substitution using simple forward and backward substitution within each diagonal block.The method is fully described in Duff (1977).
A more recent method is available through solver function
sparse.direct_real_gen_solve
and factorization functionsparse.direct_real_gen_lu
.
- References
Duff, I S, 1977, MA28 – a set of Fortran subroutines for sparse unsymmetric linear equations, AERE Report R8730, HMSO