This is a pre-release version (latest). Go to latest (2.4.4)
{ } Raw JSON

bundles / numpy latest / docs

Doc

Polynomials

docs/reference:routines.polynomials

Polynomials in NumPy can be created, manipulated, and even fitted using the convenience classes of the numpy.polynomial package, introduced in NumPy 1.4.

Prior to NumPy 1.4, numpy.poly1d was the class of choice and it is still available in order to maintain backward compatibility. However, the newer polynomial package <numpy.polynomial> is more complete and its convenience classes <routines.polynomials.classes> provide a more consistent, better-behaved interface for working with polynomial expressions. Therefore numpy.polynomial is recommended for new coding.

Transitioning from numpy.poly1d to numpy.polynomial

As noted above, the poly1d class <numpy.poly1d> and associated functions defined in numpy.lib.polynomial, such as numpy.polyfit and numpy.poly, are considered legacy and should not be used in new code. Since NumPy version 1.4, the numpy.polynomial package is preferred for working with polynomials.

Quick Reference

The following table highlights some of the main differences between the legacy polynomial module and the polynomial package for common tasks. The Polynomial class is imported for brevity

from numpy.polynomial import Polynomial
+------------------------+----------------------------------------+---------------------------------------+
|  **How to...**         | Legacy (`numpy.poly1d`)                | `numpy.polynomial`                    |
+------------------------+----------------------------------------+---------------------------------------+
| Create a               | ``p = np.poly1d([1, 2, 3])``           | ``p = Polynomial([3, 2, 1])``         |
| polynomial object      |                                        |                                       |
| from coefficients [1]_ |                                        |                                       |
+------------------------+----------------------------------------+---------------------------------------+
| Create a polynomial    | ``r = np.poly([-1, 1])``               | ``p = Polynomial.fromroots([-1, 1])`` |
| object from roots      | ``p = np.poly1d(r)``                   |                                       |
+------------------------+----------------------------------------+---------------------------------------+
| Fit a polynomial of    |                                        |                                       |
| degree ``deg`` to data | ``np.polyfit(x, y, deg)``              | ``Polynomial.fit(x, y, deg)``         |
+------------------------+----------------------------------------+---------------------------------------+
| Evaluate a polynomial  | ``p(2.0)`` or                          | ``p(2.0)`` or ``polyval(2.0, p.coef)``|
| at a point [2]_        | ``np.polyval([1, 2, 3], 2.0)``         | (use ``p.convert().coef`` after fit)  |
+------------------------+----------------------------------------+---------------------------------------+
[1]

Note the reversed ordering of the coefficients

[2]

When evaluating polynomials created with fit(), use p(x) or polyval(x, p.convert().coef) to handle domain/window scaling correctly.

Transition Guide

There are significant differences between numpy.lib.polynomial and numpy.polynomial. The most significant difference is the ordering of the coefficients for the polynomial expressions. The various routines in numpy.polynomial all deal with series whose coefficients go from degree zero upward, which is the reverse order of the poly1d convention. The easy way to remember this is that indices correspond to degree, i.e., coef[i] is the coefficient of the term of degree i.

Though the difference in convention may be confusing, it is straightforward to convert from the legacy polynomial API to the new. For example, the following demonstrates how you would convert a numpy.poly1d instance representing the expression to a Polynomial instance representing the same expression:

See the documentation for the convenience classes <routines.polynomials.classes> for further details on the domain and window attributes.

Another major difference between the legacy polynomial module and the polynomial package is polynomial fitting. In the old module, fitting was done via the polyfit function. In the polynomial package, the fit class method is preferred. For example, consider a simple linear fit to the following data:

With the legacy polynomial module, a linear fit (i.e. polynomial of degree 1) could be applied to these data with polyfit:

With the new polynomial API, the fit class method is preferred:

Note that the coefficients are given in the scaled domain defined by the linear mapping between the window and domain. convert can be used to get the coefficients in the unscaled data domain.

Documentation for the ~numpy.polynomial package

In addition to standard power series polynomials, the polynomial package provides several additional kinds of polynomials including Chebyshev, Hermite (two subtypes), Laguerre, and Legendre polynomials. Each of these has an associated convenience class <routines.polynomials.classes> available from the numpy.polynomial namespace that provides a consistent interface for working with polynomials regardless of their type.

Documentation pertaining to specific functions defined for each kind of polynomial individually can be found in the corresponding module documentation:

Documentation for legacy polynomials