File: test.pl

package info (click to toggle)
libmath-random-tt800-perl 1.01-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 84 kB
  • sloc: ansic: 53; perl: 36; makefile: 2
file content (58 lines) | stat: -rw-r--r-- 1,562 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# Before `make install' is performed this script should be runnable with
# `make test'. After `make install' it should work as `perl test.pl'

######################### We start with some black magic to print on failure.

# Change 1..1 below to 1..last_test_to_print .
# (It may become useful if the test is moved to ./t subdirectory.)

BEGIN { $| = 1; print "1..9\n"; }
END {print "not ok 1\n" unless $loaded;}
use Math::Random::TT800;
$loaded = 1;
print "ok 1\n";

######################### End of black magic.

# Insert your test code below (better if it prints "ok 13"
# (correspondingly "not ok 13") depending on the success of chunk 13
# of the test code):

#
#  Testing with default seed
#
$tt = new Math::Random::TT800;

(sprintf("%u",$tt->next_int()) eq "3169973338") or print "not ";
print "ok 2\n";

(abs($tt->next() - 0.63445952502881) < 0.0000001 ) or print "not ";
print "ok 3\n";

for (1..100) { $tt->next_int(); }

(sprintf("%u",$tt->next_int()) eq "3491672134") or print "not ";
print "ok 4\n";

(abs($tt->next() - 0.25527860719135) < 0.0000001 ) or print "not ";
print "ok 5\n";

#
#  Testing with custom seed
#
$tt = new Math::Random::TT800 42,1,8,1,4,131,91231,9173123;

(sprintf("%u",$tt->next_int()) eq "42010539") or print "not ";
print "ok 6\n";

(abs($tt->next() - 2.3283064370808e-10) < 0.0000001 ) or print "not ";
print "ok 7\n";

for (1..100) { $tt->next_int(); }

(sprintf("%u",$tt->next_int()) eq "2788880872") or print "not ";
print "ok 8\n";

(abs($tt->next() - 0.625562964851401) < 0.0000001 ) or print "not ";
print "ok 9\n";