AbstractUnivariateSolver.java

  1. /*
  2.  * Licensed to the Apache Software Foundation (ASF) under one or more
  3.  * contributor license agreements.  See the NOTICE file distributed with
  4.  * this work for additional information regarding copyright ownership.
  5.  * The ASF licenses this file to You under the Apache License, Version 2.0
  6.  * (the "License"); you may not use this file except in compliance with
  7.  * the License.  You may obtain a copy of the License at
  8.  *
  9.  *      https://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  * Unless required by applicable law or agreed to in writing, software
  12.  * distributed under the License is distributed on an "AS IS" BASIS,
  13.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  * See the License for the specific language governing permissions and
  15.  * limitations under the License.
  16.  */

  17. /*
  18.  * This is not the original file distributed by the Apache Software Foundation
  19.  * It has been modified by the Hipparchus project
  20.  */

  21. package org.hipparchus.analysis.solvers;

  22. import org.hipparchus.analysis.UnivariateFunction;

  23. /**
  24.  * Base class for solvers.
  25.  *
  26.  */
  27. public abstract class AbstractUnivariateSolver
  28.     extends BaseAbstractUnivariateSolver<UnivariateFunction>
  29.     implements UnivariateSolver {
  30.     /**
  31.      * Construct a solver with given absolute accuracy.
  32.      *
  33.      * @param absoluteAccuracy Maximum absolute error.
  34.      */
  35.     protected AbstractUnivariateSolver(final double absoluteAccuracy) {
  36.         super(absoluteAccuracy);
  37.     }
  38.     /**
  39.      * Construct a solver with given accuracies.
  40.      *
  41.      * @param relativeAccuracy Maximum relative error.
  42.      * @param absoluteAccuracy Maximum absolute error.
  43.      */
  44.     protected AbstractUnivariateSolver(final double relativeAccuracy,
  45.                                        final double absoluteAccuracy) {
  46.         super(relativeAccuracy, absoluteAccuracy);
  47.     }
  48.     /**
  49.      * Construct a solver with given accuracies.
  50.      *
  51.      * @param relativeAccuracy Maximum relative error.
  52.      * @param absoluteAccuracy Maximum absolute error.
  53.      * @param functionValueAccuracy Maximum function value error.
  54.      */
  55.     protected AbstractUnivariateSolver(final double relativeAccuracy,
  56.                                        final double absoluteAccuracy,
  57.                                        final double functionValueAccuracy) {
  58.         super(relativeAccuracy, absoluteAccuracy, functionValueAccuracy);
  59.     }
  60. }