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 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
|
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2022 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
`define stop $stop
`define checkd(gotv,expv) do if ((gotv) !== (expv)) begin $write("%%Error: %s:%0d: got=%0d exp=%0d\n", `__FILE__,`__LINE__, (gotv), (expv)); `stop; end while(0);
module t(/*AUTOARG*/);
integer seed;
integer r;
integer sum;
initial begin
//=======
seed = 1234;
r = $dist_chi_square(seed, 5);
`checkd(seed, 923940542);
`checkd(r, 8);
sum = 1;
repeat(20) sum += $dist_chi_square(seed, 5);
`checkd(sum, 130);
sum = 1;
repeat(20) sum += $dist_chi_square(seed, -5);
`checkd(sum, 1);
sum = 1;
repeat(20) sum += $dist_chi_square(seed, 2);
`checkd(sum, 30);
//=======
seed = 1234;
r = $dist_erlang(seed, 5, 10);
`checkd(seed, 1025211431);
`checkd(r, 19);
sum = 1;
repeat(20) sum += $dist_erlang(seed, 5, 10);
`checkd(sum, 173);
sum = 1;
repeat(20) sum += $dist_erlang(seed, 5, -10);
`checkd(sum, -241);
//=======
seed = 1234;
r = $dist_exponential(seed, 5);
`checkd(seed, 85231147);
`checkd(r, 20);
sum = 1;
repeat(20) sum += $dist_exponential(seed, 5);
`checkd(sum, 104);
//=======
seed = 1234;
r = $dist_normal(seed, 5, 10);
`checkd(seed, -1570070672);
`checkd(r, 4);
sum = 1;
repeat(20) sum += $dist_normal(seed, 5, 10);
`checkd(sum, 114);
//=======
seed = 1234;
r = $dist_poisson(seed, 5);
`checkd(seed, 418012337);
`checkd(r, 2);
sum = 1;
repeat(20) sum += $dist_poisson(seed, 5);
`checkd(sum, 111);
//=======
seed = 1234;
r = $dist_t(seed, 5);
`checkd(seed, -797481412);
`checkd(r, 0);
sum = 1;
repeat(20) sum += $dist_t(seed, 5);
`checkd(sum, -2);
//=======
seed = 1234;
r = $dist_uniform(seed, 5, 10);
`checkd(seed, 85231147);
`checkd(r, 5);
sum = 1;
repeat(20) sum += $dist_uniform(seed, 5, 10);
`checkd(sum, 147);
seed = 1234;
r = $dist_uniform(seed, 10, 5);
`checkd(r, 10);
sum = 1;
repeat(20) sum += $dist_uniform(seed, -2147483648, -20);
`checkd(sum, 1768955681);
sum = 1;
repeat(20) sum += $dist_uniform(seed, 20, 2147483647);
`checkd(sum, 1534326415);
sum = 1;
repeat(20) sum += $dist_uniform(seed, -2147483648, 2147483647);
`checkd(sum, 1394525852);
seed = 0;
sum = 1;
repeat(20) sum += $dist_uniform(seed, -10, 100);
`checkd(seed, 1003647461);
`checkd(sum, 896);
$write("*-* All Finished *-*\n");
$finish;
end
endmodule
|