separated iteration counter from function evaluation counters,
some optimizers are based on gradient/jacobian only and cannot reliably be protected by monitoring the objective function calls. We now have two or three counters for each algorithm: - iteration counter, which is checked against a max allowance to prevent infinite loops if no convergence is reached - objective function evaluations, for user information only - objective function gradient/jacobian if the function is differentiable, for user information only git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@757181 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
cfa4345431
commit
87c0ddbc6e
|
@ -118,8 +118,7 @@ public class MessagesResources_fr
|
||||||
{ "equals vertices {0} and {1} in simplex configuration",
|
{ "equals vertices {0} and {1} in simplex configuration",
|
||||||
"sommets {0} et {1} \u00e9gaux dans la configuration du simplex" },
|
"sommets {0} et {1} \u00e9gaux dans la configuration du simplex" },
|
||||||
|
|
||||||
// org.apache.commons.math.optimization.direct.DirectSearchOptimizer
|
// org.apache.commons.math.estimation.AbstractEstimation
|
||||||
// org.apache.commons.math.optimization.general.AbstractLeastSquaresOptimizer
|
|
||||||
{ "maximal number of evaluations exceeded ({0})",
|
{ "maximal number of evaluations exceeded ({0})",
|
||||||
"nombre maximal d''\u00e9valuations d\u00e9pass\u00e9 ({0})" },
|
"nombre maximal d''\u00e9valuations d\u00e9pass\u00e9 ({0})" },
|
||||||
|
|
||||||
|
|
|
@ -38,16 +38,22 @@ import org.apache.commons.math.random.RandomVectorGenerator;
|
||||||
public class MultiStartScalarDifferentiableOptimizer implements ScalarDifferentiableOptimizer {
|
public class MultiStartScalarDifferentiableOptimizer implements ScalarDifferentiableOptimizer {
|
||||||
|
|
||||||
/** Serializable version identifier. */
|
/** Serializable version identifier. */
|
||||||
private static final long serialVersionUID = 9008747186334431824L;
|
private static final long serialVersionUID = 6185821146433609962L;
|
||||||
|
|
||||||
/** Underlying classical optimizer. */
|
/** Underlying classical optimizer. */
|
||||||
private final ScalarDifferentiableOptimizer optimizer;
|
private final ScalarDifferentiableOptimizer optimizer;
|
||||||
|
|
||||||
|
/** Maximal number of iterations allowed. */
|
||||||
|
private int maxIterations;
|
||||||
|
|
||||||
|
/** Number of iterations already performed for all starts. */
|
||||||
|
private int totalIterations;
|
||||||
|
|
||||||
/** Number of evaluations already performed for all starts. */
|
/** Number of evaluations already performed for all starts. */
|
||||||
private int totalEvaluations;
|
private int totalEvaluations;
|
||||||
|
|
||||||
/** Maximal number of evaluations allowed. */
|
/** Number of gradient evaluations already performed for all starts. */
|
||||||
private int maxEvaluations;
|
private int totalGradientEvaluations;
|
||||||
|
|
||||||
/** Number of starts to go. */
|
/** Number of starts to go. */
|
||||||
private int starts;
|
private int starts;
|
||||||
|
@ -69,12 +75,14 @@ public class MultiStartScalarDifferentiableOptimizer implements ScalarDifferenti
|
||||||
public MultiStartScalarDifferentiableOptimizer(final ScalarDifferentiableOptimizer optimizer,
|
public MultiStartScalarDifferentiableOptimizer(final ScalarDifferentiableOptimizer optimizer,
|
||||||
final int starts,
|
final int starts,
|
||||||
final RandomVectorGenerator generator) {
|
final RandomVectorGenerator generator) {
|
||||||
this.optimizer = optimizer;
|
this.optimizer = optimizer;
|
||||||
this.totalEvaluations = 0;
|
this.maxIterations = Integer.MAX_VALUE;
|
||||||
this.maxEvaluations = Integer.MAX_VALUE;
|
this.totalIterations = 0;
|
||||||
this.starts = starts;
|
this.totalEvaluations = 0;
|
||||||
this.generator = generator;
|
this.totalGradientEvaluations = 0;
|
||||||
this.optima = null;
|
this.starts = starts;
|
||||||
|
this.generator = generator;
|
||||||
|
this.optima = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get all the optima found during the last call to {@link
|
/** Get all the optima found during the last call to {@link
|
||||||
|
@ -110,19 +118,29 @@ public class MultiStartScalarDifferentiableOptimizer implements ScalarDifferenti
|
||||||
return (ScalarPointValuePair[]) optima.clone();
|
return (ScalarPointValuePair[]) optima.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public void setMaxIterations(int maxIterations) {
|
||||||
|
this.maxIterations = maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getMaxIterations() {
|
||||||
|
return maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getIterations() {
|
||||||
|
return totalIterations;
|
||||||
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public int getEvaluations() {
|
public int getEvaluations() {
|
||||||
return totalEvaluations;
|
return totalEvaluations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public void setMaxEvaluations(int maxEvaluations) {
|
public int getGradientEvaluations() {
|
||||||
this.maxEvaluations = maxEvaluations;
|
return totalGradientEvaluations;
|
||||||
}
|
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
|
||||||
public int getMaxEvaluations() {
|
|
||||||
return maxEvaluations;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -141,14 +159,16 @@ public class MultiStartScalarDifferentiableOptimizer implements ScalarDifferenti
|
||||||
double[] startPoint)
|
double[] startPoint)
|
||||||
throws ObjectiveException, OptimizationException {
|
throws ObjectiveException, OptimizationException {
|
||||||
|
|
||||||
optima = new ScalarPointValuePair[starts];
|
optima = new ScalarPointValuePair[starts];
|
||||||
totalEvaluations = 0;
|
totalIterations = 0;
|
||||||
|
totalEvaluations = 0;
|
||||||
|
totalGradientEvaluations = 0;
|
||||||
|
|
||||||
// multi-start loop
|
// multi-start loop
|
||||||
for (int i = 0; i < starts; ++i) {
|
for (int i = 0; i < starts; ++i) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
optimizer.setMaxEvaluations(maxEvaluations - totalEvaluations);
|
optimizer.setMaxIterations(maxIterations - totalIterations);
|
||||||
optima[i] = optimizer.optimize(f, goalType,
|
optima[i] = optimizer.optimize(f, goalType,
|
||||||
(i == 0) ? startPoint : generator.nextVector());
|
(i == 0) ? startPoint : generator.nextVector());
|
||||||
} catch (ObjectiveException obe) {
|
} catch (ObjectiveException obe) {
|
||||||
|
@ -157,7 +177,9 @@ public class MultiStartScalarDifferentiableOptimizer implements ScalarDifferenti
|
||||||
optima[i] = null;
|
optima[i] = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
totalEvaluations += optimizer.getEvaluations();
|
totalIterations += optimizer.getIterations();
|
||||||
|
totalEvaluations += optimizer.getEvaluations();
|
||||||
|
totalGradientEvaluations += optimizer.getGradientEvaluations();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -38,17 +38,20 @@ import org.apache.commons.math.random.RandomVectorGenerator;
|
||||||
public class MultiStartScalarOptimizer implements ScalarOptimizer {
|
public class MultiStartScalarOptimizer implements ScalarOptimizer {
|
||||||
|
|
||||||
/** Serializable version identifier. */
|
/** Serializable version identifier. */
|
||||||
private static final long serialVersionUID = 6648351778723282863L;
|
private static final long serialVersionUID = -7333253288301713047L;
|
||||||
|
|
||||||
/** Underlying classical optimizer. */
|
/** Underlying classical optimizer. */
|
||||||
private final ScalarOptimizer optimizer;
|
private final ScalarOptimizer optimizer;
|
||||||
|
|
||||||
|
/** Maximal number of iterations allowed. */
|
||||||
|
private int maxIterations;
|
||||||
|
|
||||||
|
/** Number of iterations already performed for all starts. */
|
||||||
|
private int totalIterations;
|
||||||
|
|
||||||
/** Number of evaluations already performed for all starts. */
|
/** Number of evaluations already performed for all starts. */
|
||||||
private int totalEvaluations;
|
private int totalEvaluations;
|
||||||
|
|
||||||
/** Maximal number of evaluations allowed. */
|
|
||||||
private int maxEvaluations;
|
|
||||||
|
|
||||||
/** Number of starts to go. */
|
/** Number of starts to go. */
|
||||||
private int starts;
|
private int starts;
|
||||||
|
|
||||||
|
@ -69,8 +72,9 @@ public class MultiStartScalarOptimizer implements ScalarOptimizer {
|
||||||
public MultiStartScalarOptimizer(final ScalarOptimizer optimizer, final int starts,
|
public MultiStartScalarOptimizer(final ScalarOptimizer optimizer, final int starts,
|
||||||
final RandomVectorGenerator generator) {
|
final RandomVectorGenerator generator) {
|
||||||
this.optimizer = optimizer;
|
this.optimizer = optimizer;
|
||||||
|
this.maxIterations = Integer.MAX_VALUE;
|
||||||
|
this.totalIterations = 0;
|
||||||
this.totalEvaluations = 0;
|
this.totalEvaluations = 0;
|
||||||
this.maxEvaluations = Integer.MAX_VALUE;
|
|
||||||
this.starts = starts;
|
this.starts = starts;
|
||||||
this.generator = generator;
|
this.generator = generator;
|
||||||
this.optima = null;
|
this.optima = null;
|
||||||
|
@ -109,21 +113,26 @@ public class MultiStartScalarOptimizer implements ScalarOptimizer {
|
||||||
return (ScalarPointValuePair[]) optima.clone();
|
return (ScalarPointValuePair[]) optima.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public void setMaxIterations(int maxIterations) {
|
||||||
|
this.maxIterations = maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getMaxIterations() {
|
||||||
|
return maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getIterations() {
|
||||||
|
return totalIterations;
|
||||||
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public int getEvaluations() {
|
public int getEvaluations() {
|
||||||
return totalEvaluations;
|
return totalEvaluations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
|
||||||
public void setMaxEvaluations(int maxEvaluations) {
|
|
||||||
this.maxEvaluations = maxEvaluations;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
|
||||||
public int getMaxEvaluations() {
|
|
||||||
return maxEvaluations;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public void setConvergenceChecker(ScalarConvergenceChecker checker) {
|
public void setConvergenceChecker(ScalarConvergenceChecker checker) {
|
||||||
optimizer.setConvergenceChecker(checker);
|
optimizer.setConvergenceChecker(checker);
|
||||||
|
@ -140,14 +149,15 @@ public class MultiStartScalarOptimizer implements ScalarOptimizer {
|
||||||
double[] startPoint)
|
double[] startPoint)
|
||||||
throws ObjectiveException, OptimizationException {
|
throws ObjectiveException, OptimizationException {
|
||||||
|
|
||||||
optima = new ScalarPointValuePair[starts];
|
optima = new ScalarPointValuePair[starts];
|
||||||
|
totalIterations = 0;
|
||||||
totalEvaluations = 0;
|
totalEvaluations = 0;
|
||||||
|
|
||||||
// multi-start loop
|
// multi-start loop
|
||||||
for (int i = 0; i < starts; ++i) {
|
for (int i = 0; i < starts; ++i) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
optimizer.setMaxEvaluations(maxEvaluations - totalEvaluations);
|
optimizer.setMaxIterations(maxIterations - totalIterations);
|
||||||
optima[i] = optimizer.optimize(f, goalType,
|
optima[i] = optimizer.optimize(f, goalType,
|
||||||
(i == 0) ? startPoint : generator.nextVector());
|
(i == 0) ? startPoint : generator.nextVector());
|
||||||
} catch (ObjectiveException obe) {
|
} catch (ObjectiveException obe) {
|
||||||
|
@ -156,6 +166,7 @@ public class MultiStartScalarOptimizer implements ScalarOptimizer {
|
||||||
optima[i] = null;
|
optima[i] = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
totalIterations += optimizer.getIterations();
|
||||||
totalEvaluations += optimizer.getEvaluations();
|
totalEvaluations += optimizer.getEvaluations();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,20 +38,23 @@ import org.apache.commons.math.random.RandomVectorGenerator;
|
||||||
public class MultiStartVectorialDifferentiableOptimizer implements VectorialDifferentiableOptimizer {
|
public class MultiStartVectorialDifferentiableOptimizer implements VectorialDifferentiableOptimizer {
|
||||||
|
|
||||||
/** Serializable version identifier. */
|
/** Serializable version identifier. */
|
||||||
private static final long serialVersionUID = -6671992853686531955L;
|
private static final long serialVersionUID = -9109278856437190136L;
|
||||||
|
|
||||||
/** Underlying classical optimizer. */
|
/** Underlying classical optimizer. */
|
||||||
private final VectorialDifferentiableOptimizer optimizer;
|
private final VectorialDifferentiableOptimizer optimizer;
|
||||||
|
|
||||||
|
/** Maximal number of iterations allowed. */
|
||||||
|
private int maxIterations;
|
||||||
|
|
||||||
|
/** Number of iterations already performed for all starts. */
|
||||||
|
private int totalIterations;
|
||||||
|
|
||||||
/** Number of evaluations already performed for all starts. */
|
/** Number of evaluations already performed for all starts. */
|
||||||
private int totalEvaluations;
|
private int totalEvaluations;
|
||||||
|
|
||||||
/** Number of jacobian evaluations already performed for all starts. */
|
/** Number of jacobian evaluations already performed for all starts. */
|
||||||
private int totalJacobianEvaluations;
|
private int totalJacobianEvaluations;
|
||||||
|
|
||||||
/** Maximal number of evaluations allowed. */
|
|
||||||
private int maxEvaluations;
|
|
||||||
|
|
||||||
/** Number of starts to go. */
|
/** Number of starts to go. */
|
||||||
private int starts;
|
private int starts;
|
||||||
|
|
||||||
|
@ -73,9 +76,10 @@ public class MultiStartVectorialDifferentiableOptimizer implements VectorialDiff
|
||||||
final int starts,
|
final int starts,
|
||||||
final RandomVectorGenerator generator) {
|
final RandomVectorGenerator generator) {
|
||||||
this.optimizer = optimizer;
|
this.optimizer = optimizer;
|
||||||
|
this.maxIterations = Integer.MAX_VALUE;
|
||||||
|
this.totalIterations = 0;
|
||||||
this.totalEvaluations = 0;
|
this.totalEvaluations = 0;
|
||||||
this.totalJacobianEvaluations = 0;
|
this.totalJacobianEvaluations = 0;
|
||||||
this.maxEvaluations = Integer.MAX_VALUE;
|
|
||||||
this.starts = starts;
|
this.starts = starts;
|
||||||
this.generator = generator;
|
this.generator = generator;
|
||||||
this.optima = null;
|
this.optima = null;
|
||||||
|
@ -114,6 +118,21 @@ public class MultiStartVectorialDifferentiableOptimizer implements VectorialDiff
|
||||||
return (VectorialPointValuePair[]) optima.clone();
|
return (VectorialPointValuePair[]) optima.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public void setMaxIterations(int maxIterations) {
|
||||||
|
this.maxIterations = maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getMaxIterations() {
|
||||||
|
return maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getIterations() {
|
||||||
|
return totalIterations;
|
||||||
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public int getEvaluations() {
|
public int getEvaluations() {
|
||||||
return totalEvaluations;
|
return totalEvaluations;
|
||||||
|
@ -124,16 +143,6 @@ public class MultiStartVectorialDifferentiableOptimizer implements VectorialDiff
|
||||||
return totalJacobianEvaluations;
|
return totalJacobianEvaluations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
|
||||||
public void setMaxEvaluations(int maxEvaluations) {
|
|
||||||
this.maxEvaluations = maxEvaluations;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
|
||||||
public int getMaxEvaluations() {
|
|
||||||
return maxEvaluations;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public void setConvergenceChecker(VectorialConvergenceChecker checker) {
|
public void setConvergenceChecker(VectorialConvergenceChecker checker) {
|
||||||
optimizer.setConvergenceChecker(checker);
|
optimizer.setConvergenceChecker(checker);
|
||||||
|
@ -150,15 +159,16 @@ public class MultiStartVectorialDifferentiableOptimizer implements VectorialDiff
|
||||||
final double[] startPoint)
|
final double[] startPoint)
|
||||||
throws ObjectiveException, OptimizationException, IllegalArgumentException {
|
throws ObjectiveException, OptimizationException, IllegalArgumentException {
|
||||||
|
|
||||||
optima = new VectorialPointValuePair[starts];
|
optima = new VectorialPointValuePair[starts];
|
||||||
totalEvaluations = 0;
|
totalIterations = 0;
|
||||||
|
totalEvaluations = 0;
|
||||||
totalJacobianEvaluations = 0;
|
totalJacobianEvaluations = 0;
|
||||||
|
|
||||||
// multi-start loop
|
// multi-start loop
|
||||||
for (int i = 0; i < starts; ++i) {
|
for (int i = 0; i < starts; ++i) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
optimizer.setMaxEvaluations(maxEvaluations - totalEvaluations);
|
optimizer.setMaxIterations(maxIterations - totalIterations);
|
||||||
optima[i] = optimizer.optimize(f, target, weights,
|
optima[i] = optimizer.optimize(f, target, weights,
|
||||||
(i == 0) ? startPoint : generator.nextVector());
|
(i == 0) ? startPoint : generator.nextVector());
|
||||||
} catch (ObjectiveException obe) {
|
} catch (ObjectiveException obe) {
|
||||||
|
@ -167,6 +177,7 @@ public class MultiStartVectorialDifferentiableOptimizer implements VectorialDiff
|
||||||
optima[i] = null;
|
optima[i] = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
totalIterations += optimizer.getIterations();
|
||||||
totalEvaluations += optimizer.getEvaluations();
|
totalEvaluations += optimizer.getEvaluations();
|
||||||
totalJacobianEvaluations += optimizer.getJacobianEvaluations();
|
totalJacobianEvaluations += optimizer.getJacobianEvaluations();
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,7 @@ import org.apache.commons.math.ConvergenceException;
|
||||||
public class OptimizationException extends ConvergenceException {
|
public class OptimizationException extends ConvergenceException {
|
||||||
|
|
||||||
/** Serializable version identifier. */
|
/** Serializable version identifier. */
|
||||||
private static final long serialVersionUID = -781139167958631145L;
|
private static final long serialVersionUID = -357696069587075016L;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simple constructor.
|
* Simple constructor.
|
||||||
|
@ -42,4 +42,12 @@ public class OptimizationException extends ConvergenceException {
|
||||||
super(specifier, parts);
|
super(specifier, parts);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create an exception with a given root cause.
|
||||||
|
* @param cause the exception or error that caused this exception to be thrown
|
||||||
|
*/
|
||||||
|
public OptimizationException(Throwable cause) {
|
||||||
|
super(cause);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,38 +29,45 @@ import java.io.Serializable;
|
||||||
*/
|
*/
|
||||||
public interface ScalarDifferentiableOptimizer extends Serializable {
|
public interface ScalarDifferentiableOptimizer extends Serializable {
|
||||||
|
|
||||||
/** Set the maximal number of objective function calls.
|
/** Set the maximal number of iterations of the algorithm.
|
||||||
* <p>
|
* @param maxIterations maximal number of function calls
|
||||||
* The number of objective function calls may be checked <em>after</em> a few
|
|
||||||
* related calls have been made. This implies that in some cases this number may
|
|
||||||
* be exceeded by a few units, depending on the dimension of the problem and kind
|
|
||||||
* of optimizer.
|
|
||||||
* </p>
|
|
||||||
* @param maxEvaluations maximal number of function calls
|
|
||||||
* .
|
|
||||||
*/
|
*/
|
||||||
void setMaxEvaluations(int maxEvaluations);
|
void setMaxIterations(int maxIterations);
|
||||||
|
|
||||||
/** Get the maximal number of objective function calls.
|
/** Get the maximal number of iterations of the algorithm.
|
||||||
* <p>
|
* @return maximal number of iterations
|
||||||
* The number of objective function calls may be checked <em>after</em> a few
|
|
||||||
* related calls have been made. This implies that in some cases this number may
|
|
||||||
* be exceeded by a few units, depending on the dimension of the problem and kind
|
|
||||||
* of optimizer.
|
|
||||||
* </p>
|
|
||||||
* @return maximal number of function calls
|
|
||||||
*/
|
*/
|
||||||
int getMaxEvaluations();
|
int getMaxIterations();
|
||||||
|
|
||||||
|
/** Get the number of iterations realized by the algorithm.
|
||||||
|
* <p>
|
||||||
|
* The number of evaluations corresponds to the last call to the
|
||||||
|
* {@link #optimize(ScalarDifferentiableObjectiveFunction, GoalType, double[]) optimize}
|
||||||
|
* method. It is 0 if the method has not been called yet.
|
||||||
|
* </p>
|
||||||
|
* @return number of iterations
|
||||||
|
*/
|
||||||
|
int getIterations();
|
||||||
|
|
||||||
/** Get the number of evaluations of the objective function.
|
/** Get the number of evaluations of the objective function.
|
||||||
* <p>
|
* <p>
|
||||||
* The number of evaluation correspond to the last call to the
|
* The number of evaluations corresponds to the last call to the
|
||||||
* {@link #optimize(ScalarObjectiveFunction, GoalType, double[]) optimize}
|
* {@link #optimize(ScalarDifferentiableObjectiveFunction, GoalType, double[]) optimize}
|
||||||
* method. It is 0 if the method has not been called yet.
|
* method. It is 0 if the method has not been called yet.
|
||||||
* </p>
|
* </p>
|
||||||
* @return number of evaluations of the objective function
|
* @return number of evaluations of the objective function
|
||||||
*/
|
*/
|
||||||
int getEvaluations();
|
int getEvaluations();
|
||||||
|
|
||||||
|
/** Get the number of evaluations of the objective function gradient.
|
||||||
|
* <p>
|
||||||
|
* The number of evaluations corresponds to the last call to the
|
||||||
|
* {@link #optimize(ScalarDifferentiableObjectiveFunction, GoalType, double[]) optimize}
|
||||||
|
* method. It is 0 if the method has not been called yet.
|
||||||
|
* </p>
|
||||||
|
* @return number of evaluations of the objective function gradient
|
||||||
|
*/
|
||||||
|
int getGradientEvaluations();
|
||||||
|
|
||||||
/** Set the convergence checker.
|
/** Set the convergence checker.
|
||||||
* @param checker object to use to check for convergence
|
* @param checker object to use to check for convergence
|
||||||
|
|
|
@ -29,38 +29,35 @@ import java.io.Serializable;
|
||||||
*/
|
*/
|
||||||
public interface ScalarOptimizer extends Serializable {
|
public interface ScalarOptimizer extends Serializable {
|
||||||
|
|
||||||
/** Set the maximal number of objective function calls.
|
/** Set the maximal number of iterations of the algorithm.
|
||||||
* <p>
|
* @param maxIterations maximal number of function calls
|
||||||
* The number of objective function calls may be checked <em>after</em> a few
|
|
||||||
* related calls have been made. This implies that in some cases this number may
|
|
||||||
* be exceeded by a few units, depending on the dimension of the problem and kind
|
|
||||||
* of optimizer.
|
|
||||||
* </p>
|
|
||||||
* @param maxEvaluations maximal number of function calls
|
|
||||||
* .
|
|
||||||
*/
|
*/
|
||||||
void setMaxEvaluations(int maxEvaluations);
|
void setMaxIterations(int maxIterations);
|
||||||
|
|
||||||
/** Get the maximal number of objective function calls.
|
/** Get the maximal number of iterations of the algorithm.
|
||||||
* <p>
|
* @return maximal number of iterations
|
||||||
* The number of objective function calls may be checked <em>after</em> a few
|
|
||||||
* related calls have been made. This implies that in some cases this number may
|
|
||||||
* be exceeded by a few units, depending on the dimension of the problem and kind
|
|
||||||
* of optimizer.
|
|
||||||
* </p>
|
|
||||||
* @return maximal number of function calls
|
|
||||||
*/
|
*/
|
||||||
int getMaxEvaluations();
|
int getMaxIterations();
|
||||||
|
|
||||||
|
/** Get the number of iterations realized by the algorithm.
|
||||||
|
* <p>
|
||||||
|
* The number of evaluations corresponds to the last call to the
|
||||||
|
* {@link #optimize(ScalarObjectiveFunction, GoalType, double[]) optimize}
|
||||||
|
* method. It is 0 if the method has not been called yet.
|
||||||
|
* </p>
|
||||||
|
* @return number of iterations
|
||||||
|
*/
|
||||||
|
int getIterations();
|
||||||
|
|
||||||
/** Get the number of evaluations of the objective function.
|
/** Get the number of evaluations of the objective function.
|
||||||
* <p>
|
* <p>
|
||||||
* The number of evaluation correspond to the last call to the
|
* The number of evaluations corresponds to the last call to the
|
||||||
* {@link #optimize(ScalarObjectiveFunction, GoalType, double[]) optimize}
|
* {@link #optimize(ScalarObjectiveFunction, GoalType, double[]) optimize}
|
||||||
* method. It is 0 if the method has not been called yet.
|
* method. It is 0 if the method has not been called yet.
|
||||||
* </p>
|
* </p>
|
||||||
* @return number of evaluations of the objective function
|
* @return number of evaluations of the objective function
|
||||||
*/
|
*/
|
||||||
int getEvaluations();
|
int getEvaluations();
|
||||||
|
|
||||||
/** Set the convergence checker.
|
/** Set the convergence checker.
|
||||||
* @param checker object to use to check for convergence
|
* @param checker object to use to check for convergence
|
||||||
|
|
|
@ -29,28 +29,21 @@ import java.io.Serializable;
|
||||||
*/
|
*/
|
||||||
public interface VectorialDifferentiableOptimizer extends Serializable {
|
public interface VectorialDifferentiableOptimizer extends Serializable {
|
||||||
|
|
||||||
/** Set the maximal number of objective function calls.
|
/** Set the maximal number of iterations of the algorithm.
|
||||||
* <p>
|
* @param maxIterations maximal number of function calls
|
||||||
* The number of objective function calls may be checked <em>after</em> a few
|
|
||||||
* related calls have been made. This implies that in some cases this number may
|
|
||||||
* be exceeded by a few units, depending on the dimension of the problem and kind
|
|
||||||
* of optimizer.
|
|
||||||
* </p>
|
|
||||||
* @param maxEvaluations maximal number of function calls
|
|
||||||
* .
|
* .
|
||||||
*/
|
*/
|
||||||
void setMaxEvaluations(int maxEvaluations);
|
void setMaxIterations(int maxIterations);
|
||||||
|
|
||||||
/** Get the maximal number of objective function calls.
|
/** Get the maximal number of iterations of the algorithm.
|
||||||
* <p>
|
* @return maximal number of iterations
|
||||||
* The number of objective function calls may be checked <em>after</em> a few
|
|
||||||
* related calls have been made. This implies that in some cases this number may
|
|
||||||
* be exceeded by a few units, depending on the dimension of the problem and kind
|
|
||||||
* of optimizer.
|
|
||||||
* </p>
|
|
||||||
* @return maximal number of function calls
|
|
||||||
*/
|
*/
|
||||||
int getMaxEvaluations();
|
int getMaxIterations();
|
||||||
|
|
||||||
|
/** Get the number of iterations realized by the algorithm.
|
||||||
|
* @return number of iterations
|
||||||
|
*/
|
||||||
|
int getIterations();
|
||||||
|
|
||||||
/** Get the number of evaluations of the objective function.
|
/** Get the number of evaluations of the objective function.
|
||||||
* <p>
|
* <p>
|
||||||
|
|
|
@ -21,6 +21,7 @@ import java.util.Arrays;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
|
||||||
import org.apache.commons.math.MathRuntimeException;
|
import org.apache.commons.math.MathRuntimeException;
|
||||||
|
import org.apache.commons.math.MaxIterationsExceededException;
|
||||||
import org.apache.commons.math.optimization.ScalarConvergenceChecker;
|
import org.apache.commons.math.optimization.ScalarConvergenceChecker;
|
||||||
import org.apache.commons.math.optimization.GoalType;
|
import org.apache.commons.math.optimization.GoalType;
|
||||||
import org.apache.commons.math.optimization.ObjectiveException;
|
import org.apache.commons.math.optimization.ObjectiveException;
|
||||||
|
@ -28,7 +29,7 @@ import org.apache.commons.math.optimization.ScalarObjectiveFunction;
|
||||||
import org.apache.commons.math.optimization.OptimizationException;
|
import org.apache.commons.math.optimization.OptimizationException;
|
||||||
import org.apache.commons.math.optimization.ScalarOptimizer;
|
import org.apache.commons.math.optimization.ScalarOptimizer;
|
||||||
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
||||||
import org.apache.commons.math.optimization.SimpleValueChecker;
|
import org.apache.commons.math.optimization.SimpleScalarValueChecker;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class implements simplex-based direct search optimization
|
* This class implements simplex-based direct search optimization
|
||||||
|
@ -65,7 +66,7 @@ import org.apache.commons.math.optimization.SimpleValueChecker;
|
||||||
* will occur.</p>
|
* will occur.</p>
|
||||||
*
|
*
|
||||||
* <p>If {@link #setConvergenceChecker(ScalarConvergenceChecker)} is not called,
|
* <p>If {@link #setConvergenceChecker(ScalarConvergenceChecker)} is not called,
|
||||||
* a default {@link SimpleValueChecker} is used.</p>
|
* a default {@link SimpleScalarValueChecker} is used.</p>
|
||||||
*
|
*
|
||||||
* <p>Convergence is checked by providing the <em>worst</em> points of
|
* <p>Convergence is checked by providing the <em>worst</em> points of
|
||||||
* previous and current simplex to the convergence checker, not the best ones.</p>
|
* previous and current simplex to the convergence checker, not the best ones.</p>
|
||||||
|
@ -95,11 +96,14 @@ public abstract class DirectSearchOptimizer implements ScalarOptimizer {
|
||||||
/** Convergence checker. */
|
/** Convergence checker. */
|
||||||
private ScalarConvergenceChecker checker;
|
private ScalarConvergenceChecker checker;
|
||||||
|
|
||||||
/** Number of evaluations already performed for the current start. */
|
/** Maximal number of iterations allowed. */
|
||||||
private int evaluations;
|
private int maxIterations;
|
||||||
|
|
||||||
/** Maximal number of evaluations allowed. */
|
/** Number of iterations already performed. */
|
||||||
private int maxEvaluations;
|
private int iterations;
|
||||||
|
|
||||||
|
/** Number of evaluations already performed. */
|
||||||
|
private int evaluations;
|
||||||
|
|
||||||
/** Start simplex configuration. */
|
/** Start simplex configuration. */
|
||||||
private double[][] startConfiguration;
|
private double[][] startConfiguration;
|
||||||
|
@ -107,8 +111,8 @@ public abstract class DirectSearchOptimizer implements ScalarOptimizer {
|
||||||
/** Simple constructor.
|
/** Simple constructor.
|
||||||
*/
|
*/
|
||||||
protected DirectSearchOptimizer() {
|
protected DirectSearchOptimizer() {
|
||||||
setConvergenceChecker(new SimpleValueChecker());
|
setConvergenceChecker(new SimpleScalarValueChecker());
|
||||||
setMaxEvaluations(Integer.MAX_VALUE);
|
setMaxIterations(Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Set start configuration for simplex.
|
/** Set start configuration for simplex.
|
||||||
|
@ -208,13 +212,23 @@ public abstract class DirectSearchOptimizer implements ScalarOptimizer {
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public void setMaxEvaluations(int maxEvaluations) {
|
public void setMaxIterations(int maxIterations) {
|
||||||
this.maxEvaluations = maxEvaluations;
|
this.maxIterations = maxIterations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public int getMaxEvaluations() {
|
public int getMaxIterations() {
|
||||||
return maxEvaluations;
|
return maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getIterations() {
|
||||||
|
return iterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getEvaluations() {
|
||||||
|
return evaluations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -229,7 +243,7 @@ public abstract class DirectSearchOptimizer implements ScalarOptimizer {
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public ScalarPointValuePair optimize(final ScalarObjectiveFunction f, final GoalType goalType,
|
public ScalarPointValuePair optimize(final ScalarObjectiveFunction f, final GoalType goalType,
|
||||||
final double[] startPoint)
|
final double[] startPoint)
|
||||||
throws ObjectiveException, OptimizationException, IllegalArgumentException {
|
throws ObjectiveException, OptimizationException, IllegalArgumentException {
|
||||||
|
|
||||||
if (startConfiguration == null) {
|
if (startConfiguration == null) {
|
||||||
|
@ -251,15 +265,15 @@ public abstract class DirectSearchOptimizer implements ScalarOptimizer {
|
||||||
};
|
};
|
||||||
|
|
||||||
// initialize search
|
// initialize search
|
||||||
|
iterations = 0;
|
||||||
evaluations = 0;
|
evaluations = 0;
|
||||||
buildSimplex(startPoint);
|
buildSimplex(startPoint);
|
||||||
evaluateSimplex(comparator);
|
evaluateSimplex(comparator);
|
||||||
|
|
||||||
ScalarPointValuePair[] previous = new ScalarPointValuePair[simplex.length];
|
ScalarPointValuePair[] previous = new ScalarPointValuePair[simplex.length];
|
||||||
int iterations = 0;
|
while (true) {
|
||||||
while (evaluations <= maxEvaluations) {
|
|
||||||
|
|
||||||
if (++iterations > 1) {
|
if (iterations > 0) {
|
||||||
boolean converged = true;
|
boolean converged = true;
|
||||||
for (int i = 0; i < simplex.length; ++i) {
|
for (int i = 0; i < simplex.length; ++i) {
|
||||||
converged &= checker.converged(iterations, previous[i], simplex[i]);
|
converged &= checker.converged(iterations, previous[i], simplex[i]);
|
||||||
|
@ -276,22 +290,24 @@ public abstract class DirectSearchOptimizer implements ScalarOptimizer {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new OptimizationException(
|
|
||||||
"maximal number of evaluations exceeded ({0})",
|
|
||||||
evaluations);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** Increment the iterations counter by 1.
|
||||||
public int getEvaluations() {
|
* @exception OptimizationException if the maximal number
|
||||||
return evaluations;
|
* of iterations is exceeded
|
||||||
|
*/
|
||||||
|
protected void incrementIterationsCounter()
|
||||||
|
throws OptimizationException {
|
||||||
|
if (++iterations > maxIterations) {
|
||||||
|
throw new OptimizationException(new MaxIterationsExceededException(maxIterations));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Compute the next simplex of the algorithm.
|
/** Compute the next simplex of the algorithm.
|
||||||
* @param comparator comparator to use to sort simplex vertices from best to worst
|
* @param comparator comparator to use to sort simplex vertices from best to worst
|
||||||
* @exception ObjectiveException if the function cannot be evaluated at
|
* @exception ObjectiveException if the function cannot be evaluated at
|
||||||
* some point
|
* some point
|
||||||
* @exception OptimizationException if the algorithm failed to converge
|
* @exception OptimizationException if the algorithm fails to converge
|
||||||
* @exception IllegalArgumentException if the start point dimension is wrong
|
* @exception IllegalArgumentException if the start point dimension is wrong
|
||||||
*/
|
*/
|
||||||
protected abstract void iterateSimplex(final Comparator<ScalarPointValuePair> comparator)
|
protected abstract void iterateSimplex(final Comparator<ScalarPointValuePair> comparator)
|
||||||
|
|
|
@ -62,8 +62,9 @@ public class MultiDirectional extends DirectSearchOptimizer {
|
||||||
protected void iterateSimplex(final Comparator<ScalarPointValuePair> comparator)
|
protected void iterateSimplex(final Comparator<ScalarPointValuePair> comparator)
|
||||||
throws ObjectiveException, OptimizationException, IllegalArgumentException {
|
throws ObjectiveException, OptimizationException, IllegalArgumentException {
|
||||||
|
|
||||||
final int max = getMaxEvaluations();
|
while (true) {
|
||||||
while (getEvaluations() < max) {
|
|
||||||
|
incrementIterationsCounter();
|
||||||
|
|
||||||
// save the original vertex
|
// save the original vertex
|
||||||
final ScalarPointValuePair[] original = simplex;
|
final ScalarPointValuePair[] original = simplex;
|
||||||
|
@ -94,10 +95,6 @@ public class MultiDirectional extends DirectSearchOptimizer {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new OptimizationException(
|
|
||||||
"maximal number of evaluations exceeded ({0})",
|
|
||||||
getEvaluations());
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Compute and evaluate a new simplex.
|
/** Compute and evaluate a new simplex.
|
||||||
|
|
|
@ -20,6 +20,7 @@ package org.apache.commons.math.optimization.direct;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
|
||||||
import org.apache.commons.math.optimization.ObjectiveException;
|
import org.apache.commons.math.optimization.ObjectiveException;
|
||||||
|
import org.apache.commons.math.optimization.OptimizationException;
|
||||||
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -73,7 +74,9 @@ public class NelderMead extends DirectSearchOptimizer {
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
protected void iterateSimplex(final Comparator<ScalarPointValuePair> comparator)
|
protected void iterateSimplex(final Comparator<ScalarPointValuePair> comparator)
|
||||||
throws ObjectiveException {
|
throws ObjectiveException, OptimizationException {
|
||||||
|
|
||||||
|
incrementIterationsCounter();
|
||||||
|
|
||||||
// the simplex has n+1 point if dimension is n
|
// the simplex has n+1 point if dimension is n
|
||||||
final int n = simplex.length - 1;
|
final int n = simplex.length - 1;
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
|
|
||||||
package org.apache.commons.math.optimization.general;
|
package org.apache.commons.math.optimization.general;
|
||||||
|
|
||||||
|
import org.apache.commons.math.MaxIterationsExceededException;
|
||||||
import org.apache.commons.math.linear.InvalidMatrixException;
|
import org.apache.commons.math.linear.InvalidMatrixException;
|
||||||
import org.apache.commons.math.linear.MatrixUtils;
|
import org.apache.commons.math.linear.MatrixUtils;
|
||||||
import org.apache.commons.math.linear.RealMatrix;
|
import org.apache.commons.math.linear.RealMatrix;
|
||||||
|
@ -40,20 +41,23 @@ import org.apache.commons.math.optimization.VectorialPointValuePair;
|
||||||
public abstract class AbstractLeastSquaresOptimizer implements VectorialDifferentiableOptimizer {
|
public abstract class AbstractLeastSquaresOptimizer implements VectorialDifferentiableOptimizer {
|
||||||
|
|
||||||
/** Serializable version identifier */
|
/** Serializable version identifier */
|
||||||
private static final long serialVersionUID = -3080152374642370722L;
|
private static final long serialVersionUID = 5413193243329026789L;
|
||||||
|
|
||||||
/** Default maximal number of objective function evaluations allowed. */
|
/** Default maximal number of iterations allowed. */
|
||||||
public static final int DEFAULT_MAX_EVALUATIONS = 100;
|
public static final int DEFAULT_MAX_ITERATIONS = 100;
|
||||||
|
|
||||||
/** Number of evaluations already performed for the current start. */
|
/** Maximal number of iterations allowed. */
|
||||||
|
private int maxIterations;
|
||||||
|
|
||||||
|
/** Number of iterations already performed. */
|
||||||
|
private int iterations;
|
||||||
|
|
||||||
|
/** Number of evaluations already performed. */
|
||||||
private int objectiveEvaluations;
|
private int objectiveEvaluations;
|
||||||
|
|
||||||
/** Number of jacobian evaluations. */
|
/** Number of jacobian evaluations. */
|
||||||
private int jacobianEvaluations;
|
private int jacobianEvaluations;
|
||||||
|
|
||||||
/** Maximal number of evaluations allowed. */
|
|
||||||
private int maxEvaluations;
|
|
||||||
|
|
||||||
/** Convergence checker. */
|
/** Convergence checker. */
|
||||||
protected VectorialConvergenceChecker checker;
|
protected VectorialConvergenceChecker checker;
|
||||||
|
|
||||||
|
@ -99,17 +103,22 @@ public abstract class AbstractLeastSquaresOptimizer implements VectorialDifferen
|
||||||
*/
|
*/
|
||||||
protected AbstractLeastSquaresOptimizer() {
|
protected AbstractLeastSquaresOptimizer() {
|
||||||
setConvergenceChecker(new SimpleVectorialValueChecker());
|
setConvergenceChecker(new SimpleVectorialValueChecker());
|
||||||
setMaxEvaluations(DEFAULT_MAX_EVALUATIONS);
|
setMaxIterations(DEFAULT_MAX_ITERATIONS);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public void setMaxEvaluations(int maxEvaluations) {
|
public void setMaxIterations(int maxIterations) {
|
||||||
this.maxEvaluations = maxEvaluations;
|
this.maxIterations = maxIterations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public int getMaxEvaluations() {
|
public int getMaxIterations() {
|
||||||
return maxEvaluations;
|
return maxIterations;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** {@inheritDoc} */
|
||||||
|
public int getIterations() {
|
||||||
|
return iterations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -132,13 +141,26 @@ public abstract class AbstractLeastSquaresOptimizer implements VectorialDifferen
|
||||||
return checker;
|
return checker;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Increment the iterations counter by 1.
|
||||||
|
* @exception OptimizationException if the maximal number
|
||||||
|
* of iterations is exceeded
|
||||||
|
*/
|
||||||
|
protected void incrementIterationsCounter()
|
||||||
|
throws OptimizationException {
|
||||||
|
if (++iterations > maxIterations) {
|
||||||
|
if (++iterations > maxIterations) {
|
||||||
|
throw new OptimizationException(new MaxIterationsExceededException(maxIterations));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the jacobian matrix.
|
* Update the jacobian matrix.
|
||||||
* @exception ObjectiveException if the function jacobian
|
* @exception ObjectiveException if the function jacobian
|
||||||
* cannot be evaluated or its dimension doesn't match problem dimension
|
* cannot be evaluated or its dimension doesn't match problem dimension
|
||||||
*/
|
*/
|
||||||
protected void updateJacobian() throws ObjectiveException {
|
protected void updateJacobian() throws ObjectiveException {
|
||||||
incrementJacobianEvaluationsCounter();
|
++jacobianEvaluations;
|
||||||
jacobian = f.jacobian(variables, objective);
|
jacobian = f.jacobian(variables, objective);
|
||||||
if (jacobian.length != rows) {
|
if (jacobian.length != rows) {
|
||||||
throw new ObjectiveException("dimension mismatch {0} != {1}",
|
throw new ObjectiveException("dimension mismatch {0} != {1}",
|
||||||
|
@ -153,28 +175,13 @@ public abstract class AbstractLeastSquaresOptimizer implements VectorialDifferen
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Increment the jacobian evaluations counter.
|
|
||||||
*/
|
|
||||||
protected final void incrementJacobianEvaluationsCounter() {
|
|
||||||
++jacobianEvaluations;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the residuals array and cost function value.
|
* Update the residuals array and cost function value.
|
||||||
* @exception ObjectiveException if the function cannot be evaluated
|
* @exception ObjectiveException if the function cannot be evaluated
|
||||||
* or its dimension doesn't match problem dimension
|
* or its dimension doesn't match problem dimension
|
||||||
* @exception OptimizationException if the number of cost evaluations
|
|
||||||
* exceeds the maximum allowed
|
|
||||||
*/
|
*/
|
||||||
protected void updateResidualsAndCost()
|
protected void updateResidualsAndCost()
|
||||||
throws ObjectiveException, OptimizationException {
|
throws ObjectiveException {
|
||||||
|
|
||||||
if (++objectiveEvaluations > maxEvaluations) {
|
|
||||||
throw new OptimizationException(
|
|
||||||
"maximal number of evaluations exceeded ({0})",
|
|
||||||
objectiveEvaluations);
|
|
||||||
}
|
|
||||||
|
|
||||||
objective = f.objective(variables);
|
objective = f.objective(variables);
|
||||||
if (objective.length != rows) {
|
if (objective.length != rows) {
|
||||||
|
@ -298,6 +305,7 @@ public abstract class AbstractLeastSquaresOptimizer implements VectorialDifferen
|
||||||
}
|
}
|
||||||
|
|
||||||
// reset counters
|
// reset counters
|
||||||
|
iterations = 0;
|
||||||
objectiveEvaluations = 0;
|
objectiveEvaluations = 0;
|
||||||
jacobianEvaluations = 0;
|
jacobianEvaluations = 0;
|
||||||
|
|
||||||
|
@ -327,6 +335,6 @@ public abstract class AbstractLeastSquaresOptimizer implements VectorialDifferen
|
||||||
* @exception IllegalArgumentException if the start point dimension is wrong
|
* @exception IllegalArgumentException if the start point dimension is wrong
|
||||||
*/
|
*/
|
||||||
abstract protected VectorialPointValuePair doOptimize()
|
abstract protected VectorialPointValuePair doOptimize()
|
||||||
throws ObjectiveException, OptimizationException, IllegalArgumentException;
|
throws ObjectiveException, OptimizationException, IllegalArgumentException;
|
||||||
|
|
||||||
}
|
}
|
|
@ -53,7 +53,7 @@ public class GaussNewtonOptimizer extends AbstractLeastSquaresOptimizer {
|
||||||
/** Simple constructor with default settings.
|
/** Simple constructor with default settings.
|
||||||
* <p>The convergence check is set to a {@link SimpleVectorialValueChecker}
|
* <p>The convergence check is set to a {@link SimpleVectorialValueChecker}
|
||||||
* and the maximal number of evaluation is set to
|
* and the maximal number of evaluation is set to
|
||||||
* {@link AbstractLeastSquaresOptimizer#DEFAULT_MAX_EVALUATIONS}.
|
* {@link AbstractLeastSquaresOptimizer#DEFAULT_MAX_ITERATIONS}.
|
||||||
* @param useLU if true, the normal equations will be solved using LU
|
* @param useLU if true, the normal equations will be solved using LU
|
||||||
* decomposition, otherwise they will be solved using QR decomposition
|
* decomposition, otherwise they will be solved using QR decomposition
|
||||||
*/
|
*/
|
||||||
|
@ -67,8 +67,9 @@ public class GaussNewtonOptimizer extends AbstractLeastSquaresOptimizer {
|
||||||
|
|
||||||
// iterate until convergence is reached
|
// iterate until convergence is reached
|
||||||
VectorialPointValuePair current = null;
|
VectorialPointValuePair current = null;
|
||||||
boolean converged = false;
|
for (boolean converged = false; !converged;) {
|
||||||
for (int iteration = 1; ! converged; ++iteration) {
|
|
||||||
|
incrementIterationsCounter();
|
||||||
|
|
||||||
// evaluate the objective function and its jacobian
|
// evaluate the objective function and its jacobian
|
||||||
VectorialPointValuePair previous = current;
|
VectorialPointValuePair previous = current;
|
||||||
|
@ -122,7 +123,7 @@ public class GaussNewtonOptimizer extends AbstractLeastSquaresOptimizer {
|
||||||
|
|
||||||
// check convergence
|
// check convergence
|
||||||
if (previous != null) {
|
if (previous != null) {
|
||||||
converged = checker.converged(++iteration, previous, current);
|
converged = checker.converged(getIterations(), previous, current);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -146,7 +146,7 @@ public class LevenbergMarquardtOptimizer extends AbstractLeastSquaresOptimizer {
|
||||||
* <p>The default values for the algorithm settings are:
|
* <p>The default values for the algorithm settings are:
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li>{@link #setInitialStepBoundFactor initial step bound factor}: 100.0</li>
|
* <li>{@link #setInitialStepBoundFactor initial step bound factor}: 100.0</li>
|
||||||
* <li>{@link #setMaxCostEval maximal cost evaluations}: 1000</li>
|
* <li>{@link #setMaxIterations maximal iterations}: 1000</li>
|
||||||
* <li>{@link #setCostRelativeTolerance cost relative tolerance}: 1.0e-10</li>
|
* <li>{@link #setCostRelativeTolerance cost relative tolerance}: 1.0e-10</li>
|
||||||
* <li>{@link #setParRelativeTolerance parameters relative tolerance}: 1.0e-10</li>
|
* <li>{@link #setParRelativeTolerance parameters relative tolerance}: 1.0e-10</li>
|
||||||
* <li>{@link #setOrthoTolerance orthogonality tolerance}: 1.0e-10</li>
|
* <li>{@link #setOrthoTolerance orthogonality tolerance}: 1.0e-10</li>
|
||||||
|
@ -156,7 +156,7 @@ public class LevenbergMarquardtOptimizer extends AbstractLeastSquaresOptimizer {
|
||||||
public LevenbergMarquardtOptimizer() {
|
public LevenbergMarquardtOptimizer() {
|
||||||
|
|
||||||
// set up the superclass with a default max cost evaluations setting
|
// set up the superclass with a default max cost evaluations setting
|
||||||
setMaxEvaluations(1000);
|
setMaxIterations(1000);
|
||||||
|
|
||||||
// default values for the tuning parameters
|
// default values for the tuning parameters
|
||||||
setInitialStepBoundFactor(100.0);
|
setInitialStepBoundFactor(100.0);
|
||||||
|
@ -237,6 +237,8 @@ public class LevenbergMarquardtOptimizer extends AbstractLeastSquaresOptimizer {
|
||||||
boolean firstIteration = true;
|
boolean firstIteration = true;
|
||||||
while (true) {
|
while (true) {
|
||||||
|
|
||||||
|
incrementIterationsCounter();
|
||||||
|
|
||||||
// compute the Q.R. decomposition of the jacobian matrix
|
// compute the Q.R. decomposition of the jacobian matrix
|
||||||
updateJacobian();
|
updateJacobian();
|
||||||
qrDecomposition();
|
qrDecomposition();
|
||||||
|
|
|
@ -27,7 +27,7 @@ import org.apache.commons.math.optimization.GoalType;
|
||||||
import org.apache.commons.math.optimization.ObjectiveException;
|
import org.apache.commons.math.optimization.ObjectiveException;
|
||||||
import org.apache.commons.math.optimization.ScalarObjectiveFunction;
|
import org.apache.commons.math.optimization.ScalarObjectiveFunction;
|
||||||
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
||||||
import org.apache.commons.math.optimization.SimpleValueChecker;
|
import org.apache.commons.math.optimization.SimpleScalarValueChecker;
|
||||||
|
|
||||||
public class MultiDirectionalTest
|
public class MultiDirectionalTest
|
||||||
extends TestCase {
|
extends TestCase {
|
||||||
|
@ -94,8 +94,8 @@ public class MultiDirectionalTest
|
||||||
};
|
};
|
||||||
|
|
||||||
MultiDirectional optimizer = new MultiDirectional();
|
MultiDirectional optimizer = new MultiDirectional();
|
||||||
optimizer.setConvergenceChecker(new SimpleValueChecker(1.0e-10, 1.0e-30));
|
optimizer.setConvergenceChecker(new SimpleScalarValueChecker(1.0e-10, 1.0e-30));
|
||||||
optimizer.setMaxEvaluations(200);
|
optimizer.setMaxIterations(200);
|
||||||
optimizer.setStartConfiguration(new double[] { 0.2, 0.2 });
|
optimizer.setStartConfiguration(new double[] { 0.2, 0.2 });
|
||||||
ScalarPointValuePair optimum;
|
ScalarPointValuePair optimum;
|
||||||
|
|
||||||
|
@ -147,8 +147,8 @@ public class MultiDirectionalTest
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
MultiDirectional optimizer = new MultiDirectional();
|
MultiDirectional optimizer = new MultiDirectional();
|
||||||
optimizer.setConvergenceChecker(new SimpleValueChecker(-1, 1.0e-3));
|
optimizer.setConvergenceChecker(new SimpleScalarValueChecker(-1, 1.0e-3));
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setStartConfiguration(new double[][] {
|
optimizer.setStartConfiguration(new double[][] {
|
||||||
{ -1.2, 1.0 }, { 0.9, 1.2 } , { 3.5, -2.3 }
|
{ -1.2, 1.0 }, { 0.9, 1.2 } , { 3.5, -2.3 }
|
||||||
});
|
});
|
||||||
|
@ -180,8 +180,8 @@ public class MultiDirectionalTest
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
MultiDirectional optimizer = new MultiDirectional();
|
MultiDirectional optimizer = new MultiDirectional();
|
||||||
optimizer.setConvergenceChecker(new SimpleValueChecker(-1.0, 1.0e-3));
|
optimizer.setConvergenceChecker(new SimpleScalarValueChecker(-1.0, 1.0e-3));
|
||||||
optimizer.setMaxEvaluations(1000);
|
optimizer.setMaxIterations(1000);
|
||||||
ScalarPointValuePair optimum =
|
ScalarPointValuePair optimum =
|
||||||
optimizer.optimize(powell, GoalType.MINIMIZE, new double[] { 3.0, -1.0, 0.0, 1.0 });
|
optimizer.optimize(powell, GoalType.MINIMIZE, new double[] { 3.0, -1.0, 0.0, 1.0 });
|
||||||
assertEquals(count, optimizer.getEvaluations());
|
assertEquals(count, optimizer.getEvaluations());
|
||||||
|
|
|
@ -27,7 +27,7 @@ import org.apache.commons.math.optimization.GoalType;
|
||||||
import org.apache.commons.math.optimization.ObjectiveException;
|
import org.apache.commons.math.optimization.ObjectiveException;
|
||||||
import org.apache.commons.math.optimization.ScalarObjectiveFunction;
|
import org.apache.commons.math.optimization.ScalarObjectiveFunction;
|
||||||
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
import org.apache.commons.math.optimization.ScalarPointValuePair;
|
||||||
import org.apache.commons.math.optimization.SimpleValueChecker;
|
import org.apache.commons.math.optimization.SimpleScalarValueChecker;
|
||||||
|
|
||||||
public class NelderMeadTest
|
public class NelderMeadTest
|
||||||
extends TestCase {
|
extends TestCase {
|
||||||
|
@ -94,8 +94,8 @@ public class NelderMeadTest
|
||||||
};
|
};
|
||||||
|
|
||||||
NelderMead optimizer = new NelderMead();
|
NelderMead optimizer = new NelderMead();
|
||||||
optimizer.setConvergenceChecker(new SimpleValueChecker(1.0e-10, 1.0e-30));
|
optimizer.setConvergenceChecker(new SimpleScalarValueChecker(1.0e-10, 1.0e-30));
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setStartConfiguration(new double[] { 0.2, 0.2 });
|
optimizer.setStartConfiguration(new double[] { 0.2, 0.2 });
|
||||||
ScalarPointValuePair optimum;
|
ScalarPointValuePair optimum;
|
||||||
|
|
||||||
|
@ -147,8 +147,8 @@ public class NelderMeadTest
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
NelderMead optimizer = new NelderMead();
|
NelderMead optimizer = new NelderMead();
|
||||||
optimizer.setConvergenceChecker(new SimpleValueChecker(-1, 1.0e-3));
|
optimizer.setConvergenceChecker(new SimpleScalarValueChecker(-1, 1.0e-3));
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setStartConfiguration(new double[][] {
|
optimizer.setStartConfiguration(new double[][] {
|
||||||
{ -1.2, 1.0 }, { 0.9, 1.2 } , { 3.5, -2.3 }
|
{ -1.2, 1.0 }, { 0.9, 1.2 } , { 3.5, -2.3 }
|
||||||
});
|
});
|
||||||
|
@ -180,8 +180,8 @@ public class NelderMeadTest
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
NelderMead optimizer = new NelderMead();
|
NelderMead optimizer = new NelderMead();
|
||||||
optimizer.setConvergenceChecker(new SimpleValueChecker(-1.0, 1.0e-3));
|
optimizer.setConvergenceChecker(new SimpleScalarValueChecker(-1.0, 1.0e-3));
|
||||||
optimizer.setMaxEvaluations(200);
|
optimizer.setMaxIterations(200);
|
||||||
ScalarPointValuePair optimum =
|
ScalarPointValuePair optimum =
|
||||||
optimizer.optimize(powell, GoalType.MINIMIZE, new double[] { 3.0, -1.0, 0.0, 1.0 });
|
optimizer.optimize(powell, GoalType.MINIMIZE, new double[] { 3.0, -1.0, 0.0, 1.0 });
|
||||||
assertEquals(count, optimizer.getEvaluations());
|
assertEquals(count, optimizer.getEvaluations());
|
||||||
|
|
|
@ -106,7 +106,7 @@ extends TestCase {
|
||||||
LinearProblem problem =
|
LinearProblem problem =
|
||||||
new LinearProblem(new double[][] { { 2 } }, new double[] { 3 });
|
new LinearProblem(new double[][] { { 2 } }, new double[] { 3 });
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1 }, new double[] { 0 });
|
optimizer.optimize(problem, problem.target, new double[] { 1 }, new double[] { 0 });
|
||||||
|
@ -122,7 +122,7 @@ extends TestCase {
|
||||||
new double[] { 4.0, 6.0, 1.0 });
|
new double[] { 4.0, 6.0, 1.0 });
|
||||||
|
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 0, 0 });
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 0, 0 });
|
||||||
|
@ -145,7 +145,7 @@ extends TestCase {
|
||||||
{ 0, 0, 0, 0, 0, 2 }
|
{ 0, 0, 0, 0, 0, 2 }
|
||||||
}, new double[] { 0.0, 1.1, 2.2, 3.3, 4.4, 5.5 });
|
}, new double[] { 0.0, 1.1, 2.2, 3.3, 4.4, 5.5 });
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1, 1, 1, 1 },
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1, 1, 1, 1 },
|
||||||
|
@ -164,7 +164,7 @@ extends TestCase {
|
||||||
{ 0, -1, 1 }
|
{ 0, -1, 1 }
|
||||||
}, new double[] { 1, 1, 1});
|
}, new double[] { 1, 1, 1});
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 0, 0, 0 });
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 0, 0, 0 });
|
||||||
|
@ -187,7 +187,7 @@ extends TestCase {
|
||||||
}, new double[] { 2, -9, 2, 2, 1 + epsilon * epsilon, 2});
|
}, new double[] { 2, -9, 2, 2, 1 + epsilon * epsilon, 2});
|
||||||
|
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1, 1, 1, 1 },
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1, 1, 1, 1 },
|
||||||
|
@ -210,7 +210,7 @@ extends TestCase {
|
||||||
{ -3, 0, -9 }
|
{ -3, 0, -9 }
|
||||||
}, new double[] { 1, 1, 1 });
|
}, new double[] { 1, 1, 1 });
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
try {
|
try {
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 0, 0, 0 });
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 0, 0, 0 });
|
||||||
|
@ -230,7 +230,7 @@ extends TestCase {
|
||||||
{ 7.0, 5.0, 9.0, 10.0 }
|
{ 7.0, 5.0, 9.0, 10.0 }
|
||||||
}, new double[] { 32, 23, 33, 31 });
|
}, new double[] { 32, 23, 33, 31 });
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
VectorialPointValuePair optimum1 =
|
VectorialPointValuePair optimum1 =
|
||||||
optimizer.optimize(problem1, problem1.target, new double[] { 1, 1, 1, 1 },
|
optimizer.optimize(problem1, problem1.target, new double[] { 1, 1, 1, 1 },
|
||||||
|
@ -267,7 +267,7 @@ extends TestCase {
|
||||||
}, new double[] { 7.0, 3.0, 5.0 });
|
}, new double[] { 7.0, 3.0, 5.0 });
|
||||||
|
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
try {
|
try {
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 },
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 },
|
||||||
|
@ -290,7 +290,7 @@ extends TestCase {
|
||||||
{ 0.0, 0.0, 0.0, -1.0, 1.0, 0.0 }
|
{ 0.0, 0.0, 0.0, -1.0, 1.0, 0.0 }
|
||||||
}, new double[] { 3.0, 12.0, -1.0, 7.0, 1.0 });
|
}, new double[] { 3.0, 12.0, -1.0, 7.0, 1.0 });
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
try {
|
try {
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1, 1, 1 },
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1, 1, 1 },
|
||||||
|
@ -311,7 +311,7 @@ extends TestCase {
|
||||||
}, new double[] { 3.0, 1.0, 5.0 });
|
}, new double[] { 3.0, 1.0, 5.0 });
|
||||||
|
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 },
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 },
|
||||||
|
@ -330,7 +330,7 @@ extends TestCase {
|
||||||
}, new double[] { 3.0, 1.0, 4.0 });
|
}, new double[] { 3.0, 1.0, 4.0 });
|
||||||
|
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 1, 1 });
|
optimizer.optimize(problem, problem.target, new double[] { 1, 1, 1 }, new double[] { 1, 1 });
|
||||||
assertTrue(optimizer.getRMS() > 0.1);
|
assertTrue(optimizer.getRMS() > 0.1);
|
||||||
|
@ -341,7 +341,7 @@ extends TestCase {
|
||||||
LinearProblem problem =
|
LinearProblem problem =
|
||||||
new LinearProblem(new double[][] { { 1, 0 }, { 0, 1 } }, new double[] { -1, 1 });
|
new LinearProblem(new double[][] { { 1, 0 }, { 0, 1 } }, new double[] { -1, 1 });
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
|
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
|
@ -382,7 +382,7 @@ extends TestCase {
|
||||||
circle.addPoint( 35.0, 15.0);
|
circle.addPoint( 35.0, 15.0);
|
||||||
circle.addPoint( 45.0, 97.0);
|
circle.addPoint( 45.0, 97.0);
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-15, 1.0e-15));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-15, 1.0e-15));
|
||||||
try {
|
try {
|
||||||
optimizer.optimize(circle, new double[] { 0, 0, 0, 0, 0 },
|
optimizer.optimize(circle, new double[] { 0, 0, 0, 0, 0 },
|
||||||
|
@ -404,7 +404,7 @@ extends TestCase {
|
||||||
circle.addPoint( 35.0, 15.0);
|
circle.addPoint( 35.0, 15.0);
|
||||||
circle.addPoint( 45.0, 97.0);
|
circle.addPoint( 45.0, 97.0);
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-13, 1.0e-13));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-13, 1.0e-13));
|
||||||
VectorialPointValuePair optimum =
|
VectorialPointValuePair optimum =
|
||||||
optimizer.optimize(circle, new double[] { 0, 0, 0, 0, 0 },
|
optimizer.optimize(circle, new double[] { 0, 0, 0, 0, 0 },
|
||||||
|
@ -458,7 +458,7 @@ extends TestCase {
|
||||||
circle.addPoint(points[i][0], points[i][1]);
|
circle.addPoint(points[i][0], points[i][1]);
|
||||||
}
|
}
|
||||||
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
GaussNewtonOptimizer optimizer = new GaussNewtonOptimizer(true);
|
||||||
optimizer.setMaxEvaluations(100);
|
optimizer.setMaxIterations(100);
|
||||||
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
optimizer.setConvergenceChecker(new SimpleVectorialValueChecker(1.0e-6, 1.0e-6));
|
||||||
try {
|
try {
|
||||||
optimizer.optimize(circle, target, weights, new double[] { -12, -12 });
|
optimizer.optimize(circle, target, weights, new double[] { -12, -12 });
|
||||||
|
|
|
@ -379,7 +379,7 @@ public class LevenbergMarquardtOptimizerTest
|
||||||
try {
|
try {
|
||||||
LevenbergMarquardtOptimizer optimizer = new LevenbergMarquardtOptimizer();
|
LevenbergMarquardtOptimizer optimizer = new LevenbergMarquardtOptimizer();
|
||||||
optimizer.setInitialStepBoundFactor(initialStepBoundFactor);
|
optimizer.setInitialStepBoundFactor(initialStepBoundFactor);
|
||||||
optimizer.setMaxEvaluations(maxCostEval);
|
optimizer.setMaxIterations(maxCostEval);
|
||||||
optimizer.setCostRelativeTolerance(costRelativeTolerance);
|
optimizer.setCostRelativeTolerance(costRelativeTolerance);
|
||||||
optimizer.setParRelativeTolerance(parRelativeTolerance);
|
optimizer.setParRelativeTolerance(parRelativeTolerance);
|
||||||
optimizer.setOrthoTolerance(orthoTolerance);
|
optimizer.setOrthoTolerance(orthoTolerance);
|
||||||
|
|
|
@ -219,7 +219,7 @@ public class MinpackTest extends TestCase {
|
||||||
0.188053165007911,
|
0.188053165007911,
|
||||||
0.122430604321144,
|
0.122430604321144,
|
||||||
0.134575665392506
|
0.134575665392506
|
||||||
}), true);
|
}), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testMinpackMeyer()
|
public void testMinpackMeyer()
|
||||||
|
@ -505,7 +505,7 @@ public class MinpackTest extends TestCase {
|
||||||
|
|
||||||
private void minpackTest(MinpackFunction function, boolean exceptionExpected) {
|
private void minpackTest(MinpackFunction function, boolean exceptionExpected) {
|
||||||
LevenbergMarquardtOptimizer optimizer = new LevenbergMarquardtOptimizer();
|
LevenbergMarquardtOptimizer optimizer = new LevenbergMarquardtOptimizer();
|
||||||
optimizer.setMaxEvaluations(100 * (function.getN() + 1));
|
optimizer.setMaxIterations(100 * (function.getN() + 1));
|
||||||
optimizer.setCostRelativeTolerance(Math.sqrt(2.22044604926e-16));
|
optimizer.setCostRelativeTolerance(Math.sqrt(2.22044604926e-16));
|
||||||
optimizer.setParRelativeTolerance(Math.sqrt(2.22044604926e-16));
|
optimizer.setParRelativeTolerance(Math.sqrt(2.22044604926e-16));
|
||||||
optimizer.setOrthoTolerance(2.22044604926e-16);
|
optimizer.setOrthoTolerance(2.22044604926e-16);
|
||||||
|
|
Loading…
Reference in New Issue