Class UnivariateMultiStartOptimizer<FUNC extends UnivariateFunction>
java.lang.Object
org.apache.commons.math3.optimization.univariate.UnivariateMultiStartOptimizer<FUNC>
- Type Parameters:
FUNC
- Type of the objective function to be optimized.
- All Implemented Interfaces:
BaseOptimizer<UnivariatePointValuePair>
,BaseUnivariateOptimizer<FUNC>
@Deprecated
public class UnivariateMultiStartOptimizer<FUNC extends UnivariateFunction>
extends Object
implements BaseUnivariateOptimizer<FUNC>
Deprecated.
As of 3.1 (to be removed in 4.0).
Special implementation of the
UnivariateOptimizer
interface
adding multi-start features to an existing optimizer.
This class wraps a classical optimizer to use it several times in
turn with different starting points in order to avoid being trapped
into a local extremum when looking for a global one.- Since:
- 3.0
-
Constructor Summary
ConstructorsConstructorDescriptionUnivariateMultiStartOptimizer
(BaseUnivariateOptimizer<FUNC> optimizer, int starts, RandomGenerator generator) Deprecated.Create a multi-start optimizer from a single-start optimizer. -
Method Summary
Modifier and TypeMethodDescriptionDeprecated.Get the convergence checker.int
Deprecated.Get the number of evaluations of the objective function.int
Deprecated.Get the maximal number of function evaluations.Deprecated.Get all the optima found during the last call tooptimize
.Deprecated.Find an optimum in the given interval.Deprecated.Find an optimum in the given interval, start at startValue.
-
Constructor Details
-
UnivariateMultiStartOptimizer
public UnivariateMultiStartOptimizer(BaseUnivariateOptimizer<FUNC> optimizer, int starts, RandomGenerator generator) Deprecated.Create a multi-start optimizer from a single-start optimizer.- Parameters:
optimizer
- Single-start optimizer to wrap.starts
- Number of starts to perform. Ifstarts == 1
, theoptimize
methods will return the same solution asoptimizer
would.generator
- Random generator to use for restarts.- Throws:
NullArgumentException
- ifoptimizer
orgenerator
isnull
.NotStrictlyPositiveException
- ifstarts < 1
.
-
-
Method Details
-
getConvergenceChecker
Deprecated.Get the convergence checker.- Specified by:
getConvergenceChecker
in interfaceBaseOptimizer<FUNC extends UnivariateFunction>
- Returns:
- the object used to check for convergence.
-
getMaxEvaluations
public int getMaxEvaluations()Deprecated.Get the maximal number of function evaluations.- Specified by:
getMaxEvaluations
in interfaceBaseOptimizer<FUNC extends UnivariateFunction>
- Returns:
- the maximal number of function evaluations.
-
getEvaluations
public int getEvaluations()Deprecated.Get the number of evaluations of the objective function. The number of evaluations corresponds to the last call to theoptimize
method. It is 0 if the method has not been called yet.- Specified by:
getEvaluations
in interfaceBaseOptimizer<FUNC extends UnivariateFunction>
- Returns:
- the number of evaluations of the objective function.
-
getOptima
Deprecated.Get all the optima found during the last call tooptimize
. The optimizer stores all the optima found during a set of restarts. Theoptimize
method returns the best point only. This method returns all the points found at the end of each starts, including the best one already returned by theoptimize
method.
The returned array as one element for each start as specified in the constructor. It is ordered with the results from the runs that did converge first, sorted from best to worst objective value (i.e in ascending order if minimizing and in descending order if maximizing), followed bynull
elements corresponding to the runs that did not converge. This means all elements will benull
if theoptimize
method did throw an exception. This also means that if the first element is notnull
, it is the best point found across all starts.- Returns:
- an array containing the optima.
- Throws:
MathIllegalStateException
- ifoptimize
has not been called.
-
optimize
public UnivariatePointValuePair optimize(int maxEval, FUNC f, GoalType goal, double min, double max) Deprecated.Find an optimum in the given interval. An optimizer may require that the interval brackets a single optimum.- Specified by:
optimize
in interfaceBaseUnivariateOptimizer<FUNC extends UnivariateFunction>
- Parameters:
maxEval
- Maximum number of function evaluations.f
- Function to optimize.goal
- Type of optimization goal: eitherGoalType.MAXIMIZE
orGoalType.MINIMIZE
.min
- Lower bound for the interval.max
- Upper bound for the interval.- Returns:
- a (point, value) pair where the function is optimum.
-
optimize
public UnivariatePointValuePair optimize(int maxEval, FUNC f, GoalType goal, double min, double max, double startValue) Deprecated.Find an optimum in the given interval, start at startValue. An optimizer may require that the interval brackets a single optimum.- Specified by:
optimize
in interfaceBaseUnivariateOptimizer<FUNC extends UnivariateFunction>
- Parameters:
maxEval
- Maximum number of function evaluations.f
- Function to optimize.goal
- Type of optimization goal: eitherGoalType.MAXIMIZE
orGoalType.MINIMIZE
.min
- Lower bound for the interval.max
- Upper bound for the interval.startValue
- Start value to use.- Returns:
- a (point, value) pair where the function is optimum.
-