1. Minor changes to Javadoc of SYMMLQ implementation, following Pr. M. A. Saunders review.
2. Added Michael Saunders as a contributor in the POM. git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1188549 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
9ca170c67f
commit
a9cf068da8
3
pom.xml
3
pom.xml
|
@ -227,6 +227,9 @@
|
||||||
<contributor>
|
<contributor>
|
||||||
<name>Joni Salonen</name>
|
<name>Joni Salonen</name>
|
||||||
</contributor>
|
</contributor>
|
||||||
|
<contributor>
|
||||||
|
<name>Michael Saunders</name>
|
||||||
|
</contributor>
|
||||||
<contributor>
|
<contributor>
|
||||||
<name>Christopher Schuck</name>
|
<name>Christopher Schuck</name>
|
||||||
</contributor>
|
</contributor>
|
||||||
|
|
|
@ -48,11 +48,11 @@ import org.apache.commons.math.util.MathUtils;
|
||||||
* definite (but <em>must</em> be self-adjoint). The work per iteration is very
|
* definite (but <em>must</em> be self-adjoint). The work per iteration is very
|
||||||
* slightly less if shift = 0.
|
* slightly less if shift = 0.
|
||||||
* </p>
|
* </p>
|
||||||
* <h3>Peconditioning</h3>
|
* <h3>Preconditioning</h3>
|
||||||
* <p>
|
* <p>
|
||||||
* Preconditioning may reduce the number of iterations required. The solver is
|
* Preconditioning may reduce the number of iterations required. The solver may be
|
||||||
* provided with a positive definite preconditioner M = C · C<sup>T</sup>
|
* provided with a positive definite preconditioner M = C · C<sup>T</sup>
|
||||||
* that is known to approximate (A - shift · I) in some sense, while
|
* that is known to approximate (A - shift · I) in some sense, where
|
||||||
* systems of the form M · y = x can be solved efficiently. Then SYMMLQ
|
* systems of the form M · y = x can be solved efficiently. Then SYMMLQ
|
||||||
* will implicitly solve the system of equations P · (A - shift ·
|
* will implicitly solve the system of equations P · (A - shift ·
|
||||||
* I) · P<sup>T</sup> · xhat = P · b, i.e. Ahat ·
|
* I) · P<sup>T</sup> · xhat = P · b, i.e. Ahat ·
|
||||||
|
@ -74,16 +74,31 @@ import org.apache.commons.math.util.MathUtils;
|
||||||
* In the present context, an iteration should be understood as one evaluation
|
* In the present context, an iteration should be understood as one evaluation
|
||||||
* of the matrix-vector product A · x. The initialization phase therefore
|
* of the matrix-vector product A · x. The initialization phase therefore
|
||||||
* counts as one iteration. If the user requires checks on the symmetry of A,
|
* counts as one iteration. If the user requires checks on the symmetry of A,
|
||||||
* this entails one further matrix-vector product by iteration. This further
|
* this entails one further matrix-vector product in the initial phase. This
|
||||||
* product is <em>not</em> accounted for in the iteration count. In other words,
|
* further product is <em>not</em> accounted for in the iteration count. In
|
||||||
* the number of iterations required to reach convergence will be identical,
|
* other words, the number of iterations required to reach convergence will be
|
||||||
* whether checks have been required or not.
|
* identical, whether checks have been required or not.
|
||||||
* </p>
|
* </p>
|
||||||
* <p>
|
* <p>
|
||||||
* The present definition of the iteration count differs from that adopted in
|
* The present definition of the iteration count differs from that adopted in
|
||||||
* the original FOTRAN code, where the initialization phase was <em>not</em>
|
* the original FOTRAN code, where the initialization phase was <em>not</em>
|
||||||
* taken into account.
|
* taken into account.
|
||||||
* </p>
|
* </p>
|
||||||
|
* <h3><a id="initguess">Initial guess of the solution</a></h3>
|
||||||
|
* <p>
|
||||||
|
* The {@code x} parameter in
|
||||||
|
* <ul>
|
||||||
|
* <li>{@link #solve(RealLinearOperator, RealVector, RealVector)},</li>
|
||||||
|
* <li>{@link #solve(RealLinearOperator, InvertibleRealLinearOperator, RealVector, RealVector)}},</li>
|
||||||
|
* <li>{@link #solveInPlace(RealLinearOperator, RealVector, RealVector)},</li>
|
||||||
|
* <li>{@link #solveInPlace(RealLinearOperator, InvertibleRealLinearOperator, RealVector, RealVector)},</li>
|
||||||
|
* <li>{@link #solveInPlace(RealLinearOperator, InvertibleRealLinearOperator, RealVector, RealVector, boolean, double)},</li>
|
||||||
|
* </ul>
|
||||||
|
* should not be considered as an initial guess, as it is set to zero in the
|
||||||
|
* initial phase. If x<sub>0</sub> is known to be a good approximation to x, one
|
||||||
|
* should compute r<sub>0</sub> = b - A · x, solve A · dx = r0,
|
||||||
|
* and set x = x<sub>0</sub> + dx.
|
||||||
|
* </p>
|
||||||
* <h3><a id="context">Exception context</a></h3>
|
* <h3><a id="context">Exception context</a></h3>
|
||||||
* <p>
|
* <p>
|
||||||
* Besides standard {@link DimensionMismatchException}, this class might throw
|
* Besides standard {@link DimensionMismatchException}, this class might throw
|
||||||
|
@ -136,8 +151,8 @@ public class SymmLQ
|
||||||
* 1. Preconditioning
|
* 1. Preconditioning
|
||||||
* ---------------
|
* ---------------
|
||||||
* The Lanczos iterations associated with Ahat and bhat read
|
* The Lanczos iterations associated with Ahat and bhat read
|
||||||
* beta[1] = |P . b|
|
* beta[1] = ||P * b||
|
||||||
* v[1] = P.b / beta[1]
|
* v[1] = P * b / beta[1]
|
||||||
* beta[k+1] * v[k+1] = Ahat * v[k] - alpha[k] * v[k] - beta[k] * v[k-1]
|
* beta[k+1] * v[k+1] = Ahat * v[k] - alpha[k] * v[k] - beta[k] * v[k-1]
|
||||||
* = P * (A - shift * I) * P' * v[k] - alpha[k] * v[k]
|
* = P * (A - shift * I) * P' * v[k] - alpha[k] * v[k]
|
||||||
* - beta[k] * v[k-1]
|
* - beta[k] * v[k-1]
|
||||||
|
@ -164,11 +179,11 @@ public class SymmLQ
|
||||||
* 3. Accounting for the goodb flag
|
* 3. Accounting for the goodb flag
|
||||||
* -----------------------------
|
* -----------------------------
|
||||||
* When goodb is set to true, the component of xL along b is computed
|
* When goodb is set to true, the component of xL along b is computed
|
||||||
* separately. From Page and Saunders (1975), equation (5.9), we have
|
* separately. From Paige and Saunders (1975), equation (5.9), we have
|
||||||
* wbar[k+1] = s[k] * wbar[k] - c[k] * v[k+1],
|
* wbar[k+1] = s[k] * wbar[k] - c[k] * v[k+1],
|
||||||
* wbar[1] = v[1].
|
* wbar[1] = v[1].
|
||||||
* Introducing wbar2[k] = wbar[k] - s[1] * ... * s[k-1] * v[1], it can
|
* Introducing wbar2[k] = wbar[k] - s[1] * ... * s[k-1] * v[1], it can
|
||||||
* easily be verified by induction that what follows the same recursive
|
* easily be verified by induction that wbar2 follows the same recursive
|
||||||
* relation
|
* relation
|
||||||
* wbar2[k+1] = s[k] * wbar2[k] - c[k] * v[k+1],
|
* wbar2[k+1] = s[k] * wbar2[k] - c[k] * v[k+1],
|
||||||
* wbar2[1] = 0,
|
* wbar2[1] = 0,
|
||||||
|
@ -317,8 +332,7 @@ public class SymmLQ
|
||||||
* @param m Preconditioner (can be {@code null}).
|
* @param m Preconditioner (can be {@code null}).
|
||||||
* @param b Right-hand side vector.
|
* @param b Right-hand side vector.
|
||||||
* @param x Vector to be updated with the solution. {@code x} should not
|
* @param x Vector to be updated with the solution. {@code x} should not
|
||||||
* be considered as an initial guess, as it is set to 0 in the
|
* be considered as an initial guess (<a href="#initguess">more</a>).
|
||||||
* initialization phase.
|
|
||||||
* @param goodb Usually {@code false}, except if {@code x} is expected
|
* @param goodb Usually {@code false}, except if {@code x} is expected
|
||||||
* to contain a large multiple of {@code b}.
|
* to contain a large multiple of {@code b}.
|
||||||
* @param shift The amount to be subtracted to all diagonal elements of
|
* @param shift The amount to be subtracted to all diagonal elements of
|
||||||
|
@ -676,7 +690,7 @@ public class SymmLQ
|
||||||
* @param delta δ parameter for the default stopping criterion.
|
* @param delta δ parameter for the default stopping criterion.
|
||||||
* @param check {@code true} if self-adjointedness of both matrix and
|
* @param check {@code true} if self-adjointedness of both matrix and
|
||||||
* preconditioner should be checked. This entails an extra matrix-vector
|
* preconditioner should be checked. This entails an extra matrix-vector
|
||||||
* product at each iteration.
|
* product in the initial phase.
|
||||||
*/
|
*/
|
||||||
public SymmLQ(final int maxIterations, final double delta,
|
public SymmLQ(final int maxIterations, final double delta,
|
||||||
final boolean check) {
|
final boolean check) {
|
||||||
|
@ -693,7 +707,7 @@ public class SymmLQ
|
||||||
* @param delta δ parameter for the default stopping criterion.
|
* @param delta δ parameter for the default stopping criterion.
|
||||||
* @param check {@code true} if self-adjointedness of both matrix and
|
* @param check {@code true} if self-adjointedness of both matrix and
|
||||||
* preconditioner should be checked. This entails an extra matrix-vector
|
* preconditioner should be checked. This entails an extra matrix-vector
|
||||||
* product at each iteration.
|
* product in the initial phase.
|
||||||
*/
|
*/
|
||||||
public SymmLQ(final IterationManager manager, final double delta,
|
public SymmLQ(final IterationManager manager, final double delta,
|
||||||
final boolean check) {
|
final boolean check) {
|
||||||
|
@ -902,7 +916,7 @@ public class SymmLQ
|
||||||
* @param m Preconditioner (can be {@code null}).
|
* @param m Preconditioner (can be {@code null}).
|
||||||
* @param b Right-hand side vector.
|
* @param b Right-hand side vector.
|
||||||
* @param x Not meaningful in this implementation. Should not be considered
|
* @param x Not meaningful in this implementation. Should not be considered
|
||||||
* as an initial guess.
|
* as an initial guess (<a href="#initguess">more</a>).
|
||||||
* @return A new vector containing the solution.
|
* @return A new vector containing the solution.
|
||||||
* @throws NullArgumentException if one of the parameters is {@code null}.
|
* @throws NullArgumentException if one of the parameters is {@code null}.
|
||||||
* @throws NonSquareOperatorException if {@code a} or {@code m} is not
|
* @throws NonSquareOperatorException if {@code a} or {@code m} is not
|
||||||
|
@ -1010,7 +1024,7 @@ public class SymmLQ
|
||||||
* @param a Linear operator A of the system.
|
* @param a Linear operator A of the system.
|
||||||
* @param b Right-hand side vector.
|
* @param b Right-hand side vector.
|
||||||
* @param x Not meaningful in this implementation. Should not be considered
|
* @param x Not meaningful in this implementation. Should not be considered
|
||||||
* as an initial guess.
|
* as an initial guess (<a href="#initguess">more</a>).
|
||||||
* @return A new vector containing the solution.
|
* @return A new vector containing the solution.
|
||||||
* @throws NullArgumentException if one of the parameters is {@code null}.
|
* @throws NullArgumentException if one of the parameters is {@code null}.
|
||||||
* @throws NonSquareOperatorException if {@code a} is not square.
|
* @throws NonSquareOperatorException if {@code a} is not square.
|
||||||
|
@ -1041,8 +1055,7 @@ public class SymmLQ
|
||||||
* @param m Preconditioner (can be {@code null}).
|
* @param m Preconditioner (can be {@code null}).
|
||||||
* @param b Right-hand side vector.
|
* @param b Right-hand side vector.
|
||||||
* @param x Vector to be updated with the solution. {@code x} should not be
|
* @param x Vector to be updated with the solution. {@code x} should not be
|
||||||
* considered as an initial guess, as it is set to 0 in the initialization
|
* considered as an initial guess (<a href="#initguess">more</a>).
|
||||||
* phase.
|
|
||||||
* @return A reference to {@code x} (shallow copy) updated with the
|
* @return A reference to {@code x} (shallow copy) updated with the
|
||||||
* solution.
|
* solution.
|
||||||
* @throws NullArgumentException if one of the parameters is {@code null}.
|
* @throws NullArgumentException if one of the parameters is {@code null}.
|
||||||
|
@ -1093,8 +1106,7 @@ public class SymmLQ
|
||||||
* @param m Preconditioner (can be {@code null}).
|
* @param m Preconditioner (can be {@code null}).
|
||||||
* @param b Right-hand side vector.
|
* @param b Right-hand side vector.
|
||||||
* @param x Vector to be updated with the solution. {@code x} should not be
|
* @param x Vector to be updated with the solution. {@code x} should not be
|
||||||
* considered as an initial guess, as it is set to 0 in the initialization
|
* considered as an initial guess (<a href="#initguess">more</a>).
|
||||||
* phase.
|
|
||||||
* @param goodb Usually {@code false}, except if {@code x} is expected to
|
* @param goodb Usually {@code false}, except if {@code x} is expected to
|
||||||
* contain a large multiple of {@code b}.
|
* contain a large multiple of {@code b}.
|
||||||
* @param shift The amount to be subtracted to all diagonal elements of A.
|
* @param shift The amount to be subtracted to all diagonal elements of A.
|
||||||
|
@ -1166,8 +1178,7 @@ public class SymmLQ
|
||||||
* @param a Linear operator A of the system.
|
* @param a Linear operator A of the system.
|
||||||
* @param b Right-hand side vector.
|
* @param b Right-hand side vector.
|
||||||
* @param x Vector to be updated with the solution. {@code x} should not be
|
* @param x Vector to be updated with the solution. {@code x} should not be
|
||||||
* considered as an initial guess, as it is set to 0 in the initialization
|
* considered as an initial guess (<a href="#initguess">more</a>).
|
||||||
* phase.
|
|
||||||
* @return A reference to {@code x} (shallow copy) updated with the
|
* @return A reference to {@code x} (shallow copy) updated with the
|
||||||
* solution.
|
* solution.
|
||||||
* @throws NullArgumentException if one of the parameters is {@code null}.
|
* @throws NullArgumentException if one of the parameters is {@code null}.
|
||||||
|
|
Loading…
Reference in New Issue