public class MultiStartMultivariateRealOptimizer extends java.lang.Object implements MultivariateRealOptimizer
MultivariateRealOptimizer 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.
| Constructor and Description | 
|---|
| MultiStartMultivariateRealOptimizer(MultivariateRealOptimizer optimizer,
                                   int starts,
                                   RandomVectorGenerator generator)Create a multi-start optimizer from a single-start optimizer | 
| Modifier and Type | Method and Description | 
|---|---|
| RealConvergenceChecker | getConvergenceChecker()Get the convergence checker. | 
| int | getEvaluations()Get the number of evaluations of the objective function. | 
| int | getIterations()Get the number of iterations realized by the algorithm. | 
| int | getMaxEvaluations()Get the maximal number of functions evaluations. | 
| int | getMaxIterations()Get the maximal number of iterations of the algorithm. | 
| RealPointValuePair[] | getOptima()Get all the optima found during the last call to  optimize. | 
| RealPointValuePair | optimize(MultivariateRealFunction f,
        GoalType goalType,
        double[] startPoint)Optimizes an objective function. | 
| void | setConvergenceChecker(RealConvergenceChecker checker)Set the convergence checker. | 
| void | setMaxEvaluations(int maxEvaluations)Set the maximal number of functions evaluations. | 
| void | setMaxIterations(int maxIterations)Set the maximal number of iterations of the algorithm. | 
public MultiStartMultivariateRealOptimizer(MultivariateRealOptimizer optimizer, int starts, RandomVectorGenerator generator)
optimizer - single-start optimizer to wrapstarts - number of starts to perform (including the
 first one), multi-start is disabled if value is less than or
 equal to 1generator - random vector generator to use for restartspublic RealPointValuePair[] getOptima() throws java.lang.IllegalStateException
optimize.
 The optimizer stores all the optima found during a set of
 restarts. The optimize 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 the optimize
 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 by and null elements
 corresponding to the runs that did not converge. This means all
 elements will be null if the optimize method did throw a ConvergenceException).
 This also means that if the first element is non null, it is the best
 point found across all starts.
java.lang.IllegalStateException - if optimize has not been calledpublic void setMaxIterations(int maxIterations)
setMaxIterations in interface MultivariateRealOptimizermaxIterations - maximal number of algorithm iterationspublic int getMaxIterations()
getMaxIterations in interface MultivariateRealOptimizerpublic void setMaxEvaluations(int maxEvaluations)
setMaxEvaluations in interface MultivariateRealOptimizermaxEvaluations - maximal number of function evaluationspublic int getMaxEvaluations()
getMaxEvaluations in interface MultivariateRealOptimizerpublic int getIterations()
 The number of evaluations corresponds to the last call to the
 optimize
 method. It is 0 if the method has not been called yet.
 
getIterations in interface MultivariateRealOptimizerpublic int getEvaluations()
 The number of evaluations corresponds to the last call to the
 optimize
 method. It is 0 if the method has not been called yet.
 
getEvaluations in interface MultivariateRealOptimizerpublic void setConvergenceChecker(RealConvergenceChecker checker)
setConvergenceChecker in interface MultivariateRealOptimizerchecker - object to use to check for convergencepublic RealConvergenceChecker getConvergenceChecker()
getConvergenceChecker in interface MultivariateRealOptimizerpublic RealPointValuePair optimize(MultivariateRealFunction f, GoalType goalType, double[] startPoint) throws FunctionEvaluationException, OptimizationException, FunctionEvaluationException
optimize in interface MultivariateRealOptimizerf - objective functiongoalType - type of optimization goal: either GoalType.MAXIMIZE
 or GoalType.MINIMIZEstartPoint - the start point for optimizationFunctionEvaluationException - if the objective function throws one during
 the searchOptimizationException - if the algorithm failed to convergeCopyright © 2010 - 2023 Adobe. All Rights Reserved