Package com.irurueta.numerical.roots
Class SafeNewtonRaphsonSingleRootEstimator
java.lang.Object
com.irurueta.numerical.roots.RootEstimator
com.irurueta.numerical.roots.SingleRootEstimator
com.irurueta.numerical.roots.BracketedSingleRootEstimator
com.irurueta.numerical.roots.DerivativeSingleRootEstimator
com.irurueta.numerical.roots.SafeNewtonRaphsonSingleRootEstimator
Computes a root for a single dimension function inside a given bracket of
 values, in other words, root will only be searched within provided minimum
 and maximum evaluation points.
 This class searches for REAL roots only!
 This implementation is based on Numerical Recipes 3rd ed. Section 9.4, page
 456.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final doubleConstant defining default accuracy of the estimated root.static final intMaximum number of iterations.static final doubleConstant defining minimum allowed tolerance.private doubleTolerance value.Fields inherited from class com.irurueta.numerical.roots.DerivativeSingleRootEstimatorderivativeListenerFields inherited from class com.irurueta.numerical.roots.BracketedSingleRootEstimatorBRACKET_EPS, bracketAvailable, DEFAULT_MAX_EVAL_POINT, DEFAULT_MIN_EVAL_POINT, FACTOR, maxEvalPoint, minEvalPoint, NTRYFields inherited from class com.irurueta.numerical.roots.SingleRootEstimatorlistener, root, rootAvailableFields inherited from class com.irurueta.numerical.roots.RootEstimatorlocked
- 
Constructor SummaryConstructorsConstructorDescriptionEmpty constructor.SafeNewtonRaphsonSingleRootEstimator(SingleDimensionFunctionEvaluatorListener listener, double minEvalPoint, double maxEvalPoint, double tolerance) Constructor.SafeNewtonRaphsonSingleRootEstimator(SingleDimensionFunctionEvaluatorListener listener, SingleDimensionFunctionEvaluatorListener derivativeListener, double minEvalPoint, double maxEvalPoint, double tolerance) Constructor.
- 
Method SummaryModifier and TypeMethodDescriptionvoidestimate()Estimates a local root for a given single dimension function being evaluated by provided listener.doubleReturns tolerance value.private voidinternalSetTolerance(double tolerance) Internal method to set tolerance value.voidsetTolerance(double tolerance) Sets tolerance value.Methods inherited from class com.irurueta.numerical.roots.DerivativeSingleRootEstimatorgetDerivativeListener, isDerivativeListenerAvailable, isReady, setDerivativeListenerMethods inherited from class com.irurueta.numerical.roots.BracketedSingleRootEstimatorcomputeBracket, computeBracket, computeBracket, getMaxEvaluationPoint, getMinEvaluationPoint, isBracketAvailable, setBracket, sign, swapMethods inherited from class com.irurueta.numerical.roots.SingleRootEstimatorgetListener, getRoot, isListenerAvailable, isRootAvailable, setListenerMethods inherited from class com.irurueta.numerical.roots.RootEstimatorisLocked
- 
Field Details- 
MAXITpublic static final int MAXITMaximum number of iterations.- See Also:
 
- 
DEFAULT_TOLERANCEpublic static final double DEFAULT_TOLERANCEConstant defining default accuracy of the estimated root.- See Also:
 
- 
MIN_TOLERANCEpublic static final double MIN_TOLERANCEConstant defining minimum allowed tolerance.- See Also:
 
- 
toleranceprivate double toleranceTolerance value. The algorithm will iterate until the result converges below this value of accuracy or until the maximum number of iterations is achieved (and in such case, convergence will be assumed to have failed).
 
- 
- 
Constructor Details- 
SafeNewtonRaphsonSingleRootEstimatorpublic SafeNewtonRaphsonSingleRootEstimator()Empty constructor.
- 
SafeNewtonRaphsonSingleRootEstimatorpublic SafeNewtonRaphsonSingleRootEstimator(SingleDimensionFunctionEvaluatorListener listener, double minEvalPoint, double maxEvalPoint, double tolerance) throws InvalidBracketRangeException Constructor.- Parameters:
- listener- Listener to evaluate a single dimension function f(x) to find its roots.
- minEvalPoint- Smallest value inside the bracket of values where the root will be searched.
- maxEvalPoint- Largest value inside the bracket of values where the root will be searched.
- tolerance- Tolerance to be achieved in the estimated root.
- Throws:
- InvalidBracketRangeException- Raised if minEvalPoint < maxEvalPoint.
- IllegalArgumentException- Raised if tolerance is negative.
 
- 
SafeNewtonRaphsonSingleRootEstimatorpublic SafeNewtonRaphsonSingleRootEstimator(SingleDimensionFunctionEvaluatorListener listener, SingleDimensionFunctionEvaluatorListener derivativeListener, double minEvalPoint, double maxEvalPoint, double tolerance) throws InvalidBracketRangeException Constructor.- Parameters:
- listener- Listener to evaluate a single dimension function f(x) to find its roots.
- derivativeListener- Listener to evaluate the function's derivative
- minEvalPoint- Smallest value inside the bracket of values where the root will be searched.
- maxEvalPoint- Largest value inside the bracket of values where the root will be searched.
- tolerance- Tolerance to be achieved in the estimated root.
- Throws:
- InvalidBracketRangeException- Raised if minEvalPoint < maxEvalPoint.
- IllegalArgumentException- Raised if tolerance is negative.
 
 
- 
- 
Method Details- 
getTolerancepublic double getTolerance()Returns tolerance value. Tolerance is the accuracy to be achieved when estimating a root. If a root is found by this class, it is ensured to have an accuracy below the tolerance value.- Returns:
- Tolerance value.
 
- 
internalSetToleranceprivate void internalSetTolerance(double tolerance) Internal method to set tolerance value. Tolerance is the accuracy to be achieved when estimating a root. If a root is found by this class, it is ensured to have an accuracy below provided tolerance value. This method does not check whether this instance is locked or not.- Parameters:
- tolerance- Tolerance value.
- Throws:
- IllegalArgumentException- Raised if provided tolerance value is negative.
 
- 
setToleranceSets tolerance value. Tolerance is the accuracy to be achieved when estimating a root. If a root is found by this class, it is ensured to have an accuracy below provided tolerance value.- Parameters:
- tolerance- Tolerance value.
- Throws:
- LockedException- Raised if this instance is locked.
- IllegalArgumentException- Raised if provided tolerance value is negative.
 
- 
estimateEstimates a local root for a given single dimension function being evaluated by provided listener.- Overrides:
- estimatein class- RootEstimator
- Throws:
- LockedException- Exception raised if this instance is already locked.
- NotReadyException- Exception raised if either a listener has not yet been provided or a bracket has not been provided or computed.
- RootEstimationException- Raised if the root estimation failed for some other reason (usually inability to evaluate the function, numerical instability or convergence problems, or no roots are found).
 
 
-