scipy.interpolate.LSQUnivariateSpline.

原函数#

LSQUnivariateSpline.antiderivative(n=1)[源代码]#

构造一个新的样条,表示此样条的原函数。

参数:
nint,可选

要评估的原函数的阶数。默认值:1

返回:
splineUnivariateSpline

阶数为 k2=k+n 的样条,表示此样条的原函数。

另请参阅

splantider, derivative

注释

在版本 0.13.0 中添加。

示例

>>> import numpy as np
>>> from scipy.interpolate import UnivariateSpline
>>> x = np.linspace(0, np.pi/2, 70)
>>> y = 1 / np.sqrt(1 - 0.8*np.sin(x)**2)
>>> spl = UnivariateSpline(x, y, s=0)

导数是原函数的逆运算,尽管会累积一些浮点误差

>>> spl(1.7), spl.antiderivative().derivative()(1.7)
(array(2.1565429877197317), array(2.1565429877201865))

原函数可用于评估定积分

>>> ispl = spl.antiderivative()
>>> ispl(np.pi/2) - ispl(0)
2.2572053588768486

这确实是对完全椭圆积分 \(K(m) = \int_0^{\pi/2} [1 - m\sin^2 x]^{-1/2} dx\) 的近似

>>> from scipy.special import ellipk
>>> ellipk(0.8)
2.2572053268208538