Skip site navigation (1)Skip section navigation (2)

FreeBSD Manual Pages

  
 
  

home | help
std::normal_distribution(3)   C++ Standard Libary  std::normal_distribution(3)

NAME
       std::normal_distribution	- std::normal_distribution

Synopsis
	  Defined in header <random>
	  template< class RealType = double >  (since C++11)
	  class	normal_distribution;

	  Generates  random numbers according to the Normal (or	Gaussian) ran-
       dom number
	  distribution.	It is defined as:

		  \(\small{f(x;\mu,\sigma)}=\frac{1}{\sigma\sqrt{2\pi}
		  }\exp{(-\frac{1}{2}{(\frac{x-\mu}{\sigma})}^2)}\)f(x;	,) =

		  1

		  2

		  exp

		  -1
		  2

		  x-

		   2

	  Here \(\small\mu\) is	the mean and \(\small\sigma\) is the  standard
       deviation
	  (stddev).

	  std::normal_distribution  satisfies  all  requirements of RandomNum-
       berDistribution

Template parameters
	  RealType - The result	type generated by the generator. The effect is
       undefined if
		     this is not one of	float, double, or long double.

Member types
	  Member type	     Definition
	  result_type(C++11) RealType
	  param_type(C++11)  the type of the  parameter	 set,  see  RandomNum-
       berDistribution.

Member functions
	  constructor	constructs new distribution
	  (C++11)	(public	member function)
	  reset		resets the internal state of the distribution
	  (C++11)	(public	member function)

Generation
	  operator()	generates the next random number in the	distribution
	  (C++11)	(public	member function)

Characteristics
	  mean		returns	the distribution parameters
	  stddev	(public	member function)
	  param		gets or	sets the distribution parameter	object
	  (C++11)	(public	member function)
	  min		returns	the minimum potentially	generated value
	  (C++11)	(public	member function)
	  max		returns	the maximum potentially	generated value
	  (C++11)	(public	member function)

Non-member functions
	  operator==
	  operator!=		    compares two distribution objects
	  (C++11)		    (function)
	  (C++11)(removed in C++20)
	  operator<<		      performs	stream	input  and  output  on
       pseudo-random number
	  operator>>		    distribution
	  (C++11)		    (function template)

Example
       // Run this code

	#include <iostream>
	#include <iomanip>
	#include <string>
	#include <map>
	#include <random>
	#include <cmath>
	int main()
	{
	    std::random_device rd{};
	    std::mt19937 gen{rd()};

	    // values near the mean are	the most likely
	    // standard	deviation affects the dispersion of  generated	values
       from the	mean
	    std::normal_distribution<> d{5,2};

	    std::map<int, int> hist{};
	    for(int n=0; n<10000; ++n) {
		++hist[std::round(d(gen))];
	    }
	    for(auto p : hist) {
		std::cout << std::setw(2)
			  <<  p.first << ' ' <<	std::string(p.second/200, '*')
       << '\n';
	    }
	}

Possible output:
	-2
	-1
	 0
	 1 *
	 2 ***
	 3 ******
	 4 ********
	 5 **********
	 6 ********
	 7 *****
	 8 ***
	 9 *
	10
	11
	12

External links
	    * Weisstein, Eric W. "Normal Distribution."	From MathWorld--A Wol-
       fram Web
	      Resource.
	    * Normal Distribution. From	Wikipedia.

http://cppreference.com		  2022.07.31	   std::normal_distribution(3)

Want to link to this manual page? Use this URL:
<https://man.freebsd.org/cgi/man.cgi?query=std::normal_distribution&sektion=3&manpath=FreeBSD+Ports+15.0>

home | help