Class SimpleUnivariateValueChecker
- java.lang.Object
- 
- org.apache.commons.math4.legacy.optim.AbstractConvergenceChecker<UnivariatePointValuePair>
- 
- org.apache.commons.math4.legacy.optim.univariate.SimpleUnivariateValueChecker
 
 
- 
- All Implemented Interfaces:
- ConvergenceChecker<UnivariatePointValuePair>
 
 public class SimpleUnivariateValueChecker extends AbstractConvergenceChecker<UnivariatePointValuePair> Simple implementation of theConvergenceCheckerinterface that uses only objective function values. Convergence is considered to have been reached if either the relative difference between the objective function values is smaller than a threshold or if either the absolute difference between the objective function values is smaller than another threshold.
 Theconvergedmethod will also returntrueif the number of iterations has been set (seethis constructor).- Since:
- 3.1
 
- 
- 
Constructor SummaryConstructors Constructor Description SimpleUnivariateValueChecker(double relativeThreshold, double absoluteThreshold)Build an instance with specified thresholds.SimpleUnivariateValueChecker(double relativeThreshold, double absoluteThreshold, int maxIter)Builds an instance with specified thresholds.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanconverged(int iteration, UnivariatePointValuePair previous, UnivariatePointValuePair current)Check if the optimization algorithm has converged considering the last two points.- 
Methods inherited from class org.apache.commons.math4.legacy.optim.AbstractConvergenceCheckergetAbsoluteThreshold, getRelativeThreshold
 
- 
 
- 
- 
- 
Constructor Detail- 
SimpleUnivariateValueCheckerpublic SimpleUnivariateValueChecker(double relativeThreshold, double absoluteThreshold) Build an instance with specified thresholds. In order to perform only relative checks, the absolute tolerance must be set to a negative value. In order to perform only absolute checks, the relative tolerance must be set to a negative value.- Parameters:
- relativeThreshold- relative tolerance threshold
- absoluteThreshold- absolute tolerance threshold
 
 - 
SimpleUnivariateValueCheckerpublic SimpleUnivariateValueChecker(double relativeThreshold, double absoluteThreshold, int maxIter) Builds an instance with specified thresholds. In order to perform only relative checks, the absolute tolerance must be set to a negative value. In order to perform only absolute checks, the relative tolerance must be set to a negative value.- Parameters:
- relativeThreshold- relative tolerance threshold
- absoluteThreshold- absolute tolerance threshold
- maxIter- Maximum iteration count.
- Throws:
- NotStrictlyPositiveException- if- maxIter <= 0.
- Since:
- 3.1
 
 
- 
 - 
Method Detail- 
convergedpublic boolean converged(int iteration, UnivariatePointValuePair previous, UnivariatePointValuePair current) Check if the optimization algorithm has converged considering the last two points. This method may be called several time from the same algorithm iteration with different points. This can be detected by checking the iteration number at each call if needed. Each time this method is called, the previous and current point correspond to points with the same role at each iteration, so they can be compared. As an example, simplex-based algorithms call this method for all points of the simplex, not only for the best or worst ones.- Specified by:
- convergedin interface- ConvergenceChecker<UnivariatePointValuePair>
- Specified by:
- convergedin class- AbstractConvergenceChecker<UnivariatePointValuePair>
- Parameters:
- iteration- Index of current iteration
- previous- Best point in the previous iteration.
- current- Best point in the current iteration.
- Returns:
- trueif the algorithm has converged.
 
 
- 
 
-