Class BaseAbstractUnivariateIntegrator
- java.lang.Object
- 
- org.hipparchus.analysis.integration.BaseAbstractUnivariateIntegrator
 
- 
- All Implemented Interfaces:
- UnivariateIntegrator
 - Direct Known Subclasses:
- IterativeLegendreGaussIntegrator,- MidPointIntegrator,- RombergIntegrator,- SimpsonIntegrator,- TrapezoidIntegrator
 
 public abstract class BaseAbstractUnivariateIntegrator extends Object implements UnivariateIntegrator Provide a default implementation for several generic functions.
- 
- 
Field SummaryFields Modifier and Type Field Description static doubleDEFAULT_ABSOLUTE_ACCURACYDefault absolute accuracy.static intDEFAULT_MAX_ITERATIONS_COUNTDefault maximal iteration count.static intDEFAULT_MIN_ITERATIONS_COUNTDefault minimal iteration count.static doubleDEFAULT_RELATIVE_ACCURACYDefault relative accuracy.protected IncrementoriterationsThe iteration count.
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedBaseAbstractUnivariateIntegrator(double relativeAccuracy, double absoluteAccuracy)Construct an integrator with given accuracies.protectedBaseAbstractUnivariateIntegrator(double relativeAccuracy, double absoluteAccuracy, int minimalIterationCount, int maximalIterationCount)Construct an integrator with given accuracies and iteration counts.protectedBaseAbstractUnivariateIntegrator(int minimalIterationCount, int maximalIterationCount)Construct an integrator with given iteration counts.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected doublecomputeObjectiveValue(double point)Compute the objective function value.protected abstract doubledoIntegrate()Method for implementing actual integration algorithms in derived classes.doublegetAbsoluteAccuracy()Get the absolute accuracy.intgetEvaluations()Get the number of function evaluations of the last run of the integrator.intgetIterations()Get the number of iterations of the last run of the integrator.protected doublegetMax()Get the upper bound.intgetMaximalIterationCount()Get the upper limit for the number of iterations.protected doublegetMin()Get the lower bound.intgetMinimalIterationCount()Get the min limit for the number of iterations.doublegetRelativeAccuracy()Get the relative accuracy.doubleintegrate(int maxEval, UnivariateFunction f, double lower, double upper)Integrate the function in the given interval.protected voidsetup(int maxEval, UnivariateFunction f, double lower, double upper)Prepare for computation.
 
- 
- 
- 
Field Detail- 
DEFAULT_ABSOLUTE_ACCURACYpublic static final double DEFAULT_ABSOLUTE_ACCURACY Default absolute accuracy.- See Also:
- Constant Field Values
 
 - 
DEFAULT_RELATIVE_ACCURACYpublic static final double DEFAULT_RELATIVE_ACCURACY Default relative accuracy.- See Also:
- Constant Field Values
 
 - 
DEFAULT_MIN_ITERATIONS_COUNTpublic static final int DEFAULT_MIN_ITERATIONS_COUNT Default minimal iteration count.- See Also:
- Constant Field Values
 
 - 
DEFAULT_MAX_ITERATIONS_COUNTpublic static final int DEFAULT_MAX_ITERATIONS_COUNT Default maximal iteration count.- See Also:
- Constant Field Values
 
 - 
iterationsprotected final Incrementor iterations The iteration count.
 
- 
 - 
Constructor Detail- 
BaseAbstractUnivariateIntegratorprotected BaseAbstractUnivariateIntegrator(double relativeAccuracy, double absoluteAccuracy, int minimalIterationCount, int maximalIterationCount) throws MathIllegalArgumentExceptionConstruct an integrator with given accuracies and iteration counts.The meanings of the various parameters are: - relative accuracy:
       this is used to stop iterations if the absolute accuracy can't be
       achieved due to large values or short mantissa length. If this
       should be the primary criterion for convergence rather then a
       safety measure, set the absolute accuracy to a ridiculously small value,
       like Precision.SAFE_MIN.
- absolute accuracy: The default is usually chosen so that results in the interval -10..-0.1 and +0.1..+10 can be found with a reasonable accuracy. If the expected absolute value of your results is of much smaller magnitude, set this to a smaller value.
- minimum number of iterations: minimal iteration is needed to avoid false early convergence, e.g. the sample points happen to be zeroes of the function. Users can use the default value or choose one that they see as appropriate.
- maximum number of iterations: usually a high iteration count indicates convergence problems. However, the "reasonable value" varies widely for different algorithms. Users are advised to use the default value supplied by the algorithm.
 - Parameters:
- relativeAccuracy- relative accuracy of the result
- absoluteAccuracy- absolute accuracy of the result
- minimalIterationCount- minimum number of iterations
- maximalIterationCount- maximum number of iterations
- Throws:
- MathIllegalArgumentException- if minimal number of iterations is not strictly positive
- MathIllegalArgumentException- if maximal number of iterations is lesser than or equal to the minimal number of iterations
 
