blob: b3a2f12c43bf819baa99d10121a2dc0bd83d4fe1 [file] [log] [blame]
Raymonddee08492015-04-02 10:43:13 -07001/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements. See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17package org.apache.commons.math.distribution;
18
19import org.apache.commons.math.MathException;
20
21/**
22 * Interface representing the Poisson Distribution.
23 *
24 * <p>
25 * References:
26 * <ul>
27 * <li><a href="http://mathworld.wolfram.com/PoissonDistribution.html">
28 * Poisson distribution</a></li>
29 * </ul>
30 * </p>
31 *
32 * @version $Revision: 920852 $ $Date: 2010-03-09 13:53:44 +0100 (mar. 09 mars 2010) $
33 */
34public interface PoissonDistribution extends IntegerDistribution {
35
36 /**
37 * Get the mean for the distribution.
38 *
39 * @return the mean for the distribution.
40 */
41 double getMean();
42
43 /**
44 * Set the mean for the distribution.
45 * The parameter value must be positive; otherwise an
46 * <code>IllegalArgument</code> is thrown.
47 *
48 * @param p the mean
49 * @throws IllegalArgumentException if p &le; 0
50 * @deprecated as of v2.1
51 */
52 @Deprecated
53 void setMean(double p);
54
55 /**
56 * Calculates the Poisson distribution function using a normal approximation.
57 *
58 * @param x the upper bound, inclusive
59 * @return the distribution function value calculated using a normal approximation
60 * @throws MathException if an error occurs computing the normal approximation
61 */
62 double normalApproximateProbability(int x) throws MathException;
63
64}