MATH-1421: Code refactoring.
Replaced unnecessary usage of "pow" function. Reordered some operations. It fixes the reported case where the lower bound was negative (see unit test), but it might not be sufficient to avoid the problem in all cases.
This commit is contained in:
parent
777af155a6
commit
34adc60660
|
@ -36,14 +36,15 @@ public class WilsonScoreInterval implements BinomialConfidenceInterval {
|
||||||
final double alpha = (1.0 - confidenceLevel) / 2;
|
final double alpha = (1.0 - confidenceLevel) / 2;
|
||||||
final NormalDistribution normalDistribution = new NormalDistribution();
|
final NormalDistribution normalDistribution = new NormalDistribution();
|
||||||
final double z = normalDistribution.inverseCumulativeProbability(1 - alpha);
|
final double z = normalDistribution.inverseCumulativeProbability(1 - alpha);
|
||||||
final double zSquared = FastMath.pow(z, 2);
|
final double zSquared = z * z;
|
||||||
|
final double zSquaredOverNumTrials = zSquared / numberOfTrials;
|
||||||
final double mean = (double) numberOfSuccesses / (double) numberOfTrials;
|
final double mean = (double) numberOfSuccesses / (double) numberOfTrials;
|
||||||
|
|
||||||
final double factor = 1.0 / (1 + (1.0 / numberOfTrials) * zSquared);
|
final double factor = 1.0 / (1 + zSquaredOverNumTrials);
|
||||||
final double modifiedSuccessRatio = mean + (1.0 / (2 * numberOfTrials)) * zSquared;
|
final double modifiedSuccessRatio = mean + zSquaredOverNumTrials / 2;
|
||||||
final double difference = z *
|
final double difference = z *
|
||||||
FastMath.sqrt(1.0 / numberOfTrials * mean * (1 - mean) +
|
FastMath.sqrt(1.0 / numberOfTrials * mean * (1 - mean) +
|
||||||
(1.0 / (4 * FastMath.pow(numberOfTrials, 2)) * zSquared));
|
(zSquaredOverNumTrials / (4 * numberOfTrials)));
|
||||||
|
|
||||||
final double lowerBound = factor * (modifiedSuccessRatio - difference);
|
final double lowerBound = factor * (modifiedSuccessRatio - difference);
|
||||||
final double upperBound = factor * (modifiedSuccessRatio + difference);
|
final double upperBound = factor * (modifiedSuccessRatio + difference);
|
||||||
|
|
|
@ -40,4 +40,9 @@ public class WilsonScoreIntervalTest extends BinomialConfidenceIntervalAbstractT
|
||||||
Assert.assertEquals(0.1242664, confidenceInterval.getUpperBound(), 1E-5);
|
Assert.assertEquals(0.1242664, confidenceInterval.getUpperBound(), 1E-5);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testMath1421() {
|
||||||
|
double lo = new WilsonScoreInterval().createInterval(19436, 0, 0.95).getLowerBound();
|
||||||
|
Assert.assertTrue(lo + " < 0", lo >= 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue