10

For a project I have a specification with formulas, I have to implement. In these formulas a cumulative standard normal distribution function exists, that takes a float and outputs a probability. The function is symbolized by a Φ. Exists a Java-library, that computes this function?

Mnementh
  • 50,487
  • 48
  • 148
  • 202

5 Answers5

14

Apache Commons - Math has what you are looking for.

More specifically, check out the NormalDistribution class.

kuujo
  • 7,785
  • 1
  • 26
  • 21
Yuval Adam
  • 161,610
  • 92
  • 305
  • 395
8

If you want the exact code, this one seems to be the same function used in OpenOffice Calc (I've made some changes for it to work in java):

// returns the cumulative normal distribution function (CNDF)
// for a standard normal: N(0,1)
double CNDF(double x)
{
    int neg = (x < 0d) ? 1 : 0;
    if ( neg == 1) 
        x *= -1d;

    double k = (1d / ( 1d + 0.2316419 * x));
    double y = (((( 1.330274429 * k - 1.821255978) * k + 1.781477937) *
                   k - 0.356563782) * k + 0.319381530) * k;
    y = 1.0 - 0.398942280401 * Math.exp(-0.5 * x * x) * y;

    return (1d - neg) * y + neg * (1d - y);
}

Found it here: http://www.codeproject.com/Messages/2622967/Re-NORMSDIST-function.aspx

Erk
  • 1,159
  • 15
  • 9
  • the question wants the pdf of normal distribution! – langerra.com Jun 04 '13 at 11:30
  • I don't think so. The question says "cumulative standard normal distribution function" both in the title and the text ... unless Φ means it's supposed to be the probability density function... – Erk Dec 04 '13 at 10:18
3

A co-worker suggested colt, as he used it before. This function has exactly the result as the example in the reference document.

Mnementh
  • 50,487
  • 48
  • 148
  • 202
2

SuanShu, a Java numerical analysis library, computes the normal distribution and many other statistical distributions.

H Li
  • 15
  • 2
Ryu
  • 21
  • 1
1

You could use the power series formula, which only takes up about 10 lines of code... see for example http://introcs.cs.princeton.edu/java/22library/Gaussian.java.html (the function Phi)

daveagp
  • 2,599
  • 2
  • 20
  • 19