- relative accuracy:
       this is used to stop iterations if the absolute accuracy can't be
       achieved due to large values or short mantissa length. If this
       should be the primary criterion for convergence rather then a
       safety measure, set the absolute accuracy to a ridiculously small value,
       like 
 - 
BaseAbstractUnivariateIntegratorprotected BaseAbstractUnivariateIntegrator(double relativeAccuracy, double absoluteAccuracy)Construct an integrator with given accuracies.- Parameters:
- relativeAccuracy- relative accuracy of the result
- absoluteAccuracy- absolute accuracy of the result
 
 - 
BaseAbstractUnivariateIntegratorprotected BaseAbstractUnivariateIntegrator(int minimalIterationCount, int maximalIterationCount) throws MathIllegalArgumentExceptionConstruct an integrator with given iteration counts.- Parameters:
- minimalIterationCount- minimum number of iterations
- maximalIterationCount- maximum number of iterations
- Throws:
- MathIllegalArgumentException- if minimal number of iterations is not strictly positive
- MathIllegalArgumentException- if maximal number of iterations is lesser than or equal to the minimal number of iterations
 
 
- 
 - 
Method Detail- 
getRelativeAccuracypublic double getRelativeAccuracy() Get the relative accuracy.- Specified by:
- getRelativeAccuracyin interface- UnivariateIntegrator
- Returns:
- the accuracy
 
 - 
getAbsoluteAccuracypublic double getAbsoluteAccuracy() Get the absolute accuracy.- Specified by:
- getAbsoluteAccuracyin interface- UnivariateIntegrator
- Returns:
- the accuracy
 
 - 
getMinimalIterationCountpublic int getMinimalIterationCount() Get the min limit for the number of iterations.- Specified by:
- getMinimalIterationCountin interface- UnivariateIntegrator
- Returns:
- the actual min limit
 
 - 
getMaximalIterationCountpublic int getMaximalIterationCount() Get the upper limit for the number of iterations.- Specified by:
- getMaximalIterationCountin interface- UnivariateIntegrator
- Returns:
- the actual upper limit
 
 - 
getEvaluationspublic int getEvaluations() Get the number of function evaluations of the last run of the integrator.- Specified by:
- getEvaluationsin interface- UnivariateIntegrator
- Returns:
- number of function evaluations
 
 - 
getIterationspublic int getIterations() Get the number of iterations of the last run of the integrator.- Specified by:
- getIterationsin interface- UnivariateIntegrator
- Returns:
- number of iterations
 
 - 
getMinprotected double getMin() Get the lower bound.- Returns:
- the lower bound.
 
 - 
getMaxprotected double getMax() Get the upper bound.- Returns:
- the upper bound.
 
 - 
computeObjectiveValueprotected double computeObjectiveValue(double point) throws MathIllegalStateExceptionCompute the objective function value.- Parameters:
- point- Point at which the objective function must be evaluated.
- Returns:
- the objective function value at specified point.
- Throws:
- MathIllegalStateException- if the maximal number of function evaluations is exceeded.
 
 - 
setupprotected void setup(int maxEval, UnivariateFunction f, double lower, double upper) throws MathIllegalArgumentException, NullArgumentExceptionPrepare for computation. Subclasses must call this method if they override any of thesolvemethods.- Parameters:
- maxEval- Maximum number of evaluations.
- f- the integrand function
- lower- the min bound for the interval
- upper- the upper bound for the interval
- Throws:
- NullArgumentException- if- fis- null.
- MathIllegalArgumentException- if- min >= max.
 
 - 
integratepublic double integrate(int maxEval, UnivariateFunction f, double lower, double upper) throws MathIllegalArgumentException, MathIllegalStateException, NullArgumentExceptionIntegrate the function in the given interval.- Specified by:
- integratein interface- UnivariateIntegrator
- Parameters:
- maxEval- Maximum number of evaluations.
- f- the integrand function
- lower- the lower bound for the interval
- upper- the upper bound for the interval
- Returns:
- the value of integral
- Throws:
- MathIllegalArgumentException- if- min > maxor the endpoints do not satisfy the requirements specified by the integrator
- MathIllegalStateException- if the maximum number of function evaluations is exceeded
- NullArgumentException- if- fis- null.
 
 - 
doIntegrateprotected abstract double doIntegrate() throws MathIllegalStateExceptionMethod for implementing actual integration algorithms in derived classes.- Returns:
- the root.
- Throws:
- MathIllegalStateException- if the maximal number of evaluations is exceeded.
- MathIllegalStateException- if the maximum iteration count is exceeded or the integrator detects convergence problems otherwise
 
 
- 
 
-