Precondition check.

git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1374054 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Gilles Sadowski 2012-08-16 21:00:39 +00:00
parent 7994d3ee9d
commit b1741d1b46
2 changed files with 14 additions and 0 deletions

View File

@ -19,6 +19,8 @@ package org.apache.commons.math3.analysis.integration.gauss;
import java.math.MathContext; import java.math.MathContext;
import java.math.BigDecimal; import java.math.BigDecimal;
import org.apache.commons.math3.util.Pair; import org.apache.commons.math3.util.Pair;
import org.apache.commons.math3.exception.NotStrictlyPositiveException;
import org.apache.commons.math3.exception.util.LocalizedFormats;
/** /**
* Factory that creates Gauss-type quadrature rule using Legendre polynomials. * Factory that creates Gauss-type quadrature rule using Legendre polynomials.
@ -63,6 +65,11 @@ public class LegendreHighPrecisionRuleFactory extends BaseRuleFactory<BigDecimal
*/ */
@Override @Override
protected Pair<BigDecimal[], BigDecimal[]> computeRule(int numberOfPoints) { protected Pair<BigDecimal[], BigDecimal[]> computeRule(int numberOfPoints) {
if (numberOfPoints <= 0) {
throw new NotStrictlyPositiveException(LocalizedFormats.NUMBER_OF_POINTS,
numberOfPoints);
}
if (numberOfPoints == 1) { if (numberOfPoints == 1) {
// Break recursion. // Break recursion.
return new Pair<BigDecimal[], BigDecimal[]>(new BigDecimal[] { BigDecimal.ZERO }, return new Pair<BigDecimal[], BigDecimal[]>(new BigDecimal[] { BigDecimal.ZERO },

View File

@ -17,6 +17,8 @@
package org.apache.commons.math3.analysis.integration.gauss; package org.apache.commons.math3.analysis.integration.gauss;
import org.apache.commons.math3.util.Pair; import org.apache.commons.math3.util.Pair;
import org.apache.commons.math3.exception.NotStrictlyPositiveException;
import org.apache.commons.math3.exception.util.LocalizedFormats;
/** /**
* Factory that creates Gauss-type quadrature rule using Legendre polynomials. * Factory that creates Gauss-type quadrature rule using Legendre polynomials.
@ -35,6 +37,11 @@ public class LegendreRuleFactory extends BaseRuleFactory<Double> {
*/ */
@Override @Override
protected Pair<Double[], Double[]> computeRule(int numberOfPoints) { protected Pair<Double[], Double[]> computeRule(int numberOfPoints) {
if (numberOfPoints <= 0) {
throw new NotStrictlyPositiveException(LocalizedFormats.NUMBER_OF_POINTS,
numberOfPoints);
}
if (numberOfPoints == 1) { if (numberOfPoints == 1) {
// Break recursion. // Break recursion.
return new Pair<Double[], Double[]>(new Double[] { 0d }, return new Pair<Double[], Double[]>(new Double[] { 0d },