C++ named requirements: UniformRandomBitGenerator (since C++11)

From cppreference.com
< cpp‎ | named req
 
 
C++ named requirements
 

A uniform random bit generator is a function object returning unsigned integer values such that each value in the range of possible results has (ideally) equal probability.

Uniform random bit generators are not intended to be used as random number generators: they are used as the source of random bits (generated in bulk, for efficiency). Any uniform random bit generator may be plugged into any random number distribution in order to obtain a random number (formally, a random variate).

Requirements

The type G satisfies UniformRandomBitGenerator if

Given g, a value of type G, all following conditions are satisfied:

  • G::result_type is valid, and denotes an unsigned integer type.
  • The following expressions must be valid and have their specified effects:
(until C++20)
 Expression  Type Requirements
G::min() G::result_type 
  • Yields the smallest value that G's operator() may return. 
  • The result value is strictly less than G::max().
  • The expression must be a constant expression.
G::max() G::result_type
  • Yields the largest value that G's operator() may return.
  • The result value is strictly greater than G::min().
  • The expression must be a constant expression.
g() G::result_type
  • Returns a value in the closed interval [G::min()G::max()].
  • Has amortized constant complexity.

All following conditions are satisfied:

(since C++20)

Notes

All RandomNumberEngines satisfy this requirement.

Standard library

The following standard library facilities expect a UniformRandomBitGenerator type.

(until C++17)(C++11)
randomly re-orders elements in a range
(function template)
(C++17)
selects N random elements from a sequence
(function template)
evenly distributes real values of given precision across [01)
(function template)
produces integer values evenly distributed across a range
(class template)
produces real values evenly distributed across a range
(class template)
all other random number distributions

The following standard library facilities satisfy UniformRandomBitGenerator without additionally satisfying RandomNumberEngine:

non-deterministic random number generator using hardware entropy source
(class)

Defect reports

The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

DR Applied to Behavior as published Correct behavior
LWG 2154
(P0898R3)
C++11 it was unclear whether G::min() and G::max()
are required to be constant expressions[1]
required
  1. The time complexity requirement for these expressions were “compile-time” before C++20. The wording is ambiguous, as “compile-time time complexity” can be interpreted as both “can be evaluated in compile-time” and “the time complexity can be determined in compile-time”.

See also

specifies that a type qualifies as a uniform random bit generator
(concept)