# HG changeset patch # User Alpar Juttner # Date 2007-12-22 08:01:20 # Node ID 435bbc8127b3b6076ae41452a059be72c739125b # Parent ea5945b2da9c0b92a55d0b8e41c58c838842d8cc A better way of generating pareto distr, and swap its parameters. - Pareto distribution is now generated as a composition of a Gamma and an exponential one - Similarly to gamma() and weibull(), the shape parameter became the first one. diff --git a/lemon/random.h b/lemon/random.h --- a/lemon/random.h +++ b/lemon/random.h @@ -798,16 +798,12 @@ /// This function generates a Pareto distribution random number. /// + ///\param k shape parameter (k>0) ///\param x_min location parameter (x_min>0) - ///\param k shape parameter (k>0) /// - ///\warning This function used inverse transform sampling, therefore may - ///suffer from numerical unstability. - /// - ///\todo Implement a numerically stable method - double pareto(double x_min,double k) + double pareto(double k,double x_min) { - return x_min*pow(1.0-real(),1.0/k); + return exponential(gamma(k,1.0/x_min)); } ///@}