00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034 #if !defined(__DENSITY_H)
00035 #define __DENSITY_H
00036
00037
00038 #include <vector>
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048 namespace Density {
00049
00050
00051
00052 extern const double MinGammaPar;
00053
00054
00055 extern const double MaxGammaPar;
00056
00057 double dbeta(double x, double a, double b,
00058 bool give_log = false);
00059
00060
00061 double dbinom(int k, int n, double p, bool give_log);
00062 double dcauchy(double x, double l, double s, bool give_log);
00063 double dchisq(double x, double n, bool give_log);
00064 double ddirch(const std::vector<double>& p, const std::vector<double>& a,
00065 const bool give_log = false, const bool include_const = true);
00066 double dexp(double x, double b, bool give_log);
00067 double df(double x, double m, double n, bool give_log);
00068 double dgeom(unsigned x, double p, bool give_log);
00069 double dgamma(double x, double shape, double scale, bool give_log);
00070 double dhyper(unsigned x, unsigned r, unsigned b, unsigned n, bool giveLog);
00071 double dinvgamma(double y, double shape, double scale, bool give_log);
00072 double dlnorm(double x, double mu, double sigma, bool give_log);
00073 double dlogis(double x, double m, double s, bool give_log);
00074 double dmulti(const std::vector<int>& n, const std::vector<double>& p,
00075 bool give_log = false, bool include_factorial = false);
00076 double dnbinom(unsigned x, double n, double p, bool give_log);
00077 double dnorm(double x_in, double mu, double sigma, bool give_log);
00078 double dpois(unsigned x, double lambda, bool give_log);
00079 double dt(double x, double n, bool give_log);
00080 double dweibull(double x, double a, double b, bool give_log);
00081 double BetaEntropy(double a, double b);
00082 double logChoose(double n, double k);
00083 double gamln(double x);
00084 double lbeta(double a, double b);
00085
00086 }
00087
00088 #endif
00089
00090
00091
00092
00093