Commit | Line | Data |
ee15d750 |
1 | #include this file into another test for subclass testing... |
b3abae2a |
2 | |
3 | ok ($class->config()->{lib},$CL); |
4 | |
56d9de68 |
5 | use strict; |
6 | |
b68b7ab1 |
7 | my $z; |
8 | |
ee15d750 |
9 | while (<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); |
182 | ok ($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 | |
193 | my $monster = '1e1234567890123456789012345678901234567890'; |
194 | |
9b924220 |
195 | # new and exponent |
56d9de68 |
196 | ok ($class->new($monster)->bsstr(), |
197 | '1e+1234567890123456789012345678901234567890'); |
9b924220 |
198 | ok ($class->new($monster)->exponent(), |
199 | '1234567890123456789012345678901234567890'); |
f9a08e12 |
200 | # cmp |
201 | ok ($class->new($monster) > 0,1); |
202 | |
203 | # sub/mul |
204 | ok ($class->new($monster)->bsub( $monster),0); |
205 | ok ($class->new($monster)->bmul(2)->bsstr(), |
206 | '2e+1234567890123456789012345678901234567890'); |
207 | |
9b924220 |
208 | # mantissa |
209 | $monster = '1234567890123456789012345678901234567890e2'; |
210 | ok ($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 | |
224 | ok ($class->fzero(),0); |
225 | ok ($class->fone(),1); |
226 | ok ($class->fone('+'),1); |
227 | ok ($class->fone('-'),-1); |
228 | ok ($class->fnan(),'NaN'); |
229 | ok ($class->finf(),'inf'); |
230 | ok ($class->finf('+'),'inf'); |
231 | ok ($class->finf('-'),'-inf'); |
232 | ok ($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); |
241 | ok ($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 | |
279 | ok ($class->new(-1)->is_one(),0); |
280 | ok ($class->new(-1)->is_one('-'),1); |
281 | |
27e7b8bb |
282 | ############################################################################# |
283 | # bug 1/0.5 leaving 2e-0 instead of 2e0 |
284 | |
285 | ok ($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'); |
322 | ok ($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"); |
328 | ok ($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); |
335 | ok ($x,"20988936657440586486151264256610222593863921"); |
336 | ok ($x->length(),length "20988936657440586486151264256610222593863921"); |
337 | |
338 | $x = $class->new('2'); |
339 | my $y = $class->new('18'); |
340 | ok ($x <<= $y, 2 << 18); |
341 | ok ($x, 2 << 18); |
342 | ok ($x >>= $y, 2); |
343 | ok ($x, 2); |
344 | |
345 | $x = $class->new('2'); |
346 | $y = $class->new('18.2'); |
347 | $x <<= $y; # 2 * (2 ** 18.2); |
348 | |
349 | ok ($x->copy()->bfround(-9), '602248.763144685'); |
350 | ok ($x >>= $y, 2); # 2 * (2 ** 18.2) / (2 ** 18.2) => 2 |
351 | ok ($x, 2); |
352 | |
394e6ffb |
353 | 1; # all done |
ee15d750 |
354 | |
355 | ############################################################################### |
356 | # Perl 5.005 does not like ok ($x,undef) |
357 | |
358 | sub 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 |
368 | inf:12:NaN |
369 | -inf:12:NaN |
370 | 12:inf:NaN |
371 | 12:-inf:NaN |
372 | inf:inf:NaN |
373 | inf:-inf:NaN |
374 | -inf:-inf:NaN |
375 | abc:abc:NaN |
376 | abc:+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 |
387 | 144:-60:12 |
388 | 144:60:12 |
389 | 100:625:25 |
390 | 4096:81:1 |
391 | 1034:804:2 |
392 | 27:90:56:1 |
393 | 27:90:54:9 |
394 | &blcm |
395 | abc:abc:NaN |
396 | abc:+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 |
405 | 77:3.1415926535897932384626433832795028841971693993751058209749445923078164062862 |
406 | +0:3.141592653589793238462643383279502884197 |
407 | 11:3.1415926535 |
50109ad0 |
408 | &bnok |
409 | +inf:10:inf |
410 | NaN:NaN:NaN |
411 | NaN:1:NaN |
412 | 1:NaN:NaN |
413 | 1:1:1 |
414 | # k > n |
415 | 1:2:0 |
416 | 2:3:0 |
417 | # k < 0 |
418 | 1:-2:0 |
419 | # 7 over 3 = 35 |
420 | 7:3:35 |
421 | 7:6:1 |
422 | 100:90:17310309456440 |
b3abae2a |
423 | &flog |
990fb837 |
424 | 0::NaN |
425 | -1::NaN |
426 | -2::NaN |
427 | # base > 0, base != 1 |
428 | 2:-1:NaN |
429 | 2:0:NaN |
430 | 2:1:NaN |
431 | # log(1) is always 1, regardless of $base |
432 | 1::0 |
433 | 1:1:0 |
434 | 1:2:0 |
90d1b129 |
435 | 2::0.6931471805599453094172321214581765680755 |
436 | 2.718281828::0.9999999998311266953289851340574956564911 |
437 | $div_scale = 20; |
438 | 2.718281828::0.99999999983112669533 |
439 | $div_scale = 15; |
440 | 123::4.81218435537242 |
441 | 10::2.30258509299405 |
442 | 1000::6.90775527898214 |
443 | 100::4.60517018598809 |
444 | 2::0.693147180559945 |
445 | 3.1415::1.14470039286086 |
446 | 12345::9.42100640177928 |
447 | 0.001::-6.90775527898214 |
448 | # bug until v1.71: |
449 | 10:10:1 |
450 | 100:100:1 |
b3abae2a |
451 | # reset for further tests |
452 | $div_scale = 40; |
990fb837 |
453 | 1::0 |
394e6ffb |
454 | &frsft |
b3abae2a |
455 | NaNfrsft:2:NaN |
394e6ffb |
456 | 0:2:0 |
457 | 1:1:0.5 |
458 | 2:1:1 |
459 | 4:1:2 |
460 | 123:1:61.5 |
461 | 32:3:4 |
462 | &flsft |
b3abae2a |
463 | NaNflsft:0:NaN |
394e6ffb |
464 | 2:1:4 |
465 | 4:3:32 |
466 | 5:3:40 |
467 | 1:2:4 |
468 | 0:5:0 |
ee15d750 |
469 | &fnorm |
470 | 1:1 |
471 | -0:0 |
472 | fnormNaN:NaN |
473 | +inf:inf |
474 | -inf:-inf |
475 | 123:123 |
476 | -123.4567:-123.4567 |
027dc388 |
477 | # invalid inputs |
478 | 1__2:NaN |
479 | 1E1__2:NaN |
480 | 11__2E2:NaN |
027dc388 |
481 | .2E-3.:NaN |
2d2b2744 |
482 | 1e3e4:NaN |
483 | # strange, but valid |
027dc388 |
484 | .2E2:20 |
2d2b2744 |
485 | 1.E3:1000 |
486 | # some inputs that result in zero |
487 | 0e0:0 |
488 | +0e0:0 |
489 | +0e+0:0 |
490 | -0e+0:0 |
491 | 0e-0:0 |
492 | -0e-0:0 |
493 | +0e-0:0 |
494 | 000:0 |
495 | 00e2:0 |
496 | 00e02:0 |
497 | 000e002:0 |
498 | 000e1230:0 |
499 | 00e-3:0 |
500 | 00e+3:0 |
501 | 00e-03:0 |
502 | 00e+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 |
513 | 0:0 |
514 | 1:1 |
515 | 1.2:1 |
516 | 2.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 |
521 | 0.000641:0 |
522 | 0.0006412:0 |
523 | 0.00064123:0 |
524 | 0.000641234:0 |
525 | 0.0006412345:0 |
526 | 0.00064123456:0 |
527 | 0.000641234567:0 |
528 | 0.0006412345678:0 |
529 | 0.00064123456789:0 |
530 | 0.1:0 |
531 | 0.01:0 |
532 | 0.001:0 |
533 | 0.0001:0 |
534 | 0.00001:0 |
535 | 0.000001:0 |
536 | 0.0000001:0 |
537 | 0.00000001:0 |
538 | 0.000000001:0 |
539 | 0.0000000001:0 |
540 | 0.00000000001:0 |
990fb837 |
541 | 0.12345:0 |
542 | 0.123456:0 |
543 | 0.1234567:0 |
544 | 0.12345678:0 |
545 | 0.123456789:0 |
ee15d750 |
546 | &finf |
547 | 1:+:inf |
548 | 2:-:-inf |
549 | 3:abc:inf |
56d9de68 |
550 | &as_hex |
551 | +inf:inf |
552 | -inf:-inf |
553 | hexNaN:NaN |
554 | 0:0x0 |
555 | 5:0x5 |
556 | -5:-0x5 |
557 | &as_bin |
558 | +inf:inf |
559 | -inf:-inf |
560 | hexNaN:NaN |
561 | 0:0b0 |
562 | 5:0b101 |
563 | -5:-0b101 |
ee15d750 |
564 | &numify |
56d9de68 |
565 | # uses bsstr() so 5 => 5e+0 to be compatible w/ Perls output |
ee15d750 |
566 | 0:0e+1 |
567 | +1:1e+0 |
568 | 1234:1234e+0 |
569 | NaN:NaN |
570 | +inf:inf |
571 | -inf:-inf |
56d9de68 |
572 | -5:-5e+0 |
573 | 100:1e+2 |
574 | -100:-1e+2 |
ee15d750 |
575 | &fnan |
576 | abc:NaN |
577 | 2:NaN |
578 | -2:NaN |
579 | 0:NaN |
580 | &fone |
581 | 2:+:1 |
582 | -2:-:-1 |
583 | -2:+:1 |
584 | 2:-:-1 |
585 | 0::1 |
586 | -2::1 |
587 | abc::1 |
588 | 2:abc:1 |
589 | &fsstr |
590 | +inf:inf |
591 | -inf:-inf |
592 | abcfsstr:NaN |
56d9de68 |
593 | -abcfsstr:NaN |
ee15d750 |
594 | 1234.567:1234567e-3 |
56d9de68 |
595 | 123:123e+0 |
596 | -5:-5e+0 |
597 | -100:-1e+2 |
ee15d750 |
598 | &fstr |
599 | +inf:::inf |
600 | -inf:::-inf |
601 | abcfstr:::NaN |
602 | 1234.567:9::1234.56700 |
603 | 1234.567::-6:1234.567000 |
604 | 12345:5::12345 |
605 | 0.001234:6::0.00123400 |
606 | 0.001234::-8:0.00123400 |
607 | 0:4::0 |
608 | 0::-4:0.0000 |
609 | &fnorm |
610 | inf:inf |
611 | +inf:inf |
612 | -inf:-inf |
613 | +infinity:NaN |
614 | +-inf:NaN |
615 | abc:NaN |
616 | 1 a:NaN |
617 | 1bcd2:NaN |
618 | 11111b:NaN |
619 | +1z:NaN |
620 | -1z:NaN |
aef458a0 |
621 | 0e999:0 |
622 | 0e-999:0 |
623 | -0e999:0 |
624 | -0e-999:0 |
ee15d750 |
625 | 0:0 |
626 | +0:0 |
627 | +00:0 |
628 | +0_0_0:0 |
629 | 000000_0000000_00000:0 |
630 | -0:0 |
631 | -0000:0 |
632 | +1:1 |
633 | +01:1 |
634 | +001:1 |
635 | +00000100000:100000 |
636 | 123456789:123456789 |
637 | -1:-1 |
638 | -01:-1 |
639 | -001:-1 |
640 | -123456789:-123456789 |
641 | -00000100000:-100000 |
642 | 123.456a:NaN |
643 | 123.456:123.456 |
644 | 0.01:0.01 |
645 | .002:0.002 |
646 | +.2:0.2 |
647 | -0.0003:-0.0003 |
648 | -.0000000004:-0.0000000004 |
649 | 123456E2:12345600 |
650 | 123456E-2:1234.56 |
651 | -123456E2:-12345600 |
652 | -123456E-2:-1234.56 |
653 | 1e1:10 |
654 | 2e-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 |
666 | NaN:1:NaN |
667 | 1:NaN:NaN |
668 | NaN:-1:NaN |
669 | -1:NaN:NaN |
670 | NaN:-21:NaN |
671 | -21:NaN:NaN |
672 | NaN:21:NaN |
673 | 21:NaN:NaN |
674 | 0:0:1 |
675 | 0:1:0 |
676 | 0:9:0 |
677 | 0:-2:inf |
ee15d750 |
678 | 2:2:4 |
679 | 1:2:1 |
680 | 1:3:1 |
681 | -1:2:1 |
682 | -1:3:-1 |
683 | 123.456:2:15241.383936 |
684 | 2:-2:0.25 |
685 | 2:-3:0.125 |
686 | 128:-2:0.00006103515625 |
687 | abc:123.456:NaN |
688 | 123.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) |
703 | 2: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 |
710 | fnegNaN: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 |
721 | fabsNaN: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 |
735 | 0:5:0 |
736 | NaNfround: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 |
810 | 0:5:0 |
811 | NaNffround: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 |
839 | 0.05:0:0 |
840 | 0.5:0:0 |
841 | 0.51:0:0 |
842 | 0.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 |
857 | 0.05:0:0 |
858 | 0.5:0:0 |
859 | 0.51:0:1 |
860 | 0.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 |
875 | 0.05:0:0 |
876 | 0.5:0:1 |
877 | 0.51:0:1 |
878 | 0.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 |
893 | 0.05:0:0 |
894 | 0.5:0:0 |
895 | 0.51:0:1 |
896 | 0.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 |
911 | 0.05:0:0 |
912 | 0.5:0:1 |
913 | 0.51:0:1 |
914 | 0.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 |
929 | 0.05:0:0 |
930 | 0.5:0:0 |
931 | 0.51:0:1 |
932 | 0.41:0:0 |
933 | 0.01234567:-3:0.012 |
934 | 0.01234567:-4:0.0123 |
935 | 0.01234567:-5:0.01235 |
936 | 0.01234567:-6:0.012346 |
937 | 0.01234567:-7:0.0123457 |
938 | 0.01234567:-8:0.01234567 |
939 | 0.01234567:-9:0.012345670 |
940 | 0.01234567:-12:0.012345670000 |
941 | &fcmp |
942 | fcmpNaN:fcmpNaN: |
943 | fcmpNaN:+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 |
968 | 0:0.01:-1 |
969 | 0:0.0001:-1 |
970 | 0:-0.0001:1 |
971 | 0:-0.1:1 |
972 | 0.1:0:1 |
973 | 0.00001:0:1 |
974 | -0.0001:0:-1 |
975 | -0.1:0:-1 |
976 | 0:0.0001234:-1 |
977 | 0:-0.0001234:1 |
978 | 0.0001234:0:1 |
979 | -0.0001234:0:-1 |
980 | 0.0001:0.0005:-1 |
981 | 0.0005:0.0001:1 |
982 | 0.005:0.0001:1 |
983 | 0.001:0.0005:1 |
984 | 0.000001:0.0005:-1 |
985 | 0.00000123:0.0005:-1 |
986 | 0.00512:0.0001:1 |
987 | 0.005:0.000112:1 |
988 | 0.00123:0.0005:1 |
989 | 1.5:2:-1 |
990 | 2:1.5:1 |
991 | 1.54321:234:-1 |
992 | 234: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: |
1008 | NaN:inf: |
1009 | -inf:NaN: |
1010 | NaN:-inf: |
1011 | &facmp |
1012 | fcmpNaN:fcmpNaN: |
1013 | fcmpNaN:+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 |
1038 | 0:0.01:-1 |
1039 | 0:0.0001:-1 |
1040 | 0:-0.0001:-1 |
1041 | 0:-0.1:-1 |
1042 | 0.1:0:1 |
1043 | 0.00001:0:1 |
1044 | -0.0001:0:1 |
1045 | -0.1:0:1 |
1046 | 0:0.0001234:-1 |
1047 | 0:-0.0001234:-1 |
1048 | 0.0001234:0:1 |
1049 | -0.0001234:0:1 |
1050 | 0.0001:0.0005:-1 |
1051 | 0.0005:0.0001:1 |
1052 | 0.005:0.0001:1 |
1053 | 0.001:0.0005:1 |
1054 | 0.000001:0.0005:-1 |
1055 | 0.00000123:0.0005:-1 |
1056 | 0.00512:0.0001:1 |
1057 | 0.005:0.000112:1 |
1058 | 0.00123:0.0005:1 |
1059 | 1.5:2:-1 |
1060 | 2:1.5:1 |
1061 | 1.54321:234:-1 |
1062 | 234: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 |
1076 | 5:inf:-1 |
1077 | -1:inf:-1 |
1078 | 5:-inf:-1 |
1079 | -1:-inf:-1 |
ee15d750 |
1080 | # return undef |
1081 | +inf:facmpNaN: |
1082 | facmpNaN:inf: |
1083 | -inf:facmpNaN: |
1084 | facmpNaN:-inf: |
1085 | &fdec |
1086 | fdecNaN:NaN |
1087 | +inf:inf |
1088 | -inf:-inf |
1089 | +0:-1 |
1090 | +1:0 |
1091 | -1:-2 |
1092 | 1.23:0.23 |
1093 | -1.23:-2.23 |
e745a66c |
1094 | 100:99 |
1095 | 101:100 |
1096 | -100:-101 |
1097 | -99:-100 |
1098 | -98:-99 |
1099 | 99:98 |
ee15d750 |
1100 | &finc |
1101 | fincNaN:NaN |
1102 | +inf:inf |
1103 | -inf:-inf |
1104 | +0:1 |
1105 | +1:2 |
1106 | -1:0 |
1107 | 1.23:2.23 |
1108 | -1.23:-0.23 |
e745a66c |
1109 | 100:101 |
1110 | -100:-99 |
1111 | -99:-98 |
1112 | -101:-100 |
1113 | 99:100 |
ee15d750 |
1114 | &fadd |
1115 | abc:abc:NaN |
1116 | abc:+0:NaN |
1117 | +0:abc:NaN |
13a12e00 |
1118 | +inf:-inf:NaN |
1119 | -inf:+inf:NaN |
ee15d750 |
1120 | +inf:+inf:inf |
1121 | -inf:-inf:-inf |
1122 | baddNaN:+inf:NaN |
1123 | baddNaN:+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 |
1160 | 0.001234:0.0001234:0.0013574 |
1161 | &fsub |
1162 | abc:abc:NaN |
1163 | abc:+0:NaN |
1164 | +0:abc:NaN |
1165 | +inf:-inf:inf |
1166 | -inf:+inf:-inf |
13a12e00 |
1167 | +inf:+inf:NaN |
1168 | -inf:-inf:NaN |
ee15d750 |
1169 | baddNaN:+inf:NaN |
1170 | baddNaN:+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 |
1208 | abc:abc:NaN |
1209 | abc:+0:NaN |
1210 | +0:abc:NaN |
1211 | +inf:NaNmul:NaN |
1212 | +inf:NaNmul:NaN |
1213 | NaNmul:+inf:NaN |
1214 | NaNmul:-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 |
1223 | 123.34:+inf:inf |
1224 | -123.34:+inf:-inf |
1225 | 123.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 |
1256 | 6:120:720 |
1257 | 10:10000:100000 |
b3abae2a |
1258 | &fdiv-list |
1259 | 0:0:NaN,NaN |
1260 | 0:1:0,0 |
1261 | 9:4:2.25,1 |
1262 | 9:5:1.8,4 |
233f7bc0 |
1263 | # bug in v1.74 with bdiv in list context, when $y is 1 or -1 |
1264 | 2.1:-1:-2.1,0 |
1265 | 2.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' |
1270 | abc:abc:NaN |
1271 | abc:+1:abc:NaN |
1272 | +1:abc:NaN |
1273 | -1:abc:NaN |
1274 | 0: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 |
1288 | 123:+inf:0 |
1289 | 123:-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 |
1313 | 2:25.024996000799840031993601279744051189762:0.07992009269196593320152084692285869265447 |
394e6ffb |
1314 | 123456: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 |
1325 | 1:10:0.1 |
1326 | 1:100:0.01 |
1327 | 1:1000:0.001 |
1328 | 1:10000:0.0001 |
1329 | 1:504:0.001984126984126984127 |
1330 | 2:1.987654321:1.0062111801179738436 |
394e6ffb |
1331 | 123456789.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 |
1342 | 123456789.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 |
1351 | 0:inf:0 |
1352 | 0:-inf:0 |
1353 | 5:inf:5 |
1354 | 5:-inf:5 |
1355 | -5:inf:-5 |
1356 | -5:-inf:-5 |
1357 | inf:5:0 |
1358 | -inf:5:0 |
1359 | inf:-5:0 |
1360 | -inf:-5:0 |
1361 | 5:5:0 |
1362 | -5:-5:0 |
b3abae2a |
1363 | inf:inf:NaN |
1364 | -inf:-inf:NaN |
1365 | -inf:inf:NaN |
1366 | inf:-inf:NaN |
61f5c3f5 |
1367 | 8:0:8 |
1368 | inf:0:inf |
1369 | # exceptions to reminder rule |
1370 | -inf:0:-inf |
1371 | -8:0:-8 |
1372 | 0:0:NaN |
1373 | abc:abc:NaN |
1374 | abc:1:abc:NaN |
1375 | 1:abc:NaN |
1376 | 0:0:NaN |
1377 | 0:1:0 |
1378 | 1:0:1 |
1379 | 0:-1:0 |
1380 | -1:0:-1 |
1381 | 1:1:0 |
1382 | -1:-1:0 |
1383 | 1:-1:0 |
1384 | -1:1:0 |
1385 | 1:2:1 |
1386 | 2:1:0 |
1387 | 1000000000:9:1 |
1388 | 2000000000:9:2 |
1389 | 3000000000:9:3 |
1390 | 4000000000:9:4 |
1391 | 5000000000:9:5 |
1392 | 6000000000:9:6 |
1393 | 7000000000:9:7 |
1394 | 8000000000:9:8 |
1395 | 9000000000:9:0 |
1396 | 35500000:113:33 |
1397 | 71000000:226:66 |
1398 | 106500000:339:99 |
1399 | 1000000000:3:1 |
1400 | 10:5:0 |
1401 | 100:4:0 |
1402 | 1000:8:0 |
1403 | 10000:16:0 |
1404 | 999999999999:9:0 |
1405 | 999999999999:99:0 |
1406 | 999999999999:999:0 |
1407 | 999999999999:9999:0 |
1408 | 999999999999999:99999:0 |
1409 | -9:+5:1 |
1410 | +9:-5:-1 |
1411 | -9:-5:-4 |
1412 | -5:3:1 |
1413 | -2:3:1 |
1414 | 4:3:1 |
1415 | 1:3:1 |
1416 | -5:-3:-2 |
1417 | -2:-3:-2 |
1418 | 4:-3:-2 |
1419 | 1:-3:-2 |
1420 | 4095:4095:0 |
1421 | 100041000510123:3:0 |
1422 | 152403346:12345:4321 |
1423 | 87654321:87654321:0 |
1424 | # now some floating point tests |
1425 | 123:2.5:0.5 |
1426 | 1230:2.5:0 |
1427 | 123.4:2.5:0.9 |
1428 | 123e1:25:5 |
7596a890 |
1429 | -2.1:1:0.9 |
1430 | 2.1:1:0.1 |
1431 | -2.1:-1:-0.1 |
1432 | 2.1:-1:-0.9 |
233f7bc0 |
1433 | -3:1:0 |
1434 | 3:1:0 |
1435 | -3:-1:0 |
1436 | 3:-1:0 |
b3abae2a |
1437 | &ffac |
1438 | Nanfac:NaN |
1439 | -1:NaN |
b282a552 |
1440 | +inf:inf |
091c87b1 |
1441 | -inf:NaN |
b3abae2a |
1442 | 0:1 |
1443 | 1:1 |
1444 | 2:2 |
1445 | 3:6 |
1446 | 4:24 |
1447 | 5:120 |
1448 | 6:720 |
1449 | 10:3628800 |
1450 | 11:39916800 |
1451 | 12: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 |
1461 | 2:2:1.41421356237309504880168872420969807857 |
1462 | -2:2:NaN |
1463 | 4:2:2 |
1464 | 9:2:3 |
1465 | 16:2:4 |
1466 | 100:2:10 |
1467 | 123.456:2:11.11107555549866648462149404118219234119 |
1468 | 15241.38393:2:123.4559999756998444766131352122991626468 |
1469 | 1.44:2:1.2 |
1470 | 12:2:3.464101615137754587054892683011744733886 |
1471 | 0.49:2:0.7 |
1472 | 0.0049:2:0.07 |
1473 | # invalid ones |
1474 | 1:NaN:NaN |
1475 | -1:NaN:NaN |
1476 | 0:NaN:NaN |
1477 | -inf:NaN:NaN |
1478 | +inf:NaN:NaN |
1479 | NaN:0:NaN |
1480 | NaN:2:NaN |
1481 | NaN:inf:NaN |
1482 | NaN:inf:NaN |
1483 | 12:-inf:NaN |
1484 | 12: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 |
1491 | 12:1:12 |
1492 | -12:1:NaN |
1493 | 8:-1:NaN |
1494 | -8:-1:NaN |
1495 | # cubic root |
1496 | 8:3:2 |
1497 | -8:3:NaN |
1498 | # fourths root |
1499 | 16:4:2 |
1500 | 81: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 |
1508 | nanfsqrt:NaN |
1509 | +inf:inf |
1510 | -inf:NaN |
394e6ffb |
1511 | 1:1 |
1512 | 2:1.41421356237309504880168872420969807857 |
1513 | 4:2 |
1514 | 9:3 |
1515 | 16:4 |
1516 | 100:10 |
1517 | 123.456:11.11107555549866648462149404118219234119 |
1518 | 15241.38393:123.4559999756998444766131352122991626468 |
1519 | 1.44:1.2 |
1520 | # sqrt(1.44) = 1.2, sqrt(e10) = e5 => 12e4 |
1521 | 1.44E10:120000 |
1522 | 2e10:141421.356237309504880168872420969807857 |
b3abae2a |
1523 | 144e20:120000000000 |
61f5c3f5 |
1524 | # proved to be an endless loop under 7-9 |
1525 | 12:3.464101615137754587054892683011744733886 |
990fb837 |
1526 | 0.49:0.7 |
1527 | 0.0049:0.07 |
027dc388 |
1528 | &is_nan |
1529 | 123:0 |
1530 | abc:1 |
1531 | NaN:1 |
1532 | -123:0 |
1533 | &is_inf |
1534 | +inf::1 |
1535 | -inf::1 |
1536 | abc::0 |
1537 | 1::0 |
1538 | NaN::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 |
1548 | abc:0 |
1549 | 0:0 |
1550 | -1:1 |
1551 | -3:1 |
1552 | 1:1 |
1553 | 3:1 |
1554 | 1000001:1 |
1555 | 1000002:0 |
1556 | +inf:0 |
1557 | -inf:0 |
1558 | 123.45:0 |
1559 | -123.45:0 |
1560 | 2:0 |
b3abae2a |
1561 | &is_int |
1562 | NaNis_int:0 |
1563 | 0:1 |
1564 | 1:1 |
1565 | 2:1 |
1566 | -2:1 |
1567 | -1:1 |
1568 | -inf:0 |
1569 | +inf:0 |
1570 | 123.4567:0 |
1571 | -0.1:0 |
1572 | -0.002:0 |
ee15d750 |
1573 | &is_even |
1574 | abc:0 |
1575 | 0:1 |
1576 | -1:0 |
1577 | -3:0 |
1578 | 1:0 |
1579 | 3:0 |
1580 | 1000001:0 |
1581 | 1000002:1 |
1582 | 2:1 |
1583 | +inf:0 |
1584 | -inf:0 |
1585 | 123.456:0 |
1586 | -123.456:0 |
b3abae2a |
1587 | 0.01:0 |
1588 | -0.01:0 |
1589 | 120:1 |
1590 | 1200:1 |
1591 | -1200:1 |
ee15d750 |
1592 | &is_positive |
b68b7ab1 |
1593 | 0:0 |
ee15d750 |
1594 | 1:1 |
1595 | -1:0 |
1596 | -123:0 |
1597 | NaN:0 |
1598 | -inf:0 |
1599 | +inf:1 |
1600 | &is_negative |
1601 | 0:0 |
1602 | 1:0 |
1603 | -1:1 |
1604 | -123:1 |
1605 | NaN:0 |
1606 | -inf:1 |
1607 | +inf:0 |
1608 | &parts |
1609 | 0:0 1 |
1610 | 1:1 0 |
1611 | 123:123 0 |
1612 | -123:-123 0 |
1613 | -1200:-12 2 |
1614 | NaNparts:NaN NaN |
1615 | +inf:inf inf |
1616 | -inf:-inf inf |
1617 | &exponent |
1618 | 0:1 |
1619 | 1:0 |
1620 | 123:0 |
1621 | -123:0 |
1622 | -1200:2 |
1623 | +inf:inf |
1624 | -inf:inf |
1625 | NaNexponent:NaN |
1626 | &mantissa |
1627 | 0:0 |
1628 | 1:1 |
1629 | 123:123 |
1630 | -123:-123 |
1631 | -1200:-12 |
1632 | +inf:inf |
1633 | -inf:-inf |
1634 | NaNmantissa:NaN |
1635 | &length |
1636 | 123:3 |
1637 | -123:3 |
1638 | 0:1 |
1639 | 1:1 |
1640 | 12345678901234567890:20 |
1641 | &is_zero |
1642 | NaNzero:0 |
1643 | +inf:0 |
1644 | -inf:0 |
1645 | 0:1 |
1646 | -1:0 |
1647 | 1:0 |
1648 | &is_one |
1649 | NaNone:0 |
1650 | +inf:0 |
1651 | -inf:0 |
1652 | 0:0 |
1653 | 2:0 |
1654 | 1:1 |
1655 | -1:0 |
1656 | -2:0 |
027dc388 |
1657 | &ffloor |
ee15d750 |
1658 | 0:0 |
1659 | abc:NaN |
1660 | +inf:inf |
1661 | -inf:-inf |
1662 | 1:1 |
1663 | -51:-51 |
1664 | -51.2:-52 |
1665 | 12.2:12 |
990fb837 |
1666 | 0.12345:0 |
1667 | 0.123456:0 |
1668 | 0.1234567:0 |
1669 | 0.12345678:0 |
1670 | 0.123456789:0 |
027dc388 |
1671 | &fceil |
ee15d750 |
1672 | 0:0 |
1673 | abc:NaN |
1674 | +inf:inf |
1675 | -inf:-inf |
1676 | 1:1 |
1677 | -51:-51 |
1678 | -51.2:-51 |
1679 | 12.2:13 |