diff options
author | P. J. McDermott <pj@pehjota.net> | 2017-01-04 23:58:22 (EST) |
---|---|---|
committer | P. J. McDermott <pj@pehjota.net> | 2017-01-04 23:58:22 (EST) |
commit | bb5ef9963467421857c2ac8eec720cea6a98abe7 (patch) | |
tree | a7dbb5af7c6b1d41202bf0eed8bb372c7b15d77c /lib/Math/Decimal | |
parent | 7ba5c52e490cb3e2075d8a6b0ce055cc00b27a8c (diff) | |
download | Math-Decimal-FastPP-bb5ef9963467421857c2ac8eec720cea6a98abe7.zip Math-Decimal-FastPP-bb5ef9963467421857c2ac8eec720cea6a98abe7.tar.gz Math-Decimal-FastPP-bb5ef9963467421857c2ac8eec720cea6a98abe7.tar.bz2 |
lib/Math/Decimal/FastPP.pm: Add POD sections PHILOSOPHY and THEORY
Diffstat (limited to 'lib/Math/Decimal')
-rw-r--r-- | lib/Math/Decimal/FastPP.pm | 49 |
1 files changed, 47 insertions, 2 deletions
diff --git a/lib/Math/Decimal/FastPP.pm b/lib/Math/Decimal/FastPP.pm index ad1e7f8..030b4e5 100644 --- a/lib/Math/Decimal/FastPP.pm +++ b/lib/Math/Decimal/FastPP.pm @@ -8,7 +8,7 @@ Math::Decimal::FastPP - Fast pure-Perl decimal arithmetic $a = dadd($a, "1.23"); # $a += 1.23 $c = dmul($a, $b); # $c = $a * $b - $a = drhtz($a); # Round half towards zero + $a = drhtz($a); # Round half toward zero =head1 DESCRIPTION @@ -21,6 +21,51 @@ This module is currently less complete than Perl's built-in arithmetic and other decimal arithmetic modules. So far it only includes addition, multiplication, and rounding functions. +Despite the similar name and purpose, this module is not compatible with +L<Math::Decimal>. + +=head1 PHILOSOPHY + +This module is designed both to run fast and to be used fast. The functions are +written to be as short and fast as possible, at a small cost in readability. +For help reading the bodies of these functions, see L<THEORY> below. + +The names and parameters of this module's functions are kept minimal to allow +them to be typed quickly and to take little space in calling code. After all, a +function to add two numbers shouldn't take much more typing than C<+>. The +names of the rounding functions may look strange, but they are simply +initialisms (or acronyms, if you're creative enough) of "decimal round toward +zero" and "decimal round (away) from zero". + +=head1 THEORY + +The binary operation functions (C<dadd()> and C<dmul()>) operate on two numbers, +C<a> and C<b>. And obviously the unary operation functions (C<drhtz()> and +C<drhfz()>) operate on one number, C<a>. The binary operation functions produce +a resulting number, C<c>. + +The input numbers C<a> and C<b> are broken into their integer (C<i>) and +fractional (C<f>) parts, for example C<$ai> and C<$af>. All three numbers C<a>, +C<b>, and C<c> are comprised of a significand C<s> and (negated) exponent C<e> +and can be expressed as C<s * 10**(-1*e)>. + +The significand is all of the significant digits (although the digits are +preserved exactly as given, so leading zeroes are considered "significant") in +the form of an integer, with no radix point. It is formed simply by +concatenating the integer and fractional parts, e.g. C<$as = $ai . $af>. The +exponent is simply the number of digits in the fractional part, e.g. +C<$ae = length($af)>. + +Multiplication is done simply be multiplying the integer significands and adding +the exponents. The resulting significand and exponent is converted back into a +string with integer and fractional parts. + +Addition is a little more complicated. The exponents of the two input numbers +must match; if they don't, zeroes are appended to the significand of the number +with the smaller exponent to make the exponents match. The significands are +then added. The output number is converted from the resulting significand and +the common exponent of the input numbers. + =head1 FUNCTIONS =over 4 @@ -106,7 +151,7 @@ sub dmul $a = drhtz($a, $p); -Rounds C<$a> with precision C<$p>. Halves are rounded towards zero. For +Rounds C<$a> with precision C<$p>. Halves are rounded toward zero. For example: drhtz("23.5", 0); # Returns "23." |