Class BrentOptimizer
java.lang.Object
org.apache.commons.math3.optim.BaseOptimizer<UnivariatePointValuePair>
org.apache.commons.math3.optim.univariate.UnivariateOptimizer
org.apache.commons.math3.optim.univariate.BrentOptimizer
For a function defined on some interval
This code is an adaptation, partly based on the Python code from SciPy (module "optimize.py" v0.5); the original algorithm is also modified
(lo, hi), this class
finds an approximation x to the point at which the function
attains its minimum.
It implements Richard Brent's algorithm (from his book "Algorithms for
Minimization without Derivatives", p. 79) for finding minima of real
univariate functions.
This code is an adaptation, partly based on the Python code from SciPy (module "optimize.py" v0.5); the original algorithm is also modified
- to use an initial guess provided by the user,
- to ensure that the best point encountered is the one returned.
- Since:
- 2.0
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final doubleAbsolute threshold.private static final doubleGolden section.private static final doubleMinimum relative tolerance.private final doubleRelative threshold.Fields inherited from class BaseOptimizer
evaluations, iterations -
Constructor Summary
ConstructorsConstructorDescriptionBrentOptimizer(double rel, double abs) The arguments are used for implementing the original stopping criterion of Brent's algorithm.BrentOptimizer(double rel, double abs, ConvergenceChecker<UnivariatePointValuePair> checker) The arguments are used implement the original stopping criterion of Brent's algorithm. -
Method Summary
Modifier and TypeMethodDescriptionprivate UnivariatePointValuePairbest(UnivariatePointValuePair a, UnivariatePointValuePair b, boolean isMinim) Selects the best of two points.protected UnivariatePointValuePairPerforms the bulk of the optimization algorithm.Methods inherited from class UnivariateOptimizer
computeObjectiveValue, getGoalType, getMax, getMin, getStartValue, optimize, parseOptimizationDataMethods inherited from class BaseOptimizer
getConvergenceChecker, getEvaluations, getIterations, getMaxEvaluations, getMaxIterations, incrementEvaluationCount, incrementIterationCount, optimize
-
Field Details
-
GOLDEN_SECTION
private static final double GOLDEN_SECTIONGolden section. -
MIN_RELATIVE_TOLERANCE
private static final double MIN_RELATIVE_TOLERANCEMinimum relative tolerance. -
relativeThreshold
private final double relativeThresholdRelative threshold. -
absoluteThreshold
private final double absoluteThresholdAbsolute threshold.
-
-
Constructor Details
-
BrentOptimizer
The arguments are used implement the original stopping criterion of Brent's algorithm.absandreldefine a tolerancetol = rel |x| + abs.relshould be no smaller than 2 macheps and preferably not much less than sqrt(macheps), where macheps is the relative machine precision.absmust be positive.- Parameters:
rel- Relative threshold.abs- Absolute threshold.checker- Additional, user-defined, convergence checking procedure.- Throws:
NotStrictlyPositiveException- ifabs <= 0.NumberIsTooSmallException- ifrel < 2 * Math.ulp(1d).
-
BrentOptimizer
public BrentOptimizer(double rel, double abs) The arguments are used for implementing the original stopping criterion of Brent's algorithm.absandreldefine a tolerancetol = rel |x| + abs.relshould be no smaller than 2 macheps and preferably not much less than sqrt(macheps), where macheps is the relative machine precision.absmust be positive.- Parameters:
rel- Relative threshold.abs- Absolute threshold.- Throws:
NotStrictlyPositiveException- ifabs <= 0.NumberIsTooSmallException- ifrel < 2 * Math.ulp(1d).
-
-
Method Details
-
doOptimize
Performs the bulk of the optimization algorithm.- Specified by:
doOptimizein classBaseOptimizer<UnivariatePointValuePair>- Returns:
- the point/value pair giving the optimal value of the objective function.
-
best
private UnivariatePointValuePair best(UnivariatePointValuePair a, UnivariatePointValuePair b, boolean isMinim) Selects the best of two points.- Parameters:
a- Point and value.b- Point and value.isMinim-trueif the selected point must be the one with the lowest value.- Returns:
- the best point, or
nullifaandbare bothnull. Whenaandbhave the same function value,ais returned.
-