|
Revision 17774, 0.6 kB
(checked in by miki, 5 years ago)
|
|
import Data::Lotter
|
| Line | |
|---|
| 1 | use strict; |
|---|
| 2 | use Data::Dumper; |
|---|
| 3 | use Data::Lotter; |
|---|
| 4 | use Test::More tests => 5; |
|---|
| 5 | |
|---|
| 6 | my %candidates = ( |
|---|
| 7 | red => 1, |
|---|
| 8 | green => 10, |
|---|
| 9 | blue => 25, |
|---|
| 10 | yellow => 30, |
|---|
| 11 | white => 34, |
|---|
| 12 | ); |
|---|
| 13 | |
|---|
| 14 | my $num = 100000; |
|---|
| 15 | my $count; |
|---|
| 16 | for ( 1 .. $num ) { |
|---|
| 17 | my $lotter = Data::Lotter->new(%candidates); |
|---|
| 18 | my @ret = $lotter->pickup( 1, "REMOVE" ); |
|---|
| 19 | $count->{ $ret[0] }++; |
|---|
| 20 | } |
|---|
| 21 | while ( my ( $item, $weight ) = each %candidates ) { |
|---|
| 22 | my $result = $count->{$item} / $num * 100; |
|---|
| 23 | my $error = abs( $result - $weight ); |
|---|
| 24 | ok( $error < 1, |
|---|
| 25 | "$item has $error% error (weight:$weight, result:$result)" ); |
|---|
| 26 | } |
|---|