Class BOBYQAOptimizer
- java.lang.Object
- 
- org.hipparchus.optim.BaseOptimizer<P>
- 
- org.hipparchus.optim.BaseMultivariateOptimizer<PointValuePair>
- 
- org.hipparchus.optim.nonlinear.scalar.MultivariateOptimizer
- 
- org.hipparchus.optim.nonlinear.scalar.noderiv.BOBYQAOptimizer
 
 
 
 
- 
 public class BOBYQAOptimizer extends MultivariateOptimizer Powell's BOBYQA algorithm. This implementation is translated and adapted from the Fortran version available here. See this paper for an introduction.
 BOBYQA is particularly well suited for high dimensional problems where derivatives are not available. In most cases it outperforms thePowellOptimizersignificantly. Stochastic algorithms likeCMAESOptimizersucceed more often than BOBYQA, but are more expensive. BOBYQA could also be considered as a replacement of any derivative-based optimizer when the derivatives are approximated by finite differences.
- 
- 
Field SummaryFields Modifier and Type Field Description static doubleDEFAULT_INITIAL_RADIUSDefault value forinitialTrustRegionRadius: 10.0 .static doubleDEFAULT_STOPPING_RADIUSDefault value forstoppingTrustRegionRadius: 1.0E-8 .static intMINIMUM_PROBLEM_DIMENSIONMinimum dimension of the problem: 2- 
Fields inherited from class org.hipparchus.optim.BaseOptimizerevaluations, iterations
 
- 
 - 
Constructor SummaryConstructors Constructor Description BOBYQAOptimizer(int numberOfInterpolationPoints)Simple constructor.BOBYQAOptimizer(int numberOfInterpolationPoints, double initialTrustRegionRadius, double stoppingTrustRegionRadius)Simple constructor.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected PointValuePairdoOptimize()Performs the bulk of the optimization algorithm.- 
Methods inherited from class org.hipparchus.optim.nonlinear.scalar.MultivariateOptimizercomputeObjectiveValue, getGoalType, optimize, parseOptimizationData
 - 
Methods inherited from class org.hipparchus.optim.BaseMultivariateOptimizergetLowerBound, getStartPoint, getUpperBound
 - 
Methods inherited from class org.hipparchus.optim.BaseOptimizergetConvergenceChecker, getEvaluations, getIterations, getMaxEvaluations, getMaxIterations, incrementEvaluationCount, incrementIterationCount, optimize
 
- 
 
- 
- 
- 
Field Detail- 
MINIMUM_PROBLEM_DIMENSIONpublic static final int MINIMUM_PROBLEM_DIMENSION Minimum dimension of the problem: 2- See Also:
- Constant Field Values
 
 - 
DEFAULT_INITIAL_RADIUSpublic static final double DEFAULT_INITIAL_RADIUS Default value forinitialTrustRegionRadius: 10.0 .- See Also:
- Constant Field Values
 
 - 
DEFAULT_STOPPING_RADIUSpublic static final double DEFAULT_STOPPING_RADIUS Default value forstoppingTrustRegionRadius: 1.0E-8 .- See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
BOBYQAOptimizerpublic BOBYQAOptimizer(int numberOfInterpolationPoints) Simple constructor.- Parameters:
- numberOfInterpolationPoints- Number of interpolation conditions. For a problem of dimension- n, its value must be in the interval- [n+2, (n+1)(n+2)/2]. Choices that exceed- 2n+1are not recommended.
 
 - 
BOBYQAOptimizerpublic BOBYQAOptimizer(int numberOfInterpolationPoints, double initialTrustRegionRadius, double stoppingTrustRegionRadius)Simple constructor.- Parameters:
- numberOfInterpolationPoints- Number of interpolation conditions. For a problem of dimension- n, its value must be in the interval- [n+2, (n+1)(n+2)/2]. Choices that exceed- 2n+1are not recommended.
- initialTrustRegionRadius- Initial trust region radius.
- stoppingTrustRegionRadius- Stopping trust region radius.
 
 
- 
 - 
Method Detail- 
doOptimizeprotected PointValuePair doOptimize() Performs the bulk of the optimization algorithm.- Specified by:
- doOptimizein class- BaseOptimizer<PointValuePair>
- Returns:
- the point/value pair giving the optimal value of the objective function.
 
 
- 
 
-