Class BaseMultiStartMultivariateOptimizer<PAIR>
- java.lang.Object
- 
- org.apache.commons.math4.legacy.optim.BaseOptimizer<PAIR>
- 
- org.apache.commons.math4.legacy.optim.BaseMultivariateOptimizer<PAIR>
- 
- org.apache.commons.math4.legacy.optim.BaseMultiStartMultivariateOptimizer<PAIR>
 
 
 
- 
- Type Parameters:
- PAIR- Type of the point/value pair returned by the optimization algorithm.
 - Direct Known Subclasses:
- MultiStartMultivariateOptimizer
 
 public abstract class BaseMultiStartMultivariateOptimizer<PAIR> extends BaseMultivariateOptimizer<PAIR> Base class multi-start optimizer for a multivariate function.
 This class wraps an optimizer in order to use it several times in turn with different starting points (trying to avoid being trapped in a local extremum when looking for a global one). It is not a "user" class.- Since:
- 3.0
 
- 
- 
Constructor SummaryConstructors Constructor Description BaseMultiStartMultivariateOptimizer(BaseMultivariateOptimizer<PAIR> optimizer, int starts, Supplier<double[]> generator)Create a multi-start optimizer from a single-start optimizer.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected abstract voidclear()Method that will called in order to clear all stored optima.protected PAIRdoOptimize()Performs the bulk of the optimization algorithm.intgetEvaluations()Gets the number of evaluations of the objective function.abstract PAIR[]getOptima()Gets all the optima found during the last call tooptimize.PAIRoptimize(OptimizationData... optData)Stores data and performs the optimization.protected abstract voidstore(PAIR optimum)Method that will be called in order to store each found optimum.- 
Methods inherited from class org.apache.commons.math4.legacy.optim.BaseMultivariateOptimizergetLowerBound, getStartPoint, getUpperBound, parseOptimizationData
 - 
Methods inherited from class org.apache.commons.math4.legacy.optim.BaseOptimizergetConvergenceChecker, getIterations, getMaxEvaluations, getMaxIterations, incrementEvaluationCount, incrementIterationCount, optimize
 
- 
 
- 
- 
- 
Constructor Detail- 
BaseMultiStartMultivariateOptimizerpublic BaseMultiStartMultivariateOptimizer(BaseMultivariateOptimizer<PAIR> optimizer, int starts, Supplier<double[]> generator) Create a multi-start optimizer from a single-start optimizer.Note that if there are bounds constraints (see BaseMultivariateOptimizer.getLowerBound()andBaseMultivariateOptimizer.getUpperBound()), then a simple rejection algorithm is used at each restart. This implies that the random vector generator should have a good probability to generate vectors in the bounded domain, otherwise the rejection algorithm will hit theBaseOptimizer.getMaxEvaluations()count without generating a proper restart point. Users must be take great care of the curse of dimensionality.- Parameters:
- optimizer- Single-start optimizer to wrap.
- starts- Number of starts to perform. If- starts == 1, the- optimizewill return the same solution as the given- optimizerwould return.
- generator- Generator to use for restarts.
- Throws:
- NotStrictlyPositiveException- if- starts < 1.
 
 
- 
 - 
Method Detail- 
getEvaluationspublic int getEvaluations() Gets the number of evaluations of the objective function. The number of evaluations corresponds to the last call to theoptimizemethod. It is 0 if the method has not been called yet.- Overrides:
- getEvaluationsin class- BaseOptimizer<PAIR>
- Returns:
- the number of evaluations of the objective function.
 
 - 
getOptimapublic abstract PAIR[] getOptima() Gets all the optima found during the last call tooptimize. The optimizer stores all the optima found during a set of restarts. Theoptimizemethod 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 theoptimizemethod.
 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 bynullelements corresponding to the runs that did not converge. This means all elements will benullif theoptimizemethod did throw an exception. This also means that if the first element is notnull, it is the best point found across all starts.
 The behaviour is undefined if this method is called beforeoptimize; it will likely throwNullPointerException.- Returns:
- an array containing the optima sorted from best to worst.
 
 - 
optimizepublic PAIR optimize(OptimizationData... optData) Stores data and performs the optimization.The list of parameters is open-ended so that sub-classes can extend it with arguments specific to their concrete implementations. When the method is called multiple times, instance data is overwritten only when actually present in the list of arguments: when not specified, data set in a previous call is retained (and thus is optional in subsequent calls). Important note: Subclasses must override BaseOptimizer.parseOptimizationData(OptimizationData[])if they need to register their own options; but then, they must also callsuper.parseOptimizationData(optData)within that method.- Overrides:
- optimizein class- BaseMultivariateOptimizer<PAIR>
- Parameters:
- optData- Optimization data. In addition to those documented in- BaseOptimizer, this method will register the following data:
- Returns:
- a point/value pair that satisfies the convergence criteria.
- Throws:
- MathIllegalStateException- if- optDatadoes not contain an instance of- MaxEvalor- InitialGuess.
 
 - 
doOptimizeprotected PAIR doOptimize() Performs the bulk of the optimization algorithm.- Specified by:
- doOptimizein class- BaseOptimizer<PAIR>
- Returns:
- the point/value pair giving the optimal value of the objective function.
 
 - 
storeprotected abstract void store(PAIR optimum) Method that will be called in order to store each found optimum.- Parameters:
- optimum- Result of an optimization run.
 
 - 
clearprotected abstract void clear() Method that will called in order to clear all stored optima.
 
- 
 
-