scipy.interpolate.LSQUnivariateSpline.
原函数#
- LSQUnivariateSpline.antiderivative(n=1)[源代码]#
构造一个新的样条,表示此样条的原函数。
- 参数:
- nint,可选
要评估的原函数的阶数。默认值:1
- 返回:
- splineUnivariateSpline
阶数为 k2=k+n 的样条,表示此样条的原函数。
另请参阅
注释
在版本 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