pidigits benchmark and bpi() method in Math::BigFloat/Math::BigInt, take 7 [PATCH]
[p5sagit/p5-mst-13.2.git] / lib / Math / BigInt / t / bigfltpm.inc
CommitLineData
ee15d750 1#include this file into another test for subclass testing...
b3abae2a 2
3ok ($class->config()->{lib},$CL);
4
56d9de68 5use strict;
6
b68b7ab1 7my $z;
8
ee15d750 9while (<DATA>)
10 {
d614cd8b 11 chomp;
ee15d750 12 $_ =~ s/#.*$//; # remove comments
13 $_ =~ s/\s+$//; # trailing spaces
14 next if /^$/; # skip empty lines & comments
15 if (s/^&//)
16 {
17 $f = $_;
18 }
19 elsif (/^\$/)
20 {
21 $setup = $_; $setup =~ s/\$/\$${class}::/g; # round_mode, div_scale
22 #print "\$setup== $setup\n";
23 }
24 else
25 {
26 if (m|^(.*?):(/.+)$|)
27 {
28 $ans = $2;
29 @args = split(/:/,$1,99);
30 }
31 else
32 {
33 @args = split(/:/,$_,99); $ans = pop(@args);
34 }
9b924220 35 $try = "\$x = $class->new(\"$args[0]\");";
ee15d750 36 if ($f eq "fnorm")
37 {
38 $try .= "\$x;";
39 } elsif ($f eq "finf") {
40 $try .= "\$x->finf('$args[1]');";
027dc388 41 } elsif ($f eq "is_inf") {
42 $try .= "\$x->is_inf('$args[1]');";
ee15d750 43 } elsif ($f eq "fone") {
44 $try .= "\$x->bone('$args[1]');";
45 } elsif ($f eq "fstr") {
46 $try .= "\$x->accuracy($args[1]); \$x->precision($args[2]);";
47 $try .= '$x->fstr();';
ee15d750 48 } elsif ($f eq "parts") {
48b581a2 49 # ->bstr() to see if an object is returned
ee15d750 50 $try .= '($a,$b) = $x->parts(); $a = $a->bstr(); $b = $b->bstr();';
51 $try .= '"$a $b";';
ee15d750 52 } elsif ($f eq "exponent") {
48b581a2 53 # ->bstr() to see if an object is returned
ee15d750 54 $try .= '$x->exponent()->bstr();';
55 } elsif ($f eq "mantissa") {
48b581a2 56 # ->bstr() to see if an object is returned
ee15d750 57 $try .= '$x->mantissa()->bstr();';
56d9de68 58 } elsif ($f =~ /^(numify|length|as_number|as_hex|as_bin)$/) {
59 $try .= "\$x->$f();";
b3abae2a 60 # some unary ops (test the fxxx form, since that is done by AUTOLOAD)
027dc388 61 } elsif ($f =~ /^f(nan|sstr|neg|floor|ceil|abs)$/) {
394e6ffb 62 $try .= "\$x->f$1();";
027dc388 63 # some is_xxx test function
b3abae2a 64 } elsif ($f =~ /^is_(zero|one|negative|positive|odd|even|nan|int)$/) {
027dc388 65 $try .= "\$x->$f();";
fdb4b05f 66 } elsif ($f eq "bpi") {
67 $try .= '$class->bpi($x);';
ee15d750 68 } elsif ($f eq "finc") {
69 $try .= '++$x;';
70 } elsif ($f eq "fdec") {
71 $try .= '--$x;';
72 }elsif ($f eq "fround") {
73 $try .= "$setup; \$x->fround($args[1]);";
74 } elsif ($f eq "ffround") {
75 $try .= "$setup; \$x->ffround($args[1]);";
76 } elsif ($f eq "fsqrt") {
77 $try .= "$setup; \$x->fsqrt();";
b3abae2a 78 } elsif ($f eq "ffac") {
79 $try .= "$setup; \$x->ffac();";
990fb837 80 } elsif ($f eq "flog") {
90d1b129 81 if (defined $args[1] && $args[1] ne '')
990fb837 82 {
83 $try .= "\$y = $class->new($args[1]);";
84 $try .= "$setup; \$x->flog(\$y);";
85 }
86 else
87 {
88 $try .= "$setup; \$x->flog();";
89 }
ee15d750 90 }
91 else
92 {
990fb837 93 $try .= "\$y = $class->new(\"$args[1]\");";
b68b7ab1 94
95 if ($f eq "bgcd")
96 {
97 if (defined $args[2])
98 {
99 $try .= " \$z = $class->new(\"$args[2]\"); ";
100 }
101 $try .= "$class\::bgcd(\$x, \$y";
102 $try .= ", \$z" if (defined $args[2]);
103 $try .= " );";
104 }
105 elsif ($f eq "blcm")
106 {
107 if (defined $args[2])
108 {
109 $try .= " \$z = $class->new(\"$args[2]\"); ";
110 }
111 $try .= "$class\::blcm(\$x, \$y";
112 $try .= ", \$z" if (defined $args[2]);
113 $try .= " );";
114 } elsif ($f eq "fcmp") {
a0ac753d 115 $try .= '$x->fcmp($y);';
ee15d750 116 } elsif ($f eq "facmp") {
117 $try .= '$x->facmp($y);';
118 } elsif ($f eq "fpow") {
119 $try .= '$x ** $y;';
50109ad0 120 } elsif ($f eq "bnok") {
121 $try .= '$x->bnok($y);';
990fb837 122 } elsif ($f eq "froot") {
123 $try .= "$setup; \$x->froot(\$y);";
ee15d750 124 } elsif ($f eq "fadd") {
125 $try .= '$x + $y;';
126 } elsif ($f eq "fsub") {
127 $try .= '$x - $y;';
128 } elsif ($f eq "fmul") {
129 $try .= '$x * $y;';
130 } elsif ($f eq "fdiv") {
131 $try .= "$setup; \$x / \$y;";
b3abae2a 132 } elsif ($f eq "fdiv-list") {
133 $try .= "$setup; join(',',\$x->fdiv(\$y));";
394e6ffb 134 } elsif ($f eq "frsft") {
135 $try .= '$x >> $y;';
136 } elsif ($f eq "flsft") {
137 $try .= '$x << $y;';
ee15d750 138 } elsif ($f eq "fmod") {
139 $try .= '$x % $y;';
140 } else { warn "Unknown op '$f'"; }
141 }
e745a66c 142 # print "# Trying: '$try'\n";
ee15d750 143 $ans1 = eval $try;
b68b7ab1 144 print "# Error: $@\n" if $@;
ee15d750 145 if ($ans =~ m|^/(.*)$|)
146 {
147 my $pat = $1;
148 if ($ans1 =~ /$pat/)
149 {
150 ok (1,1);
151 }
152 else
153 {
154 print "# '$try' expected: /$pat/ got: '$ans1'\n" if !ok(1,0);
155 }
156 }
157 else
158 {
159 if ($ans eq "")
160 {
161 ok_undef ($ans1);
162 }
163 else
164 {
165 print "# Tried: '$try'\n" if !ok ($ans1, $ans);
166 if (ref($ans1) eq "$class")
167 {
027dc388 168 # float numbers are normalized (for now), so mantissa shouldn't have
169 # trailing zeros
ee15d750 170 #print $ans1->_trailing_zeros(),"\n";
171 print "# Has trailing zeros after '$try'\n"
9b924220 172 if !ok ($CL->_zeros( $ans1->{_m}), 0);
ee15d750 173 }
174 }
175 } # end pattern or string
176 }
177 } # end while
178
394e6ffb 179# check whether $class->new( Math::BigInt->new()) destroys it
180# ($y == 12 in this case)
ee15d750 181$x = Math::BigInt->new(1200); $y = $class->new($x);
182ok ($y,1200); ok ($x,1200);
183
184###############################################################################
f9a08e12 185# Really huge, big, ultra-mega-biggy-monster exponents
186# Technically, the exponents should not be limited (they are BigInts), but
187# practically there are a few places were they are limited to a Perl scalar.
188# This is sometimes for speed, sometimes because otherwise the number wouldn't
189# fit into your memory (just think of 1e123456789012345678901234567890 + 1!)
190# anyway. We don't test everything here, but let's make sure it just basically
191# works.
192
193my $monster = '1e1234567890123456789012345678901234567890';
194
9b924220 195# new and exponent
56d9de68 196ok ($class->new($monster)->bsstr(),
197 '1e+1234567890123456789012345678901234567890');
9b924220 198ok ($class->new($monster)->exponent(),
199 '1234567890123456789012345678901234567890');
f9a08e12 200# cmp
201ok ($class->new($monster) > 0,1);
202
203# sub/mul
204ok ($class->new($monster)->bsub( $monster),0);
205ok ($class->new($monster)->bmul(2)->bsstr(),
206 '2e+1234567890123456789012345678901234567890');
207
9b924220 208# mantissa
209$monster = '1234567890123456789012345678901234567890e2';
210ok ($class->new($monster)->mantissa(),
211 '123456789012345678901234567890123456789');
212
f9a08e12 213###############################################################################
b3abae2a 214# zero,inf,one,nan
ee15d750 215
394e6ffb 216$x = $class->new(2); $x->fzero(); ok_undef ($x->{_a}); ok_undef ($x->{_p});
217$x = $class->new(2); $x->finf(); ok_undef ($x->{_a}); ok_undef ($x->{_p});
218$x = $class->new(2); $x->fone(); ok_undef ($x->{_a}); ok_undef ($x->{_p});
219$x = $class->new(2); $x->fnan(); ok_undef ($x->{_a}); ok_undef ($x->{_p});
56b9c951 220
221###############################################################################
222# bone/binf etc as plain calls (Lite failed them)
223
224ok ($class->fzero(),0);
225ok ($class->fone(),1);
226ok ($class->fone('+'),1);
227ok ($class->fone('-'),-1);
228ok ($class->fnan(),'NaN');
229ok ($class->finf(),'inf');
230ok ($class->finf('+'),'inf');
231ok ($class->finf('-'),'-inf');
232ok ($class->finf('-inf'),'-inf');
61f5c3f5 233
56d9de68 234$class->accuracy(undef); $class->precision(undef); # reset
235
236###############################################################################
237# bug in bsstr()/numify() showed up in after-rounding in bdiv()
238
239$x = $class->new('0.008'); $y = $class->new(2);
240$x->bdiv(3,$y);
241ok ($x,'0.0027');
242
61f5c3f5 243###############################################################################
244# fsqrt() with set global A/P or A/P enabled on $x, also a test whether fsqrt()
245# correctly modifies $x
246
61f5c3f5 247
248$x = $class->new(12); $class->precision(-2); $x->fsqrt(); ok ($x,'3.46');
249
250$class->precision(undef);
251$x = $class->new(12); $class->precision(0); $x->fsqrt(); ok ($x,'3');
252
253$class->precision(-3); $x = $class->new(12); $x->fsqrt(); ok ($x,'3.464');
254
56d9de68 255{
256 no strict 'refs';
257 # A and P set => NaN
258 ${${class}.'::accuracy'} = 4; $x = $class->new(12);
259 $x->fsqrt(3); ok ($x,'NaN');
260 # supplied arg overrides set global
261 $class->precision(undef); $x = $class->new(12); $x->fsqrt(3); ok ($x,'3.46');
262 $class->accuracy(undef); $class->precision(undef); # reset for further tests
263}
264
265#############################################################################
13a12e00 266# can we call objectify (broken until v1.52)
267
56d9de68 268{
269 no strict;
270 $try =
271 '@args' . " = $class" . "::objectify(2,$class,4,5);".'join(" ",@args);';
272 $ans = eval $try;
273 ok ($ans,"$class 4 5");
274}
f9a08e12 275
990fb837 276#############################################################################
277# is_one('-') (broken until v1.64)
278
279ok ($class->new(-1)->is_one(),0);
280ok ($class->new(-1)->is_one('-'),1);
281
27e7b8bb 282#############################################################################
283# bug 1/0.5 leaving 2e-0 instead of 2e0
284
285ok ($class->new(1)->fdiv('0.5')->bsstr(),'2e+0');
286
03874afe 287###############################################################################
288# [perl #30609] bug with $x -= $x not beeing 0, but 2*$x
289
290$x = $class->new(3); $x -= $x; ok ($x, 0);
291$x = $class->new(-3); $x -= $x; ok ($x, 0);
292$x = $class->new(3); $x += $x; ok ($x, 6);
293$x = $class->new(-3); $x += $x; ok ($x, -6);
294
295$x = $class->new('NaN'); $x -= $x; ok ($x->is_nan(), 1);
296$x = $class->new('inf'); $x -= $x; ok ($x->is_nan(), 1);
297$x = $class->new('-inf'); $x -= $x; ok ($x->is_nan(), 1);
298
299$x = $class->new('NaN'); $x += $x; ok ($x->is_nan(), 1);
300$x = $class->new('inf'); $x += $x; ok ($x->is_inf(), 1);
301$x = $class->new('-inf'); $x += $x; ok ($x->is_inf('-'), 1);
302
303$x = $class->new('3.14'); $x -= $x; ok ($x, 0);
304$x = $class->new('-3.14'); $x -= $x; ok ($x, 0);
305$x = $class->new('3.14'); $x += $x; ok ($x, '6.28');
306$x = $class->new('-3.14'); $x += $x; ok ($x, '-6.28');
307
308$x = $class->new('3.14'); $x *= $x; ok ($x, '9.8596');
309$x = $class->new('-3.14'); $x *= $x; ok ($x, '9.8596');
310$x = $class->new('3.14'); $x /= $x; ok ($x, '1');
311$x = $class->new('-3.14'); $x /= $x; ok ($x, '1');
312$x = $class->new('3.14'); $x %= $x; ok ($x, '0');
313$x = $class->new('-3.14'); $x %= $x; ok ($x, '0');
314
ae161977 315###############################################################################
316# the following two were reported by "kenny" via hotmail.com:
317
318#perl -MMath::BigFloat -wle 'print Math::BigFloat->new(0)->bpow(".1")'
319#Use of uninitialized value in numeric le (<=) at BigFloat.pm line 1851.
320
321$x = $class->new(0); $y = $class->new('0.1');
322ok ($x ** $y, 0, 'no warnings and zero result');
323
324#perl -MMath::BigFloat -lwe 'print Math::BigFloat->new(".222222222222222222222222222222222222222222")->bceil()'
325#Use of uninitialized value in numeric le (<=) at BigFloat.pm line 1851.
326
327$x = $class->new(".222222222222222222222222222222222222222222");
328ok ($x->bceil(), 1, 'no warnings and one as result');
329
2d2b2744 330###############################################################################
331# test **=, <<=, >>=
332
333# ((2^148)-1)/17
334$x = $class->new(2); $x **= 148; $x++; $x->bdiv(17, 60)->bfloor(); $x->accuracy(undef);
335ok ($x,"20988936657440586486151264256610222593863921");
336ok ($x->length(),length "20988936657440586486151264256610222593863921");
337
338$x = $class->new('2');
339my $y = $class->new('18');
340ok ($x <<= $y, 2 << 18);
341ok ($x, 2 << 18);
342ok ($x >>= $y, 2);
343ok ($x, 2);
344
345$x = $class->new('2');
346$y = $class->new('18.2');
347$x <<= $y; # 2 * (2 ** 18.2);
348
349ok ($x->copy()->bfround(-9), '602248.763144685');
350ok ($x >>= $y, 2); # 2 * (2 ** 18.2) / (2 ** 18.2) => 2
351ok ($x, 2);
352
394e6ffb 3531; # all done
ee15d750 354
355###############################################################################
356# Perl 5.005 does not like ok ($x,undef)
357
358sub ok_undef
359 {
360 my $x = shift;
361
362 ok (1,1) and return if !defined $x;
363 ok ($x,'undef');
364 }
365
366__DATA__
b68b7ab1 367&bgcd
368inf:12:NaN
369-inf:12:NaN
37012:inf:NaN
37112:-inf:NaN
372inf:inf:NaN
373inf:-inf:NaN
374-inf:-inf:NaN
375abc:abc:NaN
376abc:+0:NaN
377+0:abc:NaN
378+0:+0:0
379+0:+1:1
380+1:+0:1
381+1:+1:1
382+2:+3:1
383+3:+2:1
384-3:+2:1
385-3:-2:1
386-144:-60:12
387144:-60:12
388144:60:12
389100:625:25
3904096:81:1
3911034:804:2
39227:90:56:1
39327:90:54:9
394&blcm
395abc:abc:NaN
396abc:+0:NaN
397+0:abc:NaN
398+0:+0:NaN
399+1:+0:0
400+0:+1:0
401+27:+90:270
402+1034:+804:415668
b3abae2a 403$div_scale = 40;
fdb4b05f 404&bpi
40577:3.1415926535897932384626433832795028841971693993751058209749445923078164062862
406+0:3.141592653589793238462643383279502884197
40711:3.1415926535
50109ad0 408&bnok
409+inf:10:inf
410NaN:NaN:NaN
411NaN:1:NaN
4121:NaN:NaN
4131:1:1
414# k > n
4151:2:0
4162:3:0
417# k < 0
4181:-2:0
419# 7 over 3 = 35
4207:3:35
4217:6:1
422100:90:17310309456440
b3abae2a 423&flog
990fb837 4240::NaN
425-1::NaN
426-2::NaN
427# base > 0, base != 1
4282:-1:NaN
4292:0:NaN
4302:1:NaN
431# log(1) is always 1, regardless of $base
4321::0
4331:1:0
4341:2:0
90d1b129 4352::0.6931471805599453094172321214581765680755
4362.718281828::0.9999999998311266953289851340574956564911
437$div_scale = 20;
4382.718281828::0.99999999983112669533
439$div_scale = 15;
440123::4.81218435537242
44110::2.30258509299405
4421000::6.90775527898214
443100::4.60517018598809
4442::0.693147180559945
4453.1415::1.14470039286086
44612345::9.42100640177928
4470.001::-6.90775527898214
448# bug until v1.71:
44910:10:1
450100:100:1
b3abae2a 451# reset for further tests
452$div_scale = 40;
990fb837 4531::0
394e6ffb 454&frsft
b3abae2a 455NaNfrsft:2:NaN
394e6ffb 4560:2:0
4571:1:0.5
4582:1:1
4594:1:2
460123:1:61.5
46132:3:4
462&flsft
b3abae2a 463NaNflsft:0:NaN
394e6ffb 4642:1:4
4654:3:32
4665:3:40
4671:2:4
4680:5:0
ee15d750 469&fnorm
4701:1
471-0:0
472fnormNaN:NaN
473+inf:inf
474-inf:-inf
475123:123
476-123.4567:-123.4567
027dc388 477# invalid inputs
4781__2:NaN
4791E1__2:NaN
48011__2E2:NaN
027dc388 481.2E-3.:NaN
2d2b2744 4821e3e4:NaN
483# strange, but valid
027dc388 484.2E2:20
2d2b2744 4851.E3:1000
486# some inputs that result in zero
4870e0:0
488+0e0:0
489+0e+0:0
490-0e+0:0
4910e-0:0
492-0e-0:0
493+0e-0:0
494000:0
49500e2:0
49600e02:0
497000e002:0
498000e1230:0
49900e-3:0
50000e+3:0
50100e-03:0
50200e+03:0
503-000:0
504-00e2:0
505-00e02:0
506-000e002:0
507-000e1230:0
508-00e-3:0
509-00e+3:0
510-00e-03:0
511-00e+03:0
ee15d750 512&as_number
5130:0
5141:1
5151.2:1
5162.345:2
517-2:-2
518-123.456:-123
519-200:-200
56d9de68 520# test for bug in brsft() not handling cases that return 0
5210.000641:0
5220.0006412:0
5230.00064123:0
5240.000641234:0
5250.0006412345:0
5260.00064123456:0
5270.000641234567:0
5280.0006412345678:0
5290.00064123456789:0
5300.1:0
5310.01:0
5320.001:0
5330.0001:0
5340.00001:0
5350.000001:0
5360.0000001:0
5370.00000001:0
5380.000000001:0
5390.0000000001:0
5400.00000000001:0
990fb837 5410.12345:0
5420.123456:0
5430.1234567:0
5440.12345678:0
5450.123456789:0
ee15d750 546&finf
5471:+:inf
5482:-:-inf
5493:abc:inf
56d9de68 550&as_hex
551+inf:inf
552-inf:-inf
553hexNaN:NaN
5540:0x0
5555:0x5
556-5:-0x5
557&as_bin
558+inf:inf
559-inf:-inf
560hexNaN:NaN
5610:0b0
5625:0b101
563-5:-0b101
ee15d750 564&numify
56d9de68 565# uses bsstr() so 5 => 5e+0 to be compatible w/ Perls output
ee15d750 5660:0e+1
567+1:1e+0
5681234:1234e+0
569NaN:NaN
570+inf:inf
571-inf:-inf
56d9de68 572-5:-5e+0
573100:1e+2
574-100:-1e+2
ee15d750 575&fnan
576abc:NaN
5772:NaN
578-2:NaN
5790:NaN
580&fone
5812:+:1
582-2:-:-1
583-2:+:1
5842:-:-1
5850::1
586-2::1
587abc::1
5882:abc:1
589&fsstr
590+inf:inf
591-inf:-inf
592abcfsstr:NaN
56d9de68 593-abcfsstr:NaN
ee15d750 5941234.567:1234567e-3
56d9de68 595123:123e+0
596-5:-5e+0
597-100:-1e+2
ee15d750 598&fstr
599+inf:::inf
600-inf:::-inf
601abcfstr:::NaN
6021234.567:9::1234.56700
6031234.567::-6:1234.567000
60412345:5::12345
6050.001234:6::0.00123400
6060.001234::-8:0.00123400
6070:4::0
6080::-4:0.0000
609&fnorm
610inf:inf
611+inf:inf
612-inf:-inf
613+infinity:NaN
614+-inf:NaN
615abc:NaN
616 1 a:NaN
6171bcd2:NaN
61811111b:NaN
619+1z:NaN
620-1z:NaN
aef458a0 6210e999:0
6220e-999:0
623-0e999:0
624-0e-999:0
ee15d750 6250:0
626+0:0
627+00:0
628+0_0_0:0
629000000_0000000_00000:0
630-0:0
631-0000:0
632+1:1
633+01:1
634+001:1
635+00000100000:100000
636123456789:123456789
637-1:-1
638-01:-1
639-001:-1
640-123456789:-123456789
641-00000100000:-100000
642123.456a:NaN
643123.456:123.456
6440.01:0.01
645.002:0.002
646+.2:0.2
647-0.0003:-0.0003
648-.0000000004:-0.0000000004
649123456E2:12345600
650123456E-2:1234.56
651-123456E2:-12345600
652-123456E-2:-1234.56
6531e1:10
6542e-11:0.00000000002
655# excercise _split
656 .02e-1:0.002
657 000001:1
658 -00001:-1
659 -1:-1
660 000.01:0.01
661 -000.0023:-0.0023
662 1.1e1:11
663-3e111:-3000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
664-4e-1111:-0.0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000004
665&fpow
9b924220 666NaN:1:NaN
6671:NaN:NaN
668NaN:-1:NaN
669-1:NaN:NaN
670NaN:-21:NaN
671-21:NaN:NaN
672NaN:21:NaN
67321:NaN:NaN
6740:0:1
6750:1:0
6760:9:0
6770:-2:inf
ee15d750 6782:2:4
6791:2:1
6801:3:1
681-1:2:1
682-1:3:-1
683123.456:2:15241.383936
6842:-2:0.25
6852:-3:0.125
686128:-2:0.00006103515625
687abc:123.456:NaN
688123.456:abc:NaN
689+inf:123.45:inf
690-inf:123.45:-inf
691+inf:-123.45:inf
692-inf:-123.45:-inf
9b924220 693-2:2:4
694-2:3:-8
695-2:4:16
696-2:5:-32
697-3:2:9
698-3:3:-27
699-3:4:81
700-3:5:-243
79c55733 701# 2 ** 0.5 == sqrt(2)
702# 1.41..7 and not 1.4170 since fallback (bsqrt(9) is '3', not 3.0...0)
7032:0.5:1.41421356237309504880168872420969807857
56b9c951 704#2:0.2:1.148698354997035006798626946777927589444
07d34614 705#6:1.5:14.6969384566990685891837044482353483518
56b9c951 706$div_scale = 20;
707#62.5:12.5:26447206647554886213592.3959144
708$div_scale = 40;
ee15d750 709&fneg
710fnegNaN:NaN
711+inf:-inf
712-inf:inf
713+0:0
714+1:-1
715-1:1
716+123456789:-123456789
717-123456789:123456789
718+123.456789:-123.456789
719-123456.789:123456.789
720&fabs
721fabsNaN:NaN
722+inf:inf
723-inf:inf
724+0:0
725+1:1
726-1:1
727+123456789:123456789
728-123456789:123456789
729+123.456789:123.456789
730-123456.789:123456.789
731&fround
732$round_mode = "trunc"
733+inf:5:inf
734-inf:5:-inf
7350:5:0
736NaNfround:5:NaN
737+10123456789:5:10123000000
738-10123456789:5:-10123000000
739+10123456789.123:5:10123000000
740-10123456789.123:5:-10123000000
741+10123456789:9:10123456700
742-10123456789:9:-10123456700
743+101234500:6:101234000
744-101234500:6:-101234000
745$round_mode = "zero"
746+20123456789:5:20123000000
747-20123456789:5:-20123000000
748+20123456789.123:5:20123000000
749-20123456789.123:5:-20123000000
750+20123456789:9:20123456800
751-20123456789:9:-20123456800
752+201234500:6:201234000
753-201234500:6:-201234000
754$round_mode = "+inf"
755+30123456789:5:30123000000
756-30123456789:5:-30123000000
757+30123456789.123:5:30123000000
758-30123456789.123:5:-30123000000
759+30123456789:9:30123456800
760-30123456789:9:-30123456800
761+301234500:6:301235000
762-301234500:6:-301234000
763$round_mode = "-inf"
764+40123456789:5:40123000000
765-40123456789:5:-40123000000
766+40123456789.123:5:40123000000
767-40123456789.123:5:-40123000000
768+40123456789:9:40123456800
769-40123456789:9:-40123456800
770+401234500:6:401234000
771-401234500:6:-401235000
772$round_mode = "odd"
773+50123456789:5:50123000000
774-50123456789:5:-50123000000
775+50123456789.123:5:50123000000
776-50123456789.123:5:-50123000000
777+50123456789:9:50123456800
778-50123456789:9:-50123456800
779+501234500:6:501235000
780-501234500:6:-501235000
781$round_mode = "even"
782+60123456789:5:60123000000
783-60123456789:5:-60123000000
784+60123456789:9:60123456800
785-60123456789:9:-60123456800
786+601234500:6:601234000
787-601234500:6:-601234000
788+60123456789.0123:5:60123000000
789-60123456789.0123:5:-60123000000
7b29e1e6 790$round_mode = "common"
791+60123456789:5:60123000000
792-60123456789:5:-60123000000
793+60123456789:6:60123500000
794-60123456789:6:-60123500000
795+60123456789:9:60123456800
796-60123456789:9:-60123456800
797+601234500:6:601235000
798-601234500:6:-601235000
799+601234400:6:601234000
800-601234400:6:-601234000
801+601234600:6:601235000
802-601234600:6:-601235000
803+601234300:6:601234000
804+60123456789.0123:5:60123000000
805-60123456789.0123:5:-60123000000
ee15d750 806&ffround
807$round_mode = "trunc"
808+inf:5:inf
809-inf:5:-inf
8100:5:0
811NaNffround:5:NaN
812+1.23:-1:1.2
813+1.234:-1:1.2
814+1.2345:-1:1.2
815+1.23:-2:1.23
816+1.234:-2:1.23
817+1.2345:-2:1.23
818+1.23:-3:1.230
819+1.234:-3:1.234
820+1.2345:-3:1.234
821-1.23:-1:-1.2
822+1.27:-1:1.2
823-1.27:-1:-1.2
824+1.25:-1:1.2
825-1.25:-1:-1.2
826+1.35:-1:1.3
827-1.35:-1:-1.3
828-0.0061234567890:-1:0.0
829-0.0061:-1:0.0
830-0.00612:-1:0.0
831-0.00612:-2:0.00
832-0.006:-1:0.0
833-0.006:-2:0.00
834-0.0006:-2:0.00
835-0.0006:-3:0.000
836-0.0065:-3:/-0\.006|-6e-03
837-0.0065:-4:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
838-0.0065:-5:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
8390.05:0:0
8400.5:0:0
8410.51:0:0
8420.41:0:0
843$round_mode = "zero"
844+2.23:-1:/2.2(?:0{5}\d+)?
845-2.23:-1:/-2.2(?:0{5}\d+)?
846+2.27:-1:/2.(?:3|29{5}\d+)
847-2.27:-1:/-2.(?:3|29{5}\d+)
848+2.25:-1:/2.2(?:0{5}\d+)?
849-2.25:-1:/-2.2(?:0{5}\d+)?
850+2.35:-1:/2.(?:3|29{5}\d+)
851-2.35:-1:/-2.(?:3|29{5}\d+)
852-0.0065:-1:0.0
853-0.0065:-2:/-0\.01|-1e-02
854-0.0065:-3:/-0\.006|-6e-03
855-0.0065:-4:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
856-0.0065:-5:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
8570.05:0:0
8580.5:0:0
8590.51:0:1
8600.41:0:0
861$round_mode = "+inf"
862+3.23:-1:/3.2(?:0{5}\d+)?
863-3.23:-1:/-3.2(?:0{5}\d+)?
864+3.27:-1:/3.(?:3|29{5}\d+)
865-3.27:-1:/-3.(?:3|29{5}\d+)
866+3.25:-1:/3.(?:3|29{5}\d+)
867-3.25:-1:/-3.2(?:0{5}\d+)?
868+3.35:-1:/3.(?:4|39{5}\d+)
869-3.35:-1:/-3.(?:3|29{5}\d+)
870-0.0065:-1:0.0
871-0.0065:-2:/-0\.01|-1e-02
872-0.0065:-3:/-0\.006|-6e-03
873-0.0065:-4:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
874-0.0065:-5:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
8750.05:0:0
8760.5:0:1
8770.51:0:1
8780.41:0:0
879$round_mode = "-inf"
880+4.23:-1:/4.2(?:0{5}\d+)?
881-4.23:-1:/-4.2(?:0{5}\d+)?
882+4.27:-1:/4.(?:3|29{5}\d+)
883-4.27:-1:/-4.(?:3|29{5}\d+)
884+4.25:-1:/4.2(?:0{5}\d+)?
885-4.25:-1:/-4.(?:3|29{5}\d+)
886+4.35:-1:/4.(?:3|29{5}\d+)
887-4.35:-1:/-4.(?:4|39{5}\d+)
888-0.0065:-1:0.0
889-0.0065:-2:/-0\.01|-1e-02
890-0.0065:-3:/-0\.007|-7e-03
891-0.0065:-4:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
892-0.0065:-5:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
8930.05:0:0
8940.5:0:0
8950.51:0:1
8960.41:0:0
897$round_mode = "odd"
898+5.23:-1:/5.2(?:0{5}\d+)?
899-5.23:-1:/-5.2(?:0{5}\d+)?
900+5.27:-1:/5.(?:3|29{5}\d+)
901-5.27:-1:/-5.(?:3|29{5}\d+)
902+5.25:-1:/5.(?:3|29{5}\d+)
903-5.25:-1:/-5.(?:3|29{5}\d+)
904+5.35:-1:/5.(?:3|29{5}\d+)
905-5.35:-1:/-5.(?:3|29{5}\d+)
906-0.0065:-1:0.0
907-0.0065:-2:/-0\.01|-1e-02
908-0.0065:-3:/-0\.007|-7e-03
909-0.0065:-4:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
910-0.0065:-5:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
9110.05:0:0
9120.5:0:1
9130.51:0:1
9140.41:0:0
915$round_mode = "even"
916+6.23:-1:/6.2(?:0{5}\d+)?
917-6.23:-1:/-6.2(?:0{5}\d+)?
918+6.27:-1:/6.(?:3|29{5}\d+)
919-6.27:-1:/-6.(?:3|29{5}\d+)
920+6.25:-1:/6.(?:2(?:0{5}\d+)?|29{5}\d+)
921-6.25:-1:/-6.(?:2(?:0{5}\d+)?|29{5}\d+)
922+6.35:-1:/6.(?:4|39{5}\d+|29{8}\d+)
923-6.35:-1:/-6.(?:4|39{5}\d+|29{8}\d+)
924-0.0065:-1:0.0
925-0.0065:-2:/-0\.01|-1e-02
926-0.0065:-3:/-0\.006|-7e-03
927-0.0065:-4:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
928-0.0065:-5:/-0\.006(?:5|49{5}\d+)|-6\.5e-03
9290.05:0:0
9300.5:0:0
9310.51:0:1
9320.41:0:0
9330.01234567:-3:0.012
9340.01234567:-4:0.0123
9350.01234567:-5:0.01235
9360.01234567:-6:0.012346
9370.01234567:-7:0.0123457
9380.01234567:-8:0.01234567
9390.01234567:-9:0.012345670
9400.01234567:-12:0.012345670000
941&fcmp
942fcmpNaN:fcmpNaN:
943fcmpNaN:+0:
944+0:fcmpNaN:
945+0:+0:0
946-1:+0:-1
947+0:-1:1
948+1:+0:1
949+0:+1:-1
950-1:+1:-1
951+1:-1:1
952-1:-1:0
953+1:+1:0
954-1.1:0:-1
955+0:-1.1:1
956+1.1:+0:1
957+0:+1.1:-1
958+123:+123:0
959+123:+12:1
960+12:+123:-1
961-123:-123:0
962-123:-12:-1
963-12:-123:1
964+123:+124:-1
965+124:+123:1
966-123:-124:1
967-124:-123:-1
9680:0.01:-1
9690:0.0001:-1
9700:-0.0001:1
9710:-0.1:1
9720.1:0:1
9730.00001:0:1
974-0.0001:0:-1
975-0.1:0:-1
9760:0.0001234:-1
9770:-0.0001234:1
9780.0001234:0:1
979-0.0001234:0:-1
9800.0001:0.0005:-1
9810.0005:0.0001:1
9820.005:0.0001:1
9830.001:0.0005:1
9840.000001:0.0005:-1
9850.00000123:0.0005:-1
9860.00512:0.0001:1
9870.005:0.000112:1
9880.00123:0.0005:1
9891.5:2:-1
9902:1.5:1
9911.54321:234:-1
992234:1.54321:1
993# infinity
994-inf:5432112345:-1
995+inf:5432112345:1
996-inf:-5432112345:-1
997+inf:-5432112345:1
998-inf:54321.12345:-1
999+inf:54321.12345:1
1000-inf:-54321.12345:-1
1001+inf:-54321.12345:1
1002+inf:+inf:0
1003-inf:-inf:0
1004+inf:-inf:1
1005-inf:+inf:-1
1006# return undef
1007+inf:NaN:
1008NaN:inf:
1009-inf:NaN:
1010NaN:-inf:
1011&facmp
1012fcmpNaN:fcmpNaN:
1013fcmpNaN:+0:
1014+0:fcmpNaN:
1015+0:+0:0
1016-1:+0:1
1017+0:-1:-1
1018+1:+0:1
1019+0:+1:-1
1020-1:+1:0
1021+1:-1:0
1022-1:-1:0
1023+1:+1:0
1024-1.1:0:1
1025+0:-1.1:-1
1026+1.1:+0:1
1027+0:+1.1:-1
1028+123:+123:0
1029+123:+12:1
1030+12:+123:-1
1031-123:-123:0
1032-123:-12:1
1033-12:-123:-1
1034+123:+124:-1
1035+124:+123:1
1036-123:-124:-1
1037-124:-123:1
10380:0.01:-1
10390:0.0001:-1
10400:-0.0001:-1
10410:-0.1:-1
10420.1:0:1
10430.00001:0:1
1044-0.0001:0:1
1045-0.1:0:1
10460:0.0001234:-1
10470:-0.0001234:-1
10480.0001234:0:1
1049-0.0001234:0:1
10500.0001:0.0005:-1
10510.0005:0.0001:1
10520.005:0.0001:1
10530.001:0.0005:1
10540.000001:0.0005:-1
10550.00000123:0.0005:-1
10560.00512:0.0001:1
10570.005:0.000112:1
10580.00123:0.0005:1
10591.5:2:-1
10602:1.5:1
10611.54321:234:-1
1062234:1.54321:1
1063# infinity
1064-inf:5432112345:1
1065+inf:5432112345:1
1066-inf:-5432112345:1
1067+inf:-5432112345:1
1068-inf:54321.12345:1
1069+inf:54321.12345:1
1070-inf:-54321.12345:1
1071+inf:-54321.12345:1
1072+inf:+inf:0
1073-inf:-inf:0
1074+inf:-inf:0
1075-inf:+inf:0
48b581a2 10765:inf:-1
1077-1:inf:-1
10785:-inf:-1
1079-1:-inf:-1
ee15d750 1080# return undef
1081+inf:facmpNaN:
1082facmpNaN:inf:
1083-inf:facmpNaN:
1084facmpNaN:-inf:
1085&fdec
1086fdecNaN:NaN
1087+inf:inf
1088-inf:-inf
1089+0:-1
1090+1:0
1091-1:-2
10921.23:0.23
1093-1.23:-2.23
e745a66c 1094100:99
1095101:100
1096-100:-101
1097-99:-100
1098-98:-99
109999:98
ee15d750 1100&finc
1101fincNaN:NaN
1102+inf:inf
1103-inf:-inf
1104+0:1
1105+1:2
1106-1:0
11071.23:2.23
1108-1.23:-0.23
e745a66c 1109100:101
1110-100:-99
1111-99:-98
1112-101:-100
111399:100
ee15d750 1114&fadd
1115abc:abc:NaN
1116abc:+0:NaN
1117+0:abc:NaN
13a12e00 1118+inf:-inf:NaN
1119-inf:+inf:NaN
ee15d750 1120+inf:+inf:inf
1121-inf:-inf:-inf
1122baddNaN:+inf:NaN
1123baddNaN:+inf:NaN
1124+inf:baddNaN:NaN
1125-inf:baddNaN:NaN
1126+0:+0:0
1127+1:+0:1
1128+0:+1:1
1129+1:+1:2
1130-1:+0:-1
1131+0:-1:-1
1132-1:-1:-2
1133-1:+1:0
1134+1:-1:0
1135+9:+1:10
1136+99:+1:100
1137+999:+1:1000
1138+9999:+1:10000
1139+99999:+1:100000
1140+999999:+1:1000000
1141+9999999:+1:10000000
1142+99999999:+1:100000000
1143+999999999:+1:1000000000
1144+9999999999:+1:10000000000
1145+99999999999:+1:100000000000
1146+10:-1:9
1147+100:-1:99
1148+1000:-1:999
1149+10000:-1:9999
1150+100000:-1:99999
1151+1000000:-1:999999
1152+10000000:-1:9999999
1153+100000000:-1:99999999
1154+1000000000:-1:999999999
1155+10000000000:-1:9999999999
1156+123456789:+987654321:1111111110
1157-123456789:+987654321:864197532
1158-123456789:-987654321:-1111111110
1159+123456789:-987654321:-864197532
11600.001234:0.0001234:0.0013574
1161&fsub
1162abc:abc:NaN
1163abc:+0:NaN
1164+0:abc:NaN
1165+inf:-inf:inf
1166-inf:+inf:-inf
13a12e00 1167+inf:+inf:NaN
1168-inf:-inf:NaN
ee15d750 1169baddNaN:+inf:NaN
1170baddNaN:+inf:NaN
1171+inf:baddNaN:NaN
1172-inf:baddNaN:NaN
1173+0:+0:0
1174+1:+0:1
1175+0:+1:-1
1176+1:+1:0
1177-1:+0:-1
1178+0:-1:1
1179-1:-1:0
1180-1:+1:-2
1181+1:-1:2
1182+9:+1:8
1183+99:+1:98
1184+999:+1:998
1185+9999:+1:9998
1186+99999:+1:99998
1187+999999:+1:999998
1188+9999999:+1:9999998
1189+99999999:+1:99999998
1190+999999999:+1:999999998
1191+9999999999:+1:9999999998
1192+99999999999:+1:99999999998
1193+10:-1:11
1194+100:-1:101
1195+1000:-1:1001
1196+10000:-1:10001
1197+100000:-1:100001
1198+1000000:-1:1000001
1199+10000000:-1:10000001
1200+100000000:-1:100000001
1201+1000000000:-1:1000000001
1202+10000000000:-1:10000000001
1203+123456789:+987654321:-864197532
1204-123456789:+987654321:-1111111110
1205-123456789:-987654321:864197532
1206+123456789:-987654321:1111111110
1207&fmul
1208abc:abc:NaN
1209abc:+0:NaN
1210+0:abc:NaN
1211+inf:NaNmul:NaN
1212+inf:NaNmul:NaN
1213NaNmul:+inf:NaN
1214NaNmul:-inf:NaN
1215+inf:+inf:inf
1216+inf:-inf:-inf
1217+inf:-inf:-inf
1218+inf:+inf:inf
1219+inf:123.34:inf
1220+inf:-123.34:-inf
1221-inf:123.34:-inf
1222-inf:-123.34:inf
1223123.34:+inf:inf
1224-123.34:+inf:-inf
1225123.34:-inf:-inf
1226-123.34:-inf:inf
1227+0:+0:0
1228+0:+1:0
1229+1:+0:0
1230+0:-1:0
1231-1:+0:0
1232+123456789123456789:+0:0
1233+0:+123456789123456789:0
1234-1:-1:1
1235-1:+1:-1
1236+1:-1:-1
1237+1:+1:1
1238+2:+3:6
1239-2:+3:-6
1240+2:-3:-6
1241-2:-3:6
1242+111:+111:12321
1243+10101:+10101:102030201
1244+1001001:+1001001:1002003002001
1245+100010001:+100010001:10002000300020001
1246+10000100001:+10000100001:100002000030000200001
1247+11111111111:+9:99999999999
1248+22222222222:+9:199999999998
1249+33333333333:+9:299999999997
1250+44444444444:+9:399999999996
1251+55555555555:+9:499999999995
1252+66666666666:+9:599999999994
1253+77777777777:+9:699999999993
1254+88888888888:+9:799999999992
1255+99999999999:+9:899999999991
12566:120:720
125710:10000:100000
b3abae2a 1258&fdiv-list
12590:0:NaN,NaN
12600:1:0,0
12619:4:2.25,1
12629:5:1.8,4
233f7bc0 1263# bug in v1.74 with bdiv in list context, when $y is 1 or -1
12642.1:-1:-2.1,0
12652.1:1:2.1,0
1266-2.1:-1:2.1,0
1267-2.1:1:-2.1,0
ee15d750 1268&fdiv
1269$div_scale = 40; $round_mode = 'even'
1270abc:abc:NaN
1271abc:+1:abc:NaN
1272+1:abc:NaN
1273-1:abc:NaN
12740:abc:NaN
1275+0:+0:NaN
1276+0:+1:0
1277+1:+0:inf
1278+3214:+0:inf
1279+0:-1:0
1280-1:+0:-inf
1281-3214:+0:-inf
1282+1:+1:1
1283-1:-1:1
1284+1:-1:-1
1285-1:+1:-1
1286+1:+2:0.5
1287+2:+1:2
1288123:+inf:0
1289123:-inf:0
1290+10:+5:2
1291+100:+4:25
1292+1000:+8:125
1293+10000:+16:625
1294+10000:-16:-625
1295+999999999999:+9:111111111111
1296+999999999999:+99:10101010101
1297+999999999999:+999:1001001001
1298+999999999999:+9999:100010001
1299+999999999999999:+99999:10000100001
1300+1000000000:+9:111111111.1111111111111111111111111111111
1301+2000000000:+9:222222222.2222222222222222222222222222222
1302+3000000000:+9:333333333.3333333333333333333333333333333
1303+4000000000:+9:444444444.4444444444444444444444444444444
1304+5000000000:+9:555555555.5555555555555555555555555555556
1305+6000000000:+9:666666666.6666666666666666666666666666667
1306+7000000000:+9:777777777.7777777777777777777777777777778
1307+8000000000:+9:888888888.8888888888888888888888888888889
1308+9000000000:+9:1000000000
1309+35500000:+113:314159.2920353982300884955752212389380531
1310+71000000:+226:314159.2920353982300884955752212389380531
1311+106500000:+339:314159.2920353982300884955752212389380531
1312+1000000000:+3:333333333.3333333333333333333333333333333
13132:25.024996000799840031993601279744051189762:0.07992009269196593320152084692285869265447
394e6ffb 1314123456:1:123456
ee15d750 1315$div_scale = 20
1316+1000000000:+9:111111111.11111111111
1317+2000000000:+9:222222222.22222222222
1318+3000000000:+9:333333333.33333333333
1319+4000000000:+9:444444444.44444444444
1320+5000000000:+9:555555555.55555555556
1321+6000000000:+9:666666666.66666666667
1322+7000000000:+9:777777777.77777777778
1323+8000000000:+9:888888888.88888888889
1324+9000000000:+9:1000000000
13251:10:0.1
13261:100:0.01
13271:1000:0.001
13281:10000:0.0001
13291:504:0.001984126984126984127
13302:1.987654321:1.0062111801179738436
394e6ffb 1331123456789.123456789123456789123456789:1:123456789.12345678912
ee15d750 1332# the next two cases are the "old" behaviour, but are now (>v0.01) different
1333#+35500000:+113:314159.292035398230088
1334#+71000000:+226:314159.292035398230088
1335+35500000:+113:314159.29203539823009
1336+71000000:+226:314159.29203539823009
1337+106500000:+339:314159.29203539823009
1338+1000000000:+3:333333333.33333333333
1339$div_scale = 1
1340# round to accuracy 1 after bdiv
1341+124:+3:40
394e6ffb 1342123456789.1234:1:100000000
ee15d750 1343# reset scale for further tests
1344$div_scale = 40
1345&fmod
61f5c3f5 1346+9:4:1
1347+9:5:4
1348+9000:56:40
1349+56:9000:56
1350# inf handling, see table in doc
13510:inf:0
13520:-inf:0
13535:inf:5
13545:-inf:5
1355-5:inf:-5
1356-5:-inf:-5
1357inf:5:0
1358-inf:5:0
1359inf:-5:0
1360-inf:-5:0
13615:5:0
1362-5:-5:0
b3abae2a 1363inf:inf:NaN
1364-inf:-inf:NaN
1365-inf:inf:NaN
1366inf:-inf:NaN
61f5c3f5 13678:0:8
1368inf:0:inf
1369# exceptions to reminder rule
1370-inf:0:-inf
1371-8:0:-8
13720:0:NaN
1373abc:abc:NaN
1374abc:1:abc:NaN
13751:abc:NaN
13760:0:NaN
13770:1:0
13781:0:1
13790:-1:0
1380-1:0:-1
13811:1:0
1382-1:-1:0
13831:-1:0
1384-1:1:0
13851:2:1
13862:1:0
13871000000000:9:1
13882000000000:9:2
13893000000000:9:3
13904000000000:9:4
13915000000000:9:5
13926000000000:9:6
13937000000000:9:7
13948000000000:9:8
13959000000000:9:0
139635500000:113:33
139771000000:226:66
1398106500000:339:99
13991000000000:3:1
140010:5:0
1401100:4:0
14021000:8:0
140310000:16:0
1404999999999999:9:0
1405999999999999:99:0
1406999999999999:999:0
1407999999999999:9999:0
1408999999999999999:99999:0
1409-9:+5:1
1410+9:-5:-1
1411-9:-5:-4
1412-5:3:1
1413-2:3:1
14144:3:1
14151:3:1
1416-5:-3:-2
1417-2:-3:-2
14184:-3:-2
14191:-3:-2
14204095:4095:0
1421100041000510123:3:0
1422152403346:12345:4321
142387654321:87654321:0
1424# now some floating point tests
1425123:2.5:0.5
14261230:2.5:0
1427123.4:2.5:0.9
1428123e1:25:5
7596a890 1429-2.1:1:0.9
14302.1:1:0.1
1431-2.1:-1:-0.1
14322.1:-1:-0.9
233f7bc0 1433-3:1:0
14343:1:0
1435-3:-1:0
14363:-1:0
b3abae2a 1437&ffac
1438Nanfac:NaN
1439-1:NaN
b282a552 1440+inf:inf
091c87b1 1441-inf:NaN
b3abae2a 14420:1
14431:1
14442:2
14453:6
14464:24
14475:120
14486:720
144910:3628800
145011:39916800
145112:479001600
990fb837 1452&froot
1453# sqrt()
1454+0:2:0
1455+1:2:1
1456-1:2:NaN
1457# -$x ** (1/2) => -$y, but not in froot()
1458-123.456:2:NaN
1459+inf:2:inf
1460-inf:2:NaN
14612:2:1.41421356237309504880168872420969807857
1462-2:2:NaN
14634:2:2
14649:2:3
146516:2:4
1466100:2:10
1467123.456:2:11.11107555549866648462149404118219234119
146815241.38393:2:123.4559999756998444766131352122991626468
14691.44:2:1.2
147012:2:3.464101615137754587054892683011744733886
14710.49:2:0.7
14720.0049:2:0.07
1473# invalid ones
14741:NaN:NaN
1475-1:NaN:NaN
14760:NaN:NaN
1477-inf:NaN:NaN
1478+inf:NaN:NaN
1479NaN:0:NaN
1480NaN:2:NaN
1481NaN:inf:NaN
1482NaN:inf:NaN
148312:-inf:NaN
148412:inf:NaN
1485+0:0:NaN
1486+1:0:NaN
1487-1:0:NaN
1488-2:0:NaN
1489-123.45:0:NaN
1490+inf:0:NaN
149112:1:12
1492-12:1:NaN
14938:-1:NaN
1494-8:-1:NaN
1495# cubic root
14968:3:2
1497-8:3:NaN
1498# fourths root
149916:4:2
150081:4:3
3a427a11 1501# see t/bigroot() for more tests
ee15d750 1502&fsqrt
1503+0:0
1504-1:NaN
1505-2:NaN
1506-16:NaN
1507-123.45:NaN
1508nanfsqrt:NaN
1509+inf:inf
1510-inf:NaN
394e6ffb 15111:1
15122:1.41421356237309504880168872420969807857
15134:2
15149:3
151516:4
1516100:10
1517123.456:11.11107555549866648462149404118219234119
151815241.38393:123.4559999756998444766131352122991626468
15191.44:1.2
1520# sqrt(1.44) = 1.2, sqrt(e10) = e5 => 12e4
15211.44E10:120000
15222e10:141421.356237309504880168872420969807857
b3abae2a 1523144e20:120000000000
61f5c3f5 1524# proved to be an endless loop under 7-9
152512:3.464101615137754587054892683011744733886
990fb837 15260.49:0.7
15270.0049:0.07
027dc388 1528&is_nan
1529123:0
1530abc:1
1531NaN:1
1532-123:0
1533&is_inf
1534+inf::1
1535-inf::1
1536abc::0
15371::0
1538NaN::0
1539-1::0
1540+inf:-:0
1541+inf:+:1
1542-inf:-:1
1543-inf:+:0
1544# it must be exactly /^[+-]inf$/
1545+infinity::0
1546-infinity::0
ee15d750 1547&is_odd
1548abc:0
15490:0
1550-1:1
1551-3:1
15521:1
15533:1
15541000001:1
15551000002:0
1556+inf:0
1557-inf:0
1558123.45:0
1559-123.45:0
15602:0
b3abae2a 1561&is_int
1562NaNis_int:0
15630:1
15641:1
15652:1
1566-2:1
1567-1:1
1568-inf:0
1569+inf:0
1570123.4567:0
1571-0.1:0
1572-0.002:0
ee15d750 1573&is_even
1574abc:0
15750:1
1576-1:0
1577-3:0
15781:0
15793:0
15801000001:0
15811000002:1
15822:1
1583+inf:0
1584-inf:0
1585123.456:0
1586-123.456:0
b3abae2a 15870.01:0
1588-0.01:0
1589120:1
15901200:1
1591-1200:1
ee15d750 1592&is_positive
b68b7ab1 15930:0
ee15d750 15941:1
1595-1:0
1596-123:0
1597NaN:0
1598-inf:0
1599+inf:1
1600&is_negative
16010:0
16021:0
1603-1:1
1604-123:1
1605NaN:0
1606-inf:1
1607+inf:0
1608&parts
16090:0 1
16101:1 0
1611123:123 0
1612-123:-123 0
1613-1200:-12 2
1614NaNparts:NaN NaN
1615+inf:inf inf
1616-inf:-inf inf
1617&exponent
16180:1
16191:0
1620123:0
1621-123:0
1622-1200:2
1623+inf:inf
1624-inf:inf
1625NaNexponent:NaN
1626&mantissa
16270:0
16281:1
1629123:123
1630-123:-123
1631-1200:-12
1632+inf:inf
1633-inf:-inf
1634NaNmantissa:NaN
1635&length
1636123:3
1637-123:3
16380:1
16391:1
164012345678901234567890:20
1641&is_zero
1642NaNzero:0
1643+inf:0
1644-inf:0
16450:1
1646-1:0
16471:0
1648&is_one
1649NaNone:0
1650+inf:0
1651-inf:0
16520:0
16532:0
16541:1
1655-1:0
1656-2:0
027dc388 1657&ffloor
ee15d750 16580:0
1659abc:NaN
1660+inf:inf
1661-inf:-inf
16621:1
1663-51:-51
1664-51.2:-52
166512.2:12
990fb837 16660.12345:0
16670.123456:0
16680.1234567:0
16690.12345678:0
16700.123456789:0
027dc388 1671&fceil
ee15d750 16720:0
1673abc:NaN
1674+inf:inf
1675-inf:-inf
16761:1
1677-51:-51
1678-51.2:-51
167912.2:13