|  | Home | Libraries | People | FAQ | More | 
boost::random::hyperexponential_distribution
// In header: <boost/random/hyperexponential_distribution.hpp> template<typename RealT = double> class hyperexponential_distribution { public: // types typedef RealT result_type; typedef RealT input_type; // member classes/structs/unions class param_type { public: // types typedef hyperexponential_distribution distribution_type; // construct/copy/destruct param_type(); template<typename ProbIterT, typename RateIterT> param_type(ProbIterT, ProbIterT, RateIterT, RateIterT); template<typename ProbRangeT, typename RateRangeT> param_type(ProbRangeT const &, RateRangeT const &, typename boost::disable_if_c< boost::has_pre_increment< ProbRangeT >::value||boost::has_pre_increment< RateRangeT >::value >::type * = 0); template<typename RateIterT> param_type(RateIterT, RateIterT, typename boost::enable_if_c< boost::has_pre_increment< RateIterT >::value >::type * = 0); template<typename RateRangeT> param_type(RateRangeT const &); param_type(std::initializer_list< RealT >, std::initializer_list< RealT >); param_type(std::initializer_list< RealT >); // public member functions std::vector< RealT > probabilities() const; std::vector< RealT > rates() const; // friend functions template<typename CharT, typename Traits> std::basic_ostream< CharT, Traits > & operator<<(std::basic_ostream< CharT, Traits > &, const param_type &); template<typename CharT, typename Traits> std::basic_istream< CharT, Traits > & operator>>(std::basic_istream< CharT, Traits > &, const param_type &); bool operator==(const param_type &, const param_type &); bool operator!=(const param_type &, const param_type &); }; // construct/copy/destruct hyperexponential_distribution(); template<typename ProbIterT, typename RateIterT> hyperexponential_distribution(ProbIterT, ProbIterT, RateIterT, RateIterT); template<typename ProbRangeT, typename RateRangeT> hyperexponential_distribution(ProbRangeT const &, RateRangeT const &, typename boost::disable_if_c< boost::has_pre_increment< ProbRangeT >::value||boost::has_pre_increment< RateRangeT >::value >::type * = 0); template<typename RateIterT> hyperexponential_distribution(RateIterT, RateIterT, typename boost::enable_if_c< boost::has_pre_increment< RateIterT >::value >::type * = 0); template<typename RateRangeT> hyperexponential_distribution(RateRangeT const &); explicit hyperexponential_distribution(param_type const &); hyperexponential_distribution(std::initializer_list< RealT > const &, std::initializer_list< RealT > const &); hyperexponential_distribution(std::initializer_list< RealT > const &); // public member functions template<typename URNG> RealT operator()(URNG &) const; template<typename URNG> RealT operator()(URNG &, const param_type &) const; std::size_t num_phases() const; std::vector< RealT > probabilities() const; std::vector< RealT > rates() const; RealT min() const; RealT max() const; param_type param() const; void param(param_type const &); void reset(); // friend functions template<typename CharT, typename Traits> std::basic_ostream< CharT, Traits > & operator<<(std::basic_ostream< CharT, Traits > &, const hyperexponential_distribution &); template<typename CharT, typename Traits> std::basic_istream< CharT, Traits > & operator>>(std::basic_istream< CharT, Traits > &, const hyperexponential_distribution &); bool operator==(const hyperexponential_distribution &, const hyperexponential_distribution &); bool operator!=(const hyperexponential_distribution &, const hyperexponential_distribution &); };
The hyperexponential distribution is a real-valued continuous distribution with two parameters, the phase probability vector probs and the rate vector rates.
A  -phase hyperexponential distribution is a mixture of
-phase hyperexponential distribution is a mixture of  exponential distributions. For this reason, it is also referred to as mixed exponential distribution or parallel
 exponential distributions. For this reason, it is also referred to as mixed exponential distribution or parallel  -phase exponential distribution.
-phase exponential distribution.
A  -phase hyperexponential distribution is characterized by two parameters, namely a phase probability vector
-phase hyperexponential distribution is characterized by two parameters, namely a phase probability vector  and a rate vector
 and a rate vector  .
.
A  -phase hyperexponential distribution is frequently used in queueing theory to model the distribution of the superposition of
-phase hyperexponential distribution is frequently used in queueing theory to model the distribution of the superposition of  independent events, like, for instance, the service time distribution of a queueing station with
 independent events, like, for instance, the service time distribution of a queueing station with  servers in parallel where the
 servers in parallel where the  -th server is chosen with probability
