Class BaseRuleFactory<T extends Number>
- java.lang.Object
-
- org.hipparchus.analysis.integration.gauss.BaseRuleFactory<T>
-
- Type Parameters:
T
- Type of the number used to represent the points and weights of the quadrature rules.
- Direct Known Subclasses:
HermiteRuleFactory
,LaguerreRuleFactory
,LegendreHighPrecisionRuleFactory
,LegendreRuleFactory
public abstract class BaseRuleFactory<T extends Number> extends Object
Base class for rules that determines the integration nodes and their weights. Subclasses must implement thecomputeRule
method.
-
-
Constructor Summary
Constructors Constructor Description BaseRuleFactory()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected void
addRule(Pair<T[],T[]> rule)
Stores a rule.protected abstract Pair<T[],T[]>
computeRule(int numberOfPoints)
Computes the rule for the given order.Pair<double[],double[]>
getRule(int numberOfPoints)
Gets a copy of the quadrature rule with the given number of integration points.protected Pair<T[],T[]>
getRuleInternal(int numberOfPoints)
Gets a rule.
-
-
-
Method Detail
-
getRule
public Pair<double[],double[]> getRule(int numberOfPoints) throws MathIllegalArgumentException
Gets a copy of the quadrature rule with the given number of integration points.- Parameters:
numberOfPoints
- Number of integration points.- Returns:
- a copy of the integration rule.
- Throws:
MathIllegalArgumentException
- ifnumberOfPoints < 1
.MathIllegalArgumentException
- if the elements of the rule pair do not have the same length.
-
getRuleInternal
protected Pair<T[],T[]> getRuleInternal(int numberOfPoints) throws MathIllegalArgumentException
Gets a rule. Synchronization ensures that rules will be computed and added to the cache at most once. The returned rule is a reference into the cache.- Parameters:
numberOfPoints
- Order of the rule to be retrieved.- Returns:
- the points and weights corresponding to the given order.
- Throws:
MathIllegalArgumentException
- if the elements of the rule pair do not have the same length.
-
addRule
protected void addRule(Pair<T[],T[]> rule) throws MathIllegalArgumentException
Stores a rule.- Parameters:
rule
- Rule to be stored.- Throws:
MathIllegalArgumentException
- if the elements of the pair do not have the same length.
-
computeRule
protected abstract Pair<T[],T[]> computeRule(int numberOfPoints) throws MathIllegalArgumentException
Computes the rule for the given order.- Parameters:
numberOfPoints
- Order of the rule to be computed.- Returns:
- the computed rule.
- Throws:
MathIllegalArgumentException
- if the elements of the pair do not have the same length.
-
-