| 
									
										
										
										
											2024-05-08 15:34:40 -04:00
										 |  |  | :mod:`!math` --- Mathematical functions
 | 
					
						
							|  |  |  | =======================================
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. module:: math
 | 
					
						
							|  |  |  |    :synopsis: Mathematical functions (sin() etc.).
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-18 13:40:43 +01:00
										 |  |  | .. testsetup::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from math import fsum
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-11 15:02:54 -04:00
										 |  |  | --------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-17 05:59:14 -04:00
										 |  |  | This module provides access to the mathematical functions defined by the C
 | 
					
						
							|  |  |  | standard.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | These functions cannot be used with complex numbers; use the functions of the
 | 
					
						
							|  |  |  | same name from the :mod:`cmath` module if you require support for complex
 | 
					
						
							|  |  |  | numbers.  The distinction between functions which support complex numbers and
 | 
					
						
							|  |  |  | those which don't is made since most users do not want to learn quite as much
 | 
					
						
							|  |  |  | mathematics as required to understand complex numbers.  Receiving an exception
 | 
					
						
							|  |  |  | instead of a complex result allows earlier detection of the unexpected complex
 | 
					
						
							|  |  |  | number used as a parameter, so that the programmer can determine how and why it
 | 
					
						
							|  |  |  | was generated in the first place.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following functions are provided by this module.  Except when explicitly
 | 
					
						
							|  |  |  | noted otherwise, all return values are floats.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  | ====================================================  ============================================
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | **Number-theoretic functions**
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`comb(n, k) <comb>`                             Number of ways to choose *k* items from *n* items without repetition and without order
 | 
					
						
							|  |  |  | :func:`factorial(n) <factorial>`                      *n* factorial
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | :func:`gcd(*integers) <gcd>`                          Greatest common divisor of the integer arguments
 | 
					
						
							|  |  |  | :func:`isqrt(n) <isqrt>`                              Integer square root of a nonnegative integer *n*
 | 
					
						
							|  |  |  | :func:`lcm(*integers) <lcm>`                          Least common multiple of the integer arguments
 | 
					
						
							|  |  |  | :func:`perm(n, k) <perm>`                             Number of ways to choose *k* items from *n* items without repetition and with order
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Floating point arithmetic**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`ceil(x) <ceil>`                                Ceiling of *x*, the smallest integer greater than or equal to *x*
 | 
					
						
							|  |  |  | :func:`fabs(x) <fabs>`                                Absolute value of *x*
 | 
					
						
							|  |  |  | :func:`floor(x)  <floor>`                             Floor of *x*, the largest integer less than or equal to *x*
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  | :func:`fma(x, y, z) <fma>`                            Fused multiply-add operation: ``(x * y) + z``
 | 
					
						
							|  |  |  | :func:`fmod(x, y) <fmod>`                             Remainder of division ``x / y``
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | :func:`modf(x) <modf>`                                Fractional and integer parts of *x*
 | 
					
						
							|  |  |  | :func:`remainder(x, y) <remainder>`                   Remainder of *x* with respect to *y*
 | 
					
						
							|  |  |  | :func:`trunc(x) <trunc>`                              Integer part of *x*
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Floating point manipulation functions**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`copysign(x, y) <copysign>`                     Magnitude (absolute value) of *x* with the sign of *y*
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  | :func:`frexp(x) <frexp>`                              Mantissa and exponent of *x*
 | 
					
						
							|  |  |  | :func:`isclose(a, b, rel_tol, abs_tol) <isclose>`     Check if the values *a* and *b* are close to each other
 | 
					
						
							|  |  |  | :func:`isfinite(x) <isfinite>`                        Check if *x* is neither an infinity nor a NaN
 | 
					
						
							|  |  |  | :func:`isinf(x) <isinf>`                              Check if *x* is a positive or negative infinity
 | 
					
						
							|  |  |  | :func:`isnan(x) <isnan>`                              Check if *x* is a NaN  (not a number)
 | 
					
						
							|  |  |  | :func:`ldexp(x, i) <ldexp>`                           ``x * (2**i)``, inverse of function :func:`frexp`
 | 
					
						
							|  |  |  | :func:`nextafter(x, y, steps) <nextafter>`            Floating-point value *steps* steps after *x* towards *y*
 | 
					
						
							|  |  |  | :func:`ulp(x) <ulp>`                                  Value of the least significant bit of *x*
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | **Power, exponential and logarithmic functions**
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`cbrt(x) <cbrt>`                                Cube root of *x*
 | 
					
						
							|  |  |  | :func:`exp(x) <exp>`                                  *e* raised to the power *x*
 | 
					
						
							|  |  |  | :func:`exp2(x) <exp2>`                                *2* raised to the power *x*
 | 
					
						
							|  |  |  | :func:`expm1(x) <expm1>`                              *e* raised to the power *x*, minus 1
 | 
					
						
							|  |  |  | :func:`log(x, base) <log>`                            Logarithm of *x* to the given base (*e* by default)
 | 
					
						
							|  |  |  | :func:`log1p(x) <log1p>`                              Natural logarithm of *1+x* (base *e*)
 | 
					
						
							|  |  |  | :func:`log2(x) <log2>`                                Base-2 logarithm of *x*
 | 
					
						
							|  |  |  | :func:`log10(x) <log10>`                              Base-10 logarithm of *x*
 | 
					
						
							|  |  |  | :func:`pow(x, y) <math.pow>`                          *x* raised to the power *y*
 | 
					
						
							|  |  |  | :func:`sqrt(x) <sqrt>`                                Square root of *x*
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | **Summation and product functions**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`dist(p, q) <dist>`                             Euclidean distance between two points *p* and *q* given as an iterable of coordinates
 | 
					
						
							|  |  |  | :func:`fsum(iterable) <fsum>`                         Sum of values in the input *iterable*
 | 
					
						
							|  |  |  | :func:`hypot(*coordinates) <hypot>`                   Euclidean norm of an iterable of coordinates
 | 
					
						
							|  |  |  | :func:`prod(iterable, start) <prod>`                  Product of elements in the input *iterable* with a *start* value
 | 
					
						
							|  |  |  | :func:`sumprod(p, q) <sumprod>`                       Sum of products from two iterables *p* and *q*
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Angular conversion**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`degrees(x) <degrees>`                          Convert angle *x* from radians to degrees
 | 
					
						
							|  |  |  | :func:`radians(x) <radians>`                          Convert angle *x* from degrees to radians
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  | **Trigonometric functions**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`acos(x) <acos>`                                Arc cosine of *x*
 | 
					
						
							|  |  |  | :func:`asin(x) <asin>`                                Arc sine of *x*
 | 
					
						
							|  |  |  | :func:`atan(x) <atan>`                                Arc tangent of *x*
 | 
					
						
							|  |  |  | :func:`atan2(y, x) <atan2>`                           ``atan(y / x)``
 | 
					
						
							|  |  |  | :func:`cos(x) <cos>`                                  Cosine of *x*
 | 
					
						
							|  |  |  | :func:`sin(x) <sin>`                                  Sine of *x*
 | 
					
						
							|  |  |  | :func:`tan(x) <tan>`                                  Tangent of *x*
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Hyperbolic functions**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`acosh(x) <acosh>`                              Inverse hyperbolic cosine of *x*
 | 
					
						
							|  |  |  | :func:`asinh(x) <asinh>`                              Inverse hyperbolic sine of *x*
 | 
					
						
							|  |  |  | :func:`atanh(x) <atanh>`                              Inverse hyperbolic tangent of *x*
 | 
					
						
							|  |  |  | :func:`cosh(x) <cosh>`                                Hyperbolic cosine of *x*
 | 
					
						
							|  |  |  | :func:`sinh(x) <sinh>`                                Hyperbolic sine of *x*
 | 
					
						
							|  |  |  | :func:`tanh(x) <tanh>`                                Hyperbolic tangent of *x*
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Special functions**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :func:`erf(x) <erf>`                                  `Error function <https://en.wikipedia.org/wiki/Error_function>`_ at *x*
 | 
					
						
							|  |  |  | :func:`erfc(x) <erfc>`                                `Complementary error function <https://en.wikipedia.org/wiki/Error_function>`_ at *x*
 | 
					
						
							|  |  |  | :func:`gamma(x) <gamma>`                              `Gamma function <https://en.wikipedia.org/wiki/Gamma_function>`_ at *x*
 | 
					
						
							|  |  |  | :func:`lgamma(x) <lgamma>`                            Natural logarithm of the absolute value of the `Gamma function <https://en.wikipedia.org/wiki/Gamma_function>`_ at *x*
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Constants**
 | 
					
						
							|  |  |  | --------------------------------------------------------------------------------------------------
 | 
					
						
							|  |  |  | :data:`pi`                                            *π* = 3.141592...
 | 
					
						
							|  |  |  | :data:`e`                                             *e* = 2.718281...
 | 
					
						
							|  |  |  | :data:`tau`                                           *τ* = 2\ *π* = 6.283185...
 | 
					
						
							|  |  |  | :data:`inf`                                           Positive infinity
 | 
					
						
							|  |  |  | :data:`nan`                                           "Not a number" (NaN)
 | 
					
						
							|  |  |  | ====================================================  ============================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | Number-theoretic functions
 | 
					
						
							|  |  |  | --------------------------
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59666-59679 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r59666 | christian.heimes | 2008-01-02 19:28:32 +0100 (Wed, 02 Jan 2008) | 1 line
  Made vs9to8 Unix compatible
........
  r59669 | guido.van.rossum | 2008-01-02 20:00:46 +0100 (Wed, 02 Jan 2008) | 2 lines
  Patch #1696.  Don't attempt to close None in dry-run mode.
........
  r59671 | jeffrey.yasskin | 2008-01-03 03:21:52 +0100 (Thu, 03 Jan 2008) | 6 lines
  Backport PEP 3141 from the py3k branch to the trunk. This includes r50877 (just
  the complex_pow part), r56649, r56652, r56715, r57296, r57302, r57359, r57361,
  r57372, r57738, r57739, r58017, r58039, r58040, and r59390, and new
  documentation. The only significant difference is that round(x) returns a float
  to preserve backward-compatibility. See http://bugs.python.org/issue1689.
........
  r59672 | christian.heimes | 2008-01-03 16:41:30 +0100 (Thu, 03 Jan 2008) | 1 line
  Issue #1726: Remove Python/atof.c from PCBuild/pythoncore.vcproj
........
  r59675 | guido.van.rossum | 2008-01-03 20:12:44 +0100 (Thu, 03 Jan 2008) | 4 lines
  Issue #1700, reported by Nguyen Quan Son, fix by Fredruk Lundh:
  Regular Expression inline flags not handled correctly for some unicode
  characters.  (Forward port from 2.5.2.)
........
  r59676 | christian.heimes | 2008-01-03 21:23:15 +0100 (Thu, 03 Jan 2008) | 1 line
  Added math.isinf() and math.isnan()
........
  r59677 | christian.heimes | 2008-01-03 22:14:48 +0100 (Thu, 03 Jan 2008) | 1 line
  Some build bots don't compile mathmodule. There is an issue with the long definition of pi and euler
........
  r59678 | christian.heimes | 2008-01-03 23:16:32 +0100 (Thu, 03 Jan 2008) | 2 lines
  Modified PyImport_Import and PyImport_ImportModule to always use absolute imports by calling __import__ with an explicit level of 0
  Added a new API function PyImport_ImportModuleNoBlock. It solves the problem with dead locks when mixing threads and imports
........
  r59679 | christian.heimes | 2008-01-03 23:32:26 +0100 (Thu, 03 Jan 2008) | 1 line
  Added copysign(x, y) function to the math module
........
											
										 
											2008-01-03 23:01:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-01 15:01:46 -07:00
										 |  |  | .. function:: comb(n, k)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the number of ways to choose *k* items from *n* items without repetition
 | 
					
						
							|  |  |  |    and without order.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-04 01:23:06 -07:00
										 |  |  |    Evaluates to ``n! / (k! * (n - k)!)`` when ``k <= n`` and evaluates
 | 
					
						
							|  |  |  |    to zero when ``k > n``.
 | 
					
						
							| 
									
										
										
										
											2019-06-01 15:01:46 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-04 01:23:06 -07:00
										 |  |  |    Also called the binomial coefficient because it is equivalent
 | 
					
						
							| 
									
										
										
										
											2022-09-17 21:09:39 -05:00
										 |  |  |    to the coefficient of k-th term in polynomial expansion of
 | 
					
						
							|  |  |  |    ``(1 + x)ⁿ``.
 | 
					
						
							| 
									
										
										
										
											2019-06-04 01:23:06 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-04 03:40:23 -07:00
										 |  |  |    Raises :exc:`TypeError` if either of the arguments are not integers.
 | 
					
						
							| 
									
										
										
										
											2019-06-04 01:23:06 -07:00
										 |  |  |    Raises :exc:`ValueError` if either of the arguments are negative.
 | 
					
						
							| 
									
										
										
										
											2019-06-01 15:01:46 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: factorial(n)
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59666-59679 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r59666 | christian.heimes | 2008-01-02 19:28:32 +0100 (Wed, 02 Jan 2008) | 1 line
  Made vs9to8 Unix compatible
........
  r59669 | guido.van.rossum | 2008-01-02 20:00:46 +0100 (Wed, 02 Jan 2008) | 2 lines
  Patch #1696.  Don't attempt to close None in dry-run mode.
........
  r59671 | jeffrey.yasskin | 2008-01-03 03:21:52 +0100 (Thu, 03 Jan 2008) | 6 lines
  Backport PEP 3141 from the py3k branch to the trunk. This includes r50877 (just
  the complex_pow part), r56649, r56652, r56715, r57296, r57302, r57359, r57361,
  r57372, r57738, r57739, r58017, r58039, r58040, and r59390, and new
  documentation. The only significant difference is that round(x) returns a float
  to preserve backward-compatibility. See http://bugs.python.org/issue1689.
........
  r59672 | christian.heimes | 2008-01-03 16:41:30 +0100 (Thu, 03 Jan 2008) | 1 line
  Issue #1726: Remove Python/atof.c from PCBuild/pythoncore.vcproj
........
  r59675 | guido.van.rossum | 2008-01-03 20:12:44 +0100 (Thu, 03 Jan 2008) | 4 lines
  Issue #1700, reported by Nguyen Quan Son, fix by Fredruk Lundh:
  Regular Expression inline flags not handled correctly for some unicode
  characters.  (Forward port from 2.5.2.)
........
  r59676 | christian.heimes | 2008-01-03 21:23:15 +0100 (Thu, 03 Jan 2008) | 1 line
  Added math.isinf() and math.isnan()
........
  r59677 | christian.heimes | 2008-01-03 22:14:48 +0100 (Thu, 03 Jan 2008) | 1 line
  Some build bots don't compile mathmodule. There is an issue with the long definition of pi and euler
