line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package Math::Erf::Approx; |
2
|
|
|
|
|
|
|
|
3
|
3
|
|
|
3
|
|
43195
|
use 5.010; |
|
3
|
|
|
|
|
10
|
|
|
3
|
|
|
|
|
111
|
|
4
|
3
|
|
|
3
|
|
18
|
use strict; |
|
3
|
|
|
|
|
4
|
|
|
3
|
|
|
|
|
98
|
|
5
|
3
|
|
|
3
|
|
13
|
use warnings; |
|
3
|
|
|
|
|
10
|
|
|
3
|
|
|
|
|
102
|
|
6
|
3
|
|
|
3
|
|
16
|
use Scalar::Util qw< blessed >; |
|
3
|
|
|
|
|
4
|
|
|
3
|
|
|
|
|
446
|
|
7
|
3
|
|
|
3
|
|
2829
|
use Sub::Exporter -setup => { exports => [qw< erf erfc >] }; |
|
3
|
|
|
|
|
47683
|
|
|
3
|
|
|
|
|
30
|
|
8
|
3
|
|
|
3
|
|
2327
|
use Test::More; |
|
3
|
|
|
|
|
23794
|
|
|
3
|
|
|
|
|
28
|
|
9
|
|
|
|
|
|
|
|
10
|
|
|
|
|
|
|
BEGIN { |
11
|
3
|
|
|
3
|
|
919
|
no warnings 'once'; |
|
3
|
|
|
|
|
6
|
|
|
3
|
|
|
|
|
147
|
|
12
|
3
|
|
|
3
|
|
8
|
$Math::Erf::Approx::AUTHORITY = 'cpan:TOBYINK'; |
13
|
3
|
|
|
|
|
1381
|
$Math::Erf::Approx::VERSION = '0.002'; |
14
|
|
|
|
|
|
|
}; |
15
|
|
|
|
|
|
|
|
16
|
|
|
|
|
|
|
sub erf |
17
|
|
|
|
|
|
|
{ |
18
|
92
|
|
|
92
|
1
|
108
|
my ($x) = @_; |
19
|
|
|
|
|
|
|
|
20
|
92
|
50
|
|
|
|
269
|
if ($x < 0) |
21
|
|
|
|
|
|
|
{ |
22
|
0
|
|
|
|
|
0
|
return -erf(-$x); |
23
|
|
|
|
|
|
|
} |
24
|
|
|
|
|
|
|
|
25
|
92
|
|
|
|
|
197
|
my @a = qw< 1.0 0.278393 0.230389 0.000972 0.078108>; |
26
|
|
|
|
|
|
|
|
27
|
92
|
|
|
|
|
87
|
my $sum; |
28
|
92
|
|
|
|
|
141
|
for my $i (0 .. 4) |
29
|
|
|
|
|
|
|
{ |
30
|
460
|
|
|
|
|
1173
|
$sum += $a[$i] * ($x ** $i); |
31
|
|
|
|
|
|
|
} |
32
|
|
|
|
|
|
|
|
33
|
92
|
|
|
|
|
412
|
1.0 - ($sum ** -4); |
34
|
|
|
|
|
|
|
} |
35
|
|
|
|
|
|
|
|
36
|
|
|
|
|
|
|
sub erfc |
37
|
|
|
|
|
|
|
{ |
38
|
46
|
|
|
46
|
1
|
64
|
my ($x, $erf) = @_; |
39
|
46
|
|
50
|
|
|
189
|
$erf //= \&erf; |
40
|
46
|
|
|
|
|
85
|
1.0 - $erf->($x); |
41
|
|
|
|
|
|
|
} |
42
|
|
|
|
|
|
|
|
43
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
sub _test_cases |
45
|
|
|
|
|
|
|
{ |
46
|
1
|
|
|
1
|
|
22
|
my @numbers = grep { /\d/ } split /\s+/, q{ |
|
139
|
|
|
|
|
239
|
|
47
|
|
|
|
|
|
|
0.00 0.0000000 1.0000000 1.30 0.9340079 0.0659921 |
48
|
|
|
|
|
|
|
0.05 0.0563720 0.9436280 1.40 0.9522851 0.0477149 |
49
|
|
|
|
|
|
|
0.10 0.1124629 0.8875371 1.50 0.9661051 0.0338949 |
50
|
|
|
|
|
|
|
0.15 0.1679960 0.8320040 1.60 0.9763484 0.0236516 |
51
|
|
|
|
|
|
|
0.20 0.2227026 0.7772974 1.70 0.9837905 0.0162095 |
52
|
|
|
|
|
|
|
0.25 0.2763264 0.7236736 1.80 0.9890905 0.0109095 |
53
|
|
|
|
|
|
|
0.30 0.3286268 0.6713732 1.90 0.9927904 0.0072096 |
54
|
|
|
|
|
|
|
0.35 0.3793821 0.6206179 2.00 0.9953223 0.0046777 |
55
|
|
|
|
|
|
|
0.40 0.4283924 0.5716076 2.10 0.9970205 0.0029795 |
56
|
|
|
|
|
|
|
0.45 0.4754817 0.5245183 2.20 0.9981372 0.0018628 |
57
|
|
|
|
|
|
|
0.50 0.5204999 0.4795001 2.30 0.9988568 0.0011432 |
58
|
|
|
|
|
|
|
0.55 0.5633234 0.4366766 2.40 0.9993115 0.0006885 |
59
|
|
|
|
|
|
|
0.60 0.6038561 0.3961439 2.50 0.9995930 0.0004070 |
60
|
|
|
|
|
|
|
0.65 0.6420293 0.3579707 2.60 0.9997640 0.0002360 |
61
|
|
|
|
|
|
|
0.70 0.6778012 0.3221988 2.70 0.9998657 0.0001343 |
62
|
|
|
|
|
|
|
0.75 0.7111556 0.2888444 2.80 0.9999250 0.0000750 |
63
|
|
|
|
|
|
|
0.80 0.7421010 0.2578990 2.90 0.9999589 0.0000411 |
64
|
|
|
|
|
|
|
0.85 0.7706681 0.2293319 3.00 0.9999779 0.0000221 |
65
|
|
|
|
|
|
|
0.90 0.7969082 0.2030918 3.10 0.9999884 0.0000116 |
66
|
|
|
|
|
|
|
0.95 0.8208908 0.1791092 3.20 0.9999940 0.0000060 |
67
|
|
|
|
|
|
|
1.00 0.8427008 0.1572992 3.30 0.9999969 0.0000031 |
68
|
|
|
|
|
|
|
1.10 0.8802051 0.1197949 3.40 0.9999985 0.0000015 |
69
|
|
|
|
|
|
|
1.20 0.9103140 0.0896860 3.50 0.9999993 0.0000007 |
70
|
|
|
|
|
|
|
}; |
71
|
|
|
|
|
|
|
|
72
|
1
|
|
|
|
|
6
|
my @test_cases; |
73
|
1
|
|
|
|
|
4
|
while (@numbers) |
74
|
|
|
|
|
|
|
{ |
75
|
46
|
|
|
|
|
112
|
push @test_cases, [shift @numbers, shift @numbers, shift @numbers]; |
76
|
|
|
|
|
|
|
} |
77
|
|
|
|
|
|
|
|
78
|
1
|
|
|
|
|
10
|
return @test_cases; |
79
|
|
|
|
|
|
|
} |
80
|
|
|
|
|
|
|
|
81
|
|
|
|
|
|
|
sub _close_enough |
82
|
|
|
|
|
|
|
{ |
83
|
92
|
|
|
92
|
|
120
|
my ($x, $y) = @_; |
84
|
92
|
|
|
|
|
150
|
my $err = abs($x - $y); |
85
|
92
|
50
|
|
|
|
430
|
return 1 if $err < 0.0005; |
86
|
0
|
|
|
|
|
0
|
diag "Got: $x"; |
87
|
0
|
|
|
|
|
0
|
diag "Expected $y"; |
88
|
0
|
|
|
|
|
0
|
return; |
89
|
|
|
|
|
|
|
} |
90
|
|
|
|
|
|
|
|
91
|
|
|
|
|
|
|
sub run_tests |
92
|
|
|
|
|
|
|
{ |
93
|
1
|
|
|
1
|
1
|
10
|
my ($class) = @_; |
94
|
1
|
|
|
|
|
5
|
my @cases = $class->_test_cases; |
95
|
|
|
|
|
|
|
|
96
|
1
|
|
|
|
|
11
|
plan tests => (2 * @cases); |
97
|
|
|
|
|
|
|
|
98
|
1
|
|
|
|
|
526
|
foreach my $tc (@cases) |
99
|
|
|
|
|
|
|
{ |
100
|
46
|
|
|
|
|
16226
|
my ($x, $erf, $erfc) = @$tc; |
101
|
46
|
|
|
|
|
92
|
ok _close_enough(erf($x), $erf), "erf($x)"; |
102
|
46
|
|
|
|
|
22730
|
ok _close_enough(erfc($x), $erfc), "erfc($x)"; |
103
|
|
|
|
|
|
|
} |
104
|
|
|
|
|
|
|
} |
105
|
|
|
|
|
|
|
|
106
|
|
|
|
|
|
|
caller(0) or __PACKAGE__->run_tests; |
107
|
|
|
|
|
|
|
__END__ |