Entropy in the Linux Kernel
Entropy is required to generate good random numbers. Modern operating systems will use physical hardware as sources for entropy and the 'randomness' goes into an entropy pool for future use.
On Linux, /dev/random and /dev/urandom are pseudo devices that provide random numbers. Both devices are supplied by the kernel's PRNG, though /dev/random will block when the entropy pool is depleted while /dev/urandom will continue to generate random numbers.
For a cheap entropy source, see Entropy Source using RTL-SDR.
Linux Entropy Pool
You can see the size of the entropy pool size in linux by running:
# cat /proc/sys/kernel/random/poolsize
The number of 'bits' of entropy can be seen at:
# cat /proc/sys/kernel/random/entropy_avail
Visualizing Randomness
The following PHP script will let you generate bitmap from data piped to the script. You can also use the commented out line to visualize PHP's rand function. This script can be found at http://api.leo.leung.xyz/random
<?php
header("Content-type: image/png");
// Requires the GD Library
$img = imagecreatetruecolor(512, 512) or die("Cannot Initialize new GD image stream");
$white = imagecolorallocate($img, 255, 255, 255);
$fp = fopen('php://stdin', 'r');
for ($x = 0; $x < 512; $x++) {
for ($y = 0; $y < 512; $y++) {
// $data = rand(0, 1)
$data = ord(fread($fp, 1));
if ($data % 2 == 0) {
imagesetpixel($img, $x, $y, $white);
}
}
}
fclose($fp);
imagepng($img);
imagedestroy($img);