........
  r59678 | christian.heimes | 2008-01-03 23:16:32 +0100 (Thu, 03 Jan 2008) | 2 lines
  Modified PyImport_Import and PyImport_ImportModule to always use absolute imports by calling __import__ with an explicit level of 0
  Added a new API function PyImport_ImportModuleNoBlock. It solves the problem with dead locks when mixing threads and imports
........
  r59679 | christian.heimes | 2008-01-03 23:32:26 +0100 (Thu, 03 Jan 2008) | 1 line
  Added copysign(x, y) function to the math module
........
											
										 
											2008-01-03 23:01:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    Return *n* factorial as an integer.  Raises :exc:`ValueError` if *n* is not integral or
 | 
					
						
							|  |  |  |    is negative.
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59666-59679 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r59666 | christian.heimes | 2008-01-02 19:28:32 +0100 (Wed, 02 Jan 2008) | 1 line
  Made vs9to8 Unix compatible
........
  r59669 | guido.van.rossum | 2008-01-02 20:00:46 +0100 (Wed, 02 Jan 2008) | 2 lines
  Patch #1696.  Don't attempt to close None in dry-run mode.
........
  r59671 | jeffrey.yasskin | 2008-01-03 03:21:52 +0100 (Thu, 03 Jan 2008) | 6 lines
  Backport PEP 3141 from the py3k branch to the trunk. This includes r50877 (just
  the complex_pow part), r56649, r56652, r56715, r57296, r57302, r57359, r57361,
  r57372, r57738, r57739, r58017, r58039, r58040, and r59390, and new
  documentation. The only significant difference is that round(x) returns a float
  to preserve backward-compatibility. See http://bugs.python.org/issue1689.
........
  r59672 | christian.heimes | 2008-01-03 16:41:30 +0100 (Thu, 03 Jan 2008) | 1 line
  Issue #1726: Remove Python/atof.c from PCBuild/pythoncore.vcproj
........
  r59675 | guido.van.rossum | 2008-01-03 20:12:44 +0100 (Thu, 03 Jan 2008) | 4 lines
  Issue #1700, reported by Nguyen Quan Son, fix by Fredruk Lundh:
  Regular Expression inline flags not handled correctly for some unicode
  characters.  (Forward port from 2.5.2.)
........
  r59676 | christian.heimes | 2008-01-03 21:23:15 +0100 (Thu, 03 Jan 2008) | 1 line
  Added math.isinf() and math.isnan()
........
  r59677 | christian.heimes | 2008-01-03 22:14:48 +0100 (Thu, 03 Jan 2008) | 1 line
  Some build bots don't compile mathmodule. There is an issue with the long definition of pi and euler
........
  r59678 | christian.heimes | 2008-01-03 23:16:32 +0100 (Thu, 03 Jan 2008) | 2 lines
  Modified PyImport_Import and PyImport_ImportModule to always use absolute imports by calling __import__ with an explicit level of 0
  Added a new API function PyImport_ImportModuleNoBlock. It solves the problem with dead locks when mixing threads and imports
........
  r59679 | christian.heimes | 2008-01-03 23:32:26 +0100 (Thu, 03 Jan 2008) | 1 line
  Added copysign(x, y) function to the math module
........
											
										 
											2008-01-03 23:01:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    .. versionchanged:: 3.10
 | 
					
						
							|  |  |  |       Floats with integral values (like ``5.0``) are no longer accepted.
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: gcd(*integers)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the greatest common divisor of the specified integer arguments.
 | 
					
						
							|  |  |  |    If any of the arguments is nonzero, then the returned value is the largest
 | 
					
						
							|  |  |  |    positive integer that is a divisor of all arguments.  If all arguments
 | 
					
						
							|  |  |  |    are zero, then the returned value is ``0``.  ``gcd()`` without arguments
 | 
					
						
							|  |  |  |    returns ``0``.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    .. versionadded:: 3.5
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    .. versionchanged:: 3.9
 | 
					
						
							|  |  |  |       Added support for an arbitrary number of arguments. Formerly, only two
 | 
					
						
							|  |  |  |       arguments were supported.
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 64002-64003,64012,64036-64037,64047,64050-64052,64054-64055,64066,64071 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r64002 | travis.oliphant | 2008-06-07 00:33:21 +0200 (Sat, 07 Jun 2008) | 1 line
  Add long double check support to configure test.
........
  r64003 | travis.oliphant | 2008-06-07 00:39:47 +0200 (Sat, 07 Jun 2008) | 1 line
  Remove locking part of new buffer protocol.
........
  r64012 | facundo.batista | 2008-06-07 15:36:36 +0200 (Sat, 07 Jun 2008) | 4 lines
  Finished bug #2451.  Fixed the retrying part to make it
  more robust.
........
  r64036 | georg.brandl | 2008-06-08 10:54:40 +0200 (Sun, 08 Jun 2008) | 2 lines
  #3028: tokenize passes the physical line.
........
  r64037 | georg.brandl | 2008-06-08 10:59:38 +0200 (Sun, 08 Jun 2008) | 2 lines
  Argh, I read it wrong. Reverted 64036 and added a clarifying remark.
........
  r64047 | raymond.hettinger | 2008-06-09 03:28:30 +0200 (Mon, 09 Jun 2008) | 1 line
  Issue3065:  Fixed pickling of named tuples.  Added tests.
........
  r64050 | raymond.hettinger | 2008-06-09 08:54:45 +0200 (Mon, 09 Jun 2008) | 1 line
  Issue #2138: Add math.factorial().
........
  r64051 | raymond.hettinger | 2008-06-09 10:33:37 +0200 (Mon, 09 Jun 2008) | 1 line
  Let set.union() and set.update() accept multiple inputs.
........
  r64052 | raymond.hettinger | 2008-06-09 11:29:17 +0200 (Mon, 09 Jun 2008) | 1 line
  Address double-rounding scenarios by setting all variables to long doubles.
........
  r64054 | raymond.hettinger | 2008-06-09 13:24:47 +0200 (Mon, 09 Jun 2008) | 1 line
  Unhappy buildbots.  Revert 64052.  Long doubles have unexpected effects on some builds.
........
  r64055 | raymond.hettinger | 2008-06-09 15:07:27 +0200 (Mon, 09 Jun 2008) | 1 line
  Let set.intersection() and set.intersection_update() take multiple input arguments.
........
  r64066 | robert.schuppenies | 2008-06-10 12:10:31 +0200 (Tue, 10 Jun 2008) | 2 lines
  Issue 3048: Fixed sys.getsizeof for unicode objects.
........
  r64071 | thomas.heller | 2008-06-10 16:07:12 +0200 (Tue, 10 Jun 2008) | 3 lines
  NEWS entry for:
  Add an optional 'offset' parameter to byref, defaulting to zero.
