Class MidPointIntegrator
- java.lang.Object
-
- org.hipparchus.analysis.integration.BaseAbstractUnivariateIntegrator
-
- org.hipparchus.analysis.integration.MidPointIntegrator
-
- All Implemented Interfaces:
UnivariateIntegrator
public class MidPointIntegrator extends BaseAbstractUnivariateIntegrator
Implements the Midpoint Rule for integration of real univariate functions. For reference, see Numerical Mathematics, ISBN 0387989595, chapter 9.2.The function should be integrable.
-
-
Field Summary
Fields Modifier and Type Field Description static int
MIDPOINT_MAX_ITERATIONS_COUNT
Maximum number of iterations for midpoint.-
Fields inherited from class org.hipparchus.analysis.integration.BaseAbstractUnivariateIntegrator
DEFAULT_ABSOLUTE_ACCURACY, DEFAULT_MAX_ITERATIONS_COUNT, DEFAULT_MIN_ITERATIONS_COUNT, DEFAULT_RELATIVE_ACCURACY, iterations
-
-
Constructor Summary
Constructors Constructor Description MidPointIntegrator()
Construct a midpoint integrator with default settings.MidPointIntegrator(double relativeAccuracy, double absoluteAccuracy, int minimalIterationCount, int maximalIterationCount)
Build a midpoint integrator with given accuracies and iterations counts.MidPointIntegrator(int minimalIterationCount, int maximalIterationCount)
Build a midpoint integrator with given iteration counts.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected double
doIntegrate()
Method for implementing actual integration algorithms in derived classes.-
Methods inherited from class org.hipparchus.analysis.integration.BaseAbstractUnivariateIntegrator
computeObjectiveValue, getAbsoluteAccuracy, getEvaluations, getIterations, getMax, getMaximalIterationCount, getMin, getMinimalIterationCount, getRelativeAccuracy, integrate, setup
-
-
-
-
Field Detail
-
MIDPOINT_MAX_ITERATIONS_COUNT
public static final int MIDPOINT_MAX_ITERATIONS_COUNT
Maximum number of iterations for midpoint.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
MidPointIntegrator
public MidPointIntegrator(double relativeAccuracy, double absoluteAccuracy, int minimalIterationCount, int maximalIterationCount) throws MathIllegalArgumentException
Build a midpoint integrator with given accuracies and iterations counts.- Parameters:
relativeAccuracy
- relative accuracy of the resultabsoluteAccuracy
- absolute accuracy of the resultminimalIterationCount
- minimum number of iterationsmaximalIterationCount
- maximum number of iterations (must be less than or equal toMIDPOINT_MAX_ITERATIONS_COUNT
- Throws:
MathIllegalArgumentException
- if minimal number of iterations is not strictly positiveMathIllegalArgumentException
- if maximal number of iterations is lesser than or equal to the minimal number of iterationsMathIllegalArgumentException
- if maximal number of iterations is greater thanMIDPOINT_MAX_ITERATIONS_COUNT
-
MidPointIntegrator
public MidPointIntegrator(int minimalIterationCount, int maximalIterationCount) throws MathIllegalArgumentException
Build a midpoint integrator with given iteration counts.- Parameters:
minimalIterationCount
- minimum number of iterationsmaximalIterationCount
- maximum number of iterations (must be less than or equal toMIDPOINT_MAX_ITERATIONS_COUNT
- Throws:
MathIllegalArgumentException
- if minimal number of iterations is not strictly positiveMathIllegalArgumentException
- if maximal number of iterations is lesser than or equal to the minimal number of iterationsMathIllegalArgumentException
- if maximal number of iterations is greater thanMIDPOINT_MAX_ITERATIONS_COUNT
-
MidPointIntegrator
public MidPointIntegrator()
Construct a midpoint integrator with default settings. (max iteration count set toMIDPOINT_MAX_ITERATIONS_COUNT
)
-
-
Method Detail
-
doIntegrate
protected double doIntegrate() throws MathIllegalArgumentException, MathIllegalStateException
Method for implementing actual integration algorithms in derived classes.- Specified by:
doIntegrate
in classBaseAbstractUnivariateIntegrator
- Returns:
- the root.
- Throws:
MathIllegalStateException
- if the maximal number of evaluations is exceeded.MathIllegalArgumentException
-
-