scipy.interpolate.NdPPoly#
- class scipy.interpolate.NdPPoly(c, x, extrapolate=None)[source]#
- Piecewise tensor product polynomial - The value at point - xp = (x', y', z', ...)is evaluated by first computing the interval indices i such that:- x[0][i[0]] <= x' < x[0][i[0]+1] x[1][i[1]] <= y' < x[1][i[1]+1] ... - and then computing: - S = sum(c[k0-m0-1,...,kn-mn-1,i[0],...,i[n]] * (xp[0] - x[0][i[0]])**m0 * ... * (xp[n] - x[n][i[n]])**mn for m0 in range(k[0]+1) ... for mn in range(k[n]+1)) - where - k[j]is the degree of the polynomial in dimension j. This representation is the piecewise multivariate power basis.- Parameters
- cndarray, shape (k0, …, kn, m0, …, mn, …)
- Polynomial coefficients, with polynomial order kj and mj+1 intervals for each dimension j. 
- xndim-tuple of ndarrays, shapes (mj+1,)
- Polynomial breakpoints for each dimension. These must be sorted in increasing order. 
- extrapolatebool, optional
- Whether to extrapolate to out-of-bounds points based on first and last intervals, or to return NaNs. Default: True. 
 
 - See also - PPoly
- piecewise polynomials in 1D 
 - Notes - High-order polynomials in the power basis can be numerically unstable. - Attributes
- xtuple of ndarrays
- Breakpoints. 
- cndarray
- Coefficients of the polynomials. 
 
 - Methods - __call__(x[, nu, extrapolate])- Evaluate the piecewise polynomial or its derivative - derivative(nu)- Construct a new piecewise polynomial representing the derivative. - antiderivative(nu)- Construct a new piecewise polynomial representing the antiderivative. - integrate(ranges[, extrapolate])- Compute a definite integral over a piecewise polynomial. - integrate_1d(a, b, axis[, extrapolate])- Compute NdPPoly representation for one dimensional definite integral - construct_fast(c, x[, extrapolate])- Construct the piecewise polynomial without making checks.