diff options
author | Mark Dickinson <mdickinson@enthought.com> | 2012-10-31 19:45:05 (GMT) |
---|---|---|
committer | Mark Dickinson <mdickinson@enthought.com> | 2012-10-31 19:45:05 (GMT) |
commit | d3405edcdc36b5fefd7ac29649374a4e8c80ad64 (patch) | |
tree | 36bf6a3e111525bf8006210e3a0569d830ff3aad /Doc/library | |
parent | 591c9214110d1004032c61b00e47ad0805947ef2 (diff) | |
parent | 6ae568b9dfb565430b0761979e56a29e41f75edd (diff) | |
download | cpython-d3405edcdc36b5fefd7ac29649374a4e8c80ad64.zip cpython-d3405edcdc36b5fefd7ac29649374a4e8c80ad64.tar.gz cpython-d3405edcdc36b5fefd7ac29649374a4e8c80ad64.tar.bz2 |
Issue #16348: merge fix from 3.2.
Diffstat (limited to 'Doc/library')
-rw-r--r-- | Doc/library/decimal.rst | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/Doc/library/decimal.rst b/Doc/library/decimal.rst index 4a2b2d0..1fc56ad 100644 --- a/Doc/library/decimal.rst +++ b/Doc/library/decimal.rst @@ -750,12 +750,21 @@ Decimal objects .. method:: remainder_near(other[, context]) - Compute the modulo as either a positive or negative value depending on - which is closest to zero. For instance, ``Decimal(10).remainder_near(6)`` - returns ``Decimal('-2')`` which is closer to zero than ``Decimal('4')``. - - If both are equally close, the one chosen will have the same sign as - *self*. + Return the remainder from dividing *self* by *other*. This differs from + ``self % other`` in that the sign of the remainder is chosen so as to + minimize its absolute value. More precisely, the return value is + ``self - n * other`` where ``n`` is the integer nearest to the exact + value of ``self / other``, and if two integers are equally near then the + even one is chosen. + + If the result is zero then its sign will be the sign of *self*. + + >>> Decimal(18).remainder_near(Decimal(10)) + Decimal('-2') + >>> Decimal(25).remainder_near(Decimal(10)) + Decimal('5') + >>> Decimal(35).remainder_near(Decimal(10)) + Decimal('-5') .. method:: rotate(other[, context]) |