public abstract class PreconditionedIterativeLinearSolver extends IterativeLinearSolver
This abstract class defines preconditioned iterative solvers. When A is ill-conditioned, instead of solving system A · x = b directly, it is preferable to solve either
Concrete implementations of this abstract class must be provided with the
preconditioner M, as a RealLinearOperator
.
Constructor and Description |
---|
PreconditionedIterativeLinearSolver(int maxIterations)
Creates a new instance of this class, with default iteration manager.
|
PreconditionedIterativeLinearSolver(IterationManager manager)
Creates a new instance of this class, with custom iteration manager.
|
Modifier and Type | Method and Description |
---|---|
protected static void |
checkParameters(RealLinearOperator a,
RealLinearOperator m,
RealVector b,
RealVector x0)
Performs all dimension checks on the parameters of
solve
and
solveInPlace ,
and throws an exception if one of the checks fails. |
RealVector |
solve(RealLinearOperator a,
RealLinearOperator m,
RealVector b)
Returns an estimate of the solution to the linear system A · x =
b.
|
RealVector |
solve(RealLinearOperator a,
RealLinearOperator m,
RealVector b,
RealVector x0)
Returns an estimate of the solution to the linear system A · x =
b.
|
RealVector |
solve(RealLinearOperator a,
RealVector b)
Returns an estimate of the solution to the linear system A · x =
b.
|
RealVector |
solve(RealLinearOperator a,
RealVector b,
RealVector x0)
Returns an estimate of the solution to the linear system A · x =
b.
|
abstract RealVector |
solveInPlace(RealLinearOperator a,
RealLinearOperator m,
RealVector b,
RealVector x0)
Returns an estimate of the solution to the linear system A · x =
b.
|
RealVector |
solveInPlace(RealLinearOperator a,
RealVector b,
RealVector x0)
Returns an estimate of the solution to the linear system A · x =
b.
|
checkParameters, getIterationManager
public PreconditionedIterativeLinearSolver(int maxIterations)
maxIterations
- the maximum number of iterationspublic PreconditionedIterativeLinearSolver(IterationManager manager) throws NullArgumentException
manager
- the custom iteration managerNullArgumentException
- if manager
is null
public RealVector solve(RealLinearOperator a, RealLinearOperator m, RealVector b, RealVector x0) throws MathIllegalArgumentException, NullArgumentException, MathIllegalStateException
a
- the linear operator A of the systemm
- the preconditioner, M (can be null
)b
- the right-hand side vectorx0
- the initial guess of the solutionNullArgumentException
- if one of the parameters is null
MathIllegalArgumentException
- if a
or m
is not
squareMathIllegalArgumentException
- if m
, b
or
x0
have dimensions inconsistent with a
MathIllegalStateException
- at exhaustion of the iteration count,
unless a custom
callback
has been set at construction of the IterationManager
public RealVector solve(RealLinearOperator a, RealVector b) throws MathIllegalArgumentException, NullArgumentException, MathIllegalStateException
solve
in class IterativeLinearSolver
a
- the linear operator A of the systemb
- the right-hand side vectorMathIllegalArgumentException
- if a
is not squareNullArgumentException
- if one of the parameters is null
MathIllegalStateException
- at exhaustion of the iteration count,
unless a custom
callback
has been set at construction of the IterationManager
public RealVector solve(RealLinearOperator a, RealVector b, RealVector x0) throws MathIllegalArgumentException, NullArgumentException, MathIllegalStateException
solve
in class IterativeLinearSolver
a
- the linear operator A of the systemb
- the right-hand side vectorx0
- the initial guess of the solutionMathIllegalArgumentException
- if a
is not squareNullArgumentException
- if one of the parameters is null
MathIllegalStateException
- at exhaustion of the iteration count,
unless a custom
callback
has been set at construction of the IterationManager
protected static void checkParameters(RealLinearOperator a, RealLinearOperator m, RealVector b, RealVector x0) throws MathIllegalArgumentException, NullArgumentException
solve
and
solveInPlace
,
and throws an exception if one of the checks fails.a
- the linear operator A of the systemm
- the preconditioner, M (can be null
)b
- the right-hand side vectorx0
- the initial guess of the solutionNullArgumentException
- if one of the parameters is null
MathIllegalArgumentException
- if a
or m
is not
squareMathIllegalArgumentException
- if m
, b
or
x0
have dimensions inconsistent with a
public RealVector solve(RealLinearOperator a, RealLinearOperator m, RealVector b) throws MathIllegalArgumentException, NullArgumentException, MathIllegalStateException
a
- the linear operator A of the systemm
- the preconditioner, M (can be null
)b
- the right-hand side vectorNullArgumentException
- if one of the parameters is null
MathIllegalArgumentException
- if a
or m
is not
squareMathIllegalArgumentException
- if m
or b
have
dimensions inconsistent with a
MathIllegalStateException
- at exhaustion of the iteration count,
unless a custom
callback
has been set at construction of the IterationManager
public abstract RealVector solveInPlace(RealLinearOperator a, RealLinearOperator m, RealVector b, RealVector x0) throws MathIllegalArgumentException, NullArgumentException, MathIllegalStateException
a
- the linear operator A of the systemm
- the preconditioner, M (can be null
)b
- the right-hand side vectorx0
- the initial guess of the solutionx0
(shallow copy) updated with the
solutionNullArgumentException
- if one of the parameters is null
MathIllegalArgumentException
- if a
or m
is not
squareMathIllegalArgumentException
- if m
, b
or
x0
have dimensions inconsistent with a
MathIllegalStateException
- at exhaustion of the iteration count,
unless a custom
callback
has been set at construction of the IterationManager
public RealVector solveInPlace(RealLinearOperator a, RealVector b, RealVector x0) throws MathIllegalArgumentException, NullArgumentException, MathIllegalStateException
solveInPlace
in class IterativeLinearSolver
a
- the linear operator A of the systemb
- the right-hand side vectorx0
- initial guess of the solutionx0
(shallow copy) updated with the
solutionMathIllegalArgumentException
- if a
is not squareNullArgumentException
- if one of the parameters is null
MathIllegalStateException
- at exhaustion of the iteration count,
unless a custom
callback
has been set at construction of the IterationManager
Copyright © 2016-2022 CS GROUP. All rights reserved.