public member function
<random>
(1) | explicit uniform_real_distribution ( result_type a = 0.0, result_type b = 1.0 ); |
---|
(2) | explicit uniform_real_distribution ( const param_type& parm ); |
---|
Construct uniform real distribution
Constructs a uniform_real_distribution object, adopting the distribution parameters specified either by a and b or by object parm.
Parameters
- a, b
- Upper and lower bounds of the range ([a,b)) of possible values the distribution can generate.
Note that the range includes a but not b.
b shall be greater than or equal to a (a<=b).
result_type is a member type that represents the type of the random numbers generated on each call to operator(). It is defined as an alias of the first class template parameter (RealType).
- parm
- An object representing the distribution's parameters, obtained by a call to member function param.
param_type is a member type.
Example
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
|
// uniform_real_distribution example
#include <iostream>
#include <chrono>
#include <random>
int main()
{
// construct a trivial random generator engine from a time-based seed:
unsigned seed = std::chrono::system_clock::now().time_since_epoch().count();
std::default_random_engine generator (seed);
std::uniform_real_distribution<double> distribution (0.0,1.0);
std::cout << "some random numbers between 0.0 and 1.0: " << std::endl;
for (int i=0; i<10; ++i)
std::cout << distribution(generator) << std::endl;
return 0;
}
|
Possible output:
some random numbers between 0.0 and 1.0:
0.423157
0.653959
0.26444
0.280517
0.884283
0.915755
0.419503
0.353592
0.0285182
0.15477
|