169 lines
4.0 KiB
Perl
169 lines
4.0 KiB
Perl
package Math::BigInt::FastCalc;
|
|
|
|
use 5.006;
|
|
use strict;
|
|
use warnings;
|
|
|
|
use Math::BigInt::Calc 1.999801;
|
|
|
|
our @ISA = qw< Math::BigInt::Calc >;
|
|
|
|
our $VERSION = '0.5009';
|
|
|
|
##############################################################################
|
|
# global constants, flags and accessory
|
|
|
|
# announce that we are compatible with MBI v1.83 and up
|
|
sub api_version () { 2; }
|
|
|
|
# use Calc to override the methods that we do not provide in XS
|
|
|
|
require XSLoader;
|
|
XSLoader::load(__PACKAGE__, $VERSION, Math::BigInt::Calc->_base_len());
|
|
|
|
##############################################################################
|
|
##############################################################################
|
|
|
|
1;
|
|
|
|
__END__
|
|
|
|
=pod
|
|
|
|
=head1 NAME
|
|
|
|
Math::BigInt::FastCalc - Math::BigInt::Calc with some XS for more speed
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
# to use it with Math::BigInt
|
|
use Math::BigInt lib => 'FastCalc';
|
|
|
|
# to use it with Math::BigFloat
|
|
use Math::BigFloat lib => 'FastCalc';
|
|
|
|
# to use it with Math::BigRat
|
|
use Math::BigRat lib => 'FastCalc';
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
Math::BigInt::FastCalc inherits from Math::BigInt::Calc.
|
|
|
|
Provides support for big integer calculations. Not intended to be used by
|
|
other modules. Other modules which sport the same functions can also be used
|
|
to support Math::BigInt, like L<Math::BigInt::GMP> or L<Math::BigInt::Pari>.
|
|
|
|
In order to allow for multiple big integer libraries, Math::BigInt was
|
|
rewritten to use library modules for core math routines. Any module which
|
|
follows the same API as this can be used instead by using the following:
|
|
|
|
use Math::BigInt lib => 'libname';
|
|
|
|
'libname' is either the long name ('Math::BigInt::Pari'), or only the short
|
|
version like 'Pari'. To use this library:
|
|
|
|
use Math::BigInt lib => 'FastCalc';
|
|
|
|
=head1 STORAGE
|
|
|
|
Math::BigInt::FastCalc works exactly like Math::BigInt::Calc. Numbers are
|
|
stored in decimal form chopped into parts.
|
|
|
|
=head1 METHODS
|
|
|
|
The following functions are now implemented in FastCalc.xs:
|
|
|
|
_is_odd _is_even _is_one _is_zero
|
|
_is_two _is_ten
|
|
_zero _one _two _ten
|
|
_acmp _len
|
|
_inc _dec
|
|
__strip_zeros _copy
|
|
|
|
=head1 BUGS
|
|
|
|
Please report any bugs or feature requests to
|
|
C<bug-math-bigint-fastcalc at rt.cpan.org>, or through the web interface at
|
|
L<https://rt.cpan.org/Ticket/Create.html?Queue=Math-BigInt-FastCalc>
|
|
(requires login).
|
|
We will be notified, and then you'll automatically be notified of progress on
|
|
your bug as I make changes.
|
|
|
|
=head1 SUPPORT
|
|
|
|
You can find documentation for this module with the perldoc command.
|
|
|
|
perldoc Math::BigInt::FastCalc
|
|
|
|
You can also look for information at:
|
|
|
|
=over 4
|
|
|
|
=item * RT: CPAN's request tracker
|
|
|
|
L<https://rt.cpan.org/Public/Dist/Display.html?Name=Math-BigInt-FastCalc>
|
|
|
|
=item * AnnoCPAN: Annotated CPAN documentation
|
|
|
|
L<http://annocpan.org/dist/Math-BigInt-FastCalc>
|
|
|
|
=item * CPAN Ratings
|
|
|
|
L<http://cpanratings.perl.org/dist/Math-BigInt-FastCalc>
|
|
|
|
=item * Search CPAN
|
|
|
|
L<http://search.cpan.org/dist/Math-BigInt-FastCalc/>
|
|
|
|
=item * CPAN Testers Matrix
|
|
|
|
L<http://matrix.cpantesters.org/?dist=Math-BigInt-FastCalc>
|
|
|
|
=item * The Bignum mailing list
|
|
|
|
=over 4
|
|
|
|
=item * Post to mailing list
|
|
|
|
C<bignum at lists.scsys.co.uk>
|
|
|
|
=item * View mailing list
|
|
|
|
L<http://lists.scsys.co.uk/pipermail/bignum/>
|
|
|
|
=item * Subscribe/Unsubscribe
|
|
|
|
L<http://lists.scsys.co.uk/cgi-bin/mailman/listinfo/bignum>
|
|
|
|
=back
|
|
|
|
=back
|
|
|
|
=head1 LICENSE
|
|
|
|
This program is free software; you may redistribute it and/or modify it under
|
|
the same terms as Perl itself.
|
|
|
|
=head1 AUTHORS
|
|
|
|
Original math code by Mark Biggar, rewritten by Tels L<http://bloodgate.com/>
|
|
in late 2000.
|
|
Separated from BigInt and shaped API with the help of John Peacock.
|
|
|
|
Fixed, sped-up and enhanced by Tels http://bloodgate.com 2001-2003.
|
|
Further streamlining (api_version 1 etc.) by Tels 2004-2007.
|
|
|
|
Bug-fixing by Peter John Acklam E<lt>pjacklam@online.noE<gt> 2010-2016.
|
|
|
|
=head1 SEE ALSO
|
|
|
|
L<Math::BigInt::Lib> for a description of the API.
|
|
|
|
Alternative libraries L<Math::BigInt::Calc>, L<Math::BigInt::GMP>, and
|
|
L<Math::BigInt::Pari>.
|
|
|
|
Some of the modules that use these libraries L<Math::BigInt>,
|
|
L<Math::BigFloat>, and L<Math::BigRat>.
|
|
|
|
=cut
|