1 #ifndef STAT_ExponentialDistribution_H
2 #define STAT_ExponentialDistribution_H
5 #include <boost/math/distributions/exponential.hpp>
6 #include <boost/random/exponential_distribution.hpp>
7 #include <boost/random/variate_generator.hpp>
27 boost::math::exponential_distribution<tReal> *mDistribution;
28 boost::random::exponential_distribution<tReal> *mRandomDistribution;
29 boost::random::variate_generator<
RNGType&,
30 boost::random::exponential_distribution<tReal> > *mGenerator;
58 inline static SP::STAT_ExponentialDistribution
New(
const tReal& lambda) {
62 p->setProperties(lambda);
68 inline static SP::STAT_ExponentialDistribution
New() {
STAT_ExponentialDistribution()
create an object
Definition: STAT_ExponentialDistribution.cpp:5
virtual tReal mean() const
compute the mean
Definition: STAT_ExponentialDistribution.cpp:61
virtual tReal quantile(const tReal &q) const
quantile
Definition: STAT_ExponentialDistribution.cpp:76
virtual void range(tReal &xmin, tReal &xmax) const
compute the range of the distribution
Definition: STAT_ExponentialDistribution.cpp:37
virtual void copy(const STAT_Distribution &d)
copy the distribution
Definition: STAT_ExponentialDistribution.h:80
virtual tReal computeGrowthRate()
return the growth rate of the distribution such that Esperance(E(exp(-z*X)))=0.5
Definition: STAT_Distribution.h:133
virtual tReal cdfc(const tReal &x) const
compute the cumulative distribution complement function at x point
Definition: STAT_ExponentialDistribution.cpp:56
void getProperties(tReal &lambda) const
Definition: STAT_ExponentialDistribution.h:90
DEFINE_SPTR(STAT_ExponentialDistribution)
virtual tReal cdf(const tReal &x) const
compute the cumulative distribution function at x point
Definition: STAT_ExponentialDistribution.cpp:50
virtual tReal mean() const =0
compute the mean
#define tBoolean
Definition: types.h:48
virtual ~STAT_ExponentialDistribution(void)
destroy an object.
Definition: STAT_ExponentialDistribution.cpp:13
virtual tReal random() const
random return a random numbers in range
Definition: STAT_ExponentialDistribution.cpp:80
static SP::STAT_ExponentialDistribution New(const tReal &lambda)
create a Exponential distibution
Definition: STAT_ExponentialDistribution.h:58
this class describes an array
Definition: CORE_Array.h:18
virtual void computeSample(const int &n, CORE_RealArray &sample) const
compute a sample of size n
Definition: STAT_ExponentialDistribution.cpp:87
virtual tReal variance() const
compute the variance
Definition: STAT_ExponentialDistribution.cpp:66
virtual tReal standardDeviation() const
compute the standard deviation
Definition: STAT_ExponentialDistribution.cpp:71
This class is the class to describes general distribution.
Definition: STAT_Distribution.h:25
virtual SP::STAT_Distribution NewInstance() const
create a new instance of the distribution
Definition: STAT_ExponentialDistribution.h:73
static SP::STAT_ExponentialDistribution New()
create a Exponential distibution
Definition: STAT_ExponentialDistribution.h:68
boost::mt19937 RNGType
Definition: STAT_Distribution.h:23
void setProperties(const tReal &lambda)
Definition: STAT_ExponentialDistribution.cpp:22
#define tReal
Definition: types.h:18
virtual tReal pdf(const tReal &x) const
compute the probability density function at x point
Definition: STAT_ExponentialDistribution.cpp:45
This class is the class to describes Exponential distribution.
Definition: STAT_ExponentialDistribution.h:16
class Free introduced for deleting a smart pointer
Definition: CORE_Object.h:106