Removed interfaces in the fluent API that do not add any value.
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1569363 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
613a83c56a
commit
b0521ef7e0
|
@ -32,8 +32,6 @@ import org.apache.commons.math3.exception.NotStrictlyPositiveException;
|
||||||
import org.apache.commons.math3.exception.util.LocalizedFormats;
|
import org.apache.commons.math3.exception.util.LocalizedFormats;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresBuilder;
|
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresBuilder;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresProblem;
|
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresProblem;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.WithStartPoint;
|
|
||||||
import org.apache.commons.math3.fitting.leastsquares.WithMaxIterations;
|
|
||||||
import org.apache.commons.math3.util.FastMath;
|
import org.apache.commons.math3.util.FastMath;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -72,9 +70,7 @@ import org.apache.commons.math3.util.FastMath;
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
* @since 3.3
|
* @since 3.3
|
||||||
*/
|
*/
|
||||||
public class GaussianCurveFitter extends AbstractCurveFitter
|
public class GaussianCurveFitter extends AbstractCurveFitter {
|
||||||
implements WithStartPoint<GaussianCurveFitter>,
|
|
||||||
WithMaxIterations<GaussianCurveFitter> {
|
|
||||||
/** Parametric function to be fitted. */
|
/** Parametric function to be fitted. */
|
||||||
private static final Gaussian.Parametric FUNCTION = new Gaussian.Parametric() {
|
private static final Gaussian.Parametric FUNCTION = new Gaussian.Parametric() {
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -27,8 +27,6 @@ import org.apache.commons.math3.exception.ZeroException;
|
||||||
import org.apache.commons.math3.exception.util.LocalizedFormats;
|
import org.apache.commons.math3.exception.util.LocalizedFormats;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresBuilder;
|
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresBuilder;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresProblem;
|
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresProblem;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.WithMaxIterations;
|
|
||||||
import org.apache.commons.math3.fitting.leastsquares.WithStartPoint;
|
|
||||||
import org.apache.commons.math3.linear.DiagonalMatrix;
|
import org.apache.commons.math3.linear.DiagonalMatrix;
|
||||||
import org.apache.commons.math3.util.FastMath;
|
import org.apache.commons.math3.util.FastMath;
|
||||||
|
|
||||||
|
@ -49,9 +47,7 @@ import org.apache.commons.math3.util.FastMath;
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
* @since 3.3
|
* @since 3.3
|
||||||
*/
|
*/
|
||||||
public class HarmonicCurveFitter extends AbstractCurveFitter
|
public class HarmonicCurveFitter extends AbstractCurveFitter {
|
||||||
implements WithStartPoint<HarmonicCurveFitter>,
|
|
||||||
WithMaxIterations<HarmonicCurveFitter> {
|
|
||||||
/** Parametric function to be fitted. */
|
/** Parametric function to be fitted. */
|
||||||
private static final HarmonicOscillator.Parametric FUNCTION = new HarmonicOscillator.Parametric();
|
private static final HarmonicOscillator.Parametric FUNCTION = new HarmonicOscillator.Parametric();
|
||||||
/** Initial guess. */
|
/** Initial guess. */
|
||||||
|
|
|
@ -22,8 +22,6 @@ import org.apache.commons.math3.analysis.polynomials.PolynomialFunction;
|
||||||
import org.apache.commons.math3.exception.MathInternalError;
|
import org.apache.commons.math3.exception.MathInternalError;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresBuilder;
|
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresBuilder;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresProblem;
|
import org.apache.commons.math3.fitting.leastsquares.LeastSquaresProblem;
|
||||||
import org.apache.commons.math3.fitting.leastsquares.WithMaxIterations;
|
|
||||||
import org.apache.commons.math3.fitting.leastsquares.WithStartPoint;
|
|
||||||
import org.apache.commons.math3.linear.DiagonalMatrix;
|
import org.apache.commons.math3.linear.DiagonalMatrix;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -39,9 +37,7 @@ import org.apache.commons.math3.linear.DiagonalMatrix;
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
* @since 3.3
|
* @since 3.3
|
||||||
*/
|
*/
|
||||||
public class PolynomialCurveFitter extends AbstractCurveFitter
|
public class PolynomialCurveFitter extends AbstractCurveFitter {
|
||||||
implements WithStartPoint<PolynomialCurveFitter>,
|
|
||||||
WithMaxIterations<PolynomialCurveFitter> {
|
|
||||||
/** Parametric function to be fitted. */
|
/** Parametric function to be fitted. */
|
||||||
private static final PolynomialFunction.Parametric FUNCTION = new PolynomialFunction.Parametric();
|
private static final PolynomialFunction.Parametric FUNCTION = new PolynomialFunction.Parametric();
|
||||||
/** Initial guess. */
|
/** Initial guess. */
|
||||||
|
|
|
@ -1,39 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.apache.commons.math3.fitting.leastsquares;
|
|
||||||
|
|
||||||
import org.apache.commons.math3.optim.ConvergenceChecker;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for "fluent-API" that advertizes a capability of the optimizer.
|
|
||||||
*
|
|
||||||
* @param <T> Concrete optimizer implementation.
|
|
||||||
* @param <PAIR> Parametric type for the {@link ConvergenceChecker}.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
* @since 3.3
|
|
||||||
*/
|
|
||||||
public interface WithConvergenceChecker<PAIR, T> {
|
|
||||||
/**
|
|
||||||
* Creates a new instance with the specified parameter.
|
|
||||||
*
|
|
||||||
* @param checker Convergence checker.
|
|
||||||
* @return a new optimizer instance with all fields identical to this
|
|
||||||
* instance except for the given argument.
|
|
||||||
*/
|
|
||||||
T withConvergenceChecker(ConvergenceChecker<PAIR> checker);
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.apache.commons.math3.fitting.leastsquares;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for "fluent-API" that advertizes a capability of the optimizer.
|
|
||||||
*
|
|
||||||
* @param <T> Concrete optimizer implementation.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
* @since 3.3
|
|
||||||
*/
|
|
||||||
public interface WithMaxEvaluations<T> {
|
|
||||||
/**
|
|
||||||
* Creates a new instance with the specified parameter.
|
|
||||||
*
|
|
||||||
* @param maxEval Maximum number of evaluations of the model function.
|
|
||||||
* @return a new optimizer instance with all fields identical to this
|
|
||||||
* instance except for the given argument.
|
|
||||||
*/
|
|
||||||
T withMaxEvaluations(int maxEval);
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.apache.commons.math3.fitting.leastsquares;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for "fluent-API" that advertizes a capability of the optimizer.
|
|
||||||
*
|
|
||||||
* @param <T> Concrete optimizer implementation.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
* @since 3.3
|
|
||||||
*/
|
|
||||||
public interface WithMaxIterations<T> {
|
|
||||||
/**
|
|
||||||
* Creates a new instance with the specified parameter.
|
|
||||||
*
|
|
||||||
* @param maxIter Maximum number of iterations.
|
|
||||||
* @return a new optimizer instance with all fields identical to this
|
|
||||||
* instance except for the given argument.
|
|
||||||
*/
|
|
||||||
T withMaxIterations(int maxIter);
|
|
||||||
}
|
|
|
@ -1,41 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.apache.commons.math3.fitting.leastsquares;
|
|
||||||
|
|
||||||
import org.apache.commons.math3.analysis.MultivariateVectorFunction;
|
|
||||||
import org.apache.commons.math3.analysis.MultivariateMatrixFunction;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for "fluent-API" that advertizes a capability of the optimizer.
|
|
||||||
*
|
|
||||||
* @param <T> Concrete optimizer implementation.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
* @since 3.3
|
|
||||||
*/
|
|
||||||
public interface WithModelAndJacobian<T> {
|
|
||||||
/**
|
|
||||||
* Creates a new instance with the specified parameters.
|
|
||||||
*
|
|
||||||
* @param model ModelFunction.
|
|
||||||
* @param jacobian Jacobian of the model function.
|
|
||||||
* @return a new optimizer instance with all fields identical to this
|
|
||||||
* instance except for the given arguments.
|
|
||||||
*/
|
|
||||||
T withModelAndJacobian(MultivariateVectorFunction model,
|
|
||||||
MultivariateMatrixFunction jacobian);
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.apache.commons.math3.fitting.leastsquares;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for "fluent-API" that advertizes a capability of the optimizer.
|
|
||||||
*
|
|
||||||
* @param <T> Concrete optimizer implementation.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
* @since 3.3
|
|
||||||
*/
|
|
||||||
public interface WithStartPoint<T> {
|
|
||||||
/**
|
|
||||||
* Creates a new instance with the specified parameter.
|
|
||||||
*
|
|
||||||
* @param start Initial guess for the parameters of the model function.
|
|
||||||
* @return a new optimizer instance with all fields identical to this
|
|
||||||
* instance except for the given argument.
|
|
||||||
*/
|
|
||||||
T withStartPoint(double[] start);
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.apache.commons.math3.fitting.leastsquares;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for "fluent-API" that advertizes a capability of the optimizer.
|
|
||||||
*
|
|
||||||
* @param <T> Concrete optimizer implementation.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
* @since 3.3
|
|
||||||
*/
|
|
||||||
public interface WithTarget<T> {
|
|
||||||
/**
|
|
||||||
* Creates a new instance with the specified parameter.
|
|
||||||
*
|
|
||||||
* @param target Objective points of the model function.
|
|
||||||
* @return a new optimizer instance with all fields identical to this
|
|
||||||
* instance except for the given argument.
|
|
||||||
*/
|
|
||||||
T withTarget(double[] target);
|
|
||||||
}
|
|
|
@ -1,38 +0,0 @@
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
||||||
* contributor license agreements. See the NOTICE file distributed with
|
|
||||||
* this work for additional information regarding copyright ownership.
|
|
||||||
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
||||||
* (the "License"); you may not use this file except in compliance with
|
|
||||||
* the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.apache.commons.math3.fitting.leastsquares;
|
|
||||||
|
|
||||||
import org.apache.commons.math3.linear.RealMatrix;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Interface for "fluent-API" that advertizes a capability of the optimizer.
|
|
||||||
*
|
|
||||||
* @param <T> Concrete optimizer implementation.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
* @since 3.3
|
|
||||||
*/
|
|
||||||
public interface WithWeight<T> {
|
|
||||||
/**
|
|
||||||
* Creates a new instance with the specified parameter.
|
|
||||||
*
|
|
||||||
* @param weight Weight matrix of the observations.
|
|
||||||
* @return a new optimizer instance with all fields identical to this
|
|
||||||
* instance except for the given argument.
|
|
||||||
*/
|
|
||||||
T withWeight(RealMatrix weight);
|
|
||||||
}
|
|
Loading…
Reference in New Issue