Package org.hipparchus.linear
Class IterativeLinearSolverEvent
- java.lang.Object
- 
- java.util.EventObject
- 
- org.hipparchus.util.IterationEvent
- 
- org.hipparchus.linear.IterativeLinearSolverEvent
 
 
 
- 
- All Implemented Interfaces:
- Serializable
 - Direct Known Subclasses:
- DefaultIterativeLinearSolverEvent
 
 public abstract class IterativeLinearSolverEvent extends IterationEvent This is the base class for all events occurring during the iterations of aIterativeLinearSolver.- See Also:
- Serialized Form
 
- 
- 
Field Summary- 
Fields inherited from class java.util.EventObjectsource
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedIterativeLinearSolverEvent(Object source, int iterations)Creates a new instance of this class.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description abstract doublegetNormOfResidual()Returns the norm of the residual.RealVectorgetResidual()Returns the residual.abstract RealVectorgetRightHandSideVector()Returns the current right-hand side of the linear system to be solved.abstract RealVectorgetSolution()Returns the current estimate of the solution to the linear system to be solved.booleanprovidesResidual()ReturnstrueifgetResidual()is supported.- 
Methods inherited from class org.hipparchus.util.IterationEventgetIterations
 - 
Methods inherited from class java.util.EventObjectgetSource, toString
 
- 
 
- 
- 
- 
Constructor Detail- 
IterativeLinearSolverEventprotected IterativeLinearSolverEvent(Object source, int iterations) Creates a new instance of this class.- Parameters:
- source- the iterative algorithm on which the event initially occurred
- iterations- the number of iterations performed at the time- thisevent is created
 
 
- 
 - 
Method Detail- 
getRightHandSideVectorpublic abstract RealVector getRightHandSideVector() Returns the current right-hand side of the linear system to be solved. This method should return an unmodifiable view, or a deep copy of the actual right-hand side vector, in order not to compromise subsequent iterations of the sourceIterativeLinearSolver.- Returns:
- the right-hand side vector, b
 
 - 
getNormOfResidualpublic abstract double getNormOfResidual() Returns the norm of the residual. The returned value is not required to be exact. Instead, the norm of the so-called updated residual (if available) should be returned. For example, theconjugate gradientmethod computes a sequence of residuals, the norm of which is cheap to compute. However, due to accumulation of round-off errors, this residual might differ from the true residual after some iterations. See e.g. A. Greenbaum and Z. Strakos, Predicting the Behavior of Finite Precision Lanzos and Conjugate Gradient Computations, Technical Report 538, Department of Computer Science, New York University, 1991 (available here).- Returns:
- the norm of the residual, ||r||
 
 - 
getResidualpublic RealVector getResidual() Returns the residual. This is an optional operation, as all iterative linear solvers do not provide cheap estimate of the updated residual vector, in which case - this method should throw a
 MathRuntimeException,
- providesResidual()returns- false.
 The default implementation throws a MathRuntimeException. If this method is overriden, thenprovidesResidual()should be overriden as well.- Returns:
- the updated residual, r
 
- this method should throw a
 
 - 
getSolutionpublic abstract RealVector getSolution() Returns the current estimate of the solution to the linear system to be solved. This method should return an unmodifiable view, or a deep copy of the actual current solution, in order not to compromise subsequent iterations of the sourceIterativeLinearSolver.- Returns:
- the solution, x
 
 - 
providesResidualpublic boolean providesResidual() - Returns:
- falseif- getResidual()throws a- MathRuntimeException
 
 
- 
 
-