Namespaces
Variants
Actions

std::random_device::entropy

From cppreference.com
< cpp‎ | numeric‎ | random‎ | random device
 
C++
 
Numerics library
 
Pseudo-random number generation
 
std::random_device
Member functions
Generation
Characteristics
random_device::entropy
 
double entropy() const noexcept;
(since C++11)

Obtains an estimate of the random number device entropy, which is a floating-point value between 0 and log2(max()+1) (which is equal to std::numeric_limits<unsigned int>::digits). If the device has n states whose individual probabilities are P0,...,Pn-1, the device entropy S is defined as

S = −∑n-1
i=0
Pilog(Pi)

A deterministic random number generator (e.g. a pseudo-random engine) has entropy zero.

[edit] Return value

The value of the device entropy, or zero if not applicable.

[edit] Notes

This function is not fully implemented in some standard libraries. For example, boost.random returns 10.

The entropy of the Linux kernel device /dev/urandom may be obtained using GNU libstdc++ uses as of version 8.1.

[edit] Example

Example output on one of the implementations

#include <iostream>
#include <random>
 
int main()
{
    std::random_device rd;
    std::cout << rd.entropy() << '\n';
}

Possible output:

32

Follow Lee on X/Twitter - Father, Husband, Serial builder creating AI, crypto, games & web tools. We are friends :) AI Will Come To Life!

Check out: eBank.nz (Art Generator) | Netwrck.com (AI Tools) | Text-Generator.io (AI API) | BitBank.nz (Crypto AI) | ReadingTime (Kids Reading) | RewordGame | BigMultiplayerChess | WebFiddle | How.nz | Helix AI Assistant