[MATH-1018] Added overloaded constructors which do not require an explicit inverseCumulativeAccuracy parameter, the default one will be used instead.
git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1519842 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
83b5df5178
commit
c4b4a75259
|
@ -51,6 +51,11 @@ If the output is not quite correct, check for invisible trailing spaces!
|
||||||
</properties>
|
</properties>
|
||||||
<body>
|
<body>
|
||||||
<release version="x.y" date="TBD" description="TBD">
|
<release version="x.y" date="TBD" description="TBD">
|
||||||
|
<action dev="tn" type="add" issue="MATH-1018" due-to="Ajo Fod">
|
||||||
|
Added overloaded constructors for subclasses of "RealDistribution" implementations
|
||||||
|
which do not require an explicit "inverseCumulativeAccuracy". The default accuracy will
|
||||||
|
be used instead.
|
||||||
|
</action>
|
||||||
<action dev="tn" type="add" issue="MATH-1001" due-to="sebb">
|
<action dev="tn" type="add" issue="MATH-1001" due-to="sebb">
|
||||||
Added overloaded methods for "Frequency#incrementValue(Comparable, long)" with
|
Added overloaded methods for "Frequency#incrementValue(Comparable, long)" with
|
||||||
int, long and char primitive arguments.
|
int, long and char primitive arguments.
|
||||||
|
|
|
@ -74,6 +74,18 @@ public class BetaDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), alpha, beta, inverseCumAccuracy);
|
this(new Well19937c(), alpha, beta, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a β distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param alpha First shape parameter (must be positive).
|
||||||
|
* @param beta Second shape parameter (must be positive).
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public BetaDistribution(RandomGenerator rng, double alpha, double beta) {
|
||||||
|
this(rng, alpha, beta, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a β distribution.
|
* Creates a β distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -80,6 +80,19 @@ public class CauchyDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), median, scale, inverseCumAccuracy);
|
this(new Well19937c(), median, scale, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a Cauchy distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param median Median for this distribution.
|
||||||
|
* @param scale Scale parameter for this distribution.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code scale <= 0}.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public CauchyDistribution(RandomGenerator rng, double median, double scale) {
|
||||||
|
this(rng, median, scale, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a Cauchy distribution.
|
* Creates a Cauchy distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -63,6 +63,17 @@ public class ChiSquaredDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), degreesOfFreedom, inverseCumAccuracy);
|
this(new Well19937c(), degreesOfFreedom, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a Chi-Squared distribution with the given degrees of freedom.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param degreesOfFreedom Degrees of freedom.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public ChiSquaredDistribution(RandomGenerator rng, double degreesOfFreedom) {
|
||||||
|
this(rng, degreesOfFreedom, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a Chi-Squared distribution with the given degrees of freedom and
|
* Create a Chi-Squared distribution with the given degrees of freedom and
|
||||||
* inverse cumulative probability accuracy.
|
* inverse cumulative probability accuracy.
|
||||||
|
|
|
@ -110,6 +110,19 @@ public class ExponentialDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), mean, inverseCumAccuracy);
|
this(new Well19937c(), mean, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an exponential distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param mean Mean of this distribution.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code mean <= 0}.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public ExponentialDistribution(RandomGenerator rng, double mean)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, mean, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an exponential distribution.
|
* Creates an exponential distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -87,6 +87,23 @@ public class FDistribution extends AbstractRealDistribution {
|
||||||
denominatorDegreesOfFreedom, inverseCumAccuracy);
|
denominatorDegreesOfFreedom, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an F distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param numeratorDegreesOfFreedom Numerator degrees of freedom.
|
||||||
|
* @param denominatorDegreesOfFreedom Denominator degrees of freedom.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code numeratorDegreesOfFreedom <= 0} or
|
||||||
|
* {@code denominatorDegreesOfFreedom <= 0}.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public FDistribution(RandomGenerator rng,
|
||||||
|
double numeratorDegreesOfFreedom,
|
||||||
|
double denominatorDegreesOfFreedom)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, numeratorDegreesOfFreedom, denominatorDegreesOfFreedom, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an F distribution.
|
* Creates an F distribution.
|
||||||
*
|
*
|
||||||
|
@ -95,8 +112,7 @@ public class FDistribution extends AbstractRealDistribution {
|
||||||
* @param denominatorDegreesOfFreedom Denominator degrees of freedom.
|
* @param denominatorDegreesOfFreedom Denominator degrees of freedom.
|
||||||
* @param inverseCumAccuracy the maximum absolute error in inverse
|
* @param inverseCumAccuracy the maximum absolute error in inverse
|
||||||
* cumulative probability estimates.
|
* cumulative probability estimates.
|
||||||
* @throws NotStrictlyPositiveException if
|
* @throws NotStrictlyPositiveException if {@code numeratorDegreesOfFreedom <= 0} or
|
||||||
* {@code numeratorDegreesOfFreedom <= 0} or
|
|
||||||
* {@code denominatorDegreesOfFreedom <= 0}.
|
* {@code denominatorDegreesOfFreedom <= 0}.
|
||||||
* @since 3.1
|
* @since 3.1
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -111,6 +111,21 @@ public class GammaDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), shape, scale, inverseCumAccuracy);
|
this(new Well19937c(), shape, scale, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a Gamma distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param shape the shape parameter
|
||||||
|
* @param scale the scale parameter
|
||||||
|
* @throws NotStrictlyPositiveException if {@code shape <= 0} or
|
||||||
|
* {@code scale <= 0}.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public GammaDistribution(RandomGenerator rng, double shape, double scale)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, shape, scale, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a Gamma distribution.
|
* Creates a Gamma distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -112,6 +112,20 @@ public class LogNormalDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), scale, shape, inverseCumAccuracy);
|
this(new Well19937c(), scale, shape, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a log-normal distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param scale Scale parameter of this distribution.
|
||||||
|
* @param shape Shape parameter of this distribution.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code shape <= 0}.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public LogNormalDistribution(RandomGenerator rng, double scale, double shape)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, scale, shape, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a log-normal distribution.
|
* Creates a log-normal distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -87,6 +87,20 @@ public class NormalDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), mean, sd, inverseCumAccuracy);
|
this(new Well19937c(), mean, sd, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a normal distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param mean Mean for this distribution.
|
||||||
|
* @param sd Standard deviation for this distribution.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code sd <= 0}.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public NormalDistribution(RandomGenerator rng, double mean, double sd)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, mean, sd, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a normal distribution.
|
* Creates a normal distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -97,6 +97,19 @@ public class ParetoDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), scale, shape, inverseCumAccuracy);
|
this(new Well19937c(), scale, shape, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a log-normal distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param scale Scale parameter of this distribution.
|
||||||
|
* @param shape Shape parameter of this distribution.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code scale <= 0} or {@code shape <= 0}.
|
||||||
|
*/
|
||||||
|
public ParetoDistribution(RandomGenerator rng, double scale, double shape)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, scale, shape, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a log-normal distribution.
|
* Creates a log-normal distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -71,6 +71,19 @@ public class TDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), degreesOfFreedom, inverseCumAccuracy);
|
this(new Well19937c(), degreesOfFreedom, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a t distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param degreesOfFreedom Degrees of freedom.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code degreesOfFreedom <= 0}
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public TDistribution(RandomGenerator rng, double degreesOfFreedom)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, degreesOfFreedom, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a t distribution.
|
* Creates a t distribution.
|
||||||
*
|
*
|
||||||
|
|
|
@ -91,6 +91,20 @@ public class WeibullDistribution extends AbstractRealDistribution {
|
||||||
this(new Well19937c(), alpha, beta, inverseCumAccuracy);
|
this(new Well19937c(), alpha, beta, inverseCumAccuracy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a Weibull distribution.
|
||||||
|
*
|
||||||
|
* @param rng Random number generator.
|
||||||
|
* @param alpha Shape parameter.
|
||||||
|
* @param beta Scale parameter.
|
||||||
|
* @throws NotStrictlyPositiveException if {@code alpha <= 0} or {@code beta <= 0}.
|
||||||
|
* @since 3.3
|
||||||
|
*/
|
||||||
|
public WeibullDistribution(RandomGenerator rng, double alpha, double beta)
|
||||||
|
throws NotStrictlyPositiveException {
|
||||||
|
this(rng, alpha, beta, DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a Weibull distribution.
|
* Creates a Weibull distribution.
|
||||||
*
|
*
|
||||||
|
@ -100,8 +114,7 @@ public class WeibullDistribution extends AbstractRealDistribution {
|
||||||
* @param inverseCumAccuracy Maximum absolute error in inverse
|
* @param inverseCumAccuracy Maximum absolute error in inverse
|
||||||
* cumulative probability estimates
|
* cumulative probability estimates
|
||||||
* (defaults to {@link #DEFAULT_INVERSE_ABSOLUTE_ACCURACY}).
|
* (defaults to {@link #DEFAULT_INVERSE_ABSOLUTE_ACCURACY}).
|
||||||
* @throws NotStrictlyPositiveException if {@code alpha <= 0} or
|
* @throws NotStrictlyPositiveException if {@code alpha <= 0} or {@code beta <= 0}.
|
||||||
* {@code beta <= 0}.
|
|
||||||
* @since 3.1
|
* @since 3.1
|
||||||
*/
|
*/
|
||||||
public WeibullDistribution(RandomGenerator rng,
|
public WeibullDistribution(RandomGenerator rng,
|
||||||
|
|
Loading…
Reference in New Issue