bigint - Transparent BigInteger support for Perl
use bigint;
$x = 2 + 4.5,"\n"; # BigInt 6 print 2 ** 512,"\n"; # really is what you think it is print inf + 42,"\n"; # inf print NaN * 7,"\n"; # NaN
Floating point constants are truncated to integer. All results are also truncated.
perl -Mbigint=a,2 -le 'print 12345+1'
See Math::BigInt's bfround() function for details.
perl -Mbignum=p,5 -le 'print 123456789+123'
perl -Mbigint=l,GMP -e 'print 2 ** 512'
Currently there is no way to specify more than one library on the command line. This will be hopefully fixed soon ;)
perl -Mbigint=v
use bigint lib => 'Calc';
You can change this by using:
use bigint lib => 'BitVect';
The following would first try to find Math::BigInt::Foo, then Math::BigInt::Bar, and when this also fails, revert to Math::BigInt::Calc:
use bigint lib => 'Foo,Math::BigInt::Bar';
Please see respective module documentation for further details.
You should not depend on the internal format, all accesses must go through accessor methods. E.g. looking at $x->{sign} is not a good idea since there is no guaranty that the object in question has such a hash key, nor is a hash underneath at all.
A sign of 'NaN' is used to represent the result when input arguments are not numbers or as a result of 0/0. '+inf' and '-inf' represent plus respectively minus infinity. You will get '+inf' when dividing a positive number by 0, and '-inf' when dividing any negative number by 0.
$x = 9; $y = $x; $x = $y = 7;
Using the copy or the original with overloaded math is okay, e.g. the following work:
$x = 9; $y = $x; print $x + 1, " ", $y,"\n"; # prints 10 9
but calling any method that modifies the number directly will result in both the original and the copy beeing destroyed:
$x = 9; $y = $x; print $x->badd(1), " ", $y,"\n"; # prints 10 10
$x = 9; $y = $x; print $x->binc(1), " ", $y,"\n"; # prints 10 10
$x = 9; $y = $x; print $x->bmul(2), " ", $y,"\n"; # prints 18 18
Using methods that do not modify, but testthe contents works:
$x = 9; $y = $x; $z = 9 if $x->is_zero(); # works fine
See the documentation about the copy constructor and "=" in overload, as well as the documentation in BigInt for further details.
The following modules are currently used by bigint:
Math::BigInt::Lite (for speed, and only if it is loadable) Math::BigInt
perl -Mbigint -le 'print sqrt(33)' perl -Mbigint -le 'print 2*255' perl -Mbigint -le 'print 4.5+2*255' perl -Mbigint -le 'print 3/7 + 5/7 + 8/3' perl -Mbigint -le 'print 123->is_odd()' perl -Mbigint -le 'print log(2)' perl -Mbigint -le 'print 2 ** 0.5' perl -Mbigint=a,65 -le 'print 2 ** 0.2'
Math::BigInt, Math::BigRat and Math::Big as well as Math::BigInt::BitVect, Math::BigInt::Pari and Math::BigInt::GMP.
Закладки на сайте Проследить за страницей |
Created 1996-2024 by Maxim Chirkov Добавить, Поддержать, Вебмастеру |