........
											
										 
											2008-06-10 19:20:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: isqrt(n)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the integer square root of the nonnegative integer *n*. This is the
 | 
					
						
							|  |  |  |    floor of the exact square root of *n*, or equivalently the greatest integer
 | 
					
						
							|  |  |  |    *a* such that *a*\ ² |nbsp| ≤ |nbsp| *n*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    For some applications, it may be more convenient to have the least integer
 | 
					
						
							|  |  |  |    *a* such that *n* |nbsp| ≤ |nbsp| *a*\ ², or in other words the ceiling of
 | 
					
						
							|  |  |  |    the exact square root of *n*. For positive *n*, this can be computed using
 | 
					
						
							|  |  |  |    ``a = 1 + isqrt(n - 1)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: lcm(*integers)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the least common multiple of the specified integer arguments.
 | 
					
						
							|  |  |  |    If all arguments are nonzero, then the returned value is the smallest
 | 
					
						
							|  |  |  |    positive integer that is a multiple of all arguments.  If any of the arguments
 | 
					
						
							|  |  |  |    is zero, then the returned value is ``0``.  ``lcm()`` without arguments
 | 
					
						
							|  |  |  |    returns ``1``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.9
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: perm(n, k=None)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the number of ways to choose *k* items from *n* items
 | 
					
						
							|  |  |  |    without repetition and with order.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Evaluates to ``n! / (n - k)!`` when ``k <= n`` and evaluates
 | 
					
						
							|  |  |  |    to zero when ``k > n``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    If *k* is not specified or is ``None``, then *k* defaults to *n*
 | 
					
						
							|  |  |  |    and the function returns ``n!``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Raises :exc:`TypeError` if either of the arguments are not integers.
 | 
					
						
							|  |  |  |    Raises :exc:`ValueError` if either of the arguments are negative.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Floating point arithmetic
 | 
					
						
							|  |  |  | -------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: ceil(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the ceiling of *x*, the smallest integer greater than or equal to *x*.
 | 
					
						
							|  |  |  |    If *x* is not a float, delegates to :meth:`x.__ceil__ <object.__ceil__>`,
 | 
					
						
							|  |  |  |    which should return an :class:`~numbers.Integral` value.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: fabs(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the absolute value of *x*.
 | 
					
						
							| 
									
										
										
										
											2019-06-17 16:57:27 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. function:: floor(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-03 00:11:20 +02:00
										 |  |  |    Return the floor of *x*, the largest integer less than or equal to *x*.  If
 | 
					
						
							|  |  |  |    *x* is not a float, delegates to :meth:`x.__floor__ <object.__floor__>`, which
 | 
					
						
							|  |  |  |    should return an :class:`~numbers.Integral` value.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-17 14:58:26 +01:00
										 |  |  | .. function:: fma(x, y, z)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Fused multiply-add operation. Return ``(x * y) + z``, computed as though with
 | 
					
						
							|  |  |  |    infinite precision and range followed by a single round to the ``float``
 | 
					
						
							|  |  |  |    format. This operation often provides better accuracy than the direct
 | 
					
						
							|  |  |  |    expression ``(x * y) + z``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This function follows the specification of the fusedMultiplyAdd operation
 | 
					
						
							|  |  |  |    described in the IEEE 754 standard. The standard leaves one case
 | 
					
						
							|  |  |  |    implementation-defined, namely the result of ``fma(0, inf, nan)``
 | 
					
						
							|  |  |  |    and ``fma(inf, 0, nan)``. In these cases, ``math.fma`` returns a NaN,
 | 
					
						
							|  |  |  |    and does not raise any exception.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.13
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. function:: fmod(x, y)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return ``fmod(x, y)``, as defined by the platform C library. Note that the
 | 
					
						
							|  |  |  |    Python expression ``x % y`` may not return the same result.  The intent of the C
 | 
					
						
							|  |  |  |    standard is that ``fmod(x, y)`` be exactly (mathematically; to infinite
 | 
					
						
							|  |  |  |    precision) equal to ``x - n*y`` for some integer *n* such that the result has
 | 
					
						
							|  |  |  |    the same sign as *x* and magnitude less than ``abs(y)``.  Python's ``x % y``
 | 
					
						
							|  |  |  |    returns a result with the sign of *y* instead, and may not be exactly computable
 | 
					
						
							|  |  |  |    for float arguments. For example, ``fmod(-1e-100, 1e100)`` is ``-1e-100``, but
 | 
					
						
							|  |  |  |    the result of Python's ``-1e-100 % 1e100`` is ``1e100-1e-100``, which cannot be
 | 
					
						
							|  |  |  |    represented exactly as a float, and rounds to the surprising ``1e100``.  For
 | 
					
						
							|  |  |  |    this reason, function :func:`fmod` is generally preferred when working with
 | 
					
						
							|  |  |  |    floats, while Python's ``x % y`` is preferred when working with integers.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: modf(x)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    Return the fractional and integer parts of *x*.  Both results carry the sign
 | 
					
						
							|  |  |  |    of *x* and are floats.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    Note that :func:`modf` has a different call/return pattern
 | 
					
						
							|  |  |  |    than its C equivalents: it takes a single argument and return a pair of
 | 
					
						
							|  |  |  |    values, rather than returning its second return value through an 'output
 | 
					
						
							|  |  |  |    parameter' (there is no such thing in Python).
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 65258,65292,65299,65308-65309,65315,65326 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r65258 | mark.dickinson | 2008-07-27 08:15:29 +0100 (Sun, 27 Jul 2008) | 4 lines
  Remove math.sum tests related to overflow, special values, and behaviour
  near the extremes of the floating-point range.  (The behaviour of math.sum
  should be regarded as undefined in these cases.)
........
  r65292 | mark.dickinson | 2008-07-29 19:45:38 +0100 (Tue, 29 Jul 2008) | 4 lines
  More modifications to tests for math.sum:  replace the Python
  version of msum by a version using a different algorithm, and
  use the new float.fromhex method to specify test results exactly.
........
  r65299 | mark.dickinson | 2008-07-30 13:01:41 +0100 (Wed, 30 Jul 2008) | 5 lines
  Fix special-value handling for math.sum.
  Also minor cleanups to the code: fix tabbing, remove
  trailing whitespace, and reformat to fit into 80
  columns.
........
  r65308 | mark.dickinson | 2008-07-30 17:20:10 +0100 (Wed, 30 Jul 2008) | 2 lines
  Rename math.sum to math.fsum
........
  r65309 | mark.dickinson | 2008-07-30 17:25:16 +0100 (Wed, 30 Jul 2008) | 3 lines
  Replace math.sum with math.fsum in a couple of comments
  that were missed by r65308
........
  r65315 | mark.dickinson | 2008-07-30 21:23:15 +0100 (Wed, 30 Jul 2008) | 2 lines
  Add note about problems with math.fsum on x86 hardware.
........
  r65326 | mark.dickinson | 2008-07-31 15:48:32 +0100 (Thu, 31 Jul 2008) | 2 lines
  Rename testSum to testFsum and move it to proper place in test_math.py
........
											
										 
											2008-08-01 08:16:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: remainder(x, y)
 | 
					
						
							| 
									
										
										
										
											2009-02-19 05:48:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    Return the IEEE 754-style remainder of *x* with respect to *y*.  For
 | 
					
						
							|  |  |  |    finite *x* and finite nonzero *y*, this is the difference ``x - n*y``,
 | 
					
						
							|  |  |  |    where ``n`` is the closest integer to the exact value of the quotient ``x /
 | 
					
						
							|  |  |  |    y``.  If ``x / y`` is exactly halfway between two consecutive integers, the
 | 
					
						
							|  |  |  |    nearest *even* integer is used for ``n``.  The remainder ``r = remainder(x,
 | 
					
						
							|  |  |  |    y)`` thus always satisfies ``abs(r) <= 0.5 * abs(y)``.
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 65258,65292,65299,65308-65309,65315,65326 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r65258 | mark.dickinson | 2008-07-27 08:15:29 +0100 (Sun, 27 Jul 2008) | 4 lines
  Remove math.sum tests related to overflow, special values, and behaviour
  near the extremes of the floating-point range.  (The behaviour of math.sum
  should be regarded as undefined in these cases.)
........
  r65292 | mark.dickinson | 2008-07-29 19:45:38 +0100 (Tue, 29 Jul 2008) | 4 lines
  More modifications to tests for math.sum:  replace the Python
  version of msum by a version using a different algorithm, and
  use the new float.fromhex method to specify test results exactly.
........
  r65299 | mark.dickinson | 2008-07-30 13:01:41 +0100 (Wed, 30 Jul 2008) | 5 lines
  Fix special-value handling for math.sum.
  Also minor cleanups to the code: fix tabbing, remove
  trailing whitespace, and reformat to fit into 80
  columns.
........
  r65308 | mark.dickinson | 2008-07-30 17:20:10 +0100 (Wed, 30 Jul 2008) | 2 lines
  Rename math.sum to math.fsum
........
  r65309 | mark.dickinson | 2008-07-30 17:25:16 +0100 (Wed, 30 Jul 2008) | 3 lines
  Replace math.sum with math.fsum in a couple of comments
  that were missed by r65308
........
  r65315 | mark.dickinson | 2008-07-30 21:23:15 +0100 (Wed, 30 Jul 2008) | 2 lines
  Add note about problems with math.fsum on x86 hardware.
........
  r65326 | mark.dickinson | 2008-07-31 15:48:32 +0100 (Thu, 31 Jul 2008) | 2 lines
  Rename testSum to testFsum and move it to proper place in test_math.py
........
											
										 
											2008-08-01 08:16:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    Special cases follow IEEE 754: in particular, ``remainder(x, math.inf)`` is
 | 
					
						
							|  |  |  |    *x* for any finite *x*, and ``remainder(x, 0)`` and
 | 
					
						
							|  |  |  |    ``remainder(math.inf, x)`` raise :exc:`ValueError` for any non-NaN *x*.
 | 
					
						
							|  |  |  |    If the result of the remainder operation is zero, that zero will have
 | 
					
						
							|  |  |  |    the same sign as *x*.
 | 
					
						
							| 
									
										
										
										
											2009-02-19 06:44:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    On platforms using IEEE 754 binary floating point, the result of this
 | 
					
						
							|  |  |  |    operation is always exactly representable: no rounding error is introduced.
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 65258,65292,65299,65308-65309,65315,65326 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r65258 | mark.dickinson | 2008-07-27 08:15:29 +0100 (Sun, 27 Jul 2008) | 4 lines
  Remove math.sum tests related to overflow, special values, and behaviour
  near the extremes of the floating-point range.  (The behaviour of math.sum
  should be regarded as undefined in these cases.)
........
  r65292 | mark.dickinson | 2008-07-29 19:45:38 +0100 (Tue, 29 Jul 2008) | 4 lines
  More modifications to tests for math.sum:  replace the Python
  version of msum by a version using a different algorithm, and
  use the new float.fromhex method to specify test results exactly.
........
  r65299 | mark.dickinson | 2008-07-30 13:01:41 +0100 (Wed, 30 Jul 2008) | 5 lines
  Fix special-value handling for math.sum.
  Also minor cleanups to the code: fix tabbing, remove
  trailing whitespace, and reformat to fit into 80
  columns.
........
  r65308 | mark.dickinson | 2008-07-30 17:20:10 +0100 (Wed, 30 Jul 2008) | 2 lines
  Rename math.sum to math.fsum
........
  r65309 | mark.dickinson | 2008-07-30 17:25:16 +0100 (Wed, 30 Jul 2008) | 3 lines
  Replace math.sum with math.fsum in a couple of comments
  that were missed by r65308
........
  r65315 | mark.dickinson | 2008-07-30 21:23:15 +0100 (Wed, 30 Jul 2008) | 2 lines
  Add note about problems with math.fsum on x86 hardware.
........
  r65326 | mark.dickinson | 2008-07-31 15:48:32 +0100 (Thu, 31 Jul 2008) | 2 lines
  Rename testSum to testFsum and move it to proper place in test_math.py
........
											
										 
											2008-08-01 08:16:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    .. versionadded:: 3.7
 | 
					
						
							| 
									
										
										
										
											2015-05-13 00:19:51 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: trunc(x)
 | 
					
						
							| 
									
										
										
										
											2015-05-12 17:24:17 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    Return *x* with the fractional part
 | 
					
						
							|  |  |  |    removed, leaving the integer part.  This rounds toward 0: ``trunc()`` is
 | 
					
						
							|  |  |  |    equivalent to :func:`floor` for positive *x*, and equivalent to :func:`ceil`
 | 
					
						
							|  |  |  |    for negative *x*. If *x* is not a float, delegates to :meth:`x.__trunc__
 | 
					
						
							|  |  |  |    <object.__trunc__>`, which should return an :class:`~numbers.Integral` value.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For the :func:`ceil`, :func:`floor`, and :func:`modf` functions, note that *all*
 | 
					
						
							|  |  |  | floating-point numbers of sufficiently large magnitude are exact integers.
 | 
					
						
							|  |  |  | Python floats typically carry no more than 53 bits of precision (the same as the
 | 
					
						
							|  |  |  | platform C double type), in which case any float *x* with ``abs(x) >= 2**52``
 | 
					
						
							|  |  |  | necessarily has no fractional bits.
 | 
					
						
							| 
									
										
										
										
											2020-02-19 23:51:37 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | Floating point manipulation functions
 | 
					
						
							|  |  |  | -------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: copysign(x, y)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return a float with the magnitude (absolute value) of *x* but the sign of
 | 
					
						
							|  |  |  |    *y*.  On platforms that support signed zeros, ``copysign(1.0, -0.0)``
 | 
					
						
							|  |  |  |    returns *-1.0*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: frexp(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the mantissa and exponent of *x* as the pair ``(m, e)``.  *m* is a float
 | 
					
						
							|  |  |  |    and *e* is an integer such that ``x == m * 2**e`` exactly. If *x* is zero,
 | 
					
						
							|  |  |  |    returns ``(0.0, 0)``, otherwise ``0.5 <= abs(m) < 1``.  This is used to "pick
 | 
					
						
							|  |  |  |    apart" the internal representation of a float in a portable way.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Note that :func:`frexp` has a different call/return pattern
 | 
					
						
							|  |  |  |    than its C equivalents: it takes a single argument and return a pair of
 | 
					
						
							|  |  |  |    values, rather than returning its second return value through an 'output
 | 
					
						
							|  |  |  |    parameter' (there is no such thing in Python).
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-31 22:05:00 +03:00
										 |  |  | .. function:: isclose(a, b, *, rel_tol=1e-09, abs_tol=0.0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return ``True`` if the values *a* and *b* are close to each other and
 | 
					
						
							|  |  |  |    ``False`` otherwise.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Whether or not two values are considered close is determined according to
 | 
					
						
							| 
									
										
										
										
											2024-11-04 12:08:15 +08:00
										 |  |  |    given absolute and relative tolerances.  If no errors occur, the result will
 | 
					
						
							|  |  |  |    be: ``abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)``.
 | 
					
						
							| 
									
										
										
										
											2015-05-31 22:05:00 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |    *rel_tol* is the relative tolerance -- it is the maximum allowed difference
 | 
					
						
							|  |  |  |    between *a* and *b*, relative to the larger absolute value of *a* or *b*.
 | 
					
						
							|  |  |  |    For example, to set a tolerance of 5%, pass ``rel_tol=0.05``.  The default
 | 
					
						
							|  |  |  |    tolerance is ``1e-09``, which assures that the two values are the same
 | 
					
						
							| 
									
										
										
										
											2024-11-04 12:08:15 +08:00
										 |  |  |    within about 9 decimal digits.  *rel_tol* must be nonnegative and less
 | 
					
						
							|  |  |  |    than ``1.0``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    *abs_tol* is the absolute tolerance; it defaults to ``0.0`` and it must be
 | 
					
						
							|  |  |  |    nonnegative.  When comparing ``x`` to ``0.0``, ``isclose(x, 0)`` is computed
 | 
					
						
							|  |  |  |    as ``abs(x) <= rel_tol  * abs(x)``, which is ``False`` for any ``x`` and
 | 
					
						
							|  |  |  |    rel_tol less than ``1.0``.  So add an appropriate positive abs_tol argument
 | 
					
						
							|  |  |  |    to the call.
 | 
					
						
							| 
									
										
										
										
											2015-05-31 22:05:00 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |    The IEEE 754 special values of ``NaN``, ``inf``, and ``-inf`` will be
 | 
					
						
							|  |  |  |    handled according to IEEE rules.  Specifically, ``NaN`` is not considered
 | 
					
						
							|  |  |  |    close to any other value, including ``NaN``.  ``inf`` and ``-inf`` are only
 | 
					
						
							|  |  |  |    considered close to themselves.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.5
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. seealso::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       :pep:`485` -- A function for testing approximate equality
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-11 17:38:24 +00:00
										 |  |  | .. function:: isfinite(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return ``True`` if *x* is neither an infinity nor a NaN, and
 | 
					
						
							|  |  |  |    ``False`` otherwise.  (Note that ``0.0`` *is* considered finite.)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-11 19:47:37 +00:00
										 |  |  |    .. versionadded:: 3.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-11 17:38:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59666-59679 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r59666 | christian.heimes | 2008-01-02 19:28:32 +0100 (Wed, 02 Jan 2008) | 1 line
  Made vs9to8 Unix compatible
........
  r59669 | guido.van.rossum | 2008-01-02 20:00:46 +0100 (Wed, 02 Jan 2008) | 2 lines
  Patch #1696.  Don't attempt to close None in dry-run mode.
........
  r59671 | jeffrey.yasskin | 2008-01-03 03:21:52 +0100 (Thu, 03 Jan 2008) | 6 lines
  Backport PEP 3141 from the py3k branch to the trunk. This includes r50877 (just
  the complex_pow part), r56649, r56652, r56715, r57296, r57302, r57359, r57361,
  r57372, r57738, r57739, r58017, r58039, r58040, and r59390, and new
  documentation. The only significant difference is that round(x) returns a float
  to preserve backward-compatibility. See http://bugs.python.org/issue1689.
........
  r59672 | christian.heimes | 2008-01-03 16:41:30 +0100 (Thu, 03 Jan 2008) | 1 line
  Issue #1726: Remove Python/atof.c from PCBuild/pythoncore.vcproj
........
  r59675 | guido.van.rossum | 2008-01-03 20:12:44 +0100 (Thu, 03 Jan 2008) | 4 lines
  Issue #1700, reported by Nguyen Quan Son, fix by Fredruk Lundh:
  Regular Expression inline flags not handled correctly for some unicode
  characters.  (Forward port from 2.5.2.)
........
  r59676 | christian.heimes | 2008-01-03 21:23:15 +0100 (Thu, 03 Jan 2008) | 1 line
  Added math.isinf() and math.isnan()
........
  r59677 | christian.heimes | 2008-01-03 22:14:48 +0100 (Thu, 03 Jan 2008) | 1 line
  Some build bots don't compile mathmodule. There is an issue with the long definition of pi and euler
........
  r59678 | christian.heimes | 2008-01-03 23:16:32 +0100 (Thu, 03 Jan 2008) | 2 lines
  Modified PyImport_Import and PyImport_ImportModule to always use absolute imports by calling __import__ with an explicit level of 0
  Added a new API function PyImport_ImportModuleNoBlock. It solves the problem with dead locks when mixing threads and imports
........
  r59679 | christian.heimes | 2008-01-03 23:32:26 +0100 (Thu, 03 Jan 2008) | 1 line
  Added copysign(x, y) function to the math module
........
											
										 
											2008-01-03 23:01:04 +00:00
										 |  |  | .. function:: isinf(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-11 19:47:37 +00:00
										 |  |  |    Return ``True`` if *x* is a positive or negative infinity, and
 | 
					
						
							|  |  |  |    ``False`` otherwise.
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59666-59679 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r59666 | christian.heimes | 2008-01-02 19:28:32 +0100 (Wed, 02 Jan 2008) | 1 line
  Made vs9to8 Unix compatible
........
  r59669 | guido.van.rossum | 2008-01-02 20:00:46 +0100 (Wed, 02 Jan 2008) | 2 lines
  Patch #1696.  Don't attempt to close None in dry-run mode.
........
  r59671 | jeffrey.yasskin | 2008-01-03 03:21:52 +0100 (Thu, 03 Jan 2008) | 6 lines
  Backport PEP 3141 from the py3k branch to the trunk. This includes r50877 (just
  the complex_pow part), r56649, r56652, r56715, r57296, r57302, r57359, r57361,
  r57372, r57738, r57739, r58017, r58039, r58040, and r59390, and new
  documentation. The only significant difference is that round(x) returns a float
  to preserve backward-compatibility. See http://bugs.python.org/issue1689.
........
  r59672 | christian.heimes | 2008-01-03 16:41:30 +0100 (Thu, 03 Jan 2008) | 1 line
  Issue #1726: Remove Python/atof.c from PCBuild/pythoncore.vcproj
........
  r59675 | guido.van.rossum | 2008-01-03 20:12:44 +0100 (Thu, 03 Jan 2008) | 4 lines
  Issue #1700, reported by Nguyen Quan Son, fix by Fredruk Lundh:
  Regular Expression inline flags not handled correctly for some unicode
  characters.  (Forward port from 2.5.2.)
........
  r59676 | christian.heimes | 2008-01-03 21:23:15 +0100 (Thu, 03 Jan 2008) | 1 line
  Added math.isinf() and math.isnan()
........
  r59677 | christian.heimes | 2008-01-03 22:14:48 +0100 (Thu, 03 Jan 2008) | 1 line
  Some build bots don't compile mathmodule. There is an issue with the long definition of pi and euler
........
  r59678 | christian.heimes | 2008-01-03 23:16:32 +0100 (Thu, 03 Jan 2008) | 2 lines
  Modified PyImport_Import and PyImport_ImportModule to always use absolute imports by calling __import__ with an explicit level of 0
  Added a new API function PyImport_ImportModuleNoBlock. It solves the problem with dead locks when mixing threads and imports
........
  r59679 | christian.heimes | 2008-01-03 23:32:26 +0100 (Thu, 03 Jan 2008) | 1 line
  Added copysign(x, y) function to the math module
........
											
										 
											2008-01-03 23:01:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: isnan(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-11 19:47:37 +00:00
										 |  |  |    Return ``True`` if *x* is a NaN (not a number), and ``False`` otherwise.
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 59666-59679 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r59666 | christian.heimes | 2008-01-02 19:28:32 +0100 (Wed, 02 Jan 2008) | 1 line
  Made vs9to8 Unix compatible
........
  r59669 | guido.van.rossum | 2008-01-02 20:00:46 +0100 (Wed, 02 Jan 2008) | 2 lines
  Patch #1696.  Don't attempt to close None in dry-run mode.
........
  r59671 | jeffrey.yasskin | 2008-01-03 03:21:52 +0100 (Thu, 03 Jan 2008) | 6 lines
  Backport PEP 3141 from the py3k branch to the trunk. This includes r50877 (just
  the complex_pow part), r56649, r56652, r56715, r57296, r57302, r57359, r57361,
  r57372, r57738, r57739, r58017, r58039, r58040, and r59390, and new
  documentation. The only significant difference is that round(x) returns a float
  to preserve backward-compatibility. See http://bugs.python.org/issue1689.
........
  r59672 | christian.heimes | 2008-01-03 16:41:30 +0100 (Thu, 03 Jan 2008) | 1 line
  Issue #1726: Remove Python/atof.c from PCBuild/pythoncore.vcproj
........
  r59675 | guido.van.rossum | 2008-01-03 20:12:44 +0100 (Thu, 03 Jan 2008) | 4 lines
  Issue #1700, reported by Nguyen Quan Son, fix by Fredruk Lundh:
  Regular Expression inline flags not handled correctly for some unicode
  characters.  (Forward port from 2.5.2.)
........
  r59676 | christian.heimes | 2008-01-03 21:23:15 +0100 (Thu, 03 Jan 2008) | 1 line
  Added math.isinf() and math.isnan()
........
  r59677 | christian.heimes | 2008-01-03 22:14:48 +0100 (Thu, 03 Jan 2008) | 1 line
  Some build bots don't compile mathmodule. There is an issue with the long definition of pi and euler
........
  r59678 | christian.heimes | 2008-01-03 23:16:32 +0100 (Thu, 03 Jan 2008) | 2 lines
  Modified PyImport_Import and PyImport_ImportModule to always use absolute imports by calling __import__ with an explicit level of 0
  Added a new API function PyImport_ImportModuleNoBlock. It solves the problem with dead locks when mixing threads and imports
........
  r59679 | christian.heimes | 2008-01-03 23:32:26 +0100 (Thu, 03 Jan 2008) | 1 line
  Added copysign(x, y) function to the math module
........
											
										 
											2008-01-03 23:01:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. function:: ldexp(x, i)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return ``x * (2**i)``.  This is essentially the inverse of function
 | 
					
						
							|  |  |  |    :func:`frexp`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-20 04:03:49 +08:00
										 |  |  | .. function:: nextafter(x, y, steps=1)
 | 
					
						
							| 
									
										
										
										
											2020-01-12 02:15:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-20 04:03:49 +08:00
										 |  |  |    Return the floating-point value *steps* steps after *x* towards *y*.
 | 
					
						
							| 
									
										
										
										
											2020-01-12 02:15:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-20 04:03:49 +08:00
										 |  |  |    If *x* is equal to *y*, return *y*, unless *steps* is zero.
 | 
					
						
							| 
									
										
										
										
											2020-01-12 02:15:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-12 12:57:47 +01:00
										 |  |  |    Examples:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * ``math.nextafter(x, math.inf)`` goes up: towards positive infinity.
 | 
					
						
							|  |  |  |    * ``math.nextafter(x, -math.inf)`` goes down: towards minus infinity.
 | 
					
						
							|  |  |  |    * ``math.nextafter(x, 0.0)`` goes towards zero.
 | 
					
						
							|  |  |  |    * ``math.nextafter(x, math.copysign(math.inf, x))`` goes away from zero.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-13 12:44:35 +01:00
										 |  |  |    See also :func:`math.ulp`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-19 12:54:54 -05:00
										 |  |  |    .. versionadded:: 3.9
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-20 04:03:49 +08:00
										 |  |  |    .. versionchanged:: 3.12
 | 
					
						
							|  |  |  |       Added the *steps* argument.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-01 08:12:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-13 12:44:35 +01:00
										 |  |  | .. function:: ulp(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the value of the least significant bit of the float *x*:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * If *x* is a NaN (not a number), return *x*.
 | 
					
						
							|  |  |  |    * If *x* is negative, return ``ulp(-x)``.
 | 
					
						
							|  |  |  |    * If *x* is a positive infinity, return *x*.
 | 
					
						
							|  |  |  |    * If *x* is equal to zero, return the smallest positive
 | 
					
						
							|  |  |  |      *denormalized* representable float (smaller than the minimum positive
 | 
					
						
							|  |  |  |      *normalized* float, :data:`sys.float_info.min <sys.float_info>`).
 | 
					
						
							|  |  |  |    * If *x* is equal to the largest positive representable float,
 | 
					
						
							|  |  |  |      return the value of the least significant bit of *x*, such that the first
 | 
					
						
							|  |  |  |      float smaller than *x* is ``x - ulp(x)``.
 | 
					
						
							|  |  |  |    * Otherwise (*x* is a positive finite number), return the value of the least
 | 
					
						
							|  |  |  |      significant bit of *x*, such that the first float bigger than *x*
 | 
					
						
							|  |  |  |      is ``x + ulp(x)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ULP stands for "Unit in the Last Place".
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    See also :func:`math.nextafter` and :data:`sys.float_info.epsilon
 | 
					
						
							|  |  |  |    <sys.float_info>`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.9
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-01 08:12:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | Power, exponential and logarithmic functions
 | 
					
						
							|  |  |  | --------------------------------------------
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-10 22:12:09 +05:30
										 |  |  | .. function:: cbrt(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the cube root of *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.11
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. function:: exp(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  |    Return *e* raised to the power *x*, where *e* = 2.718281... is the base
 | 
					
						
							|  |  |  |    of natural logarithms.  This is usually more accurate than ``math.e ** x``
 | 
					
						
							|  |  |  |    or ``pow(math.e, x)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-29 12:55:43 -06:00
										 |  |  | .. function:: exp2(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return *2* raised to the power *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.11
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-16 20:23:42 +00:00
										 |  |  | .. function:: expm1(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  |    Return *e* raised to the power *x*, minus 1.  Here *e* is the base of natural
 | 
					
						
							|  |  |  |    logarithms.  For small floats *x*, the subtraction in ``exp(x) - 1``
 | 
					
						
							| 
									
										
										
										
											2011-03-31 12:04:53 -07:00
										 |  |  |    can result in a `significant loss of precision
 | 
					
						
							| 
									
										
										
										
											2016-02-26 19:37:12 +01:00
										 |  |  |    <https://en.wikipedia.org/wiki/Loss_of_significance>`_\; the :func:`expm1`
 | 
					
						
							| 
									
										
										
										
											2022-07-30 17:21:08 -05:00
										 |  |  |    function provides a way to compute this quantity to full precision:
 | 
					
						
							| 
									
										
										
										
											2009-12-16 20:23:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       >>> from math import exp, expm1
 | 
					
						
							|  |  |  |       >>> exp(1e-5) - 1  # gives result accurate to 11 places
 | 
					
						
							|  |  |  |       1.0000050000069649e-05
 | 
					
						
							|  |  |  |       >>> expm1(1e-5)    # result accurate to full precision
 | 
					
						
							|  |  |  |       1.0000050000166668e-05
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-19 11:20:49 +00:00
										 |  |  |    .. versionadded:: 3.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-16 20:23:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-05 16:36:33 +00:00
										 |  |  | .. function:: log(x[, base])
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-05 16:36:33 +00:00
										 |  |  |    With one argument, return the natural logarithm of *x* (to base *e*).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    With two arguments, return the logarithm of *x* to the given *base*,
 | 
					
						
							|  |  |  |    calculated as ``log(x)/log(base)``.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 00:31:39 +00:00
										 |  |  | .. function:: log1p(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the natural logarithm of *1+x* (base *e*). The
 | 
					
						
							|  |  |  |    result is calculated in a way which is accurate for *x* near zero.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 01:01:09 +02:00
										 |  |  | .. function:: log2(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-08 19:48:08 -05:00
										 |  |  |    Return the base-2 logarithm of *x*. This is usually more accurate than
 | 
					
						
							|  |  |  |    ``log(x, 2)``.
 | 
					
						
							| 
									
										
										
										
											2011-05-09 01:01:09 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.3
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-21 03:35:18 +02:00
										 |  |  |    .. seealso::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       :meth:`int.bit_length` returns the number of bits necessary to represent
 | 
					
						
							|  |  |  |       an integer in binary, excluding the sign and leading zeros.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 01:01:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. function:: log10(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 74542,74544-74548,74550,74554-74555,74578,74588,74590,74603,74616-74618,74621 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r74542 | georg.brandl | 2009-08-23 23:28:56 +0200 (So, 23 Aug 2009) | 1 line
  Restore alphabetic order.
........
  r74544 | georg.brandl | 2009-08-24 19:12:30 +0200 (Mo, 24 Aug 2009) | 1 line
  #6775: fix python.org URLs in README.
........
  r74545 | georg.brandl | 2009-08-24 19:14:29 +0200 (Mo, 24 Aug 2009) | 1 line
  #6772: mention utf-8 as utf8 alias.
........
  r74546 | georg.brandl | 2009-08-24 19:20:40 +0200 (Mo, 24 Aug 2009) | 1 line
  #6725: spell "namespace" consistently.
........
  r74547 | georg.brandl | 2009-08-24 19:22:05 +0200 (Mo, 24 Aug 2009) | 1 line
  #6718: fix example.
........
  r74548 | georg.brandl | 2009-08-24 19:24:27 +0200 (Mo, 24 Aug 2009) | 1 line
  #6677: mention "deleting" as an alias for removing files.
........
  r74550 | georg.brandl | 2009-08-24 19:48:40 +0200 (Mo, 24 Aug 2009) | 1 line
  #6677: note that rmdir only removes empty directories.
........
  r74554 | georg.brandl | 2009-08-27 20:59:02 +0200 (Do, 27 Aug 2009) | 1 line
  Typo fix.
........
  r74555 | georg.brandl | 2009-08-27 21:02:43 +0200 (Do, 27 Aug 2009) | 1 line
  #6787: reference fix.
........
  r74578 | tarek.ziade | 2009-08-29 15:33:21 +0200 (Sa, 29 Aug 2009) | 1 line
  fixed #6801: symmetric_difference_update also accepts pipe
........
  r74588 | georg.brandl | 2009-08-30 10:35:01 +0200 (So, 30 Aug 2009) | 1 line
  #6803: fix old name.
........
  r74590 | georg.brandl | 2009-08-30 13:51:53 +0200 (So, 30 Aug 2009) | 1 line
  #6801: fix copy-paste oversight.
........
  r74603 | georg.brandl | 2009-08-31 08:38:29 +0200 (Mo, 31 Aug 2009) | 1 line
  other -> others where multiple arguments are accepted.
........
  r74616 | georg.brandl | 2009-09-01 09:46:26 +0200 (Di, 01 Sep 2009) | 1 line
  #6808: clarification.
........
  r74617 | georg.brandl | 2009-09-01 09:53:37 +0200 (Di, 01 Sep 2009) | 1 line
  #6765: hint that log(x, base) is not very sophisticated.
........
  r74618 | georg.brandl | 2009-09-01 10:00:47 +0200 (Di, 01 Sep 2009) | 1 line
  #6810: add a link to the section about frame objects instead of just a description where to find it.
........
  r74621 | georg.brandl | 2009-09-01 10:06:03 +0200 (Di, 01 Sep 2009) | 1 line
  #6638: fix wrong parameter name and markup a class.
........
											
										 
											2009-09-01 08:11:14 +00:00
										 |  |  |    Return the base-10 logarithm of *x*.  This is usually more accurate
 | 
					
						
							|  |  |  |    than ``log(x, 10)``.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: pow(x, y)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  |    Return *x* raised to the power *y*.  Exceptional cases follow
 | 
					
						
							| 
									
										
										
										
											2021-06-12 10:23:02 +01:00
										 |  |  |    the IEEE 754 standard as far as possible.  In particular,
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62386-62387,62389-62393,62396,62400-62402,62407,62409-62410,62412-62414,62418-62419 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62386 | christian.heimes | 2008-04-19 04:23:57 +0200 (Sat, 19 Apr 2008) | 2 lines
  Added kill, terminate and send_signal to subprocess.Popen
  The bits and pieces for the Windows side were already in place. The POSIX side is trivial (as usual) and uses os.kill().
........
  r62387 | georg.brandl | 2008-04-19 10:23:59 +0200 (Sat, 19 Apr 2008) | 2 lines
  Fix-up docs for revision 62386.
........
  r62389 | georg.brandl | 2008-04-19 18:57:43 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2369: clarify that copyfile() doesn't take a target directory.
........
  r62390 | georg.brandl | 2008-04-19 18:58:28 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2634: clarify meaning of env parameter to spawn/exec*e.
........
  r62391 | georg.brandl | 2008-04-19 18:58:49 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2633: clarify meaning of env parameter.
........
  r62392 | georg.brandl | 2008-04-19 18:59:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2631: clarify IMPORT_NAME semantics.
........
  r62393 | georg.brandl | 2008-04-19 19:00:14 +0200 (Sat, 19 Apr 2008) | 2 lines
  :func: et al. should *not* include the parens.
........
  r62396 | mark.dickinson | 2008-04-19 20:51:48 +0200 (Sat, 19 Apr 2008) | 5 lines
  Additional tests for math.pow, and extra special-case
  handling code in math.pow, in the hope of making all
  tests pass on the alpha Tru64 buildbot.
........
  r62400 | mark.dickinson | 2008-04-19 21:41:52 +0200 (Sat, 19 Apr 2008) | 3 lines
  Additional special-case handling for math.pow.
  Windows/VS2008 doesn't like (-1)**(+-inf).
........
  r62401 | benjamin.peterson | 2008-04-19 21:47:34 +0200 (Sat, 19 Apr 2008) | 2 lines
  Complete documentation for errors argument of io's open and TextIOWrapper
........
  r62402 | mark.dickinson | 2008-04-19 22:31:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  Document updates to math and cmath modules.
........
  r62407 | georg.brandl | 2008-04-19 23:28:38 +0200 (Sat, 19 Apr 2008) | 2 lines
  Update template for newest Sphinx.
........
  r62409 | mark.dickinson | 2008-04-19 23:35:35 +0200 (Sat, 19 Apr 2008) | 5 lines
  Correct documentation for math.pow;
  0**nan is nan, not 0.  (But nan**0 and 1**nan are 1.)
  Also fix minor typo: 'quite NaN' -> 'quiet NaN'
........
  r62410 | mark.dickinson | 2008-04-19 23:49:22 +0200 (Sat, 19 Apr 2008) | 4 lines
  Move asinh documentation to the proper place.
  Remove meaningless 'in radians' from inverse
  hyperbolic functions.
........
  r62412 | mark.dickinson | 2008-04-20 03:22:30 +0200 (Sun, 20 Apr 2008) | 5 lines
  Report additional diagnostic information in
  test_math, to help track down debian-alpha
  buildbot failure.
........
  r62413 | mark.dickinson | 2008-04-20 03:39:24 +0200 (Sun, 20 Apr 2008) | 3 lines
  FreeBSD doesn't follow C99 for modf(inf); so add explicit
  special-value handling to math.modf code.
........
  r62414 | mark.dickinson | 2008-04-20 06:13:13 +0200 (Sun, 20 Apr 2008) | 5 lines
  Yet more explicit special case handling to make
  math.pow behave on alpha Tru64.  All IEEE 754
  special values are now handled directly; only
  the finite**finite case is handled by libm.
........
  r62418 | mark.dickinson | 2008-04-20 18:13:17 +0200 (Sun, 20 Apr 2008) | 7 lines
  Issue 2662: Initialize special value tables dynamically (i.e. when
  cmath module is loaded) instead of statically. This fixes compile-time
  problems on platforms where HUGE_VAL is an extern variable rather than
  a constant.
  Thanks Hirokazu Yamamoto for the patch.
........
  r62419 | andrew.kuchling | 2008-04-20 18:54:02 +0200 (Sun, 20 Apr 2008) | 1 line
  Move description of math module changes; various edits to description of cmath changes
........
											
										 
											2008-04-20 21:01:16 +00:00
										 |  |  |    ``pow(1.0, x)`` and ``pow(x, 0.0)`` always return ``1.0``, even
 | 
					
						
							| 
									
										
										
										
											2024-11-01 20:35:05 +01:00
										 |  |  |    when *x* is a zero or a NaN.  If both *x* and *y* are finite,
 | 
					
						
							|  |  |  |    *x* is negative, and *y* is not an integer then ``pow(x, y)``
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62386-62387,62389-62393,62396,62400-62402,62407,62409-62410,62412-62414,62418-62419 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62386 | christian.heimes | 2008-04-19 04:23:57 +0200 (Sat, 19 Apr 2008) | 2 lines
  Added kill, terminate and send_signal to subprocess.Popen
  The bits and pieces for the Windows side were already in place. The POSIX side is trivial (as usual) and uses os.kill().
........
  r62387 | georg.brandl | 2008-04-19 10:23:59 +0200 (Sat, 19 Apr 2008) | 2 lines
  Fix-up docs for revision 62386.
........
  r62389 | georg.brandl | 2008-04-19 18:57:43 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2369: clarify that copyfile() doesn't take a target directory.
........
  r62390 | georg.brandl | 2008-04-19 18:58:28 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2634: clarify meaning of env parameter to spawn/exec*e.
........
  r62391 | georg.brandl | 2008-04-19 18:58:49 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2633: clarify meaning of env parameter.
........
  r62392 | georg.brandl | 2008-04-19 18:59:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2631: clarify IMPORT_NAME semantics.
........
  r62393 | georg.brandl | 2008-04-19 19:00:14 +0200 (Sat, 19 Apr 2008) | 2 lines
  :func: et al. should *not* include the parens.
........
  r62396 | mark.dickinson | 2008-04-19 20:51:48 +0200 (Sat, 19 Apr 2008) | 5 lines
  Additional tests for math.pow, and extra special-case
  handling code in math.pow, in the hope of making all
  tests pass on the alpha Tru64 buildbot.
........
  r62400 | mark.dickinson | 2008-04-19 21:41:52 +0200 (Sat, 19 Apr 2008) | 3 lines
  Additional special-case handling for math.pow.
  Windows/VS2008 doesn't like (-1)**(+-inf).
........
  r62401 | benjamin.peterson | 2008-04-19 21:47:34 +0200 (Sat, 19 Apr 2008) | 2 lines
  Complete documentation for errors argument of io's open and TextIOWrapper
........
  r62402 | mark.dickinson | 2008-04-19 22:31:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  Document updates to math and cmath modules.
........
  r62407 | georg.brandl | 2008-04-19 23:28:38 +0200 (Sat, 19 Apr 2008) | 2 lines
  Update template for newest Sphinx.
........
  r62409 | mark.dickinson | 2008-04-19 23:35:35 +0200 (Sat, 19 Apr 2008) | 5 lines
  Correct documentation for math.pow;
  0**nan is nan, not 0.  (But nan**0 and 1**nan are 1.)
  Also fix minor typo: 'quite NaN' -> 'quiet NaN'
........
  r62410 | mark.dickinson | 2008-04-19 23:49:22 +0200 (Sat, 19 Apr 2008) | 4 lines
  Move asinh documentation to the proper place.
  Remove meaningless 'in radians' from inverse
  hyperbolic functions.
........
  r62412 | mark.dickinson | 2008-04-20 03:22:30 +0200 (Sun, 20 Apr 2008) | 5 lines
  Report additional diagnostic information in
  test_math, to help track down debian-alpha
  buildbot failure.
........
  r62413 | mark.dickinson | 2008-04-20 03:39:24 +0200 (Sun, 20 Apr 2008) | 3 lines
  FreeBSD doesn't follow C99 for modf(inf); so add explicit
  special-value handling to math.modf code.
........
  r62414 | mark.dickinson | 2008-04-20 06:13:13 +0200 (Sun, 20 Apr 2008) | 5 lines
  Yet more explicit special case handling to make
  math.pow behave on alpha Tru64.  All IEEE 754
  special values are now handled directly; only
  the finite**finite case is handled by libm.
........
  r62418 | mark.dickinson | 2008-04-20 18:13:17 +0200 (Sun, 20 Apr 2008) | 7 lines
  Issue 2662: Initialize special value tables dynamically (i.e. when
  cmath module is loaded) instead of statically. This fixes compile-time
  problems on platforms where HUGE_VAL is an extern variable rather than
  a constant.
  Thanks Hirokazu Yamamoto for the patch.
........
  r62419 | andrew.kuchling | 2008-04-20 18:54:02 +0200 (Sun, 20 Apr 2008) | 1 line
  Move description of math module changes; various edits to description of cmath changes
........
											
										 
											2008-04-20 21:01:16 +00:00
										 |  |  |    is undefined, and raises :exc:`ValueError`.
 | 
					
						
							| 
									
										
										
										
											2008-04-19 00:31:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-23 04:53:44 +02:00
										 |  |  |    Unlike the built-in ``**`` operator, :func:`math.pow` converts both
 | 
					
						
							|  |  |  |    its arguments to type :class:`float`.  Use ``**`` or the built-in
 | 
					
						
							|  |  |  |    :func:`pow` function for computing exact integer powers.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-12 10:23:02 +01:00
										 |  |  |    .. versionchanged:: 3.11
 | 
					
						
							|  |  |  |       The special cases ``pow(0.0, -inf)`` and ``pow(-0.0, -inf)`` were
 | 
					
						
							|  |  |  |       changed to return ``inf`` instead of raising :exc:`ValueError`,
 | 
					
						
							|  |  |  |       for consistency with IEEE 754.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. function:: sqrt(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the square root of *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | Summation and product functions
 | 
					
						
							|  |  |  | -------------------------------
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-31 00:45:49 -07:00
										 |  |  | .. function:: dist(p, q)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the Euclidean distance between two points *p* and *q*, each
 | 
					
						
							| 
									
										
										
										
											2019-07-27 14:04:29 -07:00
										 |  |  |    given as a sequence (or iterable) of coordinates.  The two points
 | 
					
						
							|  |  |  |    must have the same dimension.
 | 
					
						
							| 
									
										
										
										
											2018-07-31 00:45:49 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Roughly equivalent to::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        sqrt(sum((px - qx) ** 2.0 for px, qx in zip(p, q)))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: fsum(iterable)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return an accurate floating-point sum of values in the iterable.  Avoids
 | 
					
						
							|  |  |  |    loss of precision by tracking multiple intermediate partial sums.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The algorithm's accuracy depends on IEEE-754 arithmetic guarantees and the
 | 
					
						
							|  |  |  |    typical case where the rounding mode is half-even.  On some non-Windows
 | 
					
						
							|  |  |  |    builds, the underlying C library uses extended precision addition and may
 | 
					
						
							|  |  |  |    occasionally double-round an intermediate sum causing it to be off in its
 | 
					
						
							|  |  |  |    least significant bit.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    For further discussion and two alternative approaches, see the `ASPN cookbook
 | 
					
						
							|  |  |  |    recipes for accurate floating-point summation
 | 
					
						
							|  |  |  |    <https://code.activestate.com/recipes/393090-binary-floating-point-summation-accurate-to-full-p/>`_\.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-28 07:48:04 -07:00
										 |  |  | .. function:: hypot(*coordinates)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-28 07:48:04 -07:00
										 |  |  |    Return the Euclidean norm, ``sqrt(sum(x**2 for x in coordinates))``.
 | 
					
						
							|  |  |  |    This is the length of the vector from the origin to the point
 | 
					
						
							|  |  |  |    given by the coordinates.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    For a two dimensional point ``(x, y)``, this is equivalent to computing
 | 
					
						
							|  |  |  |    the hypotenuse of a right triangle using the Pythagorean theorem,
 | 
					
						
							|  |  |  |    ``sqrt(x*x + y*y)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionchanged:: 3.8
 | 
					
						
							|  |  |  |       Added support for n-dimensional points. Formerly, only the two
 | 
					
						
							|  |  |  |       dimensional case was supported.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-13 23:33:41 -07:00
										 |  |  |    .. versionchanged:: 3.10
 | 
					
						
							|  |  |  |       Improved the algorithm's accuracy so that the maximum error is
 | 
					
						
							|  |  |  |       under 1 ulp (unit in the last place).  More typically, the result
 | 
					
						
							|  |  |  |       is almost always correctly rounded to within 1/2 ulp.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | .. function:: prod(iterable, *, start=1)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    Calculate the product of all the elements in the input *iterable*.
 | 
					
						
							|  |  |  |    The default *start* value for the product is ``1``.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    When the iterable is empty, return the start value.  This function is
 | 
					
						
							|  |  |  |    intended specifically for use with numeric values and may reject
 | 
					
						
							|  |  |  |    non-numeric types.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  |    .. versionadded:: 3.8
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. function:: sumprod(p, q)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the sum of products of values from two iterables *p* and *q*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Raises :exc:`ValueError` if the inputs do not have the same length.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Roughly equivalent to::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        sum(map(operator.mul, p, q, strict=True))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    For float and mixed int/float inputs, the intermediate products
 | 
					
						
							|  |  |  |    and sums are computed with extended precision.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.12
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 67654,67676-67677,67681,67692,67725,67761,67784-67785,67787-67788,67802,67848-67850,67862-67864,67880,67882 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r67654 | georg.brandl | 2008-12-07 16:42:09 -0600 (Sun, 07 Dec 2008) | 2 lines
  #4457: rewrite __import__() documentation.
........
  r67676 | benjamin.peterson | 2008-12-08 20:03:03 -0600 (Mon, 08 Dec 2008) | 1 line
  specify how things are copied
........
  r67677 | benjamin.peterson | 2008-12-08 20:05:11 -0600 (Mon, 08 Dec 2008) | 1 line
  revert unrelated change to installer script
........
  r67681 | jeremy.hylton | 2008-12-09 15:03:10 -0600 (Tue, 09 Dec 2008) | 2 lines
  Add simple unittests for Request
........
  r67692 | amaury.forgeotdarc | 2008-12-10 18:03:42 -0600 (Wed, 10 Dec 2008) | 2 lines
  #1030250: correctly pass the dry_run option to the mkpath() function.
........
  r67725 | benjamin.peterson | 2008-12-12 22:02:20 -0600 (Fri, 12 Dec 2008) | 1 line
  fix incorrect example
........
  r67761 | benjamin.peterson | 2008-12-14 11:26:04 -0600 (Sun, 14 Dec 2008) | 1 line
  fix missing bracket
........
  r67784 | georg.brandl | 2008-12-15 02:33:58 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4446: document "platforms" argument for setup().
........
  r67785 | georg.brandl | 2008-12-15 02:36:11 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4611: fix typo.
........
  r67787 | georg.brandl | 2008-12-15 02:58:59 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4578: fix has_key() usage in compiler package.
........
  r67788 | georg.brandl | 2008-12-15 03:07:39 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4568: remove limitation in varargs callback example.
........
  r67802 | amaury.forgeotdarc | 2008-12-15 16:29:14 -0600 (Mon, 15 Dec 2008) | 4 lines
  #3632: the "pyo" macro from gdbinit can now run when the GIL is released.
  Patch by haypo.
........
  r67848 | benjamin.peterson | 2008-12-18 20:28:56 -0600 (Thu, 18 Dec 2008) | 1 line
  fix typo
........
  r67849 | benjamin.peterson | 2008-12-18 20:31:35 -0600 (Thu, 18 Dec 2008) | 1 line
  _call_method -> _callmethod and _get_value to _getvalue
........
  r67850 | raymond.hettinger | 2008-12-19 03:06:07 -0600 (Fri, 19 Dec 2008) | 9 lines
  Fix-up and clean-up docs for int.bit_length().
  * Replace dramatic footnote with in-line comment about possible round-off errors in logarithms of large numbers.
  * Add comments to the pure python code equivalent.
  * replace floor() with int() in the mathematical equivalent so the type is correct (should be an int, not a float).
  * add abs() to the mathematical equivalent so that it matches the previous line that it is supposed to be equivalent to.
  * make one combined example with a negative input.
........
  r67862 | benjamin.peterson | 2008-12-19 20:48:02 -0600 (Fri, 19 Dec 2008) | 1 line
  copy sentence from docstring
........
  r67863 | benjamin.peterson | 2008-12-19 20:51:26 -0600 (Fri, 19 Dec 2008) | 1 line
  add headings
........
  r67864 | benjamin.peterson | 2008-12-19 20:57:19 -0600 (Fri, 19 Dec 2008) | 1 line
  beef up docstring
........
  r67880 | benjamin.peterson | 2008-12-20 16:49:24 -0600 (Sat, 20 Dec 2008) | 1 line
  remove redundant sentence
........
  r67882 | benjamin.peterson | 2008-12-20 16:59:49 -0600 (Sat, 20 Dec 2008) | 1 line
  add some recent releases to the list
........
											
										 
											2008-12-21 00:06:59 +00:00
										 |  |  | Angular conversion
 | 
					
						
							|  |  |  | ------------------
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. function:: degrees(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-12 19:15:53 -04:00
										 |  |  |    Convert angle *x* from radians to degrees.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: radians(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-12 19:15:53 -04:00
										 |  |  |    Convert angle *x* from degrees to radians.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-18 08:57:32 +01:00
										 |  |  | Trigonometric functions
 | 
					
						
							|  |  |  | -----------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: acos(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the arc cosine of *x*, in radians. The result is between ``0`` and
 | 
					
						
							|  |  |  |    ``pi``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: asin(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the arc sine of *x*, in radians. The result is between ``-pi/2`` and
 | 
					
						
							|  |  |  |    ``pi/2``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: atan(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the arc tangent of *x*, in radians. The result is between ``-pi/2`` and
 | 
					
						
							|  |  |  |    ``pi/2``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: atan2(y, x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return ``atan(y / x)``, in radians. The result is between ``-pi`` and ``pi``.
 | 
					
						
							|  |  |  |    The vector in the plane from the origin to point ``(x, y)`` makes this angle
 | 
					
						
							|  |  |  |    with the positive X axis. The point of :func:`atan2` is that the signs of both
 | 
					
						
							|  |  |  |    inputs are known to it, so it can compute the correct quadrant for the angle.
 | 
					
						
							|  |  |  |    For example, ``atan(1)`` and ``atan2(1, 1)`` are both ``pi/4``, but ``atan2(-1,
 | 
					
						
							|  |  |  |    -1)`` is ``-3*pi/4``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: cos(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the cosine of *x* radians.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: sin(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the sine of *x* radians.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: tan(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the tangent of *x* radians.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 67654,67676-67677,67681,67692,67725,67761,67784-67785,67787-67788,67802,67848-67850,67862-67864,67880,67882 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r67654 | georg.brandl | 2008-12-07 16:42:09 -0600 (Sun, 07 Dec 2008) | 2 lines
  #4457: rewrite __import__() documentation.
........
  r67676 | benjamin.peterson | 2008-12-08 20:03:03 -0600 (Mon, 08 Dec 2008) | 1 line
  specify how things are copied
........
  r67677 | benjamin.peterson | 2008-12-08 20:05:11 -0600 (Mon, 08 Dec 2008) | 1 line
  revert unrelated change to installer script
........
  r67681 | jeremy.hylton | 2008-12-09 15:03:10 -0600 (Tue, 09 Dec 2008) | 2 lines
  Add simple unittests for Request
........
  r67692 | amaury.forgeotdarc | 2008-12-10 18:03:42 -0600 (Wed, 10 Dec 2008) | 2 lines
  #1030250: correctly pass the dry_run option to the mkpath() function.
........
  r67725 | benjamin.peterson | 2008-12-12 22:02:20 -0600 (Fri, 12 Dec 2008) | 1 line
  fix incorrect example
........
  r67761 | benjamin.peterson | 2008-12-14 11:26:04 -0600 (Sun, 14 Dec 2008) | 1 line
  fix missing bracket
........
  r67784 | georg.brandl | 2008-12-15 02:33:58 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4446: document "platforms" argument for setup().
........
  r67785 | georg.brandl | 2008-12-15 02:36:11 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4611: fix typo.
........
  r67787 | georg.brandl | 2008-12-15 02:58:59 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4578: fix has_key() usage in compiler package.
........
  r67788 | georg.brandl | 2008-12-15 03:07:39 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4568: remove limitation in varargs callback example.
........
  r67802 | amaury.forgeotdarc | 2008-12-15 16:29:14 -0600 (Mon, 15 Dec 2008) | 4 lines
  #3632: the "pyo" macro from gdbinit can now run when the GIL is released.
  Patch by haypo.
........
  r67848 | benjamin.peterson | 2008-12-18 20:28:56 -0600 (Thu, 18 Dec 2008) | 1 line
  fix typo
........
  r67849 | benjamin.peterson | 2008-12-18 20:31:35 -0600 (Thu, 18 Dec 2008) | 1 line
  _call_method -> _callmethod and _get_value to _getvalue
........
  r67850 | raymond.hettinger | 2008-12-19 03:06:07 -0600 (Fri, 19 Dec 2008) | 9 lines
  Fix-up and clean-up docs for int.bit_length().
  * Replace dramatic footnote with in-line comment about possible round-off errors in logarithms of large numbers.
  * Add comments to the pure python code equivalent.
  * replace floor() with int() in the mathematical equivalent so the type is correct (should be an int, not a float).
  * add abs() to the mathematical equivalent so that it matches the previous line that it is supposed to be equivalent to.
  * make one combined example with a negative input.
........
  r67862 | benjamin.peterson | 2008-12-19 20:48:02 -0600 (Fri, 19 Dec 2008) | 1 line
  copy sentence from docstring
........
  r67863 | benjamin.peterson | 2008-12-19 20:51:26 -0600 (Fri, 19 Dec 2008) | 1 line
  add headings
........
  r67864 | benjamin.peterson | 2008-12-19 20:57:19 -0600 (Fri, 19 Dec 2008) | 1 line
  beef up docstring
........
  r67880 | benjamin.peterson | 2008-12-20 16:49:24 -0600 (Sat, 20 Dec 2008) | 1 line
  remove redundant sentence
........
  r67882 | benjamin.peterson | 2008-12-20 16:59:49 -0600 (Sat, 20 Dec 2008) | 1 line
  add some recent releases to the list
........
											
										 
											2008-12-21 00:06:59 +00:00
										 |  |  | Hyperbolic functions
 | 
					
						
							|  |  |  | --------------------
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-21 15:47:46 -04:00
										 |  |  | `Hyperbolic functions <https://en.wikipedia.org/wiki/Hyperbolic_functions>`_
 | 
					
						
							| 
									
										
										
										
											2011-03-31 12:04:53 -07:00
										 |  |  | are analogs of trigonometric functions that are based on hyperbolas
 | 
					
						
							|  |  |  | instead of circles.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62386-62387,62389-62393,62396,62400-62402,62407,62409-62410,62412-62414,62418-62419 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62386 | christian.heimes | 2008-04-19 04:23:57 +0200 (Sat, 19 Apr 2008) | 2 lines
  Added kill, terminate and send_signal to subprocess.Popen
  The bits and pieces for the Windows side were already in place. The POSIX side is trivial (as usual) and uses os.kill().
........
  r62387 | georg.brandl | 2008-04-19 10:23:59 +0200 (Sat, 19 Apr 2008) | 2 lines
  Fix-up docs for revision 62386.
........
  r62389 | georg.brandl | 2008-04-19 18:57:43 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2369: clarify that copyfile() doesn't take a target directory.
........
  r62390 | georg.brandl | 2008-04-19 18:58:28 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2634: clarify meaning of env parameter to spawn/exec*e.
........
  r62391 | georg.brandl | 2008-04-19 18:58:49 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2633: clarify meaning of env parameter.
........
  r62392 | georg.brandl | 2008-04-19 18:59:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2631: clarify IMPORT_NAME semantics.
........
  r62393 | georg.brandl | 2008-04-19 19:00:14 +0200 (Sat, 19 Apr 2008) | 2 lines
  :func: et al. should *not* include the parens.
........
  r62396 | mark.dickinson | 2008-04-19 20:51:48 +0200 (Sat, 19 Apr 2008) | 5 lines
  Additional tests for math.pow, and extra special-case
  handling code in math.pow, in the hope of making all
  tests pass on the alpha Tru64 buildbot.
........
  r62400 | mark.dickinson | 2008-04-19 21:41:52 +0200 (Sat, 19 Apr 2008) | 3 lines
  Additional special-case handling for math.pow.
  Windows/VS2008 doesn't like (-1)**(+-inf).
........
  r62401 | benjamin.peterson | 2008-04-19 21:47:34 +0200 (Sat, 19 Apr 2008) | 2 lines
  Complete documentation for errors argument of io's open and TextIOWrapper
........
  r62402 | mark.dickinson | 2008-04-19 22:31:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  Document updates to math and cmath modules.
........
  r62407 | georg.brandl | 2008-04-19 23:28:38 +0200 (Sat, 19 Apr 2008) | 2 lines
  Update template for newest Sphinx.
........
  r62409 | mark.dickinson | 2008-04-19 23:35:35 +0200 (Sat, 19 Apr 2008) | 5 lines
  Correct documentation for math.pow;
  0**nan is nan, not 0.  (But nan**0 and 1**nan are 1.)
  Also fix minor typo: 'quite NaN' -> 'quiet NaN'
........
  r62410 | mark.dickinson | 2008-04-19 23:49:22 +0200 (Sat, 19 Apr 2008) | 4 lines
  Move asinh documentation to the proper place.
  Remove meaningless 'in radians' from inverse
  hyperbolic functions.
........
  r62412 | mark.dickinson | 2008-04-20 03:22:30 +0200 (Sun, 20 Apr 2008) | 5 lines
  Report additional diagnostic information in
  test_math, to help track down debian-alpha
  buildbot failure.
........
  r62413 | mark.dickinson | 2008-04-20 03:39:24 +0200 (Sun, 20 Apr 2008) | 3 lines
  FreeBSD doesn't follow C99 for modf(inf); so add explicit
  special-value handling to math.modf code.
........
  r62414 | mark.dickinson | 2008-04-20 06:13:13 +0200 (Sun, 20 Apr 2008) | 5 lines
  Yet more explicit special case handling to make
  math.pow behave on alpha Tru64.  All IEEE 754
  special values are now handled directly; only
  the finite**finite case is handled by libm.
........
  r62418 | mark.dickinson | 2008-04-20 18:13:17 +0200 (Sun, 20 Apr 2008) | 7 lines
  Issue 2662: Initialize special value tables dynamically (i.e. when
  cmath module is loaded) instead of statically. This fixes compile-time
  problems on platforms where HUGE_VAL is an extern variable rather than
  a constant.
  Thanks Hirokazu Yamamoto for the patch.
........
  r62419 | andrew.kuchling | 2008-04-20 18:54:02 +0200 (Sun, 20 Apr 2008) | 1 line
  Move description of math module changes; various edits to description of cmath changes
........
											
										 
											2008-04-20 21:01:16 +00:00
										 |  |  | .. function:: acosh(x)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62386-62387,62389-62393,62396,62400-62402,62407,62409-62410,62412-62414,62418-62419 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62386 | christian.heimes | 2008-04-19 04:23:57 +0200 (Sat, 19 Apr 2008) | 2 lines
  Added kill, terminate and send_signal to subprocess.Popen
  The bits and pieces for the Windows side were already in place. The POSIX side is trivial (as usual) and uses os.kill().
........
  r62387 | georg.brandl | 2008-04-19 10:23:59 +0200 (Sat, 19 Apr 2008) | 2 lines
  Fix-up docs for revision 62386.
........
  r62389 | georg.brandl | 2008-04-19 18:57:43 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2369: clarify that copyfile() doesn't take a target directory.
........
  r62390 | georg.brandl | 2008-04-19 18:58:28 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2634: clarify meaning of env parameter to spawn/exec*e.
........
  r62391 | georg.brandl | 2008-04-19 18:58:49 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2633: clarify meaning of env parameter.
........
  r62392 | georg.brandl | 2008-04-19 18:59:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2631: clarify IMPORT_NAME semantics.
........
  r62393 | georg.brandl | 2008-04-19 19:00:14 +0200 (Sat, 19 Apr 2008) | 2 lines
  :func: et al. should *not* include the parens.
........
  r62396 | mark.dickinson | 2008-04-19 20:51:48 +0200 (Sat, 19 Apr 2008) | 5 lines
  Additional tests for math.pow, and extra special-case
  handling code in math.pow, in the hope of making all
  tests pass on the alpha Tru64 buildbot.
........
  r62400 | mark.dickinson | 2008-04-19 21:41:52 +0200 (Sat, 19 Apr 2008) | 3 lines
  Additional special-case handling for math.pow.
  Windows/VS2008 doesn't like (-1)**(+-inf).
........
  r62401 | benjamin.peterson | 2008-04-19 21:47:34 +0200 (Sat, 19 Apr 2008) | 2 lines
  Complete documentation for errors argument of io's open and TextIOWrapper
........
  r62402 | mark.dickinson | 2008-04-19 22:31:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  Document updates to math and cmath modules.
........
  r62407 | georg.brandl | 2008-04-19 23:28:38 +0200 (Sat, 19 Apr 2008) | 2 lines
  Update template for newest Sphinx.
........
  r62409 | mark.dickinson | 2008-04-19 23:35:35 +0200 (Sat, 19 Apr 2008) | 5 lines
  Correct documentation for math.pow;
  0**nan is nan, not 0.  (But nan**0 and 1**nan are 1.)
  Also fix minor typo: 'quite NaN' -> 'quiet NaN'
........
  r62410 | mark.dickinson | 2008-04-19 23:49:22 +0200 (Sat, 19 Apr 2008) | 4 lines
  Move asinh documentation to the proper place.
  Remove meaningless 'in radians' from inverse
  hyperbolic functions.
........
  r62412 | mark.dickinson | 2008-04-20 03:22:30 +0200 (Sun, 20 Apr 2008) | 5 lines
  Report additional diagnostic information in
  test_math, to help track down debian-alpha
  buildbot failure.
........
  r62413 | mark.dickinson | 2008-04-20 03:39:24 +0200 (Sun, 20 Apr 2008) | 3 lines
  FreeBSD doesn't follow C99 for modf(inf); so add explicit
  special-value handling to math.modf code.
........
  r62414 | mark.dickinson | 2008-04-20 06:13:13 +0200 (Sun, 20 Apr 2008) | 5 lines
  Yet more explicit special case handling to make
  math.pow behave on alpha Tru64.  All IEEE 754
  special values are now handled directly; only
  the finite**finite case is handled by libm.
........
  r62418 | mark.dickinson | 2008-04-20 18:13:17 +0200 (Sun, 20 Apr 2008) | 7 lines
  Issue 2662: Initialize special value tables dynamically (i.e. when
  cmath module is loaded) instead of statically. This fixes compile-time
  problems on platforms where HUGE_VAL is an extern variable rather than
  a constant.
  Thanks Hirokazu Yamamoto for the patch.
........
  r62419 | andrew.kuchling | 2008-04-20 18:54:02 +0200 (Sun, 20 Apr 2008) | 1 line
  Move description of math module changes; various edits to description of cmath changes
........
											
										 
											2008-04-20 21:01:16 +00:00
										 |  |  |    Return the inverse hyperbolic cosine of *x*.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 00:31:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62386-62387,62389-62393,62396,62400-62402,62407,62409-62410,62412-62414,62418-62419 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62386 | christian.heimes | 2008-04-19 04:23:57 +0200 (Sat, 19 Apr 2008) | 2 lines
  Added kill, terminate and send_signal to subprocess.Popen
  The bits and pieces for the Windows side were already in place. The POSIX side is trivial (as usual) and uses os.kill().
........
  r62387 | georg.brandl | 2008-04-19 10:23:59 +0200 (Sat, 19 Apr 2008) | 2 lines
  Fix-up docs for revision 62386.
........
  r62389 | georg.brandl | 2008-04-19 18:57:43 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2369: clarify that copyfile() doesn't take a target directory.
........
  r62390 | georg.brandl | 2008-04-19 18:58:28 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2634: clarify meaning of env parameter to spawn/exec*e.
........
  r62391 | georg.brandl | 2008-04-19 18:58:49 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2633: clarify meaning of env parameter.
........
  r62392 | georg.brandl | 2008-04-19 18:59:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2631: clarify IMPORT_NAME semantics.
........
  r62393 | georg.brandl | 2008-04-19 19:00:14 +0200 (Sat, 19 Apr 2008) | 2 lines
  :func: et al. should *not* include the parens.
........
  r62396 | mark.dickinson | 2008-04-19 20:51:48 +0200 (Sat, 19 Apr 2008) | 5 lines
  Additional tests for math.pow, and extra special-case
  handling code in math.pow, in the hope of making all
  tests pass on the alpha Tru64 buildbot.
........
  r62400 | mark.dickinson | 2008-04-19 21:41:52 +0200 (Sat, 19 Apr 2008) | 3 lines
  Additional special-case handling for math.pow.
  Windows/VS2008 doesn't like (-1)**(+-inf).
........
  r62401 | benjamin.peterson | 2008-04-19 21:47:34 +0200 (Sat, 19 Apr 2008) | 2 lines
  Complete documentation for errors argument of io's open and TextIOWrapper
........
  r62402 | mark.dickinson | 2008-04-19 22:31:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  Document updates to math and cmath modules.
........
  r62407 | georg.brandl | 2008-04-19 23:28:38 +0200 (Sat, 19 Apr 2008) | 2 lines
  Update template for newest Sphinx.
........
  r62409 | mark.dickinson | 2008-04-19 23:35:35 +0200 (Sat, 19 Apr 2008) | 5 lines
  Correct documentation for math.pow;
  0**nan is nan, not 0.  (But nan**0 and 1**nan are 1.)
  Also fix minor typo: 'quite NaN' -> 'quiet NaN'
........
  r62410 | mark.dickinson | 2008-04-19 23:49:22 +0200 (Sat, 19 Apr 2008) | 4 lines
  Move asinh documentation to the proper place.
  Remove meaningless 'in radians' from inverse
  hyperbolic functions.
........
  r62412 | mark.dickinson | 2008-04-20 03:22:30 +0200 (Sun, 20 Apr 2008) | 5 lines
  Report additional diagnostic information in
  test_math, to help track down debian-alpha
  buildbot failure.
........
  r62413 | mark.dickinson | 2008-04-20 03:39:24 +0200 (Sun, 20 Apr 2008) | 3 lines
  FreeBSD doesn't follow C99 for modf(inf); so add explicit
  special-value handling to math.modf code.
........
  r62414 | mark.dickinson | 2008-04-20 06:13:13 +0200 (Sun, 20 Apr 2008) | 5 lines
  Yet more explicit special case handling to make
  math.pow behave on alpha Tru64.  All IEEE 754
  special values are now handled directly; only
  the finite**finite case is handled by libm.
........
  r62418 | mark.dickinson | 2008-04-20 18:13:17 +0200 (Sun, 20 Apr 2008) | 7 lines
  Issue 2662: Initialize special value tables dynamically (i.e. when
  cmath module is loaded) instead of statically. This fixes compile-time
  problems on platforms where HUGE_VAL is an extern variable rather than
  a constant.
  Thanks Hirokazu Yamamoto for the patch.
........
  r62419 | andrew.kuchling | 2008-04-20 18:54:02 +0200 (Sun, 20 Apr 2008) | 1 line
  Move description of math module changes; various edits to description of cmath changes
........
											
										 
											2008-04-20 21:01:16 +00:00
										 |  |  | .. function:: asinh(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the inverse hyperbolic sine of *x*.
 | 
					
						
							| 
									
										
										
										
											2008-04-19 00:31:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 62386-62387,62389-62393,62396,62400-62402,62407,62409-62410,62412-62414,62418-62419 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r62386 | christian.heimes | 2008-04-19 04:23:57 +0200 (Sat, 19 Apr 2008) | 2 lines
  Added kill, terminate and send_signal to subprocess.Popen
  The bits and pieces for the Windows side were already in place. The POSIX side is trivial (as usual) and uses os.kill().
........
  r62387 | georg.brandl | 2008-04-19 10:23:59 +0200 (Sat, 19 Apr 2008) | 2 lines
  Fix-up docs for revision 62386.
........
  r62389 | georg.brandl | 2008-04-19 18:57:43 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2369: clarify that copyfile() doesn't take a target directory.
........
  r62390 | georg.brandl | 2008-04-19 18:58:28 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2634: clarify meaning of env parameter to spawn/exec*e.
........
  r62391 | georg.brandl | 2008-04-19 18:58:49 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2633: clarify meaning of env parameter.
........
  r62392 | georg.brandl | 2008-04-19 18:59:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  #2631: clarify IMPORT_NAME semantics.
........
  r62393 | georg.brandl | 2008-04-19 19:00:14 +0200 (Sat, 19 Apr 2008) | 2 lines
  :func: et al. should *not* include the parens.
........
  r62396 | mark.dickinson | 2008-04-19 20:51:48 +0200 (Sat, 19 Apr 2008) | 5 lines
  Additional tests for math.pow, and extra special-case
  handling code in math.pow, in the hope of making all
  tests pass on the alpha Tru64 buildbot.
........
  r62400 | mark.dickinson | 2008-04-19 21:41:52 +0200 (Sat, 19 Apr 2008) | 3 lines
  Additional special-case handling for math.pow.
  Windows/VS2008 doesn't like (-1)**(+-inf).
........
  r62401 | benjamin.peterson | 2008-04-19 21:47:34 +0200 (Sat, 19 Apr 2008) | 2 lines
  Complete documentation for errors argument of io's open and TextIOWrapper
........
  r62402 | mark.dickinson | 2008-04-19 22:31:16 +0200 (Sat, 19 Apr 2008) | 2 lines
  Document updates to math and cmath modules.
........
  r62407 | georg.brandl | 2008-04-19 23:28:38 +0200 (Sat, 19 Apr 2008) | 2 lines
  Update template for newest Sphinx.
........
  r62409 | mark.dickinson | 2008-04-19 23:35:35 +0200 (Sat, 19 Apr 2008) | 5 lines
  Correct documentation for math.pow;
  0**nan is nan, not 0.  (But nan**0 and 1**nan are 1.)
  Also fix minor typo: 'quite NaN' -> 'quiet NaN'
........
  r62410 | mark.dickinson | 2008-04-19 23:49:22 +0200 (Sat, 19 Apr 2008) | 4 lines
  Move asinh documentation to the proper place.
  Remove meaningless 'in radians' from inverse
  hyperbolic functions.
........
  r62412 | mark.dickinson | 2008-04-20 03:22:30 +0200 (Sun, 20 Apr 2008) | 5 lines
  Report additional diagnostic information in
  test_math, to help track down debian-alpha
  buildbot failure.
........
  r62413 | mark.dickinson | 2008-04-20 03:39:24 +0200 (Sun, 20 Apr 2008) | 3 lines
  FreeBSD doesn't follow C99 for modf(inf); so add explicit
  special-value handling to math.modf code.
........
  r62414 | mark.dickinson | 2008-04-20 06:13:13 +0200 (Sun, 20 Apr 2008) | 5 lines
  Yet more explicit special case handling to make
  math.pow behave on alpha Tru64.  All IEEE 754
  special values are now handled directly; only
  the finite**finite case is handled by libm.
........
  r62418 | mark.dickinson | 2008-04-20 18:13:17 +0200 (Sun, 20 Apr 2008) | 7 lines
  Issue 2662: Initialize special value tables dynamically (i.e. when
  cmath module is loaded) instead of statically. This fixes compile-time
  problems on platforms where HUGE_VAL is an extern variable rather than
  a constant.
  Thanks Hirokazu Yamamoto for the patch.
........
  r62419 | andrew.kuchling | 2008-04-20 18:54:02 +0200 (Sun, 20 Apr 2008) | 1 line
  Move description of math module changes; various edits to description of cmath changes
........
											
										 
											2008-04-20 21:01:16 +00:00
										 |  |  | .. function:: atanh(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the inverse hyperbolic tangent of *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: cosh(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the hyperbolic cosine of *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | .. function:: sinh(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the hyperbolic sine of *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: tanh(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the hyperbolic tangent of *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 00:31:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-28 19:21:11 +00:00
										 |  |  | Special functions
 | 
					
						
							|  |  |  | -----------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-19 11:20:49 +00:00
										 |  |  | .. function:: erf(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-26 19:37:12 +01:00
										 |  |  |    Return the `error function <https://en.wikipedia.org/wiki/Error_function>`_ at
 | 
					
						
							| 
									
										
										
										
											2011-03-31 12:04:53 -07:00
										 |  |  |    *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The :func:`erf` function can be used to compute traditional statistical
 | 
					
						
							|  |  |  |    functions such as the `cumulative standard normal distribution
 | 
					
						
							| 
									
										
										
										
											2024-03-13 05:19:33 +01:00
										 |  |  |    <https://en.wikipedia.org/wiki/Cumulative_distribution_function>`_::
 | 
					
						
							| 
									
										
										
										
											2011-03-31 12:04:53 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |      def phi(x):
 | 
					
						
							|  |  |  |          'Cumulative distribution function for the standard normal distribution'
 | 
					
						
							|  |  |  |          return (1.0 + erf(x / sqrt(2.0))) / 2.0
 | 
					
						
							| 
									
										
										
										
											2009-12-19 11:20:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. function:: erfc(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-31 12:04:53 -07:00
										 |  |  |    Return the complementary error function at *x*.  The `complementary error
 | 
					
						
							| 
									
										
										
										
											2016-02-26 19:37:12 +01:00
										 |  |  |    function <https://en.wikipedia.org/wiki/Error_function>`_ is defined as
 | 
					
						
							| 
									
										
										
										
											2011-03-31 13:59:24 -07:00
										 |  |  |    ``1.0 - erf(x)``.  It is used for large values of *x* where a subtraction
 | 
					
						
							|  |  |  |    from one would cause a `loss of significance
 | 
					
						
							| 
									
										
										
										
											2016-02-26 19:37:12 +01:00
										 |  |  |    <https://en.wikipedia.org/wiki/Loss_of_significance>`_\.
 | 
					
						
							| 
									
										
										
										
											2009-12-19 11:20:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-28 19:21:11 +00:00
										 |  |  | .. function:: gamma(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-26 19:37:12 +01:00
										 |  |  |    Return the `Gamma function <https://en.wikipedia.org/wiki/Gamma_function>`_ at
 | 
					
						
							| 
									
										
										
										
											2011-03-31 13:59:24 -07:00
										 |  |  |    *x*.
 | 
					
						
							| 
									
										
										
										
											2009-09-28 19:21:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:13:29 +00:00
										 |  |  |    .. versionadded:: 3.2
 | 
					
						
							| 
									
										
										
										
											2009-09-28 19:21:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-11 20:17:17 +00:00
										 |  |  | .. function:: lgamma(x)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the natural logarithm of the absolute value of the Gamma
 | 
					
						
							|  |  |  |    function at *x*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-19 11:20:49 +00:00
										 |  |  |    .. versionadded:: 3.2
 | 
					
						
							| 
									
										
										
										
											2009-12-11 20:17:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 67654,67676-67677,67681,67692,67725,67761,67784-67785,67787-67788,67802,67848-67850,67862-67864,67880,67882 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r67654 | georg.brandl | 2008-12-07 16:42:09 -0600 (Sun, 07 Dec 2008) | 2 lines
  #4457: rewrite __import__() documentation.
........
  r67676 | benjamin.peterson | 2008-12-08 20:03:03 -0600 (Mon, 08 Dec 2008) | 1 line
  specify how things are copied
........
  r67677 | benjamin.peterson | 2008-12-08 20:05:11 -0600 (Mon, 08 Dec 2008) | 1 line
  revert unrelated change to installer script
........
  r67681 | jeremy.hylton | 2008-12-09 15:03:10 -0600 (Tue, 09 Dec 2008) | 2 lines
  Add simple unittests for Request
........
  r67692 | amaury.forgeotdarc | 2008-12-10 18:03:42 -0600 (Wed, 10 Dec 2008) | 2 lines
  #1030250: correctly pass the dry_run option to the mkpath() function.
........
  r67725 | benjamin.peterson | 2008-12-12 22:02:20 -0600 (Fri, 12 Dec 2008) | 1 line
  fix incorrect example
........
  r67761 | benjamin.peterson | 2008-12-14 11:26:04 -0600 (Sun, 14 Dec 2008) | 1 line
  fix missing bracket
........
  r67784 | georg.brandl | 2008-12-15 02:33:58 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4446: document "platforms" argument for setup().
........
  r67785 | georg.brandl | 2008-12-15 02:36:11 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4611: fix typo.
........
  r67787 | georg.brandl | 2008-12-15 02:58:59 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4578: fix has_key() usage in compiler package.
........
  r67788 | georg.brandl | 2008-12-15 03:07:39 -0600 (Mon, 15 Dec 2008) | 2 lines
  #4568: remove limitation in varargs callback example.
........
  r67802 | amaury.forgeotdarc | 2008-12-15 16:29:14 -0600 (Mon, 15 Dec 2008) | 4 lines
  #3632: the "pyo" macro from gdbinit can now run when the GIL is released.
  Patch by haypo.
........
  r67848 | benjamin.peterson | 2008-12-18 20:28:56 -0600 (Thu, 18 Dec 2008) | 1 line
  fix typo
........
  r67849 | benjamin.peterson | 2008-12-18 20:31:35 -0600 (Thu, 18 Dec 2008) | 1 line
  _call_method -> _callmethod and _get_value to _getvalue
........
  r67850 | raymond.hettinger | 2008-12-19 03:06:07 -0600 (Fri, 19 Dec 2008) | 9 lines
  Fix-up and clean-up docs for int.bit_length().
  * Replace dramatic footnote with in-line comment about possible round-off errors in logarithms of large numbers.
  * Add comments to the pure python code equivalent.
  * replace floor() with int() in the mathematical equivalent so the type is correct (should be an int, not a float).
  * add abs() to the mathematical equivalent so that it matches the previous line that it is supposed to be equivalent to.
  * make one combined example with a negative input.
........
  r67862 | benjamin.peterson | 2008-12-19 20:48:02 -0600 (Fri, 19 Dec 2008) | 1 line
  copy sentence from docstring
........
  r67863 | benjamin.peterson | 2008-12-19 20:51:26 -0600 (Fri, 19 Dec 2008) | 1 line
  add headings
........
  r67864 | benjamin.peterson | 2008-12-19 20:57:19 -0600 (Fri, 19 Dec 2008) | 1 line
  beef up docstring
........
  r67880 | benjamin.peterson | 2008-12-20 16:49:24 -0600 (Sat, 20 Dec 2008) | 1 line
  remove redundant sentence
........
  r67882 | benjamin.peterson | 2008-12-20 16:59:49 -0600 (Sat, 20 Dec 2008) | 1 line
  add some recent releases to the list
........
											
										 
											2008-12-21 00:06:59 +00:00
										 |  |  | Constants
 | 
					
						
							| 
									
										
										
										
											2009-06-02 12:53:15 +00:00
										 |  |  | ---------
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. data:: pi
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  |    The mathematical constant *π* = 3.141592..., to available precision.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: e
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  |    The mathematical constant *e* = 2.718281..., to available precision.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-15 09:12:52 -07:00
										 |  |  | .. data:: tau
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  |    The mathematical constant *τ* = 6.283185..., to available precision.
 | 
					
						
							|  |  |  |    Tau is a circle constant equal to 2\ *π*, the ratio of a circle's circumference to
 | 
					
						
							| 
									
										
										
										
											2016-08-15 09:12:52 -07:00
										 |  |  |    its radius. To learn more about Tau, check out Vi Hart's video `Pi is (still)
 | 
					
						
							|  |  |  |    Wrong <https://www.youtube.com/watch?v=jG7vhMMXagQ>`_, and start celebrating
 | 
					
						
							| 
									
										
										
										
											2018-01-20 05:55:37 +05:30
										 |  |  |    `Tau day <https://tauday.com/>`_ by eating twice as much pie!
 | 
					
						
							| 
									
										
										
										
											2008-04-19 00:31:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-16 07:08:46 +02:00
										 |  |  |    .. versionadded:: 3.6
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-04 12:25:09 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-11 11:55:29 +00:00
										 |  |  | .. data:: inf
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A floating-point positive infinity.  (For negative infinity, use
 | 
					
						
							|  |  |  |    ``-math.inf``.)  Equivalent to the output of ``float('inf')``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.5
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: nan
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-03 03:58:03 +08:00
										 |  |  |    A floating-point "not a number" (NaN) value. Equivalent to the output of
 | 
					
						
							|  |  |  |    ``float('nan')``. Due to the requirements of the `IEEE-754 standard
 | 
					
						
							|  |  |  |    <https://en.wikipedia.org/wiki/IEEE_754>`_, ``math.nan`` and ``float('nan')`` are
 | 
					
						
							|  |  |  |    not considered to equal to any other numeric value, including themselves. To check
 | 
					
						
							|  |  |  |    whether a number is a NaN, use the :func:`isnan` function to test
 | 
					
						
							|  |  |  |    for NaNs instead of ``is`` or ``==``.
 | 
					
						
							| 
									
										
										
										
											2022-07-30 17:21:08 -05:00
										 |  |  |    Example:
 | 
					
						
							| 
									
										
										
										
											2022-04-03 03:58:03 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       >>> import math
 | 
					
						
							|  |  |  |       >>> math.nan == math.nan
 | 
					
						
							|  |  |  |       False
 | 
					
						
							|  |  |  |       >>> float('nan') == float('nan')
 | 
					
						
							|  |  |  |       False
 | 
					
						
							|  |  |  |       >>> math.isnan(math.nan)
 | 
					
						
							|  |  |  |       True
 | 
					
						
							|  |  |  |       >>> math.isnan(float('nan'))
 | 
					
						
							|  |  |  |       True
 | 
					
						
							| 
									
										
										
										
											2015-01-11 11:55:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-19 12:54:54 -05:00
										 |  |  |    .. versionadded:: 3.5
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-10 17:47:18 +01:00
										 |  |  |    .. versionchanged:: 3.11
 | 
					
						
							|  |  |  |       It is now always available.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-11 11:55:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 75365,75394,75402-75403,75418,75459,75484,75592-75596,75600,75602-75607,75610-75613,75616-75617,75623,75627,75640,75647,75696,75795 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r75365 | georg.brandl | 2009-10-11 22:16:16 +0200 (So, 11 Okt 2009) | 1 line
  Fix broken links found by "make linkcheck".  scipy.org seems to be done right now, so I could not verify links going there.
........
  r75394 | georg.brandl | 2009-10-13 20:10:59 +0200 (Di, 13 Okt 2009) | 1 line
  Fix markup.
........
  r75402 | georg.brandl | 2009-10-14 17:51:48 +0200 (Mi, 14 Okt 2009) | 1 line
  #7125: fix typo.
........
  r75403 | georg.brandl | 2009-10-14 17:57:46 +0200 (Mi, 14 Okt 2009) | 1 line
  #7126: os.environ changes *do* take effect in subprocesses started with os.system().
........
  r75418 | georg.brandl | 2009-10-14 20:48:32 +0200 (Mi, 14 Okt 2009) | 1 line
  #7116: str.join() takes an iterable.
........
  r75459 | georg.brandl | 2009-10-17 10:57:43 +0200 (Sa, 17 Okt 2009) | 1 line
  Fix refleaks in _ctypes PyCSimpleType_New, which fixes the refleak seen in test___all__.
........
  r75484 | georg.brandl | 2009-10-18 09:58:12 +0200 (So, 18 Okt 2009) | 1 line
  Fix missing word.
........
  r75592 | georg.brandl | 2009-10-22 09:05:48 +0200 (Do, 22 Okt 2009) | 1 line
  Fix punctuation.
........
  r75593 | georg.brandl | 2009-10-22 09:06:49 +0200 (Do, 22 Okt 2009) | 1 line
  Revert unintended change.
........
  r75594 | georg.brandl | 2009-10-22 09:56:02 +0200 (Do, 22 Okt 2009) | 1 line
  Fix markup.
........
  r75595 | georg.brandl | 2009-10-22 09:56:56 +0200 (Do, 22 Okt 2009) | 1 line
  Fix duplicate target.
........
  r75596 | georg.brandl | 2009-10-22 10:05:04 +0200 (Do, 22 Okt 2009) | 1 line
  Add a new directive marking up implementation details and start using it.
........
  r75600 | georg.brandl | 2009-10-22 13:01:46 +0200 (Do, 22 Okt 2009) | 1 line
  Make it more robust.
........
  r75602 | georg.brandl | 2009-10-22 13:28:06 +0200 (Do, 22 Okt 2009) | 1 line
  Document new directive.
........
  r75603 | georg.brandl | 2009-10-22 13:28:23 +0200 (Do, 22 Okt 2009) | 1 line
  Allow short form with text as argument.
........
  r75604 | georg.brandl | 2009-10-22 13:36:50 +0200 (Do, 22 Okt 2009) | 1 line
  Fix stylesheet for multi-paragraph impl-details.
........
  r75605 | georg.brandl | 2009-10-22 13:48:10 +0200 (Do, 22 Okt 2009) | 1 line
  Use "impl-detail" directive where applicable.
........
  r75606 | georg.brandl | 2009-10-22 17:00:06 +0200 (Do, 22 Okt 2009) | 1 line
  #6324: membership test tries iteration via __iter__.
........
  r75607 | georg.brandl | 2009-10-22 17:04:09 +0200 (Do, 22 Okt 2009) | 1 line
  #7088: document new functions in signal as Unix-only.
........
  r75610 | georg.brandl | 2009-10-22 17:27:24 +0200 (Do, 22 Okt 2009) | 1 line
  Reorder __slots__ fine print and add a clarification.
........
  r75611 | georg.brandl | 2009-10-22 17:42:32 +0200 (Do, 22 Okt 2009) | 1 line
  #7035: improve docs of the various <method>_errors() functions, and give them docstrings.
........
  r75612 | georg.brandl | 2009-10-22 17:52:15 +0200 (Do, 22 Okt 2009) | 1 line
  #7156: document curses as Unix-only.
........
  r75613 | georg.brandl | 2009-10-22 17:54:35 +0200 (Do, 22 Okt 2009) | 1 line
  #6977: getopt does not support optional option arguments.
........
  r75616 | georg.brandl | 2009-10-22 18:17:05 +0200 (Do, 22 Okt 2009) | 1 line
  Add proper references.
........
  r75617 | georg.brandl | 2009-10-22 18:20:55 +0200 (Do, 22 Okt 2009) | 1 line
  Make printout margin important.
........
  r75623 | georg.brandl | 2009-10-23 10:14:44 +0200 (Fr, 23 Okt 2009) | 1 line
  #7188: fix optionxform() docs.
........
  r75627 | fred.drake | 2009-10-23 15:04:51 +0200 (Fr, 23 Okt 2009) | 2 lines
  add further note about what's passed to optionxform
........
  r75640 | neil.schemenauer | 2009-10-23 21:58:17 +0200 (Fr, 23 Okt 2009) | 2 lines
  Improve some docstrings in the 'warnings' module.
........
  r75647 | georg.brandl | 2009-10-24 12:04:19 +0200 (Sa, 24 Okt 2009) | 1 line
  Fix markup.
........
  r75696 | georg.brandl | 2009-10-25 21:25:43 +0100 (So, 25 Okt 2009) | 1 line
  Fix a demo.
........
  r75795 | georg.brandl | 2009-10-27 16:10:22 +0100 (Di, 27 Okt 2009) | 1 line
  Fix a strange mis-edit.
........
											
										 
											2009-10-27 15:28:25 +00:00
										 |  |  | .. impl-detail::
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    The :mod:`math` module consists mostly of thin wrappers around the platform C
 | 
					
						
							| 
									
										
										
										
											2010-04-06 19:55:03 +00:00
										 |  |  |    math library functions.  Behavior in exceptional cases follows Annex F of
 | 
					
						
							|  |  |  |    the C99 standard where appropriate.  The current implementation will raise
 | 
					
						
							|  |  |  |    :exc:`ValueError` for invalid operations like ``sqrt(-1.0)`` or ``log(0.0)``
 | 
					
						
							|  |  |  |    (where C99 Annex F recommends signaling invalid operation or divide-by-zero),
 | 
					
						
							|  |  |  |    and :exc:`OverflowError` for results that overflow (for example,
 | 
					
						
							| 
									
										
											  
											
												Merged revisions 79307,79408,79430,79533,79542,79579-79580,79585-79587,79607-79608,79622,79717,79820,79822,79828,79862,79875,79923-79924,79941-79943,79945,79947,79951-79952 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r79307 | florent.xicluna | 2010-03-22 17:45:50 -0500 (Mon, 22 Mar 2010) | 2 lines
  #7667: Fix doctest failures with non-ASCII paths.
........
  r79408 | victor.stinner | 2010-03-24 20:18:38 -0500 (Wed, 24 Mar 2010) | 2 lines
  Fix a gcc warning introduced by r79397.
........
  r79430 | brian.curtin | 2010-03-25 18:48:54 -0500 (Thu, 25 Mar 2010) | 2 lines
  Fix #6538. Markup RegexObject and MatchObject as classes. Patch by Ryan Arana.
........
  r79533 | barry.warsaw | 2010-03-31 16:07:16 -0500 (Wed, 31 Mar 2010) | 6 lines
  - Issue #8233: When run as a script, py_compile.py optionally takes a single
    argument `-` which tells it to read files to compile from stdin.  Each line
    is read on demand and the named file is compiled immediately.  (Original
    patch by Piotr O?\197?\188arowski).
........
  r79542 | r.david.murray | 2010-03-31 20:28:39 -0500 (Wed, 31 Mar 2010) | 3 lines
  A couple small grammar fixes in test.rst, and rewrite the
  check_warnings docs to be clearer.
........
  r79579 | georg.brandl | 2010-04-02 03:34:41 -0500 (Fri, 02 Apr 2010) | 1 line
  Add 2.6.5.
........
  r79580 | georg.brandl | 2010-04-02 03:39:09 -0500 (Fri, 02 Apr 2010) | 1 line
  #2768: add a note on how to get a file descriptor.
........
  r79585 | georg.brandl | 2010-04-02 04:03:18 -0500 (Fri, 02 Apr 2010) | 1 line
  Remove col-spanning cells in logging docs.
........
  r79586 | georg.brandl | 2010-04-02 04:07:42 -0500 (Fri, 02 Apr 2010) | 1 line
  Document PyImport_ExecCodeModuleEx().
........
  r79587 | georg.brandl | 2010-04-02 04:11:49 -0500 (Fri, 02 Apr 2010) | 1 line
  #8012: clarification in generator glossary entry.
........
  r79607 | andrew.kuchling | 2010-04-02 12:48:23 -0500 (Fri, 02 Apr 2010) | 1 line
  #6647: document that catch_warnings is not thread-safe
........
  r79608 | andrew.kuchling | 2010-04-02 12:54:26 -0500 (Fri, 02 Apr 2010) | 1 line
  #6647: add note to two examples
........
  r79622 | tarek.ziade | 2010-04-02 16:34:19 -0500 (Fri, 02 Apr 2010) | 1 line
  removed documentation on code that was reverted and pushed into distutils2
........
  r79717 | antoine.pitrou | 2010-04-03 16:22:38 -0500 (Sat, 03 Apr 2010) | 4 lines
  Fix wording / typography, and a slightly misleading statement
  (memoryviews don't support complex structures right now)
........
  r79820 | benjamin.peterson | 2010-04-05 22:34:09 -0500 (Mon, 05 Apr 2010) | 1 line
  ready _sre types
........
  r79822 | georg.brandl | 2010-04-06 03:18:15 -0500 (Tue, 06 Apr 2010) | 1 line
  #8320: document return value of recv_into().
........
  r79828 | georg.brandl | 2010-04-06 09:33:44 -0500 (Tue, 06 Apr 2010) | 1 line
  Add JP.
........
  r79862 | georg.brandl | 2010-04-06 15:27:59 -0500 (Tue, 06 Apr 2010) | 1 line
  Fix syntax.
........
  r79875 | mark.dickinson | 2010-04-06 17:18:23 -0500 (Tue, 06 Apr 2010) | 1 line
  More NaN consistency doc fixes.
........
  r79923 | georg.brandl | 2010-04-10 06:15:24 -0500 (Sat, 10 Apr 2010) | 1 line
  #8360: skipTest was added in 2.7.
........
  r79924 | georg.brandl | 2010-04-10 06:16:59 -0500 (Sat, 10 Apr 2010) | 1 line
  #8346: update version.
........
  r79941 | andrew.kuchling | 2010-04-10 20:39:36 -0500 (Sat, 10 Apr 2010) | 1 line
  Two grammar fixes
........
  r79942 | andrew.kuchling | 2010-04-10 20:40:06 -0500 (Sat, 10 Apr 2010) | 1 line
  Punctuation fix
........
  r79943 | andrew.kuchling | 2010-04-10 20:40:30 -0500 (Sat, 10 Apr 2010) | 1 line
  Add various items
........
  r79945 | andrew.kuchling | 2010-04-10 20:40:49 -0500 (Sat, 10 Apr 2010) | 1 line
  name correct
........
  r79947 | andrew.kuchling | 2010-04-10 20:44:13 -0500 (Sat, 10 Apr 2010) | 1 line
  Remove distutils section
........
  r79951 | andrew.kuchling | 2010-04-11 07:48:08 -0500 (Sun, 11 Apr 2010) | 1 line
  Two typo fixes
........
  r79952 | andrew.kuchling | 2010-04-11 07:49:37 -0500 (Sun, 11 Apr 2010) | 1 line
  Add two items
........
											
										 
											2010-04-11 16:12:57 +00:00
										 |  |  |    ``exp(1000.0)``).  A NaN will not be returned from any of the functions
 | 
					
						
							|  |  |  |    above unless one or more of the input arguments was a NaN; in that case,
 | 
					
						
							|  |  |  |    most functions will return a NaN, but (again following C99 Annex F) there
 | 
					
						
							| 
									
										
										
										
											2010-04-06 19:55:03 +00:00
										 |  |  |    are some exceptions to this rule, for example ``pow(float('nan'), 0.0)`` or
 | 
					
						
							|  |  |  |    ``hypot(float('nan'), float('inf'))``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 22:13:37 +00:00
										 |  |  |    Note that Python makes no effort to distinguish signaling NaNs from
 | 
					
						
							|  |  |  |    quiet NaNs, and behavior for signaling NaNs remains unspecified.
 | 
					
						
							|  |  |  |    Typical behavior is to treat all NaNs as though they were quiet.
 | 
					
						
							| 
									
										
										
										
											2008-04-19 00:31:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. seealso::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Module :mod:`cmath`
 | 
					
						
							|  |  |  |       Complex number versions of many of these functions.
 | 
					
						
							| 
									
										
										
										
											2019-05-18 12:29:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. |nbsp| unicode:: 0xA0
 | 
					
						
							|  |  |  |    :trim: |