29 Numerics library [numerics]

29.6 Random number generation [rand]

29.6.8 Random number distribution class templates [rand.dist]

29.6.8.3 Bernoulli distributions [rand.dist.bern]

29.6.8.3.1 Class bernoulli_­distribution [rand.dist.bern.bernoulli]

bernoulli_­distribution Распределение случайных чисел производитbool значения ,b распределенных в соответствии с дискретной вероятностной функцией

P(b|p)={pifb=true1pifb=false.

class bernoulli_distribution {
public:
  // types
  using result_type = bool;
  using param_type  = unspecified;

  // constructors and reset functions
  explicit bernoulli_distribution(double p = 0.5);
  explicit bernoulli_distribution(const param_type& parm);
  void reset();

  // generating functions
  template<class URBG>
    result_type operator()(URBG& g);
  template<class URBG>
    result_type operator()(URBG& g, const param_type& parm);

  // property functions
  double p() const;
  param_type param() const;
  void param(const param_type& parm);
  result_type min() const;
  result_type max() const;
};

explicit bernoulli_distribution(double p = 0.5);

Requires: 0p1.

Effects: Строитbernoulli_­distribution объект; p соответствует параметру распределения.

double p() const;

Returns: Значениеp параметра, с которым был построен объект.

29.6.8.3.2 Class template binomial_­distribution [rand.dist.bern.bin]

binomial_­distribution Случайное распределение числа производит целые значенияi0 распределены по дискретной функции вероятности

P(i|t,p)=(ti)pi(1p)ti.

template<class IntType = int>
  class binomial_distribution {
  public:
    // types
    using result_type = IntType;
    using param_type  = unspecified;

    // constructors and reset functions
    explicit binomial_distribution(IntType t = 1, double p = 0.5);
    explicit binomial_distribution(const param_type& parm);
    void reset();

    // generating functions
    template<class URBG>
      result_type operator()(URBG& g);
    template<class URBG>
      result_type operator()(URBG& g, const param_type& parm);

    // property functions
    IntType t() const;
    double p() const;
    param_type param() const;
    void param(const param_type& parm);
    result_type min() const;
    result_type max() const;
  };

explicit binomial_distribution(IntType t = 1, double p = 0.5);

Requires: 0p1 и0t.

Effects: Строитbinomial_­distribution объект; t иp соответствуют соответствующим параметрам распределения.

IntType t() const;

Returns: Значениеt параметра, с которым был построен объект.

double p() const;

Returns: Значениеp параметра, с которым был построен объект.

29.6.8.3.3 Class template geometric_­distribution [rand.dist.bern.geo]

geometric_­distribution Случайное распределение числа производит целые значенияi0 распределены по дискретной функции вероятности

P(i|p)=p(1p)i.

template<class IntType = int>
  class geometric_distribution {
  public:
    // types
    using result_type = IntType;
    using param_type  = unspecified;

    // constructors and reset functions
    explicit geometric_distribution(double p = 0.5);
    explicit geometric_distribution(const param_type& parm);
    void reset();

    // generating functions
    template<class URBG>
      result_type operator()(URBG& g);
    template<class URBG>
      result_type operator()(URBG& g, const param_type& parm);

    // property functions
    double p() const;
    param_type param() const;
    void param(const param_type& parm);
    result_type min() const;
    result_type max() const;
  };

explicit geometric_distribution(double p = 0.5);

Requires: 0<p<1.

Effects: Строитgeometric_­distribution объект; p соответствует параметру распределения.

double p() const;

Returns: Значениеp параметра, с которым был построен объект.

29.6.8.3.4 Class template negative_­binomial_­distribution [rand.dist.bern.negbin]

negative_­binomial_­distribution Случайное распределение числа производит случайные целые числа ,i0 распределенные в соответствии с дискретной вероятностной функцией

P(i|k,p)=(k+i1i)pk(1p)i.

[ Note: Это означает, чтоP(i|k,p) не определено, когдаp == 1. ]end note

template<class IntType = int>
  class negative_binomial_distribution {
  public:
    // types
    using result_type = IntType;
    using param_type  = unspecified;

    // constructor and reset functions
    explicit negative_binomial_distribution(IntType k = 1, double p = 0.5);
    explicit negative_binomial_distribution(const param_type& parm);
    void reset();

    // generating functions
    template<class URBG>
      result_type operator()(URBG& g);
    template<class URBG>
      result_type operator()(URBG& g, const param_type& parm);

    // property functions
    IntType k() const;
    double p() const;
    param_type param() const;
    void param(const param_type& parm);
    result_type min() const;
    result_type max() const;
  };

explicit negative_binomial_distribution(IntType k = 1, double p = 0.5);

Requires: 0<p1 и0<k.

Effects: Строитnegative_­binomial_­distribution объект; k иp соответствуют соответствующим параметрам распределения.

IntType k() const;

Returns: Значениеk параметра, с которым был построен объект.

double p() const;

Returns: Значениеp параметра, с которым был построен объект.