zzuf/test/check-rng

76 lines
1.8 KiB
Bash
Executable File

#!/bin/sh
set -e
checkflip()
{
r=$1
expect=$2
s2=$seed
mib=20
echo "*** $mib MiB of zeroes, ratio $r ***"
rmax=-1
rmin=-1
rtot=0
for x in 0 1 2 3 4; do
ret=`dd if=/dev/zero bs=1048576 count=$mib 2>/dev/null | "$ZZUF" -s $s2 -r $r | "$ZZERO"`
if [ "$rmax" = -1 -o "$ret" -gt "$rmax" ]; then rmax=$ret; fi
if [ "$rmin" = -1 -o "$ret" -lt "$rmin" ]; then rmin=$ret; fi
rtot=`expr $rtot + $ret || true`
echo " try $x .......... $ret"
s2=`expr $s2 + 1`
done
rmean=`expr '(' $rtot + 2 ')' / 5 || true`
delta=`expr $rmean - $expect || true`
if [ "$delta" -gt -5 -a "$delta" -lt 5 ]; then
result="ok"
elif [ $(($rmean * 8)) -lt $(($expect * 7)) \
-o $(($rmean * 7)) -gt $(($expect * 8)) ]; then
result="FAILED"
FAILED=$(($FAILED + 1))
else
result="ok"
fi
TESTED=$(($TESTED + 1))
echo " expected $expect min/avg/max $rmin/$rmean/$rmax .......... $result"
}
DIR="$(dirname "$0")"
ZZUF="$DIR/../src/zzuf"
ZZERO="$DIR/zzero"
if [ ! -f "$ZZERO" ]; then
echo "error: test/zzero is missing"
exit 1
fi
FAILED=0
TESTED=0
if [ -z "$1" ]; then
seed=$(date | $ZZUF -m 2>/dev/null | cut -f2 -d' ' | tr -d abcdef | cut -b1-8)
else
seed="$1"
fi
echo "*** running zzuf RNG test suite with seed $seed ***"
# if X flips are performed on N bits set to 0, the average number of bits
# set to 1 is: N / 2 * (1 - pow(1 - 2 / N, X)
checkflip 0.000000001 0
checkflip 0.00000001 1
checkflip 0.0000001 16
checkflip 0.000001 167
checkflip 0.00001 1677
checkflip 0.0001 16775
checkflip 0.001 167604
checkflip 0.01 1661055
checkflip 0.1 15205967
if [ "$FAILED" != 0 ]; then
echo "*** $FAILED tests failed out of $TESTED ***"
exit 1
fi
echo "*** all $TESTED tests OK ***"
exit 0