-th server is chosen with probability  and its service time distribution is an exponential distribution with rate
 and its service time distribution is an exponential distribution with rate  (Allen,1990; Papadopolous et al.,1993; Trivedi,2002).
 (Allen,1990; Papadopolous et al.,1993; Trivedi,2002).
For instance, CPUs service-time distribution in a computing system has often been observed to possess such a distribution (Rosin,1965). Also, the arrival of different types of customer to a single queueing station is often modeled as a hyperexponential distribution (Papadopolous et al.,1993). Similarly, if a product manufactured in several parallel assemply lines and the outputs are merged, the failure density of the overall product is likely to be hyperexponential (Trivedi,2002).
Finally, since the hyperexponential distribution exhibits a high Coefficient of Variation (CoV), that is a CoV > 1, it is especially suited to fit empirical data with large CoV (Feitelson,2014; Wolski et al.,2013) and to approximate long-tail probability distributions (Feldmann et al.,1998).
See (Boost,2014) for more information and examples.
A  -phase hyperexponential distribution has a probability density function
-phase hyperexponential distribution has a probability density function  
 where:
 is the number of phases and also the size of the input vector parameters,
 is the number of phases and also the size of the input vector parameters,
 is the phase probability vector parameter, and
 is the phase probability vector parameter, and
 is the rate vector parameter.
 is the rate vector parameter.
Given a  -phase hyperexponential distribution with phase probability vector
-phase hyperexponential distribution with phase probability vector  and rate vector
 and rate vector  , the random variate generation algorithm consists of the following steps (Tyszer,1999):
, the random variate generation algorithm consists of the following steps (Tyszer,1999):
Generate a random variable  uniformly distribution on the interval
 uniformly distribution on the interval  .
.
Use  to select the appropriate
 to select the appropriate  (e.g., the alias method can possibly be used for this step).
 (e.g., the alias method can possibly be used for this step).
Generate an exponentially distributed random variable  with rate parameter
 with rate parameter  .
.
Return  .
.
References:
A.O. Allen, Probability, Statistics, and Queuing Theory with Computer Science Applications, Second Edition, Academic Press, 1990.
Boost C++ Libraries, Boost.Math / Statistical Distributions: Hyperexponential Distribution, Online: http://www.boost.org/doc/libs/release/libs/math/doc/html/dist.html , 2014.
D.G. Feitelson, Workload Modeling for Computer Systems Performance Evaluation, Cambridge University Press, 2014
A. Feldmann and W. Whitt, Fitting mixtures of exponentials to long-tail distributions to analyze network performance models, Performance Evaluation 31(3-4):245, doi:10.1016/S0166-5316(97)00003-5, 1998.
H.T. Papadopolous, C. Heavey and J. Browne, Queueing Theory in Manufacturing Systems Analysis and Design, Chapman & Hall/CRC, 1993, p. 35.
R.F. Rosin, Determining a computing center environment, Communications of the ACM 8(7):463-468, 1965.
K.S. Trivedi, Probability and Statistics with Reliability, Queueing, and Computer Science Applications, John Wiley & Sons, Inc., 2002.
J. Tyszer, Object-Oriented Computer Simulation of Discrete-Event Systems, Springer, 1999.
Wikipedia, Hyperexponential Distribution, Online: http://en.wikipedia.org/wiki/Hyperexponential_distribution , 2014.
Wolfram Mathematica, Hyperexponential Distribution, Online: http://reference.wolfram.com/language/ref/HyperexponentialDistribution.html , 2014.
Marco Guazzone (marco.guazzone@gmail.com)
hyperexponential_distribution 
        public
       construct/copy/destructhyperexponential_distribution();
Constructs a 1-phase hyperexponential_distribution
template<typename ProbIterT, typename RateIterT> hyperexponential_distribution(ProbIterT prob_first, ProbIterT prob_last, RateIterT rate_first, RateIterT rate_last);
Constructs a hyperexponential_distribution
The phase probability vector parameter is given by the range defined by [prob_first, prob_last) iterator pair, and the rate vector parameter is given by the range defined by [rate_first, rate_last) iterator pair.
References:
ISO, ISO/IEC 14882-2014: Information technology - Programming languages - C++, 2014
| Parameters: | 
 | ||||||||
| Template Parameters: | 
 | 
template<typename ProbRangeT, typename RateRangeT> hyperexponential_distribution(ProbRangeT const & prob_range, RateRangeT const & rate_range, typename boost::disable_if_c< boost::has_pre_increment< ProbRangeT >::value||boost::has_pre_increment< RateRangeT >::value >::type * = 0);
Constructs a hyperexponential_distribution
The phase probability vector parameter is given by the range defined by prob_range, and the rate vector parameter is given by the range defined by rate_range.
| ![[Note]](../../../../doc/src/images/note.png) | Note | 
|---|---|
| The final  | 
| Parameters: | 
 | ||||
| Template Parameters: | 
template<typename RateIterT> hyperexponential_distribution(RateIterT rate_first, RateIterT rate_last, typename boost::enable_if_c< boost::has_pre_increment< RateIterT >::value >::type * = 0);
Constructs a hyperexponential_distribution
The rate vector parameter is given by the range defined by [rate_first, rate_last) iterator pair, and the phase probability vector parameter is set to the equal phase probabilities (i.e., to a vector of the same length  of the rate vector and with each element set to
 of the rate vector and with each element set to  ).
).
| ![[Note]](../../../../doc/src/images/note.png) | Note | 
|---|---|
| The final  | 
References:
ISO, ISO/IEC 14882-2014: Information technology - Programming languages - C++, 2014
| Parameters: | 
 | ||||
| Template Parameters: | 
 | 
template<typename RateRangeT> hyperexponential_distribution(RateRangeT const & rate_range);
Constructs a param_type
The rate vector parameter is given by the range defined by rate_range, and the phase probability vector parameter is set to the equal phase probabilities (i.e., to a vector of the same length  of the rate vector and with each element set to
 of the rate vector and with each element set to  ).
).
| Parameters: | 
 | ||
| Template Parameters: | 
 | 
explicit hyperexponential_distribution(param_type const & param);
Constructs a hyperexponential_distribution
| Parameters: | 
 | 
hyperexponential_distribution(std::initializer_list< RealT > const & l1, std::initializer_list< RealT > const & l2);
Constructs a hyperexponential_distribution
The phase probability vector parameter is given by the brace-init-list (ISO,2014,sec. 8.5.4 [dcl.init.list]) defined by l1, and the rate vector parameter is given by the brace-init-list (ISO,2014,sec. 8.5.4 [dcl.init.list]) defined by l2.
References:
ISO, ISO/IEC 14882-2014: Information technology - Programming languages - C++, 2014
| Parameters: | 
 | 
hyperexponential_distribution(std::initializer_list< RealT > const & l1);
Constructs a hyperexponential_distribution
The rate vector parameter is given by the brace-init-list (ISO,2014,sec. 8.5.4 [dcl.init.list]) defined by l1, and the phase probability vector parameter is set to the equal phase probabilities (i.e., to a vector of the same length  of the rate vector and with each element set to
 of the rate vector and with each element set to  ).
).
References:
ISO, ISO/IEC 14882-2014: Information technology - Programming languages - C++, 2014
| Parameters: | 
 | 
hyperexponential_distribution public member functionstemplate<typename URNG> RealT operator()(URNG & urng) const;
Gets a random variate distributed according to the hyperexponential distribution.
| Parameters: | 
 | ||
| Template Parameters: | 
 | ||
| Returns: | A random variate distributed according to the hyperexponential distribution. | 
template<typename URNG> RealT operator()(URNG & urng, const param_type & param) const;
Gets a random variate distributed according to the hyperexponential distribution with parameters specified by param.
| Parameters: | 
 | ||||
| Template Parameters: | 
 | ||||
| Returns: | A random variate distributed according to the hyperexponential distribution. distribution with parameters specified by  | 
std::size_t num_phases() const;
Returns the number of phases of the distribution.
std::vector< RealT > probabilities() const;
Returns the phase probability vector parameter of the distribution.
std::vector< RealT > rates() const;
Returns the rate vector parameter of the distribution.
RealT min() const;
Returns the smallest value that the distribution can produce.
RealT max() const;
Returns the largest value that the distribution can produce.
param_type param() const;
Returns the parameters of the distribution.
void param(param_type const & param);
Sets the parameters of the distribution.
void reset();
Effects: Subsequent uses of the distribution do not depend on values produced by any engine prior to invoking reset.
hyperexponential_distribution friend functionstemplate<typename CharT, typename Traits> std::basic_ostream< CharT, Traits > & operator<<(std::basic_ostream< CharT, Traits > & os, const hyperexponential_distribution & hd);
Writes an hyperexponential_distributionstd::ostream. 
template<typename CharT, typename Traits> std::basic_istream< CharT, Traits > & operator>>(std::basic_istream< CharT, Traits > & is, const hyperexponential_distribution & hd);
Reads an hyperexponential_distributionstd::istream. 
bool operator==(const hyperexponential_distribution & lhs, const hyperexponential_distribution & rhs);
Returns true if the two instances of hyperexponential_distribution
bool operator!=(const hyperexponential_distribution & lhs, const hyperexponential_distribution & rhs);
Returns true if the two instances of hyperexponential